jaeger-client -> opentelemetry
This commit is contained in:
@@ -0,0 +1,103 @@
|
||||
<?php
|
||||
|
||||
declare(strict_types=1);
|
||||
|
||||
namespace OpenTelemetry\SDK\Logs;
|
||||
|
||||
use OpenTelemetry\API\Logs\LogRecord;
|
||||
use OpenTelemetry\API\Trace\Span;
|
||||
use OpenTelemetry\API\Trace\SpanContextInterface;
|
||||
use OpenTelemetry\Context\Context;
|
||||
use OpenTelemetry\Context\ContextInterface;
|
||||
use OpenTelemetry\SDK\Common\Attribute\AttributesInterface;
|
||||
use OpenTelemetry\SDK\Common\Attribute\LogRecordAttributeValidator;
|
||||
use OpenTelemetry\SDK\Common\Instrumentation\InstrumentationScopeInterface;
|
||||
use OpenTelemetry\SDK\Resource\ResourceInfo;
|
||||
|
||||
/**
|
||||
* @see https://github.com/open-telemetry/opentelemetry-specification/blob/main/specification/logs/data-model.md#log-and-event-record-definition
|
||||
* "Note: Typically this will be implemented with a new interface or (immutable) value type."
|
||||
*/
|
||||
class ReadableLogRecord extends LogRecord
|
||||
{
|
||||
private InstrumentationScopeInterface $scope;
|
||||
private LoggerSharedState $loggerSharedState;
|
||||
protected AttributesInterface $convertedAttributes;
|
||||
protected SpanContextInterface $spanContext;
|
||||
|
||||
public function __construct(InstrumentationScopeInterface $scope, LoggerSharedState $loggerSharedState, LogRecord $logRecord)
|
||||
{
|
||||
$this->scope = $scope;
|
||||
$this->loggerSharedState = $loggerSharedState;
|
||||
|
||||
parent::__construct($logRecord->body);
|
||||
$this->timestamp = $logRecord->timestamp;
|
||||
$this->observedTimestamp = $logRecord->observedTimestamp
|
||||
?? (int) (microtime(true) * LogRecord::NANOS_PER_SECOND);
|
||||
$this->context = $logRecord->context;
|
||||
$context = $this->context ?? Context::getCurrent();
|
||||
$this->spanContext = Span::fromContext($context)->getContext();
|
||||
$this->severityNumber = $logRecord->severityNumber;
|
||||
$this->severityText = $logRecord->severityText;
|
||||
|
||||
//convert attributes now so that excess data is not sent to processors
|
||||
$this->convertedAttributes = $this->loggerSharedState
|
||||
->getLogRecordLimits()
|
||||
->getAttributeFactory()
|
||||
->builder($logRecord->attributes, new LogRecordAttributeValidator())
|
||||
->build();
|
||||
}
|
||||
|
||||
public function getInstrumentationScope(): InstrumentationScopeInterface
|
||||
{
|
||||
return $this->scope;
|
||||
}
|
||||
|
||||
public function getResource(): ResourceInfo
|
||||
{
|
||||
return $this->loggerSharedState->getResource();
|
||||
}
|
||||
|
||||
public function getTimestamp(): ?int
|
||||
{
|
||||
return $this->timestamp;
|
||||
}
|
||||
|
||||
public function getObservedTimestamp(): ?int
|
||||
{
|
||||
return $this->observedTimestamp;
|
||||
}
|
||||
|
||||
public function getContext(): ?ContextInterface
|
||||
{
|
||||
return $this->context;
|
||||
}
|
||||
|
||||
public function getSpanContext(): ?SpanContextInterface
|
||||
{
|
||||
return $this->spanContext;
|
||||
}
|
||||
|
||||
public function getSeverityNumber(): ?int
|
||||
{
|
||||
return $this->severityNumber;
|
||||
}
|
||||
|
||||
public function getSeverityText(): ?string
|
||||
{
|
||||
return $this->severityText;
|
||||
}
|
||||
|
||||
/**
|
||||
* @return mixed|null
|
||||
*/
|
||||
public function getBody()
|
||||
{
|
||||
return $this->body;
|
||||
}
|
||||
|
||||
public function getAttributes(): AttributesInterface
|
||||
{
|
||||
return $this->convertedAttributes;
|
||||
}
|
||||
}
|
||||
Reference in New Issue
Block a user