2013-06-07 11:44:37 +02:00
|
|
|
<?php
|
2013-07-12 15:00:59 +02:00
|
|
|
// {{{ICINGA_LICENSE_HEADER}}}
|
|
|
|
// {{{ICINGA_LICENSE_HEADER}}}
|
|
|
|
|
2013-06-07 11:44:37 +02:00
|
|
|
namespace Icinga\Application;
|
|
|
|
|
2014-10-16 15:51:18 +02:00
|
|
|
use ErrorException;
|
2014-02-18 14:46:15 +01:00
|
|
|
use Exception;
|
2014-02-26 11:19:52 +01:00
|
|
|
use Icinga\Application\Modules\Manager as ModuleManager;
|
2013-09-24 15:26:10 +02:00
|
|
|
use Icinga\Data\ResourceFactory;
|
2014-02-26 11:19:52 +01:00
|
|
|
use Icinga\Exception\ConfigurationError;
|
2014-02-20 13:53:28 +01:00
|
|
|
use Icinga\Exception\NotReadableError;
|
2014-10-31 10:27:17 +01:00
|
|
|
use Icinga\Application\Logger;
|
2014-02-26 11:19:52 +01:00
|
|
|
use Icinga\Util\DateTimeFactory;
|
|
|
|
use Icinga\Util\Translator;
|
2014-11-04 14:35:57 +01:00
|
|
|
use Icinga\File\Ini\IniWriter;
|
2014-08-27 16:03:15 +02:00
|
|
|
use Icinga\Exception\IcingaException;
|
2013-06-07 11:44:37 +02:00
|
|
|
|
|
|
|
/**
|
|
|
|
* This class bootstraps a thin Icinga application layer
|
|
|
|
*
|
|
|
|
* Usage example for CLI:
|
|
|
|
* <code>
|
|
|
|
* use Icinga\Application\Cli;
|
2013-06-20 14:06:02 +02:00
|
|
|
|
2013-06-07 11:44:37 +02:00
|
|
|
* Cli::start();
|
|
|
|
* </code>
|
|
|
|
*
|
|
|
|
* Usage example for Icinga Web application:
|
|
|
|
* <code>
|
|
|
|
* use Icinga\Application\Web;
|
|
|
|
* Web::start()->dispatch();
|
|
|
|
* </code>
|
|
|
|
*
|
|
|
|
* Usage example for Icinga-Web 1.x compatibility mode:
|
|
|
|
* <code>
|
|
|
|
* use Icinga\Application\LegacyWeb;
|
|
|
|
* LegacyWeb::start()->setIcingaWebBasedir(ICINGAWEB_BASEDIR)->dispatch();
|
|
|
|
* </code>
|
|
|
|
*/
|
|
|
|
abstract class ApplicationBootstrap
|
|
|
|
{
|
2014-11-12 15:52:43 +01:00
|
|
|
/**
|
|
|
|
* Base directory
|
|
|
|
*
|
|
|
|
* Parent folder for at least application, bin, modules, library/vendor and public
|
|
|
|
*
|
|
|
|
* @var string
|
|
|
|
*/
|
|
|
|
protected $baseDir;
|
|
|
|
|
2014-11-13 09:33:31 +01:00
|
|
|
/**
|
|
|
|
* Application directory
|
|
|
|
*
|
|
|
|
* @var string
|
|
|
|
*/
|
|
|
|
protected $appDir;
|
|
|
|
|
2013-07-26 15:58:16 +02:00
|
|
|
/**
|
2014-11-13 09:38:04 +01:00
|
|
|
* Vendor library directory
|
2013-07-26 15:58:16 +02:00
|
|
|
*
|
2014-11-13 09:38:04 +01:00
|
|
|
* @var string
|
2013-07-26 15:58:16 +02:00
|
|
|
*/
|
2014-11-13 09:38:04 +01:00
|
|
|
protected $vendorDir;
|
2013-07-26 15:58:16 +02:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Library directory
|
|
|
|
*
|
|
|
|
* @var string
|
|
|
|
*/
|
2014-11-13 09:38:04 +01:00
|
|
|
protected $libDir;
|
2013-07-26 15:58:16 +02:00
|
|
|
|
|
|
|
/**
|
2014-11-13 09:38:04 +01:00
|
|
|
* Configuration directory
|
2013-07-26 15:58:16 +02:00
|
|
|
*
|
2014-11-13 09:38:04 +01:00
|
|
|
* @var string
|
2013-07-26 15:58:16 +02:00
|
|
|
*/
|
2014-11-13 09:38:04 +01:00
|
|
|
protected $configDir;
|
2013-07-26 15:58:16 +02:00
|
|
|
|
|
|
|
/**
|
2014-11-13 09:38:04 +01:00
|
|
|
* Icinga auto loader
|
2013-07-26 15:58:16 +02:00
|
|
|
*
|
2014-11-13 09:38:04 +01:00
|
|
|
* @var Loader
|
|
|
|
*/
|
|
|
|
private $loader;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Config object
|
|
|
|
*
|
|
|
|
* @var Config
|
2013-07-26 15:58:16 +02:00
|
|
|
*/
|
2014-11-13 09:38:04 +01:00
|
|
|
protected $config;
|
2013-07-26 15:58:16 +02:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Module manager
|
|
|
|
*
|
|
|
|
* @var ModuleManager
|
|
|
|
*/
|
|
|
|
private $moduleManager;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Flag indicates we're on cli environment
|
|
|
|
*
|
|
|
|
* @var bool
|
|
|
|
*/
|
2013-06-07 11:44:37 +02:00
|
|
|
protected $isCli = false;
|
2013-07-26 15:58:16 +02:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Flag indicates we're on web environment
|
2013-08-06 17:35:33 +02:00
|
|
|
*
|
2013-07-26 15:58:16 +02:00
|
|
|
* @var bool
|
|
|
|
*/
|
2013-06-07 11:44:37 +02:00
|
|
|
protected $isWeb = false;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Constructor
|
2014-11-12 15:52:43 +01:00
|
|
|
*
|
|
|
|
* @param string $baseDir Icinga Web 2 base directory
|
|
|
|
* @param string $configDir Path to Icinga Web 2's configuration files
|
2013-06-07 11:44:37 +02:00
|
|
|
*/
|
2014-11-12 15:52:43 +01:00
|
|
|
protected function __construct($baseDir = null, $configDir = null)
|
2013-06-07 11:44:37 +02:00
|
|
|
{
|
2014-11-12 15:52:43 +01:00
|
|
|
if ($baseDir === null) {
|
2014-11-12 17:14:09 +01:00
|
|
|
$baseDir = dirname($this->getBootstrapDirectory());
|
2014-11-12 15:52:43 +01:00
|
|
|
}
|
|
|
|
$this->baseDir = $baseDir;
|
2014-11-13 09:33:31 +01:00
|
|
|
$this->appDir = $baseDir . '/application';
|
2014-11-13 09:38:04 +01:00
|
|
|
$this->vendorDir = $baseDir . '/library/vendor';
|
2014-11-12 14:39:45 +01:00
|
|
|
$this->libDir = realpath(__DIR__ . '/../..');
|
2013-06-07 11:44:37 +02:00
|
|
|
|
2014-04-17 19:01:23 +02:00
|
|
|
if ($configDir === null) {
|
|
|
|
if (array_key_exists('ICINGAWEB_CONFIGDIR', $_SERVER)) {
|
|
|
|
$configDir = $_SERVER['ICINGAWEB_CONFIGDIR'];
|
|
|
|
} else {
|
|
|
|
$configDir = '/etc/icingaweb';
|
|
|
|
}
|
|
|
|
}
|
2014-06-25 11:53:55 +02:00
|
|
|
$canonical = realpath($configDir);
|
|
|
|
$this->configDir = $canonical ? $canonical : $configDir;
|
2014-04-17 19:01:23 +02:00
|
|
|
|
2013-07-26 15:58:16 +02:00
|
|
|
$this->setupAutoloader();
|
|
|
|
$this->setupZendAutoloader();
|
2013-06-14 13:51:44 +02:00
|
|
|
|
2013-06-07 11:44:37 +02:00
|
|
|
Benchmark::measure('Bootstrap, autoloader registered');
|
|
|
|
|
|
|
|
Icinga::setApp($this);
|
2013-07-26 15:58:16 +02:00
|
|
|
|
2013-06-07 11:44:37 +02:00
|
|
|
require_once dirname(__FILE__) . '/functions.php';
|
|
|
|
}
|
|
|
|
|
2013-07-26 15:58:16 +02:00
|
|
|
/**
|
|
|
|
* Bootstrap interface method for concrete bootstrap objects
|
|
|
|
*
|
|
|
|
* @return mixed
|
|
|
|
*/
|
2013-06-07 11:44:37 +02:00
|
|
|
abstract protected function bootstrap();
|
|
|
|
|
2013-07-26 15:58:16 +02:00
|
|
|
/**
|
|
|
|
* Getter for module manager
|
|
|
|
*
|
|
|
|
* @return ModuleManager
|
|
|
|
*/
|
|
|
|
public function getModuleManager()
|
2013-06-07 11:44:37 +02:00
|
|
|
{
|
|
|
|
return $this->moduleManager;
|
|
|
|
}
|
|
|
|
|
2013-07-12 15:00:59 +02:00
|
|
|
/**
|
|
|
|
* Getter for class loader
|
2013-07-26 15:58:16 +02:00
|
|
|
*
|
2013-07-12 15:00:59 +02:00
|
|
|
* @return Loader
|
|
|
|
*/
|
2013-06-07 11:44:37 +02:00
|
|
|
public function getLoader()
|
|
|
|
{
|
|
|
|
return $this->loader;
|
|
|
|
}
|
|
|
|
|
2013-07-26 15:58:16 +02:00
|
|
|
/**
|
|
|
|
* Getter for configuration object
|
|
|
|
*
|
|
|
|
* @return Config
|
|
|
|
*/
|
|
|
|
public function getConfig()
|
2013-06-07 11:44:37 +02:00
|
|
|
{
|
2013-07-26 15:58:16 +02:00
|
|
|
return $this->config;
|
2013-06-07 11:44:37 +02:00
|
|
|
}
|
|
|
|
|
2013-07-26 15:58:16 +02:00
|
|
|
/**
|
|
|
|
* Flag indicates we're on cli environment
|
|
|
|
*
|
|
|
|
* @return bool
|
|
|
|
*/
|
2013-06-07 11:44:37 +02:00
|
|
|
public function isCli()
|
|
|
|
{
|
|
|
|
return $this->isCli;
|
|
|
|
}
|
|
|
|
|
2013-07-26 15:58:16 +02:00
|
|
|
/**
|
|
|
|
* Flag indicates we're on web environment
|
|
|
|
*
|
|
|
|
* @return bool
|
|
|
|
*/
|
2013-06-07 11:44:37 +02:00
|
|
|
public function isWeb()
|
|
|
|
{
|
|
|
|
return $this->isWeb;
|
|
|
|
}
|
|
|
|
|
2014-11-12 15:52:43 +01:00
|
|
|
/**
|
|
|
|
* Helper to glue directories together
|
|
|
|
*
|
|
|
|
* @param string $dir
|
|
|
|
* @param string $subdir
|
|
|
|
*
|
|
|
|
* @return string
|
|
|
|
*/
|
|
|
|
private function getDirWithSubDir($dir, $subdir = null)
|
|
|
|
{
|
|
|
|
if ($subdir !== null) {
|
|
|
|
$dir .= '/' . ltrim($subdir, '/');
|
|
|
|
}
|
|
|
|
|
|
|
|
return $dir;
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Get the base directory
|
|
|
|
*
|
|
|
|
* @param string $subDir Optional sub directory to get
|
|
|
|
*
|
|
|
|
* @return string
|
|
|
|
*/
|
|
|
|
public function getBaseDir($subDir = null)
|
|
|
|
{
|
2014-11-13 09:33:31 +01:00
|
|
|
return $this->getDirWithSubDir($this->baseDir, $subDir);
|
2014-11-12 15:52:43 +01:00
|
|
|
}
|
|
|
|
|
2013-07-26 15:58:16 +02:00
|
|
|
/**
|
2014-11-13 09:33:31 +01:00
|
|
|
* Get the application directory
|
2013-07-26 15:58:16 +02:00
|
|
|
*
|
2014-11-13 09:33:31 +01:00
|
|
|
* @param string $subDir Optional sub directory to get
|
2013-08-23 09:57:32 +02:00
|
|
|
*
|
|
|
|
* @return string
|
2013-07-26 15:58:16 +02:00
|
|
|
*/
|
2014-11-13 09:33:31 +01:00
|
|
|
public function getApplicationDir($subDir = null)
|
2013-06-07 11:44:37 +02:00
|
|
|
{
|
2014-11-13 09:33:31 +01:00
|
|
|
return $this->getDirWithSubDir($this->appDir, $subDir);
|
2013-07-30 16:02:05 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
2014-11-13 09:38:04 +01:00
|
|
|
* Get the vendor library directory
|
2013-08-23 09:57:32 +02:00
|
|
|
*
|
2014-11-13 09:38:04 +01:00
|
|
|
* @param string $subDir Optional sub directory to get
|
|
|
|
*
|
|
|
|
* @return string
|
|
|
|
*/
|
|
|
|
public function getVendorDir($subDir = null)
|
|
|
|
{
|
|
|
|
return $this->getDirWithSubDir($this->vendorDir, $subDir);
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Get the configuration directory
|
|
|
|
*
|
|
|
|
* @param string $subDir Optional sub directory to get
|
2013-08-23 09:57:32 +02:00
|
|
|
*
|
|
|
|
* @return string
|
2013-07-30 16:02:05 +02:00
|
|
|
*/
|
2014-11-13 09:38:04 +01:00
|
|
|
public function getConfigDir($subDir = null)
|
2013-07-30 16:02:05 +02:00
|
|
|
{
|
2014-11-13 09:38:04 +01:00
|
|
|
return $this->getDirWithSubDir($this->configDir, $subDir);
|
2013-07-30 16:02:05 +02:00
|
|
|
}
|
|
|
|
|
2014-03-04 16:13:13 +01:00
|
|
|
/**
|
2014-11-12 17:10:05 +01:00
|
|
|
* Get the path to the bootstrapping directory
|
2014-03-04 16:13:13 +01:00
|
|
|
*
|
2014-11-12 17:10:05 +01:00
|
|
|
* This is usually /public for Web and EmbeddedWeb and /bin for the CLI
|
2014-03-04 16:13:13 +01:00
|
|
|
*
|
|
|
|
* @return string
|
|
|
|
*/
|
2014-11-12 17:14:09 +01:00
|
|
|
public function getBootstrapDirectory()
|
2014-03-04 16:13:13 +01:00
|
|
|
{
|
2014-11-12 17:10:05 +01:00
|
|
|
return dirname(realpath($_SERVER['SCRIPT_FILENAME']));
|
2014-03-04 16:13:13 +01:00
|
|
|
}
|
|
|
|
|
2013-07-30 16:02:05 +02:00
|
|
|
/**
|
2014-11-12 15:52:43 +01:00
|
|
|
* Start the bootstrap
|
2013-07-26 15:58:16 +02:00
|
|
|
*
|
2014-11-12 15:52:43 +01:00
|
|
|
* @param string $baseDir Icinga Web 2 base directory
|
|
|
|
* @param string $configDir Path to Icinga Web 2's configuration files
|
2013-08-23 09:57:32 +02:00
|
|
|
*
|
2014-11-12 15:52:43 +01:00
|
|
|
* @return static
|
2013-07-26 15:58:16 +02:00
|
|
|
*/
|
2014-11-12 15:52:43 +01:00
|
|
|
public static function start($baseDir = null, $configDir = null)
|
2013-06-07 11:44:37 +02:00
|
|
|
{
|
2014-11-12 15:52:43 +01:00
|
|
|
$application = new static($baseDir, $configDir);
|
2013-08-23 09:57:32 +02:00
|
|
|
$application->bootstrap();
|
|
|
|
return $application;
|
|
|
|
}
|
|
|
|
|
2013-07-26 15:58:16 +02:00
|
|
|
/**
|
2013-08-23 09:57:32 +02:00
|
|
|
* Setup Icinga auto loader
|
2013-07-26 15:58:16 +02:00
|
|
|
*
|
|
|
|
* @return self
|
|
|
|
*/
|
|
|
|
public function setupAutoloader()
|
2013-07-12 15:00:59 +02:00
|
|
|
{
|
2014-02-12 14:51:04 +01:00
|
|
|
require $this->libDir . '/Icinga/Application/Loader.php';
|
2013-07-12 15:00:59 +02:00
|
|
|
|
|
|
|
$this->loader = new Loader();
|
2013-07-26 15:58:16 +02:00
|
|
|
$this->loader->registerNamespace('Icinga', $this->libDir. '/Icinga');
|
2013-07-12 15:00:59 +02:00
|
|
|
$this->loader->register();
|
2013-07-26 15:58:16 +02:00
|
|
|
|
|
|
|
return $this;
|
2013-07-12 15:00:59 +02:00
|
|
|
}
|
|
|
|
|
2013-06-07 11:44:37 +02:00
|
|
|
/**
|
|
|
|
* Register the Zend Autoloader
|
|
|
|
*
|
|
|
|
* @return self
|
|
|
|
*/
|
2013-07-26 15:58:16 +02:00
|
|
|
protected function setupZendAutoloader()
|
2013-06-07 11:44:37 +02:00
|
|
|
{
|
|
|
|
require_once 'Zend/Loader/Autoloader.php';
|
2013-07-26 15:58:16 +02:00
|
|
|
|
|
|
|
\Zend_Loader_Autoloader::getInstance();
|
|
|
|
|
|
|
|
// Unfortunately this is needed to get the Zend Plugin loader working:
|
|
|
|
set_include_path(
|
|
|
|
implode(
|
|
|
|
PATH_SEPARATOR,
|
|
|
|
array($this->libDir, get_include_path())
|
|
|
|
)
|
|
|
|
);
|
|
|
|
|
2013-06-07 11:44:37 +02:00
|
|
|
return $this;
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
2014-01-22 18:11:26 +01:00
|
|
|
* Setup module manager
|
2013-06-07 11:44:37 +02:00
|
|
|
*
|
|
|
|
* @return self
|
|
|
|
*/
|
2014-01-22 18:11:26 +01:00
|
|
|
protected function setupModuleManager()
|
2013-06-07 11:44:37 +02:00
|
|
|
{
|
2014-01-24 10:48:30 +01:00
|
|
|
$this->moduleManager = new ModuleManager(
|
|
|
|
$this,
|
|
|
|
$this->configDir . '/enabledModules',
|
2014-11-13 09:33:31 +01:00
|
|
|
explode(':', $this->config->fromSection('global', 'modulePath', $this->baseDir . '/modules'))
|
2014-01-24 10:48:30 +01:00
|
|
|
);
|
2014-01-22 18:11:26 +01:00
|
|
|
return $this;
|
|
|
|
}
|
2013-06-07 11:44:37 +02:00
|
|
|
|
2014-11-10 17:34:49 +01:00
|
|
|
/**
|
|
|
|
* Load all core modules
|
|
|
|
*
|
|
|
|
* @return self
|
|
|
|
*/
|
|
|
|
protected function loadCoreModules()
|
|
|
|
{
|
|
|
|
try {
|
|
|
|
$this->moduleManager->loadCoreModules();
|
|
|
|
} catch (NotReadableError $e) {
|
|
|
|
Logger::error(new IcingaException('Cannot load core modules. An exception was thrown:', $e));
|
|
|
|
}
|
|
|
|
return $this;
|
|
|
|
}
|
|
|
|
|
2014-01-22 18:11:26 +01:00
|
|
|
/**
|
|
|
|
* Load all enabled modules
|
|
|
|
*
|
|
|
|
* @return self
|
|
|
|
*/
|
|
|
|
protected function loadEnabledModules()
|
|
|
|
{
|
2013-09-02 12:47:57 +02:00
|
|
|
try {
|
|
|
|
$this->moduleManager->loadEnabledModules();
|
2014-02-20 13:53:28 +01:00
|
|
|
} catch (NotReadableError $e) {
|
2014-08-27 16:03:15 +02:00
|
|
|
Logger::error(new IcingaException('Cannot load enabled modules. An exception was thrown:', $e));
|
2013-09-02 12:47:57 +02:00
|
|
|
}
|
2013-07-26 15:58:16 +02:00
|
|
|
return $this;
|
2013-06-07 11:44:37 +02:00
|
|
|
}
|
|
|
|
|
2014-02-26 11:19:52 +01:00
|
|
|
/**
|
|
|
|
* Setup default logging
|
|
|
|
*
|
|
|
|
* @return self
|
|
|
|
*/
|
|
|
|
protected function setupLogging()
|
|
|
|
{
|
|
|
|
Logger::create(
|
2014-11-07 13:53:03 +01:00
|
|
|
new Config(
|
2014-02-26 11:19:52 +01:00
|
|
|
array(
|
2014-10-16 15:59:56 +02:00
|
|
|
'log' => 'syslog'
|
2014-02-26 11:19:52 +01:00
|
|
|
)
|
|
|
|
)
|
|
|
|
);
|
|
|
|
return $this;
|
|
|
|
}
|
|
|
|
|
2013-06-07 11:44:37 +02:00
|
|
|
/**
|
|
|
|
* Load Configuration
|
|
|
|
*
|
|
|
|
* @return self
|
|
|
|
*/
|
2014-02-12 14:51:04 +01:00
|
|
|
protected function loadConfig()
|
2013-06-07 11:44:37 +02:00
|
|
|
{
|
2013-07-12 15:37:36 +02:00
|
|
|
Config::$configDir = $this->configDir;
|
2014-10-21 17:02:21 +02:00
|
|
|
|
2014-02-20 13:53:28 +01:00
|
|
|
try {
|
|
|
|
$this->config = Config::app();
|
|
|
|
} catch (NotReadableError $e) {
|
2014-08-27 16:03:15 +02:00
|
|
|
Logger::error(new IcingaException('Cannot load application configuration. An exception was thrown:', $e));
|
2014-11-07 13:53:03 +01:00
|
|
|
$this->config = new Config();
|
2014-02-20 13:53:28 +01:00
|
|
|
}
|
2014-10-21 17:02:21 +02:00
|
|
|
|
2013-06-07 11:44:37 +02:00
|
|
|
return $this;
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Error handling configuration
|
|
|
|
*
|
|
|
|
* @return self
|
|
|
|
*/
|
2013-07-26 15:58:16 +02:00
|
|
|
protected function setupErrorHandling()
|
2013-06-07 11:44:37 +02:00
|
|
|
{
|
2014-09-19 13:19:24 +02:00
|
|
|
error_reporting(E_ALL | E_STRICT);
|
2014-02-14 10:48:17 +01:00
|
|
|
ini_set('display_startup_errors', 1);
|
|
|
|
ini_set('display_errors', 1);
|
2014-10-16 15:51:18 +02:00
|
|
|
set_error_handler(function ($errno, $errstr, $errfile, $errline) {
|
|
|
|
if (error_reporting() === 0) {
|
|
|
|
// Error was suppressed with the @-operator
|
|
|
|
return false; // Continue with the normal error handler
|
|
|
|
}
|
|
|
|
switch($errno) {
|
2014-11-04 13:20:41 +01:00
|
|
|
case E_WARNING:
|
2014-10-16 15:51:18 +02:00
|
|
|
case E_STRICT:
|
|
|
|
throw new ErrorException($errstr, 0, $errno, $errfile, $errline);
|
|
|
|
}
|
|
|
|
return false; // Continue with the normal error handler
|
|
|
|
});
|
2014-02-14 10:48:17 +01:00
|
|
|
return $this;
|
|
|
|
}
|
2014-02-26 11:19:52 +01:00
|
|
|
|
2014-02-14 10:48:17 +01:00
|
|
|
/**
|
|
|
|
* Set up logger
|
|
|
|
*
|
|
|
|
* @return self
|
|
|
|
*/
|
|
|
|
protected function setupLogger()
|
|
|
|
{
|
2014-11-11 15:30:11 +01:00
|
|
|
if (($loggingConfig = $this->config->logging) !== null) {
|
2014-03-03 19:03:39 +01:00
|
|
|
try {
|
2014-11-07 13:53:03 +01:00
|
|
|
Logger::create($loggingConfig);
|
2014-03-03 19:03:39 +01:00
|
|
|
} catch (ConfigurationError $e) {
|
|
|
|
Logger::error($e);
|
|
|
|
}
|
2014-02-26 11:19:52 +01:00
|
|
|
}
|
2013-06-07 11:44:37 +02:00
|
|
|
return $this;
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
2014-02-20 13:53:28 +01:00
|
|
|
* Set up the resource factory
|
2013-08-13 18:08:21 +02:00
|
|
|
*
|
|
|
|
* @return self
|
|
|
|
*/
|
2013-09-24 15:26:10 +02:00
|
|
|
protected function setupResourceFactory()
|
2013-08-13 18:08:21 +02:00
|
|
|
{
|
2014-02-20 13:53:28 +01:00
|
|
|
try {
|
|
|
|
$config = Config::app('resources');
|
|
|
|
ResourceFactory::setConfig($config);
|
|
|
|
} catch (NotReadableError $e) {
|
2014-03-03 19:03:39 +01:00
|
|
|
Logger::error(
|
2014-08-27 16:03:15 +02:00
|
|
|
new IcingaException('Cannot load resource configuration. An exception was thrown:', $e)
|
2014-02-20 13:53:28 +01:00
|
|
|
);
|
|
|
|
}
|
|
|
|
|
2013-08-13 18:08:21 +02:00
|
|
|
return $this;
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Setup default timezone
|
2013-06-07 11:44:37 +02:00
|
|
|
*
|
2013-08-23 09:57:32 +02:00
|
|
|
* @return self
|
|
|
|
* @throws ConfigurationError if the timezone in config.ini isn't valid
|
2013-06-07 11:44:37 +02:00
|
|
|
*/
|
2013-07-26 15:58:16 +02:00
|
|
|
protected function setupTimezone()
|
2013-06-07 11:44:37 +02:00
|
|
|
{
|
2014-06-20 12:54:37 +02:00
|
|
|
$default = @date_default_timezone_get();
|
|
|
|
if (! $default) {
|
|
|
|
$default = 'UTC';
|
|
|
|
}
|
2014-11-07 13:53:03 +01:00
|
|
|
$timeZoneString = $this->config->fromSection('global', 'timezone', $default);
|
2013-08-12 11:21:30 +02:00
|
|
|
date_default_timezone_set($timeZoneString);
|
2014-04-17 16:38:56 +02:00
|
|
|
DateTimeFactory::setConfig(array('timezone' => $timeZoneString));
|
2013-06-07 11:44:37 +02:00
|
|
|
return $this;
|
|
|
|
}
|
2014-01-29 16:25:08 +01:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Setup internationalization using gettext
|
|
|
|
*
|
2014-06-25 11:49:47 +02:00
|
|
|
* Uses the preferred language sent by the browser or the default one
|
2014-01-29 16:25:08 +01:00
|
|
|
*
|
|
|
|
* @return self
|
|
|
|
*/
|
|
|
|
protected function setupInternationalization()
|
|
|
|
{
|
2014-09-02 16:51:17 +02:00
|
|
|
if ($this->hasLocales()) {
|
|
|
|
Translator::registerDomain(Translator::DEFAULT_DOMAIN, $this->getLocaleDir());
|
2014-06-25 11:49:47 +02:00
|
|
|
}
|
|
|
|
|
2014-02-03 12:22:13 +01:00
|
|
|
try {
|
2014-02-20 13:53:28 +01:00
|
|
|
Translator::setupLocale(
|
2014-06-25 11:49:47 +02:00
|
|
|
isset($_SERVER['HTTP_ACCEPT_LANGUAGE'])
|
|
|
|
? Translator::getPreferredLocaleCode($_SERVER['HTTP_ACCEPT_LANGUAGE'])
|
2014-02-20 13:53:28 +01:00
|
|
|
: Translator::DEFAULT_LOCALE
|
|
|
|
);
|
2014-02-03 12:22:13 +01:00
|
|
|
} catch (Exception $error) {
|
2014-02-26 11:19:52 +01:00
|
|
|
Logger::error($error);
|
2014-02-03 12:22:13 +01:00
|
|
|
}
|
2014-01-29 16:25:08 +01:00
|
|
|
|
|
|
|
return $this;
|
|
|
|
}
|
2014-09-02 16:51:17 +02:00
|
|
|
|
|
|
|
/**
|
|
|
|
* @return string Our locale directory
|
|
|
|
*/
|
|
|
|
public function getLocaleDir()
|
|
|
|
{
|
|
|
|
return $this->getApplicationDir('locale');
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* return bool Whether Icinga Web has translations
|
|
|
|
*/
|
|
|
|
public function hasLocales()
|
|
|
|
{
|
|
|
|
$localedir = $this->getLocaleDir();
|
|
|
|
return file_exists($localedir) && is_dir($localedir);
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* List all available locales
|
|
|
|
*
|
|
|
|
* NOTE: Might be a candidate for a static function in Translator
|
|
|
|
*
|
|
|
|
* return array Locale list
|
|
|
|
*/
|
|
|
|
public function listLocales()
|
|
|
|
{
|
|
|
|
$locales = array();
|
|
|
|
if (! $this->hasLocales()) {
|
|
|
|
return $locales;
|
|
|
|
}
|
|
|
|
$localedir = $this->getLocaleDir();
|
|
|
|
|
|
|
|
$dh = opendir($localedir);
|
|
|
|
while (false !== ($file = readdir($dh))) {
|
|
|
|
$filename = $localedir . DIRECTORY_SEPARATOR . $file;
|
|
|
|
if (preg_match('/^[a-z]{2}_[A-Z]{2}$/', $file) && is_dir($filename)) {
|
|
|
|
$locales[] = $file;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
closedir($dh);
|
|
|
|
sort($locales);
|
|
|
|
return $locales;
|
|
|
|
}
|
2013-06-07 11:44:37 +02:00
|
|
|
}
|