@sentry/react-native
Version:
Official Sentry SDK for react-native
114 lines • 4.84 kB
TypeScript
import type { Event, EventHint, Integration } from '@sentry/core';
export declare const MOBILE_REPLAY_INTEGRATION_NAME = "MobileReplay";
/**
* Screenshot strategy type for Android Session Replay.
*
* - `'canvas'`: Canvas-based screenshot strategy. This strategy does **not** support any masking options, it always masks text and images. Use this if your application has strict PII requirements.
* - `'pixelCopy'`: Pixel copy screenshot strategy (default). Supports all masking options.
*/
export type ScreenshotStrategy = 'canvas' | 'pixelCopy';
export interface MobileReplayOptions {
/**
* Mask all text in recordings
*
* @default true
*/
maskAllText?: boolean;
/**
* Mask all images in recordings
*
* @default true
*/
maskAllImages?: boolean;
/**
* Mask all vector graphics in recordings
* Supports `react-native-svg`
*
* @default true
*/
maskAllVectors?: boolean;
/**
* Enables the up to 5x faster experimental view renderer used by the Session Replay integration on iOS.
*
* Enabling this flag will reduce the amount of time it takes to render each frame of the session replay on the main thread, therefore reducing
* interruptions and visual lag.
*
* - Experiment: This is an experimental feature and is therefore disabled by default.
*
* @deprecated Use `enableViewRendererV2` instead.
* @platform ios
*/
enableExperimentalViewRenderer?: boolean;
/**
* Enables up to 5x faster new view renderer used by the Session Replay integration on iOS.
*
* Enabling this flag will reduce the amount of time it takes to render each frame of the session replay on the main thread, therefore reducing
* interruptions and visual lag. [Our benchmarks](https://github.com/getsentry/sentry-cocoa/pull/4940) have shown a significant improvement of
* **up to 4-5x faster rendering** (reducing `~160ms` to `~36ms` per frame) on older devices.
*
* - Experiment: In case you are noticing issues with the new view renderer, please report the issue on [GitHub](https://github.com/getsentry/sentry-cocoa).
* Eventually, we will remove this feature flag and use the new view renderer by default.
*
* @default true
* @platform ios
*/
enableViewRendererV2?: boolean;
/**
* Enables up to 5x faster but incomplete view rendering used by the Session Replay integration on iOS.
*
* Enabling this flag will reduce the amount of time it takes to render each frame of the session replay on the main thread, therefore reducing
* interruptions and visual lag.
*
* - Note: This flag can only be used together with `enableExperimentalViewRenderer` with up to 20% faster render times.
* - Experiment: This is an experimental feature and is therefore disabled by default.
*
* @default false
* @platform ios
*/
enableFastViewRendering?: boolean;
/**
* Sets the screenshot strategy used by the Session Replay integration on Android.
*
* If your application has strict PII requirements we recommend using `'canvas'`.
* This strategy does **not** support any masking options, it always masks text and images.
*
* - Experiment: In case you are noticing issues with the canvas screenshot strategy, please report the issue on [GitHub](https://github.com/getsentry/sentry-java).
*
* @default 'pixelCopy'
* @platform android
*/
screenshotStrategy?: ScreenshotStrategy;
/**
* Callback to determine if a replay should be captured for a specific error.
* When this callback returns `false`, no replay will be captured for the error.
* This callback is only called when an error occurs and `replaysOnErrorSampleRate` is set.
*
* @param event The error event
* @param hint Additional event information
* @returns `false` to skip capturing a replay for this error, `true` or `undefined` to proceed with sampling
*/
beforeErrorSampling?: (event: Event, hint: EventHint) => boolean;
}
type MobileReplayIntegration = Integration & {
options: MobileReplayOptions;
getReplayId: () => string | null;
};
/**
* The Mobile Replay Integration, let's you adjust the default mobile replay options.
* To be passed to `Sentry.init` with `replaysOnErrorSampleRate` or `replaysSessionSampleRate`.
*
* ```javascript
* Sentry.init({
* replaysOnErrorSampleRate: 1.0,
* replaysSessionSampleRate: 1.0,
* integrations: [mobileReplayIntegration({
* // Adjust the default options
* })],
* });
* ```
*
* @experimental
*/
export declare const mobileReplayIntegration: (initOptions?: MobileReplayOptions) => MobileReplayIntegration;
export {};
//# sourceMappingURL=mobilereplay.d.ts.map