@dxos/observability 0.5.5-main.23d7ea6 → 0.5.5-main.2a3283d
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/lib/browser/chunk-3LKCQYWD.mjs +159 -0
- package/dist/lib/browser/chunk-3LKCQYWD.mjs.map +7 -0
- package/dist/lib/browser/chunk-KDP3SESE.mjs +1 -0
- package/dist/lib/browser/{chunk-5E3CR23D.mjs → chunk-KRN52DNQ.mjs} +5 -8
- package/dist/lib/browser/{chunk-5E3CR23D.mjs.map → chunk-KRN52DNQ.mjs.map} +3 -3
- package/dist/lib/browser/index.mjs +2 -2
- package/dist/lib/browser/meta.json +1 -1
- package/dist/lib/browser/observability-NTPJJQW5.mjs +8 -0
- package/dist/lib/browser/observability-NTPJJQW5.mjs.map +7 -0
- package/dist/lib/browser/segment/index.mjs +2 -1
- package/dist/lib/browser/segment/index.mjs.map +1 -1
- package/dist/lib/browser/sentry/index.mjs +2 -7
- package/dist/lib/node/{chunk-NFII7GBC.cjs → chunk-4RV4LMAG.cjs} +11 -14
- package/dist/lib/node/{chunk-NFII7GBC.cjs.map → chunk-4RV4LMAG.cjs.map} +3 -3
- package/dist/lib/node/chunk-GIYJMZEQ.cjs +2 -0
- package/dist/lib/node/chunk-GIYJMZEQ.cjs.map +7 -0
- package/dist/lib/node/chunk-HKBUNAUG.cjs +161 -0
- package/dist/lib/node/chunk-HKBUNAUG.cjs.map +7 -0
- package/dist/lib/node/index.cjs +16 -16
- package/dist/lib/node/index.cjs.map +1 -1
- package/dist/lib/node/meta.json +1 -1
- package/dist/lib/node/{observability-6KNNVT6F.cjs → observability-234R4TZL.cjs} +7 -7
- package/dist/lib/node/{observability-6KNNVT6F.cjs.map → observability-234R4TZL.cjs.map} +2 -2
- package/dist/lib/node/segment/index.cjs +3 -2
- package/dist/lib/node/segment/index.cjs.map +1 -1
- package/dist/lib/node/sentry/index.cjs +11 -12
- package/dist/lib/node/sentry/index.cjs.map +2 -2
- package/dist/types/src/observability.d.ts.map +1 -1
- package/dist/types/src/observability.js +1 -5
- package/dist/types/src/observability.js.map +1 -1
- package/dist/types/src/sentry/browser.d.ts +1 -2
- package/dist/types/src/sentry/browser.d.ts.map +1 -1
- package/dist/types/src/sentry/browser.js +7 -19
- package/dist/types/src/sentry/browser.js.map +1 -1
- package/dist/types/src/sentry/index.d.ts +0 -1
- package/dist/types/src/sentry/index.d.ts.map +1 -1
- package/dist/types/src/sentry/index.js +0 -4
- package/dist/types/src/sentry/index.js.map +1 -1
- package/dist/types/src/sentry/node.d.ts.map +1 -1
- package/dist/types/src/sentry/node.js +6 -28
- package/dist/types/src/sentry/node.js.map +1 -1
- package/dist/types/src/sentry/sentry-log-processor.js +4 -4
- package/dist/types/src/sentry/sentry-log-processor.js.map +1 -1
- package/package.json +18 -19
- package/src/observability.ts +1 -4
- package/src/sentry/browser.ts +12 -7
- package/src/sentry/index.ts +0 -3
- package/src/sentry/node.ts +10 -7
- package/src/sentry/sentry-log-processor.ts +1 -1
- package/dist/lib/browser/chunk-I72ZJDDP.mjs +0 -328
- package/dist/lib/browser/chunk-I72ZJDDP.mjs.map +0 -7
- package/dist/lib/browser/observability-SGYNJETW.mjs +0 -8
- package/dist/lib/node/chunk-2F4DCY4M.cjs +0 -345
- package/dist/lib/node/chunk-2F4DCY4M.cjs.map +0 -7
- package/dist/types/src/sentry/tracing.d.ts +0 -5
- package/dist/types/src/sentry/tracing.d.ts.map +0 -1
- package/dist/types/src/sentry/tracing.js +0 -141
- package/dist/types/src/sentry/tracing.js.map +0 -1
- package/dist/types/src/sentry/tracing.test.d.ts +0 -2
- package/dist/types/src/sentry/tracing.test.d.ts.map +0 -1
- package/dist/types/src/sentry/tracing.test.js +0 -76
- package/dist/types/src/sentry/tracing.test.js.map +0 -1
- package/src/sentry/tracing.test.ts +0 -62
- package/src/sentry/tracing.ts +0 -153
- /package/dist/lib/browser/{observability-SGYNJETW.mjs.map → chunk-KDP3SESE.mjs.map} +0 -0
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"sentry-log-processor.js","sourceRoot":"","sources":["../../../../src/sentry/sentry-log-processor.ts"],"names":[],"mappings":";AAAA,EAAE;AACF,0BAA0B;AAC1B,EAAE;;;AAIF,mCAAkG;AAClG,qCAA0D;AAE1D,
|
|
1
|
+
{"version":3,"file":"sentry-log-processor.js","sourceRoot":"","sources":["../../../../src/sentry/sentry-log-processor.ts"],"names":[],"mappings":"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"}
|
package/package.json
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@dxos/observability",
|
|
3
|
-
"version": "0.5.5-main.
|
|
3
|
+
"version": "0.5.5-main.2a3283d",
|
|
4
4
|
"description": "Provides a common interface for app and platform observability",
|
|
5
5
|
"homepage": "https://dxos.org",
|
|
6
6
|
"bugs": "https://github.com/dxos/dxos/issues",
|
|
@@ -60,31 +60,30 @@
|
|
|
60
60
|
"dependencies": {
|
|
61
61
|
"@segment/analytics-node": "^2.1.0",
|
|
62
62
|
"@segment/snippet": "^4.15.3",
|
|
63
|
-
"@sentry/browser": "^7.
|
|
64
|
-
"@sentry/
|
|
65
|
-
"@sentry/node": "^7.100.1",
|
|
66
|
-
"@sentry/tracing": "^7.100.1",
|
|
63
|
+
"@sentry/browser": "^8.7.0",
|
|
64
|
+
"@sentry/node": "^8.7.0",
|
|
67
65
|
"datadog-metrics": "^0.11.1",
|
|
68
66
|
"debug": "^4.3.4",
|
|
69
67
|
"js-yaml": "^4.1.0",
|
|
70
68
|
"localforage": "^1.10.0",
|
|
71
69
|
"uuid": "^8.3.2",
|
|
72
|
-
"@dxos/async": "0.5.5-main.
|
|
73
|
-
"@dxos/
|
|
74
|
-
"@dxos/
|
|
75
|
-
"@dxos/
|
|
76
|
-
"@dxos/
|
|
77
|
-
"@dxos/
|
|
78
|
-
"@dxos/
|
|
79
|
-
"@dxos/
|
|
80
|
-
"@dxos/
|
|
81
|
-
"@dxos/node-std": "0.5.5-main.
|
|
82
|
-
"@dxos/protocols": "0.5.5-main.
|
|
83
|
-
"@dxos/react-client": "0.5.5-main.
|
|
84
|
-
"@dxos/
|
|
70
|
+
"@dxos/async": "0.5.5-main.2a3283d",
|
|
71
|
+
"@dxos/config": "0.5.5-main.2a3283d",
|
|
72
|
+
"@dxos/debug": "0.5.5-main.2a3283d",
|
|
73
|
+
"@dxos/client-services": "0.5.5-main.2a3283d",
|
|
74
|
+
"@dxos/client-protocol": "0.5.5-main.2a3283d",
|
|
75
|
+
"@dxos/log": "0.5.5-main.2a3283d",
|
|
76
|
+
"@dxos/invariant": "0.5.5-main.2a3283d",
|
|
77
|
+
"@dxos/network-manager": "0.5.5-main.2a3283d",
|
|
78
|
+
"@dxos/context": "0.5.5-main.2a3283d",
|
|
79
|
+
"@dxos/node-std": "0.5.5-main.2a3283d",
|
|
80
|
+
"@dxos/protocols": "0.5.5-main.2a3283d",
|
|
81
|
+
"@dxos/react-client": "0.5.5-main.2a3283d",
|
|
82
|
+
"@dxos/tracing": "0.5.5-main.2a3283d",
|
|
83
|
+
"@dxos/util": "0.5.5-main.2a3283d"
|
|
85
84
|
},
|
|
86
85
|
"devDependencies": {
|
|
87
|
-
"@sentry/types": "^7.
|
|
86
|
+
"@sentry/types": "^8.7.0",
|
|
88
87
|
"@types/debug": "^4.1.10",
|
|
89
88
|
"@types/js-yaml": "^4.0.5",
|
|
90
89
|
"sentry-testkit": "^5.0.5"
|
package/src/observability.ts
CHANGED
|
@@ -451,7 +451,7 @@ export class Observability {
|
|
|
451
451
|
|
|
452
452
|
private async _initErrorLogs() {
|
|
453
453
|
if (this._secrets.SENTRY_DESTINATION && this._mode !== 'disabled') {
|
|
454
|
-
const { captureException,
|
|
454
|
+
const { captureException, captureUserFeedback, init, setTag } = await import('./sentry');
|
|
455
455
|
this._captureException = captureException;
|
|
456
456
|
this._captureUserFeedback = captureUserFeedback;
|
|
457
457
|
|
|
@@ -470,9 +470,6 @@ export class Observability {
|
|
|
470
470
|
scrubFilenames: this._mode !== 'full',
|
|
471
471
|
onError: (event) => logProcessor.addLogBreadcrumbsTo(event),
|
|
472
472
|
});
|
|
473
|
-
if (this._errorReportingOptions?.tracing) {
|
|
474
|
-
configureTracing();
|
|
475
|
-
}
|
|
476
473
|
|
|
477
474
|
// TODO(nf): set platform at instantiation? needed for node.
|
|
478
475
|
log.runtimeConfig.processors.push(logProcessor.logProcessor);
|
package/src/sentry/browser.ts
CHANGED
|
@@ -10,20 +10,20 @@ import {
|
|
|
10
10
|
captureMessage as naturalCaptureMessage,
|
|
11
11
|
sendFeedback as naturalSendFeedback,
|
|
12
12
|
withScope as naturalWithScope,
|
|
13
|
-
BrowserTracing,
|
|
14
|
-
replayIntegration,
|
|
15
13
|
breadcrumbsIntegration,
|
|
14
|
+
browserTracingIntegration,
|
|
16
15
|
feedbackIntegration,
|
|
16
|
+
httpClientIntegration,
|
|
17
|
+
replayIntegration,
|
|
18
|
+
metrics,
|
|
19
|
+
startInactiveSpan,
|
|
17
20
|
} from '@sentry/browser';
|
|
18
|
-
import { httpClientIntegration } from '@sentry/integrations';
|
|
19
21
|
|
|
20
22
|
import { log } from '@dxos/log';
|
|
23
|
+
import { TRACE_PROCESSOR } from '@dxos/tracing';
|
|
21
24
|
|
|
22
25
|
import { type InitOptions } from './types';
|
|
23
26
|
|
|
24
|
-
// Browser only feature.
|
|
25
|
-
export * from './tracing';
|
|
26
|
-
|
|
27
27
|
// Polyfill export.
|
|
28
28
|
export { setTag, setTags, setUser } from '@sentry/browser';
|
|
29
29
|
|
|
@@ -45,7 +45,7 @@ export const init = (options: InitOptions) => {
|
|
|
45
45
|
breadcrumbsIntegration({ console: false, fetch: false }),
|
|
46
46
|
httpClientIntegration({ failedRequestStatusCodes: [[400, 599]] }),
|
|
47
47
|
feedbackIntegration({ autoInject: false }),
|
|
48
|
-
...(options.tracing ? [
|
|
48
|
+
...(options.tracing ? [browserTracingIntegration()] : []),
|
|
49
49
|
...(options.replay ? [replayIntegration({ blockAllMedia: true, maskAllText: true })] : []),
|
|
50
50
|
],
|
|
51
51
|
replaysSessionSampleRate: options.replaySampleRate,
|
|
@@ -58,6 +58,11 @@ export const init = (options: InitOptions) => {
|
|
|
58
58
|
},
|
|
59
59
|
});
|
|
60
60
|
|
|
61
|
+
TRACE_PROCESSOR.remoteMetrics.registerProcessor(metrics);
|
|
62
|
+
TRACE_PROCESSOR.remoteTracing.registerProcessor({
|
|
63
|
+
startSpan: startInactiveSpan,
|
|
64
|
+
});
|
|
65
|
+
|
|
61
66
|
Object.entries(options.properties ?? {}).forEach(([key, value]) => {
|
|
62
67
|
setTag(key, value);
|
|
63
68
|
});
|
package/src/sentry/index.ts
CHANGED
package/src/sentry/node.ts
CHANGED
|
@@ -2,18 +2,20 @@
|
|
|
2
2
|
// Copyright 2022 DXOS.org
|
|
3
3
|
//
|
|
4
4
|
|
|
5
|
-
import { captureConsoleIntegration } from '@sentry/integrations';
|
|
6
5
|
import {
|
|
6
|
+
type Event,
|
|
7
7
|
init as naturalInit,
|
|
8
8
|
setTag,
|
|
9
9
|
addBreadcrumb as naturalAddBreadcrumb,
|
|
10
10
|
captureException as naturalCaptureException,
|
|
11
11
|
captureMessage as naturalCaptureMessage,
|
|
12
12
|
withScope as naturalWithScope,
|
|
13
|
+
metrics,
|
|
14
|
+
startInactiveSpan,
|
|
13
15
|
} from '@sentry/node';
|
|
14
|
-
import type { Event } from '@sentry/node';
|
|
15
16
|
|
|
16
17
|
import { log } from '@dxos/log';
|
|
18
|
+
import { TRACE_PROCESSOR } from '@dxos/tracing';
|
|
17
19
|
|
|
18
20
|
import { type InitOptions } from './types';
|
|
19
21
|
|
|
@@ -28,17 +30,13 @@ export { setTag, setTags, setUser } from '@sentry/node';
|
|
|
28
30
|
*/
|
|
29
31
|
export const init = (options: InitOptions) => {
|
|
30
32
|
try {
|
|
31
|
-
if (options.tracing) {
|
|
32
|
-
void import('@sentry/tracing');
|
|
33
|
-
}
|
|
34
|
-
|
|
35
33
|
naturalInit({
|
|
36
34
|
enabled: options.enable ?? true,
|
|
37
35
|
dsn: options.destination,
|
|
38
36
|
serverName: options.installationId,
|
|
39
37
|
release: options.release,
|
|
40
38
|
environment: options.environment ?? process.env.DX_ENVIRONMENT,
|
|
41
|
-
integrations: [
|
|
39
|
+
integrations: [],
|
|
42
40
|
tracesSampleRate: options.sampleRate,
|
|
43
41
|
transport: options.transport,
|
|
44
42
|
beforeSend: (event) => {
|
|
@@ -49,6 +47,11 @@ export const init = (options: InitOptions) => {
|
|
|
49
47
|
},
|
|
50
48
|
});
|
|
51
49
|
|
|
50
|
+
TRACE_PROCESSOR.remoteMetrics.registerProcessor(metrics);
|
|
51
|
+
TRACE_PROCESSOR.remoteTracing.registerProcessor({
|
|
52
|
+
startSpan: startInactiveSpan,
|
|
53
|
+
});
|
|
54
|
+
|
|
52
55
|
Object.entries(options.properties ?? {}).forEach(([key, value]) => {
|
|
53
56
|
setTag(key, value);
|
|
54
57
|
});
|
|
@@ -7,7 +7,7 @@ import type { Breadcrumb, SeverityLevel, Event } from '@sentry/types';
|
|
|
7
7
|
import { type LogConfig, type LogEntry, LogLevel, type LogProcessor, shouldLog } from '@dxos/log';
|
|
8
8
|
import { CircularBuffer, getDebugName } from '@dxos/util';
|
|
9
9
|
|
|
10
|
-
import { withScope, captureException, captureMessage } from './';
|
|
10
|
+
import { withScope, captureException, captureMessage } from './node';
|
|
11
11
|
|
|
12
12
|
const MAX_LOG_BREADCRUMBS = 80;
|
|
13
13
|
|
|
@@ -1,328 +0,0 @@
|
|
|
1
|
-
// packages/sdk/observability/src/sentry/browser.ts
|
|
2
|
-
import { init as naturalInit, setTag, addBreadcrumb as naturalAddBreadcrumb, captureException as naturalCaptureException, captureMessage as naturalCaptureMessage, sendFeedback as naturalSendFeedback, withScope as naturalWithScope, BrowserTracing, replayIntegration, breadcrumbsIntegration, feedbackIntegration } from "@sentry/browser";
|
|
3
|
-
import { httpClientIntegration } from "@sentry/integrations";
|
|
4
|
-
import { log as log2 } from "@dxos/log";
|
|
5
|
-
|
|
6
|
-
// packages/sdk/observability/src/sentry/tracing.ts
|
|
7
|
-
import { getCurrentHub } from "@sentry/browser";
|
|
8
|
-
import { runInContext, scheduleMicroTask, Trigger } from "@dxos/async";
|
|
9
|
-
import { Context } from "@dxos/context";
|
|
10
|
-
import { invariant } from "@dxos/invariant";
|
|
11
|
-
import { getContextFromEntry, log, LogLevel } from "@dxos/log";
|
|
12
|
-
var __dxlog_file = "/home/runner/work/dxos/dxos/packages/sdk/observability/src/sentry/tracing.ts";
|
|
13
|
-
var REPORT_SPANS = false;
|
|
14
|
-
var TX;
|
|
15
|
-
var SPAN_MAP = /* @__PURE__ */ new Map();
|
|
16
|
-
var SENTRY_INITIALIZED = new Trigger();
|
|
17
|
-
var ctx = new Context({
|
|
18
|
-
onError: (err) => log.warn("Unhandled error in Sentry context", err, {
|
|
19
|
-
F: __dxlog_file,
|
|
20
|
-
L: 20,
|
|
21
|
-
S: void 0,
|
|
22
|
-
C: (f, a) => f(...a)
|
|
23
|
-
})
|
|
24
|
-
});
|
|
25
|
-
ctx.maxSafeDisposeCallbacks = 1e4;
|
|
26
|
-
var tracingConfigured = false;
|
|
27
|
-
var configureTracing = () => {
|
|
28
|
-
tracingConfigured = true;
|
|
29
|
-
runInContext(ctx, () => {
|
|
30
|
-
TX = getCurrentHub().startTransaction({
|
|
31
|
-
name: "DXOS Core Tracing",
|
|
32
|
-
op: "dxos"
|
|
33
|
-
});
|
|
34
|
-
invariant(TX, "Failed to create trace", {
|
|
35
|
-
F: __dxlog_file,
|
|
36
|
-
L: 33,
|
|
37
|
-
S: void 0,
|
|
38
|
-
A: [
|
|
39
|
-
"TX",
|
|
40
|
-
"'Failed to create trace'"
|
|
41
|
-
]
|
|
42
|
-
});
|
|
43
|
-
if (typeof window !== "undefined") {
|
|
44
|
-
window.addEventListener("beforeunload", () => {
|
|
45
|
-
finish();
|
|
46
|
-
});
|
|
47
|
-
}
|
|
48
|
-
if (typeof process !== "undefined") {
|
|
49
|
-
process.on("exit", () => {
|
|
50
|
-
finish();
|
|
51
|
-
});
|
|
52
|
-
}
|
|
53
|
-
SENTRY_INITIALIZED.wake();
|
|
54
|
-
});
|
|
55
|
-
};
|
|
56
|
-
var finish = () => {
|
|
57
|
-
for (const span of Array.from(SPAN_MAP.values()).reverse()) {
|
|
58
|
-
try {
|
|
59
|
-
span.finish();
|
|
60
|
-
} catch (err) {
|
|
61
|
-
log.warn("Failed to finish span", err, {
|
|
62
|
-
F: __dxlog_file,
|
|
63
|
-
L: 54,
|
|
64
|
-
S: void 0,
|
|
65
|
-
C: (f, a) => f(...a)
|
|
66
|
-
});
|
|
67
|
-
}
|
|
68
|
-
}
|
|
69
|
-
TX.finish();
|
|
70
|
-
};
|
|
71
|
-
var SENTRY_PROCESSOR = (config, entry) => {
|
|
72
|
-
if (!tracingConfigured) {
|
|
73
|
-
return;
|
|
74
|
-
}
|
|
75
|
-
const { message, level, error } = entry;
|
|
76
|
-
const context = getContextFromEntry(entry);
|
|
77
|
-
if (level !== LogLevel.TRACE) {
|
|
78
|
-
return;
|
|
79
|
-
}
|
|
80
|
-
scheduleMicroTask(ctx, async () => {
|
|
81
|
-
await SENTRY_INITIALIZED.wait();
|
|
82
|
-
if (REPORT_SPANS && context?.span) {
|
|
83
|
-
switch (context.span.command) {
|
|
84
|
-
case "begin": {
|
|
85
|
-
const id = context.span.id;
|
|
86
|
-
if (!id || SPAN_MAP.has(id)) {
|
|
87
|
-
log.warn("Cannot begin span", id, {
|
|
88
|
-
F: __dxlog_file,
|
|
89
|
-
L: 82,
|
|
90
|
-
S: void 0,
|
|
91
|
-
C: (f, a) => f(...a)
|
|
92
|
-
});
|
|
93
|
-
return;
|
|
94
|
-
}
|
|
95
|
-
let parentSpan = TX;
|
|
96
|
-
if (context.span.parent) {
|
|
97
|
-
parentSpan = SPAN_MAP.get(context.span.parent) ?? TX;
|
|
98
|
-
}
|
|
99
|
-
let logContext;
|
|
100
|
-
try {
|
|
101
|
-
logContext = JSON.stringify({
|
|
102
|
-
...context,
|
|
103
|
-
message,
|
|
104
|
-
level,
|
|
105
|
-
error
|
|
106
|
-
});
|
|
107
|
-
} catch (err) {
|
|
108
|
-
logContext = JSON.stringify(context);
|
|
109
|
-
}
|
|
110
|
-
const span = parentSpan.startChild({
|
|
111
|
-
op: message,
|
|
112
|
-
data: {
|
|
113
|
-
...context.span.data,
|
|
114
|
-
"@dxos/log": logContext
|
|
115
|
-
}
|
|
116
|
-
});
|
|
117
|
-
SPAN_MAP.set(context.span.id, span);
|
|
118
|
-
break;
|
|
119
|
-
}
|
|
120
|
-
case "end": {
|
|
121
|
-
const span = SPAN_MAP.get(context.span.id);
|
|
122
|
-
if (span) {
|
|
123
|
-
span.setStatus(getSpanStatus(context.span.status));
|
|
124
|
-
context.span.data && Object.entries(context.span.data).forEach(([key, value]) => span.setData(key, value));
|
|
125
|
-
span.finish();
|
|
126
|
-
SPAN_MAP.delete(context.span.id);
|
|
127
|
-
} else {
|
|
128
|
-
log.warn("Cannot end span", context.span.id, {
|
|
129
|
-
F: __dxlog_file,
|
|
130
|
-
L: 117,
|
|
131
|
-
S: void 0,
|
|
132
|
-
C: (f, a) => f(...a)
|
|
133
|
-
});
|
|
134
|
-
}
|
|
135
|
-
break;
|
|
136
|
-
}
|
|
137
|
-
case "update": {
|
|
138
|
-
const span = SPAN_MAP.get(context.span.id);
|
|
139
|
-
if (span) {
|
|
140
|
-
context.span.data && Object.entries(context.span.data).forEach(([key, value]) => span.setData(key, value));
|
|
141
|
-
} else {
|
|
142
|
-
log.warn("Cannot update span", context.span.id, {
|
|
143
|
-
F: __dxlog_file,
|
|
144
|
-
L: 127,
|
|
145
|
-
S: void 0,
|
|
146
|
-
C: (f, a) => f(...a)
|
|
147
|
-
});
|
|
148
|
-
}
|
|
149
|
-
break;
|
|
150
|
-
}
|
|
151
|
-
default: {
|
|
152
|
-
log.warn("Unknown span command", context.span.command, {
|
|
153
|
-
F: __dxlog_file,
|
|
154
|
-
L: 133,
|
|
155
|
-
S: void 0,
|
|
156
|
-
C: (f, a) => f(...a)
|
|
157
|
-
});
|
|
158
|
-
}
|
|
159
|
-
}
|
|
160
|
-
}
|
|
161
|
-
});
|
|
162
|
-
};
|
|
163
|
-
log.runtimeConfig.processors.push(SENTRY_PROCESSOR);
|
|
164
|
-
var getSpanStatus = (status) => {
|
|
165
|
-
switch (status) {
|
|
166
|
-
case "ok":
|
|
167
|
-
return "ok";
|
|
168
|
-
case "error":
|
|
169
|
-
return "not_found";
|
|
170
|
-
}
|
|
171
|
-
return status ?? "ok";
|
|
172
|
-
};
|
|
173
|
-
|
|
174
|
-
// packages/sdk/observability/src/sentry/browser.ts
|
|
175
|
-
import { setTag as setTag2, setTags, setUser } from "@sentry/browser";
|
|
176
|
-
var __dxlog_file2 = "/home/runner/work/dxos/dxos/packages/sdk/observability/src/sentry/browser.ts";
|
|
177
|
-
var init = (options) => {
|
|
178
|
-
try {
|
|
179
|
-
log2("sentry init", options, {
|
|
180
|
-
F: __dxlog_file2,
|
|
181
|
-
L: 38,
|
|
182
|
-
S: void 0,
|
|
183
|
-
C: (f, a) => f(...a)
|
|
184
|
-
});
|
|
185
|
-
naturalInit({
|
|
186
|
-
enabled: options.enable ?? true,
|
|
187
|
-
dsn: options.destination,
|
|
188
|
-
release: options.release,
|
|
189
|
-
environment: options.environment,
|
|
190
|
-
integrations: [
|
|
191
|
-
breadcrumbsIntegration({
|
|
192
|
-
console: false,
|
|
193
|
-
fetch: false
|
|
194
|
-
}),
|
|
195
|
-
httpClientIntegration({
|
|
196
|
-
failedRequestStatusCodes: [
|
|
197
|
-
[
|
|
198
|
-
400,
|
|
199
|
-
599
|
|
200
|
-
]
|
|
201
|
-
]
|
|
202
|
-
}),
|
|
203
|
-
feedbackIntegration({
|
|
204
|
-
autoInject: false
|
|
205
|
-
}),
|
|
206
|
-
...options.tracing ? [
|
|
207
|
-
new BrowserTracing()
|
|
208
|
-
] : [],
|
|
209
|
-
...options.replay ? [
|
|
210
|
-
replayIntegration({
|
|
211
|
-
blockAllMedia: true,
|
|
212
|
-
maskAllText: true
|
|
213
|
-
})
|
|
214
|
-
] : []
|
|
215
|
-
],
|
|
216
|
-
replaysSessionSampleRate: options.replaySampleRate,
|
|
217
|
-
replaysOnErrorSampleRate: options.replaySampleRateOnError,
|
|
218
|
-
tracesSampleRate: options.sampleRate,
|
|
219
|
-
transport: options.transport,
|
|
220
|
-
beforeSend: (event) => {
|
|
221
|
-
options.onError?.(event);
|
|
222
|
-
return event;
|
|
223
|
-
}
|
|
224
|
-
});
|
|
225
|
-
Object.entries(options.properties ?? {}).forEach(([key, value]) => {
|
|
226
|
-
setTag(key, value);
|
|
227
|
-
});
|
|
228
|
-
} catch (err) {
|
|
229
|
-
log2.catch("Failed to initialize sentry", err, {
|
|
230
|
-
F: __dxlog_file2,
|
|
231
|
-
L: 65,
|
|
232
|
-
S: void 0,
|
|
233
|
-
C: (f, a) => f(...a)
|
|
234
|
-
});
|
|
235
|
-
}
|
|
236
|
-
};
|
|
237
|
-
var addBreadcrumb = (breadcrumb) => {
|
|
238
|
-
try {
|
|
239
|
-
naturalAddBreadcrumb(breadcrumb);
|
|
240
|
-
log2("add breadcrumb", breadcrumb, {
|
|
241
|
-
F: __dxlog_file2,
|
|
242
|
-
L: 81,
|
|
243
|
-
S: void 0,
|
|
244
|
-
C: (f, a) => f(...a)
|
|
245
|
-
});
|
|
246
|
-
} catch (err) {
|
|
247
|
-
log2.catch("Failed to add breadcrumb", err, {
|
|
248
|
-
F: __dxlog_file2,
|
|
249
|
-
L: 83,
|
|
250
|
-
S: void 0,
|
|
251
|
-
C: (f, a) => f(...a)
|
|
252
|
-
});
|
|
253
|
-
}
|
|
254
|
-
};
|
|
255
|
-
var captureException = (exception, captureContext) => {
|
|
256
|
-
try {
|
|
257
|
-
const eventId = naturalCaptureException(exception, captureContext);
|
|
258
|
-
log2("capture exception", {
|
|
259
|
-
exception,
|
|
260
|
-
eventId,
|
|
261
|
-
...captureContext
|
|
262
|
-
}, {
|
|
263
|
-
F: __dxlog_file2,
|
|
264
|
-
L: 97,
|
|
265
|
-
S: void 0,
|
|
266
|
-
C: (f, a) => f(...a)
|
|
267
|
-
});
|
|
268
|
-
return eventId;
|
|
269
|
-
} catch (err) {
|
|
270
|
-
log2.catch("Failed to capture exception", err, {
|
|
271
|
-
F: __dxlog_file2,
|
|
272
|
-
L: 100,
|
|
273
|
-
S: void 0,
|
|
274
|
-
C: (f, a) => f(...a)
|
|
275
|
-
});
|
|
276
|
-
return "unknown";
|
|
277
|
-
}
|
|
278
|
-
};
|
|
279
|
-
var captureMessage = (exception, captureContext) => {
|
|
280
|
-
try {
|
|
281
|
-
const eventId = naturalCaptureMessage(exception, captureContext);
|
|
282
|
-
log2("capture message", {
|
|
283
|
-
exception,
|
|
284
|
-
eventId,
|
|
285
|
-
captureContext
|
|
286
|
-
}, {
|
|
287
|
-
F: __dxlog_file2,
|
|
288
|
-
L: 108,
|
|
289
|
-
S: void 0,
|
|
290
|
-
C: (f, a) => f(...a)
|
|
291
|
-
});
|
|
292
|
-
return eventId;
|
|
293
|
-
} catch (err) {
|
|
294
|
-
log2.catch("Failed to capture message", err, {
|
|
295
|
-
F: __dxlog_file2,
|
|
296
|
-
L: 111,
|
|
297
|
-
S: void 0,
|
|
298
|
-
C: (f, a) => f(...a)
|
|
299
|
-
});
|
|
300
|
-
return "unknown";
|
|
301
|
-
}
|
|
302
|
-
};
|
|
303
|
-
var captureUserFeedback = (name, email, message) => {
|
|
304
|
-
return naturalSendFeedback({
|
|
305
|
-
name,
|
|
306
|
-
email,
|
|
307
|
-
message
|
|
308
|
-
}, {
|
|
309
|
-
includeReplay: true
|
|
310
|
-
});
|
|
311
|
-
};
|
|
312
|
-
var withScope = naturalWithScope;
|
|
313
|
-
|
|
314
|
-
export {
|
|
315
|
-
configureTracing,
|
|
316
|
-
finish,
|
|
317
|
-
SENTRY_PROCESSOR,
|
|
318
|
-
init,
|
|
319
|
-
addBreadcrumb,
|
|
320
|
-
captureException,
|
|
321
|
-
captureMessage,
|
|
322
|
-
captureUserFeedback,
|
|
323
|
-
withScope,
|
|
324
|
-
setTag2 as setTag,
|
|
325
|
-
setTags,
|
|
326
|
-
setUser
|
|
327
|
-
};
|
|
328
|
-
//# sourceMappingURL=chunk-I72ZJDDP.mjs.map
|
|
@@ -1,7 +0,0 @@
|
|
|
1
|
-
{
|
|
2
|
-
"version": 3,
|
|
3
|
-
"sources": ["../../../src/sentry/browser.ts", "../../../src/sentry/tracing.ts"],
|
|
4
|
-
"sourcesContent": ["//\n// Copyright 2022 DXOS.org\n//\n\nimport {\n init as naturalInit,\n setTag,\n addBreadcrumb as naturalAddBreadcrumb,\n captureException as naturalCaptureException,\n captureMessage as naturalCaptureMessage,\n sendFeedback as naturalSendFeedback,\n withScope as naturalWithScope,\n BrowserTracing,\n replayIntegration,\n breadcrumbsIntegration,\n feedbackIntegration,\n} from '@sentry/browser';\nimport { httpClientIntegration } from '@sentry/integrations';\n\nimport { log } from '@dxos/log';\n\nimport { type InitOptions } from './types';\n\n// Browser only feature.\nexport * from './tracing';\n\n// Polyfill export.\nexport { setTag, setTags, setUser } from '@sentry/browser';\n\n/**\n * To use this SDK, call the init function as early as possible when loading the web page.\n * To set context information or send manual events, use the provided methods.\n *\n * @param options {InitOptions}\n */\nexport const init = (options: InitOptions) => {\n try {\n log('sentry init', options);\n naturalInit({\n enabled: options.enable ?? true,\n dsn: options.destination,\n release: options.release,\n environment: options.environment,\n integrations: [\n breadcrumbsIntegration({ console: false, fetch: false }),\n httpClientIntegration({ failedRequestStatusCodes: [[400, 599]] }),\n feedbackIntegration({ autoInject: false }),\n ...(options.tracing ? [new BrowserTracing()] : []),\n ...(options.replay ? [replayIntegration({ blockAllMedia: true, maskAllText: true })] : []),\n ],\n replaysSessionSampleRate: options.replaySampleRate,\n replaysOnErrorSampleRate: options.replaySampleRateOnError,\n tracesSampleRate: options.sampleRate,\n transport: options.transport,\n beforeSend: (event) => {\n options.onError?.(event);\n return event;\n },\n });\n\n Object.entries(options.properties ?? {}).forEach(([key, value]) => {\n setTag(key, value);\n });\n } catch (err) {\n log.catch('Failed to initialize sentry', err);\n }\n};\n\n/**\n * Records a new breadcrumb which will be attached to future events.\n *\n * Breadcrumbs will be added to subsequent events to provide more context on user's actions prior to an error or crash.\n *\n * https://docs.sentry.io/platforms/javascript/enriching-events/breadcrumbs/\n *\n * @param breadcrumb — The breadcrumb to record.\n */\nexport const addBreadcrumb: typeof naturalAddBreadcrumb = (breadcrumb) => {\n try {\n naturalAddBreadcrumb(breadcrumb);\n log('add breadcrumb', breadcrumb);\n } catch (err) {\n log.catch('Failed to add breadcrumb', err);\n }\n};\n\n/**\n * Captures an exception event and sends it to Sentry.\n *\n * @param exception — An exception-like object.\n * @param captureContext — Additional scope data to apply to exception event.\n * @returns — The generated eventId.\n */\nexport const captureException: typeof naturalCaptureException = (exception, captureContext) => {\n try {\n const eventId = naturalCaptureException(exception, captureContext);\n log('capture exception', { exception, eventId, ...captureContext });\n return eventId;\n } catch (err) {\n log.catch('Failed to capture exception', err);\n return 'unknown';\n }\n};\n\nexport const captureMessage: typeof naturalCaptureMessage = (exception, captureContext) => {\n try {\n const eventId = naturalCaptureMessage(exception, captureContext);\n log('capture message', { exception, eventId, captureContext });\n return eventId;\n } catch (err) {\n log.catch('Failed to capture message', err);\n return 'unknown';\n }\n};\n\nexport const captureUserFeedback = (name: string, email: string, message: string) => {\n return naturalSendFeedback({ name, email, message }, { includeReplay: true });\n};\n\nexport const withScope = naturalWithScope;\n", "//\n// Copyright 2023 DXOS.org\n//\n\n// NOTE: Browser only API. There is no node polyfill.\n\nimport { getCurrentHub } from '@sentry/browser';\nimport { type Transaction, type Span } from '@sentry/types';\n\nimport { runInContext, scheduleMicroTask, Trigger } from '@dxos/async';\nimport { Context } from '@dxos/context';\nimport { invariant } from '@dxos/invariant';\nimport { getContextFromEntry, log, LogLevel, type LogProcessor } from '@dxos/log';\n\nconst REPORT_SPANS = false;\n\nlet TX!: Transaction;\nconst SPAN_MAP = new Map<string, Span>();\nconst SENTRY_INITIALIZED = new Trigger();\nconst ctx = new Context({ onError: (err) => log.warn('Unhandled error in Sentry context', err) });\nctx.maxSafeDisposeCallbacks = 10_000;\n\nlet tracingConfigured = false;\n\nexport const configureTracing = () => {\n tracingConfigured = true;\n runInContext(ctx, () => {\n // Configure root transaction.\n TX = getCurrentHub().startTransaction({\n name: 'DXOS Core Tracing',\n op: 'dxos',\n });\n invariant(TX, 'Failed to create trace');\n if (typeof window !== 'undefined') {\n window.addEventListener('beforeunload', () => {\n finish();\n });\n }\n if (typeof process !== 'undefined') {\n process.on('exit', () => {\n finish();\n });\n }\n\n SENTRY_INITIALIZED.wake();\n });\n};\n\nexport const finish = () => {\n for (const span of Array.from(SPAN_MAP.values()).reverse()) {\n try {\n span.finish();\n } catch (err) {\n log.warn('Failed to finish span', err);\n }\n }\n TX.finish();\n};\n\nexport const SENTRY_PROCESSOR: LogProcessor = (config, entry) => {\n if (!tracingConfigured) {\n return;\n }\n\n const { message, level, error } = entry;\n const context = getContextFromEntry(entry);\n\n if (level !== LogLevel.TRACE) {\n return;\n }\n\n // NOTE: Make sure `entry` is not captured in this closure to avoid a memory leak.\n scheduleMicroTask(ctx, async () => {\n await SENTRY_INITIALIZED.wait();\n\n if (REPORT_SPANS && context?.span) {\n switch (context.span.command) {\n case 'begin': {\n const id = context.span.id;\n\n if (!id || SPAN_MAP.has(id)) {\n log.warn('Cannot begin span', id);\n return;\n }\n\n let parentSpan: Span = TX;\n if (context.span.parent) {\n parentSpan = SPAN_MAP.get(context.span.parent) ?? TX;\n }\n\n let logContext: string;\n try {\n logContext = JSON.stringify({ ...context, message, level, error });\n } catch (err) {\n logContext = JSON.stringify(context);\n }\n\n const span = parentSpan.startChild({\n op: message,\n data: {\n ...context.span.data,\n '@dxos/log': logContext,\n },\n });\n SPAN_MAP.set(context.span.id, span);\n break;\n }\n\n case 'end': {\n const span = SPAN_MAP.get(context.span.id);\n if (span) {\n span.setStatus(getSpanStatus(context.span.status));\n context.span.data && Object.entries(context.span.data).forEach(([key, value]) => span.setData(key, value));\n span.finish();\n SPAN_MAP.delete(context.span.id);\n } else {\n log.warn('Cannot end span', context.span.id);\n }\n break;\n }\n\n case 'update': {\n const span = SPAN_MAP.get(context.span.id);\n if (span) {\n context.span.data && Object.entries(context.span.data).forEach(([key, value]) => span.setData(key, value));\n } else {\n log.warn('Cannot update span', context.span.id);\n }\n break;\n }\n\n default: {\n log.warn('Unknown span command', context.span.command);\n }\n }\n }\n });\n};\n\nlog.runtimeConfig.processors.push(SENTRY_PROCESSOR);\n\n/**\n * @see https://develop.sentry.dev/sdk/event-payloads/span/#:~:text=this%20value%20explicitly.-,status,-Optional.%20Describes%20the\n */\nconst getSpanStatus = (status?: 'ok' | 'error') => {\n switch (status) {\n case 'ok':\n return 'ok';\n case 'error':\n return 'not_found';\n }\n return status ?? 'ok';\n};\n"],
|
|
5
|
-
"mappings": "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",
|
|
6
|
-
"names": ["init", "naturalInit", "setTag", "addBreadcrumb", "naturalAddBreadcrumb", "captureException", "naturalCaptureException", "captureMessage", "naturalCaptureMessage", "sendFeedback", "naturalSendFeedback", "withScope", "naturalWithScope", "BrowserTracing", "replayIntegration", "breadcrumbsIntegration", "feedbackIntegration", "httpClientIntegration", "log", "getCurrentHub", "runInContext", "scheduleMicroTask", "Trigger", "Context", "invariant", "getContextFromEntry", "log", "LogLevel", "REPORT_SPANS", "TX", "SPAN_MAP", "Map", "SENTRY_INITIALIZED", "ctx", "onError", "err", "warn", "maxSafeDisposeCallbacks", "tracingConfigured", "configureTracing", "startTransaction", "name", "op", "window", "addEventListener", "finish", "process", "on", "wake", "span", "Array", "from", "values", "reverse", "SENTRY_PROCESSOR", "config", "entry", "message", "level", "error", "context", "TRACE", "wait", "command", "id", "has", "parentSpan", "parent", "get", "logContext", "JSON", "stringify", "startChild", "data", "set", "setStatus", "getSpanStatus", "status", "Object", "entries", "forEach", "key", "value", "setData", "delete", "runtimeConfig", "processors", "push", "setTag", "setTags", "setUser", "init", "options", "log", "naturalInit", "enabled", "enable", "dsn", "destination", "release", "environment", "integrations", "breadcrumbsIntegration", "console", "fetch", "httpClientIntegration", "failedRequestStatusCodes", "feedbackIntegration", "autoInject", "tracing", "BrowserTracing", "replay", "replayIntegration", "blockAllMedia", "maskAllText", "replaysSessionSampleRate", "replaySampleRate", "replaysOnErrorSampleRate", "replaySampleRateOnError", "tracesSampleRate", "sampleRate", "transport", "beforeSend", "event", "onError", "Object", "entries", "properties", "forEach", "key", "value", "err", "catch", "addBreadcrumb", "breadcrumb", "naturalAddBreadcrumb", "captureException", "exception", "captureContext", "eventId", "naturalCaptureException", "captureMessage", "naturalCaptureMessage", "captureUserFeedback", "name", "email", "message", "naturalSendFeedback", "includeReplay", "withScope", "naturalWithScope"]
|
|
7
|
-
}
|