UNPKG

@sentry/node

Version:

Sentry Node SDK using OpenTelemetry for performance instrumentation

101 lines 4.99 kB
/// <reference types="node" /> /// <reference types="node" /> import type { RequestOptions } from 'node:http'; import type { EventEmitter } from 'node:stream'; import type { InstrumentationConfig } from '@opentelemetry/instrumentation'; import { InstrumentationBase, InstrumentationNodeModuleDefinition } from '@opentelemetry/instrumentation'; import type { Scope } from '@sentry/core'; export type SentryHttpInstrumentationOptions = InstrumentationConfig & { /** * Whether breadcrumbs should be recorded for requests. * * @default `true` */ breadcrumbs?: boolean; /** * Whether to extract the trace ID from the `sentry-trace` header for incoming requests. * By default this is done by the HttpInstrumentation, but if that is not added (e.g. because tracing is disabled, ...) * then this instrumentation can take over. * * @default `false` */ extractIncomingTraceFromHeader?: boolean; /** * Do not capture breadcrumbs for outgoing HTTP requests to URLs where the given callback returns `true`. * For the scope of this instrumentation, this callback only controls breadcrumb creation. * The same option can be passed to the top-level httpIntegration where it controls both, breadcrumb and * span creation. * * @param url Contains the entire URL, including query string (if any), protocol, host, etc. of the outgoing request. * @param request Contains the {@type RequestOptions} object used to make the outgoing request. */ ignoreOutgoingRequests?: (url: string, request: RequestOptions) => boolean; /** * Do not capture the request body for incoming HTTP requests to URLs where the given callback returns `true`. * This can be useful for long running requests where the body is not needed and we want to avoid capturing it. * * @param url Contains the entire URL, including query string (if any), protocol, host, etc. of the outgoing request. * @param request Contains the {@type RequestOptions} object used to make the outgoing request. */ ignoreIncomingRequestBody?: (url: string, request: RequestOptions) => boolean; /** * Whether the integration should create [Sessions](https://docs.sentry.io/product/releases/health/#sessions) for incoming requests to track the health and crash-free rate of your releases in Sentry. * Read more about Release Health: https://docs.sentry.io/product/releases/health/ * * Defaults to `true`. */ trackIncomingRequestsAsSessions?: boolean; /** * Number of milliseconds until sessions tracked with `trackIncomingRequestsAsSessions` will be flushed as a session aggregate. * * Defaults to `60000` (60s). */ sessionFlushingDelayMS?: number; }; /** * This custom HTTP instrumentation is used to isolate incoming requests and annotate them with additional information. * It does not emit any spans. * * The reason this is isolated from the OpenTelemetry instrumentation is that users may overwrite this, * which would lead to Sentry not working as expected. * * Important note: Contrary to other OTEL instrumentation, this one cannot be unwrapped. * It only does minimal things though and does not emit any spans. * * This is heavily inspired & adapted from: * https://github.com/open-telemetry/opentelemetry-js/blob/f8ab5592ddea5cba0a3b33bf8d74f27872c0367f/experimental/packages/opentelemetry-instrumentation-http/src/http.ts */ export declare class SentryHttpInstrumentation extends InstrumentationBase<SentryHttpInstrumentationOptions> { constructor(config?: SentryHttpInstrumentationOptions); /** @inheritdoc */ init(): [InstrumentationNodeModuleDefinition, InstrumentationNodeModuleDefinition]; /** Get the instrumentation for the http module. */ private _getHttpInstrumentation; /** Get the instrumentation for the https module. */ private _getHttpsInstrumentation; /** * Patch the incoming request function for request isolation. */ private _getPatchIncomingRequestFunction; /** * Patch the outgoing request function for breadcrumbs. */ private _getPatchOutgoingRequestFunction; /** Path the outgoing get function for breadcrumbs. */ private _getPatchOutgoingGetFunction; } /** * Starts a session and tracks it in the context of a given isolation scope. * When the passed response is finished, the session is put into a task and is * aggregated with other sessions that may happen in a certain time window * (sessionFlushingDelayMs). * * The sessions are always aggregated by the client that is on the current scope * at the time of ending the response (if there is one). */ export declare function recordRequestSession({ requestIsolationScope, response, sessionFlushingDelayMS, }: { requestIsolationScope: Scope; response: EventEmitter; sessionFlushingDelayMS?: number; }): void; //# sourceMappingURL=SentryHttpInstrumentation.d.ts.map