@microblink/blinkid-core 7.4.0 → 7.4.2

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (40) hide show
  1. package/dist/blinkid-core.js +656 -599
  2. package/dist/resources/blinkid-worker.js +521 -697
  3. package/dist/resources/full/advanced/BlinkIdModule.js +4 -4
  4. package/dist/resources/full/advanced/BlinkIdModule.wasm +0 -0
  5. package/dist/resources/full/advanced-threads/BlinkIdModule.js +12 -13
  6. package/dist/resources/full/advanced-threads/BlinkIdModule.wasm +0 -0
  7. package/dist/resources/full/basic/BlinkIdModule.js +9 -9
  8. package/dist/resources/full/basic/BlinkIdModule.wasm +0 -0
  9. package/dist/resources/lightweight/advanced/BlinkIdModule.js +3 -3
  10. package/dist/resources/lightweight/advanced/BlinkIdModule.wasm +0 -0
  11. package/dist/resources/lightweight/advanced-threads/BlinkIdModule.js +5 -5
  12. package/dist/resources/lightweight/advanced-threads/BlinkIdModule.wasm +0 -0
  13. package/dist/resources/lightweight/basic/BlinkIdModule.js +4 -4
  14. package/dist/resources/lightweight/basic/BlinkIdModule.wasm +0 -0
  15. package/dist/resources/size-manifest.json +30 -0
  16. package/package.json +1 -1
  17. package/types/deviceInfo/createDerivedDeviceInfo.d.ts +7 -0
  18. package/types/deviceInfo/createDerivedDeviceInfo.d.ts.map +1 -0
  19. package/types/deviceInfo/createDerivedDeviceInfo.test.d.ts +5 -0
  20. package/types/deviceInfo/createDerivedDeviceInfo.test.d.ts.map +1 -0
  21. package/types/deviceInfo/deviceInfo.d.ts +54 -0
  22. package/types/deviceInfo/deviceInfo.d.ts.map +1 -0
  23. package/types/deviceInfo/getAppleDeviceModel.d.ts +13 -0
  24. package/types/deviceInfo/getAppleDeviceModel.d.ts.map +1 -0
  25. package/types/deviceInfo/getAppleDeviceModel.test.d.ts +5 -0
  26. package/types/deviceInfo/getAppleDeviceModel.test.d.ts.map +1 -0
  27. package/types/deviceInfo/getBrowserFromUserAgent.d.ts +18 -0
  28. package/types/deviceInfo/getBrowserFromUserAgent.d.ts.map +1 -0
  29. package/types/deviceInfo/getBrowserFromUserAgent.test.d.ts +5 -0
  30. package/types/deviceInfo/getBrowserFromUserAgent.test.d.ts.map +1 -0
  31. package/types/deviceInfo/getOsFromUserAgent.d.ts +18 -0
  32. package/types/deviceInfo/getOsFromUserAgent.d.ts.map +1 -0
  33. package/types/deviceInfo/getOsFromUserAgent.test.d.ts +5 -0
  34. package/types/deviceInfo/getOsFromUserAgent.test.d.ts.map +1 -0
  35. package/types/deviceInfo/navigator-types.d.ts +79 -0
  36. package/types/deviceInfo/navigator-types.d.ts.map +1 -0
  37. package/types/index.d.ts +1 -0
  38. package/types/index.d.ts.map +1 -1
  39. package/dist/blinkid-core.js.map +0 -1
  40. package/types/index.rollup.d.ts +0 -2859
