blob: f06b6154de605ff0b75f2db8c02474692cd5199d (
plain)
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
|
<?php
/**
* Piwik - free/libre analytics platform
*
* @link http://piwik.org
* @license http://www.gnu.org/licenses/gpl-3.0.html GPL v3 or later
*/
namespace Piwik\Plugins\Monolog\Processor;
/**
* Processes a log message using `sprintf()`.
*/
class SprintfProcessor
{
public function __invoke(array $record)
{
$message = $record['message'];
$parameters = $record['context'];
if (is_string($message) && !empty($parameters) && strpos($message, '%') !== false) {
$parameters = $this->ensureParametersAreStrings($parameters);
$record['message'] = vsprintf($message, $parameters);
}
return $record;
}
private function ensureParametersAreStrings(array $parameters)
{
foreach ($parameters as &$param) {
if (is_array($param)) {
$param = json_encode($param);
} elseif (is_object($param)) {
$param = get_class($param);
}
}
return $parameters;
}
}
|