summaryrefslogtreecommitdiffstats
path: root/apps
diff options
context:
space:
mode:
Diffstat (limited to 'apps')
-rw-r--r--apps/dav/lib/CalDAV/Schedule/Plugin.php27
1 files changed, 16 insertions, 11 deletions
diff --git a/apps/dav/lib/CalDAV/Schedule/Plugin.php b/apps/dav/lib/CalDAV/Schedule/Plugin.php
index 1b262efd4f5..afdd473aee8 100644
--- a/apps/dav/lib/CalDAV/Schedule/Plugin.php
+++ b/apps/dav/lib/CalDAV/Schedule/Plugin.php
@@ -27,6 +27,7 @@ namespace OCA\DAV\CalDAV\Schedule;
use OCA\DAV\CalDAV\CalDavBackend;
use OCA\DAV\CalDAV\CalendarHome;
use Sabre\DAV\INode;
+use Sabre\DAV\IProperties;
use Sabre\DAV\PropFind;
use Sabre\DAV\Server;
use Sabre\DAV\Xml\Property\LocalHref;
@@ -55,19 +56,23 @@ class Plugin extends \Sabre\CalDAV\Schedule\Plugin {
* @return void
*/
function propFind(PropFind $propFind, INode $node) {
- // overwrite Sabre/Dav's implementation
- $propFind->handle('{' . self::NS_CALDAV . '}calendar-user-type', function() use ($node) {
- $calendarUserType = '{' . self::NS_CALDAV . '}calendar-user-type';
- $props = $node->getProperties([$calendarUserType]);
-
- if (isset($props[$calendarUserType])) {
- return $props[$calendarUserType];
- }
+ parent::propFind($propFind, $node);
- return 'INDIVIDUAL';
- });
+ if ($node instanceof IPrincipal) {
+ // overwrite Sabre/Dav's implementation
+ $propFind->handle('{' . self::NS_CALDAV . '}calendar-user-type', function () use ($node) {
+ if ($node instanceof IProperties) {
+ $calendarUserType = '{' . self::NS_CALDAV . '}calendar-user-type';
+ $props = $node->getProperties([$calendarUserType]);
+
+ if (isset($props[$calendarUserType])) {
+ return $props[$calendarUserType];
+ }
+ }
- parent::propFind($propFind, $node);
+ return 'INDIVIDUAL';
+ });
+ }
}
/**