UNPKG

@sentry/browser

Version:
90 lines (72 loc) 2.47 kB
Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' }); const core = require('@sentry/core'); const WINDOW = core.GLOBAL_OBJ ; const DEFAULT_LINES_OF_CONTEXT = 7; const INTEGRATION_NAME = 'ContextLines'; const _contextLinesIntegration = ((options = {}) => { const contextLines = options.frameContextLines != null ? options.frameContextLines : DEFAULT_LINES_OF_CONTEXT; return { name: INTEGRATION_NAME, processEvent(event) { return addSourceContext(event, contextLines); }, }; }) ; /** * Collects source context lines around the lines of stackframes pointing to JS embedded in * the current page's HTML. * * This integration DOES NOT work for stack frames pointing to JS files that are loaded by the browser. * For frames pointing to files, context lines are added during ingestion and symbolication * by attempting to download the JS files to the Sentry backend. * * Use this integration if you have inline JS code in HTML pages that can't be accessed * by our backend (e.g. due to a login-protected page). */ const contextLinesIntegration = core.defineIntegration(_contextLinesIntegration); /** * Processes an event and adds context lines. */ function addSourceContext(event, contextLines) { const doc = WINDOW.document; const htmlFilename = WINDOW.location && core.stripUrlQueryAndFragment(WINDOW.location.href); if (!doc || !htmlFilename) { return event; } const exceptions = event.exception?.values; if (!exceptions?.length) { return event; } const html = doc.documentElement.innerHTML; if (!html) { return event; } const htmlLines = ['<!DOCTYPE html>', '<html>', ...html.split('\n'), '</html>']; exceptions.forEach(exception => { const stacktrace = exception.stacktrace; if (stacktrace?.frames) { stacktrace.frames = stacktrace.frames.map(frame => applySourceContextToFrame(frame, htmlLines, htmlFilename, contextLines), ); } }); return event; } /** * Only exported for testing */ function applySourceContextToFrame( frame, htmlLines, htmlFilename, linesOfContext, ) { if (frame.filename !== htmlFilename || !frame.lineno || !htmlLines.length) { return frame; } core.addContextToFrame(htmlLines, frame, linesOfContext); return frame; } exports.applySourceContextToFrame = applySourceContextToFrame; exports.contextLinesIntegration = contextLinesIntegration; //# sourceMappingURL=contextlines.js.map