@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.
Files changed (65) hide show
  1. package/dist/lib/browser/chunk-3LKCQYWD.mjs +159 -0
  2. package/dist/lib/browser/chunk-3LKCQYWD.mjs.map +7 -0
  3. package/dist/lib/browser/chunk-KDP3SESE.mjs +1 -0
  4. package/dist/lib/browser/{chunk-5E3CR23D.mjs → chunk-KRN52DNQ.mjs} +5 -8
  5. package/dist/lib/browser/{chunk-5E3CR23D.mjs.map → chunk-KRN52DNQ.mjs.map} +3 -3
  6. package/dist/lib/browser/index.mjs +2 -2
  7. package/dist/lib/browser/meta.json +1 -1
  8. package/dist/lib/browser/observability-NTPJJQW5.mjs +8 -0
  9. package/dist/lib/browser/observability-NTPJJQW5.mjs.map +7 -0
  10. package/dist/lib/browser/segment/index.mjs +2 -1
  11. package/dist/lib/browser/segment/index.mjs.map +1 -1
  12. package/dist/lib/browser/sentry/index.mjs +2 -7
  13. package/dist/lib/node/{chunk-NFII7GBC.cjs → chunk-4RV4LMAG.cjs} +11 -14
  14. package/dist/lib/node/{chunk-NFII7GBC.cjs.map → chunk-4RV4LMAG.cjs.map} +3 -3
  15. package/dist/lib/node/chunk-GIYJMZEQ.cjs +2 -0
  16. package/dist/lib/node/chunk-GIYJMZEQ.cjs.map +7 -0
  17. package/dist/lib/node/chunk-HKBUNAUG.cjs +161 -0
  18. package/dist/lib/node/chunk-HKBUNAUG.cjs.map +7 -0
  19. package/dist/lib/node/index.cjs +16 -16
  20. package/dist/lib/node/index.cjs.map +1 -1
  21. package/dist/lib/node/meta.json +1 -1
  22. package/dist/lib/node/{observability-6KNNVT6F.cjs → observability-234R4TZL.cjs} +7 -7
  23. package/dist/lib/node/{observability-6KNNVT6F.cjs.map → observability-234R4TZL.cjs.map} +2 -2
  24. package/dist/lib/node/segment/index.cjs +3 -2
  25. package/dist/lib/node/segment/index.cjs.map +1 -1
  26. package/dist/lib/node/sentry/index.cjs +11 -12
  27. package/dist/lib/node/sentry/index.cjs.map +2 -2
  28. package/dist/types/src/observability.d.ts.map +1 -1
  29. package/dist/types/src/observability.js +1 -5
  30. package/dist/types/src/observability.js.map +1 -1
  31. package/dist/types/src/sentry/browser.d.ts +1 -2
  32. package/dist/types/src/sentry/browser.d.ts.map +1 -1
  33. package/dist/types/src/sentry/browser.js +7 -19
  34. package/dist/types/src/sentry/browser.js.map +1 -1
  35. package/dist/types/src/sentry/index.d.ts +0 -1
  36. package/dist/types/src/sentry/index.d.ts.map +1 -1
  37. package/dist/types/src/sentry/index.js +0 -4
  38. package/dist/types/src/sentry/index.js.map +1 -1
  39. package/dist/types/src/sentry/node.d.ts.map +1 -1
  40. package/dist/types/src/sentry/node.js +6 -28
  41. package/dist/types/src/sentry/node.js.map +1 -1
  42. package/dist/types/src/sentry/sentry-log-processor.js +4 -4
  43. package/dist/types/src/sentry/sentry-log-processor.js.map +1 -1
  44. package/package.json +18 -19
  45. package/src/observability.ts +1 -4
  46. package/src/sentry/browser.ts +12 -7
  47. package/src/sentry/index.ts +0 -3
  48. package/src/sentry/node.ts +10 -7
  49. package/src/sentry/sentry-log-processor.ts +1 -1
  50. package/dist/lib/browser/chunk-I72ZJDDP.mjs +0 -328
  51. package/dist/lib/browser/chunk-I72ZJDDP.mjs.map +0 -7
  52. package/dist/lib/browser/observability-SGYNJETW.mjs +0 -8
  53. package/dist/lib/node/chunk-2F4DCY4M.cjs +0 -345
  54. package/dist/lib/node/chunk-2F4DCY4M.cjs.map +0 -7
  55. package/dist/types/src/sentry/tracing.d.ts +0 -5
  56. package/dist/types/src/sentry/tracing.d.ts.map +0 -1
  57. package/dist/types/src/sentry/tracing.js +0 -141
  58. package/dist/types/src/sentry/tracing.js.map +0 -1
  59. package/dist/types/src/sentry/tracing.test.d.ts +0 -2
  60. package/dist/types/src/sentry/tracing.test.d.ts.map +0 -1
  61. package/dist/types/src/sentry/tracing.test.js +0 -76
  62. package/dist/types/src/sentry/tracing.test.js.map +0 -1
  63. package/src/sentry/tracing.test.ts +0 -62
  64. package/src/sentry/tracing.ts +0 -153
  65. /package/dist/lib/browser/{observability-SGYNJETW.mjs.map → chunk-KDP3SESE.mjs.map} +0 -0
