2022-10-17 21:25:03 +02:00
|
|
|
<?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.
|
|
|
|
*
|
2023-07-02 23:57:24 +02:00
|
|
|
* @see https://cloud.google.com/logging/docs/structured-logging
|
2022-10-17 21:25:03 +02:00
|
|
|
* @see https://cloud.google.com/logging/docs/reference/v2/rest/v2/LogEntry
|
|
|
|
*
|
|
|
|
* @author Luís Cobucci <lcobucci@gmail.com>
|
|
|
|
*/
|
|
|
|
final class GoogleCloudLoggingFormatter extends JsonFormatter
|
|
|
|
{
|
2023-07-02 23:57:24 +02:00
|
|
|
/** {@inheritdoc} **/
|
|
|
|
public function format(array $record): string
|
2022-10-17 21:25:03 +02:00
|
|
|
{
|
|
|
|
// Re-key level for GCP logging
|
2023-07-02 23:57:24 +02:00
|
|
|
$record['severity'] = $record['level_name'];
|
|
|
|
$record['time'] = $record['datetime']->format(DateTimeInterface::RFC3339_EXTENDED);
|
2022-10-17 21:25:03 +02:00
|
|
|
|
|
|
|
// Remove keys that are not used by GCP
|
2023-07-02 23:57:24 +02:00
|
|
|
unset($record['level'], $record['level_name'], $record['datetime']);
|
2022-10-17 21:25:03 +02:00
|
|
|
|
2023-07-02 23:57:24 +02:00
|
|
|
return parent::format($record);
|
2022-10-17 21:25:03 +02:00
|
|
|
}
|
|
|
|
}
|
2023-07-02 23:57:24 +02:00
|
|
|
|