| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687 |
- <?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 Elastica\Document;
- use Monolog\LogRecord;
- /**
- * Format a log message into an Elastica Document
- *
- * @author Jelle Vink <jelle.vink@gmail.com>
- */
- class ElasticaFormatter extends NormalizerFormatter
- {
- /**
- * @var string Elastic search index name
- */
- protected string $index;
- /**
- * @var ?string Elastic search document type
- */
- protected $type;
- /**
- * @param string $index Elastic Search index name
- * @param ?string $type Elastic Search document type, deprecated as of Elastica 7
- */
- public function __construct(string $index, ?string $type)
- {
- // elasticsearch requires a ISO 8601 format date with optional millisecond precision.
- parent::__construct('Y-m-d\TH:i:s.uP');
- $this->index = $index;
- $this->type = $type;
- }
- /**
- * @inheritDoc
- */
- public function format(LogRecord $record)
- {
- $record = parent::format($record);
- return $this->getDocument($record);
- }
- public function getIndex(): string
- {
- return $this->index;
- }
- /**
- * @deprecated since Elastica 7 type has no effect
- */
- public function getType(): string
- {
- /** @phpstan-ignore-next-line */
- return $this->type;
- }
- /**
- * Convert a log message into an Elastica Document
- *
- * @param mixed[] $record
- */
- protected function getDocument(array $record): Document
- {
- $document = new Document();
- $document->setData($record);
- if (method_exists($document, 'setType')) {
- $document->setType($this->type);
- }
- $document->setIndex($this->index);
- return $document;
- }
- }
|