UNPKG

sentry-uniapp

Version:

用于Uniapp/小程序/快应用等平台的 Sentry SDK

148 lines 4.57 kB
import { getCurrentHub, initAndBind, Integrations as CoreIntegrations, } from "@sentry/core"; import { resolvedSyncPromise } from "@sentry/utils"; import { MiniappClient } from "./client"; import { wrap as internalWrap } from "./helpers"; import { GlobalHandlers, IgnoreMpcrawlerErrors, LinkedErrors, Router, System, TryCatch, } from "./integrations/index"; export var defaultIntegrations = [ new CoreIntegrations.InboundFilters(), new CoreIntegrations.FunctionToString(), new TryCatch(), new GlobalHandlers(), new LinkedErrors(), new System(), new Router(), new IgnoreMpcrawlerErrors(), ]; /** * The Sentry Uniapp SDK Client. * * To use this SDK, call the {@link init} function as early as possible when * launching the app. To set context information or send manual events, use * the provided methods. * * @example * ``` * import { init } from 'sentry-uniapp'; * * init({ * dsn: '__DSN__', * // ... * }); * ``` * * @example * ``` * import { configureScope } from 'sentry-uniapp'; * * configureScope((scope: Scope) => { * scope.setExtra({ battery: 0.7 }); * scope.setTag({ user_mode: 'admin' }); * scope.setUser({ id: '4711' }); * }); * ``` * * @example * ``` * import { addBreadcrumb } from 'sentry-uniapp'; * * addBreadcrumb({ * message: 'My Breadcrumb', * // ... * }); * ``` * * @example * ``` * import * as Sentry from 'sentry-uniapp'; * * Sentry.captureMessage('Hello, world!'); * Sentry.captureException(new Error('Good bye')); * Sentry.captureEvent({ * message: 'Manual', * stacktrace: [ * // ... * ], * }); * ``` * * @see {@link MiniappOptions} for documentation on configuration options. */ export function init(options) { if (options === void 0) { options = {}; } // 如果将 options.defaultIntegrations 设置为 false,则不会添加默认集成,否则将在内部将其设置为建议的默认集成。 // tslint:disable-next-line: strict-comparisons if (options.defaultIntegrations === undefined) { options.defaultIntegrations = defaultIntegrations; } // https://github.com/uappkit/sentry-uniapp/issues/23 options.normalizeDepth = options.normalizeDepth || 5; if (options.defaultIntegrations) { options.defaultIntegrations[3].setExtraOptions(options.extraOptions); } initAndBind(MiniappClient, options); } /** * Present the user with a report dialog. * 向用户显示报告对话框。小程序上暂时不考虑实现该功能。 * * @param options Everything is optional, we try to fetch all info need from the global scope. */ export function showReportDialog(options) { if (options === void 0) { options = {}; } if (!options.eventId) { options.eventId = getCurrentHub().lastEventId(); } var client = getCurrentHub().getClient(); if (client) { client.showReportDialog(options); } } /** * This is the getter for lastEventId. 获取 lastEventId。 * * @returns The last event id of a captured event. */ export function lastEventId() { return getCurrentHub().lastEventId(); } /** * A promise that resolves when all current events have been sent. * If you provide a timeout and the queue takes longer to drain the promise returns false. * 在发送所有当前事件时会变为 resolved 状态的 promise。如果提供了一个超时时间并且队列需要更长时间来消耗,则 promise 将返回 false。 * * @param timeout Maximum time in ms the client should wait. */ export function flush(timeout) { var client = getCurrentHub().getClient(); if (client) { return client.flush(timeout); } return resolvedSyncPromise(false); } /** * A promise that resolves when all current events have been sent. * If you provide a timeout and the queue takes longer to drain the promise returns false. * * @param timeout Maximum time in ms the client should wait. */ export function close(timeout) { var client = getCurrentHub().getClient(); if (client) { return client.close(timeout); } return resolvedSyncPromise(false); } /** * Wrap code within a try/catch block so the SDK is able to capture errors. * 在 try / catch 块中包装代码,以便 SDK 能够捕获错误。 * 实际上是 ./helpers 文件中 warp 方法的进一步封装。 * * @param fn A function to wrap. * * @returns The result of wrapped function call. */ export function wrap(fn) { // tslint:disable-next-line: no-unsafe-any return internalWrap(fn)(); } //# sourceMappingURL=sdk.js.map