diff options
author | Joas Schilling <coding@schilljs.com> | 2016-10-13 15:34:26 +0200 |
---|---|---|
committer | Joas Schilling <coding@schilljs.com> | 2016-11-03 12:07:59 +0100 |
commit | 52dd27892b80ab91d0776c45d05d8447ac24b76e (patch) | |
tree | 56457a3d0eb6119bbe200413557bcb6d76a7329a /apps/dav/lib/CalDAV | |
parent | d3e8463de28197de2d4d61c35906b020ec85b432 (diff) | |
download | nextcloud-server-52dd27892b80ab91d0776c45d05d8447ac24b76e.tar.gz nextcloud-server-52dd27892b80ab91d0776c45d05d8447ac24b76e.zip |
Use the event dispatcher
Signed-off-by: Joas Schilling <coding@schilljs.com>
Diffstat (limited to 'apps/dav/lib/CalDAV')
-rw-r--r-- | apps/dav/lib/CalDAV/Activity/Backend.php | 143 | ||||
-rw-r--r-- | apps/dav/lib/CalDAV/CalDavBackend.php | 93 |
2 files changed, 121 insertions, 115 deletions
diff --git a/apps/dav/lib/CalDAV/Activity/Backend.php b/apps/dav/lib/CalDAV/Activity/Backend.php index 1c1637cd562..6cf09f6de46 100644 --- a/apps/dav/lib/CalDAV/Activity/Backend.php +++ b/apps/dav/lib/CalDAV/Activity/Backend.php @@ -22,8 +22,6 @@ namespace OCA\DAV\CalDAV\Activity; -use OCA\DAV\CalDAV\CalDavBackend; -use OCA\DAV\CalDAV\Calendar; use OCP\Activity\IEvent; use OCP\Activity\IManager as IActivityManager; use OCP\IGroup; @@ -39,9 +37,6 @@ use Sabre\VObject\Reader; */ class Backend { - /** @var CalDavBackend */ - protected $calDavBackend; - /** @var IActivityManager */ protected $activityManager; @@ -52,13 +47,11 @@ class Backend { protected $userSession; /** - * @param CalDavBackend $calDavBackend * @param IActivityManager $activityManager * @param IGroupManager $groupManager * @param IUserSession $userSession */ - public function __construct(CalDavBackend $calDavBackend, IActivityManager $activityManager, IGroupManager $groupManager, IUserSession $userSession) { - $this->calDavBackend = $calDavBackend; + public function __construct(IActivityManager $activityManager, IGroupManager $groupManager, IUserSession $userSession) { $this->activityManager = $activityManager; $this->groupManager = $groupManager; $this->userSession = $userSession; @@ -67,46 +60,47 @@ class Backend { /** * Creates activities when a calendar was creates * - * @param int $calendarId - * @param array $properties + * @param array $calendarData */ - public function addCalendar($calendarId, array $properties) { - $this->triggerCalendarActivity(Extension::SUBJECT_ADD, $calendarId, $properties); + public function onCalendarAdd(array $calendarData) { + $this->triggerCalendarActivity(Extension::SUBJECT_ADD, $calendarData); } /** * Creates activities when a calendar was updated * - * @param int $calendarId + * @param array $calendarData + * @param array $shares * @param array $properties */ - public function updateCalendar($calendarId, array $properties) { - $this->triggerCalendarActivity(Extension::SUBJECT_UPDATE, $calendarId, $properties); + public function onCalendarUpdate(array $calendarData, array $shares, array $properties) { + $this->triggerCalendarActivity(Extension::SUBJECT_UPDATE, $calendarData, $shares, $properties); } /** * Creates activities when a calendar was deleted * - * @param int $calendarId + * @param array $calendarData + * @param array $shares */ - public function deleteCalendar($calendarId) { - $this->triggerCalendarActivity(Extension::SUBJECT_DELETE, $calendarId); + public function onCalendarDelete(array $calendarData, array $shares) { + $this->triggerCalendarActivity(Extension::SUBJECT_DELETE, $calendarData, $shares); } /** * Creates activities for all related users when a calendar was touched * * @param string $action - * @param int $calendarId + * @param array $calendarData + * @param array $shares * @param array $changedProperties */ - protected function triggerCalendarActivity($action, $calendarId, array $changedProperties = []) { - $properties = $this->calDavBackend->getCalendarById($calendarId); - if (!isset($properties['principaluri'])) { + protected function triggerCalendarActivity($action, array $calendarData, array $shares = [], array $changedProperties = []) { + if (!isset($calendarData['principaluri'])) { return; } - $principal = explode('/', $properties['principaluri']); + $principal = explode('/', $calendarData['principaluri']); $owner = $principal[2]; $currentUser = $this->userSession->getUser(); @@ -118,7 +112,7 @@ class Backend { $event = $this->activityManager->generateEvent(); $event->setApp('dav') - ->setObject(Extension::CALENDAR, $calendarId) + ->setObject(Extension::CALENDAR, $calendarData['id']) ->setType(Extension::CALENDAR) ->setAuthor($currentUser); @@ -127,10 +121,10 @@ class Backend { '{http://apple.com/ns/ical/}calendar-color' ], array_keys($changedProperties)); - if ($action === Extension::SUBJECT_UPDATE && empty($changedVisibleInformation)) { + if (empty($shares) || ($action === Extension::SUBJECT_UPDATE && empty($changedVisibleInformation))) { $users = [$owner]; } else { - $users = $this->getUsersForCalendar($calendarId); + $users = $this->getUsersForShares($shares); $users[] = $owner; } @@ -140,7 +134,7 @@ class Backend { $user === $currentUser ? $action . '_self' : $action, [ $currentUser, - $properties['{DAV:}displayname'], + $calendarData['{DAV:}displayname'], ] ); $this->activityManager->publish($event); @@ -150,16 +144,13 @@ class Backend { /** * Creates activities for all related users when a calendar was (un-)shared * - * @param Calendar $calendar + * @param array $calendarData + * @param array $shares * @param array $add * @param array $remove */ - public function updateCalendarShares(Calendar $calendar, array $add, array $remove) { - $calendarId = $calendar->getResourceId(); - $shares = $this->calDavBackend->getShares($calendarId); - - $properties = $this->calDavBackend->getCalendarById($calendarId); - $principal = explode('/', $properties['principaluri']); + public function onCalendarUpdateShares(array $calendarData, array $shares, array $add, array $remove) { + $principal = explode('/', $calendarData['principaluri']); $owner = $principal[2]; $currentUser = $this->userSession->getUser(); @@ -171,7 +162,7 @@ class Backend { $event = $this->activityManager->generateEvent(); $event->setApp('dav') - ->setObject(Extension::CALENDAR, $calendarId) + ->setObject(Extension::CALENDAR, $calendarData['id']) ->setType(Extension::CALENDAR) ->setAuthor($currentUser); @@ -187,7 +178,7 @@ class Backend { $this->triggerActivityUser( $principal[2], $event, - $properties, + $calendarData, Extension::SUBJECT_UNSHARE_USER, Extension::SUBJECT_DELETE . '_self' ); @@ -195,7 +186,7 @@ class Backend { if ($owner !== $principal[2]) { $parameters = [ $principal[2], - $properties['{DAV:}displayname'], + $calendarData['{DAV:}displayname'], ]; if ($owner === $event->getAuthor()) { @@ -216,11 +207,11 @@ class Backend { $this->activityManager->publish($event); } } else if ($principal[1] === 'groups') { - $this->triggerActivityGroup($principal[2], $event, $properties, Extension::SUBJECT_UNSHARE_USER); + $this->triggerActivityGroup($principal[2], $event, $calendarData, Extension::SUBJECT_UNSHARE_USER); $parameters = [ $principal[2], - $properties['{DAV:}displayname'], + $calendarData['{DAV:}displayname'], ]; if ($owner === $event->getAuthor()) { @@ -253,12 +244,12 @@ class Backend { $principal = explode('/', $parts[1]); if ($principal[1] === 'users') { - $this->triggerActivityUser($principal[2], $event, $properties, Extension::SUBJECT_SHARE_USER); + $this->triggerActivityUser($principal[2], $event, $calendarData, Extension::SUBJECT_SHARE_USER); if ($owner !== $principal[2]) { $parameters = [ $principal[2], - $properties['{DAV:}displayname'], + $calendarData['{DAV:}displayname'], ]; if ($owner === $event->getAuthor()) { @@ -277,11 +268,11 @@ class Backend { $this->activityManager->publish($event); } } else if ($principal[1] === 'groups') { - $this->triggerActivityGroup($principal[2], $event, $properties, Extension::SUBJECT_SHARE_USER); + $this->triggerActivityGroup($principal[2], $event, $calendarData, Extension::SUBJECT_SHARE_USER); $parameters = [ $principal[2], - $properties['{DAV:}displayname'], + $calendarData['{DAV:}displayname'], ]; if ($owner === $event->getAuthor()) { @@ -363,49 +354,19 @@ class Backend { } /** - * Creates activities when a calendar object was created - * - * @param int $calendarId - * @param string $objectUri - */ - public function addCalendarObject($calendarId, $objectUri) { - $this->triggerCalendarObjectActivity(Extension::SUBJECT_OBJECT_ADD, $calendarId, $objectUri); - } - - /** - * Creates activities when a calendar object was updated - * - * @param int $calendarId - * @param string $objectUri - */ - public function updateCalendarObject($calendarId, $objectUri) { - $this->triggerCalendarObjectActivity(Extension::SUBJECT_OBJECT_UPDATE, $calendarId, $objectUri); - } - - /** - * Creates activities when a calendar object was deleted - * - * @param int $calendarId - * @param string $objectUri - */ - public function deleteCalendarObject($calendarId, $objectUri) { - $this->triggerCalendarObjectActivity(Extension::SUBJECT_OBJECT_DELETE, $calendarId, $objectUri); - } - - /** - * Creates activities for all related users when a calendar was touched + * Creates activities when a calendar object was created/updated/deleted * * @param string $action - * @param int $calendarId - * @param string $objectUri + * @param array $calendarData + * @param array $shares + * @param array $objectData */ - protected function triggerCalendarObjectActivity($action, $calendarId, $objectUri) { - $properties = $this->calDavBackend->getCalendarById($calendarId); - if (!isset($properties['principaluri'])) { + public function onTouchCalendarObject($action, array $calendarData, array $shares, array $objectData) { + if (!isset($calendarData['principaluri'])) { return; } - $principal = explode('/', $properties['principaluri']); + $principal = explode('/', $calendarData['principaluri']); $owner = $principal[2]; $currentUser = $this->userSession->getUser(); @@ -415,7 +376,7 @@ class Backend { $currentUser = $owner; } - $object = $this->getObjectNameAndType($calendarId, $objectUri); + $object = $this->getObjectNameAndType($objectData); $action = $action . '_' . $object['type']; if ($object['type'] === 'todo' && strpos($action, Extension::SUBJECT_OBJECT_UPDATE) === 0 && $object['status'] === 'COMPLETED') { @@ -426,11 +387,11 @@ class Backend { $event = $this->activityManager->generateEvent(); $event->setApp('dav') - ->setObject(Extension::CALENDAR, $calendarId) + ->setObject(Extension::CALENDAR, $calendarData['id']) ->setType($object['type'] === 'event' ? Extension::CALENDAR_EVENT : Extension::CALENDAR_TODO) ->setAuthor($currentUser); - $users = $this->getUsersForCalendar($calendarId); + $users = $this->getUsersForShares($shares); $users[] = $owner; foreach ($users as $user) { @@ -439,7 +400,7 @@ class Backend { $user === $currentUser ? $action . '_self' : $action, [ $currentUser, - $properties['{DAV:}displayname'], + $calendarData['{DAV:}displayname'], $object['name'], ] ); @@ -448,14 +409,11 @@ class Backend { } /** - * @param int $calendarId - * @param string $objectUri + * @param array $objectData * @return string[]|bool */ - protected function getObjectNameAndType($calendarId, $objectUri) { - $data = $this->calDavBackend->getCalendarObject($calendarId, $objectUri); - - $vObject = Reader::read($data['calendardata']); + protected function getObjectNameAndType(array $objectData) { + $vObject = Reader::read($objectData['calendardata']); $component = $componentType = null; foreach($vObject->getComponents() as $component) { if (in_array($component->name, ['VEVENT', 'VTODO'])) { @@ -478,12 +436,11 @@ class Backend { /** * Get all users that have access to a given calendar * - * @param int $calendarId + * @param array $shares * @return string[] */ - protected function getUsersForCalendar($calendarId) { + protected function getUsersForShares(array $shares) { $users = $groups = []; - $shares = $this->calDavBackend->getShares($calendarId); foreach ($shares as $share) { $prinical = explode('/', $share['{http://owncloud.org/ns}principal']); if ($prinical[1] === 'users') { diff --git a/apps/dav/lib/CalDAV/CalDavBackend.php b/apps/dav/lib/CalDAV/CalDavBackend.php index 660114e462a..fb608c2009d 100644 --- a/apps/dav/lib/CalDAV/CalDavBackend.php +++ b/apps/dav/lib/CalDAV/CalDavBackend.php @@ -26,16 +26,12 @@ namespace OCA\DAV\CalDAV; use OCA\DAV\DAV\Sharing\IShareable; -use OCA\DAV\CalDAV\Activity\Backend as ActivityBackend; -use OCP\Activity\IManager as IActivityManager; use OCP\DB\QueryBuilder\IQueryBuilder; use OCA\DAV\Connector\Sabre\Principal; use OCA\DAV\DAV\Sharing\Backend; use OCP\IDBConnection; -use OCP\IGroupManager; use OCP\IUser; use OCP\IUserManager; -use OCP\IUserSession; use OCP\Security\ISecureRandom; use Sabre\CalDAV\Backend\AbstractBackend; use Sabre\CalDAV\Backend\SchedulingSupport; @@ -52,6 +48,8 @@ use Sabre\HTTP\URLUtil; use Sabre\VObject\DateTimeParser; use Sabre\VObject\Reader; use Sabre\VObject\Recur\EventIterator; +use Symfony\Component\EventDispatcher\EventDispatcherInterface; +use Symfony\Component\EventDispatcher\GenericEvent; /** * Class CalDavBackend @@ -131,8 +129,8 @@ class CalDavBackend extends AbstractBackend implements SyncSupport, Subscription /** @var ISecureRandom */ private $random; - /** @var ActivityBackend */ - private $activityBackend; + /** @var EventDispatcherInterface */ + private $dispatcher; /** * CalDavBackend constructor. @@ -140,25 +138,20 @@ class CalDavBackend extends AbstractBackend implements SyncSupport, Subscription * @param IDBConnection $db * @param Principal $principalBackend * @param IUserManager $userManager - * @param IGroupManager $groupManager * @param ISecureRandom $random - * @param IActivityManager $activityManager - * @param IUserSession $userSession + * @param EventDispatcherInterface $dispatcher */ public function __construct(IDBConnection $db, Principal $principalBackend, IUserManager $userManager, - IGroupManager $groupManager, ISecureRandom $random, - IActivityManager $activityManager, - IUserSession $userSession) { + EventDispatcherInterface $dispatcher) { $this->db = $db; $this->principalBackend = $principalBackend; $this->userManager = $userManager; - $this->userManager = $groupManager; $this->sharingBackend = new Backend($this->db, $principalBackend, 'calendar'); - $this->activityBackend = new ActivityBackend($this, $activityManager, $groupManager, $userSession); $this->random = $random; + $this->dispatcher = $dispatcher; } /** @@ -623,7 +616,12 @@ class CalDavBackend extends AbstractBackend implements SyncSupport, Subscription $query->execute(); $calendarId = $query->getLastInsertId(); - $this->activityBackend->addCalendar($calendarId, $values); + $this->dispatcher->dispatch('\OCA\DAV\CalDAV\CalDavBackend::createCalendar', new GenericEvent( + '\OCA\DAV\CalDAV\CalDavBackend::createCalendar', + [ + 'calendarId' => $calendarId, + 'calendarData' => $this->getCalendarById($calendarId), + ])); return $calendarId; } @@ -673,7 +671,14 @@ class CalDavBackend extends AbstractBackend implements SyncSupport, Subscription $this->addChange($calendarId, "", 2); - $this->activityBackend->updateCalendar($calendarId, $mutations); + $this->dispatcher->dispatch('\OCA\DAV\CalDAV\CalDavBackend::updateCalendar', new GenericEvent( + '\OCA\DAV\CalDAV\CalDavBackend::updateCalendar', + [ + 'calendarId' => $calendarId, + 'calendarData' => $this->getCalendarById($calendarId), + 'shares' => $this->getShares($calendarId), + 'propertyMutations' => $mutations, + ])); return true; }); @@ -686,7 +691,13 @@ class CalDavBackend extends AbstractBackend implements SyncSupport, Subscription * @return void */ function deleteCalendar($calendarId) { - $this->activityBackend->deleteCalendar($calendarId); + $this->dispatcher->dispatch('\OCA\DAV\CalDAV\CalDavBackend::deleteCalendar', new GenericEvent( + '\OCA\DAV\CalDAV\CalDavBackend::deleteCalendar', + [ + 'calendarId' => $calendarId, + 'calendarData' => $this->getCalendarById($calendarId), + 'shares' => $this->getShares($calendarId), + ])); $stmt = $this->db->prepare('DELETE FROM `*PREFIX*calendarobjects` WHERE `calendarid` = ?'); $stmt->execute([$calendarId]); @@ -892,7 +903,15 @@ class CalDavBackend extends AbstractBackend implements SyncSupport, Subscription ]) ->execute(); - $this->activityBackend->addCalendarObject($calendarId, $objectUri); + $this->dispatcher->dispatch('\OCA\DAV\CalDAV\CalDavBackend::createCalendarObject', new GenericEvent( + '\OCA\DAV\CalDAV\CalDavBackend::createCalendarObject', + [ + 'calendarId' => $calendarId, + 'calendarData' => $this->getCalendarById($calendarId), + 'shares' => $this->getShares($calendarId), + 'objectData' => $this->getCalendarObject($calendarId, $objectUri), + ] + )); $this->addChange($calendarId, $objectUri, 1); return '"' . $extraData['etag'] . '"'; @@ -934,7 +953,18 @@ class CalDavBackend extends AbstractBackend implements SyncSupport, Subscription ->andWhere($query->expr()->eq('uri', $query->createNamedParameter($objectUri))) ->execute(); - $this->activityBackend->updateCalendarObject($calendarId, $objectUri); + $data = $this->getCalendarObject($calendarId, $objectUri); + if (is_array($data)) { + $this->dispatcher->dispatch('\OCA\DAV\CalDAV\CalDavBackend::updateCalendarObject', new GenericEvent( + '\OCA\DAV\CalDAV\CalDavBackend::updateCalendarObject', + [ + 'calendarId' => $calendarId, + 'calendarData' => $this->getCalendarById($calendarId), + 'shares' => $this->getShares($calendarId), + 'objectData' => $data, + ] + )); + } $this->addChange($calendarId, $objectUri, 2); return '"' . $extraData['etag'] . '"'; @@ -967,7 +997,18 @@ class CalDavBackend extends AbstractBackend implements SyncSupport, Subscription * @return void */ function deleteCalendarObject($calendarId, $objectUri) { - $this->activityBackend->deleteCalendarObject($calendarId, $objectUri); + $data = $this->getCalendarObject($calendarId, $objectUri); + if (is_array($data)) { + $this->dispatcher->dispatch('\OCA\DAV\CalDAV\CalDavBackend::deleteCalendarObject', new GenericEvent( + '\OCA\DAV\CalDAV\CalDavBackend::deleteCalendarObject', + [ + 'calendarId' => $calendarId, + 'calendarData' => $this->getCalendarById($calendarId), + 'shares' => $this->getShares($calendarId), + 'objectData' => $data, + ] + )); + } $stmt = $this->db->prepare('DELETE FROM `*PREFIX*calendarobjects` WHERE `calendarid` = ? AND `uri` = ?'); $stmt->execute([$calendarId, $objectUri]); @@ -1668,8 +1709,16 @@ class CalDavBackend extends AbstractBackend implements SyncSupport, Subscription * @param array $remove */ public function updateShares($shareable, $add, $remove) { - /** @var Calendar $shareable */ - $this->activityBackend->updateCalendarShares($shareable, $add, $remove); + $calendarId = $shareable->getResourceId(); + $this->dispatcher->dispatch('\OCA\DAV\CalDAV\CalDavBackend::updateShares', new GenericEvent( + '\OCA\DAV\CalDAV\CalDavBackend::updateShares', + [ + 'calendarId' => $calendarId, + 'calendarData' => $this->getCalendarById($calendarId), + 'shares' => $this->getShares($calendarId), + 'add' => $add, + 'remove' => $remove, + ])); $this->sharingBackend->updateShares($shareable, $add, $remove); } |