2013-10-22 14:26:45 +02:00
|
|
|
<?php
|
2015-02-04 10:46:36 +01:00
|
|
|
/* Icinga Web 2 | (c) 2013-2015 Icinga Development Team | GPLv2+ */
|
2013-10-22 14:26:45 +02:00
|
|
|
|
|
|
|
namespace Icinga\Cli;
|
|
|
|
|
|
|
|
use Icinga\Application\ApplicationBootstrap as App;
|
|
|
|
use Icinga\Cli\Documentation\CommentParser;
|
|
|
|
use ReflectionClass;
|
|
|
|
use ReflectionMethod;
|
|
|
|
|
|
|
|
class Documentation
|
|
|
|
{
|
|
|
|
protected $icinga;
|
|
|
|
|
|
|
|
public function __construct(App $app)
|
|
|
|
{
|
|
|
|
$this->app = $app;
|
|
|
|
$this->loader = $app->cliLoader();
|
|
|
|
}
|
|
|
|
|
|
|
|
public function usage($module = null, $command = null, $action = null)
|
|
|
|
{
|
2013-10-22 15:52:00 +02:00
|
|
|
if ($module) {
|
|
|
|
$module = $this->loader->resolveModuleName($module);
|
2013-10-22 14:26:45 +02:00
|
|
|
return $this->moduleUsage($module, $command, $action);
|
|
|
|
}
|
2013-10-22 15:52:00 +02:00
|
|
|
if ($command) {
|
|
|
|
$command = $this->loader->resolveCommandName($command);
|
2013-10-22 14:26:45 +02:00
|
|
|
return $this->commandUsage($command, $action);
|
|
|
|
}
|
|
|
|
return $this->globalUsage();
|
|
|
|
}
|
|
|
|
|
|
|
|
public function globalUsage()
|
|
|
|
{
|
2014-03-19 17:25:53 +01:00
|
|
|
$d = "USAGE: icingacli [module] <command> [action] [options]\n\n"
|
2013-10-22 14:26:45 +02:00
|
|
|
. "Available commands:\n\n";
|
|
|
|
foreach ($this->loader->listCommands() as $command) {
|
2014-02-21 14:07:32 +01:00
|
|
|
if ($command !== 'autocomplete') {
|
|
|
|
$obj = $this->loader->getCommandInstance($command);
|
|
|
|
$d .= sprintf(
|
|
|
|
" %-14s %s\n",
|
|
|
|
$command,
|
|
|
|
$this->getClassTitle($obj)
|
|
|
|
);
|
|
|
|
}
|
2013-10-22 14:26:45 +02:00
|
|
|
}
|
|
|
|
$d .= "\nAvailable modules:\n\n";
|
|
|
|
foreach ($this->loader->listModules() as $module) {
|
|
|
|
$d .= ' ' . $module . "\n";
|
|
|
|
}
|
|
|
|
$d .= "\nGlobal options:\n\n"
|
2016-01-21 11:47:11 +01:00
|
|
|
. " --log [t] Log to <t>, either stderr, file or syslog (default: stderr)\n"
|
2016-01-21 11:29:28 +01:00
|
|
|
. " --log-path <f> Which file to log into in case of --log file\n"
|
|
|
|
. " --verbose Be verbose\n"
|
|
|
|
. " --debug Show debug output\n"
|
|
|
|
. " --help Show help\n"
|
|
|
|
. " --benchmark Show benchmark summary\n"
|
|
|
|
. " --watch [s] Refresh output every <s> seconds (default: 5)\n"
|
2013-10-22 14:26:45 +02:00
|
|
|
;
|
2014-03-19 17:25:53 +01:00
|
|
|
$d .= "\nShow help on a specific command : icingacli help <command>"
|
|
|
|
. "\nShow help on a specific module : icingacli help <module>"
|
2013-10-22 14:26:45 +02:00
|
|
|
. "\n";
|
|
|
|
return $d;
|
|
|
|
}
|
|
|
|
|
|
|
|
public function moduleUsage($module, $command = null, $action = null)
|
|
|
|
{
|
|
|
|
$commands = $this->loader->listModuleCommands($module);
|
2014-03-06 13:08:11 +01:00
|
|
|
|
2013-10-22 14:26:45 +02:00
|
|
|
if (empty($commands)) {
|
|
|
|
return "The '$module' module does not provide any CLI commands\n";
|
|
|
|
}
|
|
|
|
$d = '';
|
|
|
|
if ($command) {
|
|
|
|
$obj = $this->loader->getModuleCommandInstance($module, $command);
|
|
|
|
}
|
|
|
|
if ($command === null) {
|
2014-03-19 17:25:53 +01:00
|
|
|
$d = "USAGE: icingacli $module <command> [<action>] [options]\n\n"
|
2013-10-22 14:26:45 +02:00
|
|
|
. "Available commands:\n\n";
|
|
|
|
foreach ($commands as $command) {
|
|
|
|
$d .= ' ' . $command . "\n";
|
|
|
|
}
|
2014-03-19 17:25:53 +01:00
|
|
|
$d .= "\nShow help on a specific command: icingacli help $module <command>\n";
|
2013-10-22 14:26:45 +02:00
|
|
|
} elseif ($action === null) {
|
|
|
|
$d .= $this->showCommandActions($obj, $command);
|
|
|
|
} else {
|
2013-10-22 15:52:00 +02:00
|
|
|
$action = $this->loader->resolveObjectActionName($obj, $action);
|
2013-10-22 14:26:45 +02:00
|
|
|
$d .= $this->getMethodDocumentation($obj, $action);
|
|
|
|
}
|
|
|
|
return $d;
|
|
|
|
}
|
|
|
|
|
|
|
|
protected function showCommandActions($command, $name)
|
|
|
|
{
|
|
|
|
$actions = $command->listActions();
|
|
|
|
$d = $this->getClassDocumentation($command)
|
|
|
|
. "Available actions:\n\n";
|
|
|
|
foreach ($actions as $action) {
|
|
|
|
$d .= sprintf(
|
|
|
|
" %-14s %s\n",
|
|
|
|
$action,
|
|
|
|
$this->getMethodTitle($command, $action)
|
|
|
|
);
|
|
|
|
}
|
2014-03-19 17:25:53 +01:00
|
|
|
$d .= "\nShow help on a specific action: icingacli help $name <action>\n";
|
2013-10-22 14:26:45 +02:00
|
|
|
return $d;
|
|
|
|
}
|
|
|
|
|
|
|
|
public function commandUsage($command, $action = null)
|
|
|
|
{
|
|
|
|
$obj = $this->loader->getCommandInstance($command);
|
2013-10-22 15:52:00 +02:00
|
|
|
$action = $this->loader->resolveObjectActionName($obj, $action);
|
|
|
|
|
2013-10-22 14:26:45 +02:00
|
|
|
$d = "\n";
|
2013-10-22 15:52:00 +02:00
|
|
|
if ($action) {
|
2013-10-22 14:26:45 +02:00
|
|
|
$d .= $this->getMethodDocumentation($obj, $action);
|
2013-10-22 15:52:00 +02:00
|
|
|
} else {
|
|
|
|
$d .= $this->showCommandActions($obj, $command);
|
2013-10-22 14:26:45 +02:00
|
|
|
}
|
|
|
|
return $d;
|
|
|
|
}
|
|
|
|
|
|
|
|
protected function getClassTitle($class)
|
|
|
|
{
|
|
|
|
$ref = new ReflectionClass($class);
|
|
|
|
$comment = new CommentParser($ref->getDocComment());
|
|
|
|
return $comment->getTitle();
|
|
|
|
}
|
|
|
|
|
|
|
|
protected function getClassDocumentation($class)
|
|
|
|
{
|
|
|
|
$ref = new ReflectionClass($class);
|
|
|
|
$comment = new CommentParser($ref->getDocComment());
|
|
|
|
return $comment->dump();
|
|
|
|
}
|
|
|
|
|
|
|
|
protected function getMethodTitle($class, $method)
|
|
|
|
{
|
|
|
|
$ref = new ReflectionMethod($class, $method . 'Action');
|
|
|
|
$comment = new CommentParser($ref->getDocComment());
|
|
|
|
return $comment->getTitle();
|
|
|
|
}
|
|
|
|
|
|
|
|
protected function getMethodDocumentation($class, $method)
|
|
|
|
{
|
|
|
|
$ref = new ReflectionMethod($class, $method . 'Action');
|
|
|
|
$comment = new CommentParser($ref->getDocComment());
|
|
|
|
return $comment->dump();
|
|
|
|
}
|
|
|
|
}
|