summaryrefslogtreecommitdiffstats
path: root/src/Monolog/Handler/AbstractProcessingHandler.php
diff options
context:
space:
mode:
authorChristophe Coevoet <stof@notk.org>2011-05-11 18:43:04 +0200
committerChristophe Coevoet <stof@notk.org>2011-05-11 18:43:04 +0200
commit0defabb726d25b05f9d3d1b0d8d97300756730b6 (patch)
tree9a25ecf71f0e7449988193791ff915e7fc23ee61 /src/Monolog/Handler/AbstractProcessingHandler.php
parent1d6697294d8ecca1b06fa6cf41ec551ba26d4f64 (diff)
downloadmonolog-0defabb726d25b05f9d3d1b0d8d97300756730b6.zip
monolog-0defabb726d25b05f9d3d1b0d8d97300756730b6.tar.gz
monolog-0defabb726d25b05f9d3d1b0d8d97300756730b6.tar.bz2
Refactored the AbstractHandler to avoid having some dummy write() methods
Diffstat (limited to 'src/Monolog/Handler/AbstractProcessingHandler.php')
-rw-r--r--src/Monolog/Handler/AbstractProcessingHandler.php80
1 files changed, 80 insertions, 0 deletions
diff --git a/src/Monolog/Handler/AbstractProcessingHandler.php b/src/Monolog/Handler/AbstractProcessingHandler.php
new file mode 100644
index 0000000..d334448
--- /dev/null
+++ b/src/Monolog/Handler/AbstractProcessingHandler.php
@@ -0,0 +1,80 @@
+<?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;
+use Monolog\Formatter\FormatterInterface;
+use Monolog\Formatter\LineFormatter;
+
+/**
+ * Base Handler class providing the Handler structure
+ *
+ * Classes extending it should (in most cases) only implement write($record)
+ *
+ * @author Jordi Boggiano <j.boggiano@seld.be>
+ * @author Christophe Coevoet <stof@notk.org>
+ */
+abstract class AbstractProcessingHandler extends AbstractHandler
+{
+ /**
+ * {@inheritdoc}
+ */
+ public function handle(array $record)
+ {
+ if ($record['level'] < $this->level) {
+ return false;
+ }
+
+ $record = $this->processRecord($record);
+
+ $record['message'] = $this->getFormatter()->format($record);
+
+ $this->write($record);
+
+ return false === $this->bubble;
+ }
+
+ /**
+ * {@inheritdoc}
+ */
+ public function handleBatch(array $records)
+ {
+ foreach ($records as $record) {
+ $this->handle($record);
+ }
+ }
+
+ /**
+ * Writes the record down to the log of the implementing handler
+ *
+ * @param array $record
+ * @return void
+ */
+ abstract protected function write(array $record);
+
+ /**
+ * Processes a record.
+ *
+ * @param array $record
+ * @return array
+ */
+ protected function processRecord(array $record)
+ {
+ if ($this->processors) {
+ foreach ($this->processors as $processor) {
+ $record = call_user_func($processor, $record);
+ }
+ }
+
+ return $record;
+ }
+}