{"version":3,"file":"trace.js","sources":["../../../src/tracing/trace.ts"],"sourcesContent":["import type { Scope, Span, SpanTimeInput, StartSpanOptions, TransactionContext } from '@sentry/types';\n\nimport { addNonEnumerableProperty, dropUndefinedKeys, logger, tracingContextFromHeaders } from '@sentry/utils';\n\nimport { DEBUG_BUILD } from '../debug-build';\nimport { getCurrentScope, withScope } from '../exports';\nimport type { Hub } from '../hub';\nimport { runWithAsyncContext } from '../hub';\nimport { getIsolationScope } from '../hub';\nimport { getCurrentHub } from '../hub';\nimport { handleCallbackErrors } from '../utils/handleCallbackErrors';\nimport { hasTracingEnabled } from '../utils/hasTracingEnabled';\nimport { spanTimeInputToSeconds, spanToJSON } from '../utils/spanUtils';\n\n/**\n * Wraps a function with a transaction/span and finishes the span after the function is done.\n *\n * Note that if you have not enabled tracing extensions via `addTracingExtensions`\n * or you didn't set `tracesSampleRate`, this function will not generate spans\n * and the `span` returned from the callback will be undefined.\n *\n * This function is meant to be used internally and may break at any time. Use at your own risk.\n *\n * @internal\n * @private\n *\n * @deprecated Use `startSpan` instead.\n */\nexport function trace(\n context: TransactionContext,\n callback: (span?: Span) => T,\n // eslint-disable-next-line @typescript-eslint/no-empty-function\n onError: (error: unknown, span?: Span) => void = () => {},\n // eslint-disable-next-line @typescript-eslint/no-empty-function\n afterFinish: () => void = () => {},\n): T {\n // eslint-disable-next-line deprecation/deprecation\n const hub = getCurrentHub();\n const scope = getCurrentScope();\n // eslint-disable-next-line deprecation/deprecation\n const parentSpan = scope.getSpan();\n\n const ctx = normalizeContext(context);\n const activeSpan = createChildSpanOrTransaction(hub, parentSpan, ctx);\n\n // eslint-disable-next-line deprecation/deprecation\n scope.setSpan(activeSpan);\n\n return handleCallbackErrors(\n () => callback(activeSpan),\n error => {\n activeSpan && activeSpan.setStatus('internal_error');\n onError(error, activeSpan);\n },\n () => {\n activeSpan && activeSpan.end();\n // eslint-disable-next-line deprecation/deprecation\n scope.setSpan(parentSpan);\n afterFinish();\n },\n );\n}\n\n/**\n * Wraps a function with a transaction/span and finishes the span after the function is done.\n * The created span is the active span and will be used as parent by other spans created inside the function\n * and can be accessed via `Sentry.getSpan()`, as long as the function is executed while the scope is active.\n *\n * If you want to create a span that is not set as active, use {@link startInactiveSpan}.\n *\n * Note that if you have not enabled tracing extensions via `addTracingExtensions`\n * or you didn't set `tracesSampleRate`, this function will not generate spans\n * and the `span` returned from the callback will be undefined.\n */\nexport function startSpan(context: StartSpanOptions, callback: (span: Span | undefined) => T): T {\n const ctx = normalizeContext(context);\n\n return runWithAsyncContext(() => {\n return withScope(context.scope, scope => {\n // eslint-disable-next-line deprecation/deprecation\n const hub = getCurrentHub();\n // eslint-disable-next-line deprecation/deprecation\n const parentSpan = scope.getSpan();\n\n const shouldSkipSpan = context.onlyIfParent && !parentSpan;\n const activeSpan = shouldSkipSpan ? undefined : createChildSpanOrTransaction(hub, parentSpan, ctx);\n\n // eslint-disable-next-line deprecation/deprecation\n scope.setSpan(activeSpan);\n\n return handleCallbackErrors(\n () => callback(activeSpan),\n () => {\n // Only update the span status if it hasn't been changed yet\n if (activeSpan) {\n const { status } = spanToJSON(activeSpan);\n if (!status || status === 'ok') {\n activeSpan.setStatus('internal_error');\n }\n }\n },\n () => activeSpan && activeSpan.end(),\n );\n });\n });\n}\n\n/**\n * @deprecated Use {@link startSpan} instead.\n */\nexport const startActiveSpan = startSpan;\n\n/**\n * Similar to `Sentry.startSpan`. Wraps a function with a transaction/span, but does not finish the span\n * after the function is done automatically. You'll have to call `span.end()` manually.\n *\n * The created span is the active span and will be used as parent by other spans created inside the function\n * and can be accessed via `Sentry.getActiveSpan()`, as long as the function is executed while the scope is active.\n *\n * Note that if you have not enabled tracing extensions via `addTracingExtensions`\n * or you didn't set `tracesSampleRate`, this function will not generate spans\n * and the `span` returned from the callback will be undefined.\n */\nexport function startSpanManual(\n context: StartSpanOptions,\n callback: (span: Span | undefined, finish: () => void) => T,\n): T {\n const ctx = normalizeContext(context);\n\n return runWithAsyncContext(() => {\n return withScope(context.scope, scope => {\n // eslint-disable-next-line deprecation/deprecation\n const hub = getCurrentHub();\n // eslint-disable-next-line deprecation/deprecation\n const parentSpan = scope.getSpan();\n\n const shouldSkipSpan = context.onlyIfParent && !parentSpan;\n const activeSpan = shouldSkipSpan ? undefined : createChildSpanOrTransaction(hub, parentSpan, ctx);\n\n // eslint-disable-next-line deprecation/deprecation\n scope.setSpan(activeSpan);\n\n function finishAndSetSpan(): void {\n activeSpan && activeSpan.end();\n }\n\n return handleCallbackErrors(\n () => callback(activeSpan, finishAndSetSpan),\n () => {\n // Only update the span status if it hasn't been changed yet, and the span is not yet finished\n if (activeSpan && activeSpan.isRecording()) {\n const { status } = spanToJSON(activeSpan);\n if (!status || status === 'ok') {\n activeSpan.setStatus('internal_error');\n }\n }\n },\n );\n });\n });\n}\n\n/**\n * Creates a span. This span is not set as active, so will not get automatic instrumentation spans\n * as children or be able to be accessed via `Sentry.getSpan()`.\n *\n * If you want to create a span that is set as active, use {@link startSpan}.\n *\n * Note that if you have not enabled tracing extensions via `addTracingExtensions`\n * or you didn't set `tracesSampleRate` or `tracesSampler`, this function will not generate spans\n * and the `span` returned from the callback will be undefined.\n */\nexport function startInactiveSpan(context: StartSpanOptions): Span | undefined {\n if (!hasTracingEnabled()) {\n return undefined;\n }\n\n const ctx = normalizeContext(context);\n // eslint-disable-next-line deprecation/deprecation\n const hub = getCurrentHub();\n const parentSpan = context.scope\n ? // eslint-disable-next-line deprecation/deprecation\n context.scope.getSpan()\n : getActiveSpan();\n\n const shouldSkipSpan = context.onlyIfParent && !parentSpan;\n\n if (shouldSkipSpan) {\n return undefined;\n }\n\n const isolationScope = getIsolationScope();\n const scope = getCurrentScope();\n\n let span: Span | undefined;\n\n if (parentSpan) {\n // eslint-disable-next-line deprecation/deprecation\n span = parentSpan.startChild(ctx);\n } else {\n const { traceId, dsc, parentSpanId, sampled } = {\n ...isolationScope.getPropagationContext(),\n ...scope.getPropagationContext(),\n };\n\n // eslint-disable-next-line deprecation/deprecation\n span = hub.startTransaction({\n traceId,\n parentSpanId,\n parentSampled: sampled,\n ...ctx,\n metadata: {\n dynamicSamplingContext: dsc,\n // eslint-disable-next-line deprecation/deprecation\n ...ctx.metadata,\n },\n });\n }\n\n setCapturedScopesOnSpan(span, scope, isolationScope);\n\n return span;\n}\n\n/**\n * Returns the currently active span.\n */\nexport function getActiveSpan(): Span | undefined {\n // eslint-disable-next-line deprecation/deprecation\n return getCurrentScope().getSpan();\n}\n\ninterface ContinueTrace {\n /**\n * Continue a trace from `sentry-trace` and `baggage` values.\n * These values can be obtained from incoming request headers,\n * or in the browser from `` and `` HTML tags.\n *\n * @deprecated Use the version of this function taking a callback as second parameter instead:\n *\n * ```\n * Sentry.continueTrace(sentryTrace: '...', baggage: '...' }, () => {\n * // ...\n * })\n * ```\n *\n */\n ({\n sentryTrace,\n baggage,\n }: {\n // eslint-disable-next-line deprecation/deprecation\n sentryTrace: Parameters[0];\n // eslint-disable-next-line deprecation/deprecation\n baggage: Parameters[1];\n }): Partial;\n\n /**\n * Continue a trace from `sentry-trace` and `baggage` values.\n * These values can be obtained from incoming request headers, or in the browser from ``\n * and `` HTML tags.\n *\n * Spans started with `startSpan`, `startSpanManual` and `startInactiveSpan`, within the callback will automatically\n * be attached to the incoming trace.\n *\n * Deprecation notice: In the next major version of the SDK the provided callback will not receive a transaction\n * context argument.\n */\n (\n {\n sentryTrace,\n baggage,\n }: {\n // eslint-disable-next-line deprecation/deprecation\n sentryTrace: Parameters[0];\n // eslint-disable-next-line deprecation/deprecation\n baggage: Parameters[1];\n },\n // TODO(v8): Remove parameter from this callback.\n callback: (transactionContext: Partial) => V,\n ): V;\n}\n\nexport const continueTrace: ContinueTrace = (\n {\n sentryTrace,\n baggage,\n }: {\n // eslint-disable-next-line deprecation/deprecation\n sentryTrace: Parameters[0];\n // eslint-disable-next-line deprecation/deprecation\n baggage: Parameters[1];\n },\n callback?: (transactionContext: Partial) => V,\n): V | Partial => {\n // TODO(v8): Change this function so it doesn't do anything besides setting the propagation context on the current scope:\n /*\n return withScope((scope) => {\n const propagationContext = propagationContextFromHeaders(sentryTrace, baggage);\n scope.setPropagationContext(propagationContext);\n return callback();\n })\n */\n\n const currentScope = getCurrentScope();\n\n // eslint-disable-next-line deprecation/deprecation\n const { traceparentData, dynamicSamplingContext, propagationContext } = tracingContextFromHeaders(\n sentryTrace,\n baggage,\n );\n\n currentScope.setPropagationContext(propagationContext);\n\n if (DEBUG_BUILD && traceparentData) {\n logger.log(`[Tracing] Continuing trace ${traceparentData.traceId}.`);\n }\n\n const transactionContext: Partial = {\n ...traceparentData,\n metadata: dropUndefinedKeys({\n dynamicSamplingContext,\n }),\n };\n\n if (!callback) {\n return transactionContext;\n }\n\n return runWithAsyncContext(() => {\n return callback(transactionContext);\n });\n};\n\nfunction createChildSpanOrTransaction(\n hub: Hub,\n parentSpan: Span | undefined,\n ctx: TransactionContext,\n): Span | undefined {\n if (!hasTracingEnabled()) {\n return undefined;\n }\n\n const isolationScope = getIsolationScope();\n const scope = getCurrentScope();\n\n let span: Span | undefined;\n if (parentSpan) {\n // eslint-disable-next-line deprecation/deprecation\n span = parentSpan.startChild(ctx);\n } else {\n const { traceId, dsc, parentSpanId, sampled } = {\n ...isolationScope.getPropagationContext(),\n ...scope.getPropagationContext(),\n };\n\n // eslint-disable-next-line deprecation/deprecation\n span = hub.startTransaction({\n traceId,\n parentSpanId,\n parentSampled: sampled,\n ...ctx,\n metadata: {\n dynamicSamplingContext: dsc,\n // eslint-disable-next-line deprecation/deprecation\n ...ctx.metadata,\n },\n });\n }\n\n setCapturedScopesOnSpan(span, scope, isolationScope);\n\n return span;\n}\n\n/**\n * This converts StartSpanOptions to TransactionContext.\n * For the most part (for now) we accept the same options,\n * but some of them need to be transformed.\n *\n * Eventually the StartSpanOptions will be more aligned with OpenTelemetry.\n */\nfunction normalizeContext(context: StartSpanOptions): TransactionContext {\n if (context.startTime) {\n const ctx: TransactionContext & { startTime?: SpanTimeInput } = { ...context };\n ctx.startTimestamp = spanTimeInputToSeconds(context.startTime);\n delete ctx.startTime;\n return ctx;\n }\n\n return context;\n}\n\nconst SCOPE_ON_START_SPAN_FIELD = '_sentryScope';\nconst ISOLATION_SCOPE_ON_START_SPAN_FIELD = '_sentryIsolationScope';\n\ntype SpanWithScopes = Span & {\n [SCOPE_ON_START_SPAN_FIELD]?: Scope;\n [ISOLATION_SCOPE_ON_START_SPAN_FIELD]?: Scope;\n};\n\nfunction setCapturedScopesOnSpan(span: Span | undefined, scope: Scope, isolationScope: Scope): void {\n if (span) {\n addNonEnumerableProperty(span, ISOLATION_SCOPE_ON_START_SPAN_FIELD, isolationScope);\n addNonEnumerableProperty(span, SCOPE_ON_START_SPAN_FIELD, scope);\n }\n}\n\n/**\n * Grabs the scope and isolation scope off a span that were active when the span was started.\n */\nexport function getCapturedScopesOnSpan(span: Span): { scope?: Scope; isolationScope?: Scope } {\n return {\n scope: (span as SpanWithScopes)[SCOPE_ON_START_SPAN_FIELD],\n isolationScope: (span as SpanWithScopes)[ISOLATION_SCOPE_ON_START_SPAN_FIELD],\n };\n}\n"],"names":["hub","getCurrentHub","getCurrentScope","handleCallbackErrors","runWithAsyncContext","withScope","spanToJSON","hasTracingEnabled","getIsolationScope","tracingContextFromHeaders","DEBUG_BUILD","logger","dropUndefinedKeys","spanTimeInputToSeconds","addNonEnumerableProperty"],"mappings":"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"}