66 lines
1.3 KiB
PHP
66 lines
1.3 KiB
PHP
<?php defined('SYSPATH') OR die('No direct script access.');
|
|
/**
|
|
* Syslog log writer.
|
|
*
|
|
* @package Kohana
|
|
* @category Logging
|
|
* @author Jeremy Bush
|
|
* @copyright (c) 2012 Kohana Team
|
|
* @license http://kohanaframework.org/license
|
|
*/
|
|
class Kohana_Log_Syslog extends Log_Writer {
|
|
|
|
/**
|
|
* @var string The syslog identifier
|
|
*/
|
|
protected $_ident;
|
|
|
|
/**
|
|
* Creates a new syslog logger.
|
|
*
|
|
* @link http://www.php.net/manual/function.openlog
|
|
*
|
|
* @param string $ident syslog identifier
|
|
* @param int $facility facility to log to
|
|
* @return void
|
|
*/
|
|
public function __construct($ident = 'KohanaPHP', $facility = LOG_USER)
|
|
{
|
|
$this->_ident = $ident;
|
|
|
|
// Open the connection to syslog
|
|
openlog($this->_ident, LOG_CONS, $facility);
|
|
}
|
|
|
|
/**
|
|
* Writes each of the messages into the syslog.
|
|
*
|
|
* @param array $messages
|
|
* @return void
|
|
*/
|
|
public function write(array $messages)
|
|
{
|
|
foreach ($messages as $message)
|
|
{
|
|
syslog($message['level'], $message['body']);
|
|
|
|
if (isset($message['additional']['exception']))
|
|
{
|
|
syslog(Log_Writer::$strace_level, $message['additional']['exception']->getTraceAsString());
|
|
}
|
|
}
|
|
}
|
|
|
|
/**
|
|
* Closes the syslog connection
|
|
*
|
|
* @return void
|
|
*/
|
|
public function __destruct()
|
|
{
|
|
// Close connection to syslog
|
|
closelog();
|
|
}
|
|
|
|
} // End Kohana_Log_Syslog
|