@sentry/tracing
Advanced tools
Comparing version 6.11.0 to 6.12.0-beta.1
import { Hub } from '@sentry/hub'; | ||
import { EventProcessor, Integration, Transaction, TransactionContext } from '@sentry/types'; | ||
import { MetricsInstrumentationOptions } from './metrics'; | ||
import { RequestInstrumentationOptions } from './request'; | ||
@@ -44,2 +45,10 @@ export declare const DEFAULT_MAX_TRANSACTION_DURATION_SECONDS = 600; | ||
/** | ||
* _metricOptions allows the user to send options to change how metrics are collected. | ||
* | ||
* _metricOptions is currently experimental. | ||
* | ||
* Default: undefined | ||
*/ | ||
_metricOptions?: Partial<MetricsInstrumentationOptions>; | ||
/** | ||
* beforeNavigate is called before a pageload/navigation transaction is created and allows users to modify transaction | ||
@@ -46,0 +55,0 @@ * context data, or drop the transaction entirely (by setting `sampled = false` in the context). |
@@ -27,3 +27,2 @@ Object.defineProperty(exports, "__esModule", { value: true }); | ||
this.name = BrowserTracing.id; | ||
this._metrics = new metrics_1.MetricsInstrumentation(); | ||
this._emitOptionsWarning = false; | ||
@@ -42,2 +41,3 @@ var tracingOrigins = request_1.defaultRequestInstrumentationOptions.tracingOrigins; | ||
this.options = tslib_1.__assign(tslib_1.__assign(tslib_1.__assign({}, DEFAULT_BROWSER_TRACING_OPTIONS), _options), { tracingOrigins: tracingOrigins }); | ||
this._metrics = new metrics_1.MetricsInstrumentation(tslib_1.__assign(tslib_1.__assign({}, this.options._metricOptions), metrics_1.DEFAULT_METRICS_INSTR_OPTIONS)); | ||
} | ||
@@ -44,0 +44,0 @@ /** |
import { SpanContext } from '@sentry/types'; | ||
import { Span } from '../span'; | ||
import { Transaction } from '../transaction'; | ||
/** | ||
* Exports a way to add options to our metric collection. Currently experimental. | ||
*/ | ||
export interface MetricsInstrumentationOptions { | ||
_reportAllChanges: boolean; | ||
} | ||
export declare const DEFAULT_METRICS_INSTR_OPTIONS: MetricsInstrumentationOptions; | ||
/** Class tracking metrics */ | ||
@@ -10,3 +17,3 @@ export declare class MetricsInstrumentation { | ||
private _clsEntry; | ||
constructor(); | ||
constructor(_options: MetricsInstrumentationOptions); | ||
/** Add performance related spans to a transaction */ | ||
@@ -13,0 +20,0 @@ addPerformanceEntries(transaction: Transaction): void; |
@@ -10,5 +10,8 @@ Object.defineProperty(exports, "__esModule", { value: true }); | ||
var global = utils_1.getGlobalObject(); | ||
exports.DEFAULT_METRICS_INSTR_OPTIONS = { | ||
_reportAllChanges: false, | ||
}; | ||
/** Class tracking metrics */ | ||
var MetricsInstrumentation = /** @class */ (function () { | ||
function MetricsInstrumentation() { | ||
function MetricsInstrumentation(_options) { | ||
var _a; | ||
@@ -22,3 +25,3 @@ this._measurements = {}; | ||
this._trackCLS(); | ||
this._trackLCP(); | ||
this._trackLCP(_options._reportAllChanges); | ||
this._trackFID(); | ||
@@ -236,3 +239,3 @@ } | ||
/** Starts tracking the Largest Contentful Paint on the current page. */ | ||
MetricsInstrumentation.prototype._trackLCP = function () { | ||
MetricsInstrumentation.prototype._trackLCP = function (reportAllChanges) { | ||
var _this = this; | ||
@@ -250,3 +253,3 @@ getLCP_1.getLCP(function (metric) { | ||
_this._lcpEntry = entry; | ||
}); | ||
}, reportAllChanges); | ||
}; | ||
@@ -253,0 +256,0 @@ /** Starts tracking the First Input Delay on the current page. */ |
import { Hub } from '@sentry/hub'; | ||
import { EventProcessor, Integration } from '@sentry/types'; | ||
interface PgOptions { | ||
usePgNative?: boolean; | ||
} | ||
/** Tracing integration for node-postgres package */ | ||
@@ -13,2 +16,4 @@ export declare class Postgres implements Integration { | ||
name: string; | ||
private _usePgNative; | ||
constructor(options?: PgOptions); | ||
/** | ||
@@ -19,2 +24,3 @@ * @inheritDoc | ||
} | ||
export {}; | ||
//# sourceMappingURL=postgres.d.ts.map |
@@ -5,3 +5,4 @@ Object.defineProperty(exports, "__esModule", { value: true }); | ||
var Postgres = /** @class */ (function () { | ||
function Postgres() { | ||
function Postgres(options) { | ||
if (options === void 0) { options = {}; } | ||
/** | ||
@@ -11,2 +12,3 @@ * @inheritDoc | ||
this.name = Postgres.id; | ||
this._usePgNative = !!options.usePgNative; | ||
} | ||
@@ -17,2 +19,3 @@ /** | ||
Postgres.prototype.setupOnce = function (_, getCurrentHub) { | ||
var _a; | ||
var pkg = utils_1.loadModule('pg'); | ||
@@ -23,2 +26,7 @@ if (!pkg) { | ||
} | ||
if (this._usePgNative && !((_a = pkg.native) === null || _a === void 0 ? void 0 : _a.Client)) { | ||
utils_1.logger.error("Postgres Integration was unable to access 'pg-native' bindings."); | ||
return; | ||
} | ||
var Client = (this._usePgNative ? pkg.native : pkg).Client; | ||
/** | ||
@@ -31,3 +39,3 @@ * function (query, callback) => void | ||
*/ | ||
utils_1.fill(pkg.Client.prototype, 'query', function (orig) { | ||
utils_1.fill(Client.prototype, 'query', function (orig) { | ||
return function (config, values, callback) { | ||
@@ -34,0 +42,0 @@ var _a, _b, _c; |
import { Hub } from '@sentry/hub'; | ||
import { EventProcessor, Integration, Transaction, TransactionContext } from '@sentry/types'; | ||
import { MetricsInstrumentationOptions } from './metrics'; | ||
import { RequestInstrumentationOptions } from './request'; | ||
@@ -44,2 +45,10 @@ export declare const DEFAULT_MAX_TRANSACTION_DURATION_SECONDS = 600; | ||
/** | ||
* _metricOptions allows the user to send options to change how metrics are collected. | ||
* | ||
* _metricOptions is currently experimental. | ||
* | ||
* Default: undefined | ||
*/ | ||
_metricOptions?: Partial<MetricsInstrumentationOptions>; | ||
/** | ||
* beforeNavigate is called before a pageload/navigation transaction is created and allows users to modify transaction | ||
@@ -46,0 +55,0 @@ * context data, or drop the transaction entirely (by setting `sampled = false` in the context). |
@@ -8,3 +8,3 @@ import { __assign } from "tslib"; | ||
import { registerBackgroundTabDetection } from './backgroundtab'; | ||
import { MetricsInstrumentation } from './metrics'; | ||
import { DEFAULT_METRICS_INSTR_OPTIONS, MetricsInstrumentation } from './metrics'; | ||
import { defaultRequestInstrumentationOptions, instrumentOutgoingRequests, } from './request'; | ||
@@ -27,3 +27,2 @@ import { instrumentRoutingWithDefaults } from './router'; | ||
this.name = BrowserTracing.id; | ||
this._metrics = new MetricsInstrumentation(); | ||
this._emitOptionsWarning = false; | ||
@@ -42,2 +41,3 @@ var tracingOrigins = defaultRequestInstrumentationOptions.tracingOrigins; | ||
this.options = __assign(__assign(__assign({}, DEFAULT_BROWSER_TRACING_OPTIONS), _options), { tracingOrigins: tracingOrigins }); | ||
this._metrics = new MetricsInstrumentation(__assign(__assign({}, this.options._metricOptions), DEFAULT_METRICS_INSTR_OPTIONS)); | ||
} | ||
@@ -44,0 +44,0 @@ /** |
import { SpanContext } from '@sentry/types'; | ||
import { Span } from '../span'; | ||
import { Transaction } from '../transaction'; | ||
/** | ||
* Exports a way to add options to our metric collection. Currently experimental. | ||
*/ | ||
export interface MetricsInstrumentationOptions { | ||
_reportAllChanges: boolean; | ||
} | ||
export declare const DEFAULT_METRICS_INSTR_OPTIONS: MetricsInstrumentationOptions; | ||
/** Class tracking metrics */ | ||
@@ -10,3 +17,3 @@ export declare class MetricsInstrumentation { | ||
private _clsEntry; | ||
constructor(); | ||
constructor(_options: MetricsInstrumentationOptions); | ||
/** Add performance related spans to a transaction */ | ||
@@ -13,0 +20,0 @@ addPerformanceEntries(transaction: Transaction): void; |
@@ -9,5 +9,8 @@ import { __assign, __rest } from "tslib"; | ||
var global = getGlobalObject(); | ||
export var DEFAULT_METRICS_INSTR_OPTIONS = { | ||
_reportAllChanges: false, | ||
}; | ||
/** Class tracking metrics */ | ||
var MetricsInstrumentation = /** @class */ (function () { | ||
function MetricsInstrumentation() { | ||
function MetricsInstrumentation(_options) { | ||
var _a; | ||
@@ -21,3 +24,3 @@ this._measurements = {}; | ||
this._trackCLS(); | ||
this._trackLCP(); | ||
this._trackLCP(_options._reportAllChanges); | ||
this._trackFID(); | ||
@@ -235,3 +238,3 @@ } | ||
/** Starts tracking the Largest Contentful Paint on the current page. */ | ||
MetricsInstrumentation.prototype._trackLCP = function () { | ||
MetricsInstrumentation.prototype._trackLCP = function (reportAllChanges) { | ||
var _this = this; | ||
@@ -249,3 +252,3 @@ getLCP(function (metric) { | ||
_this._lcpEntry = entry; | ||
}); | ||
}, reportAllChanges); | ||
}; | ||
@@ -252,0 +255,0 @@ /** Starts tracking the First Input Delay on the current page. */ |
import { Hub } from '@sentry/hub'; | ||
import { EventProcessor, Integration } from '@sentry/types'; | ||
interface PgOptions { | ||
usePgNative?: boolean; | ||
} | ||
/** Tracing integration for node-postgres package */ | ||
@@ -13,2 +16,4 @@ export declare class Postgres implements Integration { | ||
name: string; | ||
private _usePgNative; | ||
constructor(options?: PgOptions); | ||
/** | ||
@@ -19,2 +24,3 @@ * @inheritDoc | ||
} | ||
export {}; | ||
//# sourceMappingURL=postgres.d.ts.map |
import { fill, isThenable, loadModule, logger } from '@sentry/utils'; | ||
/** Tracing integration for node-postgres package */ | ||
var Postgres = /** @class */ (function () { | ||
function Postgres() { | ||
function Postgres(options) { | ||
if (options === void 0) { options = {}; } | ||
/** | ||
@@ -9,2 +10,3 @@ * @inheritDoc | ||
this.name = Postgres.id; | ||
this._usePgNative = !!options.usePgNative; | ||
} | ||
@@ -15,2 +17,3 @@ /** | ||
Postgres.prototype.setupOnce = function (_, getCurrentHub) { | ||
var _a; | ||
var pkg = loadModule('pg'); | ||
@@ -21,2 +24,7 @@ if (!pkg) { | ||
} | ||
if (this._usePgNative && !((_a = pkg.native) === null || _a === void 0 ? void 0 : _a.Client)) { | ||
logger.error("Postgres Integration was unable to access 'pg-native' bindings."); | ||
return; | ||
} | ||
var Client = (this._usePgNative ? pkg.native : pkg).Client; | ||
/** | ||
@@ -29,3 +37,3 @@ * function (query, callback) => void | ||
*/ | ||
fill(pkg.Client.prototype, 'query', function (orig) { | ||
fill(Client.prototype, 'query', function (orig) { | ||
return function (config, values, callback) { | ||
@@ -32,0 +40,0 @@ var _a, _b, _c; |
{ | ||
"name": "@sentry/tracing", | ||
"version": "6.11.0", | ||
"version": "6.12.0-beta.1", | ||
"description": "Extensions for Sentry AM", | ||
@@ -19,11 +19,11 @@ "repository": "git://github.com/getsentry/sentry-javascript.git", | ||
"dependencies": { | ||
"@sentry/hub": "6.11.0", | ||
"@sentry/minimal": "6.11.0", | ||
"@sentry/types": "6.11.0", | ||
"@sentry/utils": "6.11.0", | ||
"@sentry/hub": "6.12.0-beta.1", | ||
"@sentry/minimal": "6.12.0-beta.1", | ||
"@sentry/types": "6.12.0-beta.1", | ||
"@sentry/utils": "6.12.0-beta.1", | ||
"tslib": "^1.9.3" | ||
}, | ||
"devDependencies": { | ||
"@sentry-internal/eslint-config-sdk": "6.11.0", | ||
"@sentry/browser": "6.11.0", | ||
"@sentry-internal/eslint-config-sdk": "6.12.0-beta.1", | ||
"@sentry/browser": "6.12.0-beta.1", | ||
"@types/express": "^4.17.1", | ||
@@ -30,0 +30,0 @@ "@types/jsdom": "^16.2.3", |
Sorry, the diff of this file is too big to display
Sorry, the diff of this file is not supported yet
Sorry, the diff of this file is too big to display
Sorry, the diff of this file is not supported yet
Sorry, the diff of this file is not supported yet
Sorry, the diff of this file is not supported yet
Sorry, the diff of this file is not supported yet
Sorry, the diff of this file is not supported yet
Sorry, the diff of this file is not supported yet
Sorry, the diff of this file is not supported yet
Sorry, the diff of this file is not supported yet
Sorry, the diff of this file is not supported yet
Sorry, the diff of this file is not supported yet
Sorry, the diff of this file is not supported yet
Sorry, the diff of this file is not supported yet
Sorry, the diff of this file is not supported yet
License Policy Violation
LicenseThis package is not allowed per your license policy. Review the package's license to ensure compliance.
Found 1 instance in 1 package
No v1
QualityPackage is not semver >=1. This means it is not stable and does not support ^ ranges.
Found 1 instance in 1 package
License Policy Violation
LicenseThis package is not allowed per your license policy. Review the package's license to ensure compliance.
Found 1 instance in 1 package
2271592
16560
2
+ Added@sentry/hub@6.12.0-beta.1(transitive)
+ Added@sentry/minimal@6.12.0-beta.1(transitive)
+ Added@sentry/types@6.12.0-beta.1(transitive)
+ Added@sentry/utils@6.12.0-beta.1(transitive)
- Removed@sentry/hub@6.11.0(transitive)
- Removed@sentry/minimal@6.11.0(transitive)
- Removed@sentry/types@6.11.0(transitive)
- Removed@sentry/utils@6.11.0(transitive)
Updated@sentry/hub@6.12.0-beta.1
Updated@sentry/types@6.12.0-beta.1
Updated@sentry/utils@6.12.0-beta.1