Next.js website for Rocky Mountain Vending company featuring: - Product catalog with Stripe integration - Service areas and parts pages - Admin dashboard with Clerk authentication - SEO optimized pages with JSON-LD structured data Co-authored-by: Cursor <cursoragent@cursor.com>
95 lines
3.2 KiB
Text
95 lines
3.2 KiB
Text
Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });
|
|
|
|
const debugBuild = require('../debug-build.js');
|
|
const debugLogger = require('../utils/debug-logger.js');
|
|
const envelope = require('../utils/envelope.js');
|
|
const promisebuffer = require('../utils/promisebuffer.js');
|
|
const ratelimit = require('../utils/ratelimit.js');
|
|
const syncpromise = require('../utils/syncpromise.js');
|
|
|
|
const DEFAULT_TRANSPORT_BUFFER_SIZE = 64;
|
|
|
|
/**
|
|
* Creates an instance of a Sentry `Transport`
|
|
*
|
|
* @param options
|
|
* @param makeRequest
|
|
*/
|
|
function createTransport(
|
|
options,
|
|
makeRequest,
|
|
buffer = promisebuffer.makePromiseBuffer(
|
|
options.bufferSize || DEFAULT_TRANSPORT_BUFFER_SIZE,
|
|
),
|
|
) {
|
|
let rateLimits = {};
|
|
const flush = (timeout) => buffer.drain(timeout);
|
|
|
|
function send(envelope$1) {
|
|
const filteredEnvelopeItems = [];
|
|
|
|
// Drop rate limited items from envelope
|
|
envelope.forEachEnvelopeItem(envelope$1, (item, type) => {
|
|
const dataCategory = envelope.envelopeItemTypeToDataCategory(type);
|
|
if (ratelimit.isRateLimited(rateLimits, dataCategory)) {
|
|
options.recordDroppedEvent('ratelimit_backoff', dataCategory);
|
|
} else {
|
|
filteredEnvelopeItems.push(item);
|
|
}
|
|
});
|
|
|
|
// Skip sending if envelope is empty after filtering out rate limited events
|
|
if (filteredEnvelopeItems.length === 0) {
|
|
return syncpromise.resolvedSyncPromise({});
|
|
}
|
|
|
|
const filteredEnvelope = envelope.createEnvelope(envelope$1[0], filteredEnvelopeItems );
|
|
|
|
// Creates client report for each item in an envelope
|
|
const recordEnvelopeLoss = (reason) => {
|
|
envelope.forEachEnvelopeItem(filteredEnvelope, (item, type) => {
|
|
options.recordDroppedEvent(reason, envelope.envelopeItemTypeToDataCategory(type));
|
|
});
|
|
};
|
|
|
|
const requestTask = () =>
|
|
makeRequest({ body: envelope.serializeEnvelope(filteredEnvelope) }).then(
|
|
response => {
|
|
// We don't want to throw on NOK responses, but we want to at least log them
|
|
if (response.statusCode !== undefined && (response.statusCode < 200 || response.statusCode >= 300)) {
|
|
debugBuild.DEBUG_BUILD && debugLogger.debug.warn(`Sentry responded with status code ${response.statusCode} to sent event.`);
|
|
}
|
|
|
|
rateLimits = ratelimit.updateRateLimits(rateLimits, response);
|
|
return response;
|
|
},
|
|
error => {
|
|
recordEnvelopeLoss('network_error');
|
|
debugBuild.DEBUG_BUILD && debugLogger.debug.error('Encountered error running transport request:', error);
|
|
throw error;
|
|
},
|
|
);
|
|
|
|
return buffer.add(requestTask).then(
|
|
result => result,
|
|
error => {
|
|
if (error === promisebuffer.SENTRY_BUFFER_FULL_ERROR) {
|
|
debugBuild.DEBUG_BUILD && debugLogger.debug.error('Skipped sending event because buffer is full.');
|
|
recordEnvelopeLoss('queue_overflow');
|
|
return syncpromise.resolvedSyncPromise({});
|
|
} else {
|
|
throw error;
|
|
}
|
|
},
|
|
);
|
|
}
|
|
|
|
return {
|
|
send,
|
|
flush,
|
|
};
|
|
}
|
|
|
|
exports.DEFAULT_TRANSPORT_BUFFER_SIZE = DEFAULT_TRANSPORT_BUFFER_SIZE;
|
|
exports.createTransport = createTransport;
|
|
//# sourceMappingURL=base.js.map
|