@cloudflare/vite-plugin 0.0.0-229d00fce
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/README.md +484 -0
- package/dist/asset-workers/asset-worker.js +2610 -0
- package/dist/asset-workers/router-worker.js +2311 -0
- package/dist/index.d.ts +31 -0
- package/dist/index.js +2403 -0
- package/dist/runner-worker/index.js +1679 -0
- package/package.json +70 -0
|
@@ -0,0 +1,2610 @@
|
|
|
1
|
+
// ../workers-shared/dist/asset-worker.mjs
|
|
2
|
+
import { WorkerEntrypoint as Fs } from "cloudflare:workers";
|
|
3
|
+
var sr = Object.defineProperty;
|
|
4
|
+
var ir = (t, e, n) => e in t ? sr(t, e, { enumerable: true, configurable: true, writable: true, value: n }) : t[e] = n;
|
|
5
|
+
var he = (t, e, n) => (ir(t, typeof e != "symbol" ? e + "" : e, n), n);
|
|
6
|
+
var Bt = (t, e, n) => {
|
|
7
|
+
if (!e.has(t)) throw TypeError("Cannot " + n);
|
|
8
|
+
};
|
|
9
|
+
var Qe = (t, e, n) => (Bt(t, e, "read from private field"), n ? n.call(t) : e.get(t));
|
|
10
|
+
var Ft = (t, e, n) => {
|
|
11
|
+
if (e.has(t)) throw TypeError("Cannot add the same private member more than once");
|
|
12
|
+
e instanceof WeakSet ? e.add(t) : e.set(t, n);
|
|
13
|
+
};
|
|
14
|
+
var $t = (t, e, n, r) => (Bt(t, e, "write to private field"), r ? r.call(t, n) : e.set(t, n), n);
|
|
15
|
+
var _e = class {
|
|
16
|
+
constructor(e) {
|
|
17
|
+
this.performanceTimer = e;
|
|
18
|
+
}
|
|
19
|
+
now() {
|
|
20
|
+
return this.performanceTimer ? this.performanceTimer.timeOrigin + this.performanceTimer.now() : Date.now();
|
|
21
|
+
}
|
|
22
|
+
};
|
|
23
|
+
var Gt = Object.prototype.toString;
|
|
24
|
+
function L(t) {
|
|
25
|
+
switch (Gt.call(t)) {
|
|
26
|
+
case "[object Error]":
|
|
27
|
+
case "[object Exception]":
|
|
28
|
+
case "[object DOMException]":
|
|
29
|
+
return true;
|
|
30
|
+
default:
|
|
31
|
+
return v(t, Error);
|
|
32
|
+
}
|
|
33
|
+
}
|
|
34
|
+
function Ht(t, e) {
|
|
35
|
+
return Gt.call(t) === `[object ${e}]`;
|
|
36
|
+
}
|
|
37
|
+
function q(t) {
|
|
38
|
+
return Ht(t, "String");
|
|
39
|
+
}
|
|
40
|
+
function ge(t) {
|
|
41
|
+
return t === null || typeof t != "object" && typeof t != "function";
|
|
42
|
+
}
|
|
43
|
+
function x(t) {
|
|
44
|
+
return Ht(t, "Object");
|
|
45
|
+
}
|
|
46
|
+
function et(t) {
|
|
47
|
+
return typeof Event < "u" && v(t, Event);
|
|
48
|
+
}
|
|
49
|
+
function tt(t) {
|
|
50
|
+
return typeof Element < "u" && v(t, Element);
|
|
51
|
+
}
|
|
52
|
+
function B(t) {
|
|
53
|
+
return !!(t && t.then && typeof t.then == "function");
|
|
54
|
+
}
|
|
55
|
+
function nt(t) {
|
|
56
|
+
return x(t) && "nativeEvent" in t && "preventDefault" in t && "stopPropagation" in t;
|
|
57
|
+
}
|
|
58
|
+
function ee(t) {
|
|
59
|
+
return typeof t == "number" && t !== t;
|
|
60
|
+
}
|
|
61
|
+
function v(t, e) {
|
|
62
|
+
try {
|
|
63
|
+
return t instanceof e;
|
|
64
|
+
} catch {
|
|
65
|
+
return false;
|
|
66
|
+
}
|
|
67
|
+
}
|
|
68
|
+
function rt(t) {
|
|
69
|
+
return !!(typeof t == "object" && t !== null && (t.__isVue || t._isVue));
|
|
70
|
+
}
|
|
71
|
+
function P(t, e = 0) {
|
|
72
|
+
return typeof t != "string" || e === 0 || t.length <= e ? t : `${t.slice(0, e)}...`;
|
|
73
|
+
}
|
|
74
|
+
function Ee(t) {
|
|
75
|
+
return t && t.Math == Math ? t : void 0;
|
|
76
|
+
}
|
|
77
|
+
var h = typeof globalThis == "object" && Ee(globalThis) || typeof window == "object" && Ee(window) || typeof self == "object" && Ee(self) || typeof global == "object" && Ee(global) || /* @__PURE__ */ function() {
|
|
78
|
+
return this;
|
|
79
|
+
}() || {};
|
|
80
|
+
function N() {
|
|
81
|
+
return h;
|
|
82
|
+
}
|
|
83
|
+
function te(t, e, n) {
|
|
84
|
+
let r = n || h, s = r.__SENTRY__ = r.__SENTRY__ || {};
|
|
85
|
+
return s[t] || (s[t] = e());
|
|
86
|
+
}
|
|
87
|
+
var zs = N();
|
|
88
|
+
var or = 80;
|
|
89
|
+
function Yt(t, e = {}) {
|
|
90
|
+
if (!t) return "<unknown>";
|
|
91
|
+
try {
|
|
92
|
+
let n = t, r = 5, s = [], i = 0, o = 0, a = " > ", c = a.length, u, l = Array.isArray(e) ? e : e.keyAttrs, d = !Array.isArray(e) && e.maxStringLength || or;
|
|
93
|
+
for (; n && i++ < r && (u = ar(n, l), !(u === "html" || i > 1 && o + s.length * c + u.length >= d)); ) s.push(u), o += u.length, n = n.parentNode;
|
|
94
|
+
return s.reverse().join(a);
|
|
95
|
+
} catch {
|
|
96
|
+
return "<unknown>";
|
|
97
|
+
}
|
|
98
|
+
}
|
|
99
|
+
function ar(t, e) {
|
|
100
|
+
let n = t, r = [], s, i, o, a, c;
|
|
101
|
+
if (!n || !n.tagName) return "";
|
|
102
|
+
r.push(n.tagName.toLowerCase());
|
|
103
|
+
let u = e && e.length ? e.filter((d) => n.getAttribute(d)).map((d) => [d, n.getAttribute(d)]) : null;
|
|
104
|
+
if (u && u.length) u.forEach((d) => {
|
|
105
|
+
r.push(`[${d[0]}="${d[1]}"]`);
|
|
106
|
+
});
|
|
107
|
+
else if (n.id && r.push(`#${n.id}`), s = n.className, s && q(s)) for (i = s.split(/\s+/), c = 0; c < i.length; c++) r.push(`.${i[c]}`);
|
|
108
|
+
let l = ["aria-label", "type", "name", "title", "alt"];
|
|
109
|
+
for (c = 0; c < l.length; c++) o = l[c], a = n.getAttribute(o), a && r.push(`[${o}="${a}"]`);
|
|
110
|
+
return r.join("");
|
|
111
|
+
}
|
|
112
|
+
var cr = "Sentry Logger ";
|
|
113
|
+
var ne = ["debug", "info", "warn", "error", "log", "assert", "trace"];
|
|
114
|
+
var W = {};
|
|
115
|
+
function ye(t) {
|
|
116
|
+
if (!("console" in h)) return t();
|
|
117
|
+
let e = h.console, n = {}, r = Object.keys(W);
|
|
118
|
+
r.forEach((s) => {
|
|
119
|
+
let i = W[s];
|
|
120
|
+
n[s] = e[s], e[s] = i;
|
|
121
|
+
});
|
|
122
|
+
try {
|
|
123
|
+
return t();
|
|
124
|
+
} finally {
|
|
125
|
+
r.forEach((s) => {
|
|
126
|
+
e[s] = n[s];
|
|
127
|
+
});
|
|
128
|
+
}
|
|
129
|
+
}
|
|
130
|
+
function ur() {
|
|
131
|
+
let t = false, e = { enable: () => {
|
|
132
|
+
t = true;
|
|
133
|
+
}, disable: () => {
|
|
134
|
+
t = false;
|
|
135
|
+
}, isEnabled: () => t };
|
|
136
|
+
return typeof __SENTRY_DEBUG__ > "u" || __SENTRY_DEBUG__ ? ne.forEach((n) => {
|
|
137
|
+
e[n] = (...r) => {
|
|
138
|
+
t && ye(() => {
|
|
139
|
+
h.console[n](`${cr}[${n}]:`, ...r);
|
|
140
|
+
});
|
|
141
|
+
};
|
|
142
|
+
}) : ne.forEach((n) => {
|
|
143
|
+
e[n] = () => {
|
|
144
|
+
};
|
|
145
|
+
}), e;
|
|
146
|
+
}
|
|
147
|
+
var f = ur();
|
|
148
|
+
var dr = /^(?:(\w+):)\/\/(?:(\w+)(?::(\w+)?)?@)([\w.-]+)(?::(\d+))?\/(.+)/;
|
|
149
|
+
function lr(t) {
|
|
150
|
+
return t === "http" || t === "https";
|
|
151
|
+
}
|
|
152
|
+
function M(t, e = false) {
|
|
153
|
+
let { host: n, path: r, pass: s, port: i, projectId: o, protocol: a, publicKey: c } = t;
|
|
154
|
+
return `${a}://${c}${e && s ? `:${s}` : ""}@${n}${i ? `:${i}` : ""}/${r && `${r}/`}${o}`;
|
|
155
|
+
}
|
|
156
|
+
function jt(t) {
|
|
157
|
+
let e = dr.exec(t);
|
|
158
|
+
if (!e) {
|
|
159
|
+
console.error(`Invalid Sentry Dsn: ${t}`);
|
|
160
|
+
return;
|
|
161
|
+
}
|
|
162
|
+
let [n, r, s = "", i, o = "", a] = e.slice(1), c = "", u = a, l = u.split("/");
|
|
163
|
+
if (l.length > 1 && (c = l.slice(0, -1).join("/"), u = l.pop()), u) {
|
|
164
|
+
let d = u.match(/^\d+/);
|
|
165
|
+
d && (u = d[0]);
|
|
166
|
+
}
|
|
167
|
+
return qt({ host: i, pass: s, path: c, projectId: u, port: o, protocol: n, publicKey: r });
|
|
168
|
+
}
|
|
169
|
+
function qt(t) {
|
|
170
|
+
return { protocol: t.protocol, publicKey: t.publicKey || "", pass: t.pass || "", host: t.host, port: t.port || "", path: t.path || "", projectId: t.projectId };
|
|
171
|
+
}
|
|
172
|
+
function fr(t) {
|
|
173
|
+
if (!(typeof __SENTRY_DEBUG__ > "u" || __SENTRY_DEBUG__)) return true;
|
|
174
|
+
let { port: e, projectId: n, protocol: r } = t;
|
|
175
|
+
return ["protocol", "publicKey", "host", "projectId"].find((o) => t[o] ? false : (f.error(`Invalid Sentry Dsn: ${o} missing`), true)) ? false : n.match(/^\d+$/) ? lr(r) ? e && isNaN(parseInt(e, 10)) ? (f.error(`Invalid Sentry Dsn: Invalid port ${e}`), false) : true : (f.error(`Invalid Sentry Dsn: Invalid protocol ${r}`), false) : (f.error(`Invalid Sentry Dsn: Invalid projectId ${n}`), false);
|
|
176
|
+
}
|
|
177
|
+
function Se(t) {
|
|
178
|
+
let e = typeof t == "string" ? jt(t) : qt(t);
|
|
179
|
+
if (!(!e || !fr(e))) return e;
|
|
180
|
+
}
|
|
181
|
+
var T = class extends Error {
|
|
182
|
+
constructor(e, n = "warn") {
|
|
183
|
+
super(e), this.message = e, this.name = new.target.prototype.constructor.name, Object.setPrototypeOf(this, new.target.prototype), this.logLevel = n;
|
|
184
|
+
}
|
|
185
|
+
};
|
|
186
|
+
function I(t, e, n) {
|
|
187
|
+
if (!(e in t)) return;
|
|
188
|
+
let r = t[e], s = n(r);
|
|
189
|
+
typeof s == "function" && Vt(s, r), t[e] = s;
|
|
190
|
+
}
|
|
191
|
+
function z(t, e, n) {
|
|
192
|
+
try {
|
|
193
|
+
Object.defineProperty(t, e, { value: n, writable: true, configurable: true });
|
|
194
|
+
} catch {
|
|
195
|
+
(typeof __SENTRY_DEBUG__ > "u" || __SENTRY_DEBUG__) && f.log(`Failed to add non-enumerable property "${e}" to object`, t);
|
|
196
|
+
}
|
|
197
|
+
}
|
|
198
|
+
function Vt(t, e) {
|
|
199
|
+
try {
|
|
200
|
+
let n = e.prototype || {};
|
|
201
|
+
t.prototype = e.prototype = n, z(t, "__sentry_original__", e);
|
|
202
|
+
} catch {
|
|
203
|
+
}
|
|
204
|
+
}
|
|
205
|
+
function it(t) {
|
|
206
|
+
return Object.keys(t).map((e) => `${encodeURIComponent(e)}=${encodeURIComponent(t[e])}`).join("&");
|
|
207
|
+
}
|
|
208
|
+
function Te(t) {
|
|
209
|
+
if (L(t)) return { message: t.message, name: t.name, stack: t.stack, ...zt(t) };
|
|
210
|
+
if (et(t)) {
|
|
211
|
+
let e = { type: t.type, target: Wt(t.target), currentTarget: Wt(t.currentTarget), ...zt(t) };
|
|
212
|
+
return typeof CustomEvent < "u" && v(t, CustomEvent) && (e.detail = t.detail), e;
|
|
213
|
+
} else return t;
|
|
214
|
+
}
|
|
215
|
+
function Wt(t) {
|
|
216
|
+
try {
|
|
217
|
+
return tt(t) ? Yt(t) : Object.prototype.toString.call(t);
|
|
218
|
+
} catch {
|
|
219
|
+
return "<unknown>";
|
|
220
|
+
}
|
|
221
|
+
}
|
|
222
|
+
function zt(t) {
|
|
223
|
+
if (typeof t == "object" && t !== null) {
|
|
224
|
+
let e = {};
|
|
225
|
+
for (let n in t) Object.prototype.hasOwnProperty.call(t, n) && (e[n] = t[n]);
|
|
226
|
+
return e;
|
|
227
|
+
} else return {};
|
|
228
|
+
}
|
|
229
|
+
function re(t, e = 40) {
|
|
230
|
+
let n = Object.keys(Te(t));
|
|
231
|
+
if (n.sort(), !n.length) return "[object has no keys]";
|
|
232
|
+
if (n[0].length >= e) return P(n[0], e);
|
|
233
|
+
for (let r = n.length; r > 0; r--) {
|
|
234
|
+
let s = n.slice(0, r).join(", ");
|
|
235
|
+
if (!(s.length > e)) return r === n.length ? s : P(s, e);
|
|
236
|
+
}
|
|
237
|
+
return "";
|
|
238
|
+
}
|
|
239
|
+
function E(t) {
|
|
240
|
+
return st(t, /* @__PURE__ */ new Map());
|
|
241
|
+
}
|
|
242
|
+
function st(t, e) {
|
|
243
|
+
if (x(t)) {
|
|
244
|
+
let n = e.get(t);
|
|
245
|
+
if (n !== void 0) return n;
|
|
246
|
+
let r = {};
|
|
247
|
+
e.set(t, r);
|
|
248
|
+
for (let s of Object.keys(t)) typeof t[s] < "u" && (r[s] = st(t[s], e));
|
|
249
|
+
return r;
|
|
250
|
+
}
|
|
251
|
+
if (Array.isArray(t)) {
|
|
252
|
+
let n = e.get(t);
|
|
253
|
+
if (n !== void 0) return n;
|
|
254
|
+
let r = [];
|
|
255
|
+
return e.set(t, r), t.forEach((s) => {
|
|
256
|
+
r.push(st(s, e));
|
|
257
|
+
}), r;
|
|
258
|
+
}
|
|
259
|
+
return t;
|
|
260
|
+
}
|
|
261
|
+
function pr(t, e = false) {
|
|
262
|
+
return !(e || t && !t.startsWith("/") && !t.includes(":\\") && !t.startsWith(".") && !t.match(/^[a-zA-Z]([a-zA-Z0-9.\-+])*:\/\//)) && t !== void 0 && !t.includes("node_modules/");
|
|
263
|
+
}
|
|
264
|
+
function Jt(t) {
|
|
265
|
+
let e = /^\s*[-]{4,}$/, n = /at (?:async )?(?:(.+?)\s+\()?(?:(.+):(\d+):(\d+)?|([^)]+))\)?/;
|
|
266
|
+
return (r) => {
|
|
267
|
+
let s = r.match(n);
|
|
268
|
+
if (s) {
|
|
269
|
+
let i, o, a, c, u;
|
|
270
|
+
if (s[1]) {
|
|
271
|
+
a = s[1];
|
|
272
|
+
let p = a.lastIndexOf(".");
|
|
273
|
+
if (a[p - 1] === "." && p--, p > 0) {
|
|
274
|
+
i = a.slice(0, p), o = a.slice(p + 1);
|
|
275
|
+
let m = i.indexOf(".Module");
|
|
276
|
+
m > 0 && (a = a.slice(m + 1), i = i.slice(0, m));
|
|
277
|
+
}
|
|
278
|
+
c = void 0;
|
|
279
|
+
}
|
|
280
|
+
o && (c = i, u = o), o === "<anonymous>" && (u = void 0, a = void 0), a === void 0 && (u = u || "<anonymous>", a = c ? `${c}.${u}` : u);
|
|
281
|
+
let l = s[2] && s[2].startsWith("file://") ? s[2].slice(7) : s[2], d = s[5] === "native";
|
|
282
|
+
return !l && s[5] && !d && (l = s[5]), { filename: l, module: t ? t(l) : void 0, function: a, lineno: parseInt(s[3], 10) || void 0, colno: parseInt(s[4], 10) || void 0, in_app: pr(l, d) };
|
|
283
|
+
}
|
|
284
|
+
if (r.match(e)) return { filename: r };
|
|
285
|
+
};
|
|
286
|
+
}
|
|
287
|
+
var Zt = 50;
|
|
288
|
+
var Kt = /\(error: (.*)\)/;
|
|
289
|
+
var Xt = /captureMessage|captureException/;
|
|
290
|
+
function be(...t) {
|
|
291
|
+
let e = t.sort((n, r) => n[0] - r[0]).map((n) => n[1]);
|
|
292
|
+
return (n, r = 0) => {
|
|
293
|
+
let s = [], i = n.split(`
|
|
294
|
+
`);
|
|
295
|
+
for (let o = r; o < i.length; o++) {
|
|
296
|
+
let a = i[o];
|
|
297
|
+
if (a.length > 1024) continue;
|
|
298
|
+
let c = Kt.test(a) ? a.replace(Kt, "$1") : a;
|
|
299
|
+
if (!c.match(/\S*Error: /)) {
|
|
300
|
+
for (let u of e) {
|
|
301
|
+
let l = u(c);
|
|
302
|
+
if (l) {
|
|
303
|
+
s.push(l);
|
|
304
|
+
break;
|
|
305
|
+
}
|
|
306
|
+
}
|
|
307
|
+
if (s.length >= Zt) break;
|
|
308
|
+
}
|
|
309
|
+
}
|
|
310
|
+
return Qt(s);
|
|
311
|
+
};
|
|
312
|
+
}
|
|
313
|
+
function at(t) {
|
|
314
|
+
return Array.isArray(t) ? be(...t) : t;
|
|
315
|
+
}
|
|
316
|
+
function Qt(t) {
|
|
317
|
+
if (!t.length) return [];
|
|
318
|
+
let e = Array.from(t);
|
|
319
|
+
return /sentryWrapped/.test(e[e.length - 1].function || "") && e.pop(), e.reverse(), Xt.test(e[e.length - 1].function || "") && (e.pop(), Xt.test(e[e.length - 1].function || "") && e.pop()), e.slice(0, Zt).map((n) => ({ ...n, filename: n.filename || e[e.length - 1].filename, function: n.function || "?" }));
|
|
320
|
+
}
|
|
321
|
+
var ot = "<anonymous>";
|
|
322
|
+
function se(t) {
|
|
323
|
+
try {
|
|
324
|
+
return !t || typeof t != "function" ? ot : t.name || ot;
|
|
325
|
+
} catch {
|
|
326
|
+
return ot;
|
|
327
|
+
}
|
|
328
|
+
}
|
|
329
|
+
function ct(t) {
|
|
330
|
+
return [90, Jt(t)];
|
|
331
|
+
}
|
|
332
|
+
var ut = N();
|
|
333
|
+
function mr() {
|
|
334
|
+
if (!("fetch" in ut)) return false;
|
|
335
|
+
try {
|
|
336
|
+
return new Headers(), new Request("http://www.example.com"), new Response(), true;
|
|
337
|
+
} catch {
|
|
338
|
+
return false;
|
|
339
|
+
}
|
|
340
|
+
}
|
|
341
|
+
function en(t) {
|
|
342
|
+
return t && /^function fetch\(\)\s+\{\s+\[native code\]\s+\}$/.test(t.toString());
|
|
343
|
+
}
|
|
344
|
+
function tn() {
|
|
345
|
+
if (!mr()) return false;
|
|
346
|
+
if (en(ut.fetch)) return true;
|
|
347
|
+
let t = false, e = ut.document;
|
|
348
|
+
if (e && typeof e.createElement == "function") try {
|
|
349
|
+
let n = e.createElement("iframe");
|
|
350
|
+
n.hidden = true, e.head.appendChild(n), n.contentWindow && n.contentWindow.fetch && (t = en(n.contentWindow.fetch)), e.head.removeChild(n);
|
|
351
|
+
} catch (n) {
|
|
352
|
+
(typeof __SENTRY_DEBUG__ > "u" || __SENTRY_DEBUG__) && f.warn("Could not create sandbox iframe for pure fetch check, bailing to window.fetch: ", n);
|
|
353
|
+
}
|
|
354
|
+
return t;
|
|
355
|
+
}
|
|
356
|
+
var Re = N();
|
|
357
|
+
function nn() {
|
|
358
|
+
let t = Re.chrome, e = t && t.app && t.app.runtime, n = "history" in Re && !!Re.history.pushState && !!Re.history.replaceState;
|
|
359
|
+
return !e && n;
|
|
360
|
+
}
|
|
361
|
+
var y = N();
|
|
362
|
+
var ie = "__sentry_xhr_v2__";
|
|
363
|
+
var oe = {};
|
|
364
|
+
var rn = {};
|
|
365
|
+
function hr(t) {
|
|
366
|
+
if (!rn[t]) switch (rn[t] = true, t) {
|
|
367
|
+
case "console":
|
|
368
|
+
_r();
|
|
369
|
+
break;
|
|
370
|
+
case "dom":
|
|
371
|
+
dn();
|
|
372
|
+
break;
|
|
373
|
+
case "xhr":
|
|
374
|
+
un();
|
|
375
|
+
break;
|
|
376
|
+
case "fetch":
|
|
377
|
+
gr();
|
|
378
|
+
break;
|
|
379
|
+
case "history":
|
|
380
|
+
Er();
|
|
381
|
+
break;
|
|
382
|
+
case "error":
|
|
383
|
+
br();
|
|
384
|
+
break;
|
|
385
|
+
case "unhandledrejection":
|
|
386
|
+
Rr();
|
|
387
|
+
break;
|
|
388
|
+
default:
|
|
389
|
+
(typeof __SENTRY_DEBUG__ > "u" || __SENTRY_DEBUG__) && f.warn("unknown instrumentation type:", t);
|
|
390
|
+
return;
|
|
391
|
+
}
|
|
392
|
+
}
|
|
393
|
+
function De(t, e) {
|
|
394
|
+
oe[t] = oe[t] || [], oe[t].push(e), hr(t);
|
|
395
|
+
}
|
|
396
|
+
function A(t, e) {
|
|
397
|
+
if (!(!t || !oe[t])) for (let n of oe[t] || []) try {
|
|
398
|
+
n(e);
|
|
399
|
+
} catch (r) {
|
|
400
|
+
(typeof __SENTRY_DEBUG__ > "u" || __SENTRY_DEBUG__) && f.error(`Error while triggering instrumentation handler.
|
|
401
|
+
Type: ${t}
|
|
402
|
+
Name: ${se(n)}
|
|
403
|
+
Error:`, r);
|
|
404
|
+
}
|
|
405
|
+
}
|
|
406
|
+
function _r() {
|
|
407
|
+
"console" in h && ne.forEach(function(t) {
|
|
408
|
+
t in h.console && I(h.console, t, function(e) {
|
|
409
|
+
return W[t] = e, function(...n) {
|
|
410
|
+
A("console", { args: n, level: t });
|
|
411
|
+
let r = W[t];
|
|
412
|
+
r && r.apply(h.console, n);
|
|
413
|
+
};
|
|
414
|
+
});
|
|
415
|
+
});
|
|
416
|
+
}
|
|
417
|
+
function gr() {
|
|
418
|
+
tn() && I(h, "fetch", function(t) {
|
|
419
|
+
return function(...e) {
|
|
420
|
+
let { method: n, url: r } = cn(e), s = { args: e, fetchData: { method: n, url: r }, startTimestamp: Date.now() };
|
|
421
|
+
return A("fetch", { ...s }), t.apply(h, e).then((i) => (A("fetch", { ...s, endTimestamp: Date.now(), response: i }), i), (i) => {
|
|
422
|
+
throw A("fetch", { ...s, endTimestamp: Date.now(), error: i }), i;
|
|
423
|
+
});
|
|
424
|
+
};
|
|
425
|
+
});
|
|
426
|
+
}
|
|
427
|
+
function dt(t, e) {
|
|
428
|
+
return !!t && typeof t == "object" && !!t[e];
|
|
429
|
+
}
|
|
430
|
+
function sn(t) {
|
|
431
|
+
return typeof t == "string" ? t : t ? dt(t, "url") ? t.url : t.toString ? t.toString() : "" : "";
|
|
432
|
+
}
|
|
433
|
+
function cn(t) {
|
|
434
|
+
if (t.length === 0) return { method: "GET", url: "" };
|
|
435
|
+
if (t.length === 2) {
|
|
436
|
+
let [n, r] = t;
|
|
437
|
+
return { url: sn(n), method: dt(r, "method") ? String(r.method).toUpperCase() : "GET" };
|
|
438
|
+
}
|
|
439
|
+
let e = t[0];
|
|
440
|
+
return { url: sn(e), method: dt(e, "method") ? String(e.method).toUpperCase() : "GET" };
|
|
441
|
+
}
|
|
442
|
+
function un() {
|
|
443
|
+
if (!y.XMLHttpRequest) return;
|
|
444
|
+
let t = XMLHttpRequest.prototype;
|
|
445
|
+
I(t, "open", function(e) {
|
|
446
|
+
return function(...n) {
|
|
447
|
+
let r = Date.now(), s = n[1], i = this[ie] = { method: q(n[0]) ? n[0].toUpperCase() : n[0], url: n[1], request_headers: {} };
|
|
448
|
+
q(s) && i.method === "POST" && s.match(/sentry_key/) && (this.__sentry_own_request__ = true);
|
|
449
|
+
let o = () => {
|
|
450
|
+
let a = this[ie];
|
|
451
|
+
if (a && this.readyState === 4) {
|
|
452
|
+
try {
|
|
453
|
+
a.status_code = this.status;
|
|
454
|
+
} catch {
|
|
455
|
+
}
|
|
456
|
+
A("xhr", { args: n, endTimestamp: Date.now(), startTimestamp: r, xhr: this });
|
|
457
|
+
}
|
|
458
|
+
};
|
|
459
|
+
return "onreadystatechange" in this && typeof this.onreadystatechange == "function" ? I(this, "onreadystatechange", function(a) {
|
|
460
|
+
return function(...c) {
|
|
461
|
+
return o(), a.apply(this, c);
|
|
462
|
+
};
|
|
463
|
+
}) : this.addEventListener("readystatechange", o), I(this, "setRequestHeader", function(a) {
|
|
464
|
+
return function(...c) {
|
|
465
|
+
let [u, l] = c, d = this[ie];
|
|
466
|
+
return d && (d.request_headers[u.toLowerCase()] = l), a.apply(this, c);
|
|
467
|
+
};
|
|
468
|
+
}), e.apply(this, n);
|
|
469
|
+
};
|
|
470
|
+
}), I(t, "send", function(e) {
|
|
471
|
+
return function(...n) {
|
|
472
|
+
let r = this[ie];
|
|
473
|
+
return r && n[0] !== void 0 && (r.body = n[0]), A("xhr", { args: n, startTimestamp: Date.now(), xhr: this }), e.apply(this, n);
|
|
474
|
+
};
|
|
475
|
+
});
|
|
476
|
+
}
|
|
477
|
+
var xe;
|
|
478
|
+
function Er() {
|
|
479
|
+
if (!nn()) return;
|
|
480
|
+
let t = y.onpopstate;
|
|
481
|
+
y.onpopstate = function(...n) {
|
|
482
|
+
let r = y.location.href, s = xe;
|
|
483
|
+
if (xe = r, A("history", { from: s, to: r }), t) try {
|
|
484
|
+
return t.apply(this, n);
|
|
485
|
+
} catch {
|
|
486
|
+
}
|
|
487
|
+
};
|
|
488
|
+
function e(n) {
|
|
489
|
+
return function(...r) {
|
|
490
|
+
let s = r.length > 2 ? r[2] : void 0;
|
|
491
|
+
if (s) {
|
|
492
|
+
let i = xe, o = String(s);
|
|
493
|
+
xe = o, A("history", { from: i, to: o });
|
|
494
|
+
}
|
|
495
|
+
return n.apply(this, r);
|
|
496
|
+
};
|
|
497
|
+
}
|
|
498
|
+
I(y.history, "pushState", e), I(y.history, "replaceState", e);
|
|
499
|
+
}
|
|
500
|
+
var yr = 1e3;
|
|
501
|
+
var on;
|
|
502
|
+
var Ie;
|
|
503
|
+
function Sr(t, e) {
|
|
504
|
+
if (t.type !== e.type) return false;
|
|
505
|
+
try {
|
|
506
|
+
if (t.target !== e.target) return false;
|
|
507
|
+
} catch {
|
|
508
|
+
}
|
|
509
|
+
return true;
|
|
510
|
+
}
|
|
511
|
+
function Tr(t) {
|
|
512
|
+
if (t.type !== "keypress") return false;
|
|
513
|
+
try {
|
|
514
|
+
let e = t.target;
|
|
515
|
+
if (!e || !e.tagName) return true;
|
|
516
|
+
if (e.tagName === "INPUT" || e.tagName === "TEXTAREA" || e.isContentEditable) return false;
|
|
517
|
+
} catch {
|
|
518
|
+
}
|
|
519
|
+
return true;
|
|
520
|
+
}
|
|
521
|
+
function an(t, e = false) {
|
|
522
|
+
return (n) => {
|
|
523
|
+
if (!n || n._sentryCaptured || Tr(n)) return;
|
|
524
|
+
z(n, "_sentryCaptured", true);
|
|
525
|
+
let r = n.type === "keypress" ? "input" : n.type;
|
|
526
|
+
(Ie === void 0 || !Sr(Ie, n)) && (t({ event: n, name: r, global: e }), Ie = n), clearTimeout(on), on = y.setTimeout(() => {
|
|
527
|
+
Ie = void 0;
|
|
528
|
+
}, yr);
|
|
529
|
+
};
|
|
530
|
+
}
|
|
531
|
+
function dn() {
|
|
532
|
+
if (!y.document) return;
|
|
533
|
+
let t = A.bind(null, "dom"), e = an(t, true);
|
|
534
|
+
y.document.addEventListener("click", e, false), y.document.addEventListener("keypress", e, false), ["EventTarget", "Node"].forEach((n) => {
|
|
535
|
+
let r = y[n] && y[n].prototype;
|
|
536
|
+
!r || !r.hasOwnProperty || !r.hasOwnProperty("addEventListener") || (I(r, "addEventListener", function(s) {
|
|
537
|
+
return function(i, o, a) {
|
|
538
|
+
if (i === "click" || i == "keypress") try {
|
|
539
|
+
let c = this, u = c.__sentry_instrumentation_handlers__ = c.__sentry_instrumentation_handlers__ || {}, l = u[i] = u[i] || { refCount: 0 };
|
|
540
|
+
if (!l.handler) {
|
|
541
|
+
let d = an(t);
|
|
542
|
+
l.handler = d, s.call(this, i, d, a);
|
|
543
|
+
}
|
|
544
|
+
l.refCount++;
|
|
545
|
+
} catch {
|
|
546
|
+
}
|
|
547
|
+
return s.call(this, i, o, a);
|
|
548
|
+
};
|
|
549
|
+
}), I(r, "removeEventListener", function(s) {
|
|
550
|
+
return function(i, o, a) {
|
|
551
|
+
if (i === "click" || i == "keypress") try {
|
|
552
|
+
let c = this, u = c.__sentry_instrumentation_handlers__ || {}, l = u[i];
|
|
553
|
+
l && (l.refCount--, l.refCount <= 0 && (s.call(this, i, l.handler, a), l.handler = void 0, delete u[i]), Object.keys(u).length === 0 && delete c.__sentry_instrumentation_handlers__);
|
|
554
|
+
} catch {
|
|
555
|
+
}
|
|
556
|
+
return s.call(this, i, o, a);
|
|
557
|
+
};
|
|
558
|
+
}));
|
|
559
|
+
});
|
|
560
|
+
}
|
|
561
|
+
var Ne = null;
|
|
562
|
+
function br() {
|
|
563
|
+
Ne = y.onerror, y.onerror = function(t, e, n, r, s) {
|
|
564
|
+
return A("error", { column: r, error: s, line: n, msg: t, url: e }), Ne && !Ne.__SENTRY_LOADER__ ? Ne.apply(this, arguments) : false;
|
|
565
|
+
}, y.onerror.__SENTRY_INSTRUMENTED__ = true;
|
|
566
|
+
}
|
|
567
|
+
var Ae = null;
|
|
568
|
+
function Rr() {
|
|
569
|
+
Ae = y.onunhandledrejection, y.onunhandledrejection = function(t) {
|
|
570
|
+
return A("unhandledrejection", t), Ae && !Ae.__SENTRY_LOADER__ ? Ae.apply(this, arguments) : true;
|
|
571
|
+
}, y.onunhandledrejection.__SENTRY_INSTRUMENTED__ = true;
|
|
572
|
+
}
|
|
573
|
+
function ln() {
|
|
574
|
+
return typeof __SENTRY_BROWSER_BUNDLE__ < "u" && !!__SENTRY_BROWSER_BUNDLE__;
|
|
575
|
+
}
|
|
576
|
+
function fn() {
|
|
577
|
+
return !ln() && Object.prototype.toString.call(typeof process < "u" ? process : 0) === "[object process]";
|
|
578
|
+
}
|
|
579
|
+
function pn(t, e) {
|
|
580
|
+
return t.require(e);
|
|
581
|
+
}
|
|
582
|
+
function mn() {
|
|
583
|
+
let t = typeof WeakSet == "function", e = t ? /* @__PURE__ */ new WeakSet() : [];
|
|
584
|
+
function n(s) {
|
|
585
|
+
if (t) return e.has(s) ? true : (e.add(s), false);
|
|
586
|
+
for (let i = 0; i < e.length; i++) if (e[i] === s) return true;
|
|
587
|
+
return e.push(s), false;
|
|
588
|
+
}
|
|
589
|
+
function r(s) {
|
|
590
|
+
if (t) e.delete(s);
|
|
591
|
+
else for (let i = 0; i < e.length; i++) if (e[i] === s) {
|
|
592
|
+
e.splice(i, 1);
|
|
593
|
+
break;
|
|
594
|
+
}
|
|
595
|
+
}
|
|
596
|
+
return [n, r];
|
|
597
|
+
}
|
|
598
|
+
function g() {
|
|
599
|
+
let t = h, e = t.crypto || t.msCrypto, n = () => Math.random() * 16;
|
|
600
|
+
try {
|
|
601
|
+
if (e && e.randomUUID) return e.randomUUID().replace(/-/g, "");
|
|
602
|
+
e && e.getRandomValues && (n = () => e.getRandomValues(new Uint8Array(1))[0]);
|
|
603
|
+
} catch {
|
|
604
|
+
}
|
|
605
|
+
return ("10000000100040008000" + 1e11).replace(/[018]/g, (r) => (r ^ (n() & 15) >> r / 4).toString(16));
|
|
606
|
+
}
|
|
607
|
+
function xr(t) {
|
|
608
|
+
return t.exception && t.exception.values ? t.exception.values[0] : void 0;
|
|
609
|
+
}
|
|
610
|
+
function ae(t, e, n) {
|
|
611
|
+
let r = t.exception = t.exception || {}, s = r.values = r.values || [], i = s[0] = s[0] || {};
|
|
612
|
+
i.value || (i.value = e || ""), i.type || (i.type = n || "Error");
|
|
613
|
+
}
|
|
614
|
+
function ce(t, e) {
|
|
615
|
+
let n = xr(t);
|
|
616
|
+
if (!n) return;
|
|
617
|
+
let r = { type: "generic", handled: true }, s = n.mechanism;
|
|
618
|
+
if (n.mechanism = { ...r, ...s, ...e }, e && "data" in e) {
|
|
619
|
+
let i = { ...s && s.data, ...e.data };
|
|
620
|
+
n.mechanism.data = i;
|
|
621
|
+
}
|
|
622
|
+
}
|
|
623
|
+
function we(t) {
|
|
624
|
+
if (t && t.__sentry_captured__) return true;
|
|
625
|
+
try {
|
|
626
|
+
z(t, "__sentry_captured__", true);
|
|
627
|
+
} catch {
|
|
628
|
+
}
|
|
629
|
+
return false;
|
|
630
|
+
}
|
|
631
|
+
function ue(t) {
|
|
632
|
+
return Array.isArray(t) ? t : [t];
|
|
633
|
+
}
|
|
634
|
+
function D(t, e = 100, n = 1 / 0) {
|
|
635
|
+
try {
|
|
636
|
+
return Oe("", t, e, n);
|
|
637
|
+
} catch (r) {
|
|
638
|
+
return { ERROR: `**non-serializable** (${r})` };
|
|
639
|
+
}
|
|
640
|
+
}
|
|
641
|
+
function V(t, e = 3, n = 100 * 1024) {
|
|
642
|
+
let r = D(t, e);
|
|
643
|
+
return Dr(r) > n ? V(t, e - 1, n) : r;
|
|
644
|
+
}
|
|
645
|
+
function Oe(t, e, n = 1 / 0, r = 1 / 0, s = mn()) {
|
|
646
|
+
let [i, o] = s;
|
|
647
|
+
if (e == null || ["number", "boolean", "string"].includes(typeof e) && !ee(e)) return e;
|
|
648
|
+
let a = Ir(t, e);
|
|
649
|
+
if (!a.startsWith("[object ")) return a;
|
|
650
|
+
if (e.__sentry_skip_normalization__) return e;
|
|
651
|
+
let c = typeof e.__sentry_override_normalization_depth__ == "number" ? e.__sentry_override_normalization_depth__ : n;
|
|
652
|
+
if (c === 0) return a.replace("object ", "");
|
|
653
|
+
if (i(e)) return "[Circular ~]";
|
|
654
|
+
let u = e;
|
|
655
|
+
if (u && typeof u.toJSON == "function") try {
|
|
656
|
+
let m = u.toJSON();
|
|
657
|
+
return Oe("", m, c - 1, r, s);
|
|
658
|
+
} catch {
|
|
659
|
+
}
|
|
660
|
+
let l = Array.isArray(e) ? [] : {}, d = 0, p = Te(e);
|
|
661
|
+
for (let m in p) {
|
|
662
|
+
if (!Object.prototype.hasOwnProperty.call(p, m)) continue;
|
|
663
|
+
if (d >= r) {
|
|
664
|
+
l[m] = "[MaxProperties ~]";
|
|
665
|
+
break;
|
|
666
|
+
}
|
|
667
|
+
let O = p[m];
|
|
668
|
+
l[m] = Oe(m, O, c - 1, r, s), d++;
|
|
669
|
+
}
|
|
670
|
+
return o(e), l;
|
|
671
|
+
}
|
|
672
|
+
function Ir(t, e) {
|
|
673
|
+
try {
|
|
674
|
+
if (t === "domain" && e && typeof e == "object" && e._events) return "[Domain]";
|
|
675
|
+
if (t === "domainEmitter") return "[DomainEmitter]";
|
|
676
|
+
if (typeof global < "u" && e === global) return "[Global]";
|
|
677
|
+
if (typeof window < "u" && e === window) return "[Window]";
|
|
678
|
+
if (typeof document < "u" && e === document) return "[Document]";
|
|
679
|
+
if (rt(e)) return "[VueViewModel]";
|
|
680
|
+
if (nt(e)) return "[SyntheticEvent]";
|
|
681
|
+
if (typeof e == "number" && e !== e) return "[NaN]";
|
|
682
|
+
if (typeof e == "function") return `[Function: ${se(e)}]`;
|
|
683
|
+
if (typeof e == "symbol") return `[${String(e)}]`;
|
|
684
|
+
if (typeof e == "bigint") return `[BigInt: ${String(e)}]`;
|
|
685
|
+
let n = Nr(e);
|
|
686
|
+
return /^HTML(\w*)Element$/.test(n) ? `[HTMLElement: ${n}]` : `[object ${n}]`;
|
|
687
|
+
} catch (n) {
|
|
688
|
+
return `**non-serializable** (${n})`;
|
|
689
|
+
}
|
|
690
|
+
}
|
|
691
|
+
function Nr(t) {
|
|
692
|
+
let e = Object.getPrototypeOf(t);
|
|
693
|
+
return e ? e.constructor.name : "null prototype";
|
|
694
|
+
}
|
|
695
|
+
function Ar(t) {
|
|
696
|
+
return ~-encodeURI(t).split(/%..|./).length;
|
|
697
|
+
}
|
|
698
|
+
function Dr(t) {
|
|
699
|
+
return Ar(JSON.stringify(t));
|
|
700
|
+
}
|
|
701
|
+
var wr = /^(\S+:\\|\/?)([\s\S]*?)((?:\.{1,2}|[^/\\]+?|)(\.[^./\\]*|))(?:[/\\]*)$/;
|
|
702
|
+
function Or(t) {
|
|
703
|
+
let e = t.length > 1024 ? `<truncated>${t.slice(-1024)}` : t, n = wr.exec(e);
|
|
704
|
+
return n ? n.slice(1) : [];
|
|
705
|
+
}
|
|
706
|
+
function lt(t, e) {
|
|
707
|
+
let n = Or(t)[2];
|
|
708
|
+
return e && n.slice(e.length * -1) === e && (n = n.slice(0, n.length - e.length)), n;
|
|
709
|
+
}
|
|
710
|
+
var k;
|
|
711
|
+
(function(t) {
|
|
712
|
+
t[t.PENDING = 0] = "PENDING";
|
|
713
|
+
let n = 1;
|
|
714
|
+
t[t.RESOLVED = n] = "RESOLVED";
|
|
715
|
+
let r = 2;
|
|
716
|
+
t[t.REJECTED = r] = "REJECTED";
|
|
717
|
+
})(k || (k = {}));
|
|
718
|
+
function b(t) {
|
|
719
|
+
return new S((e) => {
|
|
720
|
+
e(t);
|
|
721
|
+
});
|
|
722
|
+
}
|
|
723
|
+
function F(t) {
|
|
724
|
+
return new S((e, n) => {
|
|
725
|
+
n(t);
|
|
726
|
+
});
|
|
727
|
+
}
|
|
728
|
+
var S = class {
|
|
729
|
+
constructor(e) {
|
|
730
|
+
S.prototype.__init.call(this), S.prototype.__init2.call(this), S.prototype.__init3.call(this), S.prototype.__init4.call(this), this._state = k.PENDING, this._handlers = [];
|
|
731
|
+
try {
|
|
732
|
+
e(this._resolve, this._reject);
|
|
733
|
+
} catch (n) {
|
|
734
|
+
this._reject(n);
|
|
735
|
+
}
|
|
736
|
+
}
|
|
737
|
+
then(e, n) {
|
|
738
|
+
return new S((r, s) => {
|
|
739
|
+
this._handlers.push([false, (i) => {
|
|
740
|
+
if (!e) r(i);
|
|
741
|
+
else try {
|
|
742
|
+
r(e(i));
|
|
743
|
+
} catch (o) {
|
|
744
|
+
s(o);
|
|
745
|
+
}
|
|
746
|
+
}, (i) => {
|
|
747
|
+
if (!n) s(i);
|
|
748
|
+
else try {
|
|
749
|
+
r(n(i));
|
|
750
|
+
} catch (o) {
|
|
751
|
+
s(o);
|
|
752
|
+
}
|
|
753
|
+
}]), this._executeHandlers();
|
|
754
|
+
});
|
|
755
|
+
}
|
|
756
|
+
catch(e) {
|
|
757
|
+
return this.then((n) => n, e);
|
|
758
|
+
}
|
|
759
|
+
finally(e) {
|
|
760
|
+
return new S((n, r) => {
|
|
761
|
+
let s, i;
|
|
762
|
+
return this.then((o) => {
|
|
763
|
+
i = false, s = o, e && e();
|
|
764
|
+
}, (o) => {
|
|
765
|
+
i = true, s = o, e && e();
|
|
766
|
+
}).then(() => {
|
|
767
|
+
if (i) {
|
|
768
|
+
r(s);
|
|
769
|
+
return;
|
|
770
|
+
}
|
|
771
|
+
n(s);
|
|
772
|
+
});
|
|
773
|
+
});
|
|
774
|
+
}
|
|
775
|
+
__init() {
|
|
776
|
+
this._resolve = (e) => {
|
|
777
|
+
this._setResult(k.RESOLVED, e);
|
|
778
|
+
};
|
|
779
|
+
}
|
|
780
|
+
__init2() {
|
|
781
|
+
this._reject = (e) => {
|
|
782
|
+
this._setResult(k.REJECTED, e);
|
|
783
|
+
};
|
|
784
|
+
}
|
|
785
|
+
__init3() {
|
|
786
|
+
this._setResult = (e, n) => {
|
|
787
|
+
if (this._state === k.PENDING) {
|
|
788
|
+
if (B(n)) {
|
|
789
|
+
n.then(this._resolve, this._reject);
|
|
790
|
+
return;
|
|
791
|
+
}
|
|
792
|
+
this._state = e, this._value = n, this._executeHandlers();
|
|
793
|
+
}
|
|
794
|
+
};
|
|
795
|
+
}
|
|
796
|
+
__init4() {
|
|
797
|
+
this._executeHandlers = () => {
|
|
798
|
+
if (this._state === k.PENDING) return;
|
|
799
|
+
let e = this._handlers.slice();
|
|
800
|
+
this._handlers = [], e.forEach((n) => {
|
|
801
|
+
n[0] || (this._state === k.RESOLVED && n[1](this._value), this._state === k.REJECTED && n[2](this._value), n[0] = true);
|
|
802
|
+
});
|
|
803
|
+
};
|
|
804
|
+
}
|
|
805
|
+
};
|
|
806
|
+
function ft(t) {
|
|
807
|
+
let e = [];
|
|
808
|
+
function n() {
|
|
809
|
+
return t === void 0 || e.length < t;
|
|
810
|
+
}
|
|
811
|
+
function r(o) {
|
|
812
|
+
return e.splice(e.indexOf(o), 1)[0];
|
|
813
|
+
}
|
|
814
|
+
function s(o) {
|
|
815
|
+
if (!n()) return F(new T("Not adding Promise because buffer limit was reached."));
|
|
816
|
+
let a = o();
|
|
817
|
+
return e.indexOf(a) === -1 && e.push(a), a.then(() => r(a)).then(null, () => r(a).then(null, () => {
|
|
818
|
+
})), a;
|
|
819
|
+
}
|
|
820
|
+
function i(o) {
|
|
821
|
+
return new S((a, c) => {
|
|
822
|
+
let u = e.length;
|
|
823
|
+
if (!u) return a(true);
|
|
824
|
+
let l = setTimeout(() => {
|
|
825
|
+
o && o > 0 && a(false);
|
|
826
|
+
}, o);
|
|
827
|
+
e.forEach((d) => {
|
|
828
|
+
b(d).then(() => {
|
|
829
|
+
--u || (clearTimeout(l), a(true));
|
|
830
|
+
}, c);
|
|
831
|
+
});
|
|
832
|
+
});
|
|
833
|
+
}
|
|
834
|
+
return { $: e, add: s, drain: i };
|
|
835
|
+
}
|
|
836
|
+
var _n = N();
|
|
837
|
+
var mt = { nowSeconds: () => Date.now() / 1e3 };
|
|
838
|
+
function vr() {
|
|
839
|
+
let { performance: t } = _n;
|
|
840
|
+
if (!t || !t.now) return;
|
|
841
|
+
let e = Date.now() - t.now();
|
|
842
|
+
return { now: () => t.now(), timeOrigin: e };
|
|
843
|
+
}
|
|
844
|
+
function kr() {
|
|
845
|
+
try {
|
|
846
|
+
return pn(module, "perf_hooks").performance;
|
|
847
|
+
} catch {
|
|
848
|
+
return;
|
|
849
|
+
}
|
|
850
|
+
}
|
|
851
|
+
var pt = fn() ? kr() : vr();
|
|
852
|
+
var hn = pt === void 0 ? mt : { nowSeconds: () => (pt.timeOrigin + pt.now()) / 1e3 };
|
|
853
|
+
var $ = mt.nowSeconds.bind(mt);
|
|
854
|
+
var G = hn.nowSeconds.bind(hn);
|
|
855
|
+
var de;
|
|
856
|
+
var Cr = (() => {
|
|
857
|
+
let { performance: t } = _n;
|
|
858
|
+
if (!t || !t.now) {
|
|
859
|
+
de = "none";
|
|
860
|
+
return;
|
|
861
|
+
}
|
|
862
|
+
let e = 3600 * 1e3, n = t.now(), r = Date.now(), s = t.timeOrigin ? Math.abs(t.timeOrigin + n - r) : e, i = s < e, o = t.timing && t.timing.navigationStart, c = typeof o == "number" ? Math.abs(o + n - r) : e, u = c < e;
|
|
863
|
+
return i || u ? s <= c ? (de = "timeOrigin", t.timeOrigin) : (de = "navigationStart", o) : (de = "dateNow", r);
|
|
864
|
+
})();
|
|
865
|
+
var Pr = new RegExp("^[ \\t]*([0-9a-f]{32})?-?([0-9a-f]{16})?-?([01])?[ \\t]*$");
|
|
866
|
+
function ht(t = g(), e = g().substring(16), n) {
|
|
867
|
+
let r = "";
|
|
868
|
+
return n !== void 0 && (r = n ? "-1" : "-0"), `${t}-${e}${r}`;
|
|
869
|
+
}
|
|
870
|
+
function U(t, e = []) {
|
|
871
|
+
return [t, e];
|
|
872
|
+
}
|
|
873
|
+
function gt(t, e) {
|
|
874
|
+
let [n, r] = t;
|
|
875
|
+
return [n, [...r, e]];
|
|
876
|
+
}
|
|
877
|
+
function ve(t, e) {
|
|
878
|
+
let n = t[1];
|
|
879
|
+
for (let r of n) {
|
|
880
|
+
let s = r[0].type;
|
|
881
|
+
if (e(r, s)) return true;
|
|
882
|
+
}
|
|
883
|
+
return false;
|
|
884
|
+
}
|
|
885
|
+
function _t(t, e) {
|
|
886
|
+
return (e || new TextEncoder()).encode(t);
|
|
887
|
+
}
|
|
888
|
+
function Et(t, e) {
|
|
889
|
+
let [n, r] = t, s = JSON.stringify(n);
|
|
890
|
+
function i(o) {
|
|
891
|
+
typeof s == "string" ? s = typeof o == "string" ? s + o : [_t(s, e), o] : s.push(typeof o == "string" ? _t(o, e) : o);
|
|
892
|
+
}
|
|
893
|
+
for (let o of r) {
|
|
894
|
+
let [a, c] = o;
|
|
895
|
+
if (i(`
|
|
896
|
+
${JSON.stringify(a)}
|
|
897
|
+
`), typeof c == "string" || c instanceof Uint8Array) i(c);
|
|
898
|
+
else {
|
|
899
|
+
let u;
|
|
900
|
+
try {
|
|
901
|
+
u = JSON.stringify(c);
|
|
902
|
+
} catch {
|
|
903
|
+
u = JSON.stringify(D(c));
|
|
904
|
+
}
|
|
905
|
+
i(u);
|
|
906
|
+
}
|
|
907
|
+
}
|
|
908
|
+
return typeof s == "string" ? s : Mr(s);
|
|
909
|
+
}
|
|
910
|
+
function Mr(t) {
|
|
911
|
+
let e = t.reduce((s, i) => s + i.length, 0), n = new Uint8Array(e), r = 0;
|
|
912
|
+
for (let s of t) n.set(s, r), r += s.length;
|
|
913
|
+
return n;
|
|
914
|
+
}
|
|
915
|
+
function yt(t, e) {
|
|
916
|
+
let n = typeof t.data == "string" ? _t(t.data, e) : t.data;
|
|
917
|
+
return [E({ type: "attachment", length: n.length, filename: t.filename, content_type: t.contentType, attachment_type: t.attachmentType }), n];
|
|
918
|
+
}
|
|
919
|
+
var Ur = { session: "session", sessions: "session", attachment: "attachment", transaction: "transaction", event: "error", client_report: "internal", user_report: "default", profile: "profile", replay_event: "replay", replay_recording: "replay", check_in: "monitor", statsd: "unknown" };
|
|
920
|
+
function ke(t) {
|
|
921
|
+
return Ur[t];
|
|
922
|
+
}
|
|
923
|
+
function Ce(t) {
|
|
924
|
+
if (!t || !t.sdk) return;
|
|
925
|
+
let { name: e, version: n } = t.sdk;
|
|
926
|
+
return { name: e, version: n };
|
|
927
|
+
}
|
|
928
|
+
function St(t, e, n, r) {
|
|
929
|
+
let s = t.sdkProcessingMetadata && t.sdkProcessingMetadata.dynamicSamplingContext;
|
|
930
|
+
return { event_id: t.event_id, sent_at: (/* @__PURE__ */ new Date()).toISOString(), ...e && { sdk: e }, ...!!n && r && { dsn: M(r) }, ...s && { trace: E({ ...s }) } };
|
|
931
|
+
}
|
|
932
|
+
function gn(t, e = Date.now()) {
|
|
933
|
+
let n = parseInt(`${t}`, 10);
|
|
934
|
+
if (!isNaN(n)) return n * 1e3;
|
|
935
|
+
let r = Date.parse(`${t}`);
|
|
936
|
+
return isNaN(r) ? 6e4 : r - e;
|
|
937
|
+
}
|
|
938
|
+
function En(t, e) {
|
|
939
|
+
return t[e] || t.all || 0;
|
|
940
|
+
}
|
|
941
|
+
function Tt(t, e, n = Date.now()) {
|
|
942
|
+
return En(t, e) > n;
|
|
943
|
+
}
|
|
944
|
+
function bt(t, { statusCode: e, headers: n }, r = Date.now()) {
|
|
945
|
+
let s = { ...t }, i = n && n["x-sentry-rate-limits"], o = n && n["retry-after"];
|
|
946
|
+
if (i) for (let a of i.trim().split(",")) {
|
|
947
|
+
let [c, u] = a.split(":", 2), l = parseInt(c, 10), d = (isNaN(l) ? 60 : l) * 1e3;
|
|
948
|
+
if (!u) s.all = r + d;
|
|
949
|
+
else for (let p of u.split(";")) s[p] = r + d;
|
|
950
|
+
}
|
|
951
|
+
else o ? s.all = r + gn(o, r) : e === 429 && (s.all = r + 60 * 1e3);
|
|
952
|
+
return s;
|
|
953
|
+
}
|
|
954
|
+
function Rt(t, e) {
|
|
955
|
+
return t(e.stack || "", 1);
|
|
956
|
+
}
|
|
957
|
+
function yn(t, e) {
|
|
958
|
+
let n = { type: e.name || e.constructor.name, value: e.message }, r = Rt(t, e);
|
|
959
|
+
return r.length && (n.stacktrace = { frames: r }), n;
|
|
960
|
+
}
|
|
961
|
+
function Lr(t) {
|
|
962
|
+
if ("name" in t && typeof t.name == "string") {
|
|
963
|
+
let e = `'${t.name}' captured as exception`;
|
|
964
|
+
return "message" in t && typeof t.message == "string" && (e += ` with message '${t.message}'`), e;
|
|
965
|
+
} else return "message" in t && typeof t.message == "string" ? t.message : `Object captured as exception with keys: ${re(t)}`;
|
|
966
|
+
}
|
|
967
|
+
function xt(t, e, n, r) {
|
|
968
|
+
let s = n, o = r && r.data && r.data.mechanism || { handled: true, type: "generic" };
|
|
969
|
+
if (!L(n)) {
|
|
970
|
+
if (x(n)) {
|
|
971
|
+
let c = t(), u = c.getClient(), l = u && u.getOptions().normalizeDepth;
|
|
972
|
+
c.configureScope((p) => {
|
|
973
|
+
p.setExtra("__serialized__", V(n, l));
|
|
974
|
+
});
|
|
975
|
+
let d = Lr(n);
|
|
976
|
+
s = r && r.syntheticException || new Error(d), s.message = d;
|
|
977
|
+
} else s = r && r.syntheticException || new Error(n), s.message = n;
|
|
978
|
+
o.synthetic = true;
|
|
979
|
+
}
|
|
980
|
+
let a = { exception: { values: [yn(e, s)] } };
|
|
981
|
+
return ae(a, void 0, void 0), ce(a, o), { ...a, event_id: r && r.event_id };
|
|
982
|
+
}
|
|
983
|
+
function It(t, e, n = "info", r, s) {
|
|
984
|
+
let i = { event_id: r && r.event_id, level: n, message: e };
|
|
985
|
+
if (s && r && r.syntheticException) {
|
|
986
|
+
let o = Rt(t, r.syntheticException);
|
|
987
|
+
o.length && (i.exception = { values: [{ value: e, stacktrace: { frames: o } }] });
|
|
988
|
+
}
|
|
989
|
+
return i;
|
|
990
|
+
}
|
|
991
|
+
var J = "production";
|
|
992
|
+
function le() {
|
|
993
|
+
return te("globalEventProcessors", () => []);
|
|
994
|
+
}
|
|
995
|
+
function Sn(t) {
|
|
996
|
+
le().push(t);
|
|
997
|
+
}
|
|
998
|
+
function K(t, e, n, r = 0) {
|
|
999
|
+
return new S((s, i) => {
|
|
1000
|
+
let o = t[r];
|
|
1001
|
+
if (e === null || typeof o != "function") s(e);
|
|
1002
|
+
else {
|
|
1003
|
+
let a = o({ ...e }, n);
|
|
1004
|
+
(typeof __SENTRY_DEBUG__ > "u" || __SENTRY_DEBUG__) && o.id && a === null && f.log(`Event processor "${o.id}" dropped event`), B(a) ? a.then((c) => K(t, c, n, r + 1).then(s)).then(null, i) : K(t, a, n, r + 1).then(s).then(null, i);
|
|
1005
|
+
}
|
|
1006
|
+
});
|
|
1007
|
+
}
|
|
1008
|
+
function Tn(t) {
|
|
1009
|
+
let e = G(), n = { sid: g(), init: true, timestamp: e, started: e, duration: 0, status: "ok", errors: 0, ignoreDuration: false, toJSON: () => Br(n) };
|
|
1010
|
+
return t && C(n, t), n;
|
|
1011
|
+
}
|
|
1012
|
+
function C(t, e = {}) {
|
|
1013
|
+
if (e.user && (!t.ipAddress && e.user.ip_address && (t.ipAddress = e.user.ip_address), !t.did && !e.did && (t.did = e.user.id || e.user.email || e.user.username)), t.timestamp = e.timestamp || G(), e.abnormal_mechanism && (t.abnormal_mechanism = e.abnormal_mechanism), e.ignoreDuration && (t.ignoreDuration = e.ignoreDuration), e.sid && (t.sid = e.sid.length === 32 ? e.sid : g()), e.init !== void 0 && (t.init = e.init), !t.did && e.did && (t.did = `${e.did}`), typeof e.started == "number" && (t.started = e.started), t.ignoreDuration) t.duration = void 0;
|
|
1014
|
+
else if (typeof e.duration == "number") t.duration = e.duration;
|
|
1015
|
+
else {
|
|
1016
|
+
let n = t.timestamp - t.started;
|
|
1017
|
+
t.duration = n >= 0 ? n : 0;
|
|
1018
|
+
}
|
|
1019
|
+
e.release && (t.release = e.release), e.environment && (t.environment = e.environment), !t.ipAddress && e.ipAddress && (t.ipAddress = e.ipAddress), !t.userAgent && e.userAgent && (t.userAgent = e.userAgent), typeof e.errors == "number" && (t.errors = e.errors), e.status && (t.status = e.status);
|
|
1020
|
+
}
|
|
1021
|
+
function bn(t, e) {
|
|
1022
|
+
let n = {};
|
|
1023
|
+
e ? n = { status: e } : t.status === "ok" && (n = { status: "exited" }), C(t, n);
|
|
1024
|
+
}
|
|
1025
|
+
function Br(t) {
|
|
1026
|
+
return E({ sid: `${t.sid}`, init: t.init, started: new Date(t.started * 1e3).toISOString(), timestamp: new Date(t.timestamp * 1e3).toISOString(), status: t.status, errors: t.errors, did: typeof t.did == "number" || typeof t.did == "string" ? `${t.did}` : void 0, duration: t.duration, abnormal_mechanism: t.abnormal_mechanism, attrs: { release: t.release, environment: t.environment, ip_address: t.ipAddress, user_agent: t.userAgent } });
|
|
1027
|
+
}
|
|
1028
|
+
var Fr = 100;
|
|
1029
|
+
var w = class {
|
|
1030
|
+
constructor() {
|
|
1031
|
+
this._notifyingListeners = false, this._scopeListeners = [], this._eventProcessors = [], this._breadcrumbs = [], this._attachments = [], this._user = {}, this._tags = {}, this._extra = {}, this._contexts = {}, this._sdkProcessingMetadata = {}, this._propagationContext = Rn();
|
|
1032
|
+
}
|
|
1033
|
+
static clone(e) {
|
|
1034
|
+
let n = new w();
|
|
1035
|
+
return e && (n._breadcrumbs = [...e._breadcrumbs], n._tags = { ...e._tags }, n._extra = { ...e._extra }, n._contexts = { ...e._contexts }, n._user = e._user, n._level = e._level, n._span = e._span, n._session = e._session, n._transactionName = e._transactionName, n._fingerprint = e._fingerprint, n._eventProcessors = [...e._eventProcessors], n._requestSession = e._requestSession, n._attachments = [...e._attachments], n._sdkProcessingMetadata = { ...e._sdkProcessingMetadata }, n._propagationContext = { ...e._propagationContext }), n;
|
|
1036
|
+
}
|
|
1037
|
+
addScopeListener(e) {
|
|
1038
|
+
this._scopeListeners.push(e);
|
|
1039
|
+
}
|
|
1040
|
+
addEventProcessor(e) {
|
|
1041
|
+
return this._eventProcessors.push(e), this;
|
|
1042
|
+
}
|
|
1043
|
+
setUser(e) {
|
|
1044
|
+
return this._user = e || {}, this._session && C(this._session, { user: e }), this._notifyScopeListeners(), this;
|
|
1045
|
+
}
|
|
1046
|
+
getUser() {
|
|
1047
|
+
return this._user;
|
|
1048
|
+
}
|
|
1049
|
+
getRequestSession() {
|
|
1050
|
+
return this._requestSession;
|
|
1051
|
+
}
|
|
1052
|
+
setRequestSession(e) {
|
|
1053
|
+
return this._requestSession = e, this;
|
|
1054
|
+
}
|
|
1055
|
+
setTags(e) {
|
|
1056
|
+
return this._tags = { ...this._tags, ...e }, this._notifyScopeListeners(), this;
|
|
1057
|
+
}
|
|
1058
|
+
setTag(e, n) {
|
|
1059
|
+
return this._tags = { ...this._tags, [e]: n }, this._notifyScopeListeners(), this;
|
|
1060
|
+
}
|
|
1061
|
+
setExtras(e) {
|
|
1062
|
+
return this._extra = { ...this._extra, ...e }, this._notifyScopeListeners(), this;
|
|
1063
|
+
}
|
|
1064
|
+
setExtra(e, n) {
|
|
1065
|
+
return this._extra = { ...this._extra, [e]: n }, this._notifyScopeListeners(), this;
|
|
1066
|
+
}
|
|
1067
|
+
setFingerprint(e) {
|
|
1068
|
+
return this._fingerprint = e, this._notifyScopeListeners(), this;
|
|
1069
|
+
}
|
|
1070
|
+
setLevel(e) {
|
|
1071
|
+
return this._level = e, this._notifyScopeListeners(), this;
|
|
1072
|
+
}
|
|
1073
|
+
setTransactionName(e) {
|
|
1074
|
+
return this._transactionName = e, this._notifyScopeListeners(), this;
|
|
1075
|
+
}
|
|
1076
|
+
setContext(e, n) {
|
|
1077
|
+
return n === null ? delete this._contexts[e] : this._contexts[e] = n, this._notifyScopeListeners(), this;
|
|
1078
|
+
}
|
|
1079
|
+
setSpan(e) {
|
|
1080
|
+
return this._span = e, this._notifyScopeListeners(), this;
|
|
1081
|
+
}
|
|
1082
|
+
getSpan() {
|
|
1083
|
+
return this._span;
|
|
1084
|
+
}
|
|
1085
|
+
getTransaction() {
|
|
1086
|
+
let e = this.getSpan();
|
|
1087
|
+
return e && e.transaction;
|
|
1088
|
+
}
|
|
1089
|
+
setSession(e) {
|
|
1090
|
+
return e ? this._session = e : delete this._session, this._notifyScopeListeners(), this;
|
|
1091
|
+
}
|
|
1092
|
+
getSession() {
|
|
1093
|
+
return this._session;
|
|
1094
|
+
}
|
|
1095
|
+
update(e) {
|
|
1096
|
+
if (!e) return this;
|
|
1097
|
+
if (typeof e == "function") {
|
|
1098
|
+
let n = e(this);
|
|
1099
|
+
return n instanceof w ? n : this;
|
|
1100
|
+
}
|
|
1101
|
+
return e instanceof w ? (this._tags = { ...this._tags, ...e._tags }, this._extra = { ...this._extra, ...e._extra }, this._contexts = { ...this._contexts, ...e._contexts }, e._user && Object.keys(e._user).length && (this._user = e._user), e._level && (this._level = e._level), e._fingerprint && (this._fingerprint = e._fingerprint), e._requestSession && (this._requestSession = e._requestSession), e._propagationContext && (this._propagationContext = e._propagationContext)) : x(e) && (e = e, this._tags = { ...this._tags, ...e.tags }, this._extra = { ...this._extra, ...e.extra }, this._contexts = { ...this._contexts, ...e.contexts }, e.user && (this._user = e.user), e.level && (this._level = e.level), e.fingerprint && (this._fingerprint = e.fingerprint), e.requestSession && (this._requestSession = e.requestSession), e.propagationContext && (this._propagationContext = e.propagationContext)), this;
|
|
1102
|
+
}
|
|
1103
|
+
clear() {
|
|
1104
|
+
return this._breadcrumbs = [], this._tags = {}, this._extra = {}, this._user = {}, this._contexts = {}, this._level = void 0, this._transactionName = void 0, this._fingerprint = void 0, this._requestSession = void 0, this._span = void 0, this._session = void 0, this._notifyScopeListeners(), this._attachments = [], this._propagationContext = Rn(), this;
|
|
1105
|
+
}
|
|
1106
|
+
addBreadcrumb(e, n) {
|
|
1107
|
+
let r = typeof n == "number" ? n : Fr;
|
|
1108
|
+
if (r <= 0) return this;
|
|
1109
|
+
let s = { timestamp: $(), ...e }, i = this._breadcrumbs;
|
|
1110
|
+
return i.push(s), this._breadcrumbs = i.length > r ? i.slice(-r) : i, this._notifyScopeListeners(), this;
|
|
1111
|
+
}
|
|
1112
|
+
getLastBreadcrumb() {
|
|
1113
|
+
return this._breadcrumbs[this._breadcrumbs.length - 1];
|
|
1114
|
+
}
|
|
1115
|
+
clearBreadcrumbs() {
|
|
1116
|
+
return this._breadcrumbs = [], this._notifyScopeListeners(), this;
|
|
1117
|
+
}
|
|
1118
|
+
addAttachment(e) {
|
|
1119
|
+
return this._attachments.push(e), this;
|
|
1120
|
+
}
|
|
1121
|
+
getAttachments() {
|
|
1122
|
+
return this._attachments;
|
|
1123
|
+
}
|
|
1124
|
+
clearAttachments() {
|
|
1125
|
+
return this._attachments = [], this;
|
|
1126
|
+
}
|
|
1127
|
+
applyToEvent(e, n = {}, r) {
|
|
1128
|
+
if (this._extra && Object.keys(this._extra).length && (e.extra = { ...this._extra, ...e.extra }), this._tags && Object.keys(this._tags).length && (e.tags = { ...this._tags, ...e.tags }), this._user && Object.keys(this._user).length && (e.user = { ...this._user, ...e.user }), this._contexts && Object.keys(this._contexts).length && (e.contexts = { ...this._contexts, ...e.contexts }), this._level && (e.level = this._level), this._transactionName && (e.transaction = this._transactionName), this._span) {
|
|
1129
|
+
e.contexts = { trace: this._span.getTraceContext(), ...e.contexts };
|
|
1130
|
+
let o = this._span.transaction;
|
|
1131
|
+
if (o) {
|
|
1132
|
+
e.sdkProcessingMetadata = { dynamicSamplingContext: o.getDynamicSamplingContext(), ...e.sdkProcessingMetadata };
|
|
1133
|
+
let a = o.name;
|
|
1134
|
+
a && (e.tags = { transaction: a, ...e.tags });
|
|
1135
|
+
}
|
|
1136
|
+
}
|
|
1137
|
+
this._applyFingerprint(e);
|
|
1138
|
+
let s = this._getBreadcrumbs(), i = [...e.breadcrumbs || [], ...s];
|
|
1139
|
+
return e.breadcrumbs = i.length > 0 ? i : void 0, e.sdkProcessingMetadata = { ...e.sdkProcessingMetadata, ...this._sdkProcessingMetadata, propagationContext: this._propagationContext }, K([...r || [], ...le(), ...this._eventProcessors], e, n);
|
|
1140
|
+
}
|
|
1141
|
+
setSDKProcessingMetadata(e) {
|
|
1142
|
+
return this._sdkProcessingMetadata = { ...this._sdkProcessingMetadata, ...e }, this;
|
|
1143
|
+
}
|
|
1144
|
+
setPropagationContext(e) {
|
|
1145
|
+
return this._propagationContext = e, this;
|
|
1146
|
+
}
|
|
1147
|
+
getPropagationContext() {
|
|
1148
|
+
return this._propagationContext;
|
|
1149
|
+
}
|
|
1150
|
+
_getBreadcrumbs() {
|
|
1151
|
+
return this._breadcrumbs;
|
|
1152
|
+
}
|
|
1153
|
+
_notifyScopeListeners() {
|
|
1154
|
+
this._notifyingListeners || (this._notifyingListeners = true, this._scopeListeners.forEach((e) => {
|
|
1155
|
+
e(this);
|
|
1156
|
+
}), this._notifyingListeners = false);
|
|
1157
|
+
}
|
|
1158
|
+
_applyFingerprint(e) {
|
|
1159
|
+
e.fingerprint = e.fingerprint ? ue(e.fingerprint) : [], this._fingerprint && (e.fingerprint = e.fingerprint.concat(this._fingerprint)), e.fingerprint && !e.fingerprint.length && delete e.fingerprint;
|
|
1160
|
+
}
|
|
1161
|
+
};
|
|
1162
|
+
function Rn() {
|
|
1163
|
+
return { traceId: g(), spanId: g().substring(16) };
|
|
1164
|
+
}
|
|
1165
|
+
var xn = 4;
|
|
1166
|
+
var $r = 100;
|
|
1167
|
+
var H = class {
|
|
1168
|
+
constructor(e, n = new w(), r = xn) {
|
|
1169
|
+
this._version = r, this._stack = [{ scope: n }], e && this.bindClient(e);
|
|
1170
|
+
}
|
|
1171
|
+
isOlderThan(e) {
|
|
1172
|
+
return this._version < e;
|
|
1173
|
+
}
|
|
1174
|
+
bindClient(e) {
|
|
1175
|
+
let n = this.getStackTop();
|
|
1176
|
+
n.client = e, e && e.setupIntegrations && e.setupIntegrations();
|
|
1177
|
+
}
|
|
1178
|
+
pushScope() {
|
|
1179
|
+
let e = w.clone(this.getScope());
|
|
1180
|
+
return this.getStack().push({ client: this.getClient(), scope: e }), e;
|
|
1181
|
+
}
|
|
1182
|
+
popScope() {
|
|
1183
|
+
return this.getStack().length <= 1 ? false : !!this.getStack().pop();
|
|
1184
|
+
}
|
|
1185
|
+
withScope(e) {
|
|
1186
|
+
let n = this.pushScope();
|
|
1187
|
+
try {
|
|
1188
|
+
e(n);
|
|
1189
|
+
} finally {
|
|
1190
|
+
this.popScope();
|
|
1191
|
+
}
|
|
1192
|
+
}
|
|
1193
|
+
getClient() {
|
|
1194
|
+
return this.getStackTop().client;
|
|
1195
|
+
}
|
|
1196
|
+
getScope() {
|
|
1197
|
+
return this.getStackTop().scope;
|
|
1198
|
+
}
|
|
1199
|
+
getStack() {
|
|
1200
|
+
return this._stack;
|
|
1201
|
+
}
|
|
1202
|
+
getStackTop() {
|
|
1203
|
+
return this._stack[this._stack.length - 1];
|
|
1204
|
+
}
|
|
1205
|
+
captureException(e, n) {
|
|
1206
|
+
let r = this._lastEventId = n && n.event_id ? n.event_id : g(), s = new Error("Sentry syntheticException");
|
|
1207
|
+
return this._withClient((i, o) => {
|
|
1208
|
+
i.captureException(e, { originalException: e, syntheticException: s, ...n, event_id: r }, o);
|
|
1209
|
+
}), r;
|
|
1210
|
+
}
|
|
1211
|
+
captureMessage(e, n, r) {
|
|
1212
|
+
let s = this._lastEventId = r && r.event_id ? r.event_id : g(), i = new Error(e);
|
|
1213
|
+
return this._withClient((o, a) => {
|
|
1214
|
+
o.captureMessage(e, n, { originalException: e, syntheticException: i, ...r, event_id: s }, a);
|
|
1215
|
+
}), s;
|
|
1216
|
+
}
|
|
1217
|
+
captureEvent(e, n) {
|
|
1218
|
+
let r = n && n.event_id ? n.event_id : g();
|
|
1219
|
+
return e.type || (this._lastEventId = r), this._withClient((s, i) => {
|
|
1220
|
+
s.captureEvent(e, { ...n, event_id: r }, i);
|
|
1221
|
+
}), r;
|
|
1222
|
+
}
|
|
1223
|
+
lastEventId() {
|
|
1224
|
+
return this._lastEventId;
|
|
1225
|
+
}
|
|
1226
|
+
addBreadcrumb(e, n) {
|
|
1227
|
+
let { scope: r, client: s } = this.getStackTop();
|
|
1228
|
+
if (!s) return;
|
|
1229
|
+
let { beforeBreadcrumb: i = null, maxBreadcrumbs: o = $r } = s.getOptions && s.getOptions() || {};
|
|
1230
|
+
if (o <= 0) return;
|
|
1231
|
+
let c = { timestamp: $(), ...e }, u = i ? ye(() => i(c, n)) : c;
|
|
1232
|
+
u !== null && (s.emit && s.emit("beforeAddBreadcrumb", u, n), r.addBreadcrumb(u, o));
|
|
1233
|
+
}
|
|
1234
|
+
setUser(e) {
|
|
1235
|
+
this.getScope().setUser(e);
|
|
1236
|
+
}
|
|
1237
|
+
setTags(e) {
|
|
1238
|
+
this.getScope().setTags(e);
|
|
1239
|
+
}
|
|
1240
|
+
setExtras(e) {
|
|
1241
|
+
this.getScope().setExtras(e);
|
|
1242
|
+
}
|
|
1243
|
+
setTag(e, n) {
|
|
1244
|
+
this.getScope().setTag(e, n);
|
|
1245
|
+
}
|
|
1246
|
+
setExtra(e, n) {
|
|
1247
|
+
this.getScope().setExtra(e, n);
|
|
1248
|
+
}
|
|
1249
|
+
setContext(e, n) {
|
|
1250
|
+
this.getScope().setContext(e, n);
|
|
1251
|
+
}
|
|
1252
|
+
configureScope(e) {
|
|
1253
|
+
let { scope: n, client: r } = this.getStackTop();
|
|
1254
|
+
r && e(n);
|
|
1255
|
+
}
|
|
1256
|
+
run(e) {
|
|
1257
|
+
let n = Nt(this);
|
|
1258
|
+
try {
|
|
1259
|
+
e(this);
|
|
1260
|
+
} finally {
|
|
1261
|
+
Nt(n);
|
|
1262
|
+
}
|
|
1263
|
+
}
|
|
1264
|
+
getIntegration(e) {
|
|
1265
|
+
let n = this.getClient();
|
|
1266
|
+
if (!n) return null;
|
|
1267
|
+
try {
|
|
1268
|
+
return n.getIntegration(e);
|
|
1269
|
+
} catch {
|
|
1270
|
+
return (typeof __SENTRY_DEBUG__ > "u" || __SENTRY_DEBUG__) && f.warn(`Cannot retrieve integration ${e.id} from the current Hub`), null;
|
|
1271
|
+
}
|
|
1272
|
+
}
|
|
1273
|
+
startTransaction(e, n) {
|
|
1274
|
+
let r = this._callExtensionMethod("startTransaction", e, n);
|
|
1275
|
+
if ((typeof __SENTRY_DEBUG__ > "u" || __SENTRY_DEBUG__) && !r) {
|
|
1276
|
+
let s = this.getClient();
|
|
1277
|
+
console.warn(s ? `Tracing extension 'startTransaction' has not been added. Call 'addTracingExtensions' before calling 'init':
|
|
1278
|
+
Sentry.addTracingExtensions();
|
|
1279
|
+
Sentry.init({...});
|
|
1280
|
+
` : "Tracing extension 'startTransaction' is missing. You should 'init' the SDK before calling 'startTransaction'");
|
|
1281
|
+
}
|
|
1282
|
+
return r;
|
|
1283
|
+
}
|
|
1284
|
+
traceHeaders() {
|
|
1285
|
+
return this._callExtensionMethod("traceHeaders");
|
|
1286
|
+
}
|
|
1287
|
+
captureSession(e = false) {
|
|
1288
|
+
if (e) return this.endSession();
|
|
1289
|
+
this._sendSessionUpdate();
|
|
1290
|
+
}
|
|
1291
|
+
endSession() {
|
|
1292
|
+
let n = this.getStackTop().scope, r = n.getSession();
|
|
1293
|
+
r && bn(r), this._sendSessionUpdate(), n.setSession();
|
|
1294
|
+
}
|
|
1295
|
+
startSession(e) {
|
|
1296
|
+
let { scope: n, client: r } = this.getStackTop(), { release: s, environment: i = J } = r && r.getOptions() || {}, { userAgent: o } = h.navigator || {}, a = Tn({ release: s, environment: i, user: n.getUser(), ...o && { userAgent: o }, ...e }), c = n.getSession && n.getSession();
|
|
1297
|
+
return c && c.status === "ok" && C(c, { status: "exited" }), this.endSession(), n.setSession(a), a;
|
|
1298
|
+
}
|
|
1299
|
+
shouldSendDefaultPii() {
|
|
1300
|
+
let e = this.getClient(), n = e && e.getOptions();
|
|
1301
|
+
return !!(n && n.sendDefaultPii);
|
|
1302
|
+
}
|
|
1303
|
+
_sendSessionUpdate() {
|
|
1304
|
+
let { scope: e, client: n } = this.getStackTop(), r = e.getSession();
|
|
1305
|
+
r && n && n.captureSession && n.captureSession(r);
|
|
1306
|
+
}
|
|
1307
|
+
_withClient(e) {
|
|
1308
|
+
let { scope: n, client: r } = this.getStackTop();
|
|
1309
|
+
r && e(r, n);
|
|
1310
|
+
}
|
|
1311
|
+
_callExtensionMethod(e, ...n) {
|
|
1312
|
+
let s = Y().__SENTRY__;
|
|
1313
|
+
if (s && s.extensions && typeof s.extensions[e] == "function") return s.extensions[e].apply(this, n);
|
|
1314
|
+
(typeof __SENTRY_DEBUG__ > "u" || __SENTRY_DEBUG__) && f.warn(`Extension method ${e} couldn't be found, doing nothing.`);
|
|
1315
|
+
}
|
|
1316
|
+
};
|
|
1317
|
+
function Y() {
|
|
1318
|
+
return h.__SENTRY__ = h.__SENTRY__ || { extensions: {}, hub: void 0 }, h;
|
|
1319
|
+
}
|
|
1320
|
+
function Nt(t) {
|
|
1321
|
+
let e = Y(), n = Pe(e);
|
|
1322
|
+
return At(e, t), n;
|
|
1323
|
+
}
|
|
1324
|
+
function R() {
|
|
1325
|
+
let t = Y();
|
|
1326
|
+
if (t.__SENTRY__ && t.__SENTRY__.acs) {
|
|
1327
|
+
let e = t.__SENTRY__.acs.getCurrentHub();
|
|
1328
|
+
if (e) return e;
|
|
1329
|
+
}
|
|
1330
|
+
return Gr(t);
|
|
1331
|
+
}
|
|
1332
|
+
function Gr(t = Y()) {
|
|
1333
|
+
return (!Hr(t) || Pe(t).isOlderThan(xn)) && At(t, new H()), Pe(t);
|
|
1334
|
+
}
|
|
1335
|
+
function Hr(t) {
|
|
1336
|
+
return !!(t && t.__SENTRY__ && t.__SENTRY__.hub);
|
|
1337
|
+
}
|
|
1338
|
+
function Pe(t) {
|
|
1339
|
+
return te("hub", () => new H(), t);
|
|
1340
|
+
}
|
|
1341
|
+
function At(t, e) {
|
|
1342
|
+
if (!t) return false;
|
|
1343
|
+
let n = t.__SENTRY__ = t.__SENTRY__ || {};
|
|
1344
|
+
return n.hub = e, true;
|
|
1345
|
+
}
|
|
1346
|
+
function In(t) {
|
|
1347
|
+
return (t || R()).getScope().getTransaction();
|
|
1348
|
+
}
|
|
1349
|
+
var Nn = false;
|
|
1350
|
+
function An() {
|
|
1351
|
+
Nn || (Nn = true, De("error", Dt), De("unhandledrejection", Dt));
|
|
1352
|
+
}
|
|
1353
|
+
function Dt() {
|
|
1354
|
+
let t = In();
|
|
1355
|
+
if (t) {
|
|
1356
|
+
let e = "internal_error";
|
|
1357
|
+
(typeof __SENTRY_DEBUG__ > "u" || __SENTRY_DEBUG__) && f.log(`[Tracing] Transaction: ${e} -> Global error occured`), t.setStatus(e);
|
|
1358
|
+
}
|
|
1359
|
+
}
|
|
1360
|
+
Dt.tag = "sentry_tracingErrorCallback";
|
|
1361
|
+
var Me = class {
|
|
1362
|
+
constructor(e = 1e3) {
|
|
1363
|
+
this._maxlen = e, this.spans = [];
|
|
1364
|
+
}
|
|
1365
|
+
add(e) {
|
|
1366
|
+
this.spans.length > this._maxlen ? e.spanRecorder = void 0 : this.spans.push(e);
|
|
1367
|
+
}
|
|
1368
|
+
};
|
|
1369
|
+
var X = class {
|
|
1370
|
+
constructor(e = {}) {
|
|
1371
|
+
this.traceId = e.traceId || g(), this.spanId = e.spanId || g().substring(16), this.startTimestamp = e.startTimestamp || G(), this.tags = e.tags || {}, this.data = e.data || {}, this.instrumenter = e.instrumenter || "sentry", this.origin = e.origin || "manual", e.parentSpanId && (this.parentSpanId = e.parentSpanId), "sampled" in e && (this.sampled = e.sampled), e.op && (this.op = e.op), e.description && (this.description = e.description), e.name && (this.description = e.name), e.status && (this.status = e.status), e.endTimestamp && (this.endTimestamp = e.endTimestamp);
|
|
1372
|
+
}
|
|
1373
|
+
get name() {
|
|
1374
|
+
return this.description || "";
|
|
1375
|
+
}
|
|
1376
|
+
set name(e) {
|
|
1377
|
+
this.setName(e);
|
|
1378
|
+
}
|
|
1379
|
+
startChild(e) {
|
|
1380
|
+
let n = new X({ ...e, parentSpanId: this.spanId, sampled: this.sampled, traceId: this.traceId });
|
|
1381
|
+
if (n.spanRecorder = this.spanRecorder, n.spanRecorder && n.spanRecorder.add(n), n.transaction = this.transaction, (typeof __SENTRY_DEBUG__ > "u" || __SENTRY_DEBUG__) && n.transaction) {
|
|
1382
|
+
let r = e && e.op || "< unknown op >", s = n.transaction.name || "< unknown name >", i = n.transaction.spanId, o = `[Tracing] Starting '${r}' span on transaction '${s}' (${i}).`;
|
|
1383
|
+
n.transaction.metadata.spanMetadata[n.spanId] = { logMessage: o }, f.log(o);
|
|
1384
|
+
}
|
|
1385
|
+
return n;
|
|
1386
|
+
}
|
|
1387
|
+
setTag(e, n) {
|
|
1388
|
+
return this.tags = { ...this.tags, [e]: n }, this;
|
|
1389
|
+
}
|
|
1390
|
+
setData(e, n) {
|
|
1391
|
+
return this.data = { ...this.data, [e]: n }, this;
|
|
1392
|
+
}
|
|
1393
|
+
setStatus(e) {
|
|
1394
|
+
return this.status = e, this;
|
|
1395
|
+
}
|
|
1396
|
+
setHttpStatus(e) {
|
|
1397
|
+
this.setTag("http.status_code", String(e)), this.setData("http.response.status_code", e);
|
|
1398
|
+
let n = Yr(e);
|
|
1399
|
+
return n !== "unknown_error" && this.setStatus(n), this;
|
|
1400
|
+
}
|
|
1401
|
+
setName(e) {
|
|
1402
|
+
this.description = e;
|
|
1403
|
+
}
|
|
1404
|
+
isSuccess() {
|
|
1405
|
+
return this.status === "ok";
|
|
1406
|
+
}
|
|
1407
|
+
finish(e) {
|
|
1408
|
+
if ((typeof __SENTRY_DEBUG__ > "u" || __SENTRY_DEBUG__) && this.transaction && this.transaction.spanId !== this.spanId) {
|
|
1409
|
+
let { logMessage: n } = this.transaction.metadata.spanMetadata[this.spanId];
|
|
1410
|
+
n && f.log(n.replace("Starting", "Finishing"));
|
|
1411
|
+
}
|
|
1412
|
+
this.endTimestamp = typeof e == "number" ? e : G();
|
|
1413
|
+
}
|
|
1414
|
+
toTraceparent() {
|
|
1415
|
+
return ht(this.traceId, this.spanId, this.sampled);
|
|
1416
|
+
}
|
|
1417
|
+
toContext() {
|
|
1418
|
+
return E({ data: this.data, description: this.description, endTimestamp: this.endTimestamp, op: this.op, parentSpanId: this.parentSpanId, sampled: this.sampled, spanId: this.spanId, startTimestamp: this.startTimestamp, status: this.status, tags: this.tags, traceId: this.traceId });
|
|
1419
|
+
}
|
|
1420
|
+
updateWithContext(e) {
|
|
1421
|
+
return this.data = e.data || {}, this.description = e.description, this.endTimestamp = e.endTimestamp, this.op = e.op, this.parentSpanId = e.parentSpanId, this.sampled = e.sampled, this.spanId = e.spanId || this.spanId, this.startTimestamp = e.startTimestamp || this.startTimestamp, this.status = e.status, this.tags = e.tags || {}, this.traceId = e.traceId || this.traceId, this;
|
|
1422
|
+
}
|
|
1423
|
+
getTraceContext() {
|
|
1424
|
+
return E({ data: Object.keys(this.data).length > 0 ? this.data : void 0, description: this.description, op: this.op, parent_span_id: this.parentSpanId, span_id: this.spanId, status: this.status, tags: Object.keys(this.tags).length > 0 ? this.tags : void 0, trace_id: this.traceId });
|
|
1425
|
+
}
|
|
1426
|
+
toJSON() {
|
|
1427
|
+
return E({ data: Object.keys(this.data).length > 0 ? this.data : void 0, description: this.description, op: this.op, parent_span_id: this.parentSpanId, span_id: this.spanId, start_timestamp: this.startTimestamp, status: this.status, tags: Object.keys(this.tags).length > 0 ? this.tags : void 0, timestamp: this.endTimestamp, trace_id: this.traceId, origin: this.origin });
|
|
1428
|
+
}
|
|
1429
|
+
};
|
|
1430
|
+
function Yr(t) {
|
|
1431
|
+
if (t < 400 && t >= 100) return "ok";
|
|
1432
|
+
if (t >= 400 && t < 500) switch (t) {
|
|
1433
|
+
case 401:
|
|
1434
|
+
return "unauthenticated";
|
|
1435
|
+
case 403:
|
|
1436
|
+
return "permission_denied";
|
|
1437
|
+
case 404:
|
|
1438
|
+
return "not_found";
|
|
1439
|
+
case 409:
|
|
1440
|
+
return "already_exists";
|
|
1441
|
+
case 413:
|
|
1442
|
+
return "failed_precondition";
|
|
1443
|
+
case 429:
|
|
1444
|
+
return "resource_exhausted";
|
|
1445
|
+
default:
|
|
1446
|
+
return "invalid_argument";
|
|
1447
|
+
}
|
|
1448
|
+
if (t >= 500 && t < 600) switch (t) {
|
|
1449
|
+
case 501:
|
|
1450
|
+
return "unimplemented";
|
|
1451
|
+
case 503:
|
|
1452
|
+
return "unavailable";
|
|
1453
|
+
case 504:
|
|
1454
|
+
return "deadline_exceeded";
|
|
1455
|
+
default:
|
|
1456
|
+
return "internal_error";
|
|
1457
|
+
}
|
|
1458
|
+
return "unknown_error";
|
|
1459
|
+
}
|
|
1460
|
+
function Z(t, e, n) {
|
|
1461
|
+
let r = e.getOptions(), { publicKey: s } = e.getDsn() || {}, { segment: i } = n && n.getUser() || {}, o = E({ environment: r.environment || J, release: r.release, user_segment: i, public_key: s, trace_id: t });
|
|
1462
|
+
return e.emit && e.emit("createDsc", o), o;
|
|
1463
|
+
}
|
|
1464
|
+
var Ue = class extends X {
|
|
1465
|
+
constructor(e, n) {
|
|
1466
|
+
super(e), delete this.description, this._measurements = {}, this._contexts = {}, this._hub = n || R(), this._name = e.name || "", this.metadata = { source: "custom", ...e.metadata, spanMetadata: {} }, this._trimEnd = e.trimEnd, this.transaction = this;
|
|
1467
|
+
let r = this.metadata.dynamicSamplingContext;
|
|
1468
|
+
r && (this._frozenDynamicSamplingContext = { ...r });
|
|
1469
|
+
}
|
|
1470
|
+
get name() {
|
|
1471
|
+
return this._name;
|
|
1472
|
+
}
|
|
1473
|
+
set name(e) {
|
|
1474
|
+
this.setName(e);
|
|
1475
|
+
}
|
|
1476
|
+
setName(e, n = "custom") {
|
|
1477
|
+
this._name = e, this.metadata.source = n;
|
|
1478
|
+
}
|
|
1479
|
+
initSpanRecorder(e = 1e3) {
|
|
1480
|
+
this.spanRecorder || (this.spanRecorder = new Me(e)), this.spanRecorder.add(this);
|
|
1481
|
+
}
|
|
1482
|
+
setContext(e, n) {
|
|
1483
|
+
n === null ? delete this._contexts[e] : this._contexts[e] = n;
|
|
1484
|
+
}
|
|
1485
|
+
setMeasurement(e, n, r = "") {
|
|
1486
|
+
this._measurements[e] = { value: n, unit: r };
|
|
1487
|
+
}
|
|
1488
|
+
setMetadata(e) {
|
|
1489
|
+
this.metadata = { ...this.metadata, ...e };
|
|
1490
|
+
}
|
|
1491
|
+
finish(e) {
|
|
1492
|
+
let n = this._finishTransaction(e);
|
|
1493
|
+
if (n) return this._hub.captureEvent(n);
|
|
1494
|
+
}
|
|
1495
|
+
toContext() {
|
|
1496
|
+
let e = super.toContext();
|
|
1497
|
+
return E({ ...e, name: this.name, trimEnd: this._trimEnd });
|
|
1498
|
+
}
|
|
1499
|
+
updateWithContext(e) {
|
|
1500
|
+
return super.updateWithContext(e), this.name = e.name || "", this._trimEnd = e.trimEnd, this;
|
|
1501
|
+
}
|
|
1502
|
+
getDynamicSamplingContext() {
|
|
1503
|
+
if (this._frozenDynamicSamplingContext) return this._frozenDynamicSamplingContext;
|
|
1504
|
+
let e = this._hub || R(), n = e.getClient();
|
|
1505
|
+
if (!n) return {};
|
|
1506
|
+
let r = e.getScope(), s = Z(this.traceId, n, r), i = this.metadata.sampleRate;
|
|
1507
|
+
i !== void 0 && (s.sample_rate = `${i}`);
|
|
1508
|
+
let o = this.metadata.source;
|
|
1509
|
+
return o && o !== "url" && (s.transaction = this.name), this.sampled !== void 0 && (s.sampled = String(this.sampled)), s;
|
|
1510
|
+
}
|
|
1511
|
+
setHub(e) {
|
|
1512
|
+
this._hub = e;
|
|
1513
|
+
}
|
|
1514
|
+
_finishTransaction(e) {
|
|
1515
|
+
if (this.endTimestamp !== void 0) return;
|
|
1516
|
+
this.name || ((typeof __SENTRY_DEBUG__ > "u" || __SENTRY_DEBUG__) && f.warn("Transaction has no name, falling back to `<unlabeled transaction>`."), this.name = "<unlabeled transaction>"), super.finish(e);
|
|
1517
|
+
let n = this._hub.getClient();
|
|
1518
|
+
if (n && n.emit && n.emit("finishTransaction", this), this.sampled !== true) {
|
|
1519
|
+
(typeof __SENTRY_DEBUG__ > "u" || __SENTRY_DEBUG__) && f.log("[Tracing] Discarding transaction because its trace was not chosen to be sampled."), n && n.recordDroppedEvent("sample_rate", "transaction");
|
|
1520
|
+
return;
|
|
1521
|
+
}
|
|
1522
|
+
let r = this.spanRecorder ? this.spanRecorder.spans.filter((a) => a !== this && a.endTimestamp) : [];
|
|
1523
|
+
this._trimEnd && r.length > 0 && (this.endTimestamp = r.reduce((a, c) => a.endTimestamp && c.endTimestamp ? a.endTimestamp > c.endTimestamp ? a : c : a).endTimestamp);
|
|
1524
|
+
let s = this.metadata, i = { contexts: { ...this._contexts, trace: this.getTraceContext() }, spans: r, start_timestamp: this.startTimestamp, tags: this.tags, timestamp: this.endTimestamp, transaction: this.name, type: "transaction", sdkProcessingMetadata: { ...s, dynamicSamplingContext: this.getDynamicSamplingContext() }, ...s.source && { transaction_info: { source: s.source } } };
|
|
1525
|
+
return Object.keys(this._measurements).length > 0 && ((typeof __SENTRY_DEBUG__ > "u" || __SENTRY_DEBUG__) && f.log("[Measurements] Adding measurements to transaction", JSON.stringify(this._measurements, void 0, 2)), i.measurements = this._measurements), (typeof __SENTRY_DEBUG__ > "u" || __SENTRY_DEBUG__) && f.log(`[Tracing] Finishing ${this.op} transaction: ${this.name}.`), i;
|
|
1526
|
+
}
|
|
1527
|
+
};
|
|
1528
|
+
function Dn(t) {
|
|
1529
|
+
if (typeof __SENTRY_TRACING__ == "boolean" && !__SENTRY_TRACING__) return false;
|
|
1530
|
+
let e = R().getClient(), n = t || e && e.getOptions();
|
|
1531
|
+
return !!n && (n.enableTracing || "tracesSampleRate" in n || "tracesSampler" in n);
|
|
1532
|
+
}
|
|
1533
|
+
function wn(t, e, n) {
|
|
1534
|
+
if (!Dn(e)) return t.sampled = false, t;
|
|
1535
|
+
if (t.sampled !== void 0) return t.setMetadata({ sampleRate: Number(t.sampled) }), t;
|
|
1536
|
+
let r;
|
|
1537
|
+
return typeof e.tracesSampler == "function" ? (r = e.tracesSampler(n), t.setMetadata({ sampleRate: Number(r) })) : n.parentSampled !== void 0 ? r = n.parentSampled : typeof e.tracesSampleRate < "u" ? (r = e.tracesSampleRate, t.setMetadata({ sampleRate: Number(r) })) : (r = 1, t.setMetadata({ sampleRate: r })), jr(r) ? r ? (t.sampled = Math.random() < r, t.sampled ? ((typeof __SENTRY_DEBUG__ > "u" || __SENTRY_DEBUG__) && f.log(`[Tracing] starting ${t.op} transaction - ${t.name}`), t) : ((typeof __SENTRY_DEBUG__ > "u" || __SENTRY_DEBUG__) && f.log(`[Tracing] Discarding transaction because it's not included in the random sample (sampling rate = ${Number(r)})`), t)) : ((typeof __SENTRY_DEBUG__ > "u" || __SENTRY_DEBUG__) && f.log(`[Tracing] Discarding transaction because ${typeof e.tracesSampler == "function" ? "tracesSampler returned 0 or false" : "a negative sampling decision was inherited or tracesSampleRate is set to 0"}`), t.sampled = false, t) : ((typeof __SENTRY_DEBUG__ > "u" || __SENTRY_DEBUG__) && f.warn("[Tracing] Discarding transaction because of invalid sample rate."), t.sampled = false, t);
|
|
1538
|
+
}
|
|
1539
|
+
function jr(t) {
|
|
1540
|
+
return ee(t) || !(typeof t == "number" || typeof t == "boolean") ? ((typeof __SENTRY_DEBUG__ > "u" || __SENTRY_DEBUG__) && f.warn(`[Tracing] Given sample rate is invalid. Sample rate must be a boolean or a number between 0 and 1. Got ${JSON.stringify(t)} of type ${JSON.stringify(typeof t)}.`), false) : t < 0 || t > 1 ? ((typeof __SENTRY_DEBUG__ > "u" || __SENTRY_DEBUG__) && f.warn(`[Tracing] Given sample rate is invalid. Sample rate must be between 0 and 1. Got ${t}.`), false) : true;
|
|
1541
|
+
}
|
|
1542
|
+
function qr() {
|
|
1543
|
+
let e = this.getScope().getSpan();
|
|
1544
|
+
return e ? { "sentry-trace": e.toTraceparent() } : {};
|
|
1545
|
+
}
|
|
1546
|
+
function Wr(t, e) {
|
|
1547
|
+
let n = this.getClient(), r = n && n.getOptions() || {}, s = r.instrumenter || "sentry", i = t.instrumenter || "sentry";
|
|
1548
|
+
s !== i && ((typeof __SENTRY_DEBUG__ > "u" || __SENTRY_DEBUG__) && f.error(`A transaction was started with instrumenter=\`${i}\`, but the SDK is configured with the \`${s}\` instrumenter.
|
|
1549
|
+
The transaction will not be sampled. Please use the ${s} instrumentation to start transactions.`), t.sampled = false);
|
|
1550
|
+
let o = new Ue(t, this);
|
|
1551
|
+
return o = wn(o, r, { parentSampled: t.parentSampled, transactionContext: t, ...e }), o.sampled && o.initSpanRecorder(r._experiments && r._experiments.maxSpans), n && n.emit && n.emit("startTransaction", o), o;
|
|
1552
|
+
}
|
|
1553
|
+
function On() {
|
|
1554
|
+
let t = Y();
|
|
1555
|
+
t.__SENTRY__ && (t.__SENTRY__.extensions = t.__SENTRY__.extensions || {}, t.__SENTRY__.extensions.startTransaction || (t.__SENTRY__.extensions.startTransaction = Wr), t.__SENTRY__.extensions.traceHeaders || (t.__SENTRY__.extensions.traceHeaders = qr), An());
|
|
1556
|
+
}
|
|
1557
|
+
var Le = class {
|
|
1558
|
+
constructor(e, n) {
|
|
1559
|
+
this._client = e, this.flushTimeout = 60, this._pendingAggregates = {}, this._isEnabled = true, this._intervalId = setInterval(() => this.flush(), this.flushTimeout * 1e3), this._sessionAttrs = n;
|
|
1560
|
+
}
|
|
1561
|
+
flush() {
|
|
1562
|
+
let e = this.getSessionAggregates();
|
|
1563
|
+
e.aggregates.length !== 0 && (this._pendingAggregates = {}, this._client.sendSession(e));
|
|
1564
|
+
}
|
|
1565
|
+
getSessionAggregates() {
|
|
1566
|
+
let e = Object.keys(this._pendingAggregates).map((r) => this._pendingAggregates[parseInt(r)]), n = { attrs: this._sessionAttrs, aggregates: e };
|
|
1567
|
+
return E(n);
|
|
1568
|
+
}
|
|
1569
|
+
close() {
|
|
1570
|
+
clearInterval(this._intervalId), this._isEnabled = false, this.flush();
|
|
1571
|
+
}
|
|
1572
|
+
incrementSessionStatusCount() {
|
|
1573
|
+
if (!this._isEnabled) return;
|
|
1574
|
+
let e = R().getScope(), n = e.getRequestSession();
|
|
1575
|
+
n && n.status && (this._incrementSessionStatusCount(n.status, /* @__PURE__ */ new Date()), e.setRequestSession(void 0));
|
|
1576
|
+
}
|
|
1577
|
+
_incrementSessionStatusCount(e, n) {
|
|
1578
|
+
let r = new Date(n).setSeconds(0, 0);
|
|
1579
|
+
this._pendingAggregates[r] = this._pendingAggregates[r] || {};
|
|
1580
|
+
let s = this._pendingAggregates[r];
|
|
1581
|
+
switch (s.started || (s.started = new Date(r).toISOString()), e) {
|
|
1582
|
+
case "errored":
|
|
1583
|
+
return s.errored = (s.errored || 0) + 1, s.errored;
|
|
1584
|
+
case "ok":
|
|
1585
|
+
return s.exited = (s.exited || 0) + 1, s.exited;
|
|
1586
|
+
default:
|
|
1587
|
+
return s.crashed = (s.crashed || 0) + 1, s.crashed;
|
|
1588
|
+
}
|
|
1589
|
+
}
|
|
1590
|
+
};
|
|
1591
|
+
var zr = "7";
|
|
1592
|
+
function Vr(t) {
|
|
1593
|
+
let e = t.protocol ? `${t.protocol}:` : "", n = t.port ? `:${t.port}` : "";
|
|
1594
|
+
return `${e}//${t.host}${n}${t.path ? `/${t.path}` : ""}/api/`;
|
|
1595
|
+
}
|
|
1596
|
+
function Jr(t) {
|
|
1597
|
+
return `${Vr(t)}${t.projectId}/envelope/`;
|
|
1598
|
+
}
|
|
1599
|
+
function Kr(t, e) {
|
|
1600
|
+
return it({ sentry_key: t.publicKey, sentry_version: zr, ...e && { sentry_client: `${e.name}/${e.version}` } });
|
|
1601
|
+
}
|
|
1602
|
+
function vn(t, e = {}) {
|
|
1603
|
+
let n = typeof e == "string" ? e : e.tunnel, r = typeof e == "string" || !e._metadata ? void 0 : e._metadata.sdk;
|
|
1604
|
+
return n || `${Jr(t)}?${Kr(t, r)}`;
|
|
1605
|
+
}
|
|
1606
|
+
function Xr(t, e) {
|
|
1607
|
+
return e && (t.sdk = t.sdk || {}, t.sdk.name = t.sdk.name || e.name, t.sdk.version = t.sdk.version || e.version, t.sdk.integrations = [...t.sdk.integrations || [], ...e.integrations || []], t.sdk.packages = [...t.sdk.packages || [], ...e.packages || []]), t;
|
|
1608
|
+
}
|
|
1609
|
+
function kn(t, e, n, r) {
|
|
1610
|
+
let s = Ce(n), i = { sent_at: (/* @__PURE__ */ new Date()).toISOString(), ...s && { sdk: s }, ...!!r && e && { dsn: M(e) } }, o = "aggregates" in t ? [{ type: "sessions" }, t] : [{ type: "session" }, t.toJSON()];
|
|
1611
|
+
return U(i, [o]);
|
|
1612
|
+
}
|
|
1613
|
+
function Cn(t, e, n, r) {
|
|
1614
|
+
let s = Ce(n), i = t.type && t.type !== "replay_event" ? t.type : "event";
|
|
1615
|
+
Xr(t, n && n.sdk);
|
|
1616
|
+
let o = St(t, s, r, e);
|
|
1617
|
+
return delete t.sdkProcessingMetadata, U(o, [[{ type: i }, t]]);
|
|
1618
|
+
}
|
|
1619
|
+
var Pn = [];
|
|
1620
|
+
function Zr(t) {
|
|
1621
|
+
let e = {};
|
|
1622
|
+
return t.forEach((n) => {
|
|
1623
|
+
let { name: r } = n, s = e[r];
|
|
1624
|
+
s && !s.isDefaultInstance && n.isDefaultInstance || (e[r] = n);
|
|
1625
|
+
}), Object.keys(e).map((n) => e[n]);
|
|
1626
|
+
}
|
|
1627
|
+
function wt(t) {
|
|
1628
|
+
let e = t.defaultIntegrations || [], n = t.integrations;
|
|
1629
|
+
e.forEach((o) => {
|
|
1630
|
+
o.isDefaultInstance = true;
|
|
1631
|
+
});
|
|
1632
|
+
let r;
|
|
1633
|
+
Array.isArray(n) ? r = [...e, ...n] : typeof n == "function" ? r = ue(n(e)) : r = e;
|
|
1634
|
+
let s = Zr(r), i = Qr(s, (o) => o.name === "Debug");
|
|
1635
|
+
if (i !== -1) {
|
|
1636
|
+
let [o] = s.splice(i, 1);
|
|
1637
|
+
s.push(o);
|
|
1638
|
+
}
|
|
1639
|
+
return s;
|
|
1640
|
+
}
|
|
1641
|
+
function Mn(t, e) {
|
|
1642
|
+
let n = {};
|
|
1643
|
+
return e.forEach((r) => {
|
|
1644
|
+
r && Ot(t, r, n);
|
|
1645
|
+
}), n;
|
|
1646
|
+
}
|
|
1647
|
+
function Ot(t, e, n) {
|
|
1648
|
+
if (n[e.name] = e, Pn.indexOf(e.name) === -1 && (e.setupOnce(Sn, R), Pn.push(e.name)), t.on && typeof e.preprocessEvent == "function") {
|
|
1649
|
+
let r = e.preprocessEvent.bind(e);
|
|
1650
|
+
t.on("preprocessEvent", (s, i) => r(s, i, t));
|
|
1651
|
+
}
|
|
1652
|
+
if (t.addEventProcessor && typeof e.processEvent == "function") {
|
|
1653
|
+
let r = e.processEvent.bind(e), s = Object.assign((i, o) => r(i, o, t), { id: e.name });
|
|
1654
|
+
t.addEventProcessor(s);
|
|
1655
|
+
}
|
|
1656
|
+
(typeof __SENTRY_DEBUG__ > "u" || __SENTRY_DEBUG__) && f.log(`Integration installed: ${e.name}`);
|
|
1657
|
+
}
|
|
1658
|
+
function Qr(t, e) {
|
|
1659
|
+
for (let n = 0; n < t.length; n++) if (e(t[n]) === true) return n;
|
|
1660
|
+
return -1;
|
|
1661
|
+
}
|
|
1662
|
+
function Ln(t, e, n, r, s) {
|
|
1663
|
+
let { normalizeDepth: i = 3, normalizeMaxBreadth: o = 1e3 } = t, a = { ...e, event_id: e.event_id || n.event_id || g(), timestamp: e.timestamp || $() }, c = n.integrations || t.integrations.map((p) => p.name);
|
|
1664
|
+
es(a, t), rs(a, c), e.type === void 0 && ts(a, t.stackParser);
|
|
1665
|
+
let u = r;
|
|
1666
|
+
n.captureContext && (u = w.clone(u).update(n.captureContext));
|
|
1667
|
+
let l = b(a), d = s && s.getEventProcessors ? s.getEventProcessors() : [];
|
|
1668
|
+
if (u) {
|
|
1669
|
+
if (u.getAttachments) {
|
|
1670
|
+
let p = [...n.attachments || [], ...u.getAttachments()];
|
|
1671
|
+
p.length && (n.attachments = p);
|
|
1672
|
+
}
|
|
1673
|
+
l = u.applyToEvent(a, n, d);
|
|
1674
|
+
} else l = K([...d, ...le()], a, n);
|
|
1675
|
+
return l.then((p) => (p && ns(p), typeof i == "number" && i > 0 ? ss(p, i, o) : p));
|
|
1676
|
+
}
|
|
1677
|
+
function es(t, e) {
|
|
1678
|
+
let { environment: n, release: r, dist: s, maxValueLength: i = 250 } = e;
|
|
1679
|
+
"environment" in t || (t.environment = "environment" in e ? n : J), t.release === void 0 && r !== void 0 && (t.release = r), t.dist === void 0 && s !== void 0 && (t.dist = s), t.message && (t.message = P(t.message, i));
|
|
1680
|
+
let o = t.exception && t.exception.values && t.exception.values[0];
|
|
1681
|
+
o && o.value && (o.value = P(o.value, i));
|
|
1682
|
+
let a = t.request;
|
|
1683
|
+
a && a.url && (a.url = P(a.url, i));
|
|
1684
|
+
}
|
|
1685
|
+
var Un = /* @__PURE__ */ new WeakMap();
|
|
1686
|
+
function ts(t, e) {
|
|
1687
|
+
let n = h._sentryDebugIds;
|
|
1688
|
+
if (!n) return;
|
|
1689
|
+
let r, s = Un.get(e);
|
|
1690
|
+
s ? r = s : (r = /* @__PURE__ */ new Map(), Un.set(e, r));
|
|
1691
|
+
let i = Object.keys(n).reduce((o, a) => {
|
|
1692
|
+
let c, u = r.get(a);
|
|
1693
|
+
u ? c = u : (c = e(a), r.set(a, c));
|
|
1694
|
+
for (let l = c.length - 1; l >= 0; l--) {
|
|
1695
|
+
let d = c[l];
|
|
1696
|
+
if (d.filename) {
|
|
1697
|
+
o[d.filename] = n[a];
|
|
1698
|
+
break;
|
|
1699
|
+
}
|
|
1700
|
+
}
|
|
1701
|
+
return o;
|
|
1702
|
+
}, {});
|
|
1703
|
+
try {
|
|
1704
|
+
t.exception.values.forEach((o) => {
|
|
1705
|
+
o.stacktrace.frames.forEach((a) => {
|
|
1706
|
+
a.filename && (a.debug_id = i[a.filename]);
|
|
1707
|
+
});
|
|
1708
|
+
});
|
|
1709
|
+
} catch {
|
|
1710
|
+
}
|
|
1711
|
+
}
|
|
1712
|
+
function ns(t) {
|
|
1713
|
+
let e = {};
|
|
1714
|
+
try {
|
|
1715
|
+
t.exception.values.forEach((r) => {
|
|
1716
|
+
r.stacktrace.frames.forEach((s) => {
|
|
1717
|
+
s.debug_id && (s.abs_path ? e[s.abs_path] = s.debug_id : s.filename && (e[s.filename] = s.debug_id), delete s.debug_id);
|
|
1718
|
+
});
|
|
1719
|
+
});
|
|
1720
|
+
} catch {
|
|
1721
|
+
}
|
|
1722
|
+
if (Object.keys(e).length === 0) return;
|
|
1723
|
+
t.debug_meta = t.debug_meta || {}, t.debug_meta.images = t.debug_meta.images || [];
|
|
1724
|
+
let n = t.debug_meta.images;
|
|
1725
|
+
Object.keys(e).forEach((r) => {
|
|
1726
|
+
n.push({ type: "sourcemap", code_file: r, debug_id: e[r] });
|
|
1727
|
+
});
|
|
1728
|
+
}
|
|
1729
|
+
function rs(t, e) {
|
|
1730
|
+
e.length > 0 && (t.sdk = t.sdk || {}, t.sdk.integrations = [...t.sdk.integrations || [], ...e]);
|
|
1731
|
+
}
|
|
1732
|
+
function ss(t, e, n) {
|
|
1733
|
+
if (!t) return null;
|
|
1734
|
+
let r = { ...t, ...t.breadcrumbs && { breadcrumbs: t.breadcrumbs.map((s) => ({ ...s, ...s.data && { data: D(s.data, e, n) } })) }, ...t.user && { user: D(t.user, e, n) }, ...t.contexts && { contexts: D(t.contexts, e, n) }, ...t.extra && { extra: D(t.extra, e, n) } };
|
|
1735
|
+
return t.contexts && t.contexts.trace && r.contexts && (r.contexts.trace = t.contexts.trace, t.contexts.trace.data && (r.contexts.trace.data = D(t.contexts.trace.data, e, n))), t.spans && (r.spans = t.spans.map((s) => (s.data && (s.data = D(s.data, e, n)), s))), r;
|
|
1736
|
+
}
|
|
1737
|
+
var Bn = "Not capturing exception because it's already been captured.";
|
|
1738
|
+
var Be = class {
|
|
1739
|
+
constructor(e) {
|
|
1740
|
+
if (this._options = e, this._integrations = {}, this._integrationsInitialized = false, this._numProcessing = 0, this._outcomes = {}, this._hooks = {}, this._eventProcessors = [], e.dsn ? this._dsn = Se(e.dsn) : (typeof __SENTRY_DEBUG__ > "u" || __SENTRY_DEBUG__) && f.warn("No DSN provided, client will not send events."), this._dsn) {
|
|
1741
|
+
let n = vn(this._dsn, e);
|
|
1742
|
+
this._transport = e.transport({ recordDroppedEvent: this.recordDroppedEvent.bind(this), ...e.transportOptions, url: n });
|
|
1743
|
+
}
|
|
1744
|
+
}
|
|
1745
|
+
captureException(e, n, r) {
|
|
1746
|
+
if (we(e)) {
|
|
1747
|
+
(typeof __SENTRY_DEBUG__ > "u" || __SENTRY_DEBUG__) && f.log(Bn);
|
|
1748
|
+
return;
|
|
1749
|
+
}
|
|
1750
|
+
let s = n && n.event_id;
|
|
1751
|
+
return this._process(this.eventFromException(e, n).then((i) => this._captureEvent(i, n, r)).then((i) => {
|
|
1752
|
+
s = i;
|
|
1753
|
+
})), s;
|
|
1754
|
+
}
|
|
1755
|
+
captureMessage(e, n, r, s) {
|
|
1756
|
+
let i = r && r.event_id, o = ge(e) ? this.eventFromMessage(String(e), n, r) : this.eventFromException(e, r);
|
|
1757
|
+
return this._process(o.then((a) => this._captureEvent(a, r, s)).then((a) => {
|
|
1758
|
+
i = a;
|
|
1759
|
+
})), i;
|
|
1760
|
+
}
|
|
1761
|
+
captureEvent(e, n, r) {
|
|
1762
|
+
if (n && n.originalException && we(n.originalException)) {
|
|
1763
|
+
(typeof __SENTRY_DEBUG__ > "u" || __SENTRY_DEBUG__) && f.log(Bn);
|
|
1764
|
+
return;
|
|
1765
|
+
}
|
|
1766
|
+
let s = n && n.event_id;
|
|
1767
|
+
return this._process(this._captureEvent(e, n, r).then((i) => {
|
|
1768
|
+
s = i;
|
|
1769
|
+
})), s;
|
|
1770
|
+
}
|
|
1771
|
+
captureSession(e) {
|
|
1772
|
+
typeof e.release != "string" ? (typeof __SENTRY_DEBUG__ > "u" || __SENTRY_DEBUG__) && f.warn("Discarded session because of missing or non-string release") : (this.sendSession(e), C(e, { init: false }));
|
|
1773
|
+
}
|
|
1774
|
+
getDsn() {
|
|
1775
|
+
return this._dsn;
|
|
1776
|
+
}
|
|
1777
|
+
getOptions() {
|
|
1778
|
+
return this._options;
|
|
1779
|
+
}
|
|
1780
|
+
getSdkMetadata() {
|
|
1781
|
+
return this._options._metadata;
|
|
1782
|
+
}
|
|
1783
|
+
getTransport() {
|
|
1784
|
+
return this._transport;
|
|
1785
|
+
}
|
|
1786
|
+
flush(e) {
|
|
1787
|
+
let n = this._transport;
|
|
1788
|
+
return n ? this._isClientDoneProcessing(e).then((r) => n.flush(e).then((s) => r && s)) : b(true);
|
|
1789
|
+
}
|
|
1790
|
+
close(e) {
|
|
1791
|
+
return this.flush(e).then((n) => (this.getOptions().enabled = false, n));
|
|
1792
|
+
}
|
|
1793
|
+
getEventProcessors() {
|
|
1794
|
+
return this._eventProcessors;
|
|
1795
|
+
}
|
|
1796
|
+
addEventProcessor(e) {
|
|
1797
|
+
this._eventProcessors.push(e);
|
|
1798
|
+
}
|
|
1799
|
+
setupIntegrations(e) {
|
|
1800
|
+
(e && !this._integrationsInitialized || this._isEnabled() && !this._integrationsInitialized) && (this._integrations = Mn(this, this._options.integrations), this._integrationsInitialized = true);
|
|
1801
|
+
}
|
|
1802
|
+
getIntegrationById(e) {
|
|
1803
|
+
return this._integrations[e];
|
|
1804
|
+
}
|
|
1805
|
+
getIntegration(e) {
|
|
1806
|
+
try {
|
|
1807
|
+
return this._integrations[e.id] || null;
|
|
1808
|
+
} catch {
|
|
1809
|
+
return (typeof __SENTRY_DEBUG__ > "u" || __SENTRY_DEBUG__) && f.warn(`Cannot retrieve integration ${e.id} from the current Client`), null;
|
|
1810
|
+
}
|
|
1811
|
+
}
|
|
1812
|
+
addIntegration(e) {
|
|
1813
|
+
Ot(this, e, this._integrations);
|
|
1814
|
+
}
|
|
1815
|
+
sendEvent(e, n = {}) {
|
|
1816
|
+
this.emit("beforeSendEvent", e, n);
|
|
1817
|
+
let r = Cn(e, this._dsn, this._options._metadata, this._options.tunnel);
|
|
1818
|
+
for (let i of n.attachments || []) r = gt(r, yt(i, this._options.transportOptions && this._options.transportOptions.textEncoder));
|
|
1819
|
+
let s = this._sendEnvelope(r);
|
|
1820
|
+
s && s.then((i) => this.emit("afterSendEvent", e, i), null);
|
|
1821
|
+
}
|
|
1822
|
+
sendSession(e) {
|
|
1823
|
+
let n = kn(e, this._dsn, this._options._metadata, this._options.tunnel);
|
|
1824
|
+
this._sendEnvelope(n);
|
|
1825
|
+
}
|
|
1826
|
+
recordDroppedEvent(e, n, r) {
|
|
1827
|
+
if (this._options.sendClientReports) {
|
|
1828
|
+
let s = `${e}:${n}`;
|
|
1829
|
+
(typeof __SENTRY_DEBUG__ > "u" || __SENTRY_DEBUG__) && f.log(`Adding outcome: "${s}"`), this._outcomes[s] = this._outcomes[s] + 1 || 1;
|
|
1830
|
+
}
|
|
1831
|
+
}
|
|
1832
|
+
on(e, n) {
|
|
1833
|
+
this._hooks[e] || (this._hooks[e] = []), this._hooks[e].push(n);
|
|
1834
|
+
}
|
|
1835
|
+
emit(e, ...n) {
|
|
1836
|
+
this._hooks[e] && this._hooks[e].forEach((r) => r(...n));
|
|
1837
|
+
}
|
|
1838
|
+
_updateSessionFromEvent(e, n) {
|
|
1839
|
+
let r = false, s = false, i = n.exception && n.exception.values;
|
|
1840
|
+
if (i) {
|
|
1841
|
+
s = true;
|
|
1842
|
+
for (let c of i) {
|
|
1843
|
+
let u = c.mechanism;
|
|
1844
|
+
if (u && u.handled === false) {
|
|
1845
|
+
r = true;
|
|
1846
|
+
break;
|
|
1847
|
+
}
|
|
1848
|
+
}
|
|
1849
|
+
}
|
|
1850
|
+
let o = e.status === "ok";
|
|
1851
|
+
(o && e.errors === 0 || o && r) && (C(e, { ...r && { status: "crashed" }, errors: e.errors || Number(s || r) }), this.captureSession(e));
|
|
1852
|
+
}
|
|
1853
|
+
_isClientDoneProcessing(e) {
|
|
1854
|
+
return new S((n) => {
|
|
1855
|
+
let r = 0, s = 1, i = setInterval(() => {
|
|
1856
|
+
this._numProcessing == 0 ? (clearInterval(i), n(true)) : (r += s, e && r >= e && (clearInterval(i), n(false)));
|
|
1857
|
+
}, s);
|
|
1858
|
+
});
|
|
1859
|
+
}
|
|
1860
|
+
_isEnabled() {
|
|
1861
|
+
return this.getOptions().enabled !== false && this._transport !== void 0;
|
|
1862
|
+
}
|
|
1863
|
+
_prepareEvent(e, n, r) {
|
|
1864
|
+
let s = this.getOptions(), i = Object.keys(this._integrations);
|
|
1865
|
+
return !n.integrations && i.length > 0 && (n.integrations = i), this.emit("preprocessEvent", e, n), Ln(s, e, n, r, this).then((o) => {
|
|
1866
|
+
if (o === null) return o;
|
|
1867
|
+
let { propagationContext: a } = o.sdkProcessingMetadata || {};
|
|
1868
|
+
if (!(o.contexts && o.contexts.trace) && a) {
|
|
1869
|
+
let { traceId: u, spanId: l, parentSpanId: d, dsc: p } = a;
|
|
1870
|
+
o.contexts = { trace: { trace_id: u, span_id: l, parent_span_id: d }, ...o.contexts };
|
|
1871
|
+
let m = p || Z(u, this, r);
|
|
1872
|
+
o.sdkProcessingMetadata = { dynamicSamplingContext: m, ...o.sdkProcessingMetadata };
|
|
1873
|
+
}
|
|
1874
|
+
return o;
|
|
1875
|
+
});
|
|
1876
|
+
}
|
|
1877
|
+
_captureEvent(e, n = {}, r) {
|
|
1878
|
+
return this._processEvent(e, n, r).then((s) => s.event_id, (s) => {
|
|
1879
|
+
if (typeof __SENTRY_DEBUG__ > "u" || __SENTRY_DEBUG__) {
|
|
1880
|
+
let i = s;
|
|
1881
|
+
i.logLevel === "log" ? f.log(i.message) : f.warn(i);
|
|
1882
|
+
}
|
|
1883
|
+
});
|
|
1884
|
+
}
|
|
1885
|
+
_processEvent(e, n, r) {
|
|
1886
|
+
let s = this.getOptions(), { sampleRate: i } = s, o = $n(e), a = Fn(e), c = e.type || "error", u = `before send for type \`${c}\``;
|
|
1887
|
+
if (a && typeof i == "number" && Math.random() > i) return this.recordDroppedEvent("sample_rate", "error", e), F(new T(`Discarding event because it's not included in the random sample (sampling rate = ${i})`, "log"));
|
|
1888
|
+
let l = c === "replay_event" ? "replay" : c;
|
|
1889
|
+
return this._prepareEvent(e, n, r).then((d) => {
|
|
1890
|
+
if (d === null) throw this.recordDroppedEvent("event_processor", l, e), new T("An event processor returned `null`, will not send event.", "log");
|
|
1891
|
+
if (n.data && n.data.__sentry__ === true) return d;
|
|
1892
|
+
let m = os(s, d, n);
|
|
1893
|
+
return is(m, u);
|
|
1894
|
+
}).then((d) => {
|
|
1895
|
+
if (d === null) throw this.recordDroppedEvent("before_send", l, e), new T(`${u} returned \`null\`, will not send event.`, "log");
|
|
1896
|
+
let p = r && r.getSession();
|
|
1897
|
+
!o && p && this._updateSessionFromEvent(p, d);
|
|
1898
|
+
let m = d.transaction_info;
|
|
1899
|
+
if (o && m && d.transaction !== e.transaction) {
|
|
1900
|
+
let O = "custom";
|
|
1901
|
+
d.transaction_info = { ...m, source: O };
|
|
1902
|
+
}
|
|
1903
|
+
return this.sendEvent(d, n), d;
|
|
1904
|
+
}).then(null, (d) => {
|
|
1905
|
+
throw d instanceof T ? d : (this.captureException(d, { data: { __sentry__: true }, originalException: d }), new T(`Event processing pipeline threw an error, original event will not be sent. Details have been sent as a new event.
|
|
1906
|
+
Reason: ${d}`));
|
|
1907
|
+
});
|
|
1908
|
+
}
|
|
1909
|
+
_process(e) {
|
|
1910
|
+
this._numProcessing++, e.then((n) => (this._numProcessing--, n), (n) => (this._numProcessing--, n));
|
|
1911
|
+
}
|
|
1912
|
+
_sendEnvelope(e) {
|
|
1913
|
+
if (this.emit("beforeEnvelope", e), this._isEnabled() && this._transport) return this._transport.send(e).then(null, (n) => {
|
|
1914
|
+
(typeof __SENTRY_DEBUG__ > "u" || __SENTRY_DEBUG__) && f.error("Error while sending event:", n);
|
|
1915
|
+
});
|
|
1916
|
+
(typeof __SENTRY_DEBUG__ > "u" || __SENTRY_DEBUG__) && f.error("Transport disabled");
|
|
1917
|
+
}
|
|
1918
|
+
_clearOutcomes() {
|
|
1919
|
+
let e = this._outcomes;
|
|
1920
|
+
return this._outcomes = {}, Object.keys(e).map((n) => {
|
|
1921
|
+
let [r, s] = n.split(":");
|
|
1922
|
+
return { reason: r, category: s, quantity: e[n] };
|
|
1923
|
+
});
|
|
1924
|
+
}
|
|
1925
|
+
};
|
|
1926
|
+
function is(t, e) {
|
|
1927
|
+
let n = `${e} must return \`null\` or a valid event.`;
|
|
1928
|
+
if (B(t)) return t.then((r) => {
|
|
1929
|
+
if (!x(r) && r !== null) throw new T(n);
|
|
1930
|
+
return r;
|
|
1931
|
+
}, (r) => {
|
|
1932
|
+
throw new T(`${e} rejected with ${r}`);
|
|
1933
|
+
});
|
|
1934
|
+
if (!x(t) && t !== null) throw new T(n);
|
|
1935
|
+
return t;
|
|
1936
|
+
}
|
|
1937
|
+
function os(t, e, n) {
|
|
1938
|
+
let { beforeSend: r, beforeSendTransaction: s } = t;
|
|
1939
|
+
return Fn(e) && r ? r(e, n) : $n(e) && s ? s(e, n) : e;
|
|
1940
|
+
}
|
|
1941
|
+
function Fn(t) {
|
|
1942
|
+
return t.type === void 0;
|
|
1943
|
+
}
|
|
1944
|
+
function $n(t) {
|
|
1945
|
+
return t.type === "transaction";
|
|
1946
|
+
}
|
|
1947
|
+
function Gn(t, e, n, r, s) {
|
|
1948
|
+
let i = { sent_at: (/* @__PURE__ */ new Date()).toISOString() };
|
|
1949
|
+
n && n.sdk && (i.sdk = { name: n.sdk.name, version: n.sdk.version }), r && s && (i.dsn = M(s)), e && (i.trace = E(e));
|
|
1950
|
+
let o = as(t);
|
|
1951
|
+
return U(i, [o]);
|
|
1952
|
+
}
|
|
1953
|
+
function as(t) {
|
|
1954
|
+
return [{ type: "check_in" }, t];
|
|
1955
|
+
}
|
|
1956
|
+
var fe = class extends Be {
|
|
1957
|
+
constructor(e) {
|
|
1958
|
+
On(), super(e);
|
|
1959
|
+
}
|
|
1960
|
+
eventFromException(e, n) {
|
|
1961
|
+
return b(xt(R, this._options.stackParser, e, n));
|
|
1962
|
+
}
|
|
1963
|
+
eventFromMessage(e, n = "info", r) {
|
|
1964
|
+
return b(It(this._options.stackParser, e, n, r, this._options.attachStacktrace));
|
|
1965
|
+
}
|
|
1966
|
+
captureException(e, n, r) {
|
|
1967
|
+
if (this._options.autoSessionTracking && this._sessionFlusher && r) {
|
|
1968
|
+
let s = r.getRequestSession();
|
|
1969
|
+
s && s.status === "ok" && (s.status = "errored");
|
|
1970
|
+
}
|
|
1971
|
+
return super.captureException(e, n, r);
|
|
1972
|
+
}
|
|
1973
|
+
captureEvent(e, n, r) {
|
|
1974
|
+
if (this._options.autoSessionTracking && this._sessionFlusher && r && (e.type || "exception") === "exception" && e.exception && e.exception.values && e.exception.values.length > 0) {
|
|
1975
|
+
let o = r.getRequestSession();
|
|
1976
|
+
o && o.status === "ok" && (o.status = "errored");
|
|
1977
|
+
}
|
|
1978
|
+
return super.captureEvent(e, n, r);
|
|
1979
|
+
}
|
|
1980
|
+
close(e) {
|
|
1981
|
+
return this._sessionFlusher && this._sessionFlusher.close(), super.close(e);
|
|
1982
|
+
}
|
|
1983
|
+
initSessionFlusher() {
|
|
1984
|
+
let { release: e, environment: n } = this._options;
|
|
1985
|
+
e ? this._sessionFlusher = new Le(this, { release: e, environment: n }) : (typeof __SENTRY_DEBUG__ > "u" || __SENTRY_DEBUG__) && f.warn("Cannot initialise an instance of SessionFlusher if no release is provided!");
|
|
1986
|
+
}
|
|
1987
|
+
captureCheckIn(e, n, r) {
|
|
1988
|
+
let s = e.status !== "in_progress" && e.checkInId ? e.checkInId : g();
|
|
1989
|
+
if (!this._isEnabled()) return (typeof __SENTRY_DEBUG__ > "u" || __SENTRY_DEBUG__) && f.warn("SDK not enabled, will not capture checkin."), s;
|
|
1990
|
+
let i = this.getOptions(), { release: o, environment: a, tunnel: c } = i, u = { check_in_id: s, monitor_slug: e.monitorSlug, status: e.status, release: o, environment: a };
|
|
1991
|
+
e.status !== "in_progress" && (u.duration = e.duration), n && (u.monitor_config = { schedule: n.schedule, checkin_margin: n.checkinMargin, max_runtime: n.maxRuntime, timezone: n.timezone });
|
|
1992
|
+
let [l, d] = this._getTraceInfoFromScope(r);
|
|
1993
|
+
d && (u.contexts = { trace: d });
|
|
1994
|
+
let p = Gn(u, l, this.getSdkMetadata(), c, this.getDsn());
|
|
1995
|
+
return (typeof __SENTRY_DEBUG__ > "u" || __SENTRY_DEBUG__) && f.info("Sending checkin:", e.monitorSlug, e.status), this._sendEnvelope(p), s;
|
|
1996
|
+
}
|
|
1997
|
+
_captureRequestSession() {
|
|
1998
|
+
this._sessionFlusher ? this._sessionFlusher.incrementSessionStatusCount() : (typeof __SENTRY_DEBUG__ > "u" || __SENTRY_DEBUG__) && f.warn("Discarded request mode session because autoSessionTracking option was disabled");
|
|
1999
|
+
}
|
|
2000
|
+
_prepareEvent(e, n, r) {
|
|
2001
|
+
return this._options.platform && (e.platform = e.platform || this._options.platform), this._options.runtime && (e.contexts = { ...e.contexts, runtime: (e.contexts || {}).runtime || this._options.runtime }), this._options.serverName && (e.server_name = e.server_name || this._options.serverName), super._prepareEvent(e, n, r);
|
|
2002
|
+
}
|
|
2003
|
+
_getTraceInfoFromScope(e) {
|
|
2004
|
+
if (!e) return [void 0, void 0];
|
|
2005
|
+
let n = e.getSpan();
|
|
2006
|
+
if (n) return [n.transaction ? n.transaction.getDynamicSamplingContext() : void 0, n.getTraceContext()];
|
|
2007
|
+
let { traceId: r, spanId: s, parentSpanId: i, dsc: o } = e.getPropagationContext(), a = { trace_id: r, span_id: s, parent_span_id: i };
|
|
2008
|
+
return o ? [o, a] : [Z(r, this, e), a];
|
|
2009
|
+
}
|
|
2010
|
+
};
|
|
2011
|
+
var cs = 30;
|
|
2012
|
+
function vt(t, e, n = ft(t.bufferSize || cs)) {
|
|
2013
|
+
let r = {}, s = (o) => n.drain(o);
|
|
2014
|
+
function i(o) {
|
|
2015
|
+
let a = [];
|
|
2016
|
+
if (ve(o, (d, p) => {
|
|
2017
|
+
let m = ke(p);
|
|
2018
|
+
if (Tt(r, m)) {
|
|
2019
|
+
let O = Hn(d, p);
|
|
2020
|
+
t.recordDroppedEvent("ratelimit_backoff", m, O);
|
|
2021
|
+
} else a.push(d);
|
|
2022
|
+
}), a.length === 0) return b();
|
|
2023
|
+
let c = U(o[0], a), u = (d) => {
|
|
2024
|
+
ve(c, (p, m) => {
|
|
2025
|
+
let O = Hn(p, m);
|
|
2026
|
+
t.recordDroppedEvent(d, ke(m), O);
|
|
2027
|
+
});
|
|
2028
|
+
}, l = () => e({ body: Et(c, t.textEncoder) }).then((d) => (d.statusCode !== void 0 && (d.statusCode < 200 || d.statusCode >= 300) && (typeof __SENTRY_DEBUG__ > "u" || __SENTRY_DEBUG__) && f.warn(`Sentry responded with status code ${d.statusCode} to sent event.`), r = bt(r, d), d), (d) => {
|
|
2029
|
+
throw u("network_error"), d;
|
|
2030
|
+
});
|
|
2031
|
+
return n.add(l).then((d) => d, (d) => {
|
|
2032
|
+
if (d instanceof T) return (typeof __SENTRY_DEBUG__ > "u" || __SENTRY_DEBUG__) && f.error("Skipped sending event because buffer is full."), u("queue_overflow"), b();
|
|
2033
|
+
throw d;
|
|
2034
|
+
});
|
|
2035
|
+
}
|
|
2036
|
+
return i.__sentry__baseTransport__ = true, { send: i, flush: s };
|
|
2037
|
+
}
|
|
2038
|
+
function Hn(t, e) {
|
|
2039
|
+
if (!(e !== "event" && e !== "transaction")) return Array.isArray(t) ? t[1] : void 0;
|
|
2040
|
+
}
|
|
2041
|
+
function jn(t) {
|
|
2042
|
+
return typeof t == "object" && t !== null;
|
|
2043
|
+
}
|
|
2044
|
+
function us(t) {
|
|
2045
|
+
return jn(t) && "handled" in t && typeof t.handled == "boolean" && "type" in t && typeof t.type == "string";
|
|
2046
|
+
}
|
|
2047
|
+
function ds(t) {
|
|
2048
|
+
return jn(t) && "mechanism" in t && us(t.mechanism);
|
|
2049
|
+
}
|
|
2050
|
+
function ls() {
|
|
2051
|
+
if (h.SENTRY_RELEASE && h.SENTRY_RELEASE.id) return h.SENTRY_RELEASE.id;
|
|
2052
|
+
}
|
|
2053
|
+
function Yn(t, e) {
|
|
2054
|
+
return t !== void 0 ? (t[e[0]] = e[1], t) : { [e[0]]: e[1] };
|
|
2055
|
+
}
|
|
2056
|
+
function qn(t, e) {
|
|
2057
|
+
return t(e.stack || "", 1);
|
|
2058
|
+
}
|
|
2059
|
+
function fs(t) {
|
|
2060
|
+
let e = t && t.message;
|
|
2061
|
+
return e ? e.error && typeof e.error.message == "string" ? e.error.message : e : "No error message";
|
|
2062
|
+
}
|
|
2063
|
+
function Wn(t, e) {
|
|
2064
|
+
let n = { type: e.name || e.constructor.name, value: fs(e) }, r = qn(t, e);
|
|
2065
|
+
return r.length && (n.stacktrace = { frames: r }), n.type === void 0 && n.value === "" && (n.value = "Unrecoverable error caught"), n;
|
|
2066
|
+
}
|
|
2067
|
+
function ps(t, e, n, r) {
|
|
2068
|
+
let s, o = (r && r.data && ds(r.data) ? r.data.mechanism : void 0) ?? { handled: true, type: "generic" };
|
|
2069
|
+
if (L(n)) s = n;
|
|
2070
|
+
else {
|
|
2071
|
+
if (x(n)) {
|
|
2072
|
+
let c = `Non-Error exception captured with keys: ${re(n)}`, u = t?.getClient(), l = u && u.getOptions().normalizeDepth;
|
|
2073
|
+
t?.configureScope((d) => {
|
|
2074
|
+
d.setExtra("__serialized__", V(n, l));
|
|
2075
|
+
}), s = r && r.syntheticException || new Error(c), s.message = c;
|
|
2076
|
+
} else s = r && r.syntheticException || new Error(n), s.message = n;
|
|
2077
|
+
o.synthetic = true;
|
|
2078
|
+
}
|
|
2079
|
+
let a = { exception: { values: [Wn(e, s)] } };
|
|
2080
|
+
return ae(a, void 0, void 0), ce(a, o), { ...a, event_id: r && r.event_id };
|
|
2081
|
+
}
|
|
2082
|
+
function ms(t, e, n = "info", r, s) {
|
|
2083
|
+
let i = { event_id: r && r.event_id, level: n, message: e };
|
|
2084
|
+
if (s && r && r.syntheticException) {
|
|
2085
|
+
let o = qn(t, r.syntheticException);
|
|
2086
|
+
o.length && (i.exception = { values: [{ value: e, stacktrace: { frames: o } }] });
|
|
2087
|
+
}
|
|
2088
|
+
return i;
|
|
2089
|
+
}
|
|
2090
|
+
var hs = 5;
|
|
2091
|
+
var He = class {
|
|
2092
|
+
name = He.id;
|
|
2093
|
+
limit;
|
|
2094
|
+
constructor(e = {}) {
|
|
2095
|
+
this.limit = e.limit || hs;
|
|
2096
|
+
}
|
|
2097
|
+
setupOnce(e, n) {
|
|
2098
|
+
let r = n().getClient();
|
|
2099
|
+
r && e((s, i) => {
|
|
2100
|
+
let o = n().getIntegration(He);
|
|
2101
|
+
return o ? _s(r.getOptions().stackParser, o.limit, s, i) : s;
|
|
2102
|
+
});
|
|
2103
|
+
}
|
|
2104
|
+
};
|
|
2105
|
+
var Fe = He;
|
|
2106
|
+
he(Fe, "id", "LinkedErrors");
|
|
2107
|
+
function _s(t, e, n, r) {
|
|
2108
|
+
if (!n.exception || !n.exception.values || !r || !v(r.originalException, Error)) return n;
|
|
2109
|
+
let s = zn(t, e, r.originalException);
|
|
2110
|
+
return n.exception.values = [...s, ...n.exception.values], n;
|
|
2111
|
+
}
|
|
2112
|
+
function zn(t, e, n, r = []) {
|
|
2113
|
+
if (!v(n.cause, Error) || r.length + 1 >= e) return r;
|
|
2114
|
+
let s = Wn(t, n.cause);
|
|
2115
|
+
return zn(t, e, n.cause, [s, ...r]);
|
|
2116
|
+
}
|
|
2117
|
+
var gs = { allowedHeaders: ["CF-RAY", "CF-Worker"] };
|
|
2118
|
+
var Q;
|
|
2119
|
+
var Ye = class {
|
|
2120
|
+
constructor(e = {}) {
|
|
2121
|
+
he(this, "name", Ye.id);
|
|
2122
|
+
Ft(this, Q, void 0);
|
|
2123
|
+
$t(this, Q, { ...gs, ...e });
|
|
2124
|
+
}
|
|
2125
|
+
setupOnce(e, n) {
|
|
2126
|
+
n().getClient() && e((s) => {
|
|
2127
|
+
let { sdkProcessingMetadata: i } = s;
|
|
2128
|
+
return !n().getIntegration(Ye) || !i || ("request" in i && i.request instanceof Request && (s.request = ys(i.request, Qe(this, Q)), s.user = Es(s.user ?? {}, i.request, Qe(this, Q))), "requestData" in i && (s.request ? s.request.data = i.requestData : s.request = { data: i.requestData })), s;
|
|
2129
|
+
});
|
|
2130
|
+
}
|
|
2131
|
+
};
|
|
2132
|
+
var $e = Ye;
|
|
2133
|
+
Q = /* @__PURE__ */ new WeakMap(), he($e, "id", "RequestData");
|
|
2134
|
+
function Es(t, e, n) {
|
|
2135
|
+
let r = e.headers.get("CF-Connecting-IP"), { allowedIps: s } = n, i = { ...t };
|
|
2136
|
+
return !("ip_address" in t) && r && s !== void 0 && Ss(r, s) && (i.ip_address = r), Object.keys(i).length > 0 ? i : void 0;
|
|
2137
|
+
}
|
|
2138
|
+
function ys(t, e) {
|
|
2139
|
+
let n = t.headers.get("cookie"), r;
|
|
2140
|
+
if (n) try {
|
|
2141
|
+
r = Ts(n);
|
|
2142
|
+
} catch {
|
|
2143
|
+
}
|
|
2144
|
+
let s = {};
|
|
2145
|
+
for (let [u, l] of t.headers.entries()) u !== "cookie" && (s[u] = l);
|
|
2146
|
+
let i = { method: t.method, cookies: r, headers: s };
|
|
2147
|
+
try {
|
|
2148
|
+
let u = new URL(t.url);
|
|
2149
|
+
i.url = `${u.protocol}//${u.hostname}${u.pathname}`, i.query_string = u.search;
|
|
2150
|
+
} catch {
|
|
2151
|
+
let l = t.url.indexOf("?");
|
|
2152
|
+
l < 0 ? i.url = t.url : (i.url = t.url.substr(0, l), i.query_string = t.url.substr(l + 1));
|
|
2153
|
+
}
|
|
2154
|
+
let { allowedHeaders: o, allowedCookies: a, allowedSearchParams: c } = e;
|
|
2155
|
+
if (o !== void 0 && i.headers ? (i.headers = kt(i.headers, o), Object.keys(i.headers).length === 0 && delete i.headers) : delete i.headers, a !== void 0 && i.cookies ? (i.cookies = kt(i.cookies, a), Object.keys(i.cookies).length === 0 && delete i.cookies) : delete i.cookies, c !== void 0) {
|
|
2156
|
+
let u = Object.fromEntries(new URLSearchParams(i.query_string)), l = new URLSearchParams();
|
|
2157
|
+
Object.keys(kt(u, c)).forEach((d) => {
|
|
2158
|
+
l.set(d, u[d]);
|
|
2159
|
+
}), i.query_string = l.toString();
|
|
2160
|
+
} else delete i.query_string;
|
|
2161
|
+
return i;
|
|
2162
|
+
}
|
|
2163
|
+
function Ss(t, e) {
|
|
2164
|
+
return typeof e == "boolean" ? e : e instanceof RegExp ? e.test(t) : Array.isArray(e) ? e.map((r) => r.toLowerCase()).includes(t) : false;
|
|
2165
|
+
}
|
|
2166
|
+
function kt(t, e) {
|
|
2167
|
+
let n = () => false;
|
|
2168
|
+
if (typeof e == "boolean") return e ? t : {};
|
|
2169
|
+
if (e instanceof RegExp) n = (r) => e.test(r);
|
|
2170
|
+
else if (Array.isArray(e)) {
|
|
2171
|
+
let r = e.map((s) => s.toLowerCase());
|
|
2172
|
+
n = (s) => r.includes(s.toLowerCase());
|
|
2173
|
+
} else return {};
|
|
2174
|
+
return Object.keys(t).filter(n).reduce((r, s) => (r[s] = t[s], r), {});
|
|
2175
|
+
}
|
|
2176
|
+
function Ts(t) {
|
|
2177
|
+
if (typeof t != "string") return {};
|
|
2178
|
+
try {
|
|
2179
|
+
return t.split(";").map((e) => e.split("=")).reduce((e, [n, r]) => (e[decodeURIComponent(n.trim())] = decodeURIComponent(r.trim()), e), {});
|
|
2180
|
+
} catch {
|
|
2181
|
+
return {};
|
|
2182
|
+
}
|
|
2183
|
+
}
|
|
2184
|
+
function bs(t, e) {
|
|
2185
|
+
let n = {};
|
|
2186
|
+
return t.forEach((r) => {
|
|
2187
|
+
n[r.name] = r, r.setupOnce((s) => {
|
|
2188
|
+
e.getScope()?.addEventProcessor(s);
|
|
2189
|
+
}, () => e);
|
|
2190
|
+
}), n;
|
|
2191
|
+
}
|
|
2192
|
+
var Ct = class extends fe {
|
|
2193
|
+
#e = null;
|
|
2194
|
+
constructor(e) {
|
|
2195
|
+
e._metadata = e._metadata || {}, e._metadata.sdk = e._metadata.sdk || { name: "toucan-js", packages: [{ name: "npm:toucan-js", version: "3.3.1" }], version: "3.3.1" }, super(e);
|
|
2196
|
+
}
|
|
2197
|
+
setupIntegrations() {
|
|
2198
|
+
this._isEnabled() && !this._integrationsInitialized && this.#e && (this._integrations = bs(this._options.integrations, this.#e), this._integrationsInitialized = true);
|
|
2199
|
+
}
|
|
2200
|
+
eventFromException(e, n) {
|
|
2201
|
+
return b(ps(this.#e, this._options.stackParser, e, n));
|
|
2202
|
+
}
|
|
2203
|
+
eventFromMessage(e, n = "info", r) {
|
|
2204
|
+
return b(ms(this._options.stackParser, e, n, r, this._options.attachStacktrace));
|
|
2205
|
+
}
|
|
2206
|
+
_prepareEvent(e, n, r) {
|
|
2207
|
+
return e.platform = e.platform || "javascript", this.getOptions().request && (e.sdkProcessingMetadata = Yn(e.sdkProcessingMetadata, ["request", this.getOptions().request])), this.getOptions().requestData && (e.sdkProcessingMetadata = Yn(e.sdkProcessingMetadata, ["requestData", this.getOptions().requestData])), super._prepareEvent(e, n, r);
|
|
2208
|
+
}
|
|
2209
|
+
getSdk() {
|
|
2210
|
+
return this.#e;
|
|
2211
|
+
}
|
|
2212
|
+
setSdk(e) {
|
|
2213
|
+
this.#e = e;
|
|
2214
|
+
}
|
|
2215
|
+
setRequestBody(e) {
|
|
2216
|
+
this.getOptions().requestData = e;
|
|
2217
|
+
}
|
|
2218
|
+
setEnabled(e) {
|
|
2219
|
+
this.getOptions().enabled = e;
|
|
2220
|
+
}
|
|
2221
|
+
};
|
|
2222
|
+
function Rs(t) {
|
|
2223
|
+
let [e, n] = ct(t);
|
|
2224
|
+
return [e, (s) => {
|
|
2225
|
+
let i = n(s);
|
|
2226
|
+
if (i) {
|
|
2227
|
+
let o = i.filename;
|
|
2228
|
+
i.abs_path = o !== void 0 && !o.startsWith("/") ? `/${o}` : o, i.in_app = o !== void 0;
|
|
2229
|
+
}
|
|
2230
|
+
return i;
|
|
2231
|
+
}];
|
|
2232
|
+
}
|
|
2233
|
+
function xs(t) {
|
|
2234
|
+
if (t) return lt(t, ".js");
|
|
2235
|
+
}
|
|
2236
|
+
var Is = be(Rs(xs));
|
|
2237
|
+
function Ns(t) {
|
|
2238
|
+
function e({ body: n }) {
|
|
2239
|
+
try {
|
|
2240
|
+
let s = (t.fetcher ?? fetch)(t.url, { method: "POST", headers: t.headers, body: n }).then((i) => ({ statusCode: i.status, headers: { "retry-after": i.headers.get("Retry-After"), "x-sentry-rate-limits": i.headers.get("X-Sentry-Rate-Limits") } }));
|
|
2241
|
+
return t.context && t.context.waitUntil(s), s;
|
|
2242
|
+
} catch (r) {
|
|
2243
|
+
return F(r);
|
|
2244
|
+
}
|
|
2245
|
+
}
|
|
2246
|
+
return vt(t, e);
|
|
2247
|
+
}
|
|
2248
|
+
var Ge = class extends H {
|
|
2249
|
+
constructor(e) {
|
|
2250
|
+
if (e.defaultIntegrations = e.defaultIntegrations === false ? [] : [...Array.isArray(e.defaultIntegrations) ? e.defaultIntegrations : [new $e(e.requestDataOptions), new Fe()]], e.release === void 0) {
|
|
2251
|
+
let r = ls();
|
|
2252
|
+
r !== void 0 && (e.release = r);
|
|
2253
|
+
}
|
|
2254
|
+
let n = new Ct({ ...e, transport: Ns, integrations: wt(e), stackParser: at(e.stackParser || Is), transportOptions: { ...e.transportOptions, context: e.context } });
|
|
2255
|
+
super(n), n.setSdk(this), n.setupIntegrations();
|
|
2256
|
+
}
|
|
2257
|
+
setRequestBody(e) {
|
|
2258
|
+
this.getClient()?.setRequestBody(e);
|
|
2259
|
+
}
|
|
2260
|
+
setEnabled(e) {
|
|
2261
|
+
this.getClient()?.setEnabled(e);
|
|
2262
|
+
}
|
|
2263
|
+
captureCheckIn(e, n, r) {
|
|
2264
|
+
return e.status === "in_progress" && this.setContext("monitor", { slug: e.monitorSlug }), this.getClient().captureCheckIn(e, n, r);
|
|
2265
|
+
}
|
|
2266
|
+
};
|
|
2267
|
+
function Vn(t, e, n, r, s) {
|
|
2268
|
+
if (!(n && r && s)) return;
|
|
2269
|
+
let i = new Ge({ dsn: n, request: t, context: e, sampleRate: 1, requestDataOptions: { allowedHeaders: ["user-agent", "cf-challenge", "accept-encoding", "accept-language", "cf-ray", "content-length", "content-type", "host"], allowedSearchParams: /(.*)/ }, transportOptions: { headers: { "CF-Access-Client-ID": r, "CF-Access-Client-Secret": s } } }), o = t.cf?.colo ?? "UNKNOWN";
|
|
2270
|
+
i.setTag("colo", o);
|
|
2271
|
+
let a = t.headers.get("user-agent") ?? "UA UNKNOWN";
|
|
2272
|
+
return i.setUser({ userAgent: a, colo: o }), i;
|
|
2273
|
+
}
|
|
2274
|
+
var je = class {
|
|
2275
|
+
constructor(e) {
|
|
2276
|
+
this.data = {};
|
|
2277
|
+
this.readyAnalytics = e;
|
|
2278
|
+
}
|
|
2279
|
+
setData(e) {
|
|
2280
|
+
this.data = { ...this.data, ...e };
|
|
2281
|
+
}
|
|
2282
|
+
getData(e) {
|
|
2283
|
+
return this.data[e];
|
|
2284
|
+
}
|
|
2285
|
+
write() {
|
|
2286
|
+
this.readyAnalytics && this.readyAnalytics.logEvent({ version: 1, accountId: 0, indexId: this.data.hostname?.substring(0, 96), doubles: [this.data.requestTime ?? -1, this.data.coloId ?? -1, this.data.metalId ?? -1, this.data.coloTier ?? -1], blobs: [this.data.hostname?.substring(0, 256), this.data.userAgent?.substring(0, 256), this.data.htmlHandling, this.data.notFoundHandling, this.data.error?.substring(0, 256), this.data.version, this.data.coloRegion] });
|
|
2287
|
+
}
|
|
2288
|
+
};
|
|
2289
|
+
var We = class {
|
|
2290
|
+
constructor(e) {
|
|
2291
|
+
this.data = e;
|
|
2292
|
+
}
|
|
2293
|
+
async get(e) {
|
|
2294
|
+
let n = await ws(e), r = Pt(new Uint8Array(this.data, 20), n);
|
|
2295
|
+
return r ? vs(r) : null;
|
|
2296
|
+
}
|
|
2297
|
+
};
|
|
2298
|
+
var ws = async (t) => {
|
|
2299
|
+
let n = new TextEncoder().encode(t), r = await crypto.subtle.digest("SHA-256", n.buffer);
|
|
2300
|
+
return new Uint8Array(r, 0, 16);
|
|
2301
|
+
};
|
|
2302
|
+
var Pt = (t, e) => {
|
|
2303
|
+
if (t.byteLength === 0) return false;
|
|
2304
|
+
let n = t.byteOffset + (t.byteLength / 40 >> 1) * 40, r = new Uint8Array(t.buffer, n, 16);
|
|
2305
|
+
if (r.byteLength !== e.byteLength) throw new TypeError("Search value and current value are of different lengths");
|
|
2306
|
+
let s = Os(e, r);
|
|
2307
|
+
if (s < 0) {
|
|
2308
|
+
let i = t.byteOffset, o = n - t.byteOffset;
|
|
2309
|
+
return Pt(new Uint8Array(t.buffer, i, o), e);
|
|
2310
|
+
} else if (s > 0) {
|
|
2311
|
+
let i = n + 40, o = t.buffer.byteLength - n - 40;
|
|
2312
|
+
return Pt(new Uint8Array(t.buffer, i, o), e);
|
|
2313
|
+
} else return new Uint8Array(t.buffer, n, 40);
|
|
2314
|
+
};
|
|
2315
|
+
var Os = (t, e) => {
|
|
2316
|
+
if (t.byteLength < e.byteLength) return -1;
|
|
2317
|
+
if (t.byteLength > e.byteLength) return 1;
|
|
2318
|
+
for (let [n, r] of t.entries()) {
|
|
2319
|
+
if (r < e[n]) return -1;
|
|
2320
|
+
if (r > e[n]) return 1;
|
|
2321
|
+
}
|
|
2322
|
+
return 0;
|
|
2323
|
+
};
|
|
2324
|
+
var vs = (t) => [...t.slice(16, 16 + 16)].map((n) => n.toString(16).padStart(2, "0")).join("");
|
|
2325
|
+
var Mt = (t) => ({ html_handling: t?.html_handling ?? "auto-trailing-slash", not_found_handling: t?.not_found_handling ?? "none", serve_directly: t?.serve_directly ?? true });
|
|
2326
|
+
var ze = class extends Response {
|
|
2327
|
+
constructor(e, n) {
|
|
2328
|
+
super(e, { ...n, status: 200 });
|
|
2329
|
+
}
|
|
2330
|
+
};
|
|
2331
|
+
var me = class extends Response {
|
|
2332
|
+
constructor(...[e, n]) {
|
|
2333
|
+
super(e, { ...n, status: 404, statusText: "Not Found" });
|
|
2334
|
+
}
|
|
2335
|
+
};
|
|
2336
|
+
var Ve = class extends Response {
|
|
2337
|
+
constructor(...[e, n]) {
|
|
2338
|
+
super(e, { ...n, status: 405, statusText: "Method Not Allowed" });
|
|
2339
|
+
}
|
|
2340
|
+
};
|
|
2341
|
+
var j = class extends Response {
|
|
2342
|
+
constructor(e, n) {
|
|
2343
|
+
super(null, { ...n, status: 500 });
|
|
2344
|
+
}
|
|
2345
|
+
};
|
|
2346
|
+
var Je = class extends Response {
|
|
2347
|
+
constructor(...[e, n]) {
|
|
2348
|
+
super(null, { ...n, status: 304, statusText: "Not Modified" });
|
|
2349
|
+
}
|
|
2350
|
+
};
|
|
2351
|
+
var Ke = class extends Response {
|
|
2352
|
+
constructor(e, n) {
|
|
2353
|
+
super(null, { ...n, status: 307, statusText: "Temporary Redirect", headers: { ...n?.headers, Location: e } });
|
|
2354
|
+
}
|
|
2355
|
+
};
|
|
2356
|
+
var Jn = "public, max-age=0, must-revalidate";
|
|
2357
|
+
function Kn(t, e, n) {
|
|
2358
|
+
let r = new Headers({ "Content-Type": e, ETag: `"${t}"` });
|
|
2359
|
+
return ks(n) && r.append("Cache-Control", Jn), r;
|
|
2360
|
+
}
|
|
2361
|
+
function ks(t) {
|
|
2362
|
+
return !t.headers.has("Authorization") && !t.headers.has("Range");
|
|
2363
|
+
}
|
|
2364
|
+
var Xn = async (t, e, n, r, s) => {
|
|
2365
|
+
let { pathname: i, search: o } = new URL(t.url), a = Ut(i);
|
|
2366
|
+
a = a.replace(/\/+/g, "/");
|
|
2367
|
+
let c = await Xe(a, n, r);
|
|
2368
|
+
if (!c) return new me();
|
|
2369
|
+
let u = t.method.toUpperCase();
|
|
2370
|
+
if (!["GET", "HEAD"].includes(u)) return new Ve();
|
|
2371
|
+
let l = c.redirect ?? a, d = Ls(l);
|
|
2372
|
+
if (d !== i && c.asset || c.redirect) return new Ke(d + o);
|
|
2373
|
+
if (!c.asset) return new j(new Error("Unknown action"));
|
|
2374
|
+
let p = await e.JAEGER.enterSpan("getByETag", async (rr) => (rr.setTags({ pathname: i, eTag: c.asset.eTag, status: c.asset.status }), await s(c.asset.eTag))), m = Kn(c.asset.eTag, p.contentType, t), O = `"${c.asset.eTag}"`, tr = `W/${O}`, nr = t.headers.get("If-None-Match") || "";
|
|
2375
|
+
if ([tr, O].includes(nr)) return new Je(null, { headers: m });
|
|
2376
|
+
let Lt = u === "HEAD" ? null : p.readableStream;
|
|
2377
|
+
switch (c.asset.status) {
|
|
2378
|
+
case 404:
|
|
2379
|
+
return new me(Lt, { headers: m });
|
|
2380
|
+
case 200:
|
|
2381
|
+
return new ze(Lt, { headers: m });
|
|
2382
|
+
}
|
|
2383
|
+
};
|
|
2384
|
+
var Xe = async (t, e, n, r = false) => {
|
|
2385
|
+
switch (e.html_handling) {
|
|
2386
|
+
case "auto-trailing-slash":
|
|
2387
|
+
return Cs(t, e, n, r);
|
|
2388
|
+
case "force-trailing-slash":
|
|
2389
|
+
return Ps(t, e, n, r);
|
|
2390
|
+
case "drop-trailing-slash":
|
|
2391
|
+
return Ms(t, e, n, r);
|
|
2392
|
+
case "none":
|
|
2393
|
+
return Us(t, e, n);
|
|
2394
|
+
}
|
|
2395
|
+
};
|
|
2396
|
+
var Cs = async (t, e, n, r) => {
|
|
2397
|
+
let s = null, i = null, o = await n(t);
|
|
2398
|
+
if (t.endsWith("/index")) {
|
|
2399
|
+
if (o) return { asset: { eTag: o, status: 200 }, redirect: null };
|
|
2400
|
+
if (s = await _(`${t}.html`, t.slice(0, -5), e, n, r)) return s;
|
|
2401
|
+
if (s = await _(`${t.slice(0, -6)}.html`, t.slice(0, -6), e, n, r)) return s;
|
|
2402
|
+
} else if (t.endsWith("/index.html")) {
|
|
2403
|
+
if (s = await _(t, t.slice(0, -10), e, n, r)) return s;
|
|
2404
|
+
if (s = await _(`${t.slice(0, -11)}.html`, t.slice(0, -11), e, n, r)) return s;
|
|
2405
|
+
} else if (t.endsWith("/")) {
|
|
2406
|
+
if (i = await n(`${t}index.html`)) return { asset: { eTag: i, status: 200 }, redirect: null };
|
|
2407
|
+
if (s = await _(`${t.slice(0, -1)}.html`, t.slice(0, -1), e, n, r)) return s;
|
|
2408
|
+
} else if (t.endsWith(".html")) {
|
|
2409
|
+
if (s = await _(t, t.slice(0, -5), e, n, r)) return s;
|
|
2410
|
+
if (s = await _(`${t.slice(0, -5)}/index.html`, `${t.slice(0, -5)}/`, e, n, r)) return s;
|
|
2411
|
+
}
|
|
2412
|
+
return o ? { asset: { eTag: o, status: 200 }, redirect: null } : (i = await n(`${t}.html`)) ? { asset: { eTag: i, status: 200 }, redirect: null } : (s = await _(`${t}/index.html`, `${t}/`, e, n, r)) ? s : Ze(t, e, n);
|
|
2413
|
+
};
|
|
2414
|
+
var Ps = async (t, e, n, r) => {
|
|
2415
|
+
let s = null, i = null, o = await n(t);
|
|
2416
|
+
if (t.endsWith("/index")) {
|
|
2417
|
+
if (o) return { asset: { eTag: o, status: 200 }, redirect: null };
|
|
2418
|
+
if (s = await _(`${t}.html`, t.slice(0, -5), e, n, r)) return s;
|
|
2419
|
+
if (s = await _(`${t.slice(0, -6)}.html`, t.slice(0, -5), e, n, r)) return s;
|
|
2420
|
+
} else if (t.endsWith("/index.html")) {
|
|
2421
|
+
if (s = await _(t, t.slice(0, -10), e, n, r)) return s;
|
|
2422
|
+
if (s = await _(`${t.slice(0, -11)}.html`, t.slice(0, -10), e, n, r)) return s;
|
|
2423
|
+
} else if (t.endsWith("/")) {
|
|
2424
|
+
if (i = await n(`${t}index.html`)) return { asset: { eTag: i, status: 200 }, redirect: null };
|
|
2425
|
+
if (i = await n(`${t.slice(0, -1)}.html`)) return { asset: { eTag: i, status: 200 }, redirect: null };
|
|
2426
|
+
} else if (t.endsWith(".html")) {
|
|
2427
|
+
if (s = await _(t, `${t.slice(0, -5)}/`, e, n, r)) return s;
|
|
2428
|
+
if (o) return { asset: { eTag: o, status: 200 }, redirect: null };
|
|
2429
|
+
if (s = await _(`${t.slice(0, -5)}/index.html`, `${t.slice(0, -5)}/`, e, n, r)) return s;
|
|
2430
|
+
}
|
|
2431
|
+
return o ? { asset: { eTag: o, status: 200 }, redirect: null } : (s = await _(`${t}.html`, `${t}/`, e, n, r)) || (s = await _(`${t}/index.html`, `${t}/`, e, n, r)) ? s : Ze(t, e, n);
|
|
2432
|
+
};
|
|
2433
|
+
var Ms = async (t, e, n, r) => {
|
|
2434
|
+
let s = null, i = null, o = await n(t);
|
|
2435
|
+
if (t.endsWith("/index")) {
|
|
2436
|
+
if (o) return { asset: { eTag: o, status: 200 }, redirect: null };
|
|
2437
|
+
if (t === "/index") {
|
|
2438
|
+
if (s = await _("/index.html", "/", e, n, r)) return s;
|
|
2439
|
+
} else {
|
|
2440
|
+
if (s = await _(`${t.slice(0, -6)}.html`, t.slice(0, -6), e, n, r)) return s;
|
|
2441
|
+
if (s = await _(`${t}.html`, t.slice(0, -6), e, n, r)) return s;
|
|
2442
|
+
}
|
|
2443
|
+
} else if (t.endsWith("/index.html")) if (t === "/index.html") {
|
|
2444
|
+
if (s = await _("/index.html", "/", e, n, r)) return s;
|
|
2445
|
+
} else {
|
|
2446
|
+
if (s = await _(t, t.slice(0, -11), e, n, r)) return s;
|
|
2447
|
+
if (o) return { asset: { eTag: o, status: 200 }, redirect: null };
|
|
2448
|
+
if (s = await _(`${t.slice(0, -11)}.html`, t.slice(0, -11), e, n, r)) return s;
|
|
2449
|
+
}
|
|
2450
|
+
else if (t.endsWith("/")) if (t === "/") {
|
|
2451
|
+
if (i = await n("/index.html")) return { asset: { eTag: i, status: 200 }, redirect: null };
|
|
2452
|
+
} else {
|
|
2453
|
+
if (s = await _(`${t.slice(0, -1)}.html`, t.slice(0, -1), e, n, r)) return s;
|
|
2454
|
+
if (s = await _(`${t.slice(0, -1)}/index.html`, t.slice(0, -1), e, n, r)) return s;
|
|
2455
|
+
}
|
|
2456
|
+
else if (t.endsWith(".html")) {
|
|
2457
|
+
if (s = await _(t, t.slice(0, -5), e, n, r)) return s;
|
|
2458
|
+
if (s = await _(`${t.slice(0, -5)}/index.html`, t.slice(0, -5), e, n, r)) return s;
|
|
2459
|
+
}
|
|
2460
|
+
return o ? { asset: { eTag: o, status: 200 }, redirect: null } : (i = await n(`${t}.html`)) ? { asset: { eTag: i, status: 200 }, redirect: null } : (i = await n(`${t}/index.html`)) ? { asset: { eTag: i, status: 200 }, redirect: null } : Ze(t, e, n);
|
|
2461
|
+
};
|
|
2462
|
+
var Us = async (t, e, n) => {
|
|
2463
|
+
let r = await n(t);
|
|
2464
|
+
return r ? { asset: { eTag: r, status: 200 }, redirect: null } : Ze(t, e, n);
|
|
2465
|
+
};
|
|
2466
|
+
var Ze = async (t, e, n) => {
|
|
2467
|
+
switch (e.not_found_handling) {
|
|
2468
|
+
case "single-page-application": {
|
|
2469
|
+
let r = await n("/index.html");
|
|
2470
|
+
return r ? { asset: { eTag: r, status: 200 }, redirect: null } : null;
|
|
2471
|
+
}
|
|
2472
|
+
case "404-page": {
|
|
2473
|
+
let r = t;
|
|
2474
|
+
for (; r; ) {
|
|
2475
|
+
r = r.slice(0, r.lastIndexOf("/"));
|
|
2476
|
+
let s = await n(`${r}/404.html`);
|
|
2477
|
+
if (s) return { asset: { eTag: s, status: 404 }, redirect: null };
|
|
2478
|
+
}
|
|
2479
|
+
return null;
|
|
2480
|
+
}
|
|
2481
|
+
case "none":
|
|
2482
|
+
default:
|
|
2483
|
+
return null;
|
|
2484
|
+
}
|
|
2485
|
+
};
|
|
2486
|
+
var _ = async (t, e, n, r, s) => {
|
|
2487
|
+
if (s) return null;
|
|
2488
|
+
if (!await r(e)) {
|
|
2489
|
+
let i = await Xe(e, n, r, true);
|
|
2490
|
+
if (i?.asset && i.asset.eTag === await r(t)) return { asset: null, redirect: e };
|
|
2491
|
+
}
|
|
2492
|
+
return null;
|
|
2493
|
+
};
|
|
2494
|
+
var Ut = (t) => t.split("/").map((e) => {
|
|
2495
|
+
try {
|
|
2496
|
+
return decodeURIComponent(e);
|
|
2497
|
+
} catch {
|
|
2498
|
+
return e;
|
|
2499
|
+
}
|
|
2500
|
+
}).join("/");
|
|
2501
|
+
var Ls = (t) => t.split("/").map((e) => {
|
|
2502
|
+
try {
|
|
2503
|
+
return encodeURIComponent(e);
|
|
2504
|
+
} catch {
|
|
2505
|
+
return e;
|
|
2506
|
+
}
|
|
2507
|
+
}).join("/");
|
|
2508
|
+
async function Zn(t, e, n, r = 1) {
|
|
2509
|
+
let s = 0;
|
|
2510
|
+
for (; s <= r; ) try {
|
|
2511
|
+
let i = await t.getWithMetadata(e, { type: "stream", cacheTtl: 31536e3 });
|
|
2512
|
+
if (i.value === null) {
|
|
2513
|
+
let o = await t.getWithMetadata(e, { type: "stream", cacheTtl: 60 });
|
|
2514
|
+
return o.value !== null && n && n.captureException(new Error(`Initial request for asset ${e} failed, but subsequent request succeeded.`)), o;
|
|
2515
|
+
}
|
|
2516
|
+
return i;
|
|
2517
|
+
} catch {
|
|
2518
|
+
if (s >= r) throw new Error(`Requested asset ${e} could not be fetched from KV namespace.`);
|
|
2519
|
+
await new Promise((o) => setTimeout(o, Math.pow(2, s++) * 1e3));
|
|
2520
|
+
}
|
|
2521
|
+
}
|
|
2522
|
+
function Bs() {
|
|
2523
|
+
return { addLogs: () => {
|
|
2524
|
+
}, setTags: () => {
|
|
2525
|
+
}, end: () => {
|
|
2526
|
+
}, isRecording: true };
|
|
2527
|
+
}
|
|
2528
|
+
function Qn() {
|
|
2529
|
+
return { enterSpan: (t, e, ...n) => e(Bs(), ...n), getSpanContext: () => ({ traceId: "test-trace", spanId: "test-span", parentSpanId: "test-parent-span", traceFlags: 0 }), runWithSpanContext: (t, e, ...n) => e(...n), traceId: "test-trace", spanId: "test-span", parentSpanId: "test-parent-span", cfTraceIdHeader: "test-trace:test-span:0" };
|
|
2530
|
+
}
|
|
2531
|
+
var er = class extends Fs {
|
|
2532
|
+
async fetch(t) {
|
|
2533
|
+
let e, n = new je(this.env.ANALYTICS), r = new _e(this.env.UNSAFE_PERFORMANCE), s = r.now();
|
|
2534
|
+
try {
|
|
2535
|
+
this.env.JAEGER || (this.env.JAEGER = Qn()), e = Vn(t, this.ctx, this.env.SENTRY_DSN, this.env.SENTRY_ACCESS_CLIENT_ID, this.env.SENTRY_ACCESS_CLIENT_SECRET);
|
|
2536
|
+
let i = Mt(this.env.CONFIG), o = t.headers.get("user-agent") ?? "UA UNKNOWN";
|
|
2537
|
+
if (e) {
|
|
2538
|
+
let c = this.env.COLO_METADATA.coloId;
|
|
2539
|
+
e.setTag("colo", this.env.COLO_METADATA.coloId), e.setTag("metal", this.env.COLO_METADATA.metalId), e.setUser({ userAgent: o, colo: c });
|
|
2540
|
+
}
|
|
2541
|
+
let a = new URL(t.url);
|
|
2542
|
+
return this.env.COLO_METADATA && this.env.VERSION_METADATA && n.setData({ coloId: this.env.COLO_METADATA.coloId, metalId: this.env.COLO_METADATA.metalId, coloTier: this.env.COLO_METADATA.coloTier, coloRegion: this.env.COLO_METADATA.coloRegion, version: this.env.VERSION_METADATA.id, hostname: a.hostname, htmlHandling: i.html_handling, notFoundHandling: i.not_found_handling, userAgent: o }), this.env.JAEGER.enterSpan("handleRequest", async (c) => (c.setTags({ hostname: a.hostname, eyeballPath: a.pathname, env: this.env.ENVIRONMENT, version: this.env.VERSION_METADATA?.id }), Xn(t, this.env, i, this.unstable_exists.bind(this), this.unstable_getByETag.bind(this)))).catch((c) => this.handleError(e, n, c)).finally(() => this.submitMetrics(n, r, s));
|
|
2543
|
+
} catch (i) {
|
|
2544
|
+
let o = this.handleError(e, n, i);
|
|
2545
|
+
return this.submitMetrics(n, r, s), o;
|
|
2546
|
+
}
|
|
2547
|
+
}
|
|
2548
|
+
handleError(t, e, n) {
|
|
2549
|
+
try {
|
|
2550
|
+
let r = new j(n);
|
|
2551
|
+
return t && t.captureException(n), n instanceof Error && e.setData({ error: n.message }), r;
|
|
2552
|
+
} catch (r) {
|
|
2553
|
+
return console.error("Error handling error", r), new j(r);
|
|
2554
|
+
}
|
|
2555
|
+
}
|
|
2556
|
+
submitMetrics(t, e, n) {
|
|
2557
|
+
try {
|
|
2558
|
+
t.setData({ requestTime: e.now() - n }), t.write();
|
|
2559
|
+
} catch (r) {
|
|
2560
|
+
console.error("Error submitting metrics", r);
|
|
2561
|
+
}
|
|
2562
|
+
}
|
|
2563
|
+
async unstable_canFetch(t) {
|
|
2564
|
+
let e = new URL(t.url), n = Ut(e.pathname);
|
|
2565
|
+
return await Xe(n, { ...Mt(this.env.CONFIG), not_found_handling: "none" }, this.unstable_exists.bind(this)) !== null;
|
|
2566
|
+
}
|
|
2567
|
+
async unstable_getByETag(t) {
|
|
2568
|
+
let e = await Zn(this.env.ASSETS_KV_NAMESPACE, t);
|
|
2569
|
+
if (!e || !e.value) throw new Error(`Requested asset ${t} exists in the asset manifest but not in the KV namespace.`);
|
|
2570
|
+
return { readableStream: e.value, contentType: e.metadata?.contentType ?? "application/octet-stream" };
|
|
2571
|
+
}
|
|
2572
|
+
async unstable_getByPathname(t) {
|
|
2573
|
+
let e = await this.unstable_exists(t);
|
|
2574
|
+
return e ? this.unstable_getByETag(e) : null;
|
|
2575
|
+
}
|
|
2576
|
+
async unstable_exists(t) {
|
|
2577
|
+
return await new We(this.env.ASSETS_MANIFEST).get(t);
|
|
2578
|
+
}
|
|
2579
|
+
};
|
|
2580
|
+
|
|
2581
|
+
// src/shared.ts
|
|
2582
|
+
var UNKNOWN_HOST = "http://localhost";
|
|
2583
|
+
|
|
2584
|
+
// src/asset-workers/asset-worker.ts
|
|
2585
|
+
var CustomAssetWorker = class extends er {
|
|
2586
|
+
async fetch(request) {
|
|
2587
|
+
const response = await super.fetch(request);
|
|
2588
|
+
const modifiedResponse = new Response(response.body, response);
|
|
2589
|
+
modifiedResponse.headers.delete("ETag");
|
|
2590
|
+
modifiedResponse.headers.delete("Cache-Control");
|
|
2591
|
+
return modifiedResponse;
|
|
2592
|
+
}
|
|
2593
|
+
async unstable_getByETag(eTag) {
|
|
2594
|
+
const url = new URL(eTag, UNKNOWN_HOST);
|
|
2595
|
+
const response = await this.env.__VITE_FETCH_ASSET__.fetch(url);
|
|
2596
|
+
if (!response.body) {
|
|
2597
|
+
throw new Error(`Unexpected error. No HTML found for ${eTag}.`);
|
|
2598
|
+
}
|
|
2599
|
+
return { readableStream: response.body, contentType: "text/html" };
|
|
2600
|
+
}
|
|
2601
|
+
async unstable_exists(pathname) {
|
|
2602
|
+
const url = new URL(pathname.replace(/^\/{2,}/, "/"), UNKNOWN_HOST);
|
|
2603
|
+
const response = await this.env.__VITE_ASSET_EXISTS__.fetch(url);
|
|
2604
|
+
const exists = await response.json();
|
|
2605
|
+
return exists ? pathname : null;
|
|
2606
|
+
}
|
|
2607
|
+
};
|
|
2608
|
+
export {
|
|
2609
|
+
CustomAssetWorker as default
|
|
2610
|
+
};
|