aboutsummaryrefslogtreecommitdiffstats
path: root/apps/dav/lib/CalDAV
diff options
context:
space:
mode:
Diffstat (limited to 'apps/dav/lib/CalDAV')
-rw-r--r--apps/dav/lib/CalDAV/CalDavBackend.php5
-rw-r--r--apps/dav/lib/CalDAV/Publishing/PublishPlugin.php45
-rw-r--r--apps/dav/lib/CalDAV/Publishing/Xml/Publisher.php15
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);
+ }
}
}