2015-10-21 13:06:48 +00:00
|
|
|
<?php
|
|
|
|
|
|
|
|
namespace OCA\DAV;
|
|
|
|
|
|
|
|
use OCA\DAV\Connector\Sabre\Auth;
|
|
|
|
use OCA\DAV\Connector\Sabre\BlockLegacyClientPlugin;
|
|
|
|
use OCA\DAV\Files\CustomPropertiesBackend;
|
|
|
|
use OCP\IRequest;
|
|
|
|
use Sabre\DAV\Auth\Plugin;
|
|
|
|
use Sabre\HTTP\Util;
|
|
|
|
|
|
|
|
class Server {
|
|
|
|
|
|
|
|
/** @var IRequest */
|
|
|
|
private $request;
|
|
|
|
|
|
|
|
public function __construct(IRequest $request, $baseUri) {
|
|
|
|
$this->request = $request;
|
|
|
|
$this->baseUri = $baseUri;
|
2015-11-16 15:09:04 +00:00
|
|
|
$logger = \OC::$server->getLogger();
|
|
|
|
$dispatcher = \OC::$server->getEventDispatcher();
|
|
|
|
|
2015-10-21 13:06:48 +00:00
|
|
|
$root = new RootCollection();
|
|
|
|
$this->server = new \OCA\DAV\Connector\Sabre\Server($root);
|
|
|
|
|
|
|
|
// Backends
|
2015-10-26 12:02:10 +00:00
|
|
|
$authBackend = new Auth(
|
|
|
|
\OC::$server->getSession(),
|
|
|
|
\OC::$server->getUserSession()
|
|
|
|
);
|
2015-10-21 13:06:48 +00:00
|
|
|
|
|
|
|
// Set URL explicitly due to reverse-proxy situations
|
|
|
|
$this->server->httpRequest->setUrl($this->request->getRequestUri());
|
|
|
|
$this->server->setBaseUri($this->baseUri);
|
|
|
|
|
|
|
|
$this->server->addPlugin(new BlockLegacyClientPlugin(\OC::$server->getConfig()));
|
|
|
|
$this->server->addPlugin(new Plugin($authBackend, 'ownCloud'));
|
2015-11-16 15:09:04 +00:00
|
|
|
$this->server->addPlugin(new \OCA\DAV\Connector\Sabre\DummyGetResponsePlugin());
|
|
|
|
$this->server->addPlugin(new \OCA\DAV\Connector\Sabre\ExceptionLoggerPlugin('webdav', $logger));
|
|
|
|
$this->server->addPlugin(new \OCA\DAV\Connector\Sabre\LockPlugin());
|
|
|
|
$this->server->addPlugin(new \OCA\DAV\Connector\Sabre\ListenerPlugin($dispatcher));
|
2015-11-23 12:53:57 +00:00
|
|
|
$this->server->addPlugin(new \Sabre\DAV\Sync\Plugin());
|
2015-10-21 13:06:48 +00:00
|
|
|
|
2015-11-24 10:15:31 +00:00
|
|
|
// acl
|
|
|
|
$acl = new \Sabre\DAVACL\Plugin();
|
|
|
|
$acl->defaultUsernamePath = 'principals/users';
|
|
|
|
$this->server->addPlugin($acl);
|
|
|
|
|
2015-10-31 00:28:21 +00:00
|
|
|
// calendar plugins
|
|
|
|
$this->server->addPlugin(new \Sabre\CalDAV\Plugin());
|
|
|
|
$this->server->addPlugin(new \Sabre\CalDAV\ICSExportPlugin());
|
|
|
|
$senderEmail = \OCP\Util::getDefaultEmailAddress('no-reply');
|
|
|
|
$this->server->addPlugin(new \Sabre\CalDAV\Schedule\Plugin());
|
|
|
|
$this->server->addPlugin(new \Sabre\CalDAV\Schedule\IMipPlugin($senderEmail));
|
|
|
|
$this->server->addPlugin(new \Sabre\CalDAV\SharingPlugin());
|
|
|
|
$this->server->addPlugin(new \Sabre\CalDAV\Subscriptions\Plugin());
|
|
|
|
$this->server->addPlugin(new \Sabre\CalDAV\Notifications\Plugin());
|
2015-11-10 06:54:35 +00:00
|
|
|
$this->server->addPlugin(new CardDAV\Sharing\Plugin($authBackend, \OC::$server->getRequest()));
|
2015-11-09 12:27:19 +00:00
|
|
|
|
2015-10-31 00:28:21 +00:00
|
|
|
// addressbook plugins
|
2015-11-27 12:14:55 +00:00
|
|
|
$this->server->addPlugin(new \OCA\DAV\CardDAV\Plugin());
|
2015-11-10 06:27:34 +00:00
|
|
|
|
2015-11-27 11:54:31 +00:00
|
|
|
// system tags plugins
|
|
|
|
$this->server->addPlugin(new \OCA\DAV\SystemTag\SystemTagPlugin(\OC::$server->getSystemTagManager()));
|
|
|
|
|
2015-11-13 10:47:32 +00:00
|
|
|
// Finder on OS X requires Class 2 WebDAV support (locking), since we do
|
|
|
|
// not provide locking we emulate it using a fake locking plugin.
|
|
|
|
if($request->isUserAgent(['/WebDAVFS/'])) {
|
|
|
|
$this->server->addPlugin(new \OCA\DAV\Connector\Sabre\FakeLockerPlugin());
|
|
|
|
}
|
|
|
|
|
2015-10-21 13:06:48 +00:00
|
|
|
// wait with registering these until auth is handled and the filesystem is setup
|
|
|
|
$this->server->on('beforeMethod', function () {
|
|
|
|
// custom properties plugin must be the last one
|
|
|
|
$user = \OC::$server->getUserSession()->getUser();
|
|
|
|
if (!is_null($user)) {
|
|
|
|
$this->server->addPlugin(
|
|
|
|
new \Sabre\DAV\PropertyStorage\Plugin(
|
|
|
|
new CustomPropertiesBackend(
|
|
|
|
$this->server->tree,
|
|
|
|
\OC::$server->getDatabaseConnection(),
|
|
|
|
\OC::$server->getUserSession()->getUser()
|
|
|
|
)
|
|
|
|
)
|
|
|
|
);
|
|
|
|
}
|
|
|
|
});
|
|
|
|
}
|
|
|
|
|
|
|
|
public function exec() {
|
|
|
|
$this->server->exec();
|
|
|
|
}
|
|
|
|
}
|