40 lines
1.1 KiB
PHP
40 lines
1.1 KiB
PHP
|
<?php declare(strict_types=1);
|
||
|
|
||
|
/*
|
||
|
* This file is part of the Monolog package.
|
||
|
*
|
||
|
* (c) Jordi Boggiano <j.boggiano@seld.be>
|
||
|
*
|
||
|
* For the full copyright and license information, please view the LICENSE
|
||
|
* file that was distributed with this source code.
|
||
|
*/
|
||
|
|
||
|
namespace Monolog\Formatter;
|
||
|
|
||
|
use DateTimeInterface;
|
||
|
use Monolog\LogRecord;
|
||
|
|
||
|
/**
|
||
|
* Encodes message information into JSON in a format compatible with Cloud logging.
|
||
|
*
|
||
|
* @see https://cloud.google.com/logging/docs/reference/v2/rest/v2/LogEntry
|
||
|
*
|
||
|
* @author Luís Cobucci <lcobucci@gmail.com>
|
||
|
*/
|
||
|
final class GoogleCloudLoggingFormatter extends JsonFormatter
|
||
|
{
|
||
|
protected function normalizeRecord(LogRecord $record): array
|
||
|
{
|
||
|
$normalized = parent::normalizeRecord($record);
|
||
|
|
||
|
// Re-key level for GCP logging
|
||
|
$normalized['severity'] = $normalized['level_name'];
|
||
|
$normalized['timestamp'] = $record->datetime->format(DateTimeInterface::RFC3339_EXTENDED);
|
||
|
|
||
|
// Remove keys that are not used by GCP
|
||
|
unset($normalized['level'], $normalized['level_name'], $normalized['datetime']);
|
||
|
|
||
|
return $normalized;
|
||
|
}
|
||
|
}
|