2013-08-12 15:58:26 +02:00
|
|
|
<?php
|
2014-04-28 14:03:52 +02:00
|
|
|
// @codeCoverageIgnoreStart
|
2013-08-12 15:58:26 +02:00
|
|
|
// {{{ICINGA_LICENSE_HEADER}}}
|
|
|
|
/**
|
2013-10-23 15:10:33 +02:00
|
|
|
* This file is part of Icinga Web 2.
|
2013-09-04 18:27:16 +02:00
|
|
|
*
|
2013-10-23 15:10:33 +02:00
|
|
|
* Icinga Web 2 - Head for multiple monitoring backends.
|
2013-08-12 15:58:26 +02:00
|
|
|
* Copyright (C) 2013 Icinga Development Team
|
2013-09-04 18:27:16 +02:00
|
|
|
*
|
2013-08-12 15:58:26 +02:00
|
|
|
* This program is free software; you can redistribute it and/or
|
|
|
|
* modify it under the terms of the GNU General Public License
|
|
|
|
* as published by the Free Software Foundation; either version 2
|
|
|
|
* of the License, or (at your option) any later version.
|
2013-09-04 18:27:16 +02:00
|
|
|
*
|
2013-08-12 15:58:26 +02:00
|
|
|
* 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 General Public License for more details.
|
2013-09-04 18:27:16 +02:00
|
|
|
*
|
2013-08-12 15:58:26 +02:00
|
|
|
* You should have received a copy of the GNU General Public License
|
|
|
|
* along with this program; if not, write to the Free Software
|
|
|
|
* Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
|
2013-09-04 18:27:16 +02:00
|
|
|
*
|
2013-10-23 15:10:33 +02:00
|
|
|
* @copyright 2013 Icinga Development Team <info@icinga.org>
|
|
|
|
* @license http://www.gnu.org/licenses/gpl-2.0.txt GPL, version 2
|
|
|
|
* @author Icinga Development Team <info@icinga.org>
|
|
|
|
*
|
2013-08-12 15:58:26 +02:00
|
|
|
*/
|
|
|
|
// {{{ICINGA_LICENSE_HEADER}}}
|
|
|
|
|
|
|
|
namespace Icinga\Web\Controller;
|
|
|
|
|
2014-04-28 14:03:52 +02:00
|
|
|
use Icinga\Application\Modules\Module;
|
|
|
|
use Icinga\Application\Icinga;
|
|
|
|
use Icinga\Web\Widget\Tabs;
|
2013-08-12 15:58:26 +02:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Static helper class that collects tabs provided by the 'createProvidedTabs' method
|
|
|
|
* of controllers.
|
|
|
|
*/
|
|
|
|
class ControllerTabCollector
|
|
|
|
{
|
|
|
|
/**
|
|
|
|
* Scan all controllers with the provided name
|
|
|
|
* in the application and (loaded) module folders and collects their provided tabs
|
|
|
|
*
|
|
|
|
* @param string $controller The name of the controllers to use for tab collection
|
|
|
|
*
|
|
|
|
* @return Tabs A @see Tabs instance containing the application tabs first
|
|
|
|
* followed by the tabs provided from the modules
|
|
|
|
*/
|
|
|
|
public static function collectControllerTabs($controller)
|
|
|
|
{
|
|
|
|
require_once(Icinga::app()->getApplicationDir('/controllers/'.$controller.'.php'));
|
|
|
|
|
|
|
|
$applicationTabs = $controller::createProvidedTabs();
|
|
|
|
$moduleTabs = self::collectModuleTabs($controller);
|
|
|
|
|
|
|
|
$tabs = new Tabs();
|
|
|
|
foreach ($applicationTabs as $name => $tab) {
|
|
|
|
$tabs->add($name, $tab);
|
|
|
|
}
|
|
|
|
|
|
|
|
foreach ($moduleTabs as $name => $tab) {
|
|
|
|
// don't overwrite application tabs if the module wants to
|
|
|
|
if ($tabs->has($name)) {
|
|
|
|
continue;
|
|
|
|
}
|
|
|
|
$tabs->add($name, $tab);
|
|
|
|
}
|
|
|
|
return $tabs;
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Collect module tabs for all modules containing the given controller
|
|
|
|
*
|
|
|
|
* @param string $controller The controller name to use for tab collection
|
|
|
|
*
|
|
|
|
* @return array An array of Tabs objects or arrays containing Tab descriptions
|
|
|
|
*/
|
|
|
|
private static function collectModuleTabs($controller)
|
|
|
|
{
|
|
|
|
$moduleManager = Icinga::app()->getModuleManager();
|
|
|
|
$modules = $moduleManager->listEnabledModules();
|
|
|
|
$tabs = array();
|
|
|
|
foreach ($modules as $module) {
|
|
|
|
$tabs += self::createModuleConfigurationTabs($controller, $moduleManager->getModule($module));
|
|
|
|
}
|
|
|
|
|
|
|
|
return $tabs;
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Collects the tabs from the createProvidedTabs() method in the configuration controller
|
|
|
|
*
|
|
|
|
* If the module doesn't have the given controller or createProvidedTabs method in the controller
|
|
|
|
* an empty array will be returned
|
|
|
|
*
|
|
|
|
* @param string $controller The name of the controller that provides tabs via createProvidedTabs
|
|
|
|
* @param Module $module The module instance that provides the controller
|
|
|
|
*
|
|
|
|
* @return array
|
|
|
|
*/
|
|
|
|
private static function createModuleConfigurationTabs($controller, Module $module)
|
|
|
|
{
|
|
|
|
$controllerDir = $module->getControllerDir();
|
|
|
|
$name = $module->getName();
|
|
|
|
|
|
|
|
$controllerDir = $controllerDir . '/' . $controller . '.php';
|
|
|
|
$controllerName = ucfirst($name) . '_' . $controller;
|
|
|
|
|
|
|
|
if (is_readable($controllerDir)) {
|
|
|
|
require_once(realpath($controllerDir));
|
|
|
|
if (!method_exists($controllerName, "createProvidedTabs")) {
|
|
|
|
return array();
|
|
|
|
}
|
|
|
|
$tab = $controllerName::createProvidedTabs();
|
|
|
|
if (!is_array($tab)) {
|
|
|
|
$tab = array($name => $tab);
|
|
|
|
}
|
|
|
|
return $tab;
|
|
|
|
}
|
|
|
|
return array();
|
|
|
|
}
|
|
|
|
}
|
2014-04-28 14:03:52 +02:00
|
|
|
// @codeCoverageIgnoreEnd
|