1
0
mirror of https://github.com/Seldaek/monolog.git synced 2025-10-21 08:36:33 +02:00

Rename to GroupHandler, remove callback support, add couple of tests

This commit is contained in:
lenar
2011-05-10 18:04:41 +03:00
parent 6fcc54d09f
commit 0eb5896c5b
2 changed files with 43 additions and 0 deletions

View File

@@ -0,0 +1,82 @@
<?php
/*
* This file is part of the Monolog package.
*
* (c) Jordi Boggiano <j.boggiano@seld.be>
*
* For the full copyright and license information, please view the LICENSE
* file that was distributed with this source code.
*/
namespace Monolog\Handler;
use Monolog\Logger;
/**
* Forwards records to multiple handlers
*
* @author Lenar Lõhmus <lenar@city.ee>
*/
class ForwarderHandler extends AbstractHandler
{
private $handlersInitialized;
protected $handlers;
/**
* @param Array $handlers Array of Handlers or factory callbacks($record, $fingersCrossedHandler).
* @param Boolean $bubble Whether the messages that are handled can bubble up the stack or not
*/
public function __construct(array $handlers, $bubble = false)
{
$this->handlersInitialized = false;
$this->handlers = $handlers;
$this->bubble = $bubble;
}
/**
* {@inheritdoc}
*/
public function handle(array $record)
{
$this->handlersInitialized || $this->initializeHandlers();
foreach ($this->handlers as $handler) {
$handler->handle($record);
}
return false === $this->bubble;
}
/**
* {@inheritdoc}
*/
public function handleBatch(array $records)
{
$this->handlersInitialized || $this->initializeHandlers();
foreach ($this->handlers as $handler) {
$handler->handleBatch($records);
}
}
/**
* Implemented to comply with the AbstractHandler requirements. Can not be called.
*/
protected function write(array $record)
{
throw new \BadMethodCallException('This method should not be called directly on the ForwarderHandler.');
}
private function initializeHandlers()
{
foreach ($this->handlers as &$handler) {
if (!$handler instanceof HandlerInterface) {
$handler = call_user_func($handler, $record, $this);
if (!$handler instanceof HandlerInterface) {
throw new \RuntimeException("The factory callback should return a HandlerInterface");
}
}
}
$this->handlersInitialized = true;
}
}