-
Notifications
You must be signed in to change notification settings - Fork 1.2k
/
instrumentEventData.ts
48 lines (40 loc) · 1.63 KB
/
instrumentEventData.ts
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
// Copyright (c) Microsoft Corporation. All rights reserved.
// Licensed under the MIT License.
import { getTraceParentHeader, extractSpanContextFromTraceParentHeader } from "@azure/core-tracing";
import { Span, SpanContext } from "@opentelemetry/types";
import { EventData } from "../eventData";
/**
* @ignore
*/
export const TRACEPARENT_PROPERTY = "Diagnostic-Id";
/**
* Populates the `EventData` with `SpanContext` info to support trace propagation.
* Creates and returns a copy of the passed in `EventData` unless the `EventData`
* has already been instrumented.
* @param eventData The `EventData` to instrument.
* @param span The `Span` containing the context to propagate tracing information.
* @ignore
*/
export function instrumentEventData(eventData: EventData, span: Span): EventData {
if (eventData.properties && eventData.properties[TRACEPARENT_PROPERTY]) {
return eventData;
}
// create a copy so the original isn't modified
eventData = { ...eventData, properties: { ...eventData.properties } };
const traceParent = getTraceParentHeader(span.context());
if (traceParent) {
eventData.properties![TRACEPARENT_PROPERTY] = traceParent;
}
return eventData;
}
/**
* Extracts the `SpanContext` from an `EventData` if the context exists.
* @param eventData An individual `EventData` object.
*/
export function extractSpanContextFromEventData(eventData: EventData): SpanContext | undefined {
if (!eventData.properties || !eventData.properties[TRACEPARENT_PROPERTY]) {
return;
}
const diagnosticId = eventData.properties[TRACEPARENT_PROPERTY];
return extractSpanContextFromTraceParentHeader(diagnosticId);
}