@ttt-productions/monitoring-core 0.0.4 → 0.0.6
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/adapter.d.ts +6 -0
- package/dist/adapter.d.ts.map +1 -1
- package/dist/adapters/noop.d.ts.map +1 -1
- package/dist/adapters/noop.js +1 -0
- package/dist/adapters/noop.js.map +1 -1
- package/dist/adapters/sentry-node.d.ts +3 -0
- package/dist/adapters/sentry-node.d.ts.map +1 -0
- package/dist/adapters/sentry-node.js +75 -0
- package/dist/adapters/sentry-node.js.map +1 -0
- package/dist/adapters/sentry.d.ts.map +1 -1
- package/dist/adapters/sentry.js +8 -0
- package/dist/adapters/sentry.js.map +1 -1
- package/dist/api.d.ts +6 -0
- package/dist/api.d.ts.map +1 -1
- package/dist/api.js +6 -0
- package/dist/api.js.map +1 -1
- package/dist/index.d.ts +1 -1
- package/dist/index.d.ts.map +1 -1
- package/dist/index.js +1 -1
- package/dist/index.js.map +1 -1
- package/dist/init.d.ts.map +1 -1
- package/dist/init.js +7 -0
- package/dist/init.js.map +1 -1
- package/dist/types.d.ts +1 -1
- package/dist/types.d.ts.map +1 -1
- package/package.json +11 -2
- package/src/adapter.d.ts +16 -0
- package/src/adapter.d.ts.map +1 -0
- package/src/adapter.js +2 -0
- package/src/adapter.js.map +1 -0
- package/src/adapter.ts +8 -1
- package/src/adapters/noop.d.ts +3 -0
- package/src/adapters/noop.d.ts.map +1 -0
- package/src/adapters/noop.js +16 -0
- package/src/adapters/noop.js.map +1 -0
- package/src/adapters/noop.ts +8 -1
- package/src/adapters/sentry-node.d.ts +3 -0
- package/src/adapters/sentry-node.d.ts.map +1 -0
- package/src/adapters/sentry-node.js +75 -0
- package/src/adapters/sentry-node.js.map +1 -0
- package/src/adapters/sentry-node.ts +105 -0
- package/src/adapters/sentry.d.ts +3 -0
- package/src/adapters/sentry.d.ts.map +1 -0
- package/src/adapters/sentry.js +82 -0
- package/src/adapters/sentry.js.map +1 -0
- package/src/adapters/sentry.ts +16 -1
- package/src/api.d.ts +13 -0
- package/src/api.d.ts.map +1 -0
- package/src/api.js +29 -0
- package/src/api.js.map +1 -0
- package/src/api.ts +12 -0
- package/src/index.d.ts +4 -0
- package/src/index.d.ts.map +1 -0
- package/src/index.js +3 -0
- package/src/index.js.map +1 -0
- package/src/index.ts +1 -1
- package/src/init.d.ts +5 -0
- package/src/init.d.ts.map +1 -0
- package/src/init.js +33 -0
- package/src/init.js.map +1 -0
- package/src/init.ts +9 -1
- package/src/types.d.ts +21 -0
- package/src/types.d.ts.map +1 -0
- package/src/types.js +2 -0
- package/src/types.js.map +1 -0
- package/src/types.ts +2 -2
- package/tsconfig.json +17 -10
package/dist/adapter.d.ts
CHANGED
|
@@ -6,5 +6,11 @@ export interface MonitoringAdapter {
|
|
|
6
6
|
setUser(user: MonitoringUser | null): void;
|
|
7
7
|
setTag(key: string, value: string): void;
|
|
8
8
|
withScope?<T>(fn: (scope: ScopeLike) => T): T;
|
|
9
|
+
addBreadcrumb?(breadcrumb: {
|
|
10
|
+
category?: string;
|
|
11
|
+
message?: string;
|
|
12
|
+
level?: "fatal" | "error" | "warning" | "info" | "debug";
|
|
13
|
+
data?: Record<string, unknown>;
|
|
14
|
+
}): void;
|
|
9
15
|
}
|
|
10
16
|
//# sourceMappingURL=adapter.d.ts.map
|
package/dist/adapter.d.ts.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"adapter.d.ts","sourceRoot":"","sources":["../src/adapter.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,qBAAqB,EAAE,cAAc,EAAE,SAAS,EAAE,MAAM,SAAS,CAAC;AAEhF,MAAM,WAAW,iBAAiB;IAChC,IAAI,CAAC,OAAO,EAAE,qBAAqB,GAAG,IAAI,GAAG,OAAO,CAAC,IAAI,CAAC,CAAC;IAE3D,gBAAgB,CAAC,KAAK,EAAE,OAAO,EAAE,OAAO,CAAC,EAAE,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,GAAG,IAAI,CAAC;IAC1E,cAAc,CACZ,OAAO,EAAE,MAAM,EACf,KAAK,CAAC,EAAE,OAAO,GAAG,OAAO,GAAG,SAAS,GAAG,MAAM,GAAG,OAAO,GACvD,IAAI,CAAC;IAER,OAAO,CAAC,IAAI,EAAE,cAAc,GAAG,IAAI,GAAG,IAAI,CAAC;IAC3C,MAAM,CAAC,GAAG,EAAE,MAAM,EAAE,KAAK,EAAE,MAAM,GAAG,IAAI,CAAC;IAEzC,SAAS,CAAC,CAAC,CAAC,EAAE,EAAE,EAAE,CAAC,KAAK,EAAE,SAAS,KAAK,CAAC,GAAG,CAAC,CAAC;
|
|
1
|
+
{"version":3,"file":"adapter.d.ts","sourceRoot":"","sources":["../src/adapter.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,qBAAqB,EAAE,cAAc,EAAE,SAAS,EAAE,MAAM,SAAS,CAAC;AAEhF,MAAM,WAAW,iBAAiB;IAChC,IAAI,CAAC,OAAO,EAAE,qBAAqB,GAAG,IAAI,GAAG,OAAO,CAAC,IAAI,CAAC,CAAC;IAE3D,gBAAgB,CAAC,KAAK,EAAE,OAAO,EAAE,OAAO,CAAC,EAAE,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,GAAG,IAAI,CAAC;IAC1E,cAAc,CACZ,OAAO,EAAE,MAAM,EACf,KAAK,CAAC,EAAE,OAAO,GAAG,OAAO,GAAG,SAAS,GAAG,MAAM,GAAG,OAAO,GACvD,IAAI,CAAC;IAER,OAAO,CAAC,IAAI,EAAE,cAAc,GAAG,IAAI,GAAG,IAAI,CAAC;IAC3C,MAAM,CAAC,GAAG,EAAE,MAAM,EAAE,KAAK,EAAE,MAAM,GAAG,IAAI,CAAC;IAEzC,SAAS,CAAC,CAAC,CAAC,EAAE,EAAE,EAAE,CAAC,KAAK,EAAE,SAAS,KAAK,CAAC,GAAG,CAAC,CAAC;IAE9C,aAAa,CAAC,CAAC,UAAU,EAAE;QACzB,QAAQ,CAAC,EAAE,MAAM,CAAC;QAClB,OAAO,CAAC,EAAE,MAAM,CAAC;QACjB,KAAK,CAAC,EAAE,OAAO,GAAG,OAAO,GAAG,SAAS,GAAG,MAAM,GAAG,OAAO,CAAC;QACzD,IAAI,CAAC,EAAE,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,CAAC;KAChC,GAAG,IAAI,CAAC;CACV"}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"noop.d.ts","sourceRoot":"","sources":["../../src/adapters/noop.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,iBAAiB,EAAE,MAAM,YAAY,CAAC;AAUpD,eAAO,MAAM,WAAW,EAAE,
|
|
1
|
+
{"version":3,"file":"noop.d.ts","sourceRoot":"","sources":["../../src/adapters/noop.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,iBAAiB,EAAE,MAAM,YAAY,CAAC;AAUpD,eAAO,MAAM,WAAW,EAAE,iBAiBzB,CAAC"}
|
package/dist/adapters/noop.js
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"noop.js","sourceRoot":"","sources":["../../src/adapters/noop.ts"],"names":[],"mappings":"AAGA,MAAM,SAAS,GAAc;IAC3B,MAAM,EAAE,GAAG,EAAE,GAAE,CAAC;IAChB,OAAO,EAAE,GAAG,EAAE,GAAE,CAAC;IACjB,QAAQ,EAAE,GAAG,EAAE,GAAE,CAAC;IAClB,UAAU,EAAE,GAAG,EAAE,GAAE,CAAC;CACrB,CAAC;AAEF,MAAM,CAAC,MAAM,WAAW,GAAsB;IAC5C,IAAI,EAAE,CAAC,QAA+B,EAAE,EAAE,GAAE,CAAC;IAE7C,gBAAgB,EAAE,CAAC,MAAe,EAAE,QAAkC,EAAE,EAAE,GAAE,CAAC;IAC7E,cAAc,EAAE,CAAC,QAAgB,EAAE,MAAY,EAAE,EAAE,GAAE,CAAC;IAEtD,OAAO,EAAE,CAAC,KAA4B,EAAE,EAAE,GAAE,CAAC;IAC7C,MAAM,EAAE,CAAC,IAAY,EAAE,MAAc,EAAE,EAAE,GAAE,CAAC;IAE5C,SAAS,EAAE,CAAI,EAA2B,EAAE,EAAE,CAAC,EAAE,CAAC,SAAS,CAAC;
|
|
1
|
+
{"version":3,"file":"noop.js","sourceRoot":"","sources":["../../src/adapters/noop.ts"],"names":[],"mappings":"AAGA,MAAM,SAAS,GAAc;IAC3B,MAAM,EAAE,GAAG,EAAE,GAAE,CAAC;IAChB,OAAO,EAAE,GAAG,EAAE,GAAE,CAAC;IACjB,QAAQ,EAAE,GAAG,EAAE,GAAE,CAAC;IAClB,UAAU,EAAE,GAAG,EAAE,GAAE,CAAC;CACrB,CAAC;AAEF,MAAM,CAAC,MAAM,WAAW,GAAsB;IAC5C,IAAI,EAAE,CAAC,QAA+B,EAAE,EAAE,GAAE,CAAC;IAE7C,gBAAgB,EAAE,CAAC,MAAe,EAAE,QAAkC,EAAE,EAAE,GAAE,CAAC;IAC7E,cAAc,EAAE,CAAC,QAAgB,EAAE,MAAY,EAAE,EAAE,GAAE,CAAC;IAEtD,OAAO,EAAE,CAAC,KAA4B,EAAE,EAAE,GAAE,CAAC;IAC7C,MAAM,EAAE,CAAC,IAAY,EAAE,MAAc,EAAE,EAAE,GAAE,CAAC;IAE5C,SAAS,EAAE,CAAI,EAA2B,EAAE,EAAE,CAAC,EAAE,CAAC,SAAS,CAAC;IAE5D,aAAa,EAAE,CAAC,WAKf,EAAE,EAAE,GAAE,CAAC;CACT,CAAC"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"sentry-node.d.ts","sourceRoot":"","sources":["../../src/adapters/sentry-node.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,iBAAiB,EAAE,MAAM,YAAY,CAAC;AAwBpD,eAAO,MAAM,iBAAiB,EAAE,iBAgF/B,CAAC"}
|
|
@@ -0,0 +1,75 @@
|
|
|
1
|
+
let sentryNodePromise = null;
|
|
2
|
+
function getSentryNode() {
|
|
3
|
+
if (!sentryNodePromise) {
|
|
4
|
+
sentryNodePromise = Function("return import('@sentry/node')")().then((m) => m);
|
|
5
|
+
}
|
|
6
|
+
return sentryNodePromise;
|
|
7
|
+
}
|
|
8
|
+
export const SentryNodeAdapter = {
|
|
9
|
+
async init(options) {
|
|
10
|
+
const enabled = options.enabled ?? true;
|
|
11
|
+
if (!enabled || !options.dsn)
|
|
12
|
+
return;
|
|
13
|
+
const S = await getSentryNode();
|
|
14
|
+
S.init({
|
|
15
|
+
dsn: options.dsn,
|
|
16
|
+
environment: options.environment,
|
|
17
|
+
enabled: true,
|
|
18
|
+
release: options.release,
|
|
19
|
+
});
|
|
20
|
+
},
|
|
21
|
+
captureException(error, context) {
|
|
22
|
+
void (async () => {
|
|
23
|
+
const S = await getSentryNode();
|
|
24
|
+
if (context) {
|
|
25
|
+
S.withScope((scope) => {
|
|
26
|
+
for (const [k, v] of Object.entries(context)) {
|
|
27
|
+
if (typeof scope?.setExtra === "function")
|
|
28
|
+
scope.setExtra(k, v);
|
|
29
|
+
}
|
|
30
|
+
S.captureException(error);
|
|
31
|
+
});
|
|
32
|
+
return;
|
|
33
|
+
}
|
|
34
|
+
S.captureException(error);
|
|
35
|
+
})();
|
|
36
|
+
},
|
|
37
|
+
captureMessage(message, level) {
|
|
38
|
+
void (async () => {
|
|
39
|
+
const S = await getSentryNode();
|
|
40
|
+
S.captureMessage(message, level);
|
|
41
|
+
})();
|
|
42
|
+
},
|
|
43
|
+
setUser(user) {
|
|
44
|
+
void (async () => {
|
|
45
|
+
const S = await getSentryNode();
|
|
46
|
+
S.setUser(user);
|
|
47
|
+
})();
|
|
48
|
+
},
|
|
49
|
+
setTag(key, value) {
|
|
50
|
+
void (async () => {
|
|
51
|
+
const S = await getSentryNode();
|
|
52
|
+
S.setTag(key, value);
|
|
53
|
+
})();
|
|
54
|
+
},
|
|
55
|
+
withScope(fn) {
|
|
56
|
+
const minimalScope = {
|
|
57
|
+
setTag: () => { },
|
|
58
|
+
setUser: () => { },
|
|
59
|
+
setExtra: () => { },
|
|
60
|
+
setContext: () => { },
|
|
61
|
+
};
|
|
62
|
+
void (async () => {
|
|
63
|
+
const S = await getSentryNode();
|
|
64
|
+
S.withScope((scope) => fn(scope));
|
|
65
|
+
})();
|
|
66
|
+
return fn(minimalScope);
|
|
67
|
+
},
|
|
68
|
+
addBreadcrumb(breadcrumb) {
|
|
69
|
+
void (async () => {
|
|
70
|
+
const S = await getSentryNode();
|
|
71
|
+
S.addBreadcrumb(breadcrumb);
|
|
72
|
+
})();
|
|
73
|
+
},
|
|
74
|
+
};
|
|
75
|
+
//# sourceMappingURL=sentry-node.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"sentry-node.js","sourceRoot":"","sources":["../../src/adapters/sentry-node.ts"],"names":[],"mappings":"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"}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"sentry.d.ts","sourceRoot":"","sources":["../../src/adapters/sentry.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,iBAAiB,EAAE,MAAM,YAAY,CAAC;
|
|
1
|
+
{"version":3,"file":"sentry.d.ts","sourceRoot":"","sources":["../../src/adapters/sentry.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,iBAAiB,EAAE,MAAM,YAAY,CAAC;AAyBpD,eAAO,MAAM,aAAa,EAAE,iBAqF3B,CAAC"}
|
package/dist/adapters/sentry.js
CHANGED
|
@@ -70,5 +70,13 @@ export const SentryAdapter = {
|
|
|
70
70
|
})();
|
|
71
71
|
return fn(minimalScope);
|
|
72
72
|
},
|
|
73
|
+
addBreadcrumb(breadcrumb) {
|
|
74
|
+
void (async () => {
|
|
75
|
+
const S = await getSentry();
|
|
76
|
+
if (S.addBreadcrumb) {
|
|
77
|
+
S.addBreadcrumb(breadcrumb);
|
|
78
|
+
}
|
|
79
|
+
})();
|
|
80
|
+
},
|
|
73
81
|
};
|
|
74
82
|
//# sourceMappingURL=sentry.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"sentry.js","sourceRoot":"","sources":["../../src/adapters/sentry.ts"],"names":[],"mappings":"
|
|
1
|
+
{"version":3,"file":"sentry.js","sourceRoot":"","sources":["../../src/adapters/sentry.ts"],"names":[],"mappings":"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"}
|
package/dist/api.d.ts
CHANGED
|
@@ -4,4 +4,10 @@ export declare function captureMessage(message: string, level?: "fatal" | "error
|
|
|
4
4
|
export declare function setUser(user: MonitoringUser | null): void;
|
|
5
5
|
export declare function setTag(key: string, value: string): void;
|
|
6
6
|
export declare function withScope(fn: (scope: any) => any): any;
|
|
7
|
+
export declare function addBreadcrumb(breadcrumb: {
|
|
8
|
+
category?: string;
|
|
9
|
+
message?: string;
|
|
10
|
+
level?: "fatal" | "error" | "warning" | "info" | "debug";
|
|
11
|
+
data?: Record<string, unknown>;
|
|
12
|
+
}): void;
|
|
7
13
|
//# sourceMappingURL=api.d.ts.map
|
package/dist/api.d.ts.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"api.d.ts","sourceRoot":"","sources":["../src/api.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,cAAc,EAAE,MAAM,SAAS,CAAC;AAG9C,wBAAgB,gBAAgB,CAAC,KAAK,EAAE,OAAO,EAAE,OAAO,CAAC,EAAE,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,QAEjF;AAED,wBAAgB,cAAc,CAC5B,OAAO,EAAE,MAAM,EACf,KAAK,CAAC,EAAE,OAAO,GAAG,OAAO,GAAG,SAAS,GAAG,MAAM,GAAG,OAAO,QAGzD;AAED,wBAAgB,OAAO,CAAC,IAAI,EAAE,cAAc,GAAG,IAAI,QAElD;AAED,wBAAgB,MAAM,CAAC,GAAG,EAAE,MAAM,EAAE,KAAK,EAAE,MAAM,QAEhD;AAED,wBAAgB,SAAS,CAAC,EAAE,EAAE,CAAC,KAAK,EAAE,GAAG,KAAK,GAAG,OAQhD"}
|
|
1
|
+
{"version":3,"file":"api.d.ts","sourceRoot":"","sources":["../src/api.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,cAAc,EAAE,MAAM,SAAS,CAAC;AAG9C,wBAAgB,gBAAgB,CAAC,KAAK,EAAE,OAAO,EAAE,OAAO,CAAC,EAAE,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,QAEjF;AAED,wBAAgB,cAAc,CAC5B,OAAO,EAAE,MAAM,EACf,KAAK,CAAC,EAAE,OAAO,GAAG,OAAO,GAAG,SAAS,GAAG,MAAM,GAAG,OAAO,QAGzD;AAED,wBAAgB,OAAO,CAAC,IAAI,EAAE,cAAc,GAAG,IAAI,QAElD;AAED,wBAAgB,MAAM,CAAC,GAAG,EAAE,MAAM,EAAE,KAAK,EAAE,MAAM,QAEhD;AAED,wBAAgB,SAAS,CAAC,EAAE,EAAE,CAAC,KAAK,EAAE,GAAG,KAAK,GAAG,OAQhD;AAED,wBAAgB,aAAa,CAAC,UAAU,EAAE;IACxC,QAAQ,CAAC,EAAE,MAAM,CAAC;IAClB,OAAO,CAAC,EAAE,MAAM,CAAC;IACjB,KAAK,CAAC,EAAE,OAAO,GAAG,OAAO,GAAG,SAAS,GAAG,MAAM,GAAG,OAAO,CAAC;IACzD,IAAI,CAAC,EAAE,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,CAAC;CAChC,QAKA"}
|
package/dist/api.js
CHANGED
package/dist/api.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"api.js","sourceRoot":"","sources":["../src/api.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,oBAAoB,EAAE,MAAM,QAAQ,CAAC;AAE9C,MAAM,UAAU,gBAAgB,CAAC,KAAc,EAAE,OAAiC;IAChF,OAAO,oBAAoB,EAAE,CAAC,gBAAgB,CAAC,KAAK,EAAE,OAAO,CAAC,CAAC;AACjE,CAAC;AAED,MAAM,UAAU,cAAc,CAC5B,OAAe,EACf,KAAwD;IAExD,OAAO,oBAAoB,EAAE,CAAC,cAAc,CAAC,OAAO,EAAE,KAAK,CAAC,CAAC;AAC/D,CAAC;AAED,MAAM,UAAU,OAAO,CAAC,IAA2B;IACjD,OAAO,oBAAoB,EAAE,CAAC,OAAO,CAAC,IAAI,CAAC,CAAC;AAC9C,CAAC;AAED,MAAM,UAAU,MAAM,CAAC,GAAW,EAAE,KAAa;IAC/C,OAAO,oBAAoB,EAAE,CAAC,MAAM,CAAC,GAAG,EAAE,KAAK,CAAC,CAAC;AACnD,CAAC;AAED,MAAM,UAAU,SAAS,CAAC,EAAuB;IAC/C,MAAM,CAAC,GAAG,oBAAoB,EAAE,CAAC;IACjC,OAAO,CAAC,CAAC,SAAS,CAAC,CAAC,CAAC,CAAC,CAAC,SAAS,CAAC,EAAS,CAAC,CAAC,CAAC,CAAC,EAAE,CAAC;QAC/C,MAAM,EAAE,GAAG,EAAE,GAAE,CAAC;QAChB,OAAO,EAAE,GAAG,EAAE,GAAE,CAAC;QACjB,QAAQ,EAAE,GAAG,EAAE,GAAE,CAAC;QAClB,UAAU,EAAE,GAAG,EAAE,GAAE,CAAC;KACrB,CAAC,CAAC;AACL,CAAC"}
|
|
1
|
+
{"version":3,"file":"api.js","sourceRoot":"","sources":["../src/api.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,oBAAoB,EAAE,MAAM,QAAQ,CAAC;AAE9C,MAAM,UAAU,gBAAgB,CAAC,KAAc,EAAE,OAAiC;IAChF,OAAO,oBAAoB,EAAE,CAAC,gBAAgB,CAAC,KAAK,EAAE,OAAO,CAAC,CAAC;AACjE,CAAC;AAED,MAAM,UAAU,cAAc,CAC5B,OAAe,EACf,KAAwD;IAExD,OAAO,oBAAoB,EAAE,CAAC,cAAc,CAAC,OAAO,EAAE,KAAK,CAAC,CAAC;AAC/D,CAAC;AAED,MAAM,UAAU,OAAO,CAAC,IAA2B;IACjD,OAAO,oBAAoB,EAAE,CAAC,OAAO,CAAC,IAAI,CAAC,CAAC;AAC9C,CAAC;AAED,MAAM,UAAU,MAAM,CAAC,GAAW,EAAE,KAAa;IAC/C,OAAO,oBAAoB,EAAE,CAAC,MAAM,CAAC,GAAG,EAAE,KAAK,CAAC,CAAC;AACnD,CAAC;AAED,MAAM,UAAU,SAAS,CAAC,EAAuB;IAC/C,MAAM,CAAC,GAAG,oBAAoB,EAAE,CAAC;IACjC,OAAO,CAAC,CAAC,SAAS,CAAC,CAAC,CAAC,CAAC,CAAC,SAAS,CAAC,EAAS,CAAC,CAAC,CAAC,CAAC,EAAE,CAAC;QAC/C,MAAM,EAAE,GAAG,EAAE,GAAE,CAAC;QAChB,OAAO,EAAE,GAAG,EAAE,GAAE,CAAC;QACjB,QAAQ,EAAE,GAAG,EAAE,GAAE,CAAC;QAClB,UAAU,EAAE,GAAG,EAAE,GAAE,CAAC;KACrB,CAAC,CAAC;AACL,CAAC;AAED,MAAM,UAAU,aAAa,CAAC,UAK7B;IACC,MAAM,CAAC,GAAG,oBAAoB,EAAE,CAAC;IACjC,IAAI,CAAC,CAAC,aAAa,EAAE,CAAC;QACpB,CAAC,CAAC,aAAa,CAAC,UAAU,CAAC,CAAC;IAC9B,CAAC;AACH,CAAC"}
|
package/dist/index.d.ts
CHANGED
|
@@ -1,4 +1,4 @@
|
|
|
1
1
|
export type { MonitoringInitOptions, MonitoringUser, MonitoringProvider, ScopeLike } from "./types";
|
|
2
2
|
export { initMonitoring } from "./init";
|
|
3
|
-
export { captureException, captureMessage, setUser, setTag, withScope } from "./api";
|
|
3
|
+
export { captureException, captureMessage, setUser, setTag, withScope, addBreadcrumb } from "./api";
|
|
4
4
|
//# sourceMappingURL=index.d.ts.map
|
package/dist/index.d.ts.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../src/index.ts"],"names":[],"mappings":"AAAA,YAAY,EAAE,qBAAqB,EAAE,cAAc,EAAE,kBAAkB,EAAE,SAAS,EAAE,MAAM,SAAS,CAAC;AAEpG,OAAO,EAAE,cAAc,EAAE,MAAM,QAAQ,CAAC;AACxC,OAAO,EAAE,gBAAgB,EAAE,cAAc,EAAE,OAAO,EAAE,MAAM,EAAE,SAAS,EAAE,MAAM,OAAO,CAAC"}
|
|
1
|
+
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../src/index.ts"],"names":[],"mappings":"AAAA,YAAY,EAAE,qBAAqB,EAAE,cAAc,EAAE,kBAAkB,EAAE,SAAS,EAAE,MAAM,SAAS,CAAC;AAEpG,OAAO,EAAE,cAAc,EAAE,MAAM,QAAQ,CAAC;AACxC,OAAO,EAAE,gBAAgB,EAAE,cAAc,EAAE,OAAO,EAAE,MAAM,EAAE,SAAS,EAAE,aAAa,EAAE,MAAM,OAAO,CAAC"}
|
package/dist/index.js
CHANGED
package/dist/index.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.js","sourceRoot":"","sources":["../src/index.ts"],"names":[],"mappings":"AAEA,OAAO,EAAE,cAAc,EAAE,MAAM,QAAQ,CAAC;AACxC,OAAO,EAAE,gBAAgB,EAAE,cAAc,EAAE,OAAO,EAAE,MAAM,EAAE,SAAS,EAAE,MAAM,OAAO,CAAC"}
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../src/index.ts"],"names":[],"mappings":"AAEA,OAAO,EAAE,cAAc,EAAE,MAAM,QAAQ,CAAC;AACxC,OAAO,EAAE,gBAAgB,EAAE,cAAc,EAAE,OAAO,EAAE,MAAM,EAAE,SAAS,EAAE,aAAa,EAAE,MAAM,OAAO,CAAC"}
|
package/dist/init.d.ts.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"init.d.ts","sourceRoot":"","sources":["../src/init.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,iBAAiB,EAAE,MAAM,WAAW,CAAC;AACnD,OAAO,KAAK,EAAE,qBAAqB,EAAE,MAAM,SAAS,CAAC;
|
|
1
|
+
{"version":3,"file":"init.d.ts","sourceRoot":"","sources":["../src/init.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,iBAAiB,EAAE,MAAM,WAAW,CAAC;AACnD,OAAO,KAAK,EAAE,qBAAqB,EAAE,MAAM,SAAS,CAAC;AAQrD,wBAAgB,oBAAoB,IAAI,iBAAiB,CAExD;AAED,wBAAsB,cAAc,CAAC,OAAO,EAAE,qBAAqB,GAAG,OAAO,CAAC,IAAI,CAAC,CA2BlF"}
|
package/dist/init.js
CHANGED
|
@@ -1,5 +1,6 @@
|
|
|
1
1
|
import { NoopAdapter } from "./adapters/noop";
|
|
2
2
|
import { SentryAdapter } from "./adapters/sentry";
|
|
3
|
+
import { SentryNodeAdapter } from "./adapters/sentry-node";
|
|
3
4
|
let adapter = NoopAdapter;
|
|
4
5
|
let initialized = false;
|
|
5
6
|
export function getMonitoringAdapter() {
|
|
@@ -20,6 +21,12 @@ export async function initMonitoring(options) {
|
|
|
20
21
|
initialized = true;
|
|
21
22
|
return;
|
|
22
23
|
}
|
|
24
|
+
if (options.provider === "sentry-node") {
|
|
25
|
+
adapter = SentryNodeAdapter;
|
|
26
|
+
await adapter.init(options);
|
|
27
|
+
initialized = true;
|
|
28
|
+
return;
|
|
29
|
+
}
|
|
23
30
|
adapter = NoopAdapter;
|
|
24
31
|
initialized = true;
|
|
25
32
|
}
|
package/dist/init.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"init.js","sourceRoot":"","sources":["../src/init.ts"],"names":[],"mappings":"AAEA,OAAO,EAAE,WAAW,EAAE,MAAM,iBAAiB,CAAC;AAC9C,OAAO,EAAE,aAAa,EAAE,MAAM,mBAAmB,CAAC;
|
|
1
|
+
{"version":3,"file":"init.js","sourceRoot":"","sources":["../src/init.ts"],"names":[],"mappings":"AAEA,OAAO,EAAE,WAAW,EAAE,MAAM,iBAAiB,CAAC;AAC9C,OAAO,EAAE,aAAa,EAAE,MAAM,mBAAmB,CAAC;AAClD,OAAO,EAAE,iBAAiB,EAAE,MAAM,wBAAwB,CAAC;AAE3D,IAAI,OAAO,GAAsB,WAAW,CAAC;AAC7C,IAAI,WAAW,GAAG,KAAK,CAAC;AAExB,MAAM,UAAU,oBAAoB;IAClC,OAAO,OAAO,CAAC;AACjB,CAAC;AAED,MAAM,CAAC,KAAK,UAAU,cAAc,CAAC,OAA8B;IACjE,IAAI,WAAW;QAAE,OAAO;IAExB,MAAM,OAAO,GAAG,OAAO,CAAC,OAAO,IAAI,IAAI,CAAC;IAExC,IAAI,CAAC,OAAO,IAAI,OAAO,CAAC,QAAQ,KAAK,MAAM,EAAE,CAAC;QAC5C,OAAO,GAAG,WAAW,CAAC;QACtB,WAAW,GAAG,IAAI,CAAC;QACnB,OAAO;IACT,CAAC;IAED,IAAI,OAAO,CAAC,QAAQ,KAAK,QAAQ,EAAE,CAAC;QAClC,OAAO,GAAG,aAAa,CAAC;QACxB,MAAM,OAAO,CAAC,IAAI,CAAC,OAAO,CAAC,CAAC;QAC5B,WAAW,GAAG,IAAI,CAAC;QACnB,OAAO;IACT,CAAC;IAED,IAAI,OAAO,CAAC,QAAQ,KAAK,aAAa,EAAE,CAAC;QACvC,OAAO,GAAG,iBAAiB,CAAC;QAC5B,MAAM,OAAO,CAAC,IAAI,CAAC,OAAO,CAAC,CAAC;QAC5B,WAAW,GAAG,IAAI,CAAC;QACnB,OAAO;IACT,CAAC;IAED,OAAO,GAAG,WAAW,CAAC;IACtB,WAAW,GAAG,IAAI,CAAC;AACrB,CAAC"}
|
package/dist/types.d.ts
CHANGED
package/dist/types.d.ts.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"types.d.ts","sourceRoot":"","sources":["../src/types.ts"],"names":[],"mappings":"AAAA,MAAM,MAAM,kBAAkB,GAAG,QAAQ,GAAG,MAAM,CAAC;
|
|
1
|
+
{"version":3,"file":"types.d.ts","sourceRoot":"","sources":["../src/types.ts"],"names":[],"mappings":"AAAA,MAAM,MAAM,kBAAkB,GAAG,QAAQ,GAAG,aAAa,GAAG,MAAM,CAAC;AAEnE,MAAM,MAAM,qBAAqB,GAAG;IAClC,QAAQ,EAAE,kBAAkB,CAAC;IAC7B,GAAG,CAAC,EAAE,MAAM,CAAC;IACb,WAAW,CAAC,EAAE,MAAM,CAAC;IACrB,OAAO,CAAC,EAAE,OAAO,CAAC;IAClB,OAAO,CAAC,EAAE,MAAM,CAAC;CAClB,CAAC;AAEF,MAAM,MAAM,cAAc,GAAG;IAC3B,EAAE,CAAC,EAAE,MAAM,CAAC;IACZ,KAAK,CAAC,EAAE,MAAM,CAAC;IACf,QAAQ,CAAC,EAAE,MAAM,CAAC;IAClB,UAAU,CAAC,EAAE,MAAM,CAAC;CACrB,CAAC;AAEF,MAAM,MAAM,SAAS,GAAG;IACtB,MAAM,EAAE,CAAC,GAAG,EAAE,MAAM,EAAE,KAAK,EAAE,MAAM,KAAK,IAAI,CAAC;IAC7C,OAAO,EAAE,CAAC,IAAI,EAAE,cAAc,GAAG,IAAI,KAAK,IAAI,CAAC;IAC/C,QAAQ,EAAE,CAAC,GAAG,EAAE,MAAM,EAAE,KAAK,EAAE,OAAO,KAAK,IAAI,CAAC;IAChD,UAAU,EAAE,CAAC,GAAG,EAAE,MAAM,EAAE,OAAO,EAAE,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,KAAK,IAAI,CAAC;CACrE,CAAC"}
|
package/package.json
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@ttt-productions/monitoring-core",
|
|
3
|
-
"version": "0.0.
|
|
3
|
+
"version": "0.0.6",
|
|
4
4
|
"repository": {
|
|
5
5
|
"type": "git",
|
|
6
6
|
"url": "git+https://github.com/ttt-productions/ttt-packages.git",
|
|
@@ -17,6 +17,15 @@
|
|
|
17
17
|
"sideEffects": false,
|
|
18
18
|
"dependencies": {},
|
|
19
19
|
"peerDependencies": {
|
|
20
|
-
"@sentry/nextjs": ">=8.0.0"
|
|
20
|
+
"@sentry/nextjs": ">=8.0.0",
|
|
21
|
+
"@sentry/node": ">=8.0.0"
|
|
22
|
+
},
|
|
23
|
+
"peerDependenciesMeta": {
|
|
24
|
+
"@sentry/nextjs": {
|
|
25
|
+
"optional": true
|
|
26
|
+
},
|
|
27
|
+
"@sentry/node": {
|
|
28
|
+
"optional": true
|
|
29
|
+
}
|
|
21
30
|
}
|
|
22
31
|
}
|
package/src/adapter.d.ts
ADDED
|
@@ -0,0 +1,16 @@
|
|
|
1
|
+
import type { MonitoringInitOptions, MonitoringUser, ScopeLike } from "./types";
|
|
2
|
+
export interface MonitoringAdapter {
|
|
3
|
+
init(options: MonitoringInitOptions): void | Promise<void>;
|
|
4
|
+
captureException(error: unknown, context?: Record<string, unknown>): void;
|
|
5
|
+
captureMessage(message: string, level?: "fatal" | "error" | "warning" | "info" | "debug"): void;
|
|
6
|
+
setUser(user: MonitoringUser | null): void;
|
|
7
|
+
setTag(key: string, value: string): void;
|
|
8
|
+
withScope?<T>(fn: (scope: ScopeLike) => T): T;
|
|
9
|
+
addBreadcrumb?(breadcrumb: {
|
|
10
|
+
category?: string;
|
|
11
|
+
message?: string;
|
|
12
|
+
level?: "fatal" | "error" | "warning" | "info" | "debug";
|
|
13
|
+
data?: Record<string, unknown>;
|
|
14
|
+
}): void;
|
|
15
|
+
}
|
|
16
|
+
//# sourceMappingURL=adapter.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"adapter.d.ts","sourceRoot":"","sources":["adapter.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,qBAAqB,EAAE,cAAc,EAAE,SAAS,EAAE,MAAM,SAAS,CAAC;AAEhF,MAAM,WAAW,iBAAiB;IAChC,IAAI,CAAC,OAAO,EAAE,qBAAqB,GAAG,IAAI,GAAG,OAAO,CAAC,IAAI,CAAC,CAAC;IAE3D,gBAAgB,CAAC,KAAK,EAAE,OAAO,EAAE,OAAO,CAAC,EAAE,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,GAAG,IAAI,CAAC;IAC1E,cAAc,CACZ,OAAO,EAAE,MAAM,EACf,KAAK,CAAC,EAAE,OAAO,GAAG,OAAO,GAAG,SAAS,GAAG,MAAM,GAAG,OAAO,GACvD,IAAI,CAAC;IAER,OAAO,CAAC,IAAI,EAAE,cAAc,GAAG,IAAI,GAAG,IAAI,CAAC;IAC3C,MAAM,CAAC,GAAG,EAAE,MAAM,EAAE,KAAK,EAAE,MAAM,GAAG,IAAI,CAAC;IAEzC,SAAS,CAAC,CAAC,CAAC,EAAE,EAAE,EAAE,CAAC,KAAK,EAAE,SAAS,KAAK,CAAC,GAAG,CAAC,CAAC;IAE9C,aAAa,CAAC,CAAC,UAAU,EAAE;QACzB,QAAQ,CAAC,EAAE,MAAM,CAAC;QAClB,OAAO,CAAC,EAAE,MAAM,CAAC;QACjB,KAAK,CAAC,EAAE,OAAO,GAAG,OAAO,GAAG,SAAS,GAAG,MAAM,GAAG,OAAO,CAAC;QACzD,IAAI,CAAC,EAAE,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,CAAC;KAChC,GAAG,IAAI,CAAC;CACV"}
|
package/src/adapter.js
ADDED
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"adapter.js","sourceRoot":"","sources":["adapter.ts"],"names":[],"mappings":""}
|
package/src/adapter.ts
CHANGED
|
@@ -13,4 +13,11 @@ export interface MonitoringAdapter {
|
|
|
13
13
|
setTag(key: string, value: string): void;
|
|
14
14
|
|
|
15
15
|
withScope?<T>(fn: (scope: ScopeLike) => T): T;
|
|
16
|
-
|
|
16
|
+
|
|
17
|
+
addBreadcrumb?(breadcrumb: {
|
|
18
|
+
category?: string;
|
|
19
|
+
message?: string;
|
|
20
|
+
level?: "fatal" | "error" | "warning" | "info" | "debug";
|
|
21
|
+
data?: Record<string, unknown>;
|
|
22
|
+
}): void;
|
|
23
|
+
}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"noop.d.ts","sourceRoot":"","sources":["noop.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,iBAAiB,EAAE,MAAM,YAAY,CAAC;AAUpD,eAAO,MAAM,WAAW,EAAE,iBAiBzB,CAAC"}
|
|
@@ -0,0 +1,16 @@
|
|
|
1
|
+
const noopScope = {
|
|
2
|
+
setTag: () => { },
|
|
3
|
+
setUser: () => { },
|
|
4
|
+
setExtra: () => { },
|
|
5
|
+
setContext: () => { },
|
|
6
|
+
};
|
|
7
|
+
export const NoopAdapter = {
|
|
8
|
+
init: (_options) => { },
|
|
9
|
+
captureException: (_error, _context) => { },
|
|
10
|
+
captureMessage: (_message, _level) => { },
|
|
11
|
+
setUser: (_user) => { },
|
|
12
|
+
setTag: (_key, _value) => { },
|
|
13
|
+
withScope: (fn) => fn(noopScope),
|
|
14
|
+
addBreadcrumb: (_breadcrumb) => { },
|
|
15
|
+
};
|
|
16
|
+
//# sourceMappingURL=noop.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"noop.js","sourceRoot":"","sources":["noop.ts"],"names":[],"mappings":"AAGA,MAAM,SAAS,GAAc;IAC3B,MAAM,EAAE,GAAG,EAAE,GAAE,CAAC;IAChB,OAAO,EAAE,GAAG,EAAE,GAAE,CAAC;IACjB,QAAQ,EAAE,GAAG,EAAE,GAAE,CAAC;IAClB,UAAU,EAAE,GAAG,EAAE,GAAE,CAAC;CACrB,CAAC;AAEF,MAAM,CAAC,MAAM,WAAW,GAAsB;IAC5C,IAAI,EAAE,CAAC,QAA+B,EAAE,EAAE,GAAE,CAAC;IAE7C,gBAAgB,EAAE,CAAC,MAAe,EAAE,QAAkC,EAAE,EAAE,GAAE,CAAC;IAC7E,cAAc,EAAE,CAAC,QAAgB,EAAE,MAAY,EAAE,EAAE,GAAE,CAAC;IAEtD,OAAO,EAAE,CAAC,KAA4B,EAAE,EAAE,GAAE,CAAC;IAC7C,MAAM,EAAE,CAAC,IAAY,EAAE,MAAc,EAAE,EAAE,GAAE,CAAC;IAE5C,SAAS,EAAE,CAAI,EAA2B,EAAE,EAAE,CAAC,EAAE,CAAC,SAAS,CAAC;IAE5D,aAAa,EAAE,CAAC,WAKf,EAAE,EAAE,GAAE,CAAC;CACT,CAAC"}
|
package/src/adapters/noop.ts
CHANGED
|
@@ -18,4 +18,11 @@ export const NoopAdapter: MonitoringAdapter = {
|
|
|
18
18
|
setTag: (_key: string, _value: string) => {},
|
|
19
19
|
|
|
20
20
|
withScope: <T>(fn: (scope: ScopeLike) => T) => fn(noopScope),
|
|
21
|
-
|
|
21
|
+
|
|
22
|
+
addBreadcrumb: (_breadcrumb: {
|
|
23
|
+
category?: string;
|
|
24
|
+
message?: string;
|
|
25
|
+
level?: "fatal" | "error" | "warning" | "info" | "debug";
|
|
26
|
+
data?: Record<string, unknown>;
|
|
27
|
+
}) => {},
|
|
28
|
+
};
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"sentry-node.d.ts","sourceRoot":"","sources":["sentry-node.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,iBAAiB,EAAE,MAAM,YAAY,CAAC;AAwBpD,eAAO,MAAM,iBAAiB,EAAE,iBAgF/B,CAAC"}
|
|
@@ -0,0 +1,75 @@
|
|
|
1
|
+
let sentryNodePromise = null;
|
|
2
|
+
function getSentryNode() {
|
|
3
|
+
if (!sentryNodePromise) {
|
|
4
|
+
sentryNodePromise = Function("return import('@sentry/node')")().then((m) => m);
|
|
5
|
+
}
|
|
6
|
+
return sentryNodePromise;
|
|
7
|
+
}
|
|
8
|
+
export const SentryNodeAdapter = {
|
|
9
|
+
async init(options) {
|
|
10
|
+
const enabled = options.enabled ?? true;
|
|
11
|
+
if (!enabled || !options.dsn)
|
|
12
|
+
return;
|
|
13
|
+
const S = await getSentryNode();
|
|
14
|
+
S.init({
|
|
15
|
+
dsn: options.dsn,
|
|
16
|
+
environment: options.environment,
|
|
17
|
+
enabled: true,
|
|
18
|
+
release: options.release,
|
|
19
|
+
});
|
|
20
|
+
},
|
|
21
|
+
captureException(error, context) {
|
|
22
|
+
void (async () => {
|
|
23
|
+
const S = await getSentryNode();
|
|
24
|
+
if (context) {
|
|
25
|
+
S.withScope((scope) => {
|
|
26
|
+
for (const [k, v] of Object.entries(context)) {
|
|
27
|
+
if (typeof scope?.setExtra === "function")
|
|
28
|
+
scope.setExtra(k, v);
|
|
29
|
+
}
|
|
30
|
+
S.captureException(error);
|
|
31
|
+
});
|
|
32
|
+
return;
|
|
33
|
+
}
|
|
34
|
+
S.captureException(error);
|
|
35
|
+
})();
|
|
36
|
+
},
|
|
37
|
+
captureMessage(message, level) {
|
|
38
|
+
void (async () => {
|
|
39
|
+
const S = await getSentryNode();
|
|
40
|
+
S.captureMessage(message, level);
|
|
41
|
+
})();
|
|
42
|
+
},
|
|
43
|
+
setUser(user) {
|
|
44
|
+
void (async () => {
|
|
45
|
+
const S = await getSentryNode();
|
|
46
|
+
S.setUser(user);
|
|
47
|
+
})();
|
|
48
|
+
},
|
|
49
|
+
setTag(key, value) {
|
|
50
|
+
void (async () => {
|
|
51
|
+
const S = await getSentryNode();
|
|
52
|
+
S.setTag(key, value);
|
|
53
|
+
})();
|
|
54
|
+
},
|
|
55
|
+
withScope(fn) {
|
|
56
|
+
const minimalScope = {
|
|
57
|
+
setTag: () => { },
|
|
58
|
+
setUser: () => { },
|
|
59
|
+
setExtra: () => { },
|
|
60
|
+
setContext: () => { },
|
|
61
|
+
};
|
|
62
|
+
void (async () => {
|
|
63
|
+
const S = await getSentryNode();
|
|
64
|
+
S.withScope((scope) => fn(scope));
|
|
65
|
+
})();
|
|
66
|
+
return fn(minimalScope);
|
|
67
|
+
},
|
|
68
|
+
addBreadcrumb(breadcrumb) {
|
|
69
|
+
void (async () => {
|
|
70
|
+
const S = await getSentryNode();
|
|
71
|
+
S.addBreadcrumb(breadcrumb);
|
|
72
|
+
})();
|
|
73
|
+
},
|
|
74
|
+
};
|
|
75
|
+
//# sourceMappingURL=sentry-node.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"sentry-node.js","sourceRoot":"","sources":["sentry-node.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,105 @@
|
|
|
1
|
+
import type { MonitoringAdapter } from "../adapter";
|
|
2
|
+
import type { MonitoringInitOptions, MonitoringUser, ScopeLike } from "../types";
|
|
3
|
+
|
|
4
|
+
type SentryNodeLike = {
|
|
5
|
+
init: (opts: any) => void;
|
|
6
|
+
captureException: (e: unknown, hint?: any) => void;
|
|
7
|
+
captureMessage: (m: string, level?: any) => void;
|
|
8
|
+
setUser: (u: any) => void;
|
|
9
|
+
setTag: (k: string, v: string) => void;
|
|
10
|
+
withScope: (fn: (scope: any) => void) => void;
|
|
11
|
+
addBreadcrumb: (breadcrumb: any) => void;
|
|
12
|
+
};
|
|
13
|
+
|
|
14
|
+
let sentryNodePromise: Promise<SentryNodeLike> | null = null;
|
|
15
|
+
|
|
16
|
+
function getSentryNode(): Promise<SentryNodeLike> {
|
|
17
|
+
if (!sentryNodePromise) {
|
|
18
|
+
sentryNodePromise = (Function("return import('@sentry/node')")() as Promise<any>).then(
|
|
19
|
+
(m) => m as SentryNodeLike
|
|
20
|
+
);
|
|
21
|
+
}
|
|
22
|
+
return sentryNodePromise;
|
|
23
|
+
}
|
|
24
|
+
|
|
25
|
+
export const SentryNodeAdapter: MonitoringAdapter = {
|
|
26
|
+
async init(options: MonitoringInitOptions) {
|
|
27
|
+
const enabled = options.enabled ?? true;
|
|
28
|
+
if (!enabled || !options.dsn) return;
|
|
29
|
+
|
|
30
|
+
const S = await getSentryNode();
|
|
31
|
+
S.init({
|
|
32
|
+
dsn: options.dsn,
|
|
33
|
+
environment: options.environment,
|
|
34
|
+
enabled: true,
|
|
35
|
+
release: options.release,
|
|
36
|
+
});
|
|
37
|
+
},
|
|
38
|
+
|
|
39
|
+
captureException(error: unknown, context?: Record<string, unknown>) {
|
|
40
|
+
void (async () => {
|
|
41
|
+
const S = await getSentryNode();
|
|
42
|
+
|
|
43
|
+
if (context) {
|
|
44
|
+
S.withScope((scope) => {
|
|
45
|
+
for (const [k, v] of Object.entries(context)) {
|
|
46
|
+
if (typeof scope?.setExtra === "function") scope.setExtra(k, v);
|
|
47
|
+
}
|
|
48
|
+
S.captureException(error);
|
|
49
|
+
});
|
|
50
|
+
return;
|
|
51
|
+
}
|
|
52
|
+
|
|
53
|
+
S.captureException(error);
|
|
54
|
+
})();
|
|
55
|
+
},
|
|
56
|
+
|
|
57
|
+
captureMessage(message: string, level?: any) {
|
|
58
|
+
void (async () => {
|
|
59
|
+
const S = await getSentryNode();
|
|
60
|
+
S.captureMessage(message, level);
|
|
61
|
+
})();
|
|
62
|
+
},
|
|
63
|
+
|
|
64
|
+
setUser(user: MonitoringUser | null) {
|
|
65
|
+
void (async () => {
|
|
66
|
+
const S = await getSentryNode();
|
|
67
|
+
S.setUser(user as any);
|
|
68
|
+
})();
|
|
69
|
+
},
|
|
70
|
+
|
|
71
|
+
setTag(key: string, value: string) {
|
|
72
|
+
void (async () => {
|
|
73
|
+
const S = await getSentryNode();
|
|
74
|
+
S.setTag(key, value);
|
|
75
|
+
})();
|
|
76
|
+
},
|
|
77
|
+
|
|
78
|
+
withScope<T>(fn: (scope: ScopeLike) => T): T {
|
|
79
|
+
const minimalScope: ScopeLike = {
|
|
80
|
+
setTag: () => {},
|
|
81
|
+
setUser: () => {},
|
|
82
|
+
setExtra: () => {},
|
|
83
|
+
setContext: () => {},
|
|
84
|
+
};
|
|
85
|
+
|
|
86
|
+
void (async () => {
|
|
87
|
+
const S = await getSentryNode();
|
|
88
|
+
S.withScope((scope) => fn(scope as any));
|
|
89
|
+
})();
|
|
90
|
+
|
|
91
|
+
return fn(minimalScope);
|
|
92
|
+
},
|
|
93
|
+
|
|
94
|
+
addBreadcrumb(breadcrumb: {
|
|
95
|
+
category?: string;
|
|
96
|
+
message?: string;
|
|
97
|
+
level?: "fatal" | "error" | "warning" | "info" | "debug";
|
|
98
|
+
data?: Record<string, unknown>;
|
|
99
|
+
}) {
|
|
100
|
+
void (async () => {
|
|
101
|
+
const S = await getSentryNode();
|
|
102
|
+
S.addBreadcrumb(breadcrumb);
|
|
103
|
+
})();
|
|
104
|
+
},
|
|
105
|
+
};
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"sentry.d.ts","sourceRoot":"","sources":["sentry.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,iBAAiB,EAAE,MAAM,YAAY,CAAC;AAyBpD,eAAO,MAAM,aAAa,EAAE,iBAqF3B,CAAC"}
|
|
@@ -0,0 +1,82 @@
|
|
|
1
|
+
let sentryPromise = null;
|
|
2
|
+
function getSentry() {
|
|
3
|
+
if (!sentryPromise) {
|
|
4
|
+
// keep the import fully dynamic and untyped so TS doesn't require the module at build time
|
|
5
|
+
sentryPromise = Function("return import('@sentry/nextjs')")().then((m) => m);
|
|
6
|
+
}
|
|
7
|
+
return sentryPromise;
|
|
8
|
+
}
|
|
9
|
+
export const SentryAdapter = {
|
|
10
|
+
async init(options) {
|
|
11
|
+
const enabled = options.enabled ?? true;
|
|
12
|
+
if (!enabled || !options.dsn)
|
|
13
|
+
return;
|
|
14
|
+
const S = await getSentry();
|
|
15
|
+
S.init({
|
|
16
|
+
dsn: options.dsn,
|
|
17
|
+
environment: options.environment,
|
|
18
|
+
enabled: true,
|
|
19
|
+
release: options.release,
|
|
20
|
+
});
|
|
21
|
+
},
|
|
22
|
+
captureException(error, context) {
|
|
23
|
+
void (async () => {
|
|
24
|
+
const S = await getSentry();
|
|
25
|
+
if (context && S.withScope) {
|
|
26
|
+
S.withScope((scope) => {
|
|
27
|
+
for (const [k, v] of Object.entries(context)) {
|
|
28
|
+
if (typeof scope?.setExtra === "function")
|
|
29
|
+
scope.setExtra(k, v);
|
|
30
|
+
}
|
|
31
|
+
S.captureException(error);
|
|
32
|
+
});
|
|
33
|
+
return;
|
|
34
|
+
}
|
|
35
|
+
S.captureException(error);
|
|
36
|
+
})();
|
|
37
|
+
},
|
|
38
|
+
captureMessage(message, level) {
|
|
39
|
+
void (async () => {
|
|
40
|
+
const S = await getSentry();
|
|
41
|
+
S.captureMessage(message, level);
|
|
42
|
+
})();
|
|
43
|
+
},
|
|
44
|
+
setUser(user) {
|
|
45
|
+
void (async () => {
|
|
46
|
+
const S = await getSentry();
|
|
47
|
+
S.setUser(user);
|
|
48
|
+
})();
|
|
49
|
+
},
|
|
50
|
+
setTag(key, value) {
|
|
51
|
+
void (async () => {
|
|
52
|
+
const S = await getSentry();
|
|
53
|
+
S.setTag(key, value);
|
|
54
|
+
})();
|
|
55
|
+
},
|
|
56
|
+
withScope(fn) {
|
|
57
|
+
// run immediately (sync) with a minimal scope.
|
|
58
|
+
// also try to run in real Sentry scope when available.
|
|
59
|
+
const minimalScope = {
|
|
60
|
+
setTag: () => { },
|
|
61
|
+
setUser: () => { },
|
|
62
|
+
setExtra: () => { },
|
|
63
|
+
setContext: () => { },
|
|
64
|
+
};
|
|
65
|
+
void (async () => {
|
|
66
|
+
const S = await getSentry();
|
|
67
|
+
if (!S.withScope)
|
|
68
|
+
return;
|
|
69
|
+
S.withScope((scope) => fn(scope));
|
|
70
|
+
})();
|
|
71
|
+
return fn(minimalScope);
|
|
72
|
+
},
|
|
73
|
+
addBreadcrumb(breadcrumb) {
|
|
74
|
+
void (async () => {
|
|
75
|
+
const S = await getSentry();
|
|
76
|
+
if (S.addBreadcrumb) {
|
|
77
|
+
S.addBreadcrumb(breadcrumb);
|
|
78
|
+
}
|
|
79
|
+
})();
|
|
80
|
+
},
|
|
81
|
+
};
|
|
82
|
+
//# sourceMappingURL=sentry.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"sentry.js","sourceRoot":"","sources":["sentry.ts"],"names":[],"mappings":"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"}
|
package/src/adapters/sentry.ts
CHANGED
|
@@ -8,6 +8,7 @@ type SentryLike = {
|
|
|
8
8
|
setUser: (u: any) => void;
|
|
9
9
|
setTag: (k: string, v: string) => void;
|
|
10
10
|
withScope?: (fn: (scope: any) => void) => void;
|
|
11
|
+
addBreadcrumb?: (breadcrumb: any) => void;
|
|
11
12
|
};
|
|
12
13
|
|
|
13
14
|
let sentryPromise: Promise<SentryLike> | null = null;
|
|
@@ -93,4 +94,18 @@ export const SentryAdapter: MonitoringAdapter = {
|
|
|
93
94
|
|
|
94
95
|
return fn(minimalScope);
|
|
95
96
|
},
|
|
96
|
-
|
|
97
|
+
|
|
98
|
+
addBreadcrumb(breadcrumb: {
|
|
99
|
+
category?: string;
|
|
100
|
+
message?: string;
|
|
101
|
+
level?: "fatal" | "error" | "warning" | "info" | "debug";
|
|
102
|
+
data?: Record<string, unknown>;
|
|
103
|
+
}) {
|
|
104
|
+
void (async () => {
|
|
105
|
+
const S = await getSentry();
|
|
106
|
+
if (S.addBreadcrumb) {
|
|
107
|
+
S.addBreadcrumb(breadcrumb);
|
|
108
|
+
}
|
|
109
|
+
})();
|
|
110
|
+
},
|
|
111
|
+
};
|
package/src/api.d.ts
ADDED
|
@@ -0,0 +1,13 @@
|
|
|
1
|
+
import type { MonitoringUser } from "./types";
|
|
2
|
+
export declare function captureException(error: unknown, context?: Record<string, unknown>): void;
|
|
3
|
+
export declare function captureMessage(message: string, level?: "fatal" | "error" | "warning" | "info" | "debug"): void;
|
|
4
|
+
export declare function setUser(user: MonitoringUser | null): void;
|
|
5
|
+
export declare function setTag(key: string, value: string): void;
|
|
6
|
+
export declare function withScope(fn: (scope: any) => any): any;
|
|
7
|
+
export declare function addBreadcrumb(breadcrumb: {
|
|
8
|
+
category?: string;
|
|
9
|
+
message?: string;
|
|
10
|
+
level?: "fatal" | "error" | "warning" | "info" | "debug";
|
|
11
|
+
data?: Record<string, unknown>;
|
|
12
|
+
}): void;
|
|
13
|
+
//# sourceMappingURL=api.d.ts.map
|
package/src/api.d.ts.map
ADDED
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"api.d.ts","sourceRoot":"","sources":["api.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,cAAc,EAAE,MAAM,SAAS,CAAC;AAG9C,wBAAgB,gBAAgB,CAAC,KAAK,EAAE,OAAO,EAAE,OAAO,CAAC,EAAE,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,QAEjF;AAED,wBAAgB,cAAc,CAC5B,OAAO,EAAE,MAAM,EACf,KAAK,CAAC,EAAE,OAAO,GAAG,OAAO,GAAG,SAAS,GAAG,MAAM,GAAG,OAAO,QAGzD;AAED,wBAAgB,OAAO,CAAC,IAAI,EAAE,cAAc,GAAG,IAAI,QAElD;AAED,wBAAgB,MAAM,CAAC,GAAG,EAAE,MAAM,EAAE,KAAK,EAAE,MAAM,QAEhD;AAED,wBAAgB,SAAS,CAAC,EAAE,EAAE,CAAC,KAAK,EAAE,GAAG,KAAK,GAAG,OAQhD;AAED,wBAAgB,aAAa,CAAC,UAAU,EAAE;IACxC,QAAQ,CAAC,EAAE,MAAM,CAAC;IAClB,OAAO,CAAC,EAAE,MAAM,CAAC;IACjB,KAAK,CAAC,EAAE,OAAO,GAAG,OAAO,GAAG,SAAS,GAAG,MAAM,GAAG,OAAO,CAAC;IACzD,IAAI,CAAC,EAAE,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,CAAC;CAChC,QAKA"}
|
package/src/api.js
ADDED
|
@@ -0,0 +1,29 @@
|
|
|
1
|
+
import { getMonitoringAdapter } from "./init";
|
|
2
|
+
export function captureException(error, context) {
|
|
3
|
+
return getMonitoringAdapter().captureException(error, context);
|
|
4
|
+
}
|
|
5
|
+
export function captureMessage(message, level) {
|
|
6
|
+
return getMonitoringAdapter().captureMessage(message, level);
|
|
7
|
+
}
|
|
8
|
+
export function setUser(user) {
|
|
9
|
+
return getMonitoringAdapter().setUser(user);
|
|
10
|
+
}
|
|
11
|
+
export function setTag(key, value) {
|
|
12
|
+
return getMonitoringAdapter().setTag(key, value);
|
|
13
|
+
}
|
|
14
|
+
export function withScope(fn) {
|
|
15
|
+
const a = getMonitoringAdapter();
|
|
16
|
+
return a.withScope ? a.withScope(fn) : fn({
|
|
17
|
+
setTag: () => { },
|
|
18
|
+
setUser: () => { },
|
|
19
|
+
setExtra: () => { },
|
|
20
|
+
setContext: () => { },
|
|
21
|
+
});
|
|
22
|
+
}
|
|
23
|
+
export function addBreadcrumb(breadcrumb) {
|
|
24
|
+
const a = getMonitoringAdapter();
|
|
25
|
+
if (a.addBreadcrumb) {
|
|
26
|
+
a.addBreadcrumb(breadcrumb);
|
|
27
|
+
}
|
|
28
|
+
}
|
|
29
|
+
//# sourceMappingURL=api.js.map
|
package/src/api.js.map
ADDED
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"api.js","sourceRoot":"","sources":["api.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,oBAAoB,EAAE,MAAM,QAAQ,CAAC;AAE9C,MAAM,UAAU,gBAAgB,CAAC,KAAc,EAAE,OAAiC;IAChF,OAAO,oBAAoB,EAAE,CAAC,gBAAgB,CAAC,KAAK,EAAE,OAAO,CAAC,CAAC;AACjE,CAAC;AAED,MAAM,UAAU,cAAc,CAC5B,OAAe,EACf,KAAwD;IAExD,OAAO,oBAAoB,EAAE,CAAC,cAAc,CAAC,OAAO,EAAE,KAAK,CAAC,CAAC;AAC/D,CAAC;AAED,MAAM,UAAU,OAAO,CAAC,IAA2B;IACjD,OAAO,oBAAoB,EAAE,CAAC,OAAO,CAAC,IAAI,CAAC,CAAC;AAC9C,CAAC;AAED,MAAM,UAAU,MAAM,CAAC,GAAW,EAAE,KAAa;IAC/C,OAAO,oBAAoB,EAAE,CAAC,MAAM,CAAC,GAAG,EAAE,KAAK,CAAC,CAAC;AACnD,CAAC;AAED,MAAM,UAAU,SAAS,CAAC,EAAuB;IAC/C,MAAM,CAAC,GAAG,oBAAoB,EAAE,CAAC;IACjC,OAAO,CAAC,CAAC,SAAS,CAAC,CAAC,CAAC,CAAC,CAAC,SAAS,CAAC,EAAS,CAAC,CAAC,CAAC,CAAC,EAAE,CAAC;QAC/C,MAAM,EAAE,GAAG,EAAE,GAAE,CAAC;QAChB,OAAO,EAAE,GAAG,EAAE,GAAE,CAAC;QACjB,QAAQ,EAAE,GAAG,EAAE,GAAE,CAAC;QAClB,UAAU,EAAE,GAAG,EAAE,GAAE,CAAC;KACrB,CAAC,CAAC;AACL,CAAC;AAED,MAAM,UAAU,aAAa,CAAC,UAK7B;IACC,MAAM,CAAC,GAAG,oBAAoB,EAAE,CAAC;IACjC,IAAI,CAAC,CAAC,aAAa,EAAE,CAAC;QACpB,CAAC,CAAC,aAAa,CAAC,UAAU,CAAC,CAAC;IAC9B,CAAC;AACH,CAAC"}
|
package/src/api.ts
CHANGED
|
@@ -29,3 +29,15 @@ export function withScope(fn: (scope: any) => any) {
|
|
|
29
29
|
setContext: () => {},
|
|
30
30
|
});
|
|
31
31
|
}
|
|
32
|
+
|
|
33
|
+
export function addBreadcrumb(breadcrumb: {
|
|
34
|
+
category?: string;
|
|
35
|
+
message?: string;
|
|
36
|
+
level?: "fatal" | "error" | "warning" | "info" | "debug";
|
|
37
|
+
data?: Record<string, unknown>;
|
|
38
|
+
}) {
|
|
39
|
+
const a = getMonitoringAdapter();
|
|
40
|
+
if (a.addBreadcrumb) {
|
|
41
|
+
a.addBreadcrumb(breadcrumb);
|
|
42
|
+
}
|
|
43
|
+
}
|
package/src/index.d.ts
ADDED
|
@@ -0,0 +1,4 @@
|
|
|
1
|
+
export type { MonitoringInitOptions, MonitoringUser, MonitoringProvider, ScopeLike } from "./types";
|
|
2
|
+
export { initMonitoring } from "./init";
|
|
3
|
+
export { captureException, captureMessage, setUser, setTag, withScope, addBreadcrumb } from "./api";
|
|
4
|
+
//# sourceMappingURL=index.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["index.ts"],"names":[],"mappings":"AAAA,YAAY,EAAE,qBAAqB,EAAE,cAAc,EAAE,kBAAkB,EAAE,SAAS,EAAE,MAAM,SAAS,CAAC;AAEpG,OAAO,EAAE,cAAc,EAAE,MAAM,QAAQ,CAAC;AACxC,OAAO,EAAE,gBAAgB,EAAE,cAAc,EAAE,OAAO,EAAE,MAAM,EAAE,SAAS,EAAE,aAAa,EAAE,MAAM,OAAO,CAAC"}
|
package/src/index.js
ADDED
package/src/index.js.map
ADDED
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["index.ts"],"names":[],"mappings":"AAEA,OAAO,EAAE,cAAc,EAAE,MAAM,QAAQ,CAAC;AACxC,OAAO,EAAE,gBAAgB,EAAE,cAAc,EAAE,OAAO,EAAE,MAAM,EAAE,SAAS,EAAE,aAAa,EAAE,MAAM,OAAO,CAAC"}
|
package/src/index.ts
CHANGED
|
@@ -1,4 +1,4 @@
|
|
|
1
1
|
export type { MonitoringInitOptions, MonitoringUser, MonitoringProvider, ScopeLike } from "./types";
|
|
2
2
|
|
|
3
3
|
export { initMonitoring } from "./init";
|
|
4
|
-
export { captureException, captureMessage, setUser, setTag, withScope } from "./api";
|
|
4
|
+
export { captureException, captureMessage, setUser, setTag, withScope, addBreadcrumb } from "./api";
|
package/src/init.d.ts
ADDED
|
@@ -0,0 +1,5 @@
|
|
|
1
|
+
import type { MonitoringAdapter } from "./adapter";
|
|
2
|
+
import type { MonitoringInitOptions } from "./types";
|
|
3
|
+
export declare function getMonitoringAdapter(): MonitoringAdapter;
|
|
4
|
+
export declare function initMonitoring(options: MonitoringInitOptions): Promise<void>;
|
|
5
|
+
//# sourceMappingURL=init.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"init.d.ts","sourceRoot":"","sources":["init.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,iBAAiB,EAAE,MAAM,WAAW,CAAC;AACnD,OAAO,KAAK,EAAE,qBAAqB,EAAE,MAAM,SAAS,CAAC;AAQrD,wBAAgB,oBAAoB,IAAI,iBAAiB,CAExD;AAED,wBAAsB,cAAc,CAAC,OAAO,EAAE,qBAAqB,GAAG,OAAO,CAAC,IAAI,CAAC,CA2BlF"}
|
package/src/init.js
ADDED
|
@@ -0,0 +1,33 @@
|
|
|
1
|
+
import { NoopAdapter } from "./adapters/noop";
|
|
2
|
+
import { SentryAdapter } from "./adapters/sentry";
|
|
3
|
+
import { SentryNodeAdapter } from "./adapters/sentry-node";
|
|
4
|
+
let adapter = NoopAdapter;
|
|
5
|
+
let initialized = false;
|
|
6
|
+
export function getMonitoringAdapter() {
|
|
7
|
+
return adapter;
|
|
8
|
+
}
|
|
9
|
+
export async function initMonitoring(options) {
|
|
10
|
+
if (initialized)
|
|
11
|
+
return;
|
|
12
|
+
const enabled = options.enabled ?? true;
|
|
13
|
+
if (!enabled || options.provider === "noop") {
|
|
14
|
+
adapter = NoopAdapter;
|
|
15
|
+
initialized = true;
|
|
16
|
+
return;
|
|
17
|
+
}
|
|
18
|
+
if (options.provider === "sentry") {
|
|
19
|
+
adapter = SentryAdapter;
|
|
20
|
+
await adapter.init(options);
|
|
21
|
+
initialized = true;
|
|
22
|
+
return;
|
|
23
|
+
}
|
|
24
|
+
if (options.provider === "sentry-node") {
|
|
25
|
+
adapter = SentryNodeAdapter;
|
|
26
|
+
await adapter.init(options);
|
|
27
|
+
initialized = true;
|
|
28
|
+
return;
|
|
29
|
+
}
|
|
30
|
+
adapter = NoopAdapter;
|
|
31
|
+
initialized = true;
|
|
32
|
+
}
|
|
33
|
+
//# sourceMappingURL=init.js.map
|
package/src/init.js.map
ADDED
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"init.js","sourceRoot":"","sources":["init.ts"],"names":[],"mappings":"AAEA,OAAO,EAAE,WAAW,EAAE,MAAM,iBAAiB,CAAC;AAC9C,OAAO,EAAE,aAAa,EAAE,MAAM,mBAAmB,CAAC;AAClD,OAAO,EAAE,iBAAiB,EAAE,MAAM,wBAAwB,CAAC;AAE3D,IAAI,OAAO,GAAsB,WAAW,CAAC;AAC7C,IAAI,WAAW,GAAG,KAAK,CAAC;AAExB,MAAM,UAAU,oBAAoB;IAClC,OAAO,OAAO,CAAC;AACjB,CAAC;AAED,MAAM,CAAC,KAAK,UAAU,cAAc,CAAC,OAA8B;IACjE,IAAI,WAAW;QAAE,OAAO;IAExB,MAAM,OAAO,GAAG,OAAO,CAAC,OAAO,IAAI,IAAI,CAAC;IAExC,IAAI,CAAC,OAAO,IAAI,OAAO,CAAC,QAAQ,KAAK,MAAM,EAAE,CAAC;QAC5C,OAAO,GAAG,WAAW,CAAC;QACtB,WAAW,GAAG,IAAI,CAAC;QACnB,OAAO;IACT,CAAC;IAED,IAAI,OAAO,CAAC,QAAQ,KAAK,QAAQ,EAAE,CAAC;QAClC,OAAO,GAAG,aAAa,CAAC;QACxB,MAAM,OAAO,CAAC,IAAI,CAAC,OAAO,CAAC,CAAC;QAC5B,WAAW,GAAG,IAAI,CAAC;QACnB,OAAO;IACT,CAAC;IAED,IAAI,OAAO,CAAC,QAAQ,KAAK,aAAa,EAAE,CAAC;QACvC,OAAO,GAAG,iBAAiB,CAAC;QAC5B,MAAM,OAAO,CAAC,IAAI,CAAC,OAAO,CAAC,CAAC;QAC5B,WAAW,GAAG,IAAI,CAAC;QACnB,OAAO;IACT,CAAC;IAED,OAAO,GAAG,WAAW,CAAC;IACtB,WAAW,GAAG,IAAI,CAAC;AACrB,CAAC"}
|
package/src/init.ts
CHANGED
|
@@ -2,6 +2,7 @@ import type { MonitoringAdapter } from "./adapter";
|
|
|
2
2
|
import type { MonitoringInitOptions } from "./types";
|
|
3
3
|
import { NoopAdapter } from "./adapters/noop";
|
|
4
4
|
import { SentryAdapter } from "./adapters/sentry";
|
|
5
|
+
import { SentryNodeAdapter } from "./adapters/sentry-node";
|
|
5
6
|
|
|
6
7
|
let adapter: MonitoringAdapter = NoopAdapter;
|
|
7
8
|
let initialized = false;
|
|
@@ -28,6 +29,13 @@ export async function initMonitoring(options: MonitoringInitOptions): Promise<vo
|
|
|
28
29
|
return;
|
|
29
30
|
}
|
|
30
31
|
|
|
32
|
+
if (options.provider === "sentry-node") {
|
|
33
|
+
adapter = SentryNodeAdapter;
|
|
34
|
+
await adapter.init(options);
|
|
35
|
+
initialized = true;
|
|
36
|
+
return;
|
|
37
|
+
}
|
|
38
|
+
|
|
31
39
|
adapter = NoopAdapter;
|
|
32
40
|
initialized = true;
|
|
33
|
-
}
|
|
41
|
+
}
|
package/src/types.d.ts
ADDED
|
@@ -0,0 +1,21 @@
|
|
|
1
|
+
export type MonitoringProvider = "sentry" | "sentry-node" | "noop";
|
|
2
|
+
export type MonitoringInitOptions = {
|
|
3
|
+
provider: MonitoringProvider;
|
|
4
|
+
dsn?: string;
|
|
5
|
+
environment?: string;
|
|
6
|
+
enabled?: boolean;
|
|
7
|
+
release?: string;
|
|
8
|
+
};
|
|
9
|
+
export type MonitoringUser = {
|
|
10
|
+
id?: string;
|
|
11
|
+
email?: string;
|
|
12
|
+
username?: string;
|
|
13
|
+
ip_address?: string;
|
|
14
|
+
};
|
|
15
|
+
export type ScopeLike = {
|
|
16
|
+
setTag: (key: string, value: string) => void;
|
|
17
|
+
setUser: (user: MonitoringUser | null) => void;
|
|
18
|
+
setExtra: (key: string, value: unknown) => void;
|
|
19
|
+
setContext: (key: string, context: Record<string, unknown>) => void;
|
|
20
|
+
};
|
|
21
|
+
//# sourceMappingURL=types.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"types.d.ts","sourceRoot":"","sources":["types.ts"],"names":[],"mappings":"AAAA,MAAM,MAAM,kBAAkB,GAAG,QAAQ,GAAG,aAAa,GAAG,MAAM,CAAC;AAEnE,MAAM,MAAM,qBAAqB,GAAG;IAClC,QAAQ,EAAE,kBAAkB,CAAC;IAC7B,GAAG,CAAC,EAAE,MAAM,CAAC;IACb,WAAW,CAAC,EAAE,MAAM,CAAC;IACrB,OAAO,CAAC,EAAE,OAAO,CAAC;IAClB,OAAO,CAAC,EAAE,MAAM,CAAC;CAClB,CAAC;AAEF,MAAM,MAAM,cAAc,GAAG;IAC3B,EAAE,CAAC,EAAE,MAAM,CAAC;IACZ,KAAK,CAAC,EAAE,MAAM,CAAC;IACf,QAAQ,CAAC,EAAE,MAAM,CAAC;IAClB,UAAU,CAAC,EAAE,MAAM,CAAC;CACrB,CAAC;AAEF,MAAM,MAAM,SAAS,GAAG;IACtB,MAAM,EAAE,CAAC,GAAG,EAAE,MAAM,EAAE,KAAK,EAAE,MAAM,KAAK,IAAI,CAAC;IAC7C,OAAO,EAAE,CAAC,IAAI,EAAE,cAAc,GAAG,IAAI,KAAK,IAAI,CAAC;IAC/C,QAAQ,EAAE,CAAC,GAAG,EAAE,MAAM,EAAE,KAAK,EAAE,OAAO,KAAK,IAAI,CAAC;IAChD,UAAU,EAAE,CAAC,GAAG,EAAE,MAAM,EAAE,OAAO,EAAE,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,KAAK,IAAI,CAAC;CACrE,CAAC"}
|
package/src/types.js
ADDED
package/src/types.js.map
ADDED
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"types.js","sourceRoot":"","sources":["types.ts"],"names":[],"mappings":""}
|
package/src/types.ts
CHANGED
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
export type MonitoringProvider = "sentry" | "noop";
|
|
1
|
+
export type MonitoringProvider = "sentry" | "sentry-node" | "noop";
|
|
2
2
|
|
|
3
3
|
export type MonitoringInitOptions = {
|
|
4
4
|
provider: MonitoringProvider;
|
|
@@ -20,4 +20,4 @@ export type ScopeLike = {
|
|
|
20
20
|
setUser: (user: MonitoringUser | null) => void;
|
|
21
21
|
setExtra: (key: string, value: unknown) => void;
|
|
22
22
|
setContext: (key: string, context: Record<string, unknown>) => void;
|
|
23
|
-
};
|
|
23
|
+
};
|
package/tsconfig.json
CHANGED
|
@@ -1,11 +1,18 @@
|
|
|
1
1
|
{
|
|
2
|
-
|
|
3
|
-
"
|
|
4
|
-
|
|
5
|
-
|
|
6
|
-
|
|
7
|
-
|
|
8
|
-
|
|
9
|
-
"
|
|
10
|
-
|
|
11
|
-
|
|
2
|
+
"compilerOptions": {
|
|
3
|
+
"target": "ES2020",
|
|
4
|
+
"module": "ESNext",
|
|
5
|
+
"moduleResolution": "bundler",
|
|
6
|
+
"declaration": true,
|
|
7
|
+
"declarationMap": true,
|
|
8
|
+
"sourceMap": true,
|
|
9
|
+
"outDir": "dist",
|
|
10
|
+
"rootDir": "src",
|
|
11
|
+
"strict": true,
|
|
12
|
+
"esModuleInterop": true,
|
|
13
|
+
"skipLibCheck": true,
|
|
14
|
+
"forceConsistentCasingInFileNames": true
|
|
15
|
+
},
|
|
16
|
+
"include": ["src"],
|
|
17
|
+
"exclude": ["node_modules", "dist"]
|
|
18
|
+
}
|