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
|
<?php
/**
* Matomo - free/libre analytics platform
*
* @link https://matomo.org
* @license https://www.gnu.org/licenses/gpl-3.0.html GPL v3 or later
*/
namespace Piwik\Plugins\Monolog\Processor;
use Monolog\LogRecord;
/**
* Processes a log message using `sprintf()`.
*/
class SprintfProcessor
{
public function __invoke(LogRecord $record)
{
$message = $record->message;
$parameters = $record->context;
if (!empty($parameters) && strpos($message, '%') !== false) {
$parameters = $this->ensureParametersAreStrings($parameters);
return new LogRecord(
datetime: $record->datetime,
channel: $record->channel,
level: $record->level,
message: vsprintf($message, $parameters),
context: $record->context,
extra: $record->extra,
formatted: $record->formatted,
);
}
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;
}
}
|