@@ -1,686 +1,560 @@
1
- var __defProp = Object.defineProperty;
2
- var __typeError = (msg) => {
3
- throw TypeError(msg);
1
+ var Oe = Object.defineProperty;
2
+ var J = (e) => {
3
+ throw TypeError(e);
4
4
  };
5
- var __defNormalProp = (obj, key, value) => key in obj ? __defProp(obj, key, { enumerable: true, configurable: true, writable: true, value }) : obj[key] = value;
6
- var __publicField = (obj, key, value) => __defNormalProp(obj, typeof key !== "symbol" ? key + "" : key, value);
7
- var __accessCheck = (obj, member, msg) => member.has(obj) || __typeError("Cannot " + msg);
8
- var __privateGet = (obj, member, getter) => (__accessCheck(obj, member, "read from private field"), getter ? getter.call(obj) : member.get(obj));
9
- var __privateAdd = (obj, member, value) => member.has(obj) ? __typeError("Cannot add the same private member more than once") : member instanceof WeakSet ? member.add(obj) : member.set(obj, value);
10
- var __privateSet = (obj, member, value, setter) => (__accessCheck(obj, member, "write to private field"), setter ? setter.call(obj, value) : member.set(obj, value), value);
11
- var __privateMethod = (obj, member, method) => (__accessCheck(obj, member, "access private method"), method);
5
+ var Le = (e, t, r) => t in e ? Oe(e, t, { enumerable: !0, configurable: !0, writable: !0, value: r }) : e[t] = r;
6
+ var B = (e, t, r) => Le(e, typeof t != "symbol" ? t + "" : t, r), $ = (e, t, r) => t.has(e) || J("Cannot " + r);
7
+ var m = (e, t, r) => ($(e, t, "read from private field"), r ? r.call(e) : t.get(e)), S = (e, t, r) => t.has(e) ? J("Cannot add the same private member more than once") : t instanceof WeakSet ? t.add(e) : t.set(e, r), x = (e, t, r, o) => ($(e, t, "write to private field"), o ? o.call(e, r) : t.set(e, r), r), v = (e, t, r) => ($(e, t, "access private method"), r);
12
8
  /**
13
9
  * @license
14
10
  * Copyright 2019 Google LLC
15
11
  * SPDX-License-Identifier: Apache-2.0
16
12
  */
17
- var _wasmModule, _defaultSessionSettings, _showDemoOverlay, _showProductionOverlay, _proxyUrls, _BlinkIdWorker_instances, loadWasm_fn, configureProxyUrls_fn, validateProxyPermissions_fn, sanitizeProxyUrls_fn, buildServiceUrl_fn;
18
- const proxyMarker = Symbol("Comlink.proxy");
19
- const createEndpoint = Symbol("Comlink.endpoint");
20
- const releaseProxy = Symbol("Comlink.releaseProxy");
21
- const finalizer = Symbol("Comlink.finalizer");
22
- const throwMarker = Symbol("Comlink.thrown");
23
- const isObject = (val) => typeof val === "object" && val !== null || typeof val === "function";
24
- const proxyTransferHandler = {
25
- canHandle: (val) => isObject(val) && val[proxyMarker],
26
- serialize(obj) {
27
- const { port1, port2 } = new MessageChannel();
28
- expose(obj, port1);
29
- return [port2, [port2]];
13
+ const re = Symbol("Comlink.proxy"), Ae = Symbol("Comlink.endpoint"), Re = Symbol("Comlink.releaseProxy"), z = Symbol("Comlink.finalizer"), N = Symbol("Comlink.thrown"), ne = (e) => typeof e == "object" && e !== null || typeof e == "function", ke = {
14
+ canHandle: (e) => ne(e) && e[re],
15
+ serialize(e) {
16
+ const { port1: t, port2: r } = new MessageChannel();
17
+ return V(e, t), [r, [r]];
30
18
  },
31
- deserialize(port) {
32
- port.start();
33
- return wrap(port);
34
- }
35
- };
36
- const throwTransferHandler = {
37
- canHandle: (value) => isObject(value) && throwMarker in value,
38
- serialize({ value }) {
39
- let serialized;
40
- if (value instanceof Error) {
41
- serialized = {
42
- isError: true,
43
- value: {
44
- message: value.message,
45
- name: value.name,
46
- stack: value.stack
47
- }
48
- };
49
- } else {
50
- serialized = { isError: false, value };
51
- }
52
- return [serialized, []];
19
+ deserialize(e) {
20
+ return e.start(), ze(e);
21
+ }
22
+ }, Ue = {
23
+ canHandle: (e) => ne(e) && N in e,
24
+ serialize({ value: e }) {
25
+ let t;
26
+ return e instanceof Error ? t = {
27
+ isError: !0,
28
+ value: {
29
+ message: e.message,
30
+ name: e.name,
31
+ stack: e.stack
32
+ }
33
+ } : t = { isError: !1, value: e }, [t, []];
53
34
  },
54
- deserialize(serialized) {
55
- if (serialized.isError) {
56
- throw Object.assign(new Error(serialized.value.message), serialized.value);
57
- }
58
- throw serialized.value;
35
+ deserialize(e) {
36
+ throw e.isError ? Object.assign(new Error(e.value.message), e.value) : e.value;
59
37
  }
60
- };
61
- const transferHandlers = /* @__PURE__ */ new Map([
62
- ["proxy", proxyTransferHandler],
63
- ["throw", throwTransferHandler]
38
+ }, se = /* @__PURE__ */ new Map([
39
+ ["proxy", ke],
40
+ ["throw", Ue]
64
41
  ]);
65
- function isAllowedOrigin(allowedOrigins, origin) {
66
- for (const allowedOrigin of allowedOrigins) {
67
- if (origin === allowedOrigin || allowedOrigin === "*") {
68
- return true;
69
- }
70
- if (allowedOrigin instanceof RegExp && allowedOrigin.test(origin)) {
71
- return true;
72
- }
73
- }
74
- return false;
75
- }
76
- function expose(obj, ep = globalThis, allowedOrigins = ["*"]) {
77
- ep.addEventListener("message", function callback(ev) {
78
- if (!ev || !ev.data) {
42
+ function Me(e, t) {
43
+ for (const r of e)
44
+ if (t === r || r === "*" || r instanceof RegExp && r.test(t))
45
+ return !0;
46
+ return !1;
47
+ }
48
+ function V(e, t = globalThis, r = ["*"]) {
49
+ t.addEventListener("message", function o(s) {
50
+ if (!s || !s.data)
79
51
  return;
80
- }
81
- if (!isAllowedOrigin(allowedOrigins, ev.origin)) {
82
- console.warn(`Invalid origin '${ev.origin}' for comlink proxy`);
52
+ if (!Me(r, s.origin)) {
53
+ console.warn(`Invalid origin '${s.origin}' for comlink proxy`);
83
54
  return;
84
55
  }
85
- const { id, type, path } = Object.assign({ path: [] }, ev.data);
86
- const argumentList = (ev.data.argumentList || []).map(fromWireValue);
87
- let returnValue;
56
+ const { id: n, type: u, path: a } = Object.assign({ path: [] }, s.data), c = (s.data.argumentList || []).map(E);
57
+ let i;
88
58
  try {
89
- const parent = path.slice(0, -1).reduce((obj2, prop) => obj2[prop], obj);
90
- const rawValue = path.reduce((obj2, prop) => obj2[prop], obj);
91
- switch (type) {
59
+ const l = a.slice(0, -1).reduce((f, p) => f[p], e), d = a.reduce((f, p) => f[p], e);
60
+ switch (u) {
92
61
  case "GET":
93
- {
94
- returnValue = rawValue;
95
- }
62
+ i = d;
96
63
  break;
97
64
  case "SET":
98
- {
99
- parent[path.slice(-1)[0]] = fromWireValue(ev.data.value);
100
- returnValue = true;
101
- }
65
+ l[a.slice(-1)[0]] = E(s.data.value), i = !0;
102
66
  break;
103
67
  case "APPLY":
104
- {
105
- returnValue = rawValue.apply(parent, argumentList);
106
- }
68
+ i = d.apply(l, c);
107
69
  break;
108
70
  case "CONSTRUCT":
109
71
  {
110
- const value = new rawValue(...argumentList);
111
- returnValue = proxy(value);
72
+ const f = new d(...c);
73
+ i = le(f);
112
74
  }
113
75
  break;
114
76
  case "ENDPOINT":
115
77
  {
116
- const { port1, port2 } = new MessageChannel();
117
- expose(obj, port2);
118
- returnValue = transfer(port1, [port1]);
78
+ const { port1: f, port2: p } = new MessageChannel();
79
+ V(e, p), i = ce(f, [f]);
119
80
  }
120
81
  break;
121
82
  case "RELEASE":
122
- {
123
- returnValue = void 0;
124
- }
83
+ i = void 0;
125
84
  break;
126
85
  default:
127
86
  return;
128
87
  }
129
- } catch (value) {
130
- returnValue = { value, [throwMarker]: 0 };
88
+ } catch (l) {
89
+ i = { value: l, [N]: 0 };
131
90
  }
132
- Promise.resolve(returnValue).catch((value) => {
133
- return { value, [throwMarker]: 0 };
134
- }).then((returnValue2) => {
135
- const [wireValue, transferables] = toWireValue(returnValue2);
136
- ep.postMessage(Object.assign(Object.assign({}, wireValue), { id }), transferables);
137
- if (type === "RELEASE") {
138
- ep.removeEventListener("message", callback);
139
- closeEndPoint(ep);
140
- if (finalizer in obj && typeof obj[finalizer] === "function") {
141
- obj[finalizer]();
142
- }
143
- }
144
- }).catch((error) => {
145
- const [wireValue, transferables] = toWireValue({
91
+ Promise.resolve(i).catch((l) => ({ value: l, [N]: 0 })).then((l) => {
92
+ const [d, f] = j(l);
93
+ t.postMessage(Object.assign(Object.assign({}, d), { id: n }), f), u === "RELEASE" && (t.removeEventListener("message", o), oe(t), z in e && typeof e[z] == "function" && e[z]());
94
+ }).catch((l) => {
95
+ const [d, f] = j({
146
96
  value: new TypeError("Unserializable return value"),
147
- [throwMarker]: 0
97
+ [N]: 0
148
98
  });
149
- ep.postMessage(Object.assign(Object.assign({}, wireValue), { id }), transferables);
99
+ t.postMessage(Object.assign(Object.assign({}, d), { id: n }), f);
150
100
  });
151
- });
152
- if (ep.start) {
153
- ep.start();
154
- }
101
+ }), t.start && t.start();
155
102
  }
156
- function isMessagePort(endpoint) {
157
- return endpoint.constructor.name === "MessagePort";
103
+ function Te(e) {
104
+ return e.constructor.name === "MessagePort";
158
105
  }
159
- function closeEndPoint(endpoint) {
160
- if (isMessagePort(endpoint))
161
- endpoint.close();
106
+ function oe(e) {
107
+ Te(e) && e.close();
162
108
  }
163
- function wrap(ep, target) {
164
- const pendingListeners = /* @__PURE__ */ new Map();
165
- ep.addEventListener("message", function handleMessage(ev) {
166
- const { data } = ev;
167
- if (!data || !data.id) {
109
+ function ze(e, t) {
110
+ const r = /* @__PURE__ */ new Map();
111
+ return e.addEventListener("message", function(s) {
112
+ const { data: n } = s;
113
+ if (!n || !n.id)
168
114
  return;
169
- }
170
- const resolver = pendingListeners.get(data.id);
171
- if (!resolver) {
172
- return;
173
- }
174
- try {
175
- resolver(data);
176
- } finally {
177
- pendingListeners.delete(data.id);
178
- }
179
- });
180
- return createProxy(ep, pendingListeners, [], target);
115
+ const u = r.get(n.id);
116
+ if (u)
117
+ try {
118
+ u(n);
119
+ } finally {
120
+ r.delete(n.id);
121
+ }
122
+ }), D(e, r, [], t);
181
123
  }
182
- function throwIfProxyReleased(isReleased) {
183
- if (isReleased) {
124
+ function k(e) {
125
+ if (e)
184
126
  throw new Error("Proxy has been released and is not useable");
185
- }
186
127
  }
187
- function releaseEndpoint(ep) {
188
- return requestResponseMessage(ep, /* @__PURE__ */ new Map(), {
128
+ function ae(e) {
129
+ return O(e, /* @__PURE__ */ new Map(), {
189
130
  type: "RELEASE"
190
131
  }).then(() => {
191
- closeEndPoint(ep);
132
+ oe(e);
192
133
  });
193
134
  }
194
- const proxyCounter = /* @__PURE__ */ new WeakMap();
195
- const proxyFinalizers = "FinalizationRegistry" in globalThis && new FinalizationRegistry((ep) => {
196
- const newCount = (proxyCounter.get(ep) || 0) - 1;
197
- proxyCounter.set(ep, newCount);
198
- if (newCount === 0) {
199
- releaseEndpoint(ep);
200
- }
135
+ const I = /* @__PURE__ */ new WeakMap(), W = "FinalizationRegistry" in globalThis && new FinalizationRegistry((e) => {
136
+ const t = (I.get(e) || 0) - 1;
137
+ I.set(e, t), t === 0 && ae(e);
201
138
  });
202
- function registerProxy(proxy2, ep) {
203
- const newCount = (proxyCounter.get(ep) || 0) + 1;
204
- proxyCounter.set(ep, newCount);
205
- if (proxyFinalizers) {
206
- proxyFinalizers.register(proxy2, ep, proxy2);
207
- }
139
+ function Ne(e, t) {
140
+ const r = (I.get(t) || 0) + 1;
141
+ I.set(t, r), W && W.register(e, t, e);
208
142
  }
209
- function unregisterProxy(proxy2) {
210
- if (proxyFinalizers) {
211
- proxyFinalizers.unregister(proxy2);
212
- }
143
+ function Ie(e) {
144
+ W && W.unregister(e);
213
145
  }
214
- function createProxy(ep, pendingListeners, path = [], target = function() {
146
+ function D(e, t, r = [], o = function() {
215
147
  }) {
216
- let isProxyReleased = false;
217
- const proxy2 = new Proxy(target, {
218
- get(_target, prop) {
219
- throwIfProxyReleased(isProxyReleased);
220
- if (prop === releaseProxy) {
148
+ let s = !1;
149
+ const n = new Proxy(o, {
150
+ get(u, a) {
151
+ if (k(s), a === Re)
221
152
  return () => {
222
- unregisterProxy(proxy2);
223
- releaseEndpoint(ep);
224
- pendingListeners.clear();
225
- isProxyReleased = true;
153
+ Ie(n), ae(e), t.clear(), s = !0;
226
154
  };
227
- }
228
- if (prop === "then") {
229
- if (path.length === 0) {
230
- return { then: () => proxy2 };
231
- }
232
- const r = requestResponseMessage(ep, pendingListeners, {
155
+ if (a === "then") {
156
+ if (r.length === 0)
157
+ return { then: () => n };
158
+ const c = O(e, t, {
233
159
  type: "GET",
234
- path: path.map((p) => p.toString())
235
- }).then(fromWireValue);
236
- return r.then.bind(r);
160
+ path: r.map((i) => i.toString())
161
+ }).then(E);
162
+ return c.then.bind(c);
237
163
  }
238
- return createProxy(ep, pendingListeners, [...path, prop]);
164
+ return D(e, t, [...r, a]);
239
165
  },
240
- set(_target, prop, rawValue) {
241
- throwIfProxyReleased(isProxyReleased);
242
- const [value, transferables] = toWireValue(rawValue);
243
- return requestResponseMessage(ep, pendingListeners, {
166
+ set(u, a, c) {
167
+ k(s);
168
+ const [i, l] = j(c);
169
+ return O(e, t, {
244
170
  type: "SET",
245
- path: [...path, prop].map((p) => p.toString()),
246
- value
247
- }, transferables).then(fromWireValue);
171
+ path: [...r, a].map((d) => d.toString()),
172
+ value: i
173
+ }, l).then(E);
248
174
  },
249
- apply(_target, _thisArg, rawArgumentList) {
250
- throwIfProxyReleased(isProxyReleased);
251
- const last = path[path.length - 1];
252
- if (last === createEndpoint) {
253
- return requestResponseMessage(ep, pendingListeners, {
175
+ apply(u, a, c) {
176
+ k(s);
177
+ const i = r[r.length - 1];
178
+ if (i === Ae)
179
+ return O(e, t, {
254
180
  type: "ENDPOINT"
255
- }).then(fromWireValue);
256
- }
257
- if (last === "bind") {
258
- return createProxy(ep, pendingListeners, path.slice(0, -1));
259
- }
260
- const [argumentList, transferables] = processArguments(rawArgumentList);
261
- return requestResponseMessage(ep, pendingListeners, {
181
+ }).then(E);
182
+ if (i === "bind")
183
+ return D(e, t, r.slice(0, -1));
184
+ const [l, d] = K(c);
185
+ return O(e, t, {
262
186
  type: "APPLY",
263
- path: path.map((p) => p.toString()),
264
- argumentList
265
- }, transferables).then(fromWireValue);
187
+ path: r.map((f) => f.toString()),
188
+ argumentList: l
189
+ }, d).then(E);
266
190
  },
267
- construct(_target, rawArgumentList) {
268
- throwIfProxyReleased(isProxyReleased);
269
- const [argumentList, transferables] = processArguments(rawArgumentList);
270
- return requestResponseMessage(ep, pendingListeners, {
191
+ construct(u, a) {
192
+ k(s);
193
+ const [c, i] = K(a);
194
+ return O(e, t, {
271
195
  type: "CONSTRUCT",
272
- path: path.map((p) => p.toString()),
273
- argumentList
274
- }, transferables).then(fromWireValue);
196
+ path: r.map((l) => l.toString()),
197
+ argumentList: c
198
+ }, i).then(E);
275
199
  }
276
200
  });
277
- registerProxy(proxy2, ep);
278
- return proxy2;
201
+ return Ne(n, e), n;
279
202
  }
280
- function myFlat(arr) {
281
- return Array.prototype.concat.apply([], arr);
203
+ function We(e) {
204
+ return Array.prototype.concat.apply([], e);
282
205
  }
283
- function processArguments(argumentList) {
284
- const processed = argumentList.map(toWireValue);
285
- return [processed.map((v) => v[0]), myFlat(processed.map((v) => v[1]))];
206
+ function K(e) {
207
+ const t = e.map(j);
208
+ return [t.map((r) => r[0]), We(t.map((r) => r[1]))];
286
209
  }
287
- const transferCache = /* @__PURE__ */ new WeakMap();
288
- function transfer(obj, transfers) {
289
- transferCache.set(obj, transfers);
290
- return obj;
210
+ const ie = /* @__PURE__ */ new WeakMap();
211
+ function ce(e, t) {
212
+ return ie.set(e, t), e;
291
213
  }
292
- function proxy(obj) {
293
- return Object.assign(obj, { [proxyMarker]: true });
214
+ function le(e) {
215
+ return Object.assign(e, { [re]: !0 });
294
216
  }
295
- function toWireValue(value) {
296
- for (const [name, handler] of transferHandlers) {
297
- if (handler.canHandle(value)) {
298
- const [serializedValue, transferables] = handler.serialize(value);
217
+ function j(e) {
218
+ for (const [t, r] of se)
219
+ if (r.canHandle(e)) {
220
+ const [o, s] = r.serialize(e);
299
221
  return [
300
222
  {
301
223
  type: "HANDLER",
302
- name,
303
- value: serializedValue
224
+ name: t,
225
+ value: o
304
226
  },
305
- transferables
227
+ s
306
228
  ];
307
229
  }
308
- }
309
230
  return [
310
231
  {
311
232
  type: "RAW",
312
- value
233
+ value: e
313
234
  },
314
- transferCache.get(value) || []
235
+ ie.get(e) || []
315
236
  ];
316
237
  }
317
- function fromWireValue(value) {
318
- switch (value.type) {
238
+ function E(e) {
239
+ switch (e.type) {
319
240
  case "HANDLER":
320
- return transferHandlers.get(value.name).deserialize(value.value);
241
+ return se.get(e.name).deserialize(e.value);
321
242
  case "RAW":
322
- return value.value;
243
+ return e.value;
323
244
  }
324
245
  }
325
- function requestResponseMessage(ep, pendingListeners, msg, transfers) {
326
- return new Promise((resolve) => {
327
- const id = generateUUID();
328
- pendingListeners.set(id, resolve);
329
- if (ep.start) {
330
- ep.start();
331
- }
332
- ep.postMessage(Object.assign({ id }, msg), transfers);
246
+ function O(e, t, r, o) {
247
+ return new Promise((s) => {
248
+ const n = je();
249
+ t.set(n, s), e.start && e.start(), e.postMessage(Object.assign({ id: n }, r), o);
333
250
  });
334
251
  }
335
- function generateUUID() {
252
+ function je() {
336
253
  return new Array(4).fill(0).map(() => Math.floor(Math.random() * Number.MAX_SAFE_INTEGER).toString(16)).join("-");
337
254
  }
338
- const bulkMemory = async () => WebAssembly.validate(new Uint8Array([0, 97, 115, 109, 1, 0, 0, 0, 1, 4, 1, 96, 0, 0, 3, 2, 1, 0, 5, 3, 1, 0, 1, 10, 14, 1, 12, 0, 65, 0, 65, 0, 65, 0, 252, 10, 0, 0, 11])), mutableGlobals = async () => WebAssembly.validate(new Uint8Array([0, 97, 115, 109, 1, 0, 0, 0, 2, 8, 1, 1, 97, 1, 98, 3, 127, 1, 6, 6, 1, 127, 1, 65, 0, 11, 7, 5, 1, 1, 97, 3, 1])), referenceTypes = async () => WebAssembly.validate(new Uint8Array([0, 97, 115, 109, 1, 0, 0, 0, 1, 4, 1, 96, 0, 0, 3, 2, 1, 0, 10, 7, 1, 5, 0, 208, 112, 26, 11])), saturatedFloatToInt = async () => WebAssembly.validate(new Uint8Array([0, 97, 115, 109, 1, 0, 0, 0, 1, 4, 1, 96, 0, 0, 3, 2, 1, 0, 10, 12, 1, 10, 0, 67, 0, 0, 0, 0, 252, 0, 26, 11])), signExtensions = async () => WebAssembly.validate(new Uint8Array([0, 97, 115, 109, 1, 0, 0, 0, 1, 4, 1, 96, 0, 0, 3, 2, 1, 0, 10, 8, 1, 6, 0, 65, 0, 192, 26, 11])), simd = async () => WebAssembly.validate(new Uint8Array([0, 97, 115, 109, 1, 0, 0, 0, 1, 5, 1, 96, 0, 1, 123, 3, 2, 1, 0, 10, 10, 1, 8, 0, 65, 0, 253, 15, 253, 98, 11])), threads = () => (async (e) => {
255
+ const Ce = async () => WebAssembly.validate(new Uint8Array([0, 97, 115, 109, 1, 0, 0, 0, 1, 4, 1, 96, 0, 0, 3, 2, 1, 0, 5, 3, 1, 0, 1, 10, 14, 1, 12, 0, 65, 0, 65, 0, 65, 0, 252, 10, 0, 0, 11])), Be = async () => WebAssembly.validate(new Uint8Array([0, 97, 115, 109, 1, 0, 0, 0, 2, 8, 1, 1, 97, 1, 98, 3, 127, 1, 6, 6, 1, 127, 1, 65, 0, 11, 7, 5, 1, 1, 97, 3, 1])), $e = async () => WebAssembly.validate(new Uint8Array([0, 97, 115, 109, 1, 0, 0, 0, 1, 4, 1, 96, 0, 0, 3, 2, 1, 0, 10, 7, 1, 5, 0, 208, 112, 26, 11])), De = async () => WebAssembly.validate(new Uint8Array([0, 97, 115, 109, 1, 0, 0, 0, 1, 4, 1, 96, 0, 0, 3, 2, 1, 0, 10, 12, 1, 10, 0, 67, 0, 0, 0, 0, 252, 0, 26, 11])), Ve = async () => WebAssembly.validate(new Uint8Array([0, 97, 115, 109, 1, 0, 0, 0, 1, 4, 1, 96, 0, 0, 3, 2, 1, 0, 10, 8, 1, 6, 0, 65, 0, 192, 26, 11])), Fe = async () => WebAssembly.validate(new Uint8Array([0, 97, 115, 109, 1, 0, 0, 0, 1, 5, 1, 96, 0, 1, 123, 3, 2, 1, 0, 10, 10, 1, 8, 0, 65, 0, 253, 15, 253, 98, 11])), He = () => (async (e) => {
339
256
  try {
340
- return "undefined" != typeof MessageChannel && new MessageChannel().port1.postMessage(new SharedArrayBuffer(1)), WebAssembly.validate(e);
341
- } catch (e2) {
342
- return false;
257
+ return typeof MessageChannel < "u" && new MessageChannel().port1.postMessage(new SharedArrayBuffer(1)), WebAssembly.validate(e);
258
+ } catch {
259
+ return !1;
343
260
  }
344
261
  })(new Uint8Array([0, 97, 115, 109, 1, 0, 0, 0, 1, 4, 1, 96, 0, 0, 3, 2, 1, 0, 5, 4, 1, 3, 1, 1, 10, 11, 1, 9, 0, 65, 0, 254, 16, 2, 0, 26, 11]));
345
- function isSafari() {
346
- const userAgent = navigator.userAgent.toLowerCase();
347
- return userAgent.includes("safari") && !userAgent.includes("chrome");
348
- }
349
- async function checkThreadsSupport() {
350
- const supportsWasmThreads = await threads();
351
- if (!supportsWasmThreads) return false;
352
- if (!("importScripts" in self)) {
262
+ function _e() {
263
+ const e = navigator.userAgent.toLowerCase();
264
+ return e.includes("safari") && !e.includes("chrome");
265
+ }
266
+ async function qe() {
267
+ if (!await He()) return !1;
268
+ if (!("importScripts" in self))
353
269
  throw Error("Not implemented");
354
- }
355
- if (isSafari()) {
356
- return false;
357
- }
358
- return "Worker" in self;
359
- }
360
- async function detectWasmFeatures() {
361
- const basicSet = [
362
- mutableGlobals(),
363
- referenceTypes(),
364
- bulkMemory(),
365
- saturatedFloatToInt(),
366
- signExtensions()
270
+ return _e() ? !1 : "Worker" in self;
271
+ }
272
+ async function Ge() {
273
+ const e = [
274
+ Be(),
275
+ $e(),
276
+ Ce(),
277
+ De(),
278
+ Ve()
367
279
  ];
368
- const supportsBasic = (await Promise.all(basicSet)).every(Boolean);
369
- if (!supportsBasic) {
280
+ if (!(await Promise.all(e)).every(Boolean))
370
281
  throw new Error("Browser doesn't meet minimum requirements!");
371
- }
372
- const supportsAdvanced = await simd();
373
- if (!supportsAdvanced) {
374
- return "basic";
375
- }
376
- const supportsAdvancedThreads = await checkThreadsSupport();
377
- if (!supportsAdvancedThreads) {
378
- return "advanced";
379
- }
380
- return "advanced-threads";
381
- }
382
- const workerType = "application/javascript";
383
- const getCrossOriginWorkerURL = (originalWorkerUrl, _options = {}) => {
384
- const options = {
385
- skipSameOrigin: true,
386
- useBlob: true,
387
- ..._options
282
+ return await Fe() ? await qe() ? "advanced-threads" : "advanced" : "basic";
283
+ }
284
+ const Y = "application/javascript", Je = (e, t = {}) => {
285
+ const r = {
286
+ skipSameOrigin: !0,
287
+ useBlob: !0,
288
+ ...t
388
289
  };
389
- if (options.skipSameOrigin && new URL(originalWorkerUrl).origin === self.location.origin) {
390
- return Promise.resolve(originalWorkerUrl);
391
- }
392
- return new Promise(
393
- (resolve, reject) => void fetch(originalWorkerUrl).then((res) => res.text()).then((codeString) => {
394
- const workerPath = new URL(originalWorkerUrl).href.split("/");
395
- workerPath.pop();
396
- let finalURL = "";
397
- if (options.useBlob) {
398
- const blob = new Blob([codeString], { type: workerType });
399
- finalURL = URL.createObjectURL(blob);
400
- } else {
401
- finalURL = `data:${workerType},` + encodeURIComponent(codeString);
402
- }
403
- resolve(finalURL);
404
- }).catch(reject)
290
+ return r.skipSameOrigin && new URL(e).origin === self.location.origin ? Promise.resolve(e) : new Promise(
291
+ (o, s) => void fetch(e).then((n) => n.text()).then((n) => {
292
+ new URL(e).href.split("/").pop();
293
+ let a = "";
294
+ if (r.useBlob) {
295
+ const c = new Blob([n], { type: Y });
296
+ a = URL.createObjectURL(c);
297
+ } else
298
+ a = `data:${Y},` + encodeURIComponent(n);
299
+ o(a);
300
+ }).catch(s)
405
301
  );
406
302
  };
407
- function isIOS() {
408
- const userAgent = self.navigator.userAgent.toLowerCase();
409
- return /iphone|ipad|ipod/.test(userAgent);
303
+ function Ke() {
304
+ const e = self.navigator.userAgent.toLowerCase();
305
+ return /iphone|ipad|ipod/.test(e);
410
306
  }
411
- function constructLicenseRequest(unlockResult) {
307
+ function Ye(e) {
412
308
  return {
413
- licenseId: unlockResult.licenseId,
414
- licensee: unlockResult.licensee,
415
- applicationIds: unlockResult.applicationIds,
416
- packageName: unlockResult.packageName,
309
+ licenseId: e.licenseId,
310
+ licensee: e.licensee,
311
+ applicationIds: e.applicationIds,
312
+ packageName: e.packageName,
417
313
  platform: "Browser",
418
- sdkName: unlockResult.sdkName,
419
- sdkVersion: unlockResult.sdkVersion
314
+ sdkName: e.sdkName,
315
+ sdkVersion: e.sdkVersion
420
316
  };
421
317
  }
422
- async function obtainNewServerPermission(unlockResult, baltazarUrl = "https://baltazar.microblink.com/api/v2/status/check") {
423
- if (!baltazarUrl || typeof baltazarUrl !== "string") {
318
+ async function X(e, t = "https://baltazar.microblink.com/api/v2/status/check") {
319
+ if (!t || typeof t != "string")
424
320
  throw new Error("Invalid baltazarUrl: must be a non-empty string");
425
- }
426
321
  try {
427
- new URL(baltazarUrl);
428
- } catch (error) {
429
- throw new Error(`Invalid baltazarUrl format: ${baltazarUrl}`);
322
+ new URL(t);
323
+ } catch {
324
+ throw new Error(`Invalid baltazarUrl format: ${t}`);
430
325
  }
431
326
  try {
432
- const response = await fetch(baltazarUrl, {
327
+ const r = await fetch(t, {
433
328
  method: "POST",
434
329
  headers: {
435
330
  "Content-Type": "application/json"
436
331
  },
437
332
  cache: "no-cache",
438
- body: JSON.stringify(constructLicenseRequest(unlockResult))
333
+ body: JSON.stringify(Ye(e))
439
334
  });
440
- if (!response.ok) {
335
+ if (!r.ok)
441
336
  throw new Error(
442
- `Server returned error: ${response.status} ${response.statusText}`
337
+ `Server returned error: ${r.status} ${r.statusText}`
443
338
  );
444
- }
445
- const serverPermission = await response.json();
446
- return serverPermission;
447
- } catch (error) {
448
- console.error("Server permission request failed:", error);
449
- throw error;
339
+ return await r.json();
340
+ } catch (r) {
341
+ throw console.error("Server permission request failed:", r), r;
450
342
  }
451
343
  }
452
- function mbToWasmPages(mb) {
453
- return Math.ceil(mb * 1024 * 1024 / 64 / 1024);
344
+ function Q(e) {
345
+ return Math.ceil(e * 1024 * 1024 / 64 / 1024);
454
346
  }
455
- async function downloadArrayBuffer(url, progressCallback) {
456
- const response = await fetch(url);
457
- if (!response.body || !response.headers.has("Content-Length")) {
458
- return response.arrayBuffer();
459
- }
460
- const contentLength = parseInt(response.headers.get("Content-Length"), 10);
461
- let loaded = 0;
462
- const reader = response.body.getReader();
463
- const chunks = [];
464
- let result = await reader.read();
465
- while (!result.done) {
466
- const value = result.value;
467
- if (value) {
468
- chunks.push(value);
469
- loaded += value.length;
470
- if (progressCallback) {
471
- const progress = Math.min(
472
- Math.round(loaded / contentLength * 100),
473
- 100
474
- );
475
- progressCallback({
476
- loaded,
477
- contentLength,
478
- progress
479
- });
480
- }
347
+ const Xe = { basic: { full: 3065339, lightweight: 3123699 }, advanced: { full: 3081342, lightweight: 3138061 }, "advanced-threads": { full: 3133844, lightweight: 3189498 } }, Qe = { basic: { full: 9141750, lightweight: 7509065 }, advanced: { full: 9141750, lightweight: 7509065 }, "advanced-threads": { full: 9141750, lightweight: 7509065 } }, Ze = {
348
+ wasm: Xe,
349
+ data: Qe
350
+ };
351
+ function et(e, t, r) {
352
+ return Ze[e][t][r];
353
+ }
354
+ async function Z(e, t, r, o, s) {
355
+ var d;
356
+ const n = await fetch(e);
357
+ if (!s)
358
+ return n.arrayBuffer();
359
+ const u = n.headers.get("Content-Length"), a = u ? parseInt(u, 10) : et(t, r, o);
360
+ if (isNaN(a) || a <= 0)
361
+ throw new Error(
362
+ `Invalid content length for ${t} file: ${a}`
363
+ );
364
+ let c = 0;
365
+ const i = new TransformStream({
366
+ transform(f, p) {
367
+ c += f.length;
368
+ const C = Math.min(
369
+ Math.round(c / a * 100),
370
+ 100
371
+ );
372
+ s({
373
+ loaded: c,
374
+ contentLength: a,
375
+ progress: C,
376
+ finished: !1
377
+ }), p.enqueue(f);
378
+ },
379
+ flush() {
380
+ s({
381
+ loaded: c,
382
+ contentLength: a,
383
+ progress: 100,
384
+ finished: !0
385
+ });
481
386
  }
482
- result = await reader.read();
483
- }
484
- const allChunks = new Uint8Array(loaded);
485
- let position = 0;
486
- for (const chunk of chunks) {
487
- allChunks.set(chunk, position);
488
- position += chunk.length;
489
- }
490
- return allChunks.buffer;
387
+ });
388
+ return new Response(
389
+ (d = n.body) == null ? void 0 : d.pipeThrough(i),
390
+ n
391
+ ).arrayBuffer();
491
392
  }
492
- function buildResourcePath(...segments) {
493
- const path = segments.filter((segment) => segment).join("/").replace(/([^:]\/)\/+/g, "$1");
393
+ function U(...e) {
394
+ const t = e.filter((r) => r).join("/").replace(/([^:]\/)\/+/g, "$1");
494
395
  try {
495
- new URL(path, "http://example.com");
396
+ new URL(t, "http://example.com");
496
397
  } catch {
497
- throw new Error(`Invalid URL: ${path}`);
498
- }
499
- return path;
500
- }
501
- function getType(payload) {
502
- return Object.prototype.toString.call(payload).slice(8, -1);
503
- }
504
- function isPlainObject(payload) {
505
- if (getType(payload) !== "Object")
506
- return false;
507
- const prototype = Object.getPrototypeOf(payload);
508
- return !!prototype && prototype.constructor === Object && prototype === Object.prototype;
509
- }
510
- function isSymbol(payload) {
511
- return getType(payload) === "Symbol";
512
- }
513
- function assignProp(carry, key, newVal, originalObject) {
514
- const propType = {}.propertyIsEnumerable.call(originalObject, key) ? "enumerable" : "nonenumerable";
515
- if (propType === "enumerable")
516
- carry[key] = newVal;
517
- if (propType === "nonenumerable") {
518
- Object.defineProperty(carry, key, {
519
- value: newVal,
520
- enumerable: false,
521
- writable: true,
522
- configurable: true
523
- });
398
+ throw new Error(`Invalid URL: ${t}`);
524
399
  }
400
+ return t;
525
401
  }
526
- function mergeRecursively(origin, newComer, compareFn) {
527
- if (!isPlainObject(newComer))
528
- return newComer;
529
- let newObject = {};
530
- if (isPlainObject(origin)) {
531
- const props2 = Object.getOwnPropertyNames(origin);
532
- const symbols2 = Object.getOwnPropertySymbols(origin);
533
- newObject = [...props2, ...symbols2].reduce((carry, key) => {
534
- const targetVal = origin[key];
535
- if (!isSymbol(key) && !Object.getOwnPropertyNames(newComer).includes(key) || isSymbol(key) && !Object.getOwnPropertySymbols(newComer).includes(key)) {
536
- assignProp(carry, key, targetVal, origin);
537
- }
538
- return carry;
402
+ function ue(e) {
403
+ return Object.prototype.toString.call(e).slice(8, -1);
404
+ }
405
+ function M(e) {
406
+ if (ue(e) !== "Object")
407
+ return !1;
408
+ const t = Object.getPrototypeOf(e);
409
+ return !!t && t.constructor === Object && t === Object.prototype;
410
+ }
411
+ function ee(e) {
412
+ return ue(e) === "Symbol";
413
+ }
414
+ function te(e, t, r, o) {
415
+ const s = {}.propertyIsEnumerable.call(o, t) ? "enumerable" : "nonenumerable";
416
+ s === "enumerable" && (e[t] = r), s === "nonenumerable" && Object.defineProperty(e, t, {
417
+ value: r,
418
+ enumerable: !1,
419
+ writable: !0,
420
+ configurable: !0
421
+ });
422
+ }
423
+ function de(e, t, r) {
424
+ if (!M(t))
425
+ return t;
426
+ let o = {};
427
+ if (M(e)) {
428
+ const a = Object.getOwnPropertyNames(e), c = Object.getOwnPropertySymbols(e);
429
+ o = [...a, ...c].reduce((i, l) => {
430
+ const d = e[l];
431
+ return (!ee(l) && !Object.getOwnPropertyNames(t).includes(l) || ee(l) && !Object.getOwnPropertySymbols(t).includes(l)) && te(i, l, d, e), i;
539
432
  }, {});
540
433
  }
541
- const props = Object.getOwnPropertyNames(newComer);
542
- const symbols = Object.getOwnPropertySymbols(newComer);
543
- const result = [...props, ...symbols].reduce((carry, key) => {
544
- let newVal = newComer[key];
545
- const targetVal = isPlainObject(origin) ? origin[key] : void 0;
546
- if (targetVal !== void 0 && isPlainObject(newVal)) {
547
- newVal = mergeRecursively(targetVal, newVal);
548
- }
549
- const propToAssign = newVal;
550
- assignProp(carry, key, propToAssign, newComer);
551
- return carry;
552
- }, newObject);
553
- return result;
554
- }
555
- function merge(object, ...otherObjects) {
556
- return otherObjects.reduce((result, newComer) => {
557
- return mergeRecursively(result, newComer);
558
- }, object);
559
- }
560
- function normalizeDocumentFilter(filter) {
561
- return {
562
- country: (filter == null ? void 0 : filter.country) ?? void 0,
563
- region: (filter == null ? void 0 : filter.region) ?? void 0,
564
- type: (filter == null ? void 0 : filter.type) ?? void 0
565
- };
434
+ const s = Object.getOwnPropertyNames(t), n = Object.getOwnPropertySymbols(t);
435
+ return [...s, ...n].reduce((a, c) => {
436
+ let i = t[c];
437
+ const l = M(e) ? e[c] : void 0;
438
+ return l !== void 0 && M(i) && (i = de(l, i)), te(a, c, i, t), a;
439
+ }, o);
566
440
  }
567
- const normalizeDocumentRule = (rule) => {
568
- return {
569
- documentFilter: normalizeDocumentFilter(rule.documentFilter),
570
- fields: rule.fields ?? []
571
- };
572
- };
573
- const normalizeDocumentAnonymizationSettings = (settings) => {
441
+ function tt(e, ...t) {
442
+ return t.reduce((r, o) => de(r, o), e);
443
+ }
444
+ function fe(e) {
574
445
  return {
575
- documentFilter: normalizeDocumentFilter(settings.documentFilter),
576
- fields: settings.fields || [],
577
- documentNumberAnonymizationSettings: settings.documentNumberAnonymizationSettings ? {
578
- prefixDigitsVisible: settings.documentNumberAnonymizationSettings.prefixDigitsVisible,
579
- suffixDigitsVisible: settings.documentNumberAnonymizationSettings.suffixDigitsVisible
580
- } : void 0
446
+ country: (e == null ? void 0 : e.country) ?? void 0,
447
+ region: (e == null ? void 0 : e.region) ?? void 0,
448
+ type: (e == null ? void 0 : e.type) ?? void 0
581
449
  };
582
- };
583
- function buildSessionSettings(options = {}, defaultSessionSettings) {
584
- var _a, _b, _c, _d;
585
- if (options) {
586
- options = Object.fromEntries(
587
- Object.entries(options).filter(([_, value]) => value !== void 0)
588
- );
589
- }
590
- const customDocumentRules = ((_b = (_a = options == null ? void 0 : options.scanningSettings) == null ? void 0 : _a.customDocumentRules) == null ? void 0 : _b.map(
591
- normalizeDocumentRule
592
- )) ?? [];
593
- const customDocumentAnonymizationSettings = ((_d = (_c = options == null ? void 0 : options.scanningSettings) == null ? void 0 : _c.customDocumentAnonymizationSettings) == null ? void 0 : _d.map(
594
- normalizeDocumentAnonymizationSettings
595
- )) ?? [];
596
- const scanningSettings = {
597
- ...options == null ? void 0 : options.scanningSettings,
598
- customDocumentRules,
599
- customDocumentAnonymizationSettings
450
+ }
451
+ const rt = (e) => ({
452
+ documentFilter: fe(e.documentFilter),
453
+ fields: e.fields ?? []
454
+ }), nt = (e) => ({
455
+ documentFilter: fe(e.documentFilter),
456
+ fields: e.fields || [],
457
+ documentNumberAnonymizationSettings: e.documentNumberAnonymizationSettings ? {
458
+ prefixDigitsVisible: e.documentNumberAnonymizationSettings.prefixDigitsVisible,
459
+ suffixDigitsVisible: e.documentNumberAnonymizationSettings.suffixDigitsVisible
460
+ } : void 0
461
+ });
462
+ function st(e = {}, t) {
463
+ var u, a, c, i;
464
+ e && (e = Object.fromEntries(
465
+ Object.entries(e).filter(([l, d]) => d !== void 0)
466
+ ));
467
+ const r = ((a = (u = e == null ? void 0 : e.scanningSettings) == null ? void 0 : u.customDocumentRules) == null ? void 0 : a.map(
468
+ rt
469
+ )) ?? [], o = ((i = (c = e == null ? void 0 : e.scanningSettings) == null ? void 0 : c.customDocumentAnonymizationSettings) == null ? void 0 : i.map(
470
+ nt
471
+ )) ?? [], s = {
472
+ ...e == null ? void 0 : e.scanningSettings,
473
+ customDocumentRules: r,
474
+ customDocumentAnonymizationSettings: o
600
475
  };
601
- const sessionSettings = merge(defaultSessionSettings, {
602
- ...options,
603
- scanningSettings
476
+ return tt(t, {
477
+ ...e,
478
+ scanningSettings: s
604
479
  });
605
- return sessionSettings;
606
480
  }
607
- class ProxyUrlValidationError extends Error {
608
- constructor(message, url) {
609
- super(`Proxy URL validation failed for "${url}": ${message}`);
610
- this.url = url;
611
- this.name = "ProxyUrlValidationError";
481
+ class T extends Error {
482
+ constructor(t, r) {
483
+ super(`Proxy URL validation failed for "${r}": ${t}`), this.url = r, this.name = "ProxyUrlValidationError";
612
484
  }
613
485
  }
614
- class BlinkIdWorker {
486
+ class ot extends Error {
487
+ constructor(r, o) {
488
+ super(r);
489
+ B(this, "code");
490
+ this.name = "LicenseError", this.code = o;
491
+ }
492
+ }
493
+ var h, L, A, R, w, g, me, he, ge, ye, pe;
494
+ class at {
615
495
  constructor() {
616
- __privateAdd(this, _BlinkIdWorker_instances);
496
+ S(this, g);
617
497
  /**
618
498
  * The Wasm module.
619
499
  */
620
- __privateAdd(this, _wasmModule);
500
+ S(this, h);
621
501
  /**
622
502
  * The default session settings.
623
503
  *
624
504
  * Must be initialized when calling initBlinkId.
625
505
  */
626
- __privateAdd(this, _defaultSessionSettings);
506
+ S(this, L);
627
507
  /**
628
508
  * The progress status callback.
629
509
  */
630
- __publicField(this, "progressStatusCallback");
510
+ B(this, "progressStatusCallback");
631
511
  /**
632
512
  * Whether the demo overlay is shown.
633
513
  */
634
- __privateAdd(this, _showDemoOverlay, true);
514
+ S(this, A, !0);
635
515
  /**
636
516
  * Whether the production overlay is shown.
637
517
  */
638
- __privateAdd(this, _showProductionOverlay, true);
518
+ S(this, R, !0);
639
519
  /**
640
520
  * Sanitized proxy URLs for Microblink services.
641
521
  */
642
- __privateAdd(this, _proxyUrls);
522
+ S(this, w);
643
523
  }
644
524
  /**
645
525
  * This method initializes everything.
646
526
  */
647
- async initBlinkId(settings, defaultSessionSettings, progressCallback) {
648
- var _a;
649
- const resourcesPath = new URL(
527
+ async initBlinkId(t, r, o) {
528
+ var u;
529
+ const s = new URL(
650
530
  "resources/",
651
- settings.resourcesLocation
531
+ t.resourcesLocation
652
532
  ).toString();
653
- __privateSet(this, _defaultSessionSettings, defaultSessionSettings);
654
- this.progressStatusCallback = progressCallback;
655
- await __privateMethod(this, _BlinkIdWorker_instances, loadWasm_fn).call(this, {
656
- resourceUrl: resourcesPath,
657
- variant: settings.wasmVariant,
658
- initialMemory: settings.initialMemory,
659
- useLightweightBuild: settings.useLightweightBuild
660
- });
661
- if (!__privateGet(this, _wasmModule)) {
533
+ if (x(this, L, r), this.progressStatusCallback = o, await v(this, g, me).call(this, {
534
+ resourceUrl: s,
535
+ variant: t.wasmVariant,
536
+ initialMemory: t.initialMemory,
537
+ useLightweightBuild: t.useLightweightBuild
538
+ }), !m(this, h))
662
539
  throw new Error("Wasm module not loaded");
663
- }
664
- const licenceUnlockResult = __privateGet(this, _wasmModule).initializeWithLicenseKey(
665
- settings.licenseKey,
666
- settings.userId,
667
- false
540
+ const n = m(this, h).initializeWithLicenseKey(
541
+ t.licenseKey,
542
+ t.userId,
543
+ !1
668
544
  );
669
- if (settings.microblinkProxyUrl) {
670
- __privateMethod(this, _BlinkIdWorker_instances, configureProxyUrls_fn).call(this, settings.microblinkProxyUrl, licenceUnlockResult);
671
- }
672
- if (licenceUnlockResult.unlockResult === "requires-server-permission") {
673
- const baltazarUrl = (_a = __privateGet(this, _proxyUrls)) == null ? void 0 : _a.baltazar;
674
- const serverPermissionResponse = baltazarUrl && licenceUnlockResult.allowBaltazarProxy ? await obtainNewServerPermission(licenceUnlockResult, baltazarUrl) : await obtainNewServerPermission(licenceUnlockResult);
675
- const serverPermissionResult = __privateGet(this, _wasmModule).submitServerPermission(
676
- JSON.stringify(serverPermissionResponse)
545
+ if (n.licenseError)
546
+ throw new ot(
547
+ "License unlock error: " + n.licenseError,
548
+ "LICENSE_ERROR"
677
549
  );
678
- if (serverPermissionResult.error) {
679
- throw new Error("Server unlock error: " + serverPermissionResult.error);
680
- }
550
+ if (t.microblinkProxyUrl && v(this, g, he).call(this, t.microblinkProxyUrl, n), n.unlockResult === "requires-server-permission") {
551
+ const a = (u = m(this, w)) == null ? void 0 : u.baltazar, c = a && n.allowBaltazarProxy ? await X(n, a) : await X(n), i = m(this, h).submitServerPermission(
552
+ JSON.stringify(c)
553
+ );
554
+ if (i.error)
555
+ throw new Error("Server unlock error: " + i.error);
681
556
  }
682
- __privateSet(this, _showDemoOverlay, licenceUnlockResult.showDemoOverlay);
683
- __privateSet(this, _showProductionOverlay, licenceUnlockResult.showProductionOverlay);
557
+ x(this, A, n.showDemoOverlay), x(this, R, n.showProductionOverlay);
684
558
  }
685
559
  /**
686
560
  * This method creates a BlinkID scanning session.
@@ -688,17 +562,14 @@ class BlinkIdWorker {
688
562
  * @param options - The options for the session.
689
563
  * @returns The session.
690
564
  */
691
- createBlinkIdScanningSession(options) {
692
- if (!__privateGet(this, _wasmModule)) {
565
+ createBlinkIdScanningSession(t) {
566
+ if (!m(this, h))
693
567
  throw new Error("Wasm module not loaded");
694
- }
695
- const sessionSettings = buildSessionSettings(
696
- options,
697
- __privateGet(this, _defaultSessionSettings)
698
- );
699
- const session = __privateGet(this, _wasmModule).createBlinkIdScanningSession(sessionSettings);
700
- const proxySession = this.createProxySession(session, sessionSettings);
701
- return proxySession;
568
+ const r = st(
569
+ t,
570
+ m(this, L)
571
+ ), o = m(this, h).createBlinkIdScanningSession(r);
572
+ return this.createProxySession(o, r);
702
573
  }
703
574
  /**
704
575
  * This method creates a proxy session.
@@ -707,38 +578,35 @@ class BlinkIdWorker {
707
578
  * @param sessionSettings - The session settings.
708
579
  * @returns The proxy session.
709
580
  */
710
- createProxySession(session, sessionSettings) {
711
- const customSession = {
712
- getResult: () => session.getResult(),
713
- process: (image) => {
714
- const processResult = session.process(image);
715
- if ("error" in processResult) {
716
- throw new Error(`Error processing frame: ${processResult.error}`);
717
- }
718
- const transferPackage = transfer(
581
+ createProxySession(t, r) {
582
+ return le({
583
+ getResult: () => t.getResult(),
584
+ process: (s) => {
585
+ const n = t.process(s);
586
+ if ("error" in n)
587
+ throw new Error(`Error processing frame: ${n.error}`);
588
+ return ce(
719
589
  {
720
- ...processResult,
721
- arrayBuffer: image.data.buffer
590
+ ...n,
591
+ arrayBuffer: s.data.buffer
722
592
  },
723
- [image.data.buffer]
593
+ [s.data.buffer]
724
594
  );
725
- return transferPackage;
726
595
  },
727
- getSettings: () => sessionSettings,
728
- reset: () => session.reset(),
729
- delete: () => session.delete(),
730
- deleteLater: () => session.deleteLater(),
731
- isDeleted: () => session.isDeleted(),
732
- isAliasOf: (other) => session.isAliasOf(other),
733
- showDemoOverlay: () => __privateGet(this, _showDemoOverlay),
734
- showProductionOverlay: () => __privateGet(this, _showProductionOverlay)
735
- };
736
- return proxy(customSession);
596
+ getSettings: () => r,
597
+ reset: () => t.reset(),
598
+ delete: () => t.delete(),
599
+ deleteLater: () => t.deleteLater(),
600
+ isDeleted: () => t.isDeleted(),
601
+ isAliasOf: (s) => t.isAliasOf(s),
602
+ showDemoOverlay: () => m(this, A),
603
+ showProductionOverlay: () => m(this, R)
604
+ });
737
605
  }
738
606
  /**
739
607
  * This method is called when the worker is terminated.
740
608
  */
741
- [finalizer]() {
609
+ [z]() {
742
610
  }
743
611
  /**
744
612
  * Terminates the workers and the Wasm runtime.
@@ -755,203 +623,159 @@ class BlinkIdWorker {
755
623
  return 1;
756
624
  }
757
625
  }
758
- _wasmModule = new WeakMap();
759
- _defaultSessionSettings = new WeakMap();
760
- _showDemoOverlay = new WeakMap();
761
- _showProductionOverlay = new WeakMap();
762
- _proxyUrls = new WeakMap();
763
- _BlinkIdWorker_instances = new WeakSet();
764
- loadWasm_fn = async function({
765
- resourceUrl,
766
- variant,
767
- useLightweightBuild,
768
- initialMemory
626
+ h = new WeakMap(), L = new WeakMap(), A = new WeakMap(), R = new WeakMap(), w = new WeakMap(), g = new WeakSet(), me = async function({
627
+ resourceUrl: t,
628
+ variant: r,
629
+ useLightweightBuild: o,
630
+ initialMemory: s
769
631
  }) {
770
- if (__privateGet(this, _wasmModule)) {
632
+ if (m(this, h)) {
771
633
  console.log("Wasm already loaded");
772
634
  return;
773
635
  }
774
- const wasmVariant = variant ?? await detectWasmFeatures();
775
- const featureVariant = useLightweightBuild ? "lightweight" : "full";
776
- const MODULE_NAME = "BlinkIdModule";
777
- const variantUrl = buildResourcePath(
778
- resourceUrl,
779
- featureVariant,
780
- wasmVariant
781
- );
782
- const workerUrl = buildResourcePath(variantUrl, `${MODULE_NAME}.js`);
783
- const wasmUrl = buildResourcePath(variantUrl, `${MODULE_NAME}.wasm`);
784
- const dataUrl = buildResourcePath(variantUrl, `${MODULE_NAME}.data`);
785
- const crossOriginWorkerUrl = await getCrossOriginWorkerURL(workerUrl);
786
- const imported = await import(
636
+ const n = r ?? await Ge(), u = o ? "lightweight" : "full", a = "BlinkIdModule", c = U(
637
+ t,
638
+ u,
639
+ n
640
+ ), i = U(c, `${a}.js`), l = U(c, `${a}.wasm`), d = U(c, `${a}.data`), f = await Je(i), C = (await import(
787
641
  /* @vite-ignore */
788
- crossOriginWorkerUrl
789
- );
790
- const createModule = imported.default;
791
- if (!initialMemory) {
792
- initialMemory = isIOS() ? 700 : 200;
793
- }
794
- const wasmMemory = new WebAssembly.Memory({
795
- initial: mbToWasmPages(initialMemory),
796
- maximum: mbToWasmPages(2048),
797
- shared: wasmVariant === "advanced-threads"
642
+ f
643
+ )).default;
644
+ s || (s = Ke() ? 700 : 200);
645
+ const we = new WebAssembly.Memory({
646
+ initial: Q(s),
647
+ maximum: Q(2048),
648
+ shared: n === "advanced-threads"
798
649
  });
799
- let wasmProgress;
800
- let dataProgress;
801
- let lastProgressUpdate = 0;
802
- const progressUpdateInterval = 32;
803
- const throttledCombinedProgress = () => {
804
- if (!this.progressStatusCallback) {
805
- return;
806
- }
807
- if (!wasmProgress || !dataProgress) {
650
+ let b, P, F = 0;
651
+ const be = 32, H = () => {
652
+ if (!this.progressStatusCallback || !b || !P)
808
653
  return;
809
- }
810
- const totalLoaded = wasmProgress.loaded + dataProgress.loaded;
811
- const totalLength = wasmProgress.contentLength + dataProgress.contentLength;
812
- const combinedPercent = Math.min(
813
- Math.round(totalLoaded / totalLength * 100),
814
- 100
815
- );
816
- const combinedProgress = {
817
- loaded: totalLoaded,
818
- contentLength: totalLength,
819
- progress: combinedPercent
820
- };
821
- const currentTime = performance.now();
822
- if (currentTime - lastProgressUpdate < progressUpdateInterval) {
823
- return;
824
- }
825
- lastProgressUpdate = currentTime;
826
- this.progressStatusCallback(combinedProgress);
827
- };
828
- const wasmProgressCallback = (progress) => {
829
- wasmProgress = progress;
830
- void throttledCombinedProgress();
831
- };
832
- const dataProgressCallback = (progress) => {
833
- dataProgress = progress;
834
- void throttledCombinedProgress();
835
- };
836
- const [preloadedWasm, preloadedData] = await Promise.all([
837
- downloadArrayBuffer(wasmUrl, wasmProgressCallback),
838
- downloadArrayBuffer(dataUrl, dataProgressCallback)
654
+ const y = b.finished && P.finished, _ = b.loaded + P.loaded, q = b.contentLength + P.contentLength, ve = y ? 100 : Math.min(Math.round(_ / q * 100), 100), G = performance.now();
655
+ G - F < be || (F = G, this.progressStatusCallback({
656
+ loaded: _,
657
+ contentLength: q,
658
+ progress: ve,
659
+ finished: y
660
+ }));
661
+ }, Pe = (y) => {
662
+ b = y, H();
663
+ }, Se = (y) => {
664
+ P = y, H();
665
+ }, [Ee, xe] = await Promise.all([
666
+ Z(
667
+ l,
668
+ "wasm",
669
+ n,
670
+ u,
671
+ Pe
672
+ ),
673
+ Z(
674
+ d,
675
+ "data",
676
+ n,
677
+ u,
678
+ Se
679
+ )
839
680
  ]);
840
- if (this.progressStatusCallback && wasmProgress && dataProgress) {
841
- const totalLength = wasmProgress.contentLength + dataProgress.contentLength;
681
+ if (this.progressStatusCallback && b && P) {
682
+ const y = b.contentLength + P.contentLength;
842
683
  this.progressStatusCallback({
843
- loaded: totalLength,
844
- contentLength: totalLength,
845
- progress: 100
684
+ loaded: y,
685
+ contentLength: y,
686
+ progress: 100,
687
+ finished: !0
846
688
  });
847
689
  }
848
- __privateSet(this, _wasmModule, await createModule({
849
- locateFile: (path) => {
850
- return `${variantUrl}/${wasmVariant}/${path}`;
851
- },
690
+ if (x(this, h, await C({
691
+ locateFile: (y) => `${c}/${n}/${y}`,
852
692
  // pthreads build breaks without this:
853
693
  // "Failed to execute 'createObjectURL' on 'URL': Overload resolution failed."
854
- mainScriptUrlOrBlob: crossOriginWorkerUrl,
855
- wasmBinary: preloadedWasm,
694
+ mainScriptUrlOrBlob: f,
695
+ wasmBinary: Ee,
856
696
  getPreloadedPackage() {
857
- return preloadedData;
697
+ return xe;
858
698
  },
859
- wasmMemory,
860
- noExitRuntime: true
861
- }));
862
- if (!__privateGet(this, _wasmModule)) {
699
+ wasmMemory: we,
700
+ noExitRuntime: !0
701
+ })), !m(this, h))
863
702
  throw new Error("Failed to load Wasm module");
864
- }
865
- };
866
- /**
703
+ }, /**
867
704
  * Configures proxy URLs based on the provided settings and license permissions.
868
705
  */
869
- configureProxyUrls_fn = function(proxyUrl, licenceUnlockResult) {
870
- if (!proxyUrl) {
706
+ he = function(t, r) {
707
+ if (!t) {
871
708
  console.debug(
872
709
  "No proxy URL configured, using default Microblink servers"
873
710
  );
874
711
  return;
875
712
  }
876
- __privateMethod(this, _BlinkIdWorker_instances, validateProxyPermissions_fn).call(this, licenceUnlockResult, proxyUrl);
713
+ v(this, g, ge).call(this, r, t);
877
714
  try {
878
- __privateSet(this, _proxyUrls, __privateMethod(this, _BlinkIdWorker_instances, sanitizeProxyUrls_fn).call(this, proxyUrl));
879
- if (licenceUnlockResult.allowPingProxy) {
880
- __privateGet(this, _wasmModule).setPingProxyUrl(__privateGet(this, _proxyUrls).ping);
881
- }
882
- console.debug("Proxy URLs configured successfully:", {
883
- ping: __privateGet(this, _proxyUrls).ping,
884
- baltazar: __privateGet(this, _proxyUrls).baltazar
715
+ x(this, w, v(this, g, ye).call(this, t)), r.allowPingProxy && m(this, h).setPingProxyUrl(m(this, w).ping), console.debug("Proxy URLs configured successfully:", {
716
+ ping: m(this, w).ping,
717
+ baltazar: m(this, w).baltazar
885
718
  });
886
- } catch (error) {
887
- const enhancedError = error instanceof ProxyUrlValidationError ? new Error(
888
- `${error.message}
719
+ } catch (o) {
720
+ throw o instanceof T ? new Error(
721
+ `${o.message}
889
722
 
890
723
  Troubleshooting:
891
724
  - Ensure the URL is accessible
892
725
  - Check HTTPS requirements
893
726
  - Verify proxy server implementation`
894
- ) : error;
895
- throw enhancedError;
727
+ ) : o;
896
728
  }
897
- };
898
- /**
729
+ }, /**
899
730
  * Validates that the license allows proxy usage.
900
731
  */
901
- validateProxyPermissions_fn = function(licenceUnlockResult, proxyUrl) {
902
- if (!licenceUnlockResult.allowPingProxy && !licenceUnlockResult.allowBaltazarProxy) {
732
+ ge = function(t, r) {
733
+ if (!t.allowPingProxy && !t.allowBaltazarProxy)
903
734
  throw new Error(
904
- `Proxy URL "${proxyUrl}" was provided, but your license does not permit proxy usage.
905
- License permissions: pingProxy=${licenceUnlockResult.allowPingProxy}, baltazarProxy=${licenceUnlockResult.allowBaltazarProxy}
735
+ `Proxy URL "${r}" was provided, but your license does not permit proxy usage.
736
+ License permissions: pingProxy=${t.allowPingProxy}, baltazarProxy=${t.allowBaltazarProxy}
906
737
  Check your license.`
907
738
  );
908
- } else if (!licenceUnlockResult.hasPing && licenceUnlockResult.unlockResult !== "requires-server-permission") {
739
+ if (!t.hasPing && t.unlockResult !== "requires-server-permission")
909
740
  throw new Error(
910
741
  `Microblink proxy URL is set but cannot be used because ping and online license check are disabled in your license.
911
742
  Check your license.`
912
743
  );
913
- }
914
- };
915
- /**
744
+ }, /**
916
745
  * Validates and sanitizes proxy URLs for different Microblink services.
917
746
  */
918
- sanitizeProxyUrls_fn = function(baseUrl) {
919
- let parsedUrl;
747
+ ye = function(t) {
748
+ let r;
920
749
  try {
921
- parsedUrl = new URL(baseUrl);
922
- } catch (error) {
923
- throw new ProxyUrlValidationError(
924
- `Failed to create URL instance for provided Microblink proxy URL "${baseUrl}". Expected format: https://your-proxy.com or https://your-proxy.com/`,
925
- baseUrl
750
+ r = new URL(t);
751
+ } catch {
752
+ throw new T(
753
+ `Failed to create URL instance for provided Microblink proxy URL "${t}". Expected format: https://your-proxy.com or https://your-proxy.com/`,
754
+ t
926
755
  );
927
756
  }
928
- if (parsedUrl.protocol !== "https:") {
929
- throw new ProxyUrlValidationError(
930
- `Proxy URL validation failed for "${baseUrl}": HTTPS protocol must be used. Expected format: https://your-proxy.com or https://your-proxy.com/`,
931
- baseUrl
757
+ if (r.protocol !== "https:")
758
+ throw new T(
759
+ `Proxy URL validation failed for "${t}": HTTPS protocol must be used. Expected format: https://your-proxy.com or https://your-proxy.com/`,
760
+ t
932
761
  );
933
- }
934
- const baseUrlStr = parsedUrl.origin;
935
- const baltazarUrl = __privateMethod(this, _BlinkIdWorker_instances, buildServiceUrl_fn).call(this, baseUrlStr, "/api/v2/status/check");
762
+ const o = r.origin, s = v(this, g, pe).call(this, o, "/api/v2/status/check");
936
763
  return {
937
- ping: baseUrlStr,
938
- baltazar: baltazarUrl
764
+ ping: o,
765
+ baltazar: s
939
766
  };
940
- };
941
- /**
767
+ }, /**
942
768
  * Builds a service URL by combining base URL with service path.
943
769
  */
944
- buildServiceUrl_fn = function(baseUrl, servicePath) {
770
+ pe = function(t, r) {
945
771
  try {
946
- const url = new URL(servicePath, baseUrl);
947
- return url.toString();
948
- } catch (error) {
949
- throw new ProxyUrlValidationError(
950
- `Failed to build service URL for path "${servicePath}"`,
951
- baseUrl
772
+ return new URL(r, t).toString();
773
+ } catch {
774
+ throw new T(
775
+ `Failed to build service URL for path "${r}"`,
776
+ t
952
777
  );
953
778
  }
954
779
  };
955
- const blinkIdWorker = new BlinkIdWorker();
956
- expose(blinkIdWorker);
957
- //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"blinkid-worker.js","sources":["../../../node_modules/.pnpm/comlink@4.4.2/node_modules/comlink/dist/esm/comlink.mjs","../../../node_modules/.pnpm/wasm-feature-detect@1.8.0/node_modules/wasm-feature-detect/dist/esm/index.js","../src/wasm-feature-detect.ts","../src/getCrossOriginWorkerURL.ts","../src/isSafari.ts","../src/licencing.ts","../src/mbToWasmPages.ts","../src/downloadArrayBuffer.ts","../src/buildResourcePath.ts","../../../node_modules/.pnpm/is-what@5.0.2/node_modules/is-what/dist/getType.js","../../../node_modules/.pnpm/is-what@5.0.2/node_modules/is-what/dist/isPlainObject.js","../../../node_modules/.pnpm/is-what@5.0.2/node_modules/is-what/dist/isSymbol.js","../../../node_modules/.pnpm/merge-anything@6.0.3/node_modules/merge-anything/dist/merge.js","../src/buildSessionSettings.ts","../src/BlinkIdWorker.ts"],"sourcesContent":["/**\n * @license\n * Copyright 2019 Google LLC\n * SPDX-License-Identifier: Apache-2.0\n */\nconst proxyMarker = Symbol(\"Comlink.proxy\");\nconst createEndpoint = Symbol(\"Comlink.endpoint\");\nconst releaseProxy = Symbol(\"Comlink.releaseProxy\");\nconst finalizer = Symbol(\"Comlink.finalizer\");\nconst throwMarker = Symbol(\"Comlink.thrown\");\nconst isObject = (val) => (typeof val === \"object\" && val !== null) || typeof val === \"function\";\n/**\n * Internal transfer handle to handle objects marked to proxy.\n */\nconst proxyTransferHandler = {\n    canHandle: (val) => isObject(val) && val[proxyMarker],\n    serialize(obj) {\n        const { port1, port2 } = new MessageChannel();\n        expose(obj, port1);\n        return [port2, [port2]];\n    },\n    deserialize(port) {\n        port.start();\n        return wrap(port);\n    },\n};\n/**\n * Internal transfer handler to handle thrown exceptions.\n */\nconst throwTransferHandler = {\n    canHandle: (value) => isObject(value) && throwMarker in value,\n    serialize({ value }) {\n        let serialized;\n        if (value instanceof Error) {\n            serialized = {\n                isError: true,\n                value: {\n                    message: value.message,\n                    name: value.name,\n                    stack: value.stack,\n                },\n            };\n        }\n        else {\n            serialized = { isError: false, value };\n        }\n        return [serialized, []];\n    },\n    deserialize(serialized) {\n        if (serialized.isError) {\n            throw Object.assign(new Error(serialized.value.message), serialized.value);\n        }\n        throw serialized.value;\n    },\n};\n/**\n * Allows customizing the serialization of certain values.\n */\nconst transferHandlers = new Map([\n    [\"proxy\", proxyTransferHandler],\n    [\"throw\", throwTransferHandler],\n]);\nfunction isAllowedOrigin(allowedOrigins, origin) {\n    for (const allowedOrigin of allowedOrigins) {\n        if (origin === allowedOrigin || allowedOrigin === \"*\") {\n            return true;\n        }\n        if (allowedOrigin instanceof RegExp && allowedOrigin.test(origin)) {\n            return true;\n        }\n    }\n    return false;\n}\nfunction expose(obj, ep = globalThis, allowedOrigins = [\"*\"]) {\n    ep.addEventListener(\"message\", function callback(ev) {\n        if (!ev || !ev.data) {\n            return;\n        }\n        if (!isAllowedOrigin(allowedOrigins, ev.origin)) {\n            console.warn(`Invalid origin '${ev.origin}' for comlink proxy`);\n            return;\n        }\n        const { id, type, path } = Object.assign({ path: [] }, ev.data);\n        const argumentList = (ev.data.argumentList || []).map(fromWireValue);\n        let returnValue;\n        try {\n            const parent = path.slice(0, -1).reduce((obj, prop) => obj[prop], obj);\n            const rawValue = path.reduce((obj, prop) => obj[prop], obj);\n            switch (type) {\n                case \"GET\" /* MessageType.GET */:\n                    {\n                        returnValue = rawValue;\n                    }\n                    break;\n                case \"SET\" /* MessageType.SET */:\n                    {\n                        parent[path.slice(-1)[0]] = fromWireValue(ev.data.value);\n                        returnValue = true;\n                    }\n                    break;\n                case \"APPLY\" /* MessageType.APPLY */:\n                    {\n                        returnValue = rawValue.apply(parent, argumentList);\n                    }\n                    break;\n                case \"CONSTRUCT\" /* MessageType.CONSTRUCT */:\n                    {\n                        const value = new rawValue(...argumentList);\n                        returnValue = proxy(value);\n                    }\n                    break;\n                case \"ENDPOINT\" /* MessageType.ENDPOINT */:\n                    {\n                        const { port1, port2 } = new MessageChannel();\n                        expose(obj, port2);\n                        returnValue = transfer(port1, [port1]);\n                    }\n                    break;\n                case \"RELEASE\" /* MessageType.RELEASE */:\n                    {\n                        returnValue = undefined;\n                    }\n                    break;\n                default:\n                    return;\n            }\n        }\n        catch (value) {\n            returnValue = { value, [throwMarker]: 0 };\n        }\n        Promise.resolve(returnValue)\n            .catch((value) => {\n            return { value, [throwMarker]: 0 };\n        })\n            .then((returnValue) => {\n            const [wireValue, transferables] = toWireValue(returnValue);\n            ep.postMessage(Object.assign(Object.assign({}, wireValue), { id }), transferables);\n            if (type === \"RELEASE\" /* MessageType.RELEASE */) {\n                // detach and deactive after sending release response above.\n                ep.removeEventListener(\"message\", callback);\n                closeEndPoint(ep);\n                if (finalizer in obj && typeof obj[finalizer] === \"function\") {\n                    obj[finalizer]();\n                }\n            }\n        })\n            .catch((error) => {\n            // Send Serialization Error To Caller\n            const [wireValue, transferables] = toWireValue({\n                value: new TypeError(\"Unserializable return value\"),\n                [throwMarker]: 0,\n            });\n            ep.postMessage(Object.assign(Object.assign({}, wireValue), { id }), transferables);\n        });\n    });\n    if (ep.start) {\n        ep.start();\n    }\n}\nfunction isMessagePort(endpoint) {\n    return endpoint.constructor.name === \"MessagePort\";\n}\nfunction closeEndPoint(endpoint) {\n    if (isMessagePort(endpoint))\n        endpoint.close();\n}\nfunction wrap(ep, target) {\n    const pendingListeners = new Map();\n    ep.addEventListener(\"message\", function handleMessage(ev) {\n        const { data } = ev;\n        if (!data || !data.id) {\n            return;\n        }\n        const resolver = pendingListeners.get(data.id);\n        if (!resolver) {\n            return;\n        }\n        try {\n            resolver(data);\n        }\n        finally {\n            pendingListeners.delete(data.id);\n        }\n    });\n    return createProxy(ep, pendingListeners, [], target);\n}\nfunction throwIfProxyReleased(isReleased) {\n    if (isReleased) {\n        throw new Error(\"Proxy has been released and is not useable\");\n    }\n}\nfunction releaseEndpoint(ep) {\n    return requestResponseMessage(ep, new Map(), {\n        type: \"RELEASE\" /* MessageType.RELEASE */,\n    }).then(() => {\n        closeEndPoint(ep);\n    });\n}\nconst proxyCounter = new WeakMap();\nconst proxyFinalizers = \"FinalizationRegistry\" in globalThis &&\n    new FinalizationRegistry((ep) => {\n        const newCount = (proxyCounter.get(ep) || 0) - 1;\n        proxyCounter.set(ep, newCount);\n        if (newCount === 0) {\n            releaseEndpoint(ep);\n        }\n    });\nfunction registerProxy(proxy, ep) {\n    const newCount = (proxyCounter.get(ep) || 0) + 1;\n    proxyCounter.set(ep, newCount);\n    if (proxyFinalizers) {\n        proxyFinalizers.register(proxy, ep, proxy);\n    }\n}\nfunction unregisterProxy(proxy) {\n    if (proxyFinalizers) {\n        proxyFinalizers.unregister(proxy);\n    }\n}\nfunction createProxy(ep, pendingListeners, path = [], target = function () { }) {\n    let isProxyReleased = false;\n    const proxy = new Proxy(target, {\n        get(_target, prop) {\n            throwIfProxyReleased(isProxyReleased);\n            if (prop === releaseProxy) {\n                return () => {\n                    unregisterProxy(proxy);\n                    releaseEndpoint(ep);\n                    pendingListeners.clear();\n                    isProxyReleased = true;\n                };\n            }\n            if (prop === \"then\") {\n                if (path.length === 0) {\n                    return { then: () => proxy };\n                }\n                const r = requestResponseMessage(ep, pendingListeners, {\n                    type: \"GET\" /* MessageType.GET */,\n                    path: path.map((p) => p.toString()),\n                }).then(fromWireValue);\n                return r.then.bind(r);\n            }\n            return createProxy(ep, pendingListeners, [...path, prop]);\n        },\n        set(_target, prop, rawValue) {\n            throwIfProxyReleased(isProxyReleased);\n            // FIXME: ES6 Proxy Handler `set` methods are supposed to return a\n            // boolean. To show good will, we return true asynchronously ¯\\_(ツ)_/¯\n            const [value, transferables] = toWireValue(rawValue);\n            return requestResponseMessage(ep, pendingListeners, {\n                type: \"SET\" /* MessageType.SET */,\n                path: [...path, prop].map((p) => p.toString()),\n                value,\n            }, transferables).then(fromWireValue);\n        },\n        apply(_target, _thisArg, rawArgumentList) {\n            throwIfProxyReleased(isProxyReleased);\n            const last = path[path.length - 1];\n            if (last === createEndpoint) {\n                return requestResponseMessage(ep, pendingListeners, {\n                    type: \"ENDPOINT\" /* MessageType.ENDPOINT */,\n                }).then(fromWireValue);\n            }\n            // We just pretend that `bind()` didn’t happen.\n            if (last === \"bind\") {\n                return createProxy(ep, pendingListeners, path.slice(0, -1));\n            }\n            const [argumentList, transferables] = processArguments(rawArgumentList);\n            return requestResponseMessage(ep, pendingListeners, {\n                type: \"APPLY\" /* MessageType.APPLY */,\n                path: path.map((p) => p.toString()),\n                argumentList,\n            }, transferables).then(fromWireValue);\n        },\n        construct(_target, rawArgumentList) {\n            throwIfProxyReleased(isProxyReleased);\n            const [argumentList, transferables] = processArguments(rawArgumentList);\n            return requestResponseMessage(ep, pendingListeners, {\n                type: \"CONSTRUCT\" /* MessageType.CONSTRUCT */,\n                path: path.map((p) => p.toString()),\n                argumentList,\n            }, transferables).then(fromWireValue);\n        },\n    });\n    registerProxy(proxy, ep);\n    return proxy;\n}\nfunction myFlat(arr) {\n    return Array.prototype.concat.apply([], arr);\n}\nfunction processArguments(argumentList) {\n    const processed = argumentList.map(toWireValue);\n    return [processed.map((v) => v[0]), myFlat(processed.map((v) => v[1]))];\n}\nconst transferCache = new WeakMap();\nfunction transfer(obj, transfers) {\n    transferCache.set(obj, transfers);\n    return obj;\n}\nfunction proxy(obj) {\n    return Object.assign(obj, { [proxyMarker]: true });\n}\nfunction windowEndpoint(w, context = globalThis, targetOrigin = \"*\") {\n    return {\n        postMessage: (msg, transferables) => w.postMessage(msg, targetOrigin, transferables),\n        addEventListener: context.addEventListener.bind(context),\n        removeEventListener: context.removeEventListener.bind(context),\n    };\n}\nfunction toWireValue(value) {\n    for (const [name, handler] of transferHandlers) {\n        if (handler.canHandle(value)) {\n            const [serializedValue, transferables] = handler.serialize(value);\n            return [\n                {\n                    type: \"HANDLER\" /* WireValueType.HANDLER */,\n                    name,\n                    value: serializedValue,\n                },\n                transferables,\n            ];\n        }\n    }\n    return [\n        {\n            type: \"RAW\" /* WireValueType.RAW */,\n            value,\n        },\n        transferCache.get(value) || [],\n    ];\n}\nfunction fromWireValue(value) {\n    switch (value.type) {\n        case \"HANDLER\" /* WireValueType.HANDLER */:\n            return transferHandlers.get(value.name).deserialize(value.value);\n        case \"RAW\" /* WireValueType.RAW */:\n            return value.value;\n    }\n}\nfunction requestResponseMessage(ep, pendingListeners, msg, transfers) {\n    return new Promise((resolve) => {\n        const id = generateUUID();\n        pendingListeners.set(id, resolve);\n        if (ep.start) {\n            ep.start();\n        }\n        ep.postMessage(Object.assign({ id }, msg), transfers);\n    });\n}\nfunction generateUUID() {\n    return new Array(4)\n        .fill(0)\n        .map(() => Math.floor(Math.random() * Number.MAX_SAFE_INTEGER).toString(16))\n        .join(\"-\");\n}\n\nexport { createEndpoint, expose, finalizer, proxy, proxyMarker, releaseProxy, transfer, transferHandlers, windowEndpoint, wrap };\n//# sourceMappingURL=comlink.mjs.map\n","export const bigInt=()=>(async e=>{try{return(await WebAssembly.instantiate(e)).instance.exports.b(BigInt(0))===BigInt(0)}catch(e){return!1}})(new Uint8Array([0,97,115,109,1,0,0,0,1,6,1,96,1,126,1,126,3,2,1,0,7,5,1,1,98,0,0,10,6,1,4,0,32,0,11])),bulkMemory=async()=>WebAssembly.validate(new Uint8Array([0,97,115,109,1,0,0,0,1,4,1,96,0,0,3,2,1,0,5,3,1,0,1,10,14,1,12,0,65,0,65,0,65,0,252,10,0,0,11])),exceptions=async()=>WebAssembly.validate(new Uint8Array([0,97,115,109,1,0,0,0,1,4,1,96,0,0,3,2,1,0,10,8,1,6,0,6,64,25,11,11])),exceptionsFinal=()=>(async()=>{try{return new WebAssembly.Module(Uint8Array.from(atob(\"AGFzbQEAAAABBAFgAAADAgEAChABDgACaR9AAQMAAAsACxoL\"),(e=>e.codePointAt(0)))),!0}catch(e){return!1}})(),extendedConst=async()=>WebAssembly.validate(new Uint8Array([0,97,115,109,1,0,0,0,5,3,1,0,1,11,9,1,0,65,1,65,2,106,11,0])),gc=()=>(async()=>WebAssembly.validate(new Uint8Array([0,97,115,109,1,0,0,0,1,5,1,95,1,120,0])))(),jsStringBuiltins=()=>(async()=>{try{return await WebAssembly.instantiate(Uint8Array.from(atob(\"AGFzbQEAAAABBgFgAW8BfwIXAQ53YXNtOmpzLXN0cmluZwR0ZXN0AAA=\"),(e=>e.codePointAt(0))),{},{builtins:[\"js-string\"]}),!0}catch(e){return!1}})(),jspi=()=>(async()=>\"Suspending\"in WebAssembly)(),memory64=async()=>WebAssembly.validate(new Uint8Array([0,97,115,109,1,0,0,0,5,3,1,4,1])),multiMemory=()=>(async()=>{try{return new WebAssembly.Module(new Uint8Array([0,97,115,109,1,0,0,0,5,5,2,0,0,0,0])),!0}catch(e){return!1}})(),multiValue=async()=>WebAssembly.validate(new Uint8Array([0,97,115,109,1,0,0,0,1,6,1,96,0,2,127,127,3,2,1,0,10,8,1,6,0,65,0,65,0,11])),mutableGlobals=async()=>WebAssembly.validate(new Uint8Array([0,97,115,109,1,0,0,0,2,8,1,1,97,1,98,3,127,1,6,6,1,127,1,65,0,11,7,5,1,1,97,3,1])),referenceTypes=async()=>WebAssembly.validate(new Uint8Array([0,97,115,109,1,0,0,0,1,4,1,96,0,0,3,2,1,0,10,7,1,5,0,208,112,26,11])),relaxedSimd=async()=>WebAssembly.validate(new Uint8Array([0,97,115,109,1,0,0,0,1,5,1,96,0,1,123,3,2,1,0,10,15,1,13,0,65,1,253,15,65,2,253,15,253,128,2,11])),saturatedFloatToInt=async()=>WebAssembly.validate(new Uint8Array([0,97,115,109,1,0,0,0,1,4,1,96,0,0,3,2,1,0,10,12,1,10,0,67,0,0,0,0,252,0,26,11])),signExtensions=async()=>WebAssembly.validate(new Uint8Array([0,97,115,109,1,0,0,0,1,4,1,96,0,0,3,2,1,0,10,8,1,6,0,65,0,192,26,11])),simd=async()=>WebAssembly.validate(new Uint8Array([0,97,115,109,1,0,0,0,1,5,1,96,0,1,123,3,2,1,0,10,10,1,8,0,65,0,253,15,253,98,11])),streamingCompilation=()=>(async()=>\"compileStreaming\"in WebAssembly)(),tailCall=async()=>WebAssembly.validate(new Uint8Array([0,97,115,109,1,0,0,0,1,4,1,96,0,0,3,2,1,0,10,6,1,4,0,18,0,11])),threads=()=>(async e=>{try{return\"undefined\"!=typeof MessageChannel&&(new MessageChannel).port1.postMessage(new SharedArrayBuffer(1)),WebAssembly.validate(e)}catch(e){return!1}})(new Uint8Array([0,97,115,109,1,0,0,0,1,4,1,96,0,0,3,2,1,0,5,4,1,3,1,1,10,11,1,9,0,65,0,254,16,2,0,26,11])),typeReflection=()=>(async()=>\"Function\"in WebAssembly)(),typedFunctionReferences=()=>(async()=>{try{return new WebAssembly.Module(Uint8Array.from(atob(\"AGFzbQEAAAABEANgAX8Bf2ABZAABf2AAAX8DBAMBAAIJBQEDAAEBChwDCwBBCkEqIAAUAGoLBwAgAEEBagsGANIBEAAL\"),(e=>e.codePointAt(0)))),!0}catch(e){return!1}})();\n","/**\n * Copyright (c) 2025 Microblink Ltd. All rights reserved.\n */\n\nimport {\n  bulkMemory,\n  mutableGlobals,\n  referenceTypes,\n  saturatedFloatToInt,\n  signExtensions,\n  simd,\n  threads,\n} from \"wasm-feature-detect\";\n\n/**\n * Checks if the browser is Safari.\n *\n * @returns True if the browser is Safari, false otherwise.\n */\nexport function isSafari() {\n  const userAgent = navigator.userAgent.toLowerCase();\n  return userAgent.includes(\"safari\") && !userAgent.includes(\"chrome\");\n}\n\n/**\n * Checks if the browser supports WASM threads.\n *\n * @returns True if the browser supports WASM threads, false otherwise.\n *\n * Safari 16 shipped with WASM threads support, but it didn't ship with nested\n * workers support, so an extra check is needed.\n *\n * @see https://github.com/GoogleChromeLabs/squoosh/pull/1325/files#diff-904900db64cd3f48b0e765dbbdc6a218a7ea74a199671bde82a8944a904db86f\n */\nexport default async function checkThreadsSupport(): Promise<boolean> {\n  const supportsWasmThreads = await threads();\n  if (!supportsWasmThreads) return false;\n\n  if (!(\"importScripts\" in self)) {\n    throw Error(\"Not implemented\");\n  }\n\n  // Safari has issues with shared memory\n  // https://github.com/emscripten-core/emscripten/issues/19374\n  if (isSafari()) {\n    return false;\n  }\n\n  return \"Worker\" in self;\n}\n\n/**\n * The WASM variant.\n */\nexport type WasmVariant = \"basic\" | \"advanced\" | \"advanced-threads\";\n\n/**\n * Detects the WASM features.\n *\n * @returns The WASM variant.\n */\nexport async function detectWasmFeatures(): Promise<WasmVariant> {\n  const basicSet = [\n    mutableGlobals(),\n    referenceTypes(),\n    bulkMemory(),\n    saturatedFloatToInt(),\n    signExtensions(),\n  ];\n\n  const supportsBasic = (await Promise.all(basicSet)).every(Boolean);\n\n  if (!supportsBasic) {\n    throw new Error(\"Browser doesn't meet minimum requirements!\");\n  }\n\n  const supportsAdvanced = await simd();\n\n  if (!supportsAdvanced) {\n    return \"basic\";\n  }\n\n  const supportsAdvancedThreads = await checkThreadsSupport();\n\n  if (!supportsAdvancedThreads) {\n    return \"advanced\";\n  }\n\n  return \"advanced-threads\";\n}\n","/**\n * Copyright (c) 2025 Microblink Ltd. All rights reserved.\n */\n\n/**\n * Original: https://github.com/CezaryDanielNowak/CrossOriginWorker\n */\n\n/**\n * The type of the worker.\n */\nconst workerType = \"application/javascript\";\n\n/**\n * The options.\n */\ntype Options = {\n  /**\n   * Whether to skip same origin.\n   */\n  skipSameOrigin?: boolean;\n  /**\n   * Whether to use blob.\n   */\n  useBlob?: boolean;\n};\n\n/**\n * Gets the cross-origin worker URL.\n * If same origin, the original worker URL is returned.\n * Otherwise, the worker is fetched and converted to a blob or data URL.\n *\n * @param originalWorkerUrl - The original worker URL.\n * @param _options - The options.\n * @returns The cross-origin worker URL.\n */\nexport const getCrossOriginWorkerURL = (\n  originalWorkerUrl: string,\n  _options: Options = {},\n) => {\n  const options = {\n    skipSameOrigin: true,\n    useBlob: true,\n\n    ..._options,\n  };\n\n  if (\n    options.skipSameOrigin &&\n    new URL(originalWorkerUrl).origin === self.location.origin\n  ) {\n    // The same origin - Worker will run fine\n    return Promise.resolve(originalWorkerUrl);\n  }\n\n  return new Promise<string>(\n    (resolve, reject) =>\n      void fetch(originalWorkerUrl)\n        .then((res) => res.text())\n        .then((codeString) => {\n          const workerPath = new URL(originalWorkerUrl).href.split(\"/\");\n          workerPath.pop();\n\n          let finalURL = \"\";\n\n          if (options.useBlob) {\n            const blob = new Blob([codeString], { type: workerType });\n            finalURL = URL.createObjectURL(blob);\n          } else {\n            finalURL = `data:${workerType},` + encodeURIComponent(codeString);\n          }\n\n          resolve(finalURL);\n        })\n        .catch(reject),\n  );\n};\n","/**\n * Copyright (c) 2025 Microblink Ltd. All rights reserved.\n */\n\n/**\n * Checks if the current environment is iOS.\n *\n * @returns True if running on iOS device, false otherwise.\n */\nexport function isIOS(): boolean {\n  const userAgent = self.navigator.userAgent.toLowerCase();\n  return /iphone|ipad|ipod/.test(userAgent);\n}\n\n/**\n * Checks if the current environment is Safari browser.\n *\n * @returns True if running on Safari, false otherwise.\n */\nexport function isSafari(): boolean {\n  const userAgent = self.navigator.userAgent.toLowerCase();\n  const isSafariBrowser =\n    userAgent.includes(\"safari\") && !userAgent.includes(\"chrome\");\n  return isSafariBrowser || isIOS();\n}\n","/**\n * Copyright (c) 2025 Microblink Ltd. All rights reserved.\n */\n\nimport {\n  LicenseUnlockResult,\n  LicenseRequest,\n  LicenseStatusResponse,\n} from \"@microblink/blinkid-wasm\";\n\n/**\n * Constructs the license request.\n *\n * @param unlockResult - The license unlock result.\n * @returns The license request.\n */\nfunction constructLicenseRequest(\n  unlockResult: LicenseUnlockResult,\n): LicenseRequest {\n  return {\n    licenseId: unlockResult.licenseId,\n    licensee: unlockResult.licensee,\n    applicationIds: unlockResult.applicationIds,\n    packageName: unlockResult.packageName,\n    platform: \"Browser\",\n    sdkName: unlockResult.sdkName,\n    sdkVersion: unlockResult.sdkVersion,\n  };\n}\n\n/**\n * Obtains a new server permission from Microblink's Baltazar service.\n *\n * @param unlockResult - The license unlock result containing license information.\n * @param baltazarUrl - The Baltazar server URL. Can be a proxy URL if configured.\n *                      Defaults to the official Microblink Baltazar server.\n * @returns Promise resolving to the server permission response.\n *\n * @example\n * ```typescript\n * // Using default Microblink server\n * const permission = await obtainNewServerPermission(unlockResult);\n *\n * // Using custom proxy server\n * const permission = await obtainNewServerPermission(\n *   unlockResult,\n *   \"https://your-proxy.example.com/api/v2/status/check\"\n * );\n * ```\n */\nexport async function obtainNewServerPermission(\n  unlockResult: LicenseUnlockResult,\n  baltazarUrl = \"https://baltazar.microblink.com/api/v2/status/check\",\n) {\n  // Basic URL validation\n  if (!baltazarUrl || typeof baltazarUrl !== \"string\") {\n    throw new Error(\"Invalid baltazarUrl: must be a non-empty string\");\n  }\n\n  // Validates URL format\n  try {\n    new URL(baltazarUrl);\n  } catch (error) {\n    throw new Error(`Invalid baltazarUrl format: ${baltazarUrl}`);\n  }\n\n  try {\n    const response = await fetch(baltazarUrl, {\n      method: \"POST\",\n      headers: {\n        \"Content-Type\": \"application/json\",\n      },\n      cache: \"no-cache\",\n      body: JSON.stringify(constructLicenseRequest(unlockResult)),\n    });\n\n    if (!response.ok) {\n      throw new Error(\n        `Server returned error: ${response.status} ${response.statusText}`,\n      );\n    }\n\n    const serverPermission = (await response.json()) as LicenseStatusResponse;\n    return serverPermission;\n  } catch (error) {\n    console.error(\"Server permission request failed:\", error);\n    throw error;\n  }\n}\n","/**\n * Copyright (c) 2025 Microblink Ltd. All rights reserved.\n */\n\n/**\n * This function converts megabytes to WebAssembly pages.\n *\n * @param mb - The number of megabytes.\n * @returns The number of WebAssembly pages.\n */\nexport function mbToWasmPages(mb: number) {\n  return Math.ceil((mb * 1024 * 1024) / 64 / 1024);\n}\n","/**\n * Copyright (c) 2025 Microblink Ltd. All rights reserved.\n */\n\n/**\n * Downloads the resource at the given URL and returns its ArrayBuffer.\n * @param url - The URL of the resource to download.\n * @param progressCallback - An optional callback that is called with download progress.\n * @returns The downloaded ArrayBuffer.\n */\nexport async function downloadArrayBuffer(\n  url: string,\n  progressCallback?: (progress: DownloadProgress) => void,\n): Promise<ArrayBuffer> {\n  const response = await fetch(url);\n\n  // Fallback: if response body or content length not available, return the full ArrayBuffer directly.\n  if (!response.body || !response.headers.has(\"Content-Length\")) {\n    return response.arrayBuffer();\n  }\n\n  const contentLength = parseInt(response.headers.get(\"Content-Length\")!, 10);\n  let loaded = 0;\n  const reader = response.body.getReader();\n  const chunks: Uint8Array[] = [];\n\n  let result = await reader.read();\n  while (!result.done) {\n    const value = result.value;\n    if (value) {\n      chunks.push(value);\n      loaded += value.length;\n      if (progressCallback) {\n        const progress = Math.min(\n          Math.round((loaded / contentLength) * 100),\n          100,\n        );\n        progressCallback({\n          loaded,\n          contentLength,\n          progress,\n        });\n      }\n    }\n    result = await reader.read();\n  }\n\n  const allChunks = new Uint8Array(loaded);\n  let position = 0;\n  for (const chunk of chunks) {\n    allChunks.set(chunk, position);\n    position += chunk.length;\n  }\n\n  return allChunks.buffer;\n}\n\n/**\n * The download progress.\n */\nexport type DownloadProgress = {\n  loaded: number;\n  contentLength: number;\n  progress: number;\n};\n","/**\n * Copyright (c) 2025 Microblink Ltd. All rights reserved.\n */\n\n/**\n * Builds, normalizes, and validates a resource URL by joining path segments.\n *\n * @param segments - Array of path segments to join.\n * @returns Normalized URL path.\n * @throws Error if the resulting URL is invalid.\n */\nexport function buildResourcePath(...segments: string[]): string {\n  // Filter out null, undefined, or empty segments using Boolean.\n  const path = segments\n    .filter((segment) => segment) // Using Boolean filtering is safe since non-empty strings are truthy.\n    .join(\"/\")\n    .replace(/([^:]\\/)\\/+/g, \"$1\");\n\n  // Validate the URL using a dummy base (works for both absolute and relative URLs).\n  try {\n    new URL(path, \"http://example.com\");\n  } catch {\n    throw new Error(`Invalid URL: ${path}`);\n  }\n\n  return path;\n}\n","/** Returns the object type of the given payload */\nexport function getType(payload) {\n    return Object.prototype.toString.call(payload).slice(8, -1);\n}\n","import { getType } from './getType.js';\n/**\n * Returns whether the payload is a plain JavaScript object (excluding special classes or objects\n * with other prototypes)\n */\nexport function isPlainObject(payload) {\n    if (getType(payload) !== 'Object')\n        return false;\n    const prototype = Object.getPrototypeOf(payload);\n    return !!prototype && prototype.constructor === Object && prototype === Object.prototype;\n}\n","import { getType } from './getType.js';\n/** Returns whether the payload is a Symbol */\nexport function isSymbol(payload) {\n    return getType(payload) === 'Symbol';\n}\n","import { isPlainObject, isSymbol } from 'is-what';\nimport { concatArrays } from './extensions.js';\nfunction assignProp(carry, key, newVal, originalObject) {\n    const propType = {}.propertyIsEnumerable.call(originalObject, key)\n        ? 'enumerable'\n        : 'nonenumerable';\n    if (propType === 'enumerable')\n        carry[key] = newVal;\n    if (propType === 'nonenumerable') {\n        Object.defineProperty(carry, key, {\n            value: newVal,\n            enumerable: false,\n            writable: true,\n            configurable: true,\n        });\n    }\n}\nfunction mergeRecursively(origin, newComer, compareFn) {\n    // always return newComer if its not an object\n    if (!isPlainObject(newComer))\n        return newComer;\n    // define newObject to merge all values upon\n    let newObject = {};\n    if (isPlainObject(origin)) {\n        const props = Object.getOwnPropertyNames(origin);\n        const symbols = Object.getOwnPropertySymbols(origin);\n        newObject = [...props, ...symbols].reduce((carry, key) => {\n            const targetVal = origin[key];\n            if ((!isSymbol(key) && !Object.getOwnPropertyNames(newComer).includes(key)) ||\n                (isSymbol(key) && !Object.getOwnPropertySymbols(newComer).includes(key))) {\n                assignProp(carry, key, targetVal, origin);\n            }\n            return carry;\n        }, {});\n    }\n    // newObject has all properties that newComer hasn't\n    const props = Object.getOwnPropertyNames(newComer);\n    const symbols = Object.getOwnPropertySymbols(newComer);\n    const result = [...props, ...symbols].reduce((carry, key) => {\n        // re-define the origin and newComer as targetVal and newVal\n        let newVal = newComer[key];\n        const targetVal = isPlainObject(origin) ? origin[key] : undefined;\n        // When newVal is an object do the merge recursively\n        if (targetVal !== undefined && isPlainObject(newVal)) {\n            newVal = mergeRecursively(targetVal, newVal, compareFn);\n        }\n        const propToAssign = compareFn ? compareFn(targetVal, newVal, key) : newVal;\n        assignProp(carry, key, propToAssign, newComer);\n        return carry;\n    }, newObject);\n    return result;\n}\n/**\n * Merge anything recursively.\n * Objects get merged, special objects (classes etc.) are re-assigned \"as is\".\n * Basic types overwrite objects or other basic types.\n */\nexport function merge(object, ...otherObjects) {\n    return otherObjects.reduce((result, newComer) => {\n        return mergeRecursively(result, newComer);\n    }, object);\n}\nexport function mergeAndCompare(compareFn, object, ...otherObjects) {\n    return otherObjects.reduce((result, newComer) => {\n        return mergeRecursively(result, newComer, compareFn);\n    }, object);\n}\nexport function mergeAndConcat(object, ...otherObjects) {\n    return otherObjects.reduce((result, newComer) => {\n        return mergeRecursively(result, newComer, concatArrays);\n    }, object);\n}\n// import { Timestamp } from '../test/Timestamp'\n// type T1 = { date: Timestamp }\n// type T2 = [{ b: string[] }, { b: number[] }, { date: Timestamp }]\n// type TestT = Merge<T1, T2>\n// type A1 = { arr: string[] }\n// type A2 = { arr: number[] }\n// type A3 = { arr: boolean[] }\n// type TestA = Merge<A1, [A2, A3]>\n// interface I1 {\n//   date: Timestamp\n// }\n// interface I2 {\n//   date: Timestamp\n// }\n// const _a: I2 = { date: '' } as unknown as I2\n// type TestI = Merge<I1, [I2]>\n// // ReturnType<(typeof merge)<I1, I2>>\n// const a = merge(_a, [_a])\n// interface Arguments extends Record<string | number | symbol, unknown> {\n//     key: string;\n// }\n// const aa1: Arguments = { key: \"value1\" }\n// const aa2: Arguments = { key: \"value2\" }\n// const aa = merge(a1, a2);\n// interface Barguments {\n//   key: string\n// }\n// const ba1: Barguments = { key: 'value1' }\n// const ba2: Barguments = { key: 'value2' }\n// const ba = merge(ba1, ba2)\n// interface Carguments {\n//   key: string\n// }\n// const ca = merge<Carguments, Carguments[]>({ key: 'value1' }, { key: 'value2' })\n// type P = Pop<Carguments[]>\n","/**\n * Copyright (c) 2025 Microblink Ltd. All rights reserved.\n */\n\nimport {\n  BlinkIdSessionSettings,\n  CroppedImageSettings,\n  DocumentAnonymizationSettings,\n  DocumentFilter,\n  DocumentRules,\n  RecognitionModeFilter,\n  ScanningSettings,\n} from \"@microblink/blinkid-wasm\";\nimport { merge } from \"merge-anything\";\nimport { OverrideProperties } from \"type-fest\";\n\n/**\n * The partial scanning settings.\n */\nexport type PartialScanningSettings = Partial<\n  OverrideProperties<\n    ScanningSettings,\n    {\n      croppedImageSettings: Partial<CroppedImageSettings>;\n      recognitionModeFilter: Partial<RecognitionModeFilter>;\n      customDocumentRules: Partial<DocumentRules>[];\n    }\n  >\n>;\n\n/**\n * The partial BlinkID session settings.\n */\nexport type PartialBlinkIdSessionSettings = OverrideProperties<\n  Partial<BlinkIdSessionSettings>,\n  {\n    scanningSettings?: PartialScanningSettings;\n  }\n>;\n\n/**\n * Normalizes the document filter.\n *\n * @param filter - The document filter.\n * @returns The normalized document filter.\n */\nfunction normalizeDocumentFilter(\n  filter: DocumentFilter | undefined,\n): DocumentFilter {\n  return {\n    country: filter?.country ?? undefined,\n    region: filter?.region ?? undefined,\n    type: filter?.type ?? undefined,\n  };\n}\n\n/**\n * Normalizes the document rule.\n *\n * @param rule - The document rule.\n * @returns The normalized document rule.\n */\nexport const normalizeDocumentRule = (\n  rule: Partial<DocumentRules>,\n): DocumentRules => {\n  return {\n    documentFilter: normalizeDocumentFilter(rule.documentFilter),\n    fields: rule.fields ?? [],\n  };\n};\n\n/**\n * Normalizes the document anonymization settings.\n *\n * @param settings - The document anonymization settings.\n * @returns The normalized document anonymization settings.\n */\nexport const normalizeDocumentAnonymizationSettings = (\n  settings: DocumentAnonymizationSettings,\n): DocumentAnonymizationSettings => {\n  return {\n    documentFilter: normalizeDocumentFilter(settings.documentFilter),\n    fields: settings.fields || [],\n    documentNumberAnonymizationSettings:\n      settings.documentNumberAnonymizationSettings\n        ? {\n            prefixDigitsVisible:\n              settings.documentNumberAnonymizationSettings.prefixDigitsVisible,\n            suffixDigitsVisible:\n              settings.documentNumberAnonymizationSettings.suffixDigitsVisible,\n          }\n        : undefined,\n  };\n};\n\n/**\n * Creates merged BlinkId session settings from default settings and user options.\n *\n * @param options - User-provided session settings.\n * @param defaultSessionSettings - The base session settings to use. These\n * settings will be merged with the provided `options`, where `options` can\n * override specific values.\n *\n * @returns Complete merged settings.\n */\nexport function buildSessionSettings(\n  options: PartialBlinkIdSessionSettings = {},\n  defaultSessionSettings: BlinkIdSessionSettings,\n): BlinkIdSessionSettings {\n  // TODO: find a better way to handle this\n  // Remove keys with undefined values from options\n  if (options) {\n    options = Object.fromEntries(\n      Object.entries(options).filter(([_, value]) => value !== undefined),\n    );\n  }\n\n  const customDocumentRules: DocumentRules[] =\n    options?.scanningSettings?.customDocumentRules?.map(\n      normalizeDocumentRule,\n    ) ?? [];\n\n  const customDocumentAnonymizationSettings: DocumentAnonymizationSettings[] =\n    options?.scanningSettings?.customDocumentAnonymizationSettings?.map(\n      normalizeDocumentAnonymizationSettings,\n    ) ?? [];\n\n  const scanningSettings = {\n    ...options?.scanningSettings,\n    customDocumentRules,\n    customDocumentAnonymizationSettings,\n  };\n\n  const sessionSettings = merge(defaultSessionSettings, {\n    ...options,\n    scanningSettings,\n  });\n\n  return sessionSettings;\n}\n","/**\n * Copyright (c) 2025 Microblink Ltd. All rights reserved.\n */\n\nimport { expose, finalizer, proxy, ProxyMarked, transfer } from \"comlink\";\nimport { detectWasmFeatures, WasmVariant } from \"./wasm-feature-detect\";\n\nimport {\n  BlinkIdProcessResult,\n  BlinkIdScanningSession,\n  BlinkIdSessionSettings,\n  BlinkIdWasmModule,\n  EmscriptenModuleFactory,\n} from \"@microblink/blinkid-wasm\";\nimport { OverrideProperties } from \"type-fest\";\nimport { getCrossOriginWorkerURL } from \"./getCrossOriginWorkerURL\";\nimport { isIOS } from \"./isSafari\";\nimport { obtainNewServerPermission } from \"./licencing\";\nimport { mbToWasmPages } from \"./mbToWasmPages\";\n\nimport { downloadArrayBuffer, DownloadProgress } from \"./downloadArrayBuffer\";\nimport { buildResourcePath } from \"./buildResourcePath\";\nimport {\n  buildSessionSettings,\n  PartialBlinkIdSessionSettings,\n} from \"./buildSessionSettings\";\n// might be needed for types to work\n\nimport type {\n  BlinkIdScanningResult,\n  BlinkIdSessionError,\n  LicenseTokenState,\n} from \"@microblink/blinkid-wasm\";\n\n/**\n * This is a workaround for the fact that the types are not exported.\n */\n// eslint-disable-next-line @typescript-eslint/no-empty-interface\ninterface _BlinkIdScanningResult extends BlinkIdScanningResult {}\n\n/**\n * This is a workaround for the fact that the types are not exported.\n */\n// eslint-disable-next-line @typescript-eslint/no-empty-interface\ninterface _BlinkIdSessionError extends BlinkIdSessionError {}\n\n/**\n * The process result with buffer.\n */\nexport type ProcessResultWithBuffer = BlinkIdProcessResult & {\n  arrayBuffer: ArrayBuffer;\n};\n\n/**\n * The worker scanning session.\n */\nexport type WorkerScanningSession = OverrideProperties<\n  BlinkIdScanningSession,\n  {\n    process: (image: ImageData) => ProcessResultWithBuffer;\n  }\n> & {\n  /**\n   * Gets the settings.\n   *\n   * @returns The settings.\n   */\n  getSettings: () => BlinkIdSessionSettings;\n  /**\n   * Shows the demo overlay.\n   *\n   * @returns Whether the demo overlay is shown.\n   */\n  showDemoOverlay: () => boolean;\n  /**\n   * Shows the production overlay.\n   *\n   * @returns Whether the production overlay is shown.\n   */\n  showProductionOverlay: () => boolean;\n};\n\n/**\n * Initialization settings for the BlinkID worker.\n *\n * These settings control how the BlinkID worker is initialized and configured,\n * including resource locations, memory allocation, and build variants.\n */\nexport type BlinkIdWorkerInitSettings = {\n  /**\n   * The license key required to unlock and use the BlinkID SDK.\n   * This must be a valid license key obtained from Microblink.\n   */\n  licenseKey: string;\n\n  /**\n   * The URL of the Microblink proxy server. This proxy handles requests to Microblink's Baltazar and Ping servers.\n   *\n   * **Requirements:**\n   * - Must be a valid HTTPS URL\n   * - The proxy server must implement the expected Microblink API endpoints\n   * - This feature is only available if explicitly permitted by your license\n   *\n   * **Endpoints:**\n   * - Ping: `{proxyUrl}/ping`\n   * - Baltazar: `{proxyUrl}/api/v2/status/check`\n   *\n   * @example \"https://your-proxy.example.com\"\n   */\n  microblinkProxyUrl?: string;\n\n  /**\n   * The parent directory where the `/resources` directory is hosted.\n   * Defaults to `window.location.href`, at the root of the current page.\n   */\n  resourcesLocation?: string;\n\n  /**\n   * A unique identifier for the user/session.\n   * Used for analytics and tracking purposes.\n   */\n  userId: string;\n\n  /**\n   * The WebAssembly module variant to use.\n   * Different variants may offer different performance/size tradeoffs.\n   */\n  wasmVariant?: WasmVariant;\n\n  /**\n   * The initial memory allocation for the Wasm module, in megabytes.\n   * Larger values may improve performance but increase memory usage.\n   */\n  initialMemory?: number;\n\n  /**\n   * Whether to use the lightweight build of the SDK.\n   * Lightweight builds have reduced size but may have limited functionality.\n   */\n  useLightweightBuild: boolean;\n};\n\n/**\n * The load Wasm params.\n */\nexport type LoadWasmParams = {\n  resourceUrl: string;\n  variant?: WasmVariant;\n  useLightweightBuild: boolean;\n  initialMemory?: number;\n};\n\n/**\n * The progress status callback.\n */\nexport type ProgressStatusCallback = (progress: DownloadProgress) => void;\n\n/**\n * Sanitized proxy URLs for different Microblink services.\n */\ntype SanitizedProxyUrls = {\n  /**\n   * URL for ping service.\n   */\n  ping: string;\n  /**\n   * URL for Baltazar service.\n   */\n  baltazar: string;\n};\n\n/**\n * Error thrown when proxy URL validation fails\n */\nclass ProxyUrlValidationError extends Error {\n  constructor(\n    message: string,\n    public readonly url: string,\n  ) {\n    super(`Proxy URL validation failed for \"${url}\": ${message}`);\n    this.name = \"ProxyUrlValidationError\";\n  }\n}\n\n/**\n * The BlinkID worker.\n */\nclass BlinkIdWorker {\n  /**\n   * The Wasm module.\n   */\n  #wasmModule?: BlinkIdWasmModule;\n  /**\n   * The default session settings.\n   *\n   * Must be initialized when calling initBlinkId.\n   */\n  #defaultSessionSettings!: BlinkIdSessionSettings;\n  /**\n   * The progress status callback.\n   */\n  progressStatusCallback?: ProgressStatusCallback;\n  /**\n   * Whether the demo overlay is shown.\n   */\n  #showDemoOverlay = true;\n  /**\n   * Whether the production overlay is shown.\n   */\n  #showProductionOverlay = true;\n\n  /**\n   * Sanitized proxy URLs for Microblink services.\n   */\n  #proxyUrls?: SanitizedProxyUrls;\n\n  /**\n   * This method loads the Wasm module.\n   */\n  async #loadWasm({\n    resourceUrl,\n    variant,\n    useLightweightBuild,\n    initialMemory,\n  }: LoadWasmParams) {\n    if (this.#wasmModule) {\n      console.log(\"Wasm already loaded\");\n      return;\n    }\n\n    const wasmVariant = variant ?? (await detectWasmFeatures());\n\n    const featureVariant = useLightweightBuild ? \"lightweight\" : \"full\";\n\n    const MODULE_NAME = \"BlinkIdModule\";\n\n    const variantUrl = buildResourcePath(\n      resourceUrl,\n      featureVariant,\n      wasmVariant,\n    );\n\n    const workerUrl = buildResourcePath(variantUrl, `${MODULE_NAME}.js`);\n    const wasmUrl = buildResourcePath(variantUrl, `${MODULE_NAME}.wasm`);\n    const dataUrl = buildResourcePath(variantUrl, `${MODULE_NAME}.data`);\n\n    const crossOriginWorkerUrl = await getCrossOriginWorkerURL(workerUrl);\n\n    const imported = (await import(\n      /* @vite-ignore */ crossOriginWorkerUrl\n    )) as {\n      default: EmscriptenModuleFactory<BlinkIdWasmModule>;\n    };\n\n    const createModule = imported.default;\n\n    // use default memory settings if not provided\n    if (!initialMemory) {\n      // safari requires a larger initial memory allocation as it often block memory growth\n      initialMemory = isIOS() ? 700 : 200;\n    }\n\n    const wasmMemory = new WebAssembly.Memory({\n      initial: mbToWasmPages(initialMemory),\n      maximum: mbToWasmPages(2048),\n      shared: wasmVariant === \"advanced-threads\",\n    });\n\n    // Create progress trackers for each download\n    let wasmProgress: DownloadProgress | undefined;\n    let dataProgress: DownloadProgress | undefined;\n\n    let lastProgressUpdate = 0;\n    const progressUpdateInterval = 32; // 32ms interval ~ 30fps\n\n    // Update the overall combined progress based on both downloads\n    // Throttle to avoid updating too frequently\n    const throttledCombinedProgress = () => {\n      // Don't update progress if the callback is not set\n      if (!this.progressStatusCallback) {\n        return;\n      }\n\n      // wait until both have started so that we know the total length\n      if (!wasmProgress || !dataProgress) {\n        return;\n      }\n\n      const totalLoaded = wasmProgress.loaded + dataProgress.loaded;\n      const totalLength =\n        wasmProgress.contentLength + dataProgress.contentLength;\n      const combinedPercent = Math.min(\n        Math.round((totalLoaded / totalLength) * 100),\n        100,\n      );\n\n      const combinedProgress: DownloadProgress = {\n        loaded: totalLoaded,\n        contentLength: totalLength,\n        progress: combinedPercent,\n      };\n\n      // Check if enough time has elapsed since the last update\n      const currentTime = performance.now();\n      if (currentTime - lastProgressUpdate < progressUpdateInterval) {\n        return;\n      }\n\n      // Update the timestamp\n      lastProgressUpdate = currentTime;\n\n      this.progressStatusCallback(combinedProgress);\n    };\n\n    // Wrap each download's progress callback to update the combined progress.\n    const wasmProgressCallback = (progress: DownloadProgress) => {\n      wasmProgress = progress;\n      void throttledCombinedProgress();\n    };\n\n    const dataProgressCallback = (progress: DownloadProgress) => {\n      dataProgress = progress;\n      void throttledCombinedProgress();\n    };\n\n    // Replace simple fetch with progress tracking for both wasm and data downloads\n    const [preloadedWasm, preloadedData] = await Promise.all([\n      downloadArrayBuffer(wasmUrl, wasmProgressCallback),\n      downloadArrayBuffer(dataUrl, dataProgressCallback),\n    ]);\n\n    // Ensure final 100% progress update is sent\n    if (this.progressStatusCallback && wasmProgress && dataProgress) {\n      const totalLength =\n        wasmProgress.contentLength + dataProgress.contentLength;\n      this.progressStatusCallback({\n        loaded: totalLength,\n        contentLength: totalLength,\n        progress: 100,\n      });\n    }\n\n    /**\n     * https://emscripten.org/docs/api_reference/module.html#module-object\n     */\n    this.#wasmModule = await createModule({\n      locateFile: (path) => {\n        return `${variantUrl}/${wasmVariant}/${path}`;\n      },\n      // pthreads build breaks without this:\n      // \"Failed to execute 'createObjectURL' on 'URL': Overload resolution failed.\"\n      mainScriptUrlOrBlob: crossOriginWorkerUrl,\n      wasmBinary: preloadedWasm,\n      getPreloadedPackage() {\n        return preloadedData;\n      },\n      wasmMemory,\n      noExitRuntime: true,\n    });\n\n    if (!this.#wasmModule) {\n      throw new Error(\"Failed to load Wasm module\");\n    }\n  }\n\n  /**\n   * This method initializes everything.\n   */\n  async initBlinkId(\n    settings: BlinkIdWorkerInitSettings,\n    defaultSessionSettings: BlinkIdSessionSettings,\n    progressCallback?: ProgressStatusCallback,\n  ) {\n    const resourcesPath = new URL(\n      \"resources/\",\n      settings.resourcesLocation,\n    ).toString();\n\n    this.#defaultSessionSettings = defaultSessionSettings;\n    this.progressStatusCallback = progressCallback;\n\n    await this.#loadWasm({\n      resourceUrl: resourcesPath,\n      variant: settings.wasmVariant,\n      initialMemory: settings.initialMemory,\n      useLightweightBuild: settings.useLightweightBuild,\n    });\n\n    if (!this.#wasmModule) {\n      throw new Error(\"Wasm module not loaded\");\n    }\n\n    // Initialize with license key\n    const licenceUnlockResult = this.#wasmModule.initializeWithLicenseKey(\n      settings.licenseKey,\n      settings.userId,\n      false,\n    );\n\n    // Handle proxy URL configuration\n    if (settings.microblinkProxyUrl) {\n      this.#configureProxyUrls(\n        settings.microblinkProxyUrl,\n        licenceUnlockResult,\n      );\n    }\n\n    // Check if we need to obtain a server permission\n    if (licenceUnlockResult.unlockResult === \"requires-server-permission\") {\n      // Use proxy URL if configured, otherwise use default\n      const baltazarUrl = this.#proxyUrls?.baltazar;\n\n      const serverPermissionResponse =\n        baltazarUrl && licenceUnlockResult.allowBaltazarProxy\n          ? await obtainNewServerPermission(licenceUnlockResult, baltazarUrl)\n          : await obtainNewServerPermission(licenceUnlockResult);\n\n      const serverPermissionResult = this.#wasmModule.submitServerPermission(\n        JSON.stringify(serverPermissionResponse),\n      );\n\n      if (serverPermissionResult.error) {\n        throw new Error(\"Server unlock error: \" + serverPermissionResult.error);\n      }\n    }\n\n    this.#showDemoOverlay = licenceUnlockResult.showDemoOverlay;\n    this.#showProductionOverlay = licenceUnlockResult.showProductionOverlay;\n  }\n\n  /**\n   * This method creates a BlinkID scanning session.\n   *\n   * @param options - The options for the session.\n   * @returns The session.\n   */\n  createBlinkIdScanningSession(options?: PartialBlinkIdSessionSettings) {\n    if (!this.#wasmModule) {\n      throw new Error(\"Wasm module not loaded\");\n    }\n\n    const sessionSettings = buildSessionSettings(\n      options,\n      this.#defaultSessionSettings,\n    );\n\n    const session =\n      this.#wasmModule.createBlinkIdScanningSession(sessionSettings);\n\n    const proxySession = this.createProxySession(session, sessionSettings);\n    return proxySession;\n  }\n\n  /**\n   * This method creates a proxy session.\n   *\n   * @param session - The session.\n   * @param sessionSettings - The session settings.\n   * @returns The proxy session.\n   */\n  createProxySession(\n    session: BlinkIdScanningSession,\n    sessionSettings: BlinkIdSessionSettings,\n  ): WorkerScanningSession & ProxyMarked {\n    /**\n     * this is a custom session that will be proxied\n     * it handles the transfer of the image data buffer\n     */\n    const customSession: WorkerScanningSession = {\n      getResult: () => session.getResult(),\n      process: (image) => {\n        const processResult = session.process(image);\n\n        if (\"error\" in processResult) {\n          throw new Error(`Error processing frame: ${processResult.error}`);\n        }\n\n        const transferPackage: ProcessResultWithBuffer = transfer(\n          {\n            ...processResult,\n            arrayBuffer: image.data.buffer,\n          },\n          [image.data.buffer],\n        );\n\n        return transferPackage;\n      },\n      getSettings: () => sessionSettings,\n      reset: () => session.reset(),\n      delete: () => session.delete(),\n      deleteLater: () => session.deleteLater(),\n      isDeleted: () => session.isDeleted(),\n      isAliasOf: (other) => session.isAliasOf(other),\n      showDemoOverlay: () => this.#showDemoOverlay,\n      showProductionOverlay: () => this.#showProductionOverlay,\n    };\n\n    return proxy(customSession);\n  }\n\n  /**\n   * This method is called when the worker is terminated.\n   */\n  [finalizer]() {\n    // console.log(\"Comlink.finalizer called on proxyWorker\");\n    // Can't use this as the `proxyWorker` gets randomly GC'd, even if in use\n    // self.close();\n  }\n\n  /**\n   * Terminates the workers and the Wasm runtime.\n   */\n  terminate() {\n    self.close();\n  }\n\n  /**\n   * If the ping is enabled, this method will return 1.\n   *\n   * @returns 1 if the ping is enabled, 0 otherwise.\n   */\n  ping() {\n    return 1;\n  }\n\n  /**\n   * Configures proxy URLs based on the provided settings and license permissions.\n   */\n  #configureProxyUrls(\n    proxyUrl: string,\n    licenceUnlockResult: {\n      allowPingProxy: boolean;\n      allowBaltazarProxy: boolean;\n      hasPing: boolean;\n      unlockResult: LicenseTokenState;\n    },\n  ): void {\n    if (!proxyUrl) {\n      console.debug(\n        \"No proxy URL configured, using default Microblink servers\",\n      );\n      return;\n    }\n\n    // Validate license permissions\n    this.#validateProxyPermissions(licenceUnlockResult, proxyUrl);\n\n    // Validate and sanitize the proxy URL\n    try {\n      this.#proxyUrls = this.#sanitizeProxyUrls(proxyUrl);\n\n      if (licenceUnlockResult.allowPingProxy) {\n        // Configure the WASM module with the sanitized URLs\n        this.#wasmModule!.setPingProxyUrl(this.#proxyUrls.ping);\n      }\n\n      console.debug(\"Proxy URLs configured successfully:\", {\n        ping: this.#proxyUrls.ping,\n        baltazar: this.#proxyUrls.baltazar,\n      });\n    } catch (error) {\n      // Enhance error message with actionable advice\n      const enhancedError =\n        error instanceof ProxyUrlValidationError\n          ? new Error(\n              `${error.message}\\n\\nTroubleshooting:\\n- Ensure the URL is accessible\\n- Check HTTPS requirements\\n- Verify proxy server implementation`,\n            )\n          : error;\n\n      throw enhancedError;\n    }\n  }\n\n  /**\n   * Validates that the license allows proxy usage.\n   */\n  #validateProxyPermissions(\n    licenceUnlockResult: {\n      allowPingProxy: boolean;\n      allowBaltazarProxy: boolean;\n      hasPing: boolean;\n      unlockResult: LicenseTokenState;\n    },\n    proxyUrl: string,\n  ): void {\n    if (\n      !licenceUnlockResult.allowPingProxy &&\n      !licenceUnlockResult.allowBaltazarProxy\n    ) {\n      throw new Error(\n        `Proxy URL \"${proxyUrl}\" was provided, but your license does not permit proxy usage.\\n` +\n          `License permissions: pingProxy=${licenceUnlockResult.allowPingProxy}, ` +\n          `baltazarProxy=${licenceUnlockResult.allowBaltazarProxy}\\n` +\n          `Check your license.`,\n      );\n    } else if (\n      !licenceUnlockResult.hasPing &&\n      licenceUnlockResult.unlockResult !== \"requires-server-permission\"\n    ) {\n      throw new Error(\n        `Microblink proxy URL is set but cannot be used because ping and online license check are disabled in your license.\\n` +\n          `Check your license.`,\n      );\n    }\n  }\n\n  /**\n   * Validates and sanitizes proxy URLs for different Microblink services.\n   */\n  #sanitizeProxyUrls(baseUrl: string): SanitizedProxyUrls {\n    // Validate base URL format\n    let parsedUrl: URL;\n    try {\n      parsedUrl = new URL(baseUrl);\n    } catch (error) {\n      throw new ProxyUrlValidationError(\n        `Failed to create URL instance for provided Microblink proxy URL \"${baseUrl}\". Expected format: https://your-proxy.com or https://your-proxy.com/`,\n        baseUrl,\n      );\n    }\n\n    // Security validation: Ensure HTTPS in production\n    if (parsedUrl.protocol !== \"https:\") {\n      throw new ProxyUrlValidationError(\n        `Proxy URL validation failed for \"${baseUrl}\": HTTPS protocol must be used. Expected format: https://your-proxy.com or https://your-proxy.com/`,\n        baseUrl,\n      );\n    }\n\n    // Create sanitized URLs for each service\n    const baseUrlStr = parsedUrl.origin;\n\n    const baltazarUrl = this.#buildServiceUrl(\n      baseUrlStr,\n      \"/api/v2/status/check\",\n    );\n\n    return {\n      ping: baseUrlStr,\n      baltazar: baltazarUrl,\n    };\n  }\n\n  /**\n   * Builds a service URL by combining base URL with service path.\n   */\n  #buildServiceUrl(baseUrl: string, servicePath: string): string {\n    try {\n      const url = new URL(servicePath, baseUrl);\n      return url.toString();\n    } catch (error) {\n      throw new ProxyUrlValidationError(\n        `Failed to build service URL for path \"${servicePath}\"`,\n        baseUrl,\n      );\n    }\n  }\n}\n\n/**\n * The BlinkID worker.\n */\nconst blinkIdWorker = new BlinkIdWorker();\n\n/**\n * The BlinkID worker proxy.\n */\nexpose(blinkIdWorker);\n\n/**\n * The BlinkID worker proxy.\n */\nexport type BlinkIdWorkerProxy = Omit<BlinkIdWorker, typeof finalizer>;\n"],"names":["obj","returnValue","proxy","e","props","symbols"],"mappings":";;;;;;;;;;;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAKA,MAAM,cAAc,OAAO,eAAe;AAC1C,MAAM,iBAAiB,OAAO,kBAAkB;AAChD,MAAM,eAAe,OAAO,sBAAsB;AAClD,MAAM,YAAY,OAAO,mBAAmB;AAC5C,MAAM,cAAc,OAAO,gBAAgB;AAC3C,MAAM,WAAW,CAAC,QAAS,OAAO,QAAQ,YAAY,QAAQ,QAAS,OAAO,QAAQ;AAItF,MAAM,uBAAuB;AAAA,EACzB,WAAW,CAAC,QAAQ,SAAS,GAAG,KAAK,IAAI,WAAW;AAAA,EACpD,UAAU,KAAK;AACX,UAAM,EAAE,OAAO,MAAO,IAAG,IAAI,eAAgB;AAC7C,WAAO,KAAK,KAAK;AACjB,WAAO,CAAC,OAAO,CAAC,KAAK,CAAC;AAAA,EACzB;AAAA,EACD,YAAY,MAAM;AACd,SAAK,MAAO;AACZ,WAAO,KAAK,IAAI;AAAA,EACnB;AACL;AAIA,MAAM,uBAAuB;AAAA,EACzB,WAAW,CAAC,UAAU,SAAS,KAAK,KAAK,eAAe;AAAA,EACxD,UAAU,EAAE,SAAS;AACjB,QAAI;AACJ,QAAI,iBAAiB,OAAO;AACxB,mBAAa;AAAA,QACT,SAAS;AAAA,QACT,OAAO;AAAA,UACH,SAAS,MAAM;AAAA,UACf,MAAM,MAAM;AAAA,UACZ,OAAO,MAAM;AAAA,QAChB;AAAA,MACJ;AAAA,IACb,OACa;AACD,mBAAa,EAAE,SAAS,OAAO,MAAO;AAAA,IAClD;AACQ,WAAO,CAAC,YAAY,EAAE;AAAA,EACzB;AAAA,EACD,YAAY,YAAY;AACpB,QAAI,WAAW,SAAS;AACpB,YAAM,OAAO,OAAO,IAAI,MAAM,WAAW,MAAM,OAAO,GAAG,WAAW,KAAK;AAAA,IACrF;AACQ,UAAM,WAAW;AAAA,EACpB;AACL;AAIA,MAAM,mBAAmB,oBAAI,IAAI;AAAA,EAC7B,CAAC,SAAS,oBAAoB;AAAA,EAC9B,CAAC,SAAS,oBAAoB;AAClC,CAAC;AACD,SAAS,gBAAgB,gBAAgB,QAAQ;AAC7C,aAAW,iBAAiB,gBAAgB;AACxC,QAAI,WAAW,iBAAiB,kBAAkB,KAAK;AACnD,aAAO;AAAA,IACnB;AACQ,QAAI,yBAAyB,UAAU,cAAc,KAAK,MAAM,GAAG;AAC/D,aAAO;AAAA,IACnB;AAAA,EACA;AACI,SAAO;AACX;AACA,SAAS,OAAO,KAAK,KAAK,YAAY,iBAAiB,CAAC,GAAG,GAAG;AAC1D,KAAG,iBAAiB,WAAW,SAAS,SAAS,IAAI;AACjD,QAAI,CAAC,MAAM,CAAC,GAAG,MAAM;AACjB;AAAA,IACZ;AACQ,QAAI,CAAC,gBAAgB,gBAAgB,GAAG,MAAM,GAAG;AAC7C,cAAQ,KAAK,mBAAmB,GAAG,MAAM,qBAAqB;AAC9D;AAAA,IACZ;AACQ,UAAM,EAAE,IAAI,MAAM,KAAM,IAAG,OAAO,OAAO,EAAE,MAAM,CAAA,KAAM,GAAG,IAAI;AAC9D,UAAM,gBAAgB,GAAG,KAAK,gBAAgB,CAAE,GAAE,IAAI,aAAa;AACnE,QAAI;AACJ,QAAI;AACA,YAAM,SAAS,KAAK,MAAM,GAAG,EAAE,EAAE,OAAO,CAACA,MAAK,SAASA,KAAI,IAAI,GAAG,GAAG;AACrE,YAAM,WAAW,KAAK,OAAO,CAACA,MAAK,SAASA,KAAI,IAAI,GAAG,GAAG;AAC1D,cAAQ,MAAI;AAAA,QACR,KAAK;AACD;AACI,0BAAc;AAAA,UACtC;AACoB;AAAA,QACJ,KAAK;AACD;AACI,mBAAO,KAAK,MAAM,EAAE,EAAE,CAAC,CAAC,IAAI,cAAc,GAAG,KAAK,KAAK;AACvD,0BAAc;AAAA,UACtC;AACoB;AAAA,QACJ,KAAK;AACD;AACI,0BAAc,SAAS,MAAM,QAAQ,YAAY;AAAA,UACzE;AACoB;AAAA,QACJ,KAAK;AACD;AACI,kBAAM,QAAQ,IAAI,SAAS,GAAG,YAAY;AAC1C,0BAAc,MAAM,KAAK;AAAA,UACjD;AACoB;AAAA,QACJ,KAAK;AACD;AACI,kBAAM,EAAE,OAAO,MAAO,IAAG,IAAI,eAAgB;AAC7C,mBAAO,KAAK,KAAK;AACjB,0BAAc,SAAS,OAAO,CAAC,KAAK,CAAC;AAAA,UAC7D;AACoB;AAAA,QACJ,KAAK;AACD;AACI,0BAAc;AAAA,UACtC;AACoB;AAAA,QACJ;AACI;AAAA,MACpB;AAAA,IACA,SACe,OAAO;AACV,oBAAc,EAAE,OAAO,CAAC,WAAW,GAAG,EAAG;AAAA,IACrD;AACQ,YAAQ,QAAQ,WAAW,EACtB,MAAM,CAAC,UAAU;AAClB,aAAO,EAAE,OAAO,CAAC,WAAW,GAAG,EAAG;AAAA,IACrC,CAAA,EACI,KAAK,CAACC,iBAAgB;AACvB,YAAM,CAAC,WAAW,aAAa,IAAI,YAAYA,YAAW;AAC1D,SAAG,YAAY,OAAO,OAAO,OAAO,OAAO,CAAE,GAAE,SAAS,GAAG,EAAE,GAAI,CAAA,GAAG,aAAa;AACjF,UAAI,SAAS,WAAqC;AAE9C,WAAG,oBAAoB,WAAW,QAAQ;AAC1C,sBAAc,EAAE;AAChB,YAAI,aAAa,OAAO,OAAO,IAAI,SAAS,MAAM,YAAY;AAC1D,cAAI,SAAS,EAAG;AAAA,QACpC;AAAA,MACA;AAAA,IACS,CAAA,EACI,MAAM,CAAC,UAAU;AAElB,YAAM,CAAC,WAAW,aAAa,IAAI,YAAY;AAAA,QAC3C,OAAO,IAAI,UAAU,6BAA6B;AAAA,QAClD,CAAC,WAAW,GAAG;AAAA,MAC/B,CAAa;AACD,SAAG,YAAY,OAAO,OAAO,OAAO,OAAO,CAAE,GAAE,SAAS,GAAG,EAAE,GAAI,CAAA,GAAG,aAAa;AAAA,IAC7F,CAAS;AAAA,EACT,CAAK;AACD,MAAI,GAAG,OAAO;AACV,OAAG,MAAO;AAAA,EAClB;AACA;AACA,SAAS,cAAc,UAAU;AAC7B,SAAO,SAAS,YAAY,SAAS;AACzC;AACA,SAAS,cAAc,UAAU;AAC7B,MAAI,cAAc,QAAQ;AACtB,aAAS,MAAO;AACxB;AACA,SAAS,KAAK,IAAI,QAAQ;AACtB,QAAM,mBAAmB,oBAAI,IAAK;AAClC,KAAG,iBAAiB,WAAW,SAAS,cAAc,IAAI;AACtD,UAAM,EAAE,KAAI,IAAK;AACjB,QAAI,CAAC,QAAQ,CAAC,KAAK,IAAI;AACnB;AAAA,IACZ;AACQ,UAAM,WAAW,iBAAiB,IAAI,KAAK,EAAE;AAC7C,QAAI,CAAC,UAAU;AACX;AAAA,IACZ;AACQ,QAAI;AACA,eAAS,IAAI;AAAA,IACzB,UACgB;AACJ,uBAAiB,OAAO,KAAK,EAAE;AAAA,IAC3C;AAAA,EACA,CAAK;AACD,SAAO,YAAY,IAAI,kBAAkB,CAAA,GAAI,MAAM;AACvD;AACA,SAAS,qBAAqB,YAAY;AACtC,MAAI,YAAY;AACZ,UAAM,IAAI,MAAM,4CAA4C;AAAA,EACpE;AACA;AACA,SAAS,gBAAgB,IAAI;AACzB,SAAO,uBAAuB,IAAI,oBAAI,OAAO;AAAA,IACzC,MAAM;AAAA,EACd,CAAK,EAAE,KAAK,MAAM;AACV,kBAAc,EAAE;AAAA,EACxB,CAAK;AACL;AACA,MAAM,eAAe,oBAAI,QAAS;AAClC,MAAM,kBAAkB,0BAA0B,cAC9C,IAAI,qBAAqB,CAAC,OAAO;AAC7B,QAAM,YAAY,aAAa,IAAI,EAAE,KAAK,KAAK;AAC/C,eAAa,IAAI,IAAI,QAAQ;AAC7B,MAAI,aAAa,GAAG;AAChB,oBAAgB,EAAE;AAAA,EAC9B;AACA,CAAK;AACL,SAAS,cAAcC,QAAO,IAAI;AAC9B,QAAM,YAAY,aAAa,IAAI,EAAE,KAAK,KAAK;AAC/C,eAAa,IAAI,IAAI,QAAQ;AAC7B,MAAI,iBAAiB;AACjB,oBAAgB,SAASA,QAAO,IAAIA,MAAK;AAAA,EACjD;AACA;AACA,SAAS,gBAAgBA,QAAO;AAC5B,MAAI,iBAAiB;AACjB,oBAAgB,WAAWA,MAAK;AAAA,EACxC;AACA;AACA,SAAS,YAAY,IAAI,kBAAkB,OAAO,CAAA,GAAI,SAAS,WAAY;GAAK;AAC5E,MAAI,kBAAkB;AACtB,QAAMA,SAAQ,IAAI,MAAM,QAAQ;AAAA,IAC5B,IAAI,SAAS,MAAM;AACf,2BAAqB,eAAe;AACpC,UAAI,SAAS,cAAc;AACvB,eAAO,MAAM;AACT,0BAAgBA,MAAK;AACrB,0BAAgB,EAAE;AAClB,2BAAiB,MAAO;AACxB,4BAAkB;AAAA,QACrB;AAAA,MACjB;AACY,UAAI,SAAS,QAAQ;AACjB,YAAI,KAAK,WAAW,GAAG;AACnB,iBAAO,EAAE,MAAM,MAAMA,OAAO;AAAA,QAChD;AACgB,cAAM,IAAI,uBAAuB,IAAI,kBAAkB;AAAA,UACnD,MAAM;AAAA,UACN,MAAM,KAAK,IAAI,CAAC,MAAM,EAAE,UAAU;AAAA,QACtD,CAAiB,EAAE,KAAK,aAAa;AACrB,eAAO,EAAE,KAAK,KAAK,CAAC;AAAA,MACpC;AACY,aAAO,YAAY,IAAI,kBAAkB,CAAC,GAAG,MAAM,IAAI,CAAC;AAAA,IAC3D;AAAA,IACD,IAAI,SAAS,MAAM,UAAU;AACzB,2BAAqB,eAAe;AAGpC,YAAM,CAAC,OAAO,aAAa,IAAI,YAAY,QAAQ;AACnD,aAAO,uBAAuB,IAAI,kBAAkB;AAAA,QAChD,MAAM;AAAA,QACN,MAAM,CAAC,GAAG,MAAM,IAAI,EAAE,IAAI,CAAC,MAAM,EAAE,UAAU;AAAA,QAC7C;AAAA,MAChB,GAAe,aAAa,EAAE,KAAK,aAAa;AAAA,IACvC;AAAA,IACD,MAAM,SAAS,UAAU,iBAAiB;AACtC,2BAAqB,eAAe;AACpC,YAAM,OAAO,KAAK,KAAK,SAAS,CAAC;AACjC,UAAI,SAAS,gBAAgB;AACzB,eAAO,uBAAuB,IAAI,kBAAkB;AAAA,UAChD,MAAM;AAAA,QAC1B,CAAiB,EAAE,KAAK,aAAa;AAAA,MACrC;AAEY,UAAI,SAAS,QAAQ;AACjB,eAAO,YAAY,IAAI,kBAAkB,KAAK,MAAM,GAAG,EAAE,CAAC;AAAA,MAC1E;AACY,YAAM,CAAC,cAAc,aAAa,IAAI,iBAAiB,eAAe;AACtE,aAAO,uBAAuB,IAAI,kBAAkB;AAAA,QAChD,MAAM;AAAA,QACN,MAAM,KAAK,IAAI,CAAC,MAAM,EAAE,UAAU;AAAA,QAClC;AAAA,MAChB,GAAe,aAAa,EAAE,KAAK,aAAa;AAAA,IACvC;AAAA,IACD,UAAU,SAAS,iBAAiB;AAChC,2BAAqB,eAAe;AACpC,YAAM,CAAC,cAAc,aAAa,IAAI,iBAAiB,eAAe;AACtE,aAAO,uBAAuB,IAAI,kBAAkB;AAAA,QAChD,MAAM;AAAA,QACN,MAAM,KAAK,IAAI,CAAC,MAAM,EAAE,UAAU;AAAA,QAClC;AAAA,MAChB,GAAe,aAAa,EAAE,KAAK,aAAa;AAAA,IACvC;AAAA,EACT,CAAK;AACD,gBAAcA,QAAO,EAAE;AACvB,SAAOA;AACX;AACA,SAAS,OAAO,KAAK;AACjB,SAAO,MAAM,UAAU,OAAO,MAAM,CAAA,GAAI,GAAG;AAC/C;AACA,SAAS,iBAAiB,cAAc;AACpC,QAAM,YAAY,aAAa,IAAI,WAAW;AAC9C,SAAO,CAAC,UAAU,IAAI,CAAC,MAAM,EAAE,CAAC,CAAC,GAAG,OAAO,UAAU,IAAI,CAAC,MAAM,EAAE,CAAC,CAAC,CAAC,CAAC;AAC1E;AACA,MAAM,gBAAgB,oBAAI,QAAS;AACnC,SAAS,SAAS,KAAK,WAAW;AAC9B,gBAAc,IAAI,KAAK,SAAS;AAChC,SAAO;AACX;AACA,SAAS,MAAM,KAAK;AAChB,SAAO,OAAO,OAAO,KAAK,EAAE,CAAC,WAAW,GAAG,MAAM;AACrD;AAQA,SAAS,YAAY,OAAO;AACxB,aAAW,CAAC,MAAM,OAAO,KAAK,kBAAkB;AAC5C,QAAI,QAAQ,UAAU,KAAK,GAAG;AAC1B,YAAM,CAAC,iBAAiB,aAAa,IAAI,QAAQ,UAAU,KAAK;AAChE,aAAO;AAAA,QACH;AAAA,UACI,MAAM;AAAA,UACN;AAAA,UACA,OAAO;AAAA,QACV;AAAA,QACD;AAAA,MACH;AAAA,IACb;AAAA,EACA;AACI,SAAO;AAAA,IACH;AAAA,MACI,MAAM;AAAA,MACN;AAAA,IACH;AAAA,IACD,cAAc,IAAI,KAAK,KAAK,CAAE;AAAA,EACjC;AACL;AACA,SAAS,cAAc,OAAO;AAC1B,UAAQ,MAAM,MAAI;AAAA,IACd,KAAK;AACD,aAAO,iBAAiB,IAAI,MAAM,IAAI,EAAE,YAAY,MAAM,KAAK;AAAA,IACnE,KAAK;AACD,aAAO,MAAM;AAAA,EACzB;AACA;AACA,SAAS,uBAAuB,IAAI,kBAAkB,KAAK,WAAW;AAClE,SAAO,IAAI,QAAQ,CAAC,YAAY;AAC5B,UAAM,KAAK,aAAc;AACzB,qBAAiB,IAAI,IAAI,OAAO;AAChC,QAAI,GAAG,OAAO;AACV,SAAG,MAAO;AAAA,IACtB;AACQ,OAAG,YAAY,OAAO,OAAO,EAAE,MAAM,GAAG,GAAG,SAAS;AAAA,EAC5D,CAAK;AACL;AACA,SAAS,eAAe;AACpB,SAAO,IAAI,MAAM,CAAC,EACb,KAAK,CAAC,EACN,IAAI,MAAM,KAAK,MAAM,KAAK,WAAW,OAAO,gBAAgB,EAAE,SAAS,EAAE,CAAC,EAC1E,KAAK,GAAG;AACjB;AClWY,MAA0O,aAAW,YAAS,YAAY,SAAS,IAAI,WAAW,CAAC,GAAE,IAAG,KAAI,KAAI,GAAE,GAAE,GAAE,GAAE,GAAE,GAAE,GAAE,IAAG,GAAE,GAAE,GAAE,GAAE,GAAE,GAAE,GAAE,GAAE,GAAE,GAAE,GAAE,IAAG,IAAG,GAAE,IAAG,GAAE,IAAG,GAAE,IAAG,GAAE,IAAG,GAAE,KAAI,IAAG,GAAE,GAAE,EAAE,CAAC,CAAC,GAA8pC,iBAAe,YAAS,YAAY,SAAS,IAAI,WAAW,CAAC,GAAE,IAAG,KAAI,KAAI,GAAE,GAAE,GAAE,GAAE,GAAE,GAAE,GAAE,GAAE,IAAG,GAAE,IAAG,GAAE,KAAI,GAAE,GAAE,GAAE,GAAE,KAAI,GAAE,IAAG,GAAE,IAAG,GAAE,GAAE,GAAE,GAAE,IAAG,GAAE,CAAC,CAAC,CAAC,GAAE,iBAAe,YAAS,YAAY,SAAS,IAAI,WAAW,CAAC,GAAE,IAAG,KAAI,KAAI,GAAE,GAAE,GAAE,GAAE,GAAE,GAAE,GAAE,IAAG,GAAE,GAAE,GAAE,GAAE,GAAE,GAAE,IAAG,GAAE,GAAE,GAAE,GAAE,KAAI,KAAI,IAAG,EAAE,CAAC,CAAC,GAA+J,sBAAoB,YAAS,YAAY,SAAS,IAAI,WAAW,CAAC,GAAE,IAAG,KAAI,KAAI,GAAE,GAAE,GAAE,GAAE,GAAE,GAAE,GAAE,IAAG,GAAE,GAAE,GAAE,GAAE,GAAE,GAAE,IAAG,IAAG,GAAE,IAAG,GAAE,IAAG,GAAE,GAAE,GAAE,GAAE,KAAI,GAAE,IAAG,EAAE,CAAC,CAAC,GAAE,iBAAe,YAAS,YAAY,SAAS,IAAI,WAAW,CAAC,GAAE,IAAG,KAAI,KAAI,GAAE,GAAE,GAAE,GAAE,GAAE,GAAE,GAAE,IAAG,GAAE,GAAE,GAAE,GAAE,GAAE,GAAE,IAAG,GAAE,GAAE,GAAE,GAAE,IAAG,GAAE,KAAI,IAAG,EAAE,CAAC,CAAC,GAAE,OAAK,YAAS,YAAY,SAAS,IAAI,WAAW,CAAC,GAAE,IAAG,KAAI,KAAI,GAAE,GAAE,GAAE,GAAE,GAAE,GAAE,GAAE,IAAG,GAAE,GAAE,KAAI,GAAE,GAAE,GAAE,GAAE,IAAG,IAAG,GAAE,GAAE,GAAE,IAAG,GAAE,KAAI,IAAG,KAAI,IAAG,EAAE,CAAC,CAAC,GAAgM,UAAQ,OAAK,OAAM,MAAG;AAAC,MAAG;AAAC,WAAM,eAAa,OAAO,kBAAiB,IAAI,iBAAgB,MAAM,YAAY,IAAI,kBAAkB,CAAC,CAAC,GAAE,YAAY,SAAS,CAAC;AAAA,EAAC,SAAOC,IAAE;AAAC,WAAQ;AAAA,EAAA;AAAC,GAAG,IAAI,WAAW,CAAC,GAAE,IAAG,KAAI,KAAI,GAAE,GAAE,GAAE,GAAE,GAAE,GAAE,GAAE,IAAG,GAAE,GAAE,GAAE,GAAE,GAAE,GAAE,GAAE,GAAE,GAAE,GAAE,GAAE,GAAE,IAAG,IAAG,GAAE,GAAE,GAAE,IAAG,GAAE,KAAI,IAAG,GAAE,GAAE,IAAG,EAAE,CAAC,CAAC;ACmB50F,SAAS,WAAW;AACnB,QAAA,YAAY,UAAU,UAAU,YAAY;AAClD,SAAO,UAAU,SAAS,QAAQ,KAAK,CAAC,UAAU,SAAS,QAAQ;AACrE;AAYA,eAA8B,sBAAwC;AAC9D,QAAA,sBAAsB,MAAM,QAAQ;AACtC,MAAA,CAAC,oBAA4B,QAAA;AAE7B,MAAA,EAAE,mBAAmB,OAAO;AAC9B,UAAM,MAAM,iBAAiB;AAAA,EAAA;AAK/B,MAAI,YAAY;AACP,WAAA;AAAA,EAAA;AAGT,SAAO,YAAY;AACrB;AAYA,eAAsB,qBAA2C;AAC/D,QAAM,WAAW;AAAA,IACf,eAAe;AAAA,IACf,eAAe;AAAA,IACf,WAAW;AAAA,IACX,oBAAoB;AAAA,IACpB,eAAe;AAAA,EACjB;AAEA,QAAM,iBAAiB,MAAM,QAAQ,IAAI,QAAQ,GAAG,MAAM,OAAO;AAEjE,MAAI,CAAC,eAAe;AACZ,UAAA,IAAI,MAAM,4CAA4C;AAAA,EAAA;AAGxD,QAAA,mBAAmB,MAAM,KAAK;AAEpC,MAAI,CAAC,kBAAkB;AACd,WAAA;AAAA,EAAA;AAGH,QAAA,0BAA0B,MAAM,oBAAoB;AAE1D,MAAI,CAAC,yBAAyB;AACrB,WAAA;AAAA,EAAA;AAGF,SAAA;AACT;AC9EA,MAAM,aAAa;AAyBZ,MAAM,0BAA0B,CACrC,mBACA,WAAoB,OACjB;AACH,QAAM,UAAU;AAAA,IACd,gBAAgB;AAAA,IAChB,SAAS;AAAA,IAET,GAAG;AAAA,EACL;AAGE,MAAA,QAAQ,kBACR,IAAI,IAAI,iBAAiB,EAAE,WAAW,KAAK,SAAS,QACpD;AAEO,WAAA,QAAQ,QAAQ,iBAAiB;AAAA,EAAA;AAG1C,SAAO,IAAI;AAAA,IACT,CAAC,SAAS,WACR,KAAK,MAAM,iBAAiB,EACzB,KAAK,CAAC,QAAQ,IAAI,KAAK,CAAC,EACxB,KAAK,CAAC,eAAe;AACpB,YAAM,aAAa,IAAI,IAAI,iBAAiB,EAAE,KAAK,MAAM,GAAG;AAC5D,iBAAW,IAAI;AAEf,UAAI,WAAW;AAEf,UAAI,QAAQ,SAAS;AACb,cAAA,OAAO,IAAI,KAAK,CAAC,UAAU,GAAG,EAAE,MAAM,YAAY;AAC7C,mBAAA,IAAI,gBAAgB,IAAI;AAAA,MAAA,OAC9B;AACL,mBAAW,QAAQ,UAAU,MAAM,mBAAmB,UAAU;AAAA,MAAA;AAGlE,cAAQ,QAAQ;AAAA,IAAA,CACjB,EACA,MAAM,MAAM;AAAA,EACnB;AACF;ACnEO,SAAS,QAAiB;AAC/B,QAAM,YAAY,KAAK,UAAU,UAAU,YAAY;AAChD,SAAA,mBAAmB,KAAK,SAAS;AAC1C;ACIA,SAAS,wBACP,cACgB;AACT,SAAA;AAAA,IACL,WAAW,aAAa;AAAA,IACxB,UAAU,aAAa;AAAA,IACvB,gBAAgB,aAAa;AAAA,IAC7B,aAAa,aAAa;AAAA,IAC1B,UAAU;AAAA,IACV,SAAS,aAAa;AAAA,IACtB,YAAY,aAAa;AAAA,EAC3B;AACF;AAsBsB,eAAA,0BACpB,cACA,cAAc,uDACd;AAEA,MAAI,CAAC,eAAe,OAAO,gBAAgB,UAAU;AAC7C,UAAA,IAAI,MAAM,iDAAiD;AAAA,EAAA;AAI/D,MAAA;AACF,QAAI,IAAI,WAAW;AAAA,WACZ,OAAO;AACd,UAAM,IAAI,MAAM,+BAA+B,WAAW,EAAE;AAAA,EAAA;AAG1D,MAAA;AACI,UAAA,WAAW,MAAM,MAAM,aAAa;AAAA,MACxC,QAAQ;AAAA,MACR,SAAS;AAAA,QACP,gBAAgB;AAAA,MAClB;AAAA,MACA,OAAO;AAAA,MACP,MAAM,KAAK,UAAU,wBAAwB,YAAY,CAAC;AAAA,IAAA,CAC3D;AAEG,QAAA,CAAC,SAAS,IAAI;AAChB,YAAM,IAAI;AAAA,QACR,0BAA0B,SAAS,MAAM,IAAI,SAAS,UAAU;AAAA,MAClE;AAAA,IAAA;AAGI,UAAA,mBAAoB,MAAM,SAAS,KAAK;AACvC,WAAA;AAAA,WACA,OAAO;AACN,YAAA,MAAM,qCAAqC,KAAK;AAClD,UAAA;AAAA,EAAA;AAEV;AC9EO,SAAS,cAAc,IAAY;AACxC,SAAO,KAAK,KAAM,KAAK,OAAO,OAAQ,KAAK,IAAI;AACjD;ACFsB,eAAA,oBACpB,KACA,kBACsB;AAChB,QAAA,WAAW,MAAM,MAAM,GAAG;AAG5B,MAAA,CAAC,SAAS,QAAQ,CAAC,SAAS,QAAQ,IAAI,gBAAgB,GAAG;AAC7D,WAAO,SAAS,YAAY;AAAA,EAAA;AAG9B,QAAM,gBAAgB,SAAS,SAAS,QAAQ,IAAI,gBAAgB,GAAI,EAAE;AAC1E,MAAI,SAAS;AACP,QAAA,SAAS,SAAS,KAAK,UAAU;AACvC,QAAM,SAAuB,CAAC;AAE1B,MAAA,SAAS,MAAM,OAAO,KAAK;AACxB,SAAA,CAAC,OAAO,MAAM;AACnB,UAAM,QAAQ,OAAO;AACrB,QAAI,OAAO;AACT,aAAO,KAAK,KAAK;AACjB,gBAAU,MAAM;AAChB,UAAI,kBAAkB;AACpB,cAAM,WAAW,KAAK;AAAA,UACpB,KAAK,MAAO,SAAS,gBAAiB,GAAG;AAAA,UACzC;AAAA,QACF;AACiB,yBAAA;AAAA,UACf;AAAA,UACA;AAAA,UACA;AAAA,QAAA,CACD;AAAA,MAAA;AAAA,IACH;AAEO,aAAA,MAAM,OAAO,KAAK;AAAA,EAAA;AAGvB,QAAA,YAAY,IAAI,WAAW,MAAM;AACvC,MAAI,WAAW;AACf,aAAW,SAAS,QAAQ;AAChB,cAAA,IAAI,OAAO,QAAQ;AAC7B,gBAAY,MAAM;AAAA,EAAA;AAGpB,SAAO,UAAU;AACnB;AC5CO,SAAS,qBAAqB,UAA4B;AAE/D,QAAM,OAAO,SACV,OAAO,CAAC,YAAY,OAAO,EAC3B,KAAK,GAAG,EACR,QAAQ,gBAAgB,IAAI;AAG3B,MAAA;AACE,QAAA,IAAI,MAAM,oBAAoB;AAAA,EAAA,QAC5B;AACN,UAAM,IAAI,MAAM,gBAAgB,IAAI,EAAE;AAAA,EAAA;AAGjC,SAAA;AACT;ACzBO,SAAS,QAAQ,SAAS;AAC7B,SAAO,OAAO,UAAU,SAAS,KAAK,OAAO,EAAE,MAAM,GAAG,EAAE;AAC9D;ACEO,SAAS,cAAc,SAAS;AACnC,MAAI,QAAQ,OAAO,MAAM;AACrB,WAAO;AACX,QAAM,YAAY,OAAO,eAAe,OAAO;AAC/C,SAAO,CAAC,CAAC,aAAa,UAAU,gBAAgB,UAAU,cAAc,OAAO;AACnF;ACRO,SAAS,SAAS,SAAS;AAC9B,SAAO,QAAQ,OAAO,MAAM;AAChC;ACFA,SAAS,WAAW,OAAO,KAAK,QAAQ,gBAAgB;AACpD,QAAM,WAAW,CAAE,EAAC,qBAAqB,KAAK,gBAAgB,GAAG,IAC3D,eACA;AACN,MAAI,aAAa;AACb,UAAM,GAAG,IAAI;AACjB,MAAI,aAAa,iBAAiB;AAC9B,WAAO,eAAe,OAAO,KAAK;AAAA,MAC9B,OAAO;AAAA,MACP,YAAY;AAAA,MACZ,UAAU;AAAA,MACV,cAAc;AAAA,IAC1B,CAAS;AAAA,EACT;AACA;AACA,SAAS,iBAAiB,QAAQ,UAAU,WAAW;AAEnD,MAAI,CAAC,cAAc,QAAQ;AACvB,WAAO;AAEX,MAAI,YAAY,CAAE;AAClB,MAAI,cAAc,MAAM,GAAG;AACvB,UAAMC,SAAQ,OAAO,oBAAoB,MAAM;AAC/C,UAAMC,WAAU,OAAO,sBAAsB,MAAM;AACnD,gBAAY,CAAC,GAAGD,QAAO,GAAGC,QAAO,EAAE,OAAO,CAAC,OAAO,QAAQ;AACtD,YAAM,YAAY,OAAO,GAAG;AAC5B,UAAK,CAAC,SAAS,GAAG,KAAK,CAAC,OAAO,oBAAoB,QAAQ,EAAE,SAAS,GAAG,KACpE,SAAS,GAAG,KAAK,CAAC,OAAO,sBAAsB,QAAQ,EAAE,SAAS,GAAG,GAAI;AAC1E,mBAAW,OAAO,KAAK,WAAW,MAAM;AAAA,MACxD;AACY,aAAO;AAAA,IACV,GAAE,EAAE;AAAA,EACb;AAEI,QAAM,QAAQ,OAAO,oBAAoB,QAAQ;AACjD,QAAM,UAAU,OAAO,sBAAsB,QAAQ;AACrD,QAAM,SAAS,CAAC,GAAG,OAAO,GAAG,OAAO,EAAE,OAAO,CAAC,OAAO,QAAQ;AAEzD,QAAI,SAAS,SAAS,GAAG;AACzB,UAAM,YAAY,cAAc,MAAM,IAAI,OAAO,GAAG,IAAI;AAExD,QAAI,cAAc,UAAa,cAAc,MAAM,GAAG;AAClD,eAAS,iBAAiB,WAAW,MAAiB;AAAA,IAClE;AACQ,UAAM,eAA+D;AACrE,eAAW,OAAO,KAAK,cAAc,QAAQ;AAC7C,WAAO;AAAA,EACV,GAAE,SAAS;AACZ,SAAO;AACX;AAMO,SAAS,MAAM,WAAW,cAAc;AAC3C,SAAO,aAAa,OAAO,CAAC,QAAQ,aAAa;AAC7C,WAAO,iBAAiB,QAAQ,QAAQ;AAAA,EAC3C,GAAE,MAAM;AACb;ACfA,SAAS,wBACP,QACgB;AACT,SAAA;AAAA,IACL,UAAS,iCAAQ,YAAW;AAAA,IAC5B,SAAQ,iCAAQ,WAAU;AAAA,IAC1B,OAAM,iCAAQ,SAAQ;AAAA,EACxB;AACF;AAQa,MAAA,wBAAwB,CACnC,SACkB;AACX,SAAA;AAAA,IACL,gBAAgB,wBAAwB,KAAK,cAAc;AAAA,IAC3D,QAAQ,KAAK,UAAU,CAAA;AAAA,EACzB;AACF;AAQa,MAAA,yCAAyC,CACpD,aACkC;AAC3B,SAAA;AAAA,IACL,gBAAgB,wBAAwB,SAAS,cAAc;AAAA,IAC/D,QAAQ,SAAS,UAAU,CAAC;AAAA,IAC5B,qCACE,SAAS,sCACL;AAAA,MACE,qBACE,SAAS,oCAAoC;AAAA,MAC/C,qBACE,SAAS,oCAAoC;AAAA,IAAA,IAEjD;AAAA,EACR;AACF;AAYO,SAAS,qBACd,UAAyC,CAAC,GAC1C,wBACwB;Ab5G1B;Aa+GE,MAAI,SAAS;AACX,cAAU,OAAO;AAAA,MACf,OAAO,QAAQ,OAAO,EAAE,OAAO,CAAC,CAAC,GAAG,KAAK,MAAM,UAAU,MAAS;AAAA,IACpE;AAAA,EAAA;AAGI,QAAA,wBACJ,8CAAS,qBAAT,mBAA2B,wBAA3B,mBAAgD;AAAA,IAC9C;AAAA,QACG,CAAC;AAEF,QAAA,wCACJ,8CAAS,qBAAT,mBAA2B,wCAA3B,mBAAgE;AAAA,IAC9D;AAAA,QACG,CAAC;AAER,QAAM,mBAAmB;AAAA,IACvB,GAAG,mCAAS;AAAA,IACZ;AAAA,IACA;AAAA,EACF;AAEM,QAAA,kBAAkB,MAAM,wBAAwB;AAAA,IACpD,GAAG;AAAA,IACH;AAAA,EAAA,CACD;AAEM,SAAA;AACT;ACmCA,MAAM,gCAAgC,MAAM;AAAA,EAC1C,YACE,SACgB,KAChB;AACA,UAAM,oCAAoC,GAAG,MAAM,OAAO,EAAE;AAF5C,SAAA,MAAA;AAGhB,SAAK,OAAO;AAAA,EAAA;AAEhB;AAKA,MAAM,cAAc;AAAA,EAApB;AAAA;AAIE;AAAA;AAAA;AAAA;AAMA;AAAA;AAAA;AAAA;AAAA;AAAA;AAIA;AAAA;AAAA;AAAA;AAIA;AAAA;AAAA;AAAA,yCAAmB;AAInB;AAAA;AAAA;AAAA,+CAAyB;AAKzB;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,EA0JA,MAAM,YACJ,UACA,wBACA,kBACA;AdpXJ;AcqXI,UAAM,gBAAgB,IAAI;AAAA,MACxB;AAAA,MACA,SAAS;AAAA,MACT,SAAS;AAEX,uBAAK,yBAA0B;AAC/B,SAAK,yBAAyB;AAE9B,UAAM,sBAAK,uCAAL,WAAe;AAAA,MACnB,aAAa;AAAA,MACb,SAAS,SAAS;AAAA,MAClB,eAAe,SAAS;AAAA,MACxB,qBAAqB,SAAS;AAAA,IAAA;AAG5B,QAAA,CAAC,mBAAK,cAAa;AACf,YAAA,IAAI,MAAM,wBAAwB;AAAA,IAAA;AAIpC,UAAA,sBAAsB,mBAAK,aAAY;AAAA,MAC3C,SAAS;AAAA,MACT,SAAS;AAAA,MACT;AAAA,IACF;AAGA,QAAI,SAAS,oBAAoB;AAC1B,4BAAA,iDAAA,WACH,SAAS,oBACT;AAAA,IACF;AAIE,QAAA,oBAAoB,iBAAiB,8BAA8B;AAE/D,YAAA,eAAc,wBAAK,gBAAL,mBAAiB;AAE/B,YAAA,2BACJ,eAAe,oBAAoB,qBAC/B,MAAM,0BAA0B,qBAAqB,WAAW,IAChE,MAAM,0BAA0B,mBAAmB;AAEnD,YAAA,yBAAyB,mBAAK,aAAY;AAAA,QAC9C,KAAK,UAAU,wBAAwB;AAAA,MACzC;AAEA,UAAI,uBAAuB,OAAO;AAChC,cAAM,IAAI,MAAM,0BAA0B,uBAAuB,KAAK;AAAA,MAAA;AAAA,IACxE;AAGF,uBAAK,kBAAmB,oBAAoB;AAC5C,uBAAK,wBAAyB,oBAAoB;AAAA,EAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,EASpD,6BAA6B,SAAyC;AAChE,QAAA,CAAC,mBAAK,cAAa;AACf,YAAA,IAAI,MAAM,wBAAwB;AAAA,IAAA;AAG1C,UAAM,kBAAkB;AAAA,MACtB;AAAA,MACA,mBAAK;AAAA,IACP;AAEA,UAAM,UACJ,mBAAK,aAAY,6BAA6B,eAAe;AAE/D,UAAM,eAAe,KAAK,mBAAmB,SAAS,eAAe;AAC9D,WAAA;AAAA,EAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,EAUT,mBACE,SACA,iBACqC;AAKrC,UAAM,gBAAuC;AAAA,MAC3C,WAAW,MAAM,QAAQ,UAAU;AAAA,MACnC,SAAS,CAAC,UAAU;AACZ,cAAA,gBAAgB,QAAQ,QAAQ,KAAK;AAE3C,YAAI,WAAW,eAAe;AAC5B,gBAAM,IAAI,MAAM,2BAA2B,cAAc,KAAK,EAAE;AAAA,QAAA;AAGlE,cAAM,kBAA2C;AAAA,UAC/C;AAAA,YACE,GAAG;AAAA,YACH,aAAa,MAAM,KAAK;AAAA,UAC1B;AAAA,UACA,CAAC,MAAM,KAAK,MAAM;AAAA,QACpB;AAEO,eAAA;AAAA,MACT;AAAA,MACA,aAAa,MAAM;AAAA,MACnB,OAAO,MAAM,QAAQ,MAAM;AAAA,MAC3B,QAAQ,MAAM,QAAQ,OAAO;AAAA,MAC7B,aAAa,MAAM,QAAQ,YAAY;AAAA,MACvC,WAAW,MAAM,QAAQ,UAAU;AAAA,MACnC,WAAW,CAAC,UAAU,QAAQ,UAAU,KAAK;AAAA,MAC7C,iBAAiB,MAAM,mBAAK;AAAA,MAC5B,uBAAuB,MAAM,mBAAK;AAAA,IACpC;AAEA,WAAO,MAAM,aAAa;AAAA,EAAA;AAAA;AAAA;AAAA;AAAA,EAM5B,CAAC,SAAS,IAAI;AAAA,EAAA;AAAA;AAAA;AAAA;AAAA,EASd,YAAY;AACV,SAAK,MAAM;AAAA,EAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,EAQb,OAAO;AACE,WAAA;AAAA,EAAA;AAuIX;AAldE;AAMA;AAQA;AAIA;AAKA;AA3BF;AAgCQ,cAAU,eAAA;AAAA,EACd;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,GACiB;AACjB,MAAI,mBAAK,cAAa;AACpB,YAAQ,IAAI,qBAAqB;AACjC;AAAA,EAAA;AAGI,QAAA,cAAc,WAAY,MAAM,mBAAmB;AAEnD,QAAA,iBAAiB,sBAAsB,gBAAgB;AAE7D,QAAM,cAAc;AAEpB,QAAM,aAAa;AAAA,IACjB;AAAA,IACA;AAAA,IACA;AAAA,EACF;AAEA,QAAM,YAAY,kBAAkB,YAAY,GAAG,WAAW,KAAK;AACnE,QAAM,UAAU,kBAAkB,YAAY,GAAG,WAAW,OAAO;AACnE,QAAM,UAAU,kBAAkB,YAAY,GAAG,WAAW,OAAO;AAE7D,QAAA,uBAAuB,MAAM,wBAAwB,SAAS;AAEpE,QAAM,WAAY,MAAM;AAAA;AAAA,IACH;AAAA;AAKrB,QAAM,eAAe,SAAS;AAG9B,MAAI,CAAC,eAAe;AAEF,oBAAA,UAAU,MAAM;AAAA,EAAA;AAG5B,QAAA,aAAa,IAAI,YAAY,OAAO;AAAA,IACxC,SAAS,cAAc,aAAa;AAAA,IACpC,SAAS,cAAc,IAAI;AAAA,IAC3B,QAAQ,gBAAgB;AAAA,EAAA,CACzB;AAGG,MAAA;AACA,MAAA;AAEJ,MAAI,qBAAqB;AACzB,QAAM,yBAAyB;AAI/B,QAAM,4BAA4B,MAAM;AAElC,QAAA,CAAC,KAAK,wBAAwB;AAChC;AAAA,IAAA;AAIE,QAAA,CAAC,gBAAgB,CAAC,cAAc;AAClC;AAAA,IAAA;AAGI,UAAA,cAAc,aAAa,SAAS,aAAa;AACjD,UAAA,cACJ,aAAa,gBAAgB,aAAa;AAC5C,UAAM,kBAAkB,KAAK;AAAA,MAC3B,KAAK,MAAO,cAAc,cAAe,GAAG;AAAA,MAC5C;AAAA,IACF;AAEA,UAAM,mBAAqC;AAAA,MACzC,QAAQ;AAAA,MACR,eAAe;AAAA,MACf,UAAU;AAAA,IACZ;AAGM,UAAA,cAAc,YAAY,IAAI;AAChC,QAAA,cAAc,qBAAqB,wBAAwB;AAC7D;AAAA,IAAA;AAImB,yBAAA;AAErB,SAAK,uBAAuB,gBAAgB;AAAA,EAC9C;AAGM,QAAA,uBAAuB,CAAC,aAA+B;AAC5C,mBAAA;AACf,SAAK,0BAA0B;AAAA,EACjC;AAEM,QAAA,uBAAuB,CAAC,aAA+B;AAC5C,mBAAA;AACf,SAAK,0BAA0B;AAAA,EACjC;AAGA,QAAM,CAAC,eAAe,aAAa,IAAI,MAAM,QAAQ,IAAI;AAAA,IACvD,oBAAoB,SAAS,oBAAoB;AAAA,IACjD,oBAAoB,SAAS,oBAAoB;AAAA,EAAA,CAClD;AAGG,MAAA,KAAK,0BAA0B,gBAAgB,cAAc;AACzD,UAAA,cACJ,aAAa,gBAAgB,aAAa;AAC5C,SAAK,uBAAuB;AAAA,MAC1B,QAAQ;AAAA,MACR,eAAe;AAAA,MACf,UAAU;AAAA,IAAA,CACX;AAAA,EAAA;AAME,qBAAA,aAAc,MAAM,aAAa;AAAA,IACpC,YAAY,CAAC,SAAS;AACpB,aAAO,GAAG,UAAU,IAAI,WAAW,IAAI,IAAI;AAAA,IAC7C;AAAA;AAAA;AAAA,IAGA,qBAAqB;AAAA,IACrB,YAAY;AAAA,IACZ,sBAAsB;AACb,aAAA;AAAA,IACT;AAAA,IACA;AAAA,IACA,eAAe;AAAA,EAAA,CAChB;AAEG,MAAA,CAAC,mBAAK,cAAa;AACf,UAAA,IAAI,MAAM,4BAA4B;AAAA,EAAA;AAC9C;AAAA;AAAA;AAAA;AAsKF,wBAAA,SACE,UACA,qBAMM;AACN,MAAI,CAAC,UAAU;AACL,YAAA;AAAA,MACN;AAAA,IACF;AACA;AAAA,EAAA;AAIG,wBAAA,uDAAA,WAA0B,qBAAqB;AAGhD,MAAA;AACG,uBAAA,YAAa,sBAAK,gDAAL,WAAwB;AAE1C,QAAI,oBAAoB,gBAAgB;AAEtC,yBAAK,aAAa,gBAAgB,mBAAK,YAAW,IAAI;AAAA,IAAA;AAGxD,YAAQ,MAAM,uCAAuC;AAAA,MACnD,MAAM,mBAAK,YAAW;AAAA,MACtB,UAAU,mBAAK,YAAW;AAAA,IAAA,CAC3B;AAAA,WACM,OAAO;AAER,UAAA,gBACJ,iBAAiB,0BACb,IAAI;AAAA,MACF,GAAG,MAAM,OAAO;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,IAAA,IAElB;AAEA,UAAA;AAAA,EAAA;AACR;AAAA;AAAA;AAAA;AAMF,8BAAA,SACE,qBAMA,UACM;AACN,MACE,CAAC,oBAAoB,kBACrB,CAAC,oBAAoB,oBACrB;AACA,UAAM,IAAI;AAAA,MACR,cAAc,QAAQ;AAAA,iCACc,oBAAoB,cAAc,mBACnD,oBAAoB,kBAAkB;AAAA;AAAA,IAE3D;AAAA,EAAA,WAEA,CAAC,oBAAoB,WACrB,oBAAoB,iBAAiB,8BACrC;AACA,UAAM,IAAI;AAAA,MACR;AAAA;AAAA,IAEF;AAAA,EAAA;AACF;AAAA;AAAA;AAAA;AAMF,gCAAmB,SAAqC;AAElD,MAAA;AACA,MAAA;AACU,gBAAA,IAAI,IAAI,OAAO;AAAA,WACpB,OAAO;AACd,UAAM,IAAI;AAAA,MACR,oEAAoE,OAAO;AAAA,MAC3E;AAAA,IACF;AAAA,EAAA;AAIE,MAAA,UAAU,aAAa,UAAU;AACnC,UAAM,IAAI;AAAA,MACR,oCAAoC,OAAO;AAAA,MAC3C;AAAA,IACF;AAAA,EAAA;AAIF,QAAM,aAAa,UAAU;AAE7B,QAAM,cAAc,sBAAK,8CAAL,WAClB,YACA;AAGK,SAAA;AAAA,IACL,MAAM;AAAA,IACN,UAAU;AAAA,EACZ;AAAA;AAAA;AAAA;AAAA;AAMF,qBAAA,SAAiB,SAAiB,aAA6B;AACzD,MAAA;AACF,UAAM,MAAM,IAAI,IAAI,aAAa,OAAO;AACxC,WAAO,IAAI,SAAS;AAAA,WACb,OAAO;AACd,UAAM,IAAI;AAAA,MACR,yCAAyC,WAAW;AAAA,MACpD;AAAA,IACF;AAAA,EAAA;AACF;AAOJ,MAAM,gBAAgB,IAAI,cAAc;AAKxC,OAAO,aAAa;","x_google_ignoreList":[0,1,9,10,11,12]}
780
+ const it = new at();
781
+ V(it);