From 8b84de934abfd42f0b8c26d778ee2b707ff7e193 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Jannis=20Mo=C3=9Fhammer?= Date: Thu, 20 Jun 2013 14:06:02 +0200 Subject: [PATCH] Move ModuleController from incubator The Notification dependency is removed and uses exceptions now, otherwise it's mostly the same like in the incubator refs #4092 --- application/controllers/ModulesController.php | 6 +- .../Icinga/Application/Modules/Manager.php | 76 ++++++++----------- public/js/icinga/util/async.js | 4 +- 3 files changed, 33 insertions(+), 53 deletions(-) diff --git a/application/controllers/ModulesController.php b/application/controllers/ModulesController.php index afd3b9178..f8f40a3b3 100755 --- a/application/controllers/ModulesController.php +++ b/application/controllers/ModulesController.php @@ -35,11 +35,7 @@ class ModulesController extends ActionController public function enableAction() { $this->manager->enableModule($this->_getParam('name')); - $this->manager->loadModule($this->_getParam('name')); - $this->getResponse()->setHeader('X-Icinga-Enable-Module', $this->_getParam('name')); - $this->replaceLayout = true; - $this->indexAction(); - + $this->redirectNow('modules/overview?_render=body'); } public function disableAction() diff --git a/library/Icinga/Application/Modules/Manager.php b/library/Icinga/Application/Modules/Manager.php index f4612de7f..4061a2421 100644 --- a/library/Icinga/Application/Modules/Manager.php +++ b/library/Icinga/Application/Modules/Manager.php @@ -2,39 +2,33 @@ namespace Icinga\Application\Modules; +use Icinga\Application\ApplicationBootstrap; +use Icinga\Data\ArrayDatasource; +use Icinga\Web\Notification; use Icinga\Exception\ConfigurationError; use Icinga\Exception\SystemPermissionException; -use Icinga\Exception\ProgrammingError; // TODO: show whether enabling/disabling modules is allowed by checking enableDir // perms class Manager { - protected $installedBaseDirs = null; + protected $installedBaseDirs; protected $enabledDirs = array(); protected $loadedModules = array(); protected $index; protected $app; + protected $enableDir; - protected $modulePaths = array(); - /** - * @param $app : The applicaiton bootstrap. This one needs a properly defined interface - * In order to test it correctly, the application now only requires a stdClass - * @param $dir : - **/ - public function __construct($app, $enabledDir = null, array $availableDirs = array()) + + public function __construct(ApplicationBootstrap $app, $dir = null) { $this->app = $app; - if (empty($availableDirs)) { - $availableDirs = array(ICINGA_APPDIR."/../modules"); - } - $this->modulePaths = $availableDirs; - if ($enabledDir === null) { - $enabledDir = $this->app->getConfig()->getConfigDir() + if ($dir === null) { + $dir = $this->app->getConfig()->getConfigDir() . '/enabledModules'; } - $this->prepareEssentials($enabledDir); + $this->prepareEssentials($dir); $this->detectEnabledModules(); } @@ -52,17 +46,10 @@ class Manager } } - public function select() - { - $source = new \Icinga\Data\ArrayDataSource($this->getModuleInfo()); - return $source->select(); - } - protected function detectEnabledModules() { $fh = opendir($this->enableDir); - $this->enabledDirs = array(); while (false !== ($file = readdir($fh))) { if ($file[0] === '.') { @@ -91,18 +78,12 @@ class Manager return $this; } - public function loadModule($name, $moduleBase = null) + public function loadModule($name) { if ($this->hasLoaded($name)) { return $this; } - - $module = null; - if ($moduleBase === null) { - $module = new Module($this->app, $name, $this->getModuleDir($name)); - } else { - $module = new $moduleBase($this->app, $name, $this->getModuleDir($name)); - } + $module = new Module($this->app, $name, $this->getModuleDir($name)); $module->register(); $this->loadedModules[$name] = $module; return $this; @@ -119,7 +100,6 @@ class Manager ); return $this; } - clearstatcache(true); $target = $this->installedBaseDirs[$name]; $link = $this->enableDir . '/' . $name; if (! is_writable($this->enableDir)) { @@ -138,7 +118,6 @@ class Manager throw new SystemPermissionException($error["message"], "symlink", $link); } } - $this->enabledDirs[$name] = $link; return $this; } @@ -172,7 +151,6 @@ class Manager } else { } - unset($this->enabledDirs[$name]); return $this; } @@ -250,6 +228,12 @@ class Manager return $info; } + public function select() + { + $ds = new ArrayDatasource($this->getModuleInfo()); + return $ds->select(); + } + public function listEnabledModules() { return array_keys($this->enabledDirs); @@ -270,19 +254,19 @@ class Manager public function detectInstalledModules() { - foreach ($this->modulePaths as $basedir) { - $fh = opendir($basedir); - if ($fh === false) { - return $this; + // TODO: Allow multiple paths for installed modules (e.g. web vs pkg) + $basedir = realpath(ICINGA_APPDIR . '/../modules'); + $fh = @opendir($basedir); + if ($fh === false) { + return $this; + } + + while ($name = readdir($fh)) { + if ($name[0] === '.') { + continue; } - - while ($name = readdir($fh)) { - if ($name[0] === '.') { - continue; - } - if (is_dir($basedir . '/' . $name)) { - $this->installedBaseDirs[$name] = $basedir . '/' . $name; - } + if (is_dir($basedir . '/' . $name)) { + $this->installedBaseDirs[$name] = $basedir . '/' . $name; } } } diff --git a/public/js/icinga/util/async.js b/public/js/icinga/util/async.js index 8e015b45a..15a6be7df 100644 --- a/public/js/icinga/util/async.js +++ b/public/js/icinga/util/async.js @@ -10,7 +10,7 @@ }; var getDOMForDestination = function(destination) { var target = destination; - if(typeof destination === "string") { + if (typeof destination === "string") { target = containerMgr.getContainer(destination)[0]; } else if(typeof destination.context !== "undefined") { target = destination[0]; @@ -89,7 +89,7 @@ if(destination) { pending.push({ request: req, - DOM: getDOMForDestination(destination) + DOM: getDOMForDestination(destination) }); req.destination = destination; }