aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorThomas Müller <thomas.mueller@tmit.eu>2016-02-09 11:23:19 +0100
committerThomas Müller <thomas.mueller@tmit.eu>2016-02-09 11:23:19 +0100
commitd11179a0f5b69ae479c214033a1ffc8d64752c83 (patch)
tree1c6e85b003c0ebff2dd35b14738e95e64bda660c
parentb93fc4fc5f30c4328a7aec47e8375c2bcee076cb (diff)
parentcd00751de56800748fb47da3880decdd25a65edd (diff)
downloadnextcloud-server-d11179a0f5b69ae479c214033a1ffc8d64752c83.tar.gz
nextcloud-server-d11179a0f5b69ae479c214033a1ffc8d64752c83.zip
Merge pull request #22227 from owncloud/appmanager-hooks
Send events when enabling and disabling of apps
-rw-r--r--lib/private/app/appmanager.php18
-rw-r--r--lib/private/server.php3
-rw-r--r--lib/public/app/managerevent.php86
-rw-r--r--tests/lib/app.php4
-rw-r--r--tests/lib/app/manager.php14
5 files changed, 116 insertions, 9 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) {
diff --git a/lib/public/app/managerevent.php b/lib/public/app/managerevent.php
new file mode 100644
index 00000000000..99e9b11b024
--- /dev/null
+++ b/lib/public/app/managerevent.php
@@ -0,0 +1,86 @@
+<?php
+/**
+ * @author Joas Schilling <nickvergessen@owncloud.com>
+ *
+ * @copyright Copyright (c) 2016, ownCloud, Inc.
+ * @license AGPL-3.0
+ *
+ * This code is free software: you can redistribute it and/or modify
+ * it under the terms of the GNU Affero General Public License, version 3,
+ * as published by the Free Software Foundation.
+ *
+ * This program is distributed in the hope that it will be useful,
+ * but WITHOUT ANY WARRANTY; without even the implied warranty of
+ * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
+ * GNU Affero General Public License for more details.
+ *
+ * You should have received a copy of the GNU Affero General Public License, version 3,
+ * along with this program. If not, see <http://www.gnu.org/licenses/>
+ *
+ */
+
+namespace OCP\App;
+
+use Symfony\Component\EventDispatcher\Event;
+
+/**
+ * Class ManagerEvent
+ *
+ * @package OCP\APP
+ * @since 9.0.0
+ */
+class ManagerEvent extends Event {
+
+ const EVENT_APP_ENABLE = 'OCP\App\IAppManager::enableApp';
+ const EVENT_APP_ENABLE_FOR_GROUPS = 'OCP\App\IAppManager::enableAppForGroups';
+ const EVENT_APP_DISABLE = 'OCP\App\IAppManager::disableApp';
+
+ /** @var string */
+ protected $event;
+ /** @var string */
+ protected $appID;
+ /** @var \OCP\IGroup[] */
+ protected $groups;
+
+ /**
+ * DispatcherEvent constructor.
+ *
+ * @param string $event
+ * @param $appID
+ * @param \OCP\IGroup[] $groups
+ * @since 9.0.0
+ */
+ public function __construct($event, $appID, array $groups = null) {
+ $this->event = $event;
+ $this->appID = $appID;
+ $this->groups = $groups;
+ }
+
+ /**
+ * @return string
+ * @since 9.0.0
+ */
+ public function getEvent() {
+ return $this->event;
+ }
+
+ /**
+ * @return string
+ * @since 9.0.0
+ */
+ public function getAppID() {
+ return $this->appID;
+ }
+
+ /**
+ * returns the group Ids
+ * @return string[]
+ * @since 9.0.0
+ */
+ public function getGroups() {
+ return array_map(function ($group) {
+ /** @var \OCP\IGroup $group */
+ return $group->getGID();
+ }, $this->groups);
+ }
+}
diff --git a/tests/lib/app.php b/tests/lib/app.php
index 3fb42ea2382..065296827dd 100644
--- a/tests/lib/app.php
+++ b/tests/lib/app.php
@@ -485,7 +485,7 @@ class Test_App extends \Test\TestCase {
return $appConfig;
});
\OC::$server->registerService('AppManager', function (\OC\Server $c) use ($appConfig) {
- return new \OC\App\AppManager($c->getUserSession(), $appConfig, $c->getGroupManager(), $c->getMemCacheFactory());
+ return new \OC\App\AppManager($c->getUserSession(), $appConfig, $c->getGroupManager(), $c->getMemCacheFactory(), $c->getEventDispatcher());
});
}
@@ -497,7 +497,7 @@ class Test_App extends \Test\TestCase {
return new \OC\AppConfig($c->getDatabaseConnection());
});
\OC::$server->registerService('AppManager', function (\OC\Server $c) {
- return new \OC\App\AppManager($c->getUserSession(), $c->getAppConfig(), $c->getGroupManager(), $c->getMemCacheFactory());
+ return new \OC\App\AppManager($c->getUserSession(), $c->getAppConfig(), $c->getGroupManager(), $c->getMemCacheFactory(), $c->getEventDispatcher());
});
// Remove the cache of the mocked apps list with a forceRefresh
diff --git a/tests/lib/app/manager.php b/tests/lib/app/manager.php
index ee9b1f308ea..ef7c01658e1 100644
--- a/tests/lib/app/manager.php
+++ b/tests/lib/app/manager.php
@@ -79,6 +79,9 @@ class Manager extends TestCase {
/** @var \OCP\App\IAppManager */
protected $manager;
+ /** @var \Symfony\Component\EventDispatcher\EventDispatcherInterface */
+ protected $eventDispatcher;
+
protected function setUp() {
parent::setUp();
@@ -87,11 +90,12 @@ class Manager extends TestCase {
$this->appConfig = $this->getAppConfig();
$this->cacheFactory = $this->getMock('\OCP\ICacheFactory');
$this->cache = $this->getMock('\OCP\ICache');
+ $this->eventDispatcher = $this->getMock('\Symfony\Component\EventDispatcher\EventDispatcherInterface');
$this->cacheFactory->expects($this->any())
->method('create')
->with('settings')
->willReturn($this->cache);
- $this->manager = new \OC\App\AppManager($this->userSession, $this->appConfig, $this->groupManager, $this->cacheFactory);
+ $this->manager = new \OC\App\AppManager($this->userSession, $this->appConfig, $this->groupManager, $this->cacheFactory, $this->eventDispatcher);
}
protected function expectClearCache() {
@@ -149,7 +153,7 @@ class Manager extends TestCase {
/** @var \OC\App\AppManager|\PHPUnit_Framework_MockObject_MockObject $manager */
$manager = $this->getMockBuilder('OC\App\AppManager')
->setConstructorArgs([
- $this->userSession, $this->appConfig, $this->groupManager, $this->cacheFactory
+ $this->userSession, $this->appConfig, $this->groupManager, $this->cacheFactory, $this->eventDispatcher
])
->setMethods([
'getAppInfo'
@@ -192,7 +196,7 @@ class Manager extends TestCase {
/** @var \OC\App\AppManager|\PHPUnit_Framework_MockObject_MockObject $manager */
$manager = $this->getMockBuilder('OC\App\AppManager')
->setConstructorArgs([
- $this->userSession, $this->appConfig, $this->groupManager, $this->cacheFactory
+ $this->userSession, $this->appConfig, $this->groupManager, $this->cacheFactory, $this->eventDispatcher
])
->setMethods([
'getAppInfo'
@@ -301,7 +305,7 @@ class Manager extends TestCase {
public function testGetAppsNeedingUpgrade() {
$this->manager = $this->getMockBuilder('\OC\App\AppManager')
- ->setConstructorArgs([$this->userSession, $this->appConfig, $this->groupManager, $this->cacheFactory])
+ ->setConstructorArgs([$this->userSession, $this->appConfig, $this->groupManager, $this->cacheFactory, $this->eventDispatcher])
->setMethods(['getAppInfo'])
->getMock();
@@ -342,7 +346,7 @@ class Manager extends TestCase {
public function testGetIncompatibleApps() {
$this->manager = $this->getMockBuilder('\OC\App\AppManager')
- ->setConstructorArgs([$this->userSession, $this->appConfig, $this->groupManager, $this->cacheFactory])
+ ->setConstructorArgs([$this->userSession, $this->appConfig, $this->groupManager, $this->cacheFactory, $this->eventDispatcher])
->setMethods(['getAppInfo'])
->getMock();