@sentry/browser
Version:
Official Sentry SDK for browsers
118 lines (96 loc) • 4.44 kB
JavaScript
Object.defineProperty(exports, '__esModule', { value: true });
const core = require('@sentry/core');
const utils$1 = require('@sentry/utils');
const debugBuild = require('../debug-build.js');
const hubextensions = require('./hubextensions.js');
const utils = require('./utils.js');
const INTEGRATION_NAME = 'BrowserProfiling';
const _browserProfilingIntegration = (() => {
return {
name: INTEGRATION_NAME,
// TODO v8: Remove this
setupOnce() {}, // eslint-disable-line @typescript-eslint/no-empty-function
setup(client) {
const scope = core.getCurrentScope();
// eslint-disable-next-line deprecation/deprecation
const transaction = scope.getTransaction();
if (transaction && utils.isAutomatedPageLoadTransaction(transaction)) {
if (utils.shouldProfileTransaction(transaction)) {
hubextensions.startProfileForTransaction(transaction);
}
}
if (typeof client.on !== 'function') {
utils$1.logger.warn('[Profiling] Client does not support hooks, profiling will be disabled');
return;
}
client.on('startTransaction', (transaction) => {
if (utils.shouldProfileTransaction(transaction)) {
hubextensions.startProfileForTransaction(transaction);
}
});
client.on('beforeEnvelope', (envelope) => {
// if not profiles are in queue, there is nothing to add to the envelope.
if (!utils.getActiveProfilesCount()) {
return;
}
const profiledTransactionEvents = utils.findProfiledTransactionsFromEnvelope(envelope);
if (!profiledTransactionEvents.length) {
return;
}
const profilesToAddToEnvelope = [];
for (const profiledTransaction of profiledTransactionEvents) {
const context = profiledTransaction && profiledTransaction.contexts;
const profile_id = context && context['profile'] && context['profile']['profile_id'];
const start_timestamp = context && context['profile'] && context['profile']['start_timestamp'];
if (typeof profile_id !== 'string') {
debugBuild.DEBUG_BUILD && utils$1.logger.log('[Profiling] cannot find profile for a transaction without a profile context');
continue;
}
if (!profile_id) {
debugBuild.DEBUG_BUILD && utils$1.logger.log('[Profiling] cannot find profile for a transaction without a profile context');
continue;
}
// Remove the profile from the transaction context before sending, relay will take care of the rest.
if (context && context['profile']) {
delete context.profile;
}
const profile = utils.takeProfileFromGlobalCache(profile_id);
if (!profile) {
debugBuild.DEBUG_BUILD && utils$1.logger.log(`[Profiling] Could not retrieve profile for transaction: ${profile_id}`);
continue;
}
const profileEvent = utils.createProfilingEvent(
profile_id,
start_timestamp ,
profile,
profiledTransaction ,
);
if (profileEvent) {
profilesToAddToEnvelope.push(profileEvent);
}
}
utils.addProfilesToEnvelope(envelope , profilesToAddToEnvelope);
});
},
};
}) ;
const browserProfilingIntegration = core.defineIntegration(_browserProfilingIntegration);
/**
* Browser profiling integration. Stores any event that has contexts["profile"]["profile_id"]
* This exists because we do not want to await async profiler.stop calls as transaction.finish is called
* in a synchronous context. Instead, we handle sending the profile async from the promise callback and
* rely on being able to pull the event from the cache when we need to construct the envelope. This makes the
* integration less reliable as we might be dropping profiles when the cache is full.
*
* @experimental
* @deprecated Use `browserProfilingIntegration()` instead.
*/
// eslint-disable-next-line deprecation/deprecation
const BrowserProfilingIntegration = core.convertIntegrationFnToClass(
INTEGRATION_NAME,
browserProfilingIntegration,
) ;
// eslint-disable-next-line deprecation/deprecation
exports.BrowserProfilingIntegration = BrowserProfilingIntegration;
exports.browserProfilingIntegration = browserProfilingIntegration;
//# sourceMappingURL=integration.js.map