diff options
author | Roeland Jago Douma <roeland@famdouma.nl> | 2017-08-03 15:14:29 +0200 |
---|---|---|
committer | Roeland Jago Douma <roeland@famdouma.nl> | 2017-08-03 15:14:29 +0200 |
commit | 4633717f0494a05a921a30066e47dc71d6002129 (patch) | |
tree | 87ce72d754e3821e5fb091be1a2db1ac59c18b2e /lib/private | |
parent | 8fecc336ac78719777c1a11ee62c14f084b56d51 (diff) | |
download | nextcloud-server-4633717f0494a05a921a30066e47dc71d6002129.tar.gz nextcloud-server-4633717f0494a05a921a30066e47dc71d6002129.zip |
Move pre_shared and post_shared events to EventDispatcher
* Now listeners for those events get proper share objects.
* Legacy hooks still fired
* Updated tests
Signed-off-by: Roeland Jago Douma <roeland@famdouma.nl>
Diffstat (limited to 'lib/private')
-rw-r--r-- | lib/private/Share20/LegacyHooks.php | 57 | ||||
-rw-r--r-- | lib/private/Share20/Manager.php | 46 |
2 files changed, 65 insertions, 38 deletions
diff --git a/lib/private/Share20/LegacyHooks.php b/lib/private/Share20/LegacyHooks.php index e7fbe7336b8..906c8e53054 100644 --- a/lib/private/Share20/LegacyHooks.php +++ b/lib/private/Share20/LegacyHooks.php @@ -22,6 +22,7 @@ */ namespace OC\Share20; +use OCP\Files\File; use OCP\Share\IShare; use Symfony\Component\EventDispatcher\EventDispatcher; use Symfony\Component\EventDispatcher\GenericEvent; @@ -41,6 +42,8 @@ class LegacyHooks { $this->eventDispatcher->addListener('OCP\Share::preUnshare', [$this, 'preUnshare']); $this->eventDispatcher->addListener('OCP\Share::postUnshare', [$this, 'postUnshare']); $this->eventDispatcher->addListener('OCP\Share::postUnshareFromSelf', [$this, 'postUnshareFromSelf']); + $this->eventDispatcher->addListener('OCP\Share::preShare', [$this, 'preShare']); + $this->eventDispatcher->addListener('OCP\Share::postShare', [$this, 'postShare']); } /** @@ -112,4 +115,58 @@ class LegacyHooks { ]; return $hookParams; } + + public function preShare(GenericEvent $e) { + /** @var IShare $share */ + $share = $e->getSubject(); + + // Pre share hook + $run = true; + $error = ''; + $preHookData = [ + 'itemType' => $share->getNode() instanceof File ? 'file' : 'folder', + 'itemSource' => $share->getNode()->getId(), + 'shareType' => $share->getShareType(), + 'uidOwner' => $share->getSharedBy(), + 'permissions' => $share->getPermissions(), + 'fileSource' => $share->getNode()->getId(), + 'expiration' => $share->getExpirationDate(), + 'token' => $share->getToken(), + 'itemTarget' => $share->getTarget(), + 'shareWith' => $share->getSharedWith(), + 'run' => &$run, + 'error' => &$error, + ]; + \OC_Hook::emit('OCP\Share', 'pre_shared', $preHookData); + + if ($run === false) { + $e->setArgument('error', $error); + $e->stopPropagation(); + } + + return $e; + } + + public function postShare(GenericEvent $e) { + /** @var IShare $share */ + $share = $e->getSubject(); + + $postHookData = [ + 'itemType' => $share->getNode() instanceof File ? 'file' : 'folder', + 'itemSource' => $share->getNode()->getId(), + 'shareType' => $share->getShareType(), + 'uidOwner' => $share->getSharedBy(), + 'permissions' => $share->getPermissions(), + 'fileSource' => $share->getNode()->getId(), + 'expiration' => $share->getExpirationDate(), + 'token' => $share->getToken(), + 'id' => $share->getId(), + 'shareWith' => $share->getSharedWith(), + 'itemTarget' => $share->getTarget(), + 'fileTarget' => $share->getTarget(), + ]; + + \OC_Hook::emit('OCP\Share', 'post_shared', $postHookData); + + } } diff --git a/lib/private/Share20/Manager.php b/lib/private/Share20/Manager.php index 9eee9a505ee..ad78a0db745 100644 --- a/lib/private/Share20/Manager.php +++ b/lib/private/Share20/Manager.php @@ -636,27 +636,11 @@ class Manager implements IManager { $target = \OC\Files\Filesystem::normalizePath($target); $share->setTarget($target); - // Pre share hook - $run = true; - $error = ''; - $preHookData = [ - 'itemType' => $share->getNode() instanceof \OCP\Files\File ? 'file' : 'folder', - 'itemSource' => $share->getNode()->getId(), - 'shareType' => $share->getShareType(), - 'uidOwner' => $share->getSharedBy(), - 'permissions' => $share->getPermissions(), - 'fileSource' => $share->getNode()->getId(), - 'expiration' => $share->getExpirationDate(), - 'token' => $share->getToken(), - 'itemTarget' => $share->getTarget(), - 'shareWith' => $share->getSharedWith(), - 'run' => &$run, - 'error' => &$error, - ]; - \OC_Hook::emit('OCP\Share', 'pre_shared', $preHookData); - - if ($run === false) { - throw new \Exception($error); + // Pre share event + $event = new GenericEvent($share); + $a = $this->eventDispatcher->dispatch('OCP\Share::preShare', $event); + if ($event->isPropagationStopped() && $event->hasArgument('error')) { + throw new \Exception($event->getArgument('error')); } $oldShare = $share; @@ -665,23 +649,9 @@ class Manager implements IManager { //reuse the node we already have $share->setNode($oldShare->getNode()); - // Post share hook - $postHookData = [ - 'itemType' => $share->getNode() instanceof \OCP\Files\File ? 'file' : 'folder', - 'itemSource' => $share->getNode()->getId(), - 'shareType' => $share->getShareType(), - 'uidOwner' => $share->getSharedBy(), - 'permissions' => $share->getPermissions(), - 'fileSource' => $share->getNode()->getId(), - 'expiration' => $share->getExpirationDate(), - 'token' => $share->getToken(), - 'id' => $share->getId(), - 'shareWith' => $share->getSharedWith(), - 'itemTarget' => $share->getTarget(), - 'fileTarget' => $share->getTarget(), - ]; - - \OC_Hook::emit('OCP\Share', 'post_shared', $postHookData); + // Post share event + $event = new GenericEvent($share); + $this->eventDispatcher->dispatch('OCP\Share::postShare', $event); if ($share->getShareType() === \OCP\Share::SHARE_TYPE_USER) { $user = $this->userManager->get($share->getSharedWith()); |