diff options
Diffstat (limited to 'apps/dav/lib/CalDAV')
-rw-r--r-- | apps/dav/lib/CalDAV/CalDavBackend.php | 5 | ||||
-rw-r--r-- | apps/dav/lib/CalDAV/Publishing/PublishPlugin.php | 45 | ||||
-rw-r--r-- | apps/dav/lib/CalDAV/Publishing/Xml/Publisher.php | 15 |
3 files changed, 39 insertions, 26 deletions
diff --git a/apps/dav/lib/CalDAV/CalDavBackend.php b/apps/dav/lib/CalDAV/CalDavBackend.php index ed311fa0ded..43466b235e5 100644 --- a/apps/dav/lib/CalDAV/CalDavBackend.php +++ b/apps/dav/lib/CalDAV/CalDavBackend.php @@ -66,6 +66,7 @@ class CalDavBackend extends AbstractBackend implements SyncSupport, Subscription */ const MAX_DATE = '2038-01-01'; + const ACCESS_PUBLIC = 4; const CLASSIFICATION_PUBLIC = 0; const CLASSIFICATION_PRIVATE = 1; const CLASSIFICATION_CONFIDENTIAL = 2; @@ -1483,13 +1484,13 @@ class CalDavBackend extends AbstractBackend implements SyncSupport, Subscription ->values([ 'principaluri' => $query->createNamedParameter($calendar->getPrincipalURI()), 'type' => $query->createNamedParameter('calendar'), - 'access' => $query->createNamedParameter(self::CLASSIFICATION_PUBLIC), + 'access' => $query->createNamedParameter(self::ACCESS_PUBLIC), 'resourceid' => $query->createNamedParameter($calendar->getResourceId()) ]); } else { $query->delete('dav_shares') ->Where($query->expr()->eq('resourceid', $query->createNamedParameter($calendar->getResourceId()))) - ->andWhere($query->expr()->eq('access', $query->createNamedParameter(self::CLASSIFICATION_PUBLIC))); + ->andWhere($query->expr()->eq('access', $query->createNamedParameter(self::ACCESS_PUBLIC))); } $query->execute(); } diff --git a/apps/dav/lib/CalDAV/Publishing/PublishPlugin.php b/apps/dav/lib/CalDAV/Publishing/PublishPlugin.php index e6a5f0eb32b..b1c42624201 100644 --- a/apps/dav/lib/CalDAV/Publishing/PublishPlugin.php +++ b/apps/dav/lib/CalDAV/Publishing/PublishPlugin.php @@ -6,13 +6,12 @@ namespace OCA\DAV\CalDAV\Publishing; use Sabre\DAV\PropFind; use Sabre\DAV\INode; -use OCP\IRequest; -use Sabre\CalDAV\IShareableCalendar; use Sabre\DAV\Server; use Sabre\DAV\ServerPlugin; use Sabre\HTTP\RequestInterface; use Sabre\HTTP\ResponseInterface; use OCA\DAV\CalDAV\Publishing\Xml\Publisher; +use OCA\DAV\CalDAV\Calendar; class PublishPlugin extends ServerPlugin { @@ -70,36 +69,42 @@ class PublishPlugin extends ServerPlugin $this->server->on('propFind', [$this, 'propFind']); } - function propFind(PropFind $propFind, INode $node) { - if ($node instanceof IShareableCalendar) { - $token = md5(\OC::$server->getConfig()->getSystemValue('secret','') . $node->getName()); - // $propFind->handle('{' . self::NS_CALENDARSERVER . '}publish-url', function() use ($node, $token) { - // return new Publisher($token); - // }); + public function propFind(PropFind $propFind, INode $node) + { + if ($node instanceof Calendar) { + $token = md5(\OC::$server->getConfig()->getSystemValue('secret', '').$node->getName()); - $propFind->handle('{' . self::NS_CALENDARSERVER . '}pre-publish-url', function() use ($node, $token) { + $propFind->handle('{'.self::NS_CALENDARSERVER.'}publish-url', function () use ($node, $token) { if ($node->getPublishStatus()) { - return new Publisher($token); + return new Publisher($token, $node->getPublishStatus()); } }); + + $propFind->handle('{'.self::NS_CALENDARSERVER.'}pre-publish-url', function () use ($node, $token) { + if ($node->getPublishStatus()) { + return new Publisher($token, false); + } + }); + } } - } /** * We intercept this to handle POST requests on calendars. * * @param RequestInterface $request * @param ResponseInterface $response + * * @return null|bool */ - function httpPost(RequestInterface $request, ResponseInterface $response) { - + public function httpPost(RequestInterface $request, ResponseInterface $response) + { $path = $request->getPath(); // Only handling xml $contentType = $request->getHeader('Content-Type'); - if (strpos($contentType, 'application/xml') === false && strpos($contentType, 'text/xml') === false) + if (strpos($contentType, 'application/xml') === false && strpos($contentType, 'text/xml') === false) { return; + } // Making sure the node exists try { @@ -123,11 +128,10 @@ class PublishPlugin extends ServerPlugin switch ($documentType) { - - case '{' . self::NS_CALENDARSERVER . '}publish-calendar' : + case '{'.self::NS_CALENDARSERVER.'}publish-calendar' : // We can only deal with IShareableCalendar objects - if (!$node instanceof IShareableCalendar) { + if (!$node instanceof Calendar) { return; } $this->server->transactionType = 'post-publish-calendar'; @@ -152,10 +156,10 @@ class PublishPlugin extends ServerPlugin // Breaking the event chain return false; - case '{' . self::NS_CALENDARSERVER . '}unpublish-calendar' : + case '{'.self::NS_CALENDARSERVER.'}unpublish-calendar' : // We can only deal with IShareableCalendar objects - if (!$node instanceof IShareableCalendar) { + if (!$node instanceof Calendar) { return; } $this->server->transactionType = 'post-unpublish-calendar'; @@ -180,8 +184,5 @@ class PublishPlugin extends ServerPlugin return false; } - - - } } diff --git a/apps/dav/lib/CalDAV/Publishing/Xml/Publisher.php b/apps/dav/lib/CalDAV/Publishing/Xml/Publisher.php index 597652d0ef1..008b5df9125 100644 --- a/apps/dav/lib/CalDAV/Publishing/Xml/Publisher.php +++ b/apps/dav/lib/CalDAV/Publishing/Xml/Publisher.php @@ -14,10 +14,17 @@ class Publisher implements XmlSerializable { protected $publishUrl; /** + * @var $isPublished + */ + protected $isPublished; + + /** * @param str $publishUrl + * @param boolean $isPublished */ - function __construct($publishUrl) { + function __construct($publishUrl, $isPublished) { $this->publishUrl = $publishUrl; + $this->isPublished = $isPublished; } /** @@ -49,7 +56,11 @@ class Publisher implements XmlSerializable { function xmlSerialize(Writer $writer) { $cs = '{' . Plugin::NS_CALENDARSERVER . '}'; - $writer->write($this->publishUrl); + if (!$this->isPublished) { + $writer->write($this->publishUrl); + } else { + $writer->writeElement('{DAV:}href', $this->publishUrl); + } } } |