235 lines
6.0 KiB
PHP
235 lines
6.0 KiB
PHP
<?php
|
|
// {{{ICINGA_LICENSE_HEADER}}}
|
|
// {{{ICINGA_LICENSE_HEADER}}}
|
|
|
|
namespace Icinga\Logger;
|
|
|
|
use Exception;
|
|
use Zend_Config;
|
|
use Icinga\Exception\ConfigurationError;
|
|
|
|
/**
|
|
* Singleton logger
|
|
*/
|
|
class Logger
|
|
{
|
|
/**
|
|
* This logger's instance
|
|
*
|
|
* @var Logger
|
|
*/
|
|
protected static $instance;
|
|
|
|
/**
|
|
* The log writer to use
|
|
*
|
|
* @var \Icinga\Logger\LogWriter
|
|
*/
|
|
protected $writer;
|
|
|
|
/**
|
|
* The configured type
|
|
*
|
|
* @string Type (syslog, file)
|
|
*/
|
|
protected $type = 'none';
|
|
|
|
/**
|
|
* The maximum severity to emit
|
|
*
|
|
* @var int
|
|
*/
|
|
protected $verbosity;
|
|
|
|
/**
|
|
* The supported severities
|
|
*/
|
|
public static $ERROR = 0;
|
|
public static $WARNING = 1;
|
|
public static $INFO = 2;
|
|
public static $DEBUG = 3;
|
|
|
|
/**
|
|
* Create a new logger object
|
|
*
|
|
* @param Zend_Config $config
|
|
*/
|
|
public function __construct(Zend_Config $config)
|
|
{
|
|
$this->verbosity = $config->level;
|
|
|
|
if ($config->enable) {
|
|
$this->writer = $this->createWriter($config);
|
|
}
|
|
}
|
|
|
|
/**
|
|
* Create a new logger object
|
|
*
|
|
* @param Zend_Config $config
|
|
*/
|
|
public static function create(Zend_Config $config)
|
|
{
|
|
static::$instance = new static($config);
|
|
}
|
|
|
|
/**
|
|
* Return a log writer
|
|
*
|
|
* @param Zend_Config $config The configuration to initialize the writer with
|
|
*
|
|
* @return \Icinga\Logger\LogWriter The requested log writer
|
|
* @throws ConfigurationError If the requested writer cannot be found
|
|
*/
|
|
protected function createWriter(Zend_Config $config)
|
|
{
|
|
$class = 'Icinga\\Logger\\Writer\\' . ucfirst(strtolower($config->type)) . 'Writer';
|
|
if (!class_exists($class)) {
|
|
throw new ConfigurationError(
|
|
'Cannot find log writer of type "%s"',
|
|
$config->type
|
|
);
|
|
}
|
|
$this->type = $config->type;
|
|
|
|
return new $class($config);
|
|
}
|
|
|
|
/**
|
|
* Write a message to the log
|
|
*
|
|
* @param string $message The message to write
|
|
* @param int $severity The severity to use
|
|
*/
|
|
public function log($message, $severity)
|
|
{
|
|
if ($this->writer !== null && $this->verbosity >= $severity) {
|
|
$this->writer->log($severity, $message);
|
|
}
|
|
}
|
|
|
|
/**
|
|
* Return a string representation of the passed arguments
|
|
*
|
|
* This method provides three different processing techniques:
|
|
* - If the only passed argument is a string it is returned unchanged
|
|
* - If the only passed argument is an exception it is formatted as follows:
|
|
* <name> in <file>:<line> with message: <message>[ <- <name> ...]
|
|
* - If multiple arguments are passed the first is interpreted as format-string
|
|
* that gets substituted with the remaining ones which can be of any type
|
|
*
|
|
* @param array $arguments The arguments to format
|
|
*
|
|
* @return string The formatted result
|
|
*/
|
|
protected static function formatMessage(array $arguments)
|
|
{
|
|
if (count($arguments) === 1) {
|
|
$message = $arguments[0];
|
|
|
|
if ($message instanceof Exception) {
|
|
$messages = array();
|
|
$error = $message;
|
|
do {
|
|
$messages[] = sprintf(
|
|
'%s in %s:%d with message: %s',
|
|
get_class($error),
|
|
$error->getFile(),
|
|
$error->getLine(),
|
|
$error->getMessage()
|
|
);
|
|
} while ($error = $error->getPrevious());
|
|
$message = implode(' <- ', $messages);
|
|
}
|
|
|
|
return $message;
|
|
}
|
|
|
|
return vsprintf(
|
|
array_shift($arguments),
|
|
array_map(
|
|
function ($a) { return is_string($a) ? $a : json_encode($a); },
|
|
$arguments
|
|
)
|
|
);
|
|
}
|
|
|
|
/**
|
|
* Log a message with severity ERROR
|
|
*
|
|
* @param mixed $arg,... A string, exception or format-string + substitutions
|
|
*/
|
|
public static function error()
|
|
{
|
|
if (static::$instance !== null && func_num_args() > 0) {
|
|
static::$instance->log(static::formatMessage(func_get_args()), static::$ERROR);
|
|
}
|
|
}
|
|
|
|
/**
|
|
* Log a message with severity WARNING
|
|
*
|
|
* @param mixed $arg,... A string, exception or format-string + substitutions
|
|
*/
|
|
public static function warning()
|
|
{
|
|
if (static::$instance !== null && func_num_args() > 0) {
|
|
static::$instance->log(static::formatMessage(func_get_args()), static::$WARNING);
|
|
}
|
|
}
|
|
|
|
/**
|
|
* Log a message with severity INFO
|
|
*
|
|
* @param mixed $arg,... A string, exception or format-string + substitutions
|
|
*/
|
|
public static function info()
|
|
{
|
|
if (static::$instance !== null && func_num_args() > 0) {
|
|
static::$instance->log(static::formatMessage(func_get_args()), static::$INFO);
|
|
}
|
|
}
|
|
|
|
/**
|
|
* Log a message with severity DEBUG
|
|
*
|
|
* @param mixed $arg,... A string, exception or format-string + substitutions
|
|
*/
|
|
public static function debug()
|
|
{
|
|
if (static::$instance !== null && func_num_args() > 0) {
|
|
static::$instance->log(static::formatMessage(func_get_args()), static::$DEBUG);
|
|
}
|
|
}
|
|
|
|
/**
|
|
* Get the log writer to use
|
|
*
|
|
* @return \Icinga\Logger\LogWriter
|
|
*/
|
|
public function getWriter()
|
|
{
|
|
return $this->writer;
|
|
}
|
|
|
|
public static function writesToSyslog()
|
|
{
|
|
return static::$instance && static::$instance->type === 'syslog';
|
|
}
|
|
|
|
public static function writesToFile()
|
|
{
|
|
return static::$instance && static::$instance->type === 'file';
|
|
}
|
|
|
|
/**
|
|
* Get this' instance
|
|
*
|
|
* @return Logger
|
|
*/
|
|
public static function getInstance()
|
|
{
|
|
return static::$instance;
|
|
}
|
|
}
|