1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
|
<?php
declare(strict_types=1);
namespace OpenTelemetry\SDK\Logs\Exporter;
use OpenTelemetry\SDK\Common\Export\TransportInterface;
use OpenTelemetry\SDK\Common\Future\CancellationInterface;
use OpenTelemetry\SDK\Common\Future\CompletedFuture;
use OpenTelemetry\SDK\Common\Future\FutureInterface;
use OpenTelemetry\SDK\Common\Instrumentation\InstrumentationScopeInterface;
use OpenTelemetry\SDK\Logs\LogRecordExporterInterface;
use OpenTelemetry\SDK\Logs\ReadableLogRecord;
use OpenTelemetry\SDK\Resource\ResourceInfo;
/**
* A JSON console exporter for LogRecords. This is only useful for testing; the
* output is human-readable, and is not compatible with the OTLP format.
*/
class ConsoleExporter implements LogRecordExporterInterface
{
private TransportInterface $transport;
public function __construct(TransportInterface $transport)
{
$this->transport = $transport;
}
/**
* @param iterable<mixed, ReadableLogRecord> $batch
*/
public function export(iterable $batch, ?CancellationInterface $cancellation = null): FutureInterface
{
$resource = null;
$scopes = [];
foreach ($batch as $record) {
if (!$resource) {
$resource = $this->convertResource($record->getResource());
}
$key = $this->scopeKey($record->getInstrumentationScope());
if (!array_key_exists($key, $scopes)) {
$scopes[$key] = $this->convertInstrumentationScope($record->getInstrumentationScope());
}
$scopes[$key]['logs'][] = $this->convertLogRecord($record);
}
$output = [
'resource' => $resource,
'scopes' => array_values($scopes),
];
$this->transport->send(json_encode($output, JSON_PRETTY_PRINT));
return new CompletedFuture(true);
}
public function forceFlush(?CancellationInterface $cancellation = null): bool
{
return true;
}
public function shutdown(?CancellationInterface $cancellation = null): bool
{
return true;
}
private function convertLogRecord(ReadableLogRecord $record): array
{
$spanContext = $record->getSpanContext();
return [
'timestamp' => $record->getTimestamp(),
'observed_timestamp' => $record->getObservedTimestamp(),
'severity_number' => $record->getSeverityNumber(),
'severity_text' => $record->getSeverityText(),
'body' => $record->getBody(),
'trace_id' => $spanContext !== null ? $spanContext->getTraceId() : '',
'span_id' => $spanContext !== null ? $spanContext->getSpanId() : '',
'trace_flags' => $spanContext !== null ? $spanContext->getTraceFlags() : null,
'attributes' => $record->getAttributes()->toArray(),
'dropped_attributes_count' => $record->getAttributes()->getDroppedAttributesCount(),
];
}
private function convertResource(ResourceInfo $resource): array
{
return [
'attributes' => $resource->getAttributes()->toArray(),
'dropped_attributes_count' => $resource->getAttributes()->getDroppedAttributesCount(),
];
}
private function scopeKey(InstrumentationScopeInterface $scope): string
{
return serialize([$scope->getName(), $scope->getVersion(), $scope->getSchemaUrl(), $scope->getAttributes()]);
}
private function convertInstrumentationScope(InstrumentationScopeInterface $scope): array
{
return [
'name' => $scope->getName(),
'version' => $scope->getVersion(),
'attributes' => $scope->getAttributes()->toArray(),
'dropped_attributes_count' => $scope->getAttributes()->getDroppedAttributesCount(),
'schema_url' => $scope->getSchemaUrl(),
'logs' => [],
];
}
}
|