2013-10-22 14:26:45 +02:00
|
|
|
<?php
|
|
|
|
|
|
|
|
namespace Icinga\Cli;
|
|
|
|
|
|
|
|
use Icinga\Cli\Screen;
|
2014-01-29 16:25:08 +01:00
|
|
|
use Icinga\Util\Translator;
|
2014-02-14 14:19:56 +01:00
|
|
|
use Icinga\Cli\Params;
|
2013-10-22 14:26:45 +02:00
|
|
|
use Icinga\Application\ApplicationBootstrap as App;
|
|
|
|
use Exception;
|
|
|
|
|
|
|
|
abstract class Command
|
|
|
|
{
|
|
|
|
protected $app;
|
|
|
|
protected $docs;
|
|
|
|
protected $params;
|
|
|
|
protected $screen;
|
|
|
|
protected $isVerbose;
|
|
|
|
protected $isDebugging;
|
|
|
|
|
|
|
|
protected $moduleName;
|
|
|
|
protected $commandName;
|
|
|
|
protected $actionName;
|
|
|
|
|
|
|
|
protected $defaultActionName = 'default';
|
|
|
|
|
|
|
|
public function __construct(App $app, $moduleName, $commandName, $actionName, $initialize = true)
|
|
|
|
{
|
|
|
|
$this->app = $app;
|
|
|
|
$this->moduleName = $moduleName;
|
|
|
|
$this->commandName = $commandName;
|
|
|
|
$this->actionName = $actionName;
|
2014-01-22 13:08:20 +01:00
|
|
|
$this->params = $app->getParams();
|
|
|
|
$this->screen = Screen::instance($app);
|
|
|
|
$this->trace = $this->params->shift('trace', false);
|
2013-10-22 14:26:45 +02:00
|
|
|
$this->isVerbose = $this->params->shift('verbose', false);
|
|
|
|
$this->isDebuging = $this->params->shift('debug', false);
|
|
|
|
if ($initialize) {
|
|
|
|
$this->init();
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2014-02-14 14:19:56 +01:00
|
|
|
public function setParams(Params $params)
|
|
|
|
{
|
|
|
|
$this->params = $params;
|
|
|
|
}
|
|
|
|
|
2013-10-22 14:26:45 +02:00
|
|
|
public function hasRemainingParams()
|
|
|
|
{
|
|
|
|
return $this->params->count() > 0;
|
|
|
|
}
|
|
|
|
|
2014-01-22 13:08:20 +01:00
|
|
|
public function showTrace()
|
|
|
|
{
|
|
|
|
return $this->trace;
|
|
|
|
}
|
|
|
|
|
2014-01-29 16:25:08 +01:00
|
|
|
/**
|
|
|
|
* Translate a string
|
|
|
|
*
|
|
|
|
* Autoselects the module domain, if any, and falls back to the global one if no translation could be found.
|
|
|
|
*
|
|
|
|
* @param string $text The string to translate
|
|
|
|
*
|
|
|
|
* @return string The translated string
|
|
|
|
*/
|
|
|
|
public function translate($text)
|
|
|
|
{
|
|
|
|
$domain = $this->moduleName === null ? 'icinga' : $this->moduleName;
|
|
|
|
return Translator::translate($text, $domain);
|
|
|
|
}
|
|
|
|
|
2013-10-22 14:26:45 +02:00
|
|
|
public function fail($msg)
|
|
|
|
{
|
|
|
|
throw new Exception($msg);
|
|
|
|
}
|
|
|
|
|
|
|
|
public function getDefaultActionName()
|
|
|
|
{
|
|
|
|
return $this->defaultActionName;
|
|
|
|
}
|
|
|
|
|
|
|
|
public function hasDefaultActionName()
|
|
|
|
{
|
|
|
|
return $this->hasActionName($this->defaultActionName);
|
|
|
|
}
|
|
|
|
|
|
|
|
public function hasActionName($name)
|
|
|
|
{
|
|
|
|
$actions = $this->listActions();
|
|
|
|
return in_array($name, $actions);
|
|
|
|
}
|
|
|
|
|
|
|
|
public function listActions()
|
|
|
|
{
|
|
|
|
$actions = array();
|
|
|
|
foreach (get_class_methods($this) as $method) {
|
|
|
|
if (preg_match('~^([A-Za-z0-9]+)Action$~', $method, $m)) {
|
|
|
|
$actions[] = $m[1];
|
|
|
|
}
|
|
|
|
}
|
|
|
|
sort($actions);
|
|
|
|
return $actions;
|
|
|
|
}
|
|
|
|
|
|
|
|
public function docs()
|
|
|
|
{
|
|
|
|
if ($this->docs === null) {
|
|
|
|
$this->docs = new Documentation($this->app);
|
|
|
|
}
|
|
|
|
return $this->docs;
|
|
|
|
}
|
|
|
|
|
|
|
|
public function showUsage($action = null)
|
|
|
|
{
|
|
|
|
if ($action === null) {
|
|
|
|
$action = $this->actionName;
|
|
|
|
}
|
|
|
|
echo $this->docs()->usage(
|
|
|
|
$this->moduleName,
|
|
|
|
$this->commandName,
|
|
|
|
$action
|
|
|
|
);
|
|
|
|
}
|
|
|
|
|
|
|
|
public function init()
|
|
|
|
{
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|