2013-10-22 14:26:45 +02:00
|
|
|
<?php
|
2016-02-08 15:41:00 +01:00
|
|
|
/* Icinga Web 2 | (c) 2013 Icinga Development Team | GPLv2+ */
|
2013-10-22 14:26:45 +02:00
|
|
|
|
|
|
|
namespace Icinga\Cli;
|
|
|
|
|
2019-07-11 11:54:52 +02:00
|
|
|
use Icinga\Application\ApplicationBootstrap as App;
|
|
|
|
use Icinga\Application\Config;
|
2019-07-11 11:54:15 +02:00
|
|
|
use Icinga\Application\Logger;
|
2019-07-11 11:54:52 +02:00
|
|
|
use Icinga\Exception\IcingaException;
|
2019-07-11 11:54:15 +02:00
|
|
|
use Icinga\Exception\NotReadableError;
|
2014-01-29 16:25:08 +01:00
|
|
|
use Icinga\Util\Translator;
|
2013-10-22 14:26:45 +02:00
|
|
|
|
|
|
|
abstract class Command
|
|
|
|
{
|
|
|
|
protected $app;
|
|
|
|
protected $docs;
|
2014-12-30 14:33:36 +01:00
|
|
|
|
|
|
|
/**
|
2015-03-12 13:39:17 +01:00
|
|
|
* @var Params
|
2014-12-30 14:33:36 +01:00
|
|
|
*/
|
2013-10-22 14:26:45 +02:00
|
|
|
protected $params;
|
|
|
|
protected $screen;
|
2016-01-19 15:07:17 +01:00
|
|
|
|
|
|
|
/**
|
2016-01-21 11:29:28 +01:00
|
|
|
* Whether the --verbose switch is given and thus the set log level INFO is
|
|
|
|
*
|
|
|
|
* @var bool
|
2016-01-19 15:07:17 +01:00
|
|
|
*/
|
2013-10-22 14:26:45 +02:00
|
|
|
protected $isVerbose;
|
|
|
|
|
2016-01-21 11:29:28 +01:00
|
|
|
/**
|
|
|
|
* Whether the --debug switch is given and thus the set log level DEBUG is
|
|
|
|
*
|
|
|
|
* @var bool
|
|
|
|
*/
|
|
|
|
protected $isDebugging;
|
|
|
|
|
2013-10-22 14:26:45 +02:00
|
|
|
protected $moduleName;
|
|
|
|
protected $commandName;
|
|
|
|
protected $actionName;
|
2014-03-06 13:08:11 +01:00
|
|
|
|
2015-11-03 16:11:20 +01:00
|
|
|
protected $config;
|
2014-08-19 10:27:26 +02:00
|
|
|
|
2015-11-03 16:11:20 +01:00
|
|
|
protected $configs;
|
2014-08-19 10:27:26 +02:00
|
|
|
|
2013-10-22 14:26:45 +02:00
|
|
|
protected $defaultActionName = 'default';
|
|
|
|
|
2019-07-11 11:54:15 +02:00
|
|
|
/** @var bool Whether to automatically load enabled modules */
|
|
|
|
protected $loadEnabledModules = true;
|
|
|
|
|
2013-10-22 14:26:45 +02:00
|
|
|
public function __construct(App $app, $moduleName, $commandName, $actionName, $initialize = true)
|
|
|
|
{
|
|
|
|
$this->app = $app;
|
2018-09-24 13:48:22 +02:00
|
|
|
$this->moduleName = $moduleName;
|
|
|
|
$this->commandName = $commandName;
|
|
|
|
$this->actionName = $actionName;
|
|
|
|
$this->params = $app->getParams();
|
2020-11-24 16:47:59 +01:00
|
|
|
$this->screen = Screen::instance();
|
2018-09-24 13:48:22 +02:00
|
|
|
$this->trace = $this->params->shift('trace', false);
|
|
|
|
$this->isVerbose = $this->params->shift('verbose', false);
|
|
|
|
$this->isDebugging = $this->params->shift('debug', false);
|
|
|
|
$this->configs = [];
|
2019-07-11 11:54:15 +02:00
|
|
|
|
|
|
|
if ($this->loadEnabledModules) {
|
|
|
|
try {
|
|
|
|
$app->getModuleManager()->loadEnabledModules();
|
|
|
|
} catch (NotReadableError $e) {
|
|
|
|
Logger::error(new IcingaException('Cannot load enabled modules. An exception was thrown:', $e));
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2013-10-22 14:26:45 +02:00
|
|
|
if ($initialize) {
|
|
|
|
$this->init();
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2014-08-19 10:27:26 +02:00
|
|
|
public function Config($file = null)
|
|
|
|
{
|
|
|
|
if ($this->isModule()) {
|
|
|
|
return $this->getModuleConfig($file);
|
|
|
|
} else {
|
|
|
|
return $this->getMainConfig($file);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
private function getModuleConfig($file = null)
|
|
|
|
{
|
|
|
|
if ($file === null) {
|
|
|
|
if ($this->config === null) {
|
|
|
|
$this->config = Config::module($this->moduleName);
|
|
|
|
}
|
|
|
|
return $this->config;
|
|
|
|
} else {
|
|
|
|
if (! array_key_exists($file, $this->configs)) {
|
|
|
|
$this->configs[$file] = Config::module($this->moduleName, $file);
|
|
|
|
}
|
|
|
|
return $this->configs[$file];
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
private function getMainConfig($file = null)
|
|
|
|
{
|
|
|
|
if ($file === null) {
|
|
|
|
if ($this->config === null) {
|
|
|
|
$this->config = Config::app();
|
|
|
|
}
|
|
|
|
return $this->config;
|
|
|
|
} else {
|
|
|
|
if (! array_key_exists($file, $this->configs)) {
|
2019-04-26 14:37:06 +02:00
|
|
|
$this->configs[$file] = Config::app($file);
|
2014-08-19 10:27:26 +02:00
|
|
|
}
|
|
|
|
return $this->configs[$file];
|
|
|
|
}
|
|
|
|
return $this->config;
|
|
|
|
}
|
|
|
|
|
|
|
|
public function isModule()
|
|
|
|
{
|
|
|
|
return substr(get_class($this), 0, 14) === 'Icinga\\Module\\';
|
|
|
|
}
|
|
|
|
|
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)
|
|
|
|
{
|
2015-11-03 10:45:39 +01:00
|
|
|
throw new IcingaException('%s', $msg);
|
2013-10-22 14:26:45 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
public function getDefaultActionName()
|
|
|
|
{
|
|
|
|
return $this->defaultActionName;
|
|
|
|
}
|
|
|
|
|
2017-05-30 17:55:52 +02:00
|
|
|
/**
|
|
|
|
* Get {@link moduleName}
|
|
|
|
*
|
|
|
|
* @return string
|
|
|
|
*/
|
|
|
|
public function getModuleName()
|
|
|
|
{
|
|
|
|
return $this->moduleName;
|
|
|
|
}
|
|
|
|
|
2013-10-22 14:26:45 +02:00
|
|
|
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
|
|
|
|
);
|
2019-05-21 08:48:38 +02:00
|
|
|
return false;
|
2013-10-22 14:26:45 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
public function init()
|
|
|
|
{
|
|
|
|
}
|
|
|
|
}
|