Skip to main content
Drupal API
User account menu
  • Log in

Breadcrumb

  1. Drupal Core 11.1.x

ReadableLogRecord.php

Namespace

OpenTelemetry\SDK\Logs

File

vendor/open-telemetry/sdk/Logs/ReadableLogRecord.php

View source
<?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 {
    protected AttributesInterface $convertedAttributes;
    protected SpanContextInterface $spanContext;
    public function __construct(InstrumentationScopeInterface $scope, LoggerSharedState $loggerSharedState, LogRecord $logRecord) {
        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;
    }

}

Classes

Title Deprecated Summary
ReadableLogRecord "Note: Typically this will be implemented with a new interface or (immutable) value type."

API Navigation

  • Drupal Core 11.1.x
  • Topics
  • Classes
  • Functions
  • Constants
  • Globals
  • Files
  • Namespaces
  • Deprecated
  • Services
RSS feed
Powered by Drupal