@microblink/blinkid-core 7.1.0 → 7.2.1

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.
@@ -1,323 +1,427 @@
1
- var be = Object.defineProperty;
2
- var z = (e) => {
3
- throw TypeError(e);
1
+ var __defProp = Object.defineProperty;
2
+ var __typeError = (msg) => {
3
+ throw TypeError(msg);
4
4
  };
5
- var ye = (e, t, n) => t in e ? be(e, t, { enumerable: !0, configurable: !0, writable: !0, value: n }) : e[t] = n;
6
- var B = (e, t, n) => ye(e, typeof t != "symbol" ? t + "" : t, n), U = (e, t, n) => t.has(e) || z("Cannot " + n);
7
- var h = (e, t, n) => (U(e, t, "read from private field"), n ? n.call(e) : t.get(e)), x = (e, t, n) => t.has(e) ? z("Cannot add the same private member more than once") : t instanceof WeakSet ? t.add(e) : t.set(e, n), N = (e, t, n, o) => (U(e, t, "write to private field"), o ? o.call(e, n) : t.set(e, n), n), F = (e, t, n) => (U(e, t, "access private method"), n);
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);
8
12
  /**
9
13
  * @license
10
14
  * Copyright 2019 Google LLC
11
15
  * SPDX-License-Identifier: Apache-2.0
12
16
  */
13
- const K = Symbol("Comlink.proxy"), we = Symbol("Comlink.endpoint"), Se = Symbol("Comlink.releaseProxy"), E = Symbol("Comlink.finalizer"), I = Symbol("Comlink.thrown"), Y = (e) => typeof e == "object" && e !== null || typeof e == "function", Pe = {
14
- canHandle: (e) => Y(e) && e[K],
15
- serialize(e) {
16
- const { port1: t, port2: n } = new MessageChannel();
17
- return W(e, t), [n, [n]];
17
+ var _wasmModule, _defaultSessionSettings, _showDemoOverlay, _showProductionOverlay, _BlinkIdWorker_instances, loadWasm_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]];
18
30
  },
19
- deserialize(e) {
20
- return e.start(), Ee(e);
21
- }
22
- }, Ae = {
23
- canHandle: (e) => Y(e) && I 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, []];
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, []];
34
53
  },
