2015-02-10 17:14:16 +01:00
|
|
|
<?php
|
|
|
|
/* Icinga Web 2 | (c) 2013-2015 Icinga Development Team | GPLv2+ */
|
|
|
|
|
|
|
|
use Icinga\Application\Icinga;
|
|
|
|
use Icinga\Module\Doc\DocController;
|
|
|
|
use Icinga\Module\Doc\DocParser;
|
2015-02-11 13:22:27 +01:00
|
|
|
use Icinga\Module\Doc\Exception\DocException;
|
2015-08-27 14:22:59 +02:00
|
|
|
use Icinga\Module\Doc\Renderer\DocSearchRenderer;
|
2015-02-10 17:14:16 +01:00
|
|
|
use Icinga\Module\Doc\Search\DocSearch;
|
|
|
|
use Icinga\Module\Doc\Search\DocSearchIterator;
|
|
|
|
|
|
|
|
class Doc_SearchController extends DocController
|
|
|
|
{
|
2015-02-11 13:22:27 +01:00
|
|
|
/**
|
|
|
|
* Render search
|
|
|
|
*/
|
2015-02-10 17:14:16 +01:00
|
|
|
public function indexAction()
|
|
|
|
{
|
2015-02-11 13:22:27 +01:00
|
|
|
$parser = new DocParser($this->getWebPath());
|
2015-02-10 17:14:16 +01:00
|
|
|
$search = new DocSearchRenderer(
|
|
|
|
new DocSearchIterator(
|
|
|
|
$parser->getDocTree()->getIterator(),
|
|
|
|
new DocSearch($this->params->get('q'))
|
|
|
|
)
|
|
|
|
);
|
2015-02-11 13:22:27 +01:00
|
|
|
$search->setUrl('doc/icingaweb/chapter');
|
2015-03-13 08:52:54 +01:00
|
|
|
if (strlen($this->params->get('q')) < 3) {
|
|
|
|
$this->view->searches = array();
|
|
|
|
return;
|
|
|
|
}
|
2015-02-11 13:22:27 +01:00
|
|
|
$searches = array(
|
|
|
|
'Icinga Web 2' => $search
|
|
|
|
);
|
|
|
|
foreach (Icinga::app()->getModuleManager()->listEnabledModules() as $module) {
|
|
|
|
if (($path = $this->getModulePath($module)) !== null) {
|
|
|
|
try {
|
|
|
|
$parser = new DocParser($path);
|
2015-03-13 08:56:37 +01:00
|
|
|
$search = new DocSearchRenderer(
|
|
|
|
new DocSearchIterator(
|
|
|
|
$parser->getDocTree()->getIterator(),
|
|
|
|
new DocSearch($this->params->get('q'))
|
|
|
|
)
|
|
|
|
);
|
2015-02-11 13:22:27 +01:00
|
|
|
} catch (DocException $e) {
|
|
|
|
continue;
|
|
|
|
}
|
|
|
|
$search
|
|
|
|
->setUrl('doc/module/chapter')
|
|
|
|
->setUrlParams(array('moduleName' => $module));
|
|
|
|
$searches[$module] = $search;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
$this->view->searches = $searches;
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Get the path to a module's documentation
|
|
|
|
*
|
|
|
|
* @param string $module
|
|
|
|
*
|
|
|
|
* @return string|null
|
|
|
|
*/
|
|
|
|
protected function getModulePath($module)
|
|
|
|
{
|
|
|
|
if (is_dir(($path = Icinga::app()->getModuleManager()->getModuleDir($module, '/doc')))) {
|
|
|
|
return $path;
|
|
|
|
}
|
|
|
|
if (($path = $this->Config()->get('documentation', 'modules')) !== null) {
|
|
|
|
$path = str_replace('{module}', $module, $path);
|
|
|
|
if (is_dir($path)) {
|
|
|
|
return $path;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
return null;
|
2015-02-10 17:14:16 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Get the path to Icinga Web 2's documentation
|
|
|
|
*
|
|
|
|
* @return string
|
|
|
|
*
|
|
|
|
* @throws Zend_Controller_Action_Exception If Icinga Web 2's documentation is not available
|
|
|
|
*/
|
2015-02-11 13:22:27 +01:00
|
|
|
protected function getWebPath()
|
2015-02-10 17:14:16 +01:00
|
|
|
{
|
|
|
|
$path = Icinga::app()->getBaseDir('doc');
|
|
|
|
if (is_dir($path)) {
|
|
|
|
return $path;
|
|
|
|
}
|
|
|
|
if (($path = $this->Config()->get('documentation', 'icingaweb2')) !== null) {
|
|
|
|
if (is_dir($path)) {
|
|
|
|
return $path;
|
|
|
|
}
|
|
|
|
}
|
2015-07-28 13:47:25 +02:00
|
|
|
$this->httpNotFound($this->translate('Documentation for Icinga Web 2 is not available'));
|
2015-02-10 17:14:16 +01:00
|
|
|
}
|
|
|
|
}
|