forked from RomeroMsk/yii2-graylog2
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathGraylogTarget.php
132 lines (125 loc) · 5 KB
/
GraylogTarget.php
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
<?php
/**
* @copyright Copyright (c) 2014 Roman Ovchinnikov
* @link https://github.com/RomeroMsk
* @version 1.0.1
*/
namespace nex\graylog;
use Yii;
use yii\helpers\ArrayHelper;
use yii\helpers\VarDumper;
use yii\log\Target;
use yii\log\Logger;
use Gelf;
use Psr\Log\LogLevel;
/**
* GraylogTarget sends log to Graylog2 (in GELF format)
*
* @author Roman Ovchinnikov <[email protected]>
* @link https://github.com/RomeroMsk/yii2-graylog2
*/
class GraylogTarget extends Target
{
/**
* @var string Graylog2 host
*/
public $host = '127.0.0.1';
/**
* @var integer Graylog2 port
*/
public $port = 12201;
/**
* @var string default facility name
*/
public $facility = 'yii2-logs';
/**
* @var boolean whether to add authenticated user username to additional fields
*/
public $addUsername = false;
/**
* @var array graylog levels
*/
private $_levels = [
Logger::LEVEL_TRACE => LogLevel::DEBUG,
Logger::LEVEL_PROFILE_BEGIN => LogLevel::DEBUG,
Logger::LEVEL_PROFILE_END => LogLevel::DEBUG,
Logger::LEVEL_INFO => LogLevel::INFO,
Logger::LEVEL_WARNING => LogLevel::WARNING,
Logger::LEVEL_ERROR => LogLevel::ERROR,
];
/**
* Sends log messages to Graylog2 input
*/
public function export()
{
$transport = new Gelf\Transport\UdpTransport($this->host, $this->port, Gelf\Transport\UdpTransport::CHUNK_SIZE_LAN);
$publisher = new Gelf\Publisher($transport);
foreach ($this->messages as $message) {
list($text, $level, $category, $timestamp) = $message;
$gelfMsg = new Gelf\Message;
// Set base parameters
$gelfMsg->setLevel(ArrayHelper::getValue($this->_levels, $level, LogLevel::INFO))
->setTimestamp($timestamp)
->setFacility($this->facility)
->setAdditional('category', $category)
->setFile('unknown')
->setLine(0);
// For string log message set only shortMessage
if (is_string($text)) {
$gelfMsg->setShortMessage($text);
} elseif ($text instanceof \Exception) {
$gelfMsg->setShortMessage('Exception ' . get_class($text) . ': ' . $text->getMessage());
$gelfMsg->setFullMessage((string) $text);
$gelfMsg->setLine($text->getLine());
$gelfMsg->setFile($text->getFile());
} else {
// If log message contains special keys 'short', 'full' or 'add', will use them as shortMessage, fullMessage and additionals respectively
$short = ArrayHelper::remove($text, 'short');
$full = ArrayHelper::remove($text, 'full');
$add = ArrayHelper::remove($text, 'add');
// If 'short' is set
if ($short !== null) {
$gelfMsg->setShortMessage($short);
// All remaining message is fullMessage by default
$gelfMsg->setFullMessage(VarDumper::dumpAsString($text));
} else {
// Will use log message as shortMessage by default (no need to add fullMessage in this case)
$gelfMsg->setShortMessage(VarDumper::dumpAsString($text));
}
// If 'full' is set will use it as fullMessage (note that all other stuff in log message will not be logged, except 'short' and 'add')
if ($full !== null) {
$gelfMsg->setFullMessage(VarDumper::dumpAsString($full));
}
// Process additionals array (only with string keys)
if (is_array($add)) {
foreach ($add as $key => $val) {
if (is_string($key)) {
if (!is_string($val)) {
$val = VarDumper::dumpAsString($val);
}
$gelfMsg->setAdditional($key, $val);
}
}
}
}
// Set 'file', 'line' and additional 'trace', if log message contains traces array
if (isset($message[4]) && is_array($message[4])) {
$traces = [];
foreach ($message[4] as $index => $trace) {
$traces[] = "{$trace['file']}:{$trace['line']}";
if ($index === 0) {
$gelfMsg->setFile($trace['file']);
$gelfMsg->setLine($trace['line']);
}
}
$gelfMsg->setAdditional('trace', implode("\n", $traces));
}
// Add username
if (($this->addUsername) && (Yii::$app->has('user')) && ($user = Yii::$app->get('user')) && ($identity = $user->getIdentity(false))) {
$gelfMsg->setAdditional('username', $identity->username);
}
// Publish message
$publisher->publish($gelfMsg);
}
}
}