This repository has been archived on 2024-04-08. You can view files and clone it, but cannot push or open issues or pull requests.

66 lines
1.3 KiB
PHP
Raw Normal View History

2012-11-09 23:18:50 +11:00
<?php defined('SYSPATH') OR die('No direct script access.');
2010-08-21 14:43:03 +10:00
/**
* Syslog log writer.
*
* @package Kohana
* @category Logging
* @author Jeremy Bush
2012-11-09 23:18:50 +11:00
* @copyright (c) 2012 Kohana Team
2011-05-13 16:00:25 +10:00
* @license http://kohanaframework.org/license
2010-08-21 14:43:03 +10:00
*/
2011-05-13 16:00:25 +10:00
class Kohana_Log_Syslog extends Log_Writer {
2010-08-21 14:43:03 +10:00
2011-05-13 16:00:25 +10:00
/**
* @var string The syslog identifier
*/
2010-08-21 14:43:03 +10:00
protected $_ident;
/**
* Creates a new syslog logger.
*
2012-11-09 23:18:50 +11:00
* @link http://www.php.net/manual/function.openlog
2010-08-21 14:43:03 +10:00
*
2012-11-09 23:18:50 +11:00
* @param string $ident syslog identifier
* @param int $facility facility to log to
2010-08-21 14:43:03 +10:00
* @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.
*
2012-11-09 23:18:50 +11:00
* @param array $messages
2010-08-21 14:43:03 +10:00
* @return void
*/
public function write(array $messages)
{
foreach ($messages as $message)
{
2011-05-13 16:00:25 +10:00
syslog($message['level'], $message['body']);
2012-11-09 23:18:50 +11:00
if (isset($message['additional']['exception']))
{
syslog(Log_Writer::$strace_level, $message['additional']['exception']->getTraceAsString());
}
2010-08-21 14:43:03 +10:00
}
}
/**
* Closes the syslog connection
*
* @return void
*/
public function __destruct()
{
// Close connection to syslog
closelog();
}
2011-05-13 16:00:25 +10:00
} // End Kohana_Log_Syslog