2023-01-23 11:03:31 +01:00

43 lines
1.0 KiB
PHP

<?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;
}
}