2014-01-24 16:41:37 +01:00
|
|
|
<?php
|
|
|
|
// @codingStandardsIgnoreStart
|
|
|
|
// {{{ICINGA_LICENSE_HEADER}}}
|
|
|
|
// {{{ICINGA_LICENSE_HEADER}}}
|
|
|
|
|
|
|
|
use Icinga\Application\Icinga;
|
2014-02-03 15:39:53 +01:00
|
|
|
use Icinga\Module\Doc\Controller as DocController;
|
2014-01-24 16:41:37 +01:00
|
|
|
|
2014-02-03 15:39:53 +01:00
|
|
|
class Doc_ModuleController extends DocController
|
2014-01-24 16:41:37 +01:00
|
|
|
{
|
|
|
|
/**
|
|
|
|
* Display module documentations index
|
|
|
|
*/
|
|
|
|
public function indexAction()
|
|
|
|
{
|
2014-02-03 15:39:53 +01:00
|
|
|
$this->view->enabledModules = Icinga::app()->getModuleManager()->listEnabledModules();
|
2014-01-24 16:41:37 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Display a module's documentation
|
|
|
|
*/
|
2014-02-03 15:39:53 +01:00
|
|
|
public function viewAction()
|
2014-01-24 16:41:37 +01:00
|
|
|
{
|
2014-02-11 15:27:42 +01:00
|
|
|
$this->populateView($this->getParam('name'));
|
2014-01-24 16:41:37 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Provide run-time dispatching of module documentation
|
|
|
|
*
|
|
|
|
* @param string $methodName
|
|
|
|
* @param array $args
|
|
|
|
*
|
|
|
|
* @return mixed
|
|
|
|
*/
|
|
|
|
public function __call($methodName, $args)
|
|
|
|
{
|
|
|
|
// TODO(el): Setup routing to retrieve module name as param and point route to moduleAction
|
|
|
|
$moduleManager = Icinga::app()->getModuleManager();
|
|
|
|
$moduleName = substr($methodName, 0, -6); // Strip 'Action' suffix
|
|
|
|
if (!$moduleManager->hasEnabled($moduleName)) {
|
|
|
|
// TODO(el): Throw a not found exception once the code has been moved to the moduleAction (see TODO above)
|
|
|
|
return parent::__call($methodName, $args);
|
|
|
|
}
|
2014-02-03 15:39:53 +01:00
|
|
|
$this->_helper->redirector->gotoSimpleAndExit('view', null, null, array('name' => $moduleName));
|
2014-01-24 16:41:37 +01:00
|
|
|
}
|
|
|
|
}
|
|
|
|
// @codingStandardsIgnoreEnd
|