ILIAS  release_5-3 Revision v5.3.23-19-g915713cf615
FluentdFormatter.php
Go to the documentation of this file.
1<?php
2
3/*
4 * This file is part of the Monolog package.
5 *
6 * (c) Jordi Boggiano <j.boggiano@seld.be>
7 *
8 * For the full copyright and license information, please view the LICENSE
9 * file that was distributed with this source code.
10 */
11
12namespace Monolog\Formatter;
13
36{
40 protected $levelTag = false;
41
42 public function __construct($levelTag = false)
43 {
44 if (!function_exists('json_encode')) {
45 throw new \RuntimeException('PHP\'s json extension is required to use Monolog\'s FluentdUnixFormatter');
46 }
47
48 $this->levelTag = (bool) $levelTag;
49 }
50
51 public function isUsingLevelsInTag()
52 {
53 return $this->levelTag;
54 }
55
56 public function format(array $record)
57 {
58 $tag = $record['channel'];
59 if ($this->levelTag) {
60 $tag .= '.' . strtolower($record['level_name']);
61 }
62
63 $message = array(
64 'message' => $record['message'],
65 'extra' => $record['extra'],
66 );
67
68 if (!$this->levelTag) {
69 $message['level'] = $record['level'];
70 $message['level_name'] = $record['level_name'];
71 }
72
73 return json_encode(array($tag, $record['datetime']->getTimestamp(), $message));
74 }
75
76 public function formatBatch(array $records)
77 {
78 $message = '';
79 foreach ($records as $record) {
80 $message .= $this->format($record);
81 }
82
83 return $message;
84 }
85}
An exception for terminatinating execution or to throw for unit testing.
formatBatch(array $records)
Formats a set of log records.
format(array $record)
Formats a log record.
if(function_exists( 'posix_getuid') &&posix_getuid()===0) if(!array_key_exists('t', $options)) $tag
Definition: cron.php:35
catch(Exception $e) $message
$records
Definition: simple_test.php:22