summaryrefslogtreecommitdiff
path: root/vendor/open-telemetry/sdk/Trace/Behavior/SpanExporterDecoratorTrait.php
diff options
context:
space:
mode:
Diffstat (limited to 'vendor/open-telemetry/sdk/Trace/Behavior/SpanExporterDecoratorTrait.php')
-rw-r--r--vendor/open-telemetry/sdk/Trace/Behavior/SpanExporterDecoratorTrait.php47
1 files changed, 47 insertions, 0 deletions
diff --git a/vendor/open-telemetry/sdk/Trace/Behavior/SpanExporterDecoratorTrait.php b/vendor/open-telemetry/sdk/Trace/Behavior/SpanExporterDecoratorTrait.php
new file mode 100644
index 000000000..97839ec5b
--- /dev/null
+++ b/vendor/open-telemetry/sdk/Trace/Behavior/SpanExporterDecoratorTrait.php
@@ -0,0 +1,47 @@
+<?php
+
+declare(strict_types=1);
+
+namespace OpenTelemetry\SDK\Trace\Behavior;
+
+use OpenTelemetry\SDK\Common\Future\CancellationInterface;
+use OpenTelemetry\SDK\Common\Future\FutureInterface;
+use OpenTelemetry\SDK\Trace\SpanDataInterface;
+use OpenTelemetry\SDK\Trace\SpanExporterInterface;
+
+trait SpanExporterDecoratorTrait
+{
+ protected SpanExporterInterface $decorated;
+
+ /**
+ * @param iterable<SpanDataInterface> $batch
+ * @return FutureInterface<bool>
+ */
+ public function export(iterable $batch, ?CancellationInterface $cancellation = null): FutureInterface
+ {
+ $batch = $this->beforeExport($batch);
+ $response = $this->decorated->export($batch, $cancellation);
+ $response->map(fn (bool $result) => $this->afterExport($batch, $result));
+
+ return $response;
+ }
+
+ abstract protected function beforeExport(iterable $spans): iterable;
+
+ abstract protected function afterExport(iterable $spans, bool $exportSuccess): void;
+
+ public function shutdown(?CancellationInterface $cancellation = null): bool
+ {
+ return $this->decorated->shutdown($cancellation);
+ }
+
+ public function forceFlush(?CancellationInterface $cancellation = null): bool
+ {
+ return $this->decorated->forceFlush($cancellation);
+ }
+
+ public function setDecorated(SpanExporterInterface $decorated): void
+ {
+ $this->decorated = $decorated;
+ }
+}