diff options
author | Arthur Schiwon <blizzz@owncloud.com> | 2016-02-09 02:51:12 +0100 |
---|---|---|
committer | Arthur Schiwon <blizzz@owncloud.com> | 2016-02-09 02:51:12 +0100 |
commit | cd00751de56800748fb47da3880decdd25a65edd (patch) | |
tree | 4ab2a1ed69b158c8dac1fe906a0029f07270a694 /lib/private | |
parent | 850ac0cf84f2492b16204b811f58a0dc7dc43b6e (diff) | |
download | nextcloud-server-cd00751de56800748fb47da3880decdd25a65edd.tar.gz nextcloud-server-cd00751de56800748fb47da3880decdd25a65edd.zip |
Send events when enabling and disabling of apps
Diffstat (limited to 'lib/private')
-rw-r--r-- | lib/private/app/appmanager.php | 18 | ||||
-rw-r--r-- | lib/private/server.php | 3 |
2 files changed, 19 insertions, 2 deletions
diff --git a/lib/private/app/appmanager.php b/lib/private/app/appmanager.php index bf07a2ef548..eeb2216d5a8 100644 --- a/lib/private/app/appmanager.php +++ b/lib/private/app/appmanager.php @@ -27,11 +27,13 @@ namespace OC\App; use OCP\App\IAppManager; +use OCP\App\ManagerEvent; use OCP\IAppConfig; use OCP\ICacheFactory; use OCP\IGroupManager; use OCP\IUser; use OCP\IUserSession; +use Symfony\Component\EventDispatcher\EventDispatcherInterface; class AppManager implements IAppManager { @@ -68,6 +70,9 @@ class AppManager implements IAppManager { /** @var string[] */ private $alwaysEnabled; + /** @var EventDispatcherInterface */ + private $dispatcher; + /** * @param \OCP\IUserSession $userSession * @param \OCP\IAppConfig $appConfig @@ -77,11 +82,13 @@ class AppManager implements IAppManager { public function __construct(IUserSession $userSession, IAppConfig $appConfig, IGroupManager $groupManager, - ICacheFactory $memCacheFactory) { + ICacheFactory $memCacheFactory, + EventDispatcherInterface $dispatcher) { $this->userSession = $userSession; $this->appConfig = $appConfig; $this->groupManager = $groupManager; $this->memCacheFactory = $memCacheFactory; + $this->dispatcher = $dispatcher; } /** @@ -201,6 +208,9 @@ class AppManager implements IAppManager { public function enableApp($appId) { $this->installedAppsCache[$appId] = 'yes'; $this->appConfig->setValue($appId, 'enabled', 'yes'); + $this->dispatcher->dispatch(ManagerEvent::EVENT_APP_ENABLE, new ManagerEvent( + ManagerEvent::EVENT_APP_ENABLE, $appId + )); $this->clearAppsCache(); } @@ -226,6 +236,9 @@ class AppManager implements IAppManager { }, $groups); $this->installedAppsCache[$appId] = json_encode($groupIds); $this->appConfig->setValue($appId, 'enabled', json_encode($groupIds)); + $this->dispatcher->dispatch(ManagerEvent::EVENT_APP_ENABLE_FOR_GROUPS, new ManagerEvent( + ManagerEvent::EVENT_APP_ENABLE_FOR_GROUPS, $appId, $groups + )); $this->clearAppsCache(); } @@ -241,6 +254,9 @@ class AppManager implements IAppManager { } unset($this->installedAppsCache[$appId]); $this->appConfig->setValue($appId, 'enabled', 'no'); + $this->dispatcher->dispatch(ManagerEvent::EVENT_APP_ENABLE, new ManagerEvent( + ManagerEvent::EVENT_APP_DISABLE, $appId + )); $this->clearAppsCache(); } diff --git a/lib/private/server.php b/lib/private/server.php index 55ac64a0c2d..0d1bed4e7d2 100644 --- a/lib/private/server.php +++ b/lib/private/server.php @@ -413,7 +413,8 @@ class Server extends ServerContainer implements IServerContainer { $c->getUserSession(), $c->getAppConfig(), $c->getGroupManager(), - $c->getMemCacheFactory() + $c->getMemCacheFactory(), + $c->getEventDispatcher() ); }); $this->registerService('DateTimeZone', function (Server $c) { |