@@ -1,345 +0,0 @@
1
- "use strict";
2
- var __create = Object.create;
3
- var __defProp = Object.defineProperty;
4
- var __getOwnPropDesc = Object.getOwnPropertyDescriptor;
5
- var __getOwnPropNames = Object.getOwnPropertyNames;
6
- var __getProtoOf = Object.getPrototypeOf;
7
- var __hasOwnProp = Object.prototype.hasOwnProperty;
8
- var __export = (target, all) => {
9
- for (var name in all)
10
- __defProp(target, name, { get: all[name], enumerable: true });
11
- };
12
- var __copyProps = (to, from, except, desc) => {
13
- if (from && typeof from === "object" || typeof from === "function") {
14
- for (let key of __getOwnPropNames(from))
15
- if (!__hasOwnProp.call(to, key) && key !== except)
16
- __defProp(to, key, { get: () => from[key], enumerable: !(desc = __getOwnPropDesc(from, key)) || desc.enumerable });
17
- }
18
- return to;
19
- };
20
- var __toESM = (mod, isNodeMode, target) => (target = mod != null ? __create(__getProtoOf(mod)) : {}, __copyProps(
21
- // If the importer is in node compatibility mode or this is not an ESM
22
- // file that has been converted to a CommonJS file using a Babel-
23
- // compatible transform (i.e. "__esModule" has not been set), then set
24
- // "default" to the CommonJS "module.exports" for node compatibility.
25
- isNodeMode || !mod || !mod.__esModule ? __defProp(target, "default", { value: mod, enumerable: true }) : target,
26
- mod
27
- ));
28
- var __toCommonJS = (mod) => __copyProps(__defProp({}, "__esModule", { value: true }), mod);
29
- var chunk_2F4DCY4M_exports = {};
30
- __export(chunk_2F4DCY4M_exports, {
31
- addBreadcrumb: () => addBreadcrumb,
32
- captureException: () => captureException,
33
- captureMessage: () => captureMessage,
34
- captureUserFeedback: () => captureUserFeedback,
35
- configureTracing: () => configureTracing,
36
- init: () => init,
37
- setTag: () => import_node2.setTag,
38
- setTags: () => import_node2.setTags,
39
- setUser: () => import_node2.setUser,
40
- withScope: () => withScope
41
- });
42
- module.exports = __toCommonJS(chunk_2F4DCY4M_exports);
43
- var import_integrations = require("@sentry/integrations");
44
- var import_node = require("@sentry/node");
45
- var import_log = require("@dxos/log");
46
- var import_node2 = require("@sentry/node");
47
- var import_browser = require("@sentry/browser");
48
- var import_async = require("@dxos/async");
49
- var import_context = require("@dxos/context");
50
- var import_invariant = require("@dxos/invariant");
51
- var import_log2 = require("@dxos/log");
52
- var __dxlog_file = "/home/runner/work/dxos/dxos/packages/sdk/observability/src/sentry/node.ts";
53
- var init = (options) => {
54
- try {
55
- if (options.tracing) {
56
- void import("@sentry/tracing");
57
- }
58
- (0, import_node.init)({
59
- enabled: options.enable ?? true,
60
- dsn: options.destination,
61
- serverName: options.installationId,
62
- release: options.release,
63
- environment: options.environment ?? process.env.DX_ENVIRONMENT,
64
- integrations: [
65
- (0, import_integrations.captureConsoleIntegration)({
66
- levels: [
67
- "error",
68
- "warn"
69
- ]
70
- })
71
- ],
72
- tracesSampleRate: options.sampleRate,
73
- transport: options.transport,
74
- beforeSend: (event) => {
75
- options.scrubFilenames && scrub(event);
76
- options.onError?.(event);
77
- return event;
78
- }
79
- });
80
- Object.entries(options.properties ?? {}).forEach(([key, value]) => {
81
- (0, import_node.setTag)(key, value);
82
- });
83
- } catch (err) {
84
- import_log.log.catch("Failed to initialize sentry", err, {
85
- F: __dxlog_file,
86
- L: 56,
87
- S: void 0,
88
- C: (f, a) => f(...a)
89
- });
90
- }
91
- };
92
- var scrub = (event) => {
93
- event.exception?.values?.forEach((value) => {
94
- value.stacktrace?.frames?.forEach((frame) => {
95
- const filename = frame.filename?.split("/");
96
- frame.filename = filename && filename[filename.length - 1];
97
- });
98
- });
99
- };
100
- var addBreadcrumb = (breadcrumb) => {
101
- try {
102
- (0, import_node.addBreadcrumb)(breadcrumb);
103
- (0, import_log.log)("add breadcrumb", breadcrumb, {
104
- F: __dxlog_file,
105
- L: 81,
106
- S: void 0,
107
- C: (f, a) => f(...a)
108
- });
109
- } catch (err) {
110
- import_log.log.catch("Failed to add breadcrumb", err, {
111
- F: __dxlog_file,
112
- L: 83,
113
- S: void 0,
114
- C: (f, a) => f(...a)
115
- });
116
- }
117
- };
118
- var captureException = (exception, captureContext) => {
119
- try {
120
- const eventId = (0, import_node.captureException)(exception, captureContext);
121
- (0, import_log.log)("capture exception", {
122
- exception,
123
- eventId,
124
- ...captureContext
125
- }, {
126
- F: __dxlog_file,
127
- L: 97,
128
- S: void 0,
129
- C: (f, a) => f(...a)
130
- });
131
- return eventId;
132
- } catch (err) {
133
- import_log.log.catch("Failed to capture exception", err, {
134
- F: __dxlog_file,
135
- L: 100,
136
- S: void 0,
137
- C: (f, a) => f(...a)
138
- });
139
- return "unknown";
140
- }
141
- };
142
- var captureMessage = (exception, captureContext) => {
143
- try {
144
- const eventId = (0, import_node.captureMessage)(exception, captureContext);
145
- (0, import_log.log)("capture message", {
146
- exception,
147
- eventId,
148
- captureContext
149
- }, {
150
- F: __dxlog_file,
151
- L: 108,
152
- S: void 0,
153
- C: (f, a) => f(...a)
154
- });
155
- return eventId;
156
- } catch (err) {
157
- import_log.log.catch("Failed to capture message", err, {
158
- F: __dxlog_file,
159
- L: 111,
160
- S: void 0,
161
- C: (f, a) => f(...a)
162
- });
163
- return "unknown";
164
- }
165
- };
166
- var captureUserFeedback = (name, email, message) => {
167
- const feedback = `User feedback: ${name} ${email} ${message}`;
168
- throw new Error(`Capture user feedback not implemented in node. Use @sentry/browser. Message: ${feedback}`);
169
- };
170
- var withScope = import_node.withScope;
171
- var __dxlog_file2 = "/home/runner/work/dxos/dxos/packages/sdk/observability/src/sentry/tracing.ts";
172
- var REPORT_SPANS = false;
173
- var TX;
174
- var SPAN_MAP = /* @__PURE__ */ new Map();
175
- var SENTRY_INITIALIZED = new import_async.Trigger();
176
- var ctx = new import_context.Context({
177
- onError: (err) => import_log2.log.warn("Unhandled error in Sentry context", err, {
178
- F: __dxlog_file2,
179
- L: 20,
180
- S: void 0,
181
- C: (f, a) => f(...a)
182
- })
183
- });
184
- ctx.maxSafeDisposeCallbacks = 1e4;
185
- var tracingConfigured = false;
186
- var configureTracing = () => {
187
- tracingConfigured = true;
188
- (0, import_async.runInContext)(ctx, () => {
189
- TX = (0, import_browser.getCurrentHub)().startTransaction({
190
- name: "DXOS Core Tracing",
191
- op: "dxos"
192
- });
193
- (0, import_invariant.invariant)(TX, "Failed to create trace", {
194
- F: __dxlog_file2,
195
- L: 33,
196
- S: void 0,
197
- A: [
198
- "TX",
199
- "'Failed to create trace'"
200
- ]
201
- });
202
- if (typeof window !== "undefined") {
203
- window.addEventListener("beforeunload", () => {
204
- finish();
205
- });
206
- }
207
- if (typeof process !== "undefined") {
208
- process.on("exit", () => {
209
- finish();
210
- });
211
- }
212
- SENTRY_INITIALIZED.wake();
213
- });
214
- };
215
- var finish = () => {
216
- for (const span of Array.from(SPAN_MAP.values()).reverse()) {
217
- try {
218
- span.finish();
219
- } catch (err) {
220
- import_log2.log.warn("Failed to finish span", err, {
221
- F: __dxlog_file2,
222
- L: 54,
223
- S: void 0,
224
- C: (f, a) => f(...a)
225
- });
226
- }
227
- }
228
- TX.finish();
229
- };
230
- var SENTRY_PROCESSOR = (config, entry) => {
231
- if (!tracingConfigured) {
232
- return;
233
- }
234
- const { message, level, error } = entry;
235
- const context = (0, import_log2.getContextFromEntry)(entry);
236
- if (level !== import_log2.LogLevel.TRACE) {
237
- return;
238
- }
239
- (0, import_async.scheduleMicroTask)(ctx, async () => {
240
- await SENTRY_INITIALIZED.wait();
241
- if (REPORT_SPANS && context?.span) {
242
- switch (context.span.command) {
243
- case "begin": {
244
- const id = context.span.id;
245
- if (!id || SPAN_MAP.has(id)) {
246
- import_log2.log.warn("Cannot begin span", id, {
247
- F: __dxlog_file2,
248
- L: 82,
249
- S: void 0,
250
- C: (f, a) => f(...a)
251
- });
252
- return;
253
- }
254
- let parentSpan = TX;
255
- if (context.span.parent) {
256
- parentSpan = SPAN_MAP.get(context.span.parent) ?? TX;
257
- }
258
- let logContext;
259
- try {
260
- logContext = JSON.stringify({
261
- ...context,
262
- message,
263
- level,
264
- error
265
- });
266
- } catch (err) {
267
- logContext = JSON.stringify(context);
268
- }
269
- const span = parentSpan.startChild({
270
- op: message,
271
- data: {
272
- ...context.span.data,
273
- "@dxos/log": logContext
274
- }
275
- });
276
- SPAN_MAP.set(context.span.id, span);
277
- break;
278
- }
279
- case "end": {
280
- const span = SPAN_MAP.get(context.span.id);
281
- if (span) {
282
- span.setStatus(getSpanStatus(context.span.status));
283
- context.span.data && Object.entries(context.span.data).forEach(([key, value]) => span.setData(key, value));
284
- span.finish();
285
- SPAN_MAP.delete(context.span.id);
286
- } else {
287
- import_log2.log.warn("Cannot end span", context.span.id, {
288
- F: __dxlog_file2,
289
- L: 117,
290
- S: void 0,
291
- C: (f, a) => f(...a)
292
- });
293
- }
294
- break;
295
- }
296
- case "update": {
297
- const span = SPAN_MAP.get(context.span.id);
298
- if (span) {
299
- context.span.data && Object.entries(context.span.data).forEach(([key, value]) => span.setData(key, value));
300
- } else {
301
- import_log2.log.warn("Cannot update span", context.span.id, {
302
- F: __dxlog_file2,
303
- L: 127,
304
- S: void 0,
305
- C: (f, a) => f(...a)
306
- });
307
- }
308
- break;
309
- }
310
- default: {
311
- import_log2.log.warn("Unknown span command", context.span.command, {
312
- F: __dxlog_file2,
313
- L: 133,
314
- S: void 0,
315
- C: (f, a) => f(...a)
316
- });
317
- }
318
- }
319
- }
320
- });
321
- };
322
- import_log2.log.runtimeConfig.processors.push(SENTRY_PROCESSOR);
323
- var getSpanStatus = (status) => {
324
- switch (status) {
325
- case "ok":
326
- return "ok";
327
- case "error":
328
- return "not_found";
329
- }
330
- return status ?? "ok";
331
- };
332
- // Annotate the CommonJS export names for ESM import in node:
333
- 0 && (module.exports = {
334
- addBreadcrumb,
335
- captureException,
336
- captureMessage,
337
- captureUserFeedback,
338
- configureTracing,
339
- init,
340
- setTag,
341
- setTags,
342
- setUser,
343
- withScope
344
- });
345
- //# sourceMappingURL=chunk-2F4DCY4M.cjs.map
@@ -1,7 +0,0 @@
1
- {
2
- "version": 3,
3
- "sources": ["../../../src/sentry/node.ts", "../../../src/sentry/tracing.ts"],
4
- "sourcesContent": ["//\n// Copyright 2022 DXOS.org\n//\n\nimport { captureConsoleIntegration } from '@sentry/integrations';\nimport {\n init as naturalInit,\n setTag,\n addBreadcrumb as naturalAddBreadcrumb,\n captureException as naturalCaptureException,\n captureMessage as naturalCaptureMessage,\n withScope as naturalWithScope,\n} from '@sentry/node';\nimport type { Event } from '@sentry/node';\n\nimport { log } from '@dxos/log';\n\nimport { type InitOptions } from './types';\n\n// Polyfill export.\nexport { setTag, setTags, setUser } from '@sentry/node';\n\n/**\n * To use this SDK, call the init function as early as possible in the main entry module.\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 if (options.tracing) {\n void import('@sentry/tracing');\n }\n\n naturalInit({\n enabled: options.enable ?? true,\n dsn: options.destination,\n serverName: options.installationId,\n release: options.release,\n environment: options.environment ?? process.env.DX_ENVIRONMENT,\n integrations: [captureConsoleIntegration({ levels: ['error', 'warn'] })],\n tracesSampleRate: options.sampleRate,\n transport: options.transport,\n beforeSend: (event) => {\n options.scrubFilenames && scrub(event);\n options.onError?.(event);\n\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\nconst scrub = (event: Event) => {\n event.exception?.values?.forEach((value) => {\n value.stacktrace?.frames?.forEach((frame) => {\n const filename = frame.filename?.split('/');\n frame.filename = filename && filename[filename.length - 1];\n });\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): Promise<void> => {\n const feedback = `User feedback: ${name} ${email} ${message}`;\n throw new Error(`Capture user feedback not implemented in node. Use @sentry/browser. Message: ${feedback}`);\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": ["import_node", "import_log", "init", "options", "tracing", "naturalInit", "enabled", "enable", "dsn", "destination", "serverName", "installationId", "release", "environment", "process", "env", "DX_ENVIRONMENT", "integrations", "captureConsoleIntegration", "levels", "tracesSampleRate", "sampleRate", "transport", "beforeSend", "event", "scrubFilenames", "scrub", "onError", "Object", "entries", "properties", "forEach", "key", "value", "setTag", "err", "log", "catch", "exception", "values", "stacktrace", "frames", "frame", "filename", "split", "length", "addBreadcrumb", "breadcrumb", "naturalAddBreadcrumb", "captureException", "captureContext", "eventId", "naturalCaptureException", "captureMessage", "naturalCaptureMessage", "captureUserFeedback", "name", "email", "message", "feedback", "Error", "withScope", "naturalWithScope", "REPORT_SPANS", "TX", "SPAN_MAP", "Map", "SENTRY_INITIALIZED", "Trigger", "ctx", "Context", "warn", "maxSafeDisposeCallbacks", "tracingConfigured", "configureTracing", "runInContext", "getCurrentHub", "startTransaction", "op", "invariant", "window", "addEventListener", "finish", "on", "wake", "span", "Array", "from", "reverse", "SENTRY_PROCESSOR", "config", "entry", "level", "error", "context", "getContextFromEntry", "LogLevel", "TRACE", "scheduleMicroTask", "wait", "command", "id", "has", "parentSpan", "parent", "get", "logContext", "JSON", "stringify", "startChild", "data", "set", "setStatus", "getSpanStatus", "status", "setData", "delete", "runtimeConfig", "processors", "push"]
7
- }
@@ -1,5 +0,0 @@
1
- import { type LogProcessor } from '@dxos/log';
2
- export declare const configureTracing: () => void;
3
- export declare const finish: () => void;
4
- export declare const SENTRY_PROCESSOR: LogProcessor;
5
- //# sourceMappingURL=tracing.d.ts.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"tracing.d.ts","sourceRoot":"","sources":["../../../../src/sentry/tracing.ts"],"names":[],"mappings":"AAYA,OAAO,EAAsC,KAAK,YAAY,EAAE,MAAM,WAAW,CAAC;AAYlF,eAAO,MAAM,gBAAgB,YAsB5B,CAAC;AAEF,eAAO,MAAM,MAAM,YASlB,CAAC;AAEF,eAAO,MAAM,gBAAgB,EAAE,YA8E9B,CAAC"}
@@ -1,141 +0,0 @@
1
- "use strict";
2
- //
3
- // Copyright 2023 DXOS.org
4
- //
5
- Object.defineProperty(exports, "__esModule", { value: true });
6
- exports.SENTRY_PROCESSOR = exports.finish = exports.configureTracing = void 0;
7
- // NOTE: Browser only API. There is no node polyfill.
8
- const browser_1 = require("@sentry/browser");
9
- const async_1 = require("@dxos/async");
10
- const context_1 = require("@dxos/context");
11
- const invariant_1 = require("@dxos/invariant");
12
- const log_1 = require("@dxos/log");
13
- const REPORT_SPANS = false;
14
- let TX;
15
- const SPAN_MAP = new Map();
16
- const SENTRY_INITIALIZED = new async_1.Trigger();
17
- const ctx = new context_1.Context({ onError: (err) => log_1.log.warn('Unhandled error in Sentry context', err) });
18
- ctx.maxSafeDisposeCallbacks = 10000;
19
- let tracingConfigured = false;
20
- const configureTracing = () => {
21
- tracingConfigured = true;
22
- (0, async_1.runInContext)(ctx, () => {
23
- // Configure root transaction.
24
- TX = (0, browser_1.getCurrentHub)().startTransaction({
25
- name: 'DXOS Core Tracing',
26
- op: 'dxos',
27
- });
28
- (0, invariant_1.invariant)(TX, 'Failed to create trace');
29
- if (typeof window !== 'undefined') {
30
- window.addEventListener('beforeunload', () => {
31
- (0, exports.finish)();
32
- });
33
- }
34
- if (typeof process !== 'undefined') {
35
- process.on('exit', () => {
36
- (0, exports.finish)();
37
- });
38
- }
39
- SENTRY_INITIALIZED.wake();
40
- });
41
- };
42
- exports.configureTracing = configureTracing;
43
- const finish = () => {
44
- for (const span of Array.from(SPAN_MAP.values()).reverse()) {
45
- try {
46
- span.finish();
47
- }
48
- catch (err) {
49
- log_1.log.warn('Failed to finish span', err);
50
- }
51
- }
52
- TX.finish();
53
- };
54
- exports.finish = finish;
55
- const SENTRY_PROCESSOR = (config, entry) => {
56
- if (!tracingConfigured) {
57
- return;
58
- }
59
- const { message, level, error } = entry;
60
- const context = (0, log_1.getContextFromEntry)(entry);
61
- if (level !== log_1.LogLevel.TRACE) {
62
- return;
63
- }
64
- // NOTE: Make sure `entry` is not captured in this closure to avoid a memory leak.
65
- (0, async_1.scheduleMicroTask)(ctx, async () => {
66
- var _a;
67
- await SENTRY_INITIALIZED.wait();
68
- if (REPORT_SPANS && (context === null || context === void 0 ? void 0 : context.span)) {
69
- switch (context.span.command) {
70
- case 'begin': {
71
- const id = context.span.id;
72
- if (!id || SPAN_MAP.has(id)) {
73
- log_1.log.warn('Cannot begin span', id);
74
- return;
75
- }
76
- let parentSpan = TX;
77
- if (context.span.parent) {
78
- parentSpan = (_a = SPAN_MAP.get(context.span.parent)) !== null && _a !== void 0 ? _a : TX;
79
- }
80
- let logContext;
81
- try {
82
- logContext = JSON.stringify({ ...context, message, level, error });
83
- }
84
- catch (err) {
85
- logContext = JSON.stringify(context);
86
- }
87
- const span = parentSpan.startChild({
88
- op: message,
89
- data: {
90
- ...context.span.data,
91
- '@dxos/log': logContext,
92
- },
93
- });
94
- SPAN_MAP.set(context.span.id, span);
95
- break;
96
- }
97
- case 'end': {
98
- const span = SPAN_MAP.get(context.span.id);
99
- if (span) {
100
- span.setStatus(getSpanStatus(context.span.status));
101
- context.span.data && Object.entries(context.span.data).forEach(([key, value]) => span.setData(key, value));
102
- span.finish();
103
- SPAN_MAP.delete(context.span.id);
104
- }
105
- else {
106
- log_1.log.warn('Cannot end span', context.span.id);
107
- }
108
- break;
109
- }
110
- case 'update': {
111
- const span = SPAN_MAP.get(context.span.id);
112
- if (span) {
113
- context.span.data && Object.entries(context.span.data).forEach(([key, value]) => span.setData(key, value));
114
- }
115
- else {
116
- log_1.log.warn('Cannot update span', context.span.id);
117
- }
118
- break;
119
- }
120
- default: {
121
- log_1.log.warn('Unknown span command', context.span.command);
122
- }
123
- }
124
- }
125
- });
126
- };
127
- exports.SENTRY_PROCESSOR = SENTRY_PROCESSOR;
128
- log_1.log.runtimeConfig.processors.push(exports.SENTRY_PROCESSOR);
129
- /**
130
- * @see https://develop.sentry.dev/sdk/event-payloads/span/#:~:text=this%20value%20explicitly.-,status,-Optional.%20Describes%20the
131
- */
132
- const getSpanStatus = (status) => {
133
- switch (status) {
134
- case 'ok':
135
- return 'ok';
136
- case 'error':
137
- return 'not_found';
138
- }
139
- return status !== null && status !== void 0 ? status : 'ok';
140
- };
141
- //# sourceMappingURL=tracing.js.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"tracing.js","sourceRoot":"","sources":["../../../../src/sentry/tracing.ts"],"names":[],"mappings":"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"}
@@ -1,2 +0,0 @@
1
- export {};
2
- //# sourceMappingURL=tracing.test.d.ts.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"tracing.test.d.ts","sourceRoot":"","sources":["../../../../src/sentry/tracing.test.ts"],"names":[],"mappings":""}
@@ -1,76 +0,0 @@
1
- "use strict";
2
- //
3
- // Copyright 2022 DXOS.org
4
- //
5
- var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
6
- if (k2 === undefined) k2 = k;
7
- var desc = Object.getOwnPropertyDescriptor(m, k);
8
- if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
9
- desc = { enumerable: true, get: function() { return m[k]; } };
10
- }
11
- Object.defineProperty(o, k2, desc);
12
- }) : (function(o, m, k, k2) {
13
- if (k2 === undefined) k2 = k;
14
- o[k2] = m[k];
15
- }));
16
- var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) {
17
- Object.defineProperty(o, "default", { enumerable: true, value: v });
18
- }) : function(o, v) {
19
- o["default"] = v;
20
- });
21
- var __importStar = (this && this.__importStar) || function (mod) {
22
- if (mod && mod.__esModule) return mod;
23
- var result = {};
24
- if (mod != null) for (var k in mod) if (k !== "default" && Object.prototype.hasOwnProperty.call(mod, k)) __createBinding(result, mod, k);
25
- __setModuleDefault(result, mod);
26
- return result;
27
- };
28
- Object.defineProperty(exports, "__esModule", { value: true });
29
- // @dxos/test platform=browser
30
- const chai_1 = require("chai");
31
- const async_1 = require("@dxos/async");
32
- const log_1 = require("@dxos/log");
33
- const test_1 = require("@dxos/test");
34
- const Sentry = __importStar(require("./browser"));
35
- const Tracing = __importStar(require("./tracing"));
36
- const testing_1 = require("../testing");
37
- const { testkit, sentryTransport } = (0, testing_1.sentryTestkit)();
38
- // TODO(burdon): https://example.com?
39
- const MOCK_DESTINATION = 'https://acacaeaccacacacabcaacdacdacadaca@sentry.io/000001';
40
- (0, test_1.describe)('Logger tracing', () => {
41
- (0, test_1.beforeAll)(() => {
42
- Sentry.init({
43
- destination: MOCK_DESTINATION,
44
- release: 'test',
45
- scrubFilenames: true,
46
- tracing: true,
47
- transport: sentryTransport,
48
- });
49
- Tracing.configureTracing();
50
- });
51
- (0, test_1.afterAll)(() => {
52
- Tracing.finish();
53
- });
54
- (0, test_1.test)('begin and end span', async () => {
55
- log_1.log.trace('test.trace', {
56
- span: {
57
- command: 'begin',
58
- id: 'test',
59
- },
60
- });
61
- log_1.log.trace('test.trace', {
62
- span: {
63
- command: 'end',
64
- id: 'test',
65
- status: 'error',
66
- },
67
- error: new Error('test'),
68
- });
69
- // Sleep to allow Sentry tracing to flush.
70
- await (0, async_1.sleep)(10);
71
- Tracing.finish();
72
- (0, chai_1.expect)(testkit.transactions().length).to.eq(1);
73
- (0, chai_1.expect)(testkit.transactions()[0].spans[0].op).to.eq('test.trace');
74
- });
75
- });
76
- //# sourceMappingURL=tracing.test.js.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"tracing.test.js","sourceRoot":"","sources":["../../../../src/sentry/tracing.test.ts"],"names":[],"mappings":";AAAA,EAAE;AACF,0BAA0B;AAC1B,EAAE;;;;;;;;;;;;;;;;;;;;;;;;;AAEF,8BAA8B;AAE9B,+BAA8B;AAE9B,uCAAoC;AACpC,mCAAgC;AAChC,qCAAiE;AAEjE,kDAAoC;AACpC,mDAAqC;AACrC,wCAA2C;AAE3C,MAAM,EAAE,OAAO,EAAE,eAAe,EAAE,GAAG,IAAA,uBAAa,GAAE,CAAC;AAErD,qCAAqC;AACrC,MAAM,gBAAgB,GAAG,2DAA2D,CAAC;AAErF,IAAA,eAAQ,EAAC,gBAAgB,EAAE,GAAG,EAAE;IAC9B,IAAA,gBAAS,EAAC,GAAG,EAAE;QACb,MAAM,CAAC,IAAI,CAAC;YACV,WAAW,EAAE,gBAAgB;YAC7B,OAAO,EAAE,MAAM;YACf,cAAc,EAAE,IAAI;YACpB,OAAO,EAAE,IAAI;YACb,SAAS,EAAE,eAAe;SAC3B,CAAC,CAAC;QAEH,OAAO,CAAC,gBAAgB,EAAE,CAAC;IAC7B,CAAC,CAAC,CAAC;IAEH,IAAA,eAAQ,EAAC,GAAG,EAAE;QACZ,OAAO,CAAC,MAAM,EAAE,CAAC;IACnB,CAAC,CAAC,CAAC;IAEH,IAAA,WAAI,EAAC,oBAAoB,EAAE,KAAK,IAAI,EAAE;QACpC,SAAG,CAAC,KAAK,CAAC,YAAY,EAAE;YACtB,IAAI,EAAE;gBACJ,OAAO,EAAE,OAAO;gBAChB,EAAE,EAAE,MAAM;aACX;SACF,CAAC,CAAC;QAEH,SAAG,CAAC,KAAK,CAAC,YAAY,EAAE;YACtB,IAAI,EAAE;gBACJ,OAAO,EAAE,KAAK;gBACd,EAAE,EAAE,MAAM;gBACV,MAAM,EAAE,OAAO;aAChB;YACD,KAAK,EAAE,IAAI,KAAK,CAAC,MAAM,CAAC;SACzB,CAAC,CAAC;QACH,0CAA0C;QAC1C,MAAM,IAAA,aAAK,EAAC,EAAE,CAAC,CAAC;QAChB,OAAO,CAAC,MAAM,EAAE,CAAC;QAEjB,IAAA,aAAM,EAAC,OAAO,CAAC,YAAY,EAAE,CAAC,MAAM,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC;QAC/C,IAAA,aAAM,EAAC,OAAO,CAAC,YAAY,EAAE,CAAC,CAAC,CAAC,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,YAAY,CAAC,CAAC;IACpE,CAAC,CAAC,CAAC;AACL,CAAC,CAAC,CAAC"}