-
Notifications
You must be signed in to change notification settings - Fork 0
/
ImplicitContextKeyedInterface.php
32 lines (28 loc) · 1.23 KB
/
ImplicitContextKeyedInterface.php
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
<?php
declare(strict_types=1);
namespace OpenTelemetry\Context;
/**
* Represents a value that can be stored within {@see ContextInterface}.
* Allows storing themselves without exposing a {@see ContextKeyInterface}.
*
* @see https://github.com/open-telemetry/opentelemetry-specification/blob/v1.6.1/specification/trace/api.md#context-interaction
* @see https://github.com/open-telemetry/opentelemetry-specification/blob/v1.6.1/specification/baggage/api.md#context-interaction
*/
interface ImplicitContextKeyedInterface
{
/**
* Adds `$this` to the {@see Context::getCurrent() current context} and makes
* the new {@see Context} the current context.
*
* {@see ScopeInterface::detach()} _MUST_ be called to properly restore the previous context.
*
* This method is equivalent to `Context::getCurrent().with($value).activate();`.
*
* @todo: Update this to suggest using the new helper method way to doing something in a specific context/span.
*/
public function activate(): ScopeInterface;
/**
* Returns a new {@see ContextInterface} created by setting `$this` into the provided [@see ContextInterface}.
*/
public function storeInContext(ContextInterface $context): ContextInterface;
}