summaryrefslogtreecommitdiffstats
path: root/lib/private
diff options
context:
space:
mode:
authorArthur Schiwon <blizzz@owncloud.com>2016-02-09 02:51:12 +0100
committerArthur Schiwon <blizzz@owncloud.com>2016-02-09 02:51:12 +0100
commitcd00751de56800748fb47da3880decdd25a65edd (patch)
tree4ab2a1ed69b158c8dac1fe906a0029f07270a694 /lib/private
parent850ac0cf84f2492b16204b811f58a0dc7dc43b6e (diff)
downloadnextcloud-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.php18
-rw-r--r--lib/private/server.php3
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) {