35
- deserialize(e) {
36
- throw e.isError ? Object.assign(new Error(e.value.message), e.value) : e.value;
54
+ deserialize(serialized) {
55
+ if (serialized.isError) {
56
+ throw Object.assign(new Error(serialized.value.message), serialized.value);
57
+ }
58
+ throw serialized.value;
37
59
  }
38
- }, X = /* @__PURE__ */ new Map([
39
- ["proxy", Pe],
40
- ["throw", Ae]
60
+ };
61
+ const transferHandlers = /* @__PURE__ */ new Map([
62
+ ["proxy", proxyTransferHandler],
63
+ ["throw", throwTransferHandler]
41
64
  ]);
42
- function Oe(e, t) {
43
- for (const n of e)
44
- if (t === n || n === "*" || n instanceof RegExp && n.test(t))
45
- return !0;
46
- return !1;
47
- }
48
- function W(e, t = globalThis, n = ["*"]) {
49
- t.addEventListener("message", function o(r) {
50
- if (!r || !r.data)
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) {
51
79
  return;
52
- if (!Oe(n, r.origin)) {
53
- console.warn(`Invalid origin '${r.origin}' for comlink proxy`);
80
+ }
81
+ if (!isAllowedOrigin(allowedOrigins, ev.origin)) {
82
+ console.warn(`Invalid origin '${ev.origin}' for comlink proxy`);
54
83
  return;
55
84
  }
56
- const { id: s, type: u, path: i } = Object.assign({ path: [] }, r.data), c = (r.data.argumentList || []).map(b);
57
- let l;
85
+ const { id, type: type2, path } = Object.assign({ path: [] }, ev.data);
86
+ const argumentList = (ev.data.argumentList || []).map(fromWireValue);
87
+ let returnValue;
58
88
  try {
59
- const a = i.slice(0, -1).reduce((m, p) => m[p], e), d = i.reduce((m, p) => m[p], e);
60
- switch (u) {
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 (type2) {
61
92
  case "GET":
62
- l = d;
93
+ {
94
+ returnValue = rawValue;
95
+ }
63
96
  break;
64
97
  case "SET":
65
- a[i.slice(-1)[0]] = b(r.data.value), l = !0;
98
+ {
99
+ parent[path.slice(-1)[0]] = fromWireValue(ev.data.value);
100
+ returnValue = true;
101
+ }
66
102
  break;
67
103
  case "APPLY":
68
- l = d.apply(a, c);
104
+ {
105
+ returnValue = rawValue.apply(parent, argumentList);
106
+ }
69
107
  break;
70
108
  case "CONSTRUCT":
71
109
  {
72
- const m = new d(...c);
73
- l = ne(m);
110
+ const value = new rawValue(...argumentList);
111
+ returnValue = proxy(value);
74
112
  }
75
113
  break;
76
114
  case "ENDPOINT":
77
115
  {
78
- const { port1: m, port2: p } = new MessageChannel();
79
- W(e, p), l = te(m, [m]);
116
+ const { port1, port2 } = new MessageChannel();
117
+ expose(obj, port2);
118
+ returnValue = transfer(port1, [port1]);
80
119
  }
81
120
  break;
82
121
  case "RELEASE":
83
- l = void 0;
122
+ {
123
+ returnValue = void 0;
124
+ }
84
125
  break;
85
126
  default:
86
127
  return;
87
128
  }
88
- } catch (a) {
89
- l = { value: a, [I]: 0 };
129
+ } catch (value) {
130
+ returnValue = { value, [throwMarker]: 0 };
90
131
  }
91
- Promise.resolve(l).catch((a) => ({ value: a, [I]: 0 })).then((a) => {
92
- const [d, m] = L(a);
93
- t.postMessage(Object.assign(Object.assign({}, d), { id: s }), m), u === "RELEASE" && (t.removeEventListener("message", o), Q(t), E in e && typeof e[E] == "function" && e[E]());
94
- }).catch((a) => {
95
- const [d, m] = L({
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 (type2 === "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({
96
146
  value: new TypeError("Unserializable return value"),
97
- [I]: 0
147
+ [throwMarker]: 0
98
148
  });
99
- t.postMessage(Object.assign(Object.assign({}, d), { id: s }), m);
149
+ ep.postMessage(Object.assign(Object.assign({}, wireValue), { id }), transferables);
100
150
  });
101
- }), t.start && t.start();
151
+ });
152
+ if (ep.start) {
153
+ ep.start();
154
+ }
102
155
  }
103
- function ke(e) {
104
- return e.constructor.name === "MessagePort";
156
+ function isMessagePort(endpoint) {
157
+ return endpoint.constructor.name === "MessagePort";
105
158
  }
106
- function Q(e) {
107
- ke(e) && e.close();
159
+ function closeEndPoint(endpoint) {
160
+ if (isMessagePort(endpoint))
161
+ endpoint.close();
108
162
  }
109
- function Ee(e, t) {
110
- const n = /* @__PURE__ */ new Map();
111
- return e.addEventListener("message", function(r) {
112
- const { data: s } = r;
113
- if (!s || !s.id)
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) {
114
168
  return;
115
- const u = n.get(s.id);
116
- if (u)
117
- try {
118
- u(s);
119
- } finally {
120
- n.delete(s.id);
121
- }
122
- }), T(e, n, [], t);
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);
123
181
  }
124
- function O(e) {
125
- if (e)
182
+ function throwIfProxyReleased(isReleased) {
183
+ if (isReleased) {
126
184
  throw new Error("Proxy has been released and is not useable");
185
+ }
127
186
  }
128
- function Z(e) {
129
- return P(e, /* @__PURE__ */ new Map(), {
187
+ function releaseEndpoint(ep) {
188
+ return requestResponseMessage(ep, /* @__PURE__ */ new Map(), {
130
189
  type: "RELEASE"
131
190
  }).then(() => {
132
- Q(e);
191
+ closeEndPoint(ep);
133
192
  });
134
193
  }
135
- const M = /* @__PURE__ */ new WeakMap(), v = "FinalizationRegistry" in globalThis && new FinalizationRegistry((e) => {
136
- const t = (M.get(e) || 0) - 1;
137
- M.set(e, t), t === 0 && Z(e);
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
+ }
138
201
  });
139
- function Ie(e, t) {
140
- const n = (M.get(t) || 0) + 1;
141
- M.set(t, n), v && v.register(e, t, e);
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
+ }
142
208
  }
143
- function Me(e) {
144
- v && v.unregister(e);
209
+ function unregisterProxy(proxy2) {
210
+ if (proxyFinalizers) {
211
+ proxyFinalizers.unregister(proxy2);
212
+ }
145
213
  }
146
- function T(e, t, n = [], o = function() {
214
+ function createProxy(ep, pendingListeners, path = [], target = function() {
147
215
  }) {
148
- let r = !1;
149
- const s = new Proxy(o, {
150
- get(u, i) {
151
- if (O(r), i === Se)
216
+ let isProxyReleased = false;
217
+ const proxy2 = new Proxy(target, {
218
+ get(_target, prop) {
219
+ throwIfProxyReleased(isProxyReleased);
220
+ if (prop === releaseProxy) {
152
221
  return () => {
153
- Me(s), Z(e), t.clear(), r = !0;
222
+ unregisterProxy(proxy2);
223
+ releaseEndpoint(ep);
224
+ pendingListeners.clear();
225
+ isProxyReleased = true;
154
226
  };
155
- if (i === "then") {
156
- if (n.length === 0)
157
- return { then: () => s };
158
- const c = P(e, t, {
227
+ }
228
+ if (prop === "then") {
229
+ if (path.length === 0) {
230
+ return { then: () => proxy2 };
231
+ }
232
+ const r = requestResponseMessage(ep, pendingListeners, {
159
233
  type: "GET",
160
- path: n.map((l) => l.toString())
161
- }).then(b);
162
- return c.then.bind(c);
234
+ path: path.map((p) => p.toString())
235
+ }).then(fromWireValue);
236
+ return r.then.bind(r);
163
237
  }
164
- return T(e, t, [...n, i]);
238
+ return createProxy(ep, pendingListeners, [...path, prop]);
165
239
  },
166
- set(u, i, c) {
167
- O(r);
168
- const [l, a] = L(c);
169
- return P(e, t, {
240
+ set(_target, prop, rawValue) {
241
+ throwIfProxyReleased(isProxyReleased);
242
+ const [value, transferables] = toWireValue(rawValue);
243
+ return requestResponseMessage(ep, pendingListeners, {
170
244
  type: "SET",
171
- path: [...n, i].map((d) => d.toString()),
172
- value: l
173
- }, a).then(b);
245
+ path: [...path, prop].map((p) => p.toString()),
246
+ value
247
+ }, transferables).then(fromWireValue);
174
248
  },
175
- apply(u, i, c) {
176
- O(r);
177
- const l = n[n.length - 1];
178
- if (l === we)
179
- return P(e, t, {
249
+ apply(_target, _thisArg, rawArgumentList) {
250
+ throwIfProxyReleased(isProxyReleased);
251
+ const last = path[path.length - 1];
252
+ if (last === createEndpoint) {
253
+ return requestResponseMessage(ep, pendingListeners, {
180
254
  type: "ENDPOINT"
181
- }).then(b);
182
- if (l === "bind")
183
- return T(e, t, n.slice(0, -1));
184
- const [a, d] = V(c);
185
- return P(e, t, {
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, {
186
262
  type: "APPLY",
187
- path: n.map((m) => m.toString()),
188
- argumentList: a
189
- }, d).then(b);
263
+ path: path.map((p) => p.toString()),
264
+ argumentList
265
+ }, transferables).then(fromWireValue);
190
266
  },
191
- construct(u, i) {
192
- O(r);
193
- const [c, l] = V(i);
194
- return P(e, t, {
267
+ construct(_target, rawArgumentList) {
268
+ throwIfProxyReleased(isProxyReleased);
269
+ const [argumentList, transferables] = processArguments(rawArgumentList);
270
+ return requestResponseMessage(ep, pendingListeners, {
195
271
  type: "CONSTRUCT",
196
- path: n.map((a) => a.toString()),
197
- argumentList: c
198
- }, l).then(b);
272
+ path: path.map((p) => p.toString()),
273
+ argumentList
274
+ }, transferables).then(fromWireValue);
199
275
  }
200
276
  });
201
- return Ie(s, e), s;
277
+ registerProxy(proxy2, ep);
278
+ return proxy2;
202
279
  }
203
- function ve(e) {
204
- return Array.prototype.concat.apply([], e);
280
+ function myFlat(arr) {
281
+ return Array.prototype.concat.apply([], arr);
205
282
  }
206
- function V(e) {
207
- const t = e.map(L);
208
- return [t.map((n) => n[0]), ve(t.map((n) => n[1]))];
283
+ function processArguments(argumentList) {
284
+ const processed = argumentList.map(toWireValue);
285
+ return [processed.map((v) => v[0]), myFlat(processed.map((v) => v[1]))];
209
286
  }
210
- const ee = /* @__PURE__ */ new WeakMap();
211
- function te(e, t) {
212
- return ee.set(e, t), e;
287
+ const transferCache = /* @__PURE__ */ new WeakMap();
288
+ function transfer(obj, transfers) {
289
+ transferCache.set(obj, transfers);
290
+ return obj;
213
291
  }
214
- function ne(e) {
215
- return Object.assign(e, { [K]: !0 });
292
+ function proxy(obj) {
293
+ return Object.assign(obj, { [proxyMarker]: true });
216
294
  }
217
- function L(e) {
218
- for (const [t, n] of X)
219
- if (n.canHandle(e)) {
220
- const [o, r] = n.serialize(e);
295
+ function toWireValue(value) {
296
+ for (const [name, handler] of transferHandlers) {
297
+ if (handler.canHandle(value)) {
298
+ const [serializedValue, transferables] = handler.serialize(value);
221
299
  return [
222
300
  {
223
301
  type: "HANDLER",
224
- name: t,
225
- value: o
302
+ name,
303
+ value: serializedValue
226
304
  },
227
- r
305
+ transferables
228
306
  ];
229
307
  }
308
+ }
230
309
  return [
231
310
  {
232
311
  type: "RAW",
233
- value: e
312
+ value
234
313
  },
235
- ee.get(e) || []
314
+ transferCache.get(value) || []
236
315
  ];
237
316
  }
238
- function b(e) {
239
- switch (e.type) {
317
+ function fromWireValue(value) {
318
+ switch (value.type) {
240
319
  case "HANDLER":
241
- return X.get(e.name).deserialize(e.value);
320
+ return transferHandlers.get(value.name).deserialize(value.value);
242
321
  case "RAW":
243
- return e.value;
322
+ return value.value;
244
323
  }
245
324
  }
246
- function P(e, t, n, o) {
247
- return new Promise((r) => {
248
- const s = Le();
249
- t.set(s, r), e.start && e.start(), e.postMessage(Object.assign({ id: s }, n), o);
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);
250
333
  });
251
334
  }
252
- function Le() {
335
+ function generateUUID() {
253
336
  return new Array(4).fill(0).map(() => Math.floor(Math.random() * Number.MAX_SAFE_INTEGER).toString(16)).join("-");
254
337
  }
255
- const Re = 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])), Ue = 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])), xe = 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])), Te = 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])), We = 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])), je = 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])), Ce = () => (async (e) => {
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) => {
256
339
  try {
257
- return typeof MessageChannel < "u" && new MessageChannel().port1.postMessage(new SharedArrayBuffer(1)), WebAssembly.validate(e);
258
- } catch {
259
- return !1;
340
+ return "undefined" != typeof MessageChannel && new MessageChannel().port1.postMessage(new SharedArrayBuffer(1)), WebAssembly.validate(e);
341
+ } catch (e2) {
342
+ return false;
260
343
  }
261
344
  })(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]));
262
- function De() {
263
- const e = navigator.userAgent.toLowerCase();
264
- return e.includes("safari") && !e.includes("chrome");
265
- }
266
- async function ze() {
267
- if (!await Ce()) return !1;
268
- if (!("importScripts" in self))
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)) {
269
353
  throw Error("Not implemented");
270
- return De() ? !1 : "Worker" in self;
271
- }
272
- async function Be() {
273
- const e = [
274
- Ue(),
275
- xe(),
276
- Re(),
277
- Te(),
278
- We()
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()
279
367
  ];
280
- if (!(await Promise.all(e)).every(Boolean))
368
+ const supportsBasic = (await Promise.all(basicSet)).every(Boolean);
369
+ if (!supportsBasic) {
281
370
  throw new Error("Browser doesn't meet minimum requirements!");
282
- return await je() ? await ze() ? "advanced-threads" : "advanced" : "basic";
283
- }
284
- const $ = "application/javascript", H = (e, t = {}) => {
285
- const n = {
286
- skipSameOrigin: !0,
287
- useBlob: !0,
288
- ...t
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 type = "application/javascript";
383
+ const getCrossOriginWorkerURL = (originalWorkerUrl, _options = {}) => {
384
+ const options = {
385
+ skipSameOrigin: true,
386
+ useBlob: true,
387
+ ..._options
289
388
  };
290
- return n.skipSameOrigin && new URL(e).origin === self.location.origin ? Promise.resolve(e) : new Promise(
291
- (o, r) => void fetch(e).then((s) => s.text()).then((s) => {
292
- new URL(e).href.split("/").pop();
293
- let i = "";
294
- if (n.useBlob) {
295
- const c = new Blob([s], { type: $ });
296
- i = URL.createObjectURL(c);
297
- } else
298
- i = `data:${$},` + encodeURIComponent(s);
299
- o(i);
300
- }).catch(r)
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 });
399
+ finalURL = URL.createObjectURL(blob);
400
+ } else {
401
+ finalURL = `data:${type},` + encodeURIComponent(codeString);
402
+ }
403
+ resolve(finalURL);
404
+ }).catch(reject)
301
405
  );
302
406
  };
303
- function Ne() {
304
- const e = self.navigator.userAgent.toLowerCase();
305
- return /iphone|ipad|ipod/.test(e);
407
+ function isIOS() {
408
+ const userAgent = self.navigator.userAgent.toLowerCase();
409
+ return /iphone|ipad|ipod/.test(userAgent);
306
410
  }
307
- function Fe(e) {
411
+ function constructLicenseRequest(unlockResult) {
308
412
  return {
309
- licenseId: e.licenseId,
310
- licensee: e.licensee,
311
- applicationIds: e.applicationIds,
312
- packageName: e.packageName,
413
+ licenseId: unlockResult.licenseId,
414
+ licensee: unlockResult.licensee,
415
+ applicationIds: unlockResult.applicationIds,
416
+ packageName: unlockResult.packageName,
313
417
  platform: "Browser",
314
- sdkName: e.sdkName,
315
- sdkVersion: e.sdkVersion
418
+ sdkName: unlockResult.sdkName,
419
+ sdkVersion: unlockResult.sdkVersion
316
420
  };
317
421
  }
318
- async function Ve(e) {
422
+ async function obtainNewServerPermission(unlockResult) {
319
423
  try {
320
- return await (await fetch(
424
+ const response = await fetch(
321
425
  "https://baltazar.microblink.com/api/v2/status/check",
322
426
  {
323
427
  method: "POST",
@@ -325,243 +429,262 @@ async function Ve(e) {
325
429
  "Content-Type": "application/json"
326
430
  },
327
431
  cache: "no-cache",
328
- body: JSON.stringify(Fe(e))
432
+ body: JSON.stringify(constructLicenseRequest(unlockResult))
433
+ }
434
+ );
435
+ const serverPermission = await response.json();
436
+ return serverPermission;
437
+ } catch (error) {
438
+ console.error(error);
439
+ throw error;
440
+ }
441
+ }
442
+ function mbToWasmPages(mb) {
443
+ return Math.ceil(mb * 1024 * 1024 / 64 / 1024);
444
+ }
445
+ async function downloadArrayBuffer(url, progressCallback) {
446
+ const response = await fetch(url);
447
+ if (!response.body || !response.headers.has("Content-Length")) {
448
+ return response.arrayBuffer();
449
+ }
450
+ const contentLength = parseInt(response.headers.get("Content-Length"), 10);
451
+ let loaded = 0;
452
+ const reader = response.body.getReader();
453
+ const chunks = [];
454
+ let result = await reader.read();
455
+ while (!result.done) {
456
+ const value = result.value;
457
+ if (value) {
458
+ chunks.push(value);
459
+ loaded += value.length;
460
+ if (progressCallback) {
461
+ const progress = Math.min(
462
+ Math.round(loaded / contentLength * 100),
463
+ 100
464
+ );
465
+ progressCallback({
466
+ loaded,
467
+ contentLength,
468
+ progress
469
+ });
329
470
  }
330
- )).json();
331
- } catch (t) {
332
- throw console.error(t), t;
333
- }
334
- }
335
- function _(e) {
336
- return Math.ceil(e * 1024 * 1024 / 64 / 1024);
337
- }
338
- async function q(e, t) {
339
- const n = await fetch(e);
340
- if (!n.body || !n.headers.has("Content-Length"))
341
- return n.arrayBuffer();
342
- const o = parseInt(n.headers.get("Content-Length"), 10);
343
- let r = 0;
344
- const s = n.body.getReader(), u = [];
345
- let i = await s.read();
346
- for (; !i.done; ) {
347
- const a = i.value;
348
- if (a && (u.push(a), r += a.length, t)) {
349
- const d = Math.min(
350
- Math.round(r / o * 100),
351
- 100
352
- );
353
- t({
354
- loaded: r,
355
- contentLength: o,
356
- progress: d
357
- });
358
471
  }
359
- i = await s.read();
472
+ result = await reader.read();
360
473
  }
361
- const c = new Uint8Array(r);
362
- let l = 0;
363
- for (const a of u)
364
- c.set(a, l), l += a.length;
365
- return c.buffer;
474
+ const allChunks = new Uint8Array(loaded);
475
+ let position = 0;
476
+ for (const chunk of chunks) {
477
+ allChunks.set(chunk, position);
478
+ position += chunk.length;
479
+ }
480
+ return allChunks.buffer;
366
481
  }
367
- function A(...e) {
368
- const t = e.filter((n) => n).join("/").replace(/([^:]\/)\/+/g, "$1");
482
+ function buildResourcePath(...segments) {
483
+ const path = segments.filter((segment) => segment).join("/").replace(/([^:]\/)\/+/g, "$1");
369
484
  try {
370
- new URL(t, "http://example.com");
485
+ new URL(path, "http://example.com");
371
486
  } catch {
372
- throw new Error(`Invalid URL: ${t}`);
373
- }
374
- return t;
375
- }
376
- const $e = {
377
- inputImageSource: "video",
378
- scanningMode: "automatic",
379
- scanningSettings: {
380
- allowUncertainFrontSideScan: !1,
381
- blurDetectionLevel: "mid",
382
- glareDetectionLevel: "mid",
383
- tiltDetectionLevel: "mid",
384
- skipImagesWithBlur: !0,
385
- skipImagesWithGlare: !0,
386
- skipImagesOccludedByHand: !1,
387
- skipImagesWithInadequateLightingConditions: !1,
388
- combineResultsFromMultipleInputImages: !0,
389
- croppedImageSettings: {
390
- dotsPerInch: 250,
391
- extensionFactor: 0,
392
- returnDocumentImage: !1,
393
- returnFaceImage: !1,
394
- returnSignatureImage: !1
395
- },
396
- customDocumentAnonymizationSettings: [],
397
- customDocumentRules: [],
398
- enableBarcodeScanOnly: !1,
399
- enableCharacterValidation: !0,
400
- inputImageMargin: 0.02,
401
- maxAllowedMismatchesPerField: 0,
402
- recognitionModeFilter: {
403
- enableBarcodeId: !0,
404
- enableFullDocumentRecognition: !0,
405
- enableMrzId: !0,
406
- enableMrzPassport: !0,
407
- enableMrzVisa: !0,
408
- enablePhotoId: !0
409
- },
410
- returnInputImages: !1,
411
- scanCroppedDocumentImage: !1,
412
- scanPassportDataPageOnly: !0,
413
- scanUnsupportedBack: !1,
414
- anonymizationMode: "full-result"
487
+ throw new Error(`Invalid URL: ${path}`);
488
+ }
489
+ return path;
490
+ }
491
+ function getType(payload) {
492
+ return Object.prototype.toString.call(payload).slice(8, -1);
493
+ }
494
+ function isPlainObject(payload) {
495
+ if (getType(payload) !== "Object")
496
+ return false;
497
+ const prototype = Object.getPrototypeOf(payload);
498
+ return !!prototype && prototype.constructor === Object && prototype === Object.prototype;
499
+ }
500
+ function isSymbol(payload) {
501
+ return getType(payload) === "Symbol";
502
+ }
503
+ function assignProp(carry, key, newVal, originalObject) {
504
+ const propType = {}.propertyIsEnumerable.call(originalObject, key) ? "enumerable" : "nonenumerable";
505
+ if (propType === "enumerable")
506
+ carry[key] = newVal;
507
+ if (propType === "nonenumerable") {
508
+ Object.defineProperty(carry, key, {
509
+ value: newVal,
510
+ enumerable: false,
511
+ writable: true,
512
+ configurable: true
513
+ });
415
514
  }
416
- };
417
- function re(e) {
418
- return Object.prototype.toString.call(e).slice(8, -1);
419
- }
420
- function k(e) {
421
- if (re(e) !== "Object")
422
- return !1;
423
- const t = Object.getPrototypeOf(e);
424
- return !!t && t.constructor === Object && t === Object.prototype;
425
- }
426
- function G(e) {
427
- return re(e) === "Symbol";
428
- }
429
- function J(e, t, n, o) {
430
- const r = {}.propertyIsEnumerable.call(o, t) ? "enumerable" : "nonenumerable";
431
- r === "enumerable" && (e[t] = n), r === "nonenumerable" && Object.defineProperty(e, t, {
432
- value: n,
433
- enumerable: !1,
434
- writable: !0,
435
- configurable: !0
436
- });
437
515
  }
438
- function se(e, t, n) {
439
- if (!k(t))
440
- return t;
441
- let o = {};
442
- if (k(e)) {
443
- const i = Object.getOwnPropertyNames(e), c = Object.getOwnPropertySymbols(e);
444
- o = [...i, ...c].reduce((l, a) => {
445
- const d = e[a];
446
- return (!G(a) && !Object.getOwnPropertyNames(t).includes(a) || G(a) && !Object.getOwnPropertySymbols(t).includes(a)) && J(l, a, d, e), l;
516
+ function mergeRecursively(origin, newComer, compareFn) {
517
+ if (!isPlainObject(newComer))
518
+ return newComer;
519
+ let newObject = {};
520
+ if (isPlainObject(origin)) {
521
+ const props2 = Object.getOwnPropertyNames(origin);
522
+ const symbols2 = Object.getOwnPropertySymbols(origin);
523
+ newObject = [...props2, ...symbols2].reduce((carry, key) => {
524
+ const targetVal = origin[key];
525
+ if (!isSymbol(key) && !Object.getOwnPropertyNames(newComer).includes(key) || isSymbol(key) && !Object.getOwnPropertySymbols(newComer).includes(key)) {
526
+ assignProp(carry, key, targetVal, origin);
527
+ }
528
+ return carry;
447
529
  }, {});
448
530
  }
449
- const r = Object.getOwnPropertyNames(t), s = Object.getOwnPropertySymbols(t);
450
- return [...r, ...s].reduce((i, c) => {
451
- let l = t[c];
452
- const a = k(e) ? e[c] : void 0;
453
- return a !== void 0 && k(l) && (l = se(a, l)), J(i, c, l, t), i;
454
- }, o);
455
- }
456
- function He(e, ...t) {
457
- return t.reduce((n, o) => se(n, o), e);
458
- }
459
- function ae(e) {
531
+ const props = Object.getOwnPropertyNames(newComer);
532
+ const symbols = Object.getOwnPropertySymbols(newComer);
533
+ const result = [...props, ...symbols].reduce((carry, key) => {
534
+ let newVal = newComer[key];
535
+ const targetVal = isPlainObject(origin) ? origin[key] : void 0;
536
+ if (targetVal !== void 0 && isPlainObject(newVal)) {
537
+ newVal = mergeRecursively(targetVal, newVal);
538
+ }
539
+ const propToAssign = newVal;
540
+ assignProp(carry, key, propToAssign, newComer);
541
+ return carry;
542
+ }, newObject);
543
+ return result;
544
+ }
545
+ function merge(object, ...otherObjects) {
546
+ return otherObjects.reduce((result, newComer) => {
547
+ return mergeRecursively(result, newComer);
548
+ }, object);
549
+ }
550
+ function normalizeDocumentFilter(filter) {
460
551
  return {
461
- country: (e == null ? void 0 : e.country) ?? void 0,
462
- region: (e == null ? void 0 : e.region) ?? void 0,
463
- type: (e == null ? void 0 : e.type) ?? void 0
552
+ country: (filter == null ? void 0 : filter.country) ?? void 0,
553
+ region: (filter == null ? void 0 : filter.region) ?? void 0,
554
+ type: (filter == null ? void 0 : filter.type) ?? void 0
464
555
  };
465
556
  }
466
- const _e = (e) => ({
467
- documentFilter: ae(e.documentFilter),
468
- fields: e.fields ?? []
469
- }), qe = (e) => ({
470
- documentFilter: ae(e.documentFilter),
471
- fields: e.fields || [],
472
- documentNumberAnonymizationSettings: e.documentNumberAnonymizationSettings ? {
473
- prefixDigitsVisible: e.documentNumberAnonymizationSettings.prefixDigitsVisible,
474
- suffixDigitsVisible: e.documentNumberAnonymizationSettings.suffixDigitsVisible
475
- } : void 0
476
- });
477
- function Ge(e = {}) {
478
- var s, u, i, c;
479
- e && (e = Object.fromEntries(
480
- Object.entries(e).filter(([l, a]) => a !== void 0)
481
- ));
482
- const t = ((u = (s = e == null ? void 0 : e.scanningSettings) == null ? void 0 : s.customDocumentRules) == null ? void 0 : u.map(
483
- _e
484
- )) ?? [], n = ((c = (i = e == null ? void 0 : e.scanningSettings) == null ? void 0 : i.customDocumentAnonymizationSettings) == null ? void 0 : c.map(
485
- qe
486
- )) ?? [], o = {
487
- ...e == null ? void 0 : e.scanningSettings,
488
- customDocumentRules: t,
489
- customDocumentAnonymizationSettings: n
557
+ const normalizeDocumentRule = (rule) => {
558
+ return {
559
+ documentFilter: normalizeDocumentFilter(rule.documentFilter),
560
+ fields: rule.fields ?? []
561
+ };
562
+ };
563
+ const normalizeDocumentAnonymizationSettings = (settings) => {
564
+ return {
565
+ documentFilter: normalizeDocumentFilter(settings.documentFilter),
566
+ fields: settings.fields || [],
567
+ documentNumberAnonymizationSettings: settings.documentNumberAnonymizationSettings ? {
568
+ prefixDigitsVisible: settings.documentNumberAnonymizationSettings.prefixDigitsVisible,
569
+ suffixDigitsVisible: settings.documentNumberAnonymizationSettings.suffixDigitsVisible
570
+ } : void 0
490
571
  };
491
- return He($e, {
492
- ...e,
493
- scanningSettings: o
572
+ };
573
+ function buildSessionSettings(options = {}, defaultSessionSettings) {
574
+ var _a, _b, _c, _d;
575
+ if (options) {
576
+ options = Object.fromEntries(
577
+ Object.entries(options).filter(([_, value]) => value !== void 0)
578
+ );
579
+ }
580
+ const customDocumentRules = ((_b = (_a = options == null ? void 0 : options.scanningSettings) == null ? void 0 : _a.customDocumentRules) == null ? void 0 : _b.map(
581
+ normalizeDocumentRule
582
+ )) ?? [];
583
+ const customDocumentAnonymizationSettings = ((_d = (_c = options == null ? void 0 : options.scanningSettings) == null ? void 0 : _c.customDocumentAnonymizationSettings) == null ? void 0 : _d.map(
584
+ normalizeDocumentAnonymizationSettings
585
+ )) ?? [];
586
+ const scanningSettings = {
587
+ ...options == null ? void 0 : options.scanningSettings,
588
+ customDocumentRules,
589
+ customDocumentAnonymizationSettings
590
+ };
591
+ const sessionSettings = merge(defaultSessionSettings, {
592
+ ...options,
593
+ scanningSettings
494
594
  });
595
+ return sessionSettings;
495
596
  }
496
- var g, R, oe;
497
- class Je {
597
+ class BlinkIdWorker {
498
598
  constructor() {
499
- x(this, R);
599
+ __privateAdd(this, _BlinkIdWorker_instances);
500
600
  // core objects
501
- x(this, g);
502
- B(this, "progressStatusCallback");
601
+ __privateAdd(this, _wasmModule);
602
+ // must be initialized when calling initBlinkId
603
+ __privateAdd(this, _defaultSessionSettings);
604
+ __publicField(this, "progressStatusCallback");
605
+ __privateAdd(this, _showDemoOverlay, true);
606
+ __privateAdd(this, _showProductionOverlay, true);
503
607
  }
504
608
  /**
505
609
  * This method initializes everything.
506
610
  */
507
- async initBlinkId(t, n) {
508
- const o = new URL(
611
+ async initBlinkId(settings, defaultSessionSettings, progressCallback) {
612
+ const resourcesPath = new URL(
509
613
  "resources/",
510
- t.resourcesLocation
614
+ settings.resourcesLocation
511
615
  ).toString();
512
- if (this.progressStatusCallback = n, await F(this, R, oe).call(this, {
513
- resourceUrl: o,
514
- variant: t.wasmVariant,
515
- initialMemory: t.initialMemory,
516
- useLightweightBuild: t.useLightweightBuild
517
- }), !h(this, g))
616
+ __privateSet(this, _defaultSessionSettings, defaultSessionSettings);
617
+ this.progressStatusCallback = progressCallback;
618
+ await __privateMethod(this, _BlinkIdWorker_instances, loadWasm_fn).call(this, {
619
+ resourceUrl: resourcesPath,
620
+ variant: settings.wasmVariant,
621
+ initialMemory: settings.initialMemory,
622
+ useLightweightBuild: settings.useLightweightBuild
623
+ });
624
+ if (!__privateGet(this, _wasmModule)) {
518
625
  throw new Error("Wasm module not loaded");
519
- const r = h(this, g).initializeWithLicenseKey(
520
- t.licenseKey,
521
- t.userId,
522
- !1
626
+ }
627
+ const licenceUnlockResult = __privateGet(this, _wasmModule).initializeWithLicenseKey(
628
+ settings.licenseKey,
629
+ settings.userId,
630
+ false
523
631
  );
524
- if (r.unlockResult === "requires-server-permission") {
525
- const s = await Ve(r), u = h(this, g).submitServerPermission(
526
- JSON.stringify(s)
632
+ if (licenceUnlockResult.unlockResult === "requires-server-permission") {
633
+ const serverPermissionResponse = await obtainNewServerPermission(licenceUnlockResult);
634
+ const serverPermissionResult = __privateGet(this, _wasmModule).submitServerPermission(
635
+ JSON.stringify(serverPermissionResponse)
527
636
  );
528
- if (u.error)
529
- throw new Error("Server unlock error: " + u.error);
637
+ if (serverPermissionResult.error) {
638
+ throw new Error("Server unlock error: " + serverPermissionResult.error);
639
+ }
530
640
  }
641
+ __privateSet(this, _showDemoOverlay, licenceUnlockResult.showDemoOverlay);
642
+ __privateSet(this, _showProductionOverlay, licenceUnlockResult.showProductionOverlay);
531
643
  }
532
- createBlinkIdScanningSession(t) {
533
- if (!h(this, g))
644
+ createBlinkIdScanningSession(options) {
645
+ if (!__privateGet(this, _wasmModule)) {
534
646
  throw new Error("Wasm module not loaded");
535
- const n = Ge(t), o = h(this, g).createBlinkIdScanningSession(n);
536
- return this.createProxySession(o, n);
537
- }
538
- createProxySession(t, n) {
539
- return ne({
540
- getResult: () => t.getResult(),
541
- process: (r) => {
542
- const s = t.process(r);
543
- if ("error" in s)
544
- throw new Error(`Error processing frame: ${s.error}`);
545
- return te(
647
+ }
648
+ const sessionSettings = buildSessionSettings(
649
+ options,
650
+ __privateGet(this, _defaultSessionSettings)
651
+ );
652
+ const session = __privateGet(this, _wasmModule).createBlinkIdScanningSession(sessionSettings);
653
+ const proxySession = this.createProxySession(session, sessionSettings);
654
+ return proxySession;
655
+ }
656
+ createProxySession(session, sessionSettings) {
657
+ const customSession = {
658
+ getResult: () => session.getResult(),
659
+ process: (image) => {
660
+ const processResult = session.process(image);
661
+ if ("error" in processResult) {
662
+ throw new Error(`Error processing frame: ${processResult.error}`);
663
+ }
664
+ const transferPackage = transfer(
546
665
  {
547
- ...s,
548
- arrayBuffer: r.data.buffer
666
+ ...processResult,
667
+ arrayBuffer: image.data.buffer
549
668
  },
550
- [r.data.buffer]
669
+ [image.data.buffer]
551
670
  );
671
+ return transferPackage;
552
672
  },
553
- getSettings: () => n,
554
- reset: () => t.reset(),
555
- delete: () => t.delete(),
556
- deleteLater: () => t.deleteLater(),
557
- isDeleted: () => t.isDeleted(),
558
- isAliasOf: (r) => t.isAliasOf(r)
559
- });
673
+ getSettings: () => sessionSettings,
674
+ reset: () => session.reset(),
675
+ delete: () => session.delete(),
676
+ deleteLater: () => session.deleteLater(),
677
+ isDeleted: () => session.isDeleted(),
678
+ isAliasOf: (other) => session.isAliasOf(other),
679
+ showDemoOverlay: () => __privateGet(this, _showDemoOverlay),
680
+ showProductionOverlay: () => __privateGet(this, _showProductionOverlay)
681
+ };
682
+ return proxy(customSession);
560
683
  }
561
684
  /**
562
685
  * This method is called when the worker is terminated.
563
686
  */
564
- [E]() {
687
+ [finalizer]() {
565
688
  }
566
689
  /**
567
690
  * Terminates the workers and the Wasm runtime.
@@ -573,78 +696,124 @@ class Je {
573
696
  return 1;
574
697
  }
575
698
  }
576
- g = new WeakMap(), R = new WeakSet(), oe = async function({
577
- resourceUrl: t,
578
- variant: n,
579
- useLightweightBuild: o,
580
- initialMemory: r
699
+ _wasmModule = new WeakMap();
700
+ _defaultSessionSettings = new WeakMap();
701
+ _showDemoOverlay = new WeakMap();
702
+ _showProductionOverlay = new WeakMap();
703
+ _BlinkIdWorker_instances = new WeakSet();
704
+ loadWasm_fn = async function({
705
+ resourceUrl,
706
+ variant,
707
+ useLightweightBuild,
708
+ initialMemory
581
709
  }) {
582
- if (h(this, g)) {
710
+ if (__privateGet(this, _wasmModule)) {
583
711
  console.log("Wasm already loaded");
584
712
  return;
585
713
  }
586
- const s = n ?? await Be(), u = o ? "lightweight" : "full", i = "BlinkIdModule", c = A(
587
- t,
588
- u,
589
- s
590
- ), l = A(c, `${i}.js`), a = A(
591
- c,
592
- `${i}.worker.mjs`
593
- ), d = A(c, `${i}.wasm`), m = A(c, `${i}.data`), p = await H(l), ie = await H(a), ce = (await import(
714
+ const wasmVariant = variant ?? await detectWasmFeatures();
715
+ const featureVariant = useLightweightBuild ? "lightweight" : "full";
716
+ const MODULE_NAME = "BlinkIdModule";
717
+ const variantUrl = buildResourcePath(
718
+ resourceUrl,
719
+ featureVariant,
720
+ wasmVariant
721
+ );
722
+ const workerUrl = buildResourcePath(variantUrl, `${MODULE_NAME}.js`);
723
+ const pThreadWorkerUrl = buildResourcePath(
724
+ variantUrl,
725
+ `${MODULE_NAME}.worker.mjs`
726
+ );
727
+ const wasmUrl = buildResourcePath(variantUrl, `${MODULE_NAME}.wasm`);
728
+ const dataUrl = buildResourcePath(variantUrl, `${MODULE_NAME}.data`);
729
+ const crossOriginWorkerUrl = await getCrossOriginWorkerURL(workerUrl);
730
+ const crossOriginPThreadWorkerUrl = await getCrossOriginWorkerURL(pThreadWorkerUrl);
731
+ const imported = await import(
594
732
  /* @vite-ignore */
595
- p
596
- )).default;
597
- r || (r = Ne() ? 700 : 200);
598
- const le = new WebAssembly.Memory({
599
- initial: _(r),
600
- maximum: _(2048),
601
- shared: s === "advanced-threads"
733
+ crossOriginWorkerUrl
734
+ );
735
+ const createModule = imported.default;
736
+ if (!initialMemory) {
737
+ initialMemory = isIOS() ? 700 : 200;
738
+ }
739
+ const wasmMemory = new WebAssembly.Memory({
740
+ initial: mbToWasmPages(initialMemory),
741
+ maximum: mbToWasmPages(2048),
742
+ shared: wasmVariant === "advanced-threads"
602
743
  });
603
- let y, w, j = 0;
604
- const ue = 32, C = () => {
605
- if (!this.progressStatusCallback || !y || !w)
744
+ let wasmProgress;
745
+ let dataProgress;
746
+ let lastProgressUpdate = 0;
747
+ const progressUpdateInterval = 32;
748
+ const throttledCombinedProgress = () => {
749
+ if (!this.progressStatusCallback) {
750
+ return;
751
+ }
752
+ if (!wasmProgress || !dataProgress) {
606
753
  return;
607
- const f = y.loaded + w.loaded, S = y.contentLength + w.contentLength, pe = Math.min(
608
- Math.round(f / S * 100),
754
+ }
755
+ const totalLoaded = wasmProgress.loaded + dataProgress.loaded;
756
+ const totalLength = wasmProgress.contentLength + dataProgress.contentLength;
757
+ const combinedPercent = Math.min(
758
+ Math.round(totalLoaded / totalLength * 100),
609
759
  100
610
- ), he = {
611
- loaded: f,
612
- contentLength: S,
613
- progress: pe
614
- }, D = performance.now();
615
- D - j < ue || (j = D, this.progressStatusCallback(he));
616
- }, de = (f) => {
617
- y = f, C();
618
- }, me = (f) => {
619
- w = f, C();
620
- }, [fe, ge] = await Promise.all([
621
- q(d, de),
622
- q(m, me)
760
+ );
761
+ const combinedProgress = {
762
+ loaded: totalLoaded,
763
+ contentLength: totalLength,
764
+ progress: combinedPercent
765
+ };
766
+ const currentTime = performance.now();
767
+ if (currentTime - lastProgressUpdate < progressUpdateInterval) {
768
+ return;
769
+ }
770
+ lastProgressUpdate = currentTime;
771
+ this.progressStatusCallback(combinedProgress);
772
+ };
773
+ const wasmProgressCallback = (progress) => {
774
+ wasmProgress = progress;
775
+ void throttledCombinedProgress();
776
+ };
777
+ const dataProgressCallback = (progress) => {
778
+ dataProgress = progress;
779
+ void throttledCombinedProgress();
780
+ };
781
+ const [preloadedWasm, preloadedData] = await Promise.all([
782
+ downloadArrayBuffer(wasmUrl, wasmProgressCallback),
783
+ downloadArrayBuffer(dataUrl, dataProgressCallback)
623
784
  ]);
624
- if (this.progressStatusCallback && y && w) {
625
- const f = y.contentLength + w.contentLength;
785
+ if (this.progressStatusCallback && wasmProgress && dataProgress) {
786
+ const totalLength = wasmProgress.contentLength + dataProgress.contentLength;
626
787
  this.progressStatusCallback({
627
- loaded: f,
628
- contentLength: f,
788
+ loaded: totalLength,
789
+ contentLength: totalLength,
629
790
  progress: 100
630
791
  });
631
792
  }
632
- if (N(this, g, await ce({
633
- locateFile: (f) => {
634
- let S;
635
- return f.includes(".worker.mjs") ? S = ie : S = `${c}/${s}/${f}`, S;
793
+ __privateSet(this, _wasmModule, await createModule({
794
+ locateFile: (path) => {
795
+ let filePath;
796
+ if (path.includes(".worker.mjs")) {
797
+ filePath = crossOriginPThreadWorkerUrl;
798
+ } else {
799
+ filePath = `${variantUrl}/${wasmVariant}/${path}`;
800
+ }
801
+ return filePath;
636
802
  },
637
803
  // pthreads build breaks without this:
638
804
  // "Failed to execute 'createObjectURL' on 'URL': Overload resolution failed."
639
- mainScriptUrlOrBlob: p,
640
- wasmBinary: fe,
805
+ mainScriptUrlOrBlob: crossOriginWorkerUrl,
806
+ wasmBinary: preloadedWasm,
641
807
  getPreloadedPackage() {
642
- return ge;
808
+ return preloadedData;
643
809
  },
644
- wasmMemory: le,
645
- noExitRuntime: !0
646
- })), !h(this, g))
810
+ wasmMemory,
811
+ noExitRuntime: true
812
+ }));
813
+ if (!__privateGet(this, _wasmModule)) {
647
814
  throw new Error("Failed to load Wasm module");
815
+ }
648
816
  };
649
- const Ke = new Je();
650
- W(Ke);
817
+ const blinkIdWorker = new BlinkIdWorker();
818
+ expose(blinkIdWorker);
819
+ //# 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\nexport function isSafari() {\n  const userAgent = navigator.userAgent.toLowerCase();\n  return userAgent.includes(\"safari\") && !userAgent.includes(\"chrome\");\n}\n\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 * 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\nexport type WasmVariant = \"basic\" | \"advanced\" | \"advanced-threads\";\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\nconst type = \"application/javascript\";\n\ntype Options = {\n  skipSameOrigin?: boolean;\n  useBlob?: boolean;\n};\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 });\n            finalURL = URL.createObjectURL(blob);\n          } else {\n            finalURL = `data:${type},` + 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 * @returns {boolean} 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 * @returns {boolean} 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\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\nexport async function obtainNewServerPermission(\n  unlockResult: LicenseUnlockResult,\n) {\n  try {\n    const response = await fetch(\n      \"https://baltazar.microblink.com/api/v2/status/check\",\n      {\n        method: \"POST\",\n        headers: {\n          \"Content-Type\": \"application/json\",\n        },\n        cache: \"no-cache\",\n        body: JSON.stringify(constructLicenseRequest(unlockResult)),\n      },\n    );\n\n    const serverPermission = (await response.json()) as LicenseStatusResponse;\n    return serverPermission;\n  } catch (error) {\n    console.error(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 * @param mb - number of megabytes\n * @returns 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\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 */\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\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\nexport type PartialBlinkIdSessionSettings = OverrideProperties<\n  Partial<BlinkIdSessionSettings>,\n  {\n    scanningSettings?: PartialScanningSettings;\n  }\n>;\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\nexport const normalizeDocumentRule = (\n  rule: Partial<DocumentRules>,\n): DocumentRules => {\n  return {\n    documentFilter: normalizeDocumentFilter(rule.documentFilter),\n    fields: rule.fields ?? [],\n  };\n};\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\n * 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} from \"@microblink/blinkid-wasm\";\n\n// this is a workaround for the fact that the types are not exported\n// eslint-disable-next-line @typescript-eslint/no-empty-interface\ninterface _BlinkIdScanningResult extends BlinkIdScanningResult {}\n// eslint-disable-next-line @typescript-eslint/no-empty-interface\ninterface _BlinkIdSessionError extends BlinkIdSessionError {}\n\nexport type ProcessResultWithBuffer = BlinkIdProcessResult & {\n  arrayBuffer: ArrayBuffer;\n};\n\nexport type WorkerScanningSession = OverrideProperties<\n  BlinkIdScanningSession,\n  {\n    process: (image: ImageData) => ProcessResultWithBuffer;\n  }\n> & {\n  getSettings: () => BlinkIdSessionSettings;\n  showDemoOverlay: () => boolean;\n  showProductionOverlay: () => boolean;\n};\n\nexport type BlinkIdWorkerInitSettings = {\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  licenseKey: string;\n  resourcesLocation?: string;\n  userId: string;\n  wasmVariant?: WasmVariant;\n  /**\n   * The initial memory allocation for the Wasm module, in megabytes.\n   */\n  initialMemory?: number;\n  useLightweightBuild: boolean;\n};\n\nexport type LoadWasmParams = {\n  resourceUrl: string;\n  variant?: WasmVariant;\n  useLightweightBuild: boolean;\n  initialMemory?: number;\n};\n\nexport type ProgressStatusCallback = (progress: DownloadProgress) => void;\n\nclass BlinkIdWorker {\n  // core objects\n  #wasmModule?: BlinkIdWasmModule;\n  // must be initialized when calling initBlinkId\n  #defaultSessionSettings!: BlinkIdSessionSettings;\n  progressStatusCallback?: ProgressStatusCallback;\n  #showDemoOverlay = true;\n  #showProductionOverlay = true;\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 pThreadWorkerUrl = buildResourcePath(\n      variantUrl,\n      `${MODULE_NAME}.worker.mjs`,\n    );\n\n    const wasmUrl = buildResourcePath(variantUrl, `${MODULE_NAME}.wasm`);\n    const dataUrl = buildResourcePath(variantUrl, `${MODULE_NAME}.data`);\n\n    const crossOriginWorkerUrl = await getCrossOriginWorkerURL(workerUrl);\n    const crossOriginPThreadWorkerUrl =\n      await getCrossOriginWorkerURL(pThreadWorkerUrl);\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        let filePath: string;\n\n        // Since `locateFile` is synchronous, we can't use\n        // `getCrossOriginWorkerURL` here. Instead, we make an exception for the\n        // pthread worker, as we know its name in advance\n        if (path.includes(\".worker.mjs\")) {\n          filePath = crossOriginPThreadWorkerUrl;\n        } else {\n          filePath = `${variantUrl}/${wasmVariant}/${path}`;\n        }\n        return filePath;\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    // check if we need to obtain a server permission\n    if (licenceUnlockResult.unlockResult === \"requires-server-permission\") {\n      const serverPermissionResponse =\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  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  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  ping() {\n    return 1;\n  }\n}\n\nconst blinkIdWorker = new BlinkIdWorker();\n\nexpose(blinkIdWorker);\n\nexport type BlinkIdWorkerProxy = Omit<BlinkIdWorker, typeof finalizer>;\n"],"names":["type","obj","returnValue","proxy","e","props","symbols"],"mappings":"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","x_google_ignoreList":[0,1,9,10,11,12]}