summaryrefslogtreecommitdiff
path: root/vendor/open-telemetry/sdk/Logs/LoggerProviderBuilder.php
diff options
context:
space:
mode:
authorAndrew Dolgov <[email protected]>2023-10-20 17:12:29 +0300
committerAndrew Dolgov <[email protected]>2023-10-20 21:13:39 +0300
commitcdd7ad020e165fe680703b6d3319b908b682fb7a (patch)
treeb51eb09b7b4587e8fbc5624ac8d88d28cfcd0b04 /vendor/open-telemetry/sdk/Logs/LoggerProviderBuilder.php
parent45a9ff0c88cbd33892ff16ab837e9059937d656e (diff)
jaeger-client -> opentelemetry
Diffstat (limited to 'vendor/open-telemetry/sdk/Logs/LoggerProviderBuilder.php')
-rw-r--r--vendor/open-telemetry/sdk/Logs/LoggerProviderBuilder.php55
1 files changed, 55 insertions, 0 deletions
diff --git a/vendor/open-telemetry/sdk/Logs/LoggerProviderBuilder.php b/vendor/open-telemetry/sdk/Logs/LoggerProviderBuilder.php
new file mode 100644
index 000000000..37c56245c
--- /dev/null
+++ b/vendor/open-telemetry/sdk/Logs/LoggerProviderBuilder.php
@@ -0,0 +1,55 @@
+<?php
+
+declare(strict_types=1);
+
+namespace OpenTelemetry\SDK\Logs;
+
+use OpenTelemetry\SDK\Common\Attribute\Attributes;
+use OpenTelemetry\SDK\Common\Instrumentation\InstrumentationScopeFactory;
+use OpenTelemetry\SDK\Logs\Processor\MultiLogRecordProcessor;
+use OpenTelemetry\SDK\Logs\Processor\NoopLogRecordProcessor;
+use OpenTelemetry\SDK\Resource\ResourceInfo;
+
+class LoggerProviderBuilder
+{
+ /**
+ * @var array<LogRecordProcessorInterface>
+ */
+ private array $processors = [];
+ private ?ResourceInfo $resource = null;
+
+ public function addLogRecordProcessor(LogRecordProcessorInterface $processor): self
+ {
+ $this->processors[] = $processor;
+
+ return $this;
+ }
+
+ public function setResource(ResourceInfo $resource): self
+ {
+ $this->resource = $resource;
+
+ return $this;
+ }
+
+ public function build(): LoggerProviderInterface
+ {
+ return new LoggerProvider(
+ $this->buildProcessor(),
+ new InstrumentationScopeFactory(Attributes::factory()),
+ $this->resource
+ );
+ }
+
+ private function buildProcessor(): LogRecordProcessorInterface
+ {
+ switch (count($this->processors)) {
+ case 0:
+ return NoopLogRecordProcessor::getInstance();
+ case 1:
+ return $this->processors[0];
+ default:
+ return new MultiLogRecordProcessor($this->processors);
+ }
+ }
+}