rittenhop-dev/versions/5.94.2/node_modules/@sentry/utils/esm/tracing.js

130 lines
3.5 KiB
JavaScript
Raw Normal View History

2024-09-23 19:40:12 -04:00
import { baggageHeaderToDynamicSamplingContext } from './baggage.js';
import { uuid4 } from './misc.js';
// eslint-disable-next-line @sentry-internal/sdk/no-regexp-constructor -- RegExp is used for readability here
const TRACEPARENT_REGEXP = new RegExp(
'^[ \\t]*' + // whitespace
'([0-9a-f]{32})?' + // trace_id
'-?([0-9a-f]{16})?' + // span_id
'-?([01])?' + // sampled
'[ \\t]*$', // whitespace
);
/**
* Extract transaction context data from a `sentry-trace` header.
*
* @param traceparent Traceparent string
*
* @returns Object containing data from the header, or undefined if traceparent string is malformed
*/
function extractTraceparentData(traceparent) {
if (!traceparent) {
return undefined;
}
const matches = traceparent.match(TRACEPARENT_REGEXP);
if (!matches) {
return undefined;
}
let parentSampled;
if (matches[3] === '1') {
parentSampled = true;
} else if (matches[3] === '0') {
parentSampled = false;
}
return {
traceId: matches[1],
parentSampled,
parentSpanId: matches[2],
};
}
/**
* Create tracing context from incoming headers.
*
* @deprecated Use `propagationContextFromHeaders` instead.
*/
// TODO(v8): Remove this function
function tracingContextFromHeaders(
sentryTrace,
baggage,
)
{
const traceparentData = extractTraceparentData(sentryTrace);
const dynamicSamplingContext = baggageHeaderToDynamicSamplingContext(baggage);
const { traceId, parentSpanId, parentSampled } = traceparentData || {};
if (!traceparentData) {
return {
traceparentData,
dynamicSamplingContext: undefined,
propagationContext: {
traceId: traceId || uuid4(),
spanId: uuid4().substring(16),
},
};
} else {
return {
traceparentData,
dynamicSamplingContext: dynamicSamplingContext || {}, // If we have traceparent data but no DSC it means we are not head of trace and we must freeze it
propagationContext: {
traceId: traceId || uuid4(),
parentSpanId: parentSpanId || uuid4().substring(16),
spanId: uuid4().substring(16),
sampled: parentSampled,
dsc: dynamicSamplingContext || {}, // If we have traceparent data but no DSC it means we are not head of trace and we must freeze it
},
};
}
}
/**
* Create a propagation context from incoming headers.
*/
function propagationContextFromHeaders(
sentryTrace,
baggage,
) {
const traceparentData = extractTraceparentData(sentryTrace);
const dynamicSamplingContext = baggageHeaderToDynamicSamplingContext(baggage);
const { traceId, parentSpanId, parentSampled } = traceparentData || {};
if (!traceparentData) {
return {
traceId: traceId || uuid4(),
spanId: uuid4().substring(16),
};
} else {
return {
traceId: traceId || uuid4(),
parentSpanId: parentSpanId || uuid4().substring(16),
spanId: uuid4().substring(16),
sampled: parentSampled,
dsc: dynamicSamplingContext || {}, // If we have traceparent data but no DSC it means we are not head of trace and we must freeze it
};
}
}
/**
* Create sentry-trace header from span context values.
*/
function generateSentryTraceHeader(
traceId = uuid4(),
spanId = uuid4().substring(16),
sampled,
) {
let sampledString = '';
if (sampled !== undefined) {
sampledString = sampled ? '-1' : '-0';
}
return `${traceId}-${spanId}${sampledString}`;
}
export { TRACEPARENT_REGEXP, extractTraceparentData, generateSentryTraceHeader, propagationContextFromHeaders, tracingContextFromHeaders };
//# sourceMappingURL=tracing.js.map