browserclaw 0.5.5 → 0.5.6

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
package/dist/index.cjs CHANGED
@@ -10,35 +10,826 @@ var promises = require('dns/promises');
10
10
  var dns = require('dns');
11
11
  var promises$1 = require('fs/promises');
12
12
  var crypto = require('crypto');
13
- var ipaddr = require('ipaddr.js');
14
13
 
15
14
  function _interopDefault (e) { return e && e.__esModule ? e : { default: e }; }
16
15
 
17
- function _interopNamespace(e) {
18
- if (e && e.__esModule) return e;
19
- var n = Object.create(null);
20
- if (e) {
21
- Object.keys(e).forEach(function (k) {
22
- if (k !== 'default') {
23
- var d = Object.getOwnPropertyDescriptor(e, k);
24
- Object.defineProperty(n, k, d.get ? d : {
25
- enumerable: true,
26
- get: function () { return e[k]; }
27
- });
28
- }
29
- });
30
- }
31
- n.default = e;
32
- return Object.freeze(n);
33
- }
34
-
35
16
  var os__default = /*#__PURE__*/_interopDefault(os);
36
17
  var path__default = /*#__PURE__*/_interopDefault(path);
37
18
  var fs__default = /*#__PURE__*/_interopDefault(fs);
38
19
  var net__default = /*#__PURE__*/_interopDefault(net);
39
- var ipaddr__namespace = /*#__PURE__*/_interopNamespace(ipaddr);
40
20
 
41
- // src/chrome-launcher.ts
21
+ var __create = Object.create;
22
+ var __defProp = Object.defineProperty;
23
+ var __getOwnPropDesc = Object.getOwnPropertyDescriptor;
24
+ var __getOwnPropNames = Object.getOwnPropertyNames;
25
+ var __getProtoOf = Object.getPrototypeOf;
26
+ var __hasOwnProp = Object.prototype.hasOwnProperty;
27
+ var __commonJS = (cb, mod) => function __require() {
28
+ return mod || (0, cb[__getOwnPropNames(cb)[0]])((mod = { exports: {} }).exports, mod), mod.exports;
29
+ };
30
+ var __copyProps = (to, from, except, desc) => {
31
+ if (from && typeof from === "object" || typeof from === "function") {
32
+ for (let key of __getOwnPropNames(from))
33
+ if (!__hasOwnProp.call(to, key) && key !== except)
34
+ __defProp(to, key, { get: () => from[key], enumerable: !(desc = __getOwnPropDesc(from, key)) || desc.enumerable });
35
+ }
36
+ return to;
37
+ };
38
+ var __toESM = (mod, isNodeMode, target) => (target = mod != null ? __create(__getProtoOf(mod)) : {}, __copyProps(
39
+ // If the importer is in node compatibility mode or this is not an ESM
40
+ // file that has been converted to a CommonJS file using a Babel-
41
+ // compatible transform (i.e. "__esModule" has not been set), then set
42
+ // "default" to the CommonJS "module.exports" for node compatibility.
43
+ __defProp(target, "default", { value: mod, enumerable: true }) ,
44
+ mod
45
+ ));
46
+
47
+ // node_modules/ipaddr.js/lib/ipaddr.js
48
+ var require_ipaddr = __commonJS({
49
+ "node_modules/ipaddr.js/lib/ipaddr.js"(exports$1, module) {
50
+ (function(root) {
51
+ const ipv4Part = "(0?\\d+|0x[a-f0-9]+)";
52
+ const ipv4Regexes = {
53
+ fourOctet: new RegExp(`^${ipv4Part}\\.${ipv4Part}\\.${ipv4Part}\\.${ipv4Part}$`, "i"),
54
+ threeOctet: new RegExp(`^${ipv4Part}\\.${ipv4Part}\\.${ipv4Part}$`, "i"),
55
+ twoOctet: new RegExp(`^${ipv4Part}\\.${ipv4Part}$`, "i"),
56
+ longValue: new RegExp(`^${ipv4Part}$`, "i")
57
+ };
58
+ const octalRegex = new RegExp(`^0[0-7]+$`, "i");
59
+ const hexRegex = new RegExp(`^0x[a-f0-9]+$`, "i");
60
+ const zoneIndex = "%[0-9a-z]{1,}";
61
+ const ipv6Part = "(?:[0-9a-f]+::?)+";
62
+ const ipv6Regexes = {
63
+ zoneIndex: new RegExp(zoneIndex, "i"),
64
+ "native": new RegExp(`^(::)?(${ipv6Part})?([0-9a-f]+)?(::)?(${zoneIndex})?$`, "i"),
65
+ deprecatedTransitional: new RegExp(`^(?:::)(${ipv4Part}\\.${ipv4Part}\\.${ipv4Part}\\.${ipv4Part}(${zoneIndex})?)$`, "i"),
66
+ transitional: new RegExp(`^((?:${ipv6Part})|(?:::)(?:${ipv6Part})?)${ipv4Part}\\.${ipv4Part}\\.${ipv4Part}\\.${ipv4Part}(${zoneIndex})?$`, "i")
67
+ };
68
+ function expandIPv6(string, parts) {
69
+ if (string.indexOf("::") !== string.lastIndexOf("::")) {
70
+ return null;
71
+ }
72
+ let colonCount = 0;
73
+ let lastColon = -1;
74
+ let zoneId = (string.match(ipv6Regexes.zoneIndex) || [])[0];
75
+ let replacement, replacementCount;
76
+ if (zoneId) {
77
+ zoneId = zoneId.substring(1);
78
+ string = string.replace(/%.+$/, "");
79
+ }
80
+ while ((lastColon = string.indexOf(":", lastColon + 1)) >= 0) {
81
+ colonCount++;
82
+ }
83
+ if (string.substr(0, 2) === "::") {
84
+ colonCount--;
85
+ }
86
+ if (string.substr(-2, 2) === "::") {
87
+ colonCount--;
88
+ }
89
+ if (colonCount > parts) {
90
+ return null;
91
+ }
92
+ replacementCount = parts - colonCount;
93
+ replacement = ":";
94
+ while (replacementCount--) {
95
+ replacement += "0:";
96
+ }
97
+ string = string.replace("::", replacement);
98
+ if (string[0] === ":") {
99
+ string = string.slice(1);
100
+ }
101
+ if (string[string.length - 1] === ":") {
102
+ string = string.slice(0, -1);
103
+ }
104
+ parts = (function() {
105
+ const ref = string.split(":");
106
+ const results = [];
107
+ for (let i = 0; i < ref.length; i++) {
108
+ results.push(parseInt(ref[i], 16));
109
+ }
110
+ return results;
111
+ })();
112
+ return {
113
+ parts,
114
+ zoneId
115
+ };
116
+ }
117
+ function matchCIDR(first, second, partSize, cidrBits) {
118
+ if (first.length !== second.length) {
119
+ throw new Error("ipaddr: cannot match CIDR for objects with different lengths");
120
+ }
121
+ let part = 0;
122
+ let shift;
123
+ while (cidrBits > 0) {
124
+ shift = partSize - cidrBits;
125
+ if (shift < 0) {
126
+ shift = 0;
127
+ }
128
+ if (first[part] >> shift !== second[part] >> shift) {
129
+ return false;
130
+ }
131
+ cidrBits -= partSize;
132
+ part += 1;
133
+ }
134
+ return true;
135
+ }
136
+ function parseIntAuto(string) {
137
+ if (hexRegex.test(string)) {
138
+ return parseInt(string, 16);
139
+ }
140
+ if (string[0] === "0" && !isNaN(parseInt(string[1], 10))) {
141
+ if (octalRegex.test(string)) {
142
+ return parseInt(string, 8);
143
+ }
144
+ throw new Error(`ipaddr: cannot parse ${string} as octal`);
145
+ }
146
+ return parseInt(string, 10);
147
+ }
148
+ function padPart(part, length) {
149
+ while (part.length < length) {
150
+ part = `0${part}`;
151
+ }
152
+ return part;
153
+ }
154
+ const ipaddr2 = {};
155
+ ipaddr2.IPv4 = (function() {
156
+ function IPv42(octets) {
157
+ if (octets.length !== 4) {
158
+ throw new Error("ipaddr: ipv4 octet count should be 4");
159
+ }
160
+ let i, octet;
161
+ for (i = 0; i < octets.length; i++) {
162
+ octet = octets[i];
163
+ if (!(0 <= octet && octet <= 255)) {
164
+ throw new Error("ipaddr: ipv4 octet should fit in 8 bits");
165
+ }
166
+ }
167
+ this.octets = octets;
168
+ }
169
+ IPv42.prototype.SpecialRanges = {
170
+ unspecified: [[new IPv42([0, 0, 0, 0]), 8]],
171
+ broadcast: [[new IPv42([255, 255, 255, 255]), 32]],
172
+ // RFC3171
173
+ multicast: [[new IPv42([224, 0, 0, 0]), 4]],
174
+ // RFC3927
175
+ linkLocal: [[new IPv42([169, 254, 0, 0]), 16]],
176
+ // RFC5735
177
+ loopback: [[new IPv42([127, 0, 0, 0]), 8]],
178
+ // RFC6598
179
+ carrierGradeNat: [[new IPv42([100, 64, 0, 0]), 10]],
180
+ // RFC1918
181
+ "private": [
182
+ [new IPv42([10, 0, 0, 0]), 8],
183
+ [new IPv42([172, 16, 0, 0]), 12],
184
+ [new IPv42([192, 168, 0, 0]), 16]
185
+ ],
186
+ // Reserved and testing-only ranges; RFCs 5735, 5737, 2544, 1700
187
+ reserved: [
188
+ [new IPv42([192, 0, 0, 0]), 24],
189
+ [new IPv42([192, 0, 2, 0]), 24],
190
+ [new IPv42([192, 88, 99, 0]), 24],
191
+ [new IPv42([198, 18, 0, 0]), 15],
192
+ [new IPv42([198, 51, 100, 0]), 24],
193
+ [new IPv42([203, 0, 113, 0]), 24],
194
+ [new IPv42([240, 0, 0, 0]), 4]
195
+ ],
196
+ // RFC7534, RFC7535
197
+ as112: [
198
+ [new IPv42([192, 175, 48, 0]), 24],
199
+ [new IPv42([192, 31, 196, 0]), 24]
200
+ ],
201
+ // RFC7450
202
+ amt: [
203
+ [new IPv42([192, 52, 193, 0]), 24]
204
+ ]
205
+ };
206
+ IPv42.prototype.kind = function() {
207
+ return "ipv4";
208
+ };
209
+ IPv42.prototype.match = function(other, cidrRange) {
210
+ let ref;
211
+ if (cidrRange === void 0) {
212
+ ref = other;
213
+ other = ref[0];
214
+ cidrRange = ref[1];
215
+ }
216
+ if (other.kind() !== "ipv4") {
217
+ throw new Error("ipaddr: cannot match ipv4 address with non-ipv4 one");
218
+ }
219
+ return matchCIDR(this.octets, other.octets, 8, cidrRange);
220
+ };
221
+ IPv42.prototype.prefixLengthFromSubnetMask = function() {
222
+ let cidr = 0;
223
+ let stop = false;
224
+ const zerotable = {
225
+ 0: 8,
226
+ 128: 7,
227
+ 192: 6,
228
+ 224: 5,
229
+ 240: 4,
230
+ 248: 3,
231
+ 252: 2,
232
+ 254: 1,
233
+ 255: 0
234
+ };
235
+ let i, octet, zeros;
236
+ for (i = 3; i >= 0; i -= 1) {
237
+ octet = this.octets[i];
238
+ if (octet in zerotable) {
239
+ zeros = zerotable[octet];
240
+ if (stop && zeros !== 0) {
241
+ return null;
242
+ }
243
+ if (zeros !== 8) {
244
+ stop = true;
245
+ }
246
+ cidr += zeros;
247
+ } else {
248
+ return null;
249
+ }
250
+ }
251
+ return 32 - cidr;
252
+ };
253
+ IPv42.prototype.range = function() {
254
+ return ipaddr2.subnetMatch(this, this.SpecialRanges);
255
+ };
256
+ IPv42.prototype.toByteArray = function() {
257
+ return this.octets.slice(0);
258
+ };
259
+ IPv42.prototype.toIPv4MappedAddress = function() {
260
+ return ipaddr2.IPv6.parse(`::ffff:${this.toString()}`);
261
+ };
262
+ IPv42.prototype.toNormalizedString = function() {
263
+ return this.toString();
264
+ };
265
+ IPv42.prototype.toString = function() {
266
+ return this.octets.join(".");
267
+ };
268
+ return IPv42;
269
+ })();
270
+ ipaddr2.IPv4.broadcastAddressFromCIDR = function(string) {
271
+ try {
272
+ const cidr = this.parseCIDR(string);
273
+ const ipInterfaceOctets = cidr[0].toByteArray();
274
+ const subnetMaskOctets = this.subnetMaskFromPrefixLength(cidr[1]).toByteArray();
275
+ const octets = [];
276
+ let i = 0;
277
+ while (i < 4) {
278
+ octets.push(parseInt(ipInterfaceOctets[i], 10) | parseInt(subnetMaskOctets[i], 10) ^ 255);
279
+ i++;
280
+ }
281
+ return new this(octets);
282
+ } catch (e) {
283
+ throw new Error("ipaddr: the address does not have IPv4 CIDR format");
284
+ }
285
+ };
286
+ ipaddr2.IPv4.isIPv4 = function(string) {
287
+ return this.parser(string) !== null;
288
+ };
289
+ ipaddr2.IPv4.isValid = function(string) {
290
+ try {
291
+ new this(this.parser(string));
292
+ return true;
293
+ } catch (e) {
294
+ return false;
295
+ }
296
+ };
297
+ ipaddr2.IPv4.isValidCIDR = function(string) {
298
+ try {
299
+ this.parseCIDR(string);
300
+ return true;
301
+ } catch (e) {
302
+ return false;
303
+ }
304
+ };
305
+ ipaddr2.IPv4.isValidFourPartDecimal = function(string) {
306
+ if (ipaddr2.IPv4.isValid(string) && string.match(/^(0|[1-9]\d*)(\.(0|[1-9]\d*)){3}$/)) {
307
+ return true;
308
+ } else {
309
+ return false;
310
+ }
311
+ };
312
+ ipaddr2.IPv4.isValidCIDRFourPartDecimal = function(string) {
313
+ const match = string.match(/^(.+)\/(\d+)$/);
314
+ if (!ipaddr2.IPv4.isValidCIDR(string) || !match) {
315
+ return false;
316
+ }
317
+ return ipaddr2.IPv4.isValidFourPartDecimal(match[1]);
318
+ };
319
+ ipaddr2.IPv4.networkAddressFromCIDR = function(string) {
320
+ let cidr, i, ipInterfaceOctets, octets, subnetMaskOctets;
321
+ try {
322
+ cidr = this.parseCIDR(string);
323
+ ipInterfaceOctets = cidr[0].toByteArray();
324
+ subnetMaskOctets = this.subnetMaskFromPrefixLength(cidr[1]).toByteArray();
325
+ octets = [];
326
+ i = 0;
327
+ while (i < 4) {
328
+ octets.push(parseInt(ipInterfaceOctets[i], 10) & parseInt(subnetMaskOctets[i], 10));
329
+ i++;
330
+ }
331
+ return new this(octets);
332
+ } catch (e) {
333
+ throw new Error("ipaddr: the address does not have IPv4 CIDR format");
334
+ }
335
+ };
336
+ ipaddr2.IPv4.parse = function(string) {
337
+ const parts = this.parser(string);
338
+ if (parts === null) {
339
+ throw new Error("ipaddr: string is not formatted like an IPv4 Address");
340
+ }
341
+ return new this(parts);
342
+ };
343
+ ipaddr2.IPv4.parseCIDR = function(string) {
344
+ let match;
345
+ if (match = string.match(/^(.+)\/(\d+)$/)) {
346
+ const maskLength = parseInt(match[2]);
347
+ if (maskLength >= 0 && maskLength <= 32) {
348
+ const parsed = [this.parse(match[1]), maskLength];
349
+ Object.defineProperty(parsed, "toString", {
350
+ value: function() {
351
+ return this.join("/");
352
+ }
353
+ });
354
+ return parsed;
355
+ }
356
+ }
357
+ throw new Error("ipaddr: string is not formatted like an IPv4 CIDR range");
358
+ };
359
+ ipaddr2.IPv4.parser = function(string) {
360
+ let match, part, value;
361
+ if (match = string.match(ipv4Regexes.fourOctet)) {
362
+ return (function() {
363
+ const ref = match.slice(1, 6);
364
+ const results = [];
365
+ for (let i = 0; i < ref.length; i++) {
366
+ part = ref[i];
367
+ results.push(parseIntAuto(part));
368
+ }
369
+ return results;
370
+ })();
371
+ } else if (match = string.match(ipv4Regexes.longValue)) {
372
+ value = parseIntAuto(match[1]);
373
+ if (value > 4294967295 || value < 0) {
374
+ throw new Error("ipaddr: address outside defined range");
375
+ }
376
+ return (function() {
377
+ const results = [];
378
+ let shift;
379
+ for (shift = 0; shift <= 24; shift += 8) {
380
+ results.push(value >> shift & 255);
381
+ }
382
+ return results;
383
+ })().reverse();
384
+ } else if (match = string.match(ipv4Regexes.twoOctet)) {
385
+ return (function() {
386
+ const ref = match.slice(1, 4);
387
+ const results = [];
388
+ value = parseIntAuto(ref[1]);
389
+ if (value > 16777215 || value < 0) {
390
+ throw new Error("ipaddr: address outside defined range");
391
+ }
392
+ results.push(parseIntAuto(ref[0]));
393
+ results.push(value >> 16 & 255);
394
+ results.push(value >> 8 & 255);
395
+ results.push(value & 255);
396
+ return results;
397
+ })();
398
+ } else if (match = string.match(ipv4Regexes.threeOctet)) {
399
+ return (function() {
400
+ const ref = match.slice(1, 5);
401
+ const results = [];
402
+ value = parseIntAuto(ref[2]);
403
+ if (value > 65535 || value < 0) {
404
+ throw new Error("ipaddr: address outside defined range");
405
+ }
406
+ results.push(parseIntAuto(ref[0]));
407
+ results.push(parseIntAuto(ref[1]));
408
+ results.push(value >> 8 & 255);
409
+ results.push(value & 255);
410
+ return results;
411
+ })();
412
+ } else {
413
+ return null;
414
+ }
415
+ };
416
+ ipaddr2.IPv4.subnetMaskFromPrefixLength = function(prefix) {
417
+ prefix = parseInt(prefix);
418
+ if (prefix < 0 || prefix > 32) {
419
+ throw new Error("ipaddr: invalid IPv4 prefix length");
420
+ }
421
+ const octets = [0, 0, 0, 0];
422
+ let j = 0;
423
+ const filledOctetCount = Math.floor(prefix / 8);
424
+ while (j < filledOctetCount) {
425
+ octets[j] = 255;
426
+ j++;
427
+ }
428
+ if (filledOctetCount < 4) {
429
+ octets[filledOctetCount] = Math.pow(2, prefix % 8) - 1 << 8 - prefix % 8;
430
+ }
431
+ return new this(octets);
432
+ };
433
+ ipaddr2.IPv6 = (function() {
434
+ function IPv62(parts, zoneId) {
435
+ let i, part;
436
+ if (parts.length === 16) {
437
+ this.parts = [];
438
+ for (i = 0; i <= 14; i += 2) {
439
+ this.parts.push(parts[i] << 8 | parts[i + 1]);
440
+ }
441
+ } else if (parts.length === 8) {
442
+ this.parts = parts;
443
+ } else {
444
+ throw new Error("ipaddr: ipv6 part count should be 8 or 16");
445
+ }
446
+ for (i = 0; i < this.parts.length; i++) {
447
+ part = this.parts[i];
448
+ if (!(0 <= part && part <= 65535)) {
449
+ throw new Error("ipaddr: ipv6 part should fit in 16 bits");
450
+ }
451
+ }
452
+ if (zoneId) {
453
+ this.zoneId = zoneId;
454
+ }
455
+ }
456
+ IPv62.prototype.SpecialRanges = {
457
+ // RFC4291, here and after
458
+ unspecified: [new IPv62([0, 0, 0, 0, 0, 0, 0, 0]), 128],
459
+ linkLocal: [new IPv62([65152, 0, 0, 0, 0, 0, 0, 0]), 10],
460
+ multicast: [new IPv62([65280, 0, 0, 0, 0, 0, 0, 0]), 8],
461
+ loopback: [new IPv62([0, 0, 0, 0, 0, 0, 0, 1]), 128],
462
+ uniqueLocal: [new IPv62([64512, 0, 0, 0, 0, 0, 0, 0]), 7],
463
+ ipv4Mapped: [new IPv62([0, 0, 0, 0, 0, 65535, 0, 0]), 96],
464
+ // RFC6666
465
+ discard: [new IPv62([256, 0, 0, 0, 0, 0, 0, 0]), 64],
466
+ // RFC6145
467
+ rfc6145: [new IPv62([0, 0, 0, 0, 65535, 0, 0, 0]), 96],
468
+ // RFC6052
469
+ rfc6052: [new IPv62([100, 65435, 0, 0, 0, 0, 0, 0]), 96],
470
+ // RFC3056
471
+ "6to4": [new IPv62([8194, 0, 0, 0, 0, 0, 0, 0]), 16],
472
+ // RFC6052, RFC6146
473
+ teredo: [new IPv62([8193, 0, 0, 0, 0, 0, 0, 0]), 32],
474
+ // RFC5180
475
+ benchmarking: [new IPv62([8193, 2, 0, 0, 0, 0, 0, 0]), 48],
476
+ // RFC7450
477
+ amt: [new IPv62([8193, 3, 0, 0, 0, 0, 0, 0]), 32],
478
+ as112v6: [
479
+ [new IPv62([8193, 4, 274, 0, 0, 0, 0, 0]), 48],
480
+ [new IPv62([9760, 79, 32768, 0, 0, 0, 0, 0]), 48]
481
+ ],
482
+ deprecated: [new IPv62([8193, 16, 0, 0, 0, 0, 0, 0]), 28],
483
+ orchid2: [new IPv62([8193, 32, 0, 0, 0, 0, 0, 0]), 28],
484
+ droneRemoteIdProtocolEntityTags: [new IPv62([8193, 48, 0, 0, 0, 0, 0, 0]), 28],
485
+ reserved: [
486
+ // RFC3849
487
+ [new IPv62([8193, 0, 0, 0, 0, 0, 0, 0]), 23],
488
+ // RFC2928
489
+ [new IPv62([8193, 3512, 0, 0, 0, 0, 0, 0]), 32]
490
+ ]
491
+ };
492
+ IPv62.prototype.isIPv4MappedAddress = function() {
493
+ return this.range() === "ipv4Mapped";
494
+ };
495
+ IPv62.prototype.kind = function() {
496
+ return "ipv6";
497
+ };
498
+ IPv62.prototype.match = function(other, cidrRange) {
499
+ let ref;
500
+ if (cidrRange === void 0) {
501
+ ref = other;
502
+ other = ref[0];
503
+ cidrRange = ref[1];
504
+ }
505
+ if (other.kind() !== "ipv6") {
506
+ throw new Error("ipaddr: cannot match ipv6 address with non-ipv6 one");
507
+ }
508
+ return matchCIDR(this.parts, other.parts, 16, cidrRange);
509
+ };
510
+ IPv62.prototype.prefixLengthFromSubnetMask = function() {
511
+ let cidr = 0;
512
+ let stop = false;
513
+ const zerotable = {
514
+ 0: 16,
515
+ 32768: 15,
516
+ 49152: 14,
517
+ 57344: 13,
518
+ 61440: 12,
519
+ 63488: 11,
520
+ 64512: 10,
521
+ 65024: 9,
522
+ 65280: 8,
523
+ 65408: 7,
524
+ 65472: 6,
525
+ 65504: 5,
526
+ 65520: 4,
527
+ 65528: 3,
528
+ 65532: 2,
529
+ 65534: 1,
530
+ 65535: 0
531
+ };
532
+ let part, zeros;
533
+ for (let i = 7; i >= 0; i -= 1) {
534
+ part = this.parts[i];
535
+ if (part in zerotable) {
536
+ zeros = zerotable[part];
537
+ if (stop && zeros !== 0) {
538
+ return null;
539
+ }
540
+ if (zeros !== 16) {
541
+ stop = true;
542
+ }
543
+ cidr += zeros;
544
+ } else {
545
+ return null;
546
+ }
547
+ }
548
+ return 128 - cidr;
549
+ };
550
+ IPv62.prototype.range = function() {
551
+ return ipaddr2.subnetMatch(this, this.SpecialRanges);
552
+ };
553
+ IPv62.prototype.toByteArray = function() {
554
+ let part;
555
+ const bytes = [];
556
+ const ref = this.parts;
557
+ for (let i = 0; i < ref.length; i++) {
558
+ part = ref[i];
559
+ bytes.push(part >> 8);
560
+ bytes.push(part & 255);
561
+ }
562
+ return bytes;
563
+ };
564
+ IPv62.prototype.toFixedLengthString = function() {
565
+ const addr = (function() {
566
+ const results = [];
567
+ for (let i = 0; i < this.parts.length; i++) {
568
+ results.push(padPart(this.parts[i].toString(16), 4));
569
+ }
570
+ return results;
571
+ }).call(this).join(":");
572
+ let suffix = "";
573
+ if (this.zoneId) {
574
+ suffix = `%${this.zoneId}`;
575
+ }
576
+ return addr + suffix;
577
+ };
578
+ IPv62.prototype.toIPv4Address = function() {
579
+ if (!this.isIPv4MappedAddress()) {
580
+ throw new Error("ipaddr: trying to convert a generic ipv6 address to ipv4");
581
+ }
582
+ const ref = this.parts.slice(-2);
583
+ const high = ref[0];
584
+ const low = ref[1];
585
+ return new ipaddr2.IPv4([high >> 8, high & 255, low >> 8, low & 255]);
586
+ };
587
+ IPv62.prototype.toNormalizedString = function() {
588
+ const addr = (function() {
589
+ const results = [];
590
+ for (let i = 0; i < this.parts.length; i++) {
591
+ results.push(this.parts[i].toString(16));
592
+ }
593
+ return results;
594
+ }).call(this).join(":");
595
+ let suffix = "";
596
+ if (this.zoneId) {
597
+ suffix = `%${this.zoneId}`;
598
+ }
599
+ return addr + suffix;
600
+ };
601
+ IPv62.prototype.toRFC5952String = function() {
602
+ const regex = /((^|:)(0(:|$)){2,})/g;
603
+ const string = this.toNormalizedString();
604
+ let bestMatchIndex = 0;
605
+ let bestMatchLength = -1;
606
+ let match;
607
+ while (match = regex.exec(string)) {
608
+ if (match[0].length > bestMatchLength) {
609
+ bestMatchIndex = match.index;
610
+ bestMatchLength = match[0].length;
611
+ }
612
+ }
613
+ if (bestMatchLength < 0) {
614
+ return string;
615
+ }
616
+ return `${string.substring(0, bestMatchIndex)}::${string.substring(bestMatchIndex + bestMatchLength)}`;
617
+ };
618
+ IPv62.prototype.toString = function() {
619
+ return this.toRFC5952String();
620
+ };
621
+ return IPv62;
622
+ })();
623
+ ipaddr2.IPv6.broadcastAddressFromCIDR = function(string) {
624
+ try {
625
+ const cidr = this.parseCIDR(string);
626
+ const ipInterfaceOctets = cidr[0].toByteArray();
627
+ const subnetMaskOctets = this.subnetMaskFromPrefixLength(cidr[1]).toByteArray();
628
+ const octets = [];
629
+ let i = 0;
630
+ while (i < 16) {
631
+ octets.push(parseInt(ipInterfaceOctets[i], 10) | parseInt(subnetMaskOctets[i], 10) ^ 255);
632
+ i++;
633
+ }
634
+ return new this(octets);
635
+ } catch (e) {
636
+ throw new Error(`ipaddr: the address does not have IPv6 CIDR format (${e})`);
637
+ }
638
+ };
639
+ ipaddr2.IPv6.isIPv6 = function(string) {
640
+ return this.parser(string) !== null;
641
+ };
642
+ ipaddr2.IPv6.isValid = function(string) {
643
+ if (typeof string === "string" && string.indexOf(":") === -1) {
644
+ return false;
645
+ }
646
+ try {
647
+ const addr = this.parser(string);
648
+ new this(addr.parts, addr.zoneId);
649
+ return true;
650
+ } catch (e) {
651
+ return false;
652
+ }
653
+ };
654
+ ipaddr2.IPv6.isValidCIDR = function(string) {
655
+ if (typeof string === "string" && string.indexOf(":") === -1) {
656
+ return false;
657
+ }
658
+ try {
659
+ this.parseCIDR(string);
660
+ return true;
661
+ } catch (e) {
662
+ return false;
663
+ }
664
+ };
665
+ ipaddr2.IPv6.networkAddressFromCIDR = function(string) {
666
+ let cidr, i, ipInterfaceOctets, octets, subnetMaskOctets;
667
+ try {
668
+ cidr = this.parseCIDR(string);
669
+ ipInterfaceOctets = cidr[0].toByteArray();
670
+ subnetMaskOctets = this.subnetMaskFromPrefixLength(cidr[1]).toByteArray();
671
+ octets = [];
672
+ i = 0;
673
+ while (i < 16) {
674
+ octets.push(parseInt(ipInterfaceOctets[i], 10) & parseInt(subnetMaskOctets[i], 10));
675
+ i++;
676
+ }
677
+ return new this(octets);
678
+ } catch (e) {
679
+ throw new Error(`ipaddr: the address does not have IPv6 CIDR format (${e})`);
680
+ }
681
+ };
682
+ ipaddr2.IPv6.parse = function(string) {
683
+ const addr = this.parser(string);
684
+ if (addr.parts === null) {
685
+ throw new Error("ipaddr: string is not formatted like an IPv6 Address");
686
+ }
687
+ return new this(addr.parts, addr.zoneId);
688
+ };
689
+ ipaddr2.IPv6.parseCIDR = function(string) {
690
+ let maskLength, match, parsed;
691
+ if (match = string.match(/^(.+)\/(\d+)$/)) {
692
+ maskLength = parseInt(match[2]);
693
+ if (maskLength >= 0 && maskLength <= 128) {
694
+ parsed = [this.parse(match[1]), maskLength];
695
+ Object.defineProperty(parsed, "toString", {
696
+ value: function() {
697
+ return this.join("/");
698
+ }
699
+ });
700
+ return parsed;
701
+ }
702
+ }
703
+ throw new Error("ipaddr: string is not formatted like an IPv6 CIDR range");
704
+ };
705
+ ipaddr2.IPv6.parser = function(string) {
706
+ let addr, i, match, octet, octets, zoneId;
707
+ if (match = string.match(ipv6Regexes.deprecatedTransitional)) {
708
+ return this.parser(`::ffff:${match[1]}`);
709
+ }
710
+ if (ipv6Regexes.native.test(string)) {
711
+ return expandIPv6(string, 8);
712
+ }
713
+ if (match = string.match(ipv6Regexes.transitional)) {
714
+ zoneId = match[6] || "";
715
+ addr = match[1];
716
+ if (!match[1].endsWith("::")) {
717
+ addr = addr.slice(0, -1);
718
+ }
719
+ addr = expandIPv6(addr + zoneId, 6);
720
+ if (addr.parts) {
721
+ octets = [
722
+ parseInt(match[2]),
723
+ parseInt(match[3]),
724
+ parseInt(match[4]),
725
+ parseInt(match[5])
726
+ ];
727
+ for (i = 0; i < octets.length; i++) {
728
+ octet = octets[i];
729
+ if (!(0 <= octet && octet <= 255)) {
730
+ return null;
731
+ }
732
+ }
733
+ addr.parts.push(octets[0] << 8 | octets[1]);
734
+ addr.parts.push(octets[2] << 8 | octets[3]);
735
+ return {
736
+ parts: addr.parts,
737
+ zoneId: addr.zoneId
738
+ };
739
+ }
740
+ }
741
+ return null;
742
+ };
743
+ ipaddr2.IPv6.subnetMaskFromPrefixLength = function(prefix) {
744
+ prefix = parseInt(prefix);
745
+ if (prefix < 0 || prefix > 128) {
746
+ throw new Error("ipaddr: invalid IPv6 prefix length");
747
+ }
748
+ const octets = [0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0];
749
+ let j = 0;
750
+ const filledOctetCount = Math.floor(prefix / 8);
751
+ while (j < filledOctetCount) {
752
+ octets[j] = 255;
753
+ j++;
754
+ }
755
+ if (filledOctetCount < 16) {
756
+ octets[filledOctetCount] = Math.pow(2, prefix % 8) - 1 << 8 - prefix % 8;
757
+ }
758
+ return new this(octets);
759
+ };
760
+ ipaddr2.fromByteArray = function(bytes) {
761
+ const length = bytes.length;
762
+ if (length === 4) {
763
+ return new ipaddr2.IPv4(bytes);
764
+ } else if (length === 16) {
765
+ return new ipaddr2.IPv6(bytes);
766
+ } else {
767
+ throw new Error("ipaddr: the binary input is neither an IPv6 nor IPv4 address");
768
+ }
769
+ };
770
+ ipaddr2.isValid = function(string) {
771
+ return ipaddr2.IPv6.isValid(string) || ipaddr2.IPv4.isValid(string);
772
+ };
773
+ ipaddr2.isValidCIDR = function(string) {
774
+ return ipaddr2.IPv6.isValidCIDR(string) || ipaddr2.IPv4.isValidCIDR(string);
775
+ };
776
+ ipaddr2.parse = function(string) {
777
+ if (ipaddr2.IPv6.isValid(string)) {
778
+ return ipaddr2.IPv6.parse(string);
779
+ } else if (ipaddr2.IPv4.isValid(string)) {
780
+ return ipaddr2.IPv4.parse(string);
781
+ } else {
782
+ throw new Error("ipaddr: the address has neither IPv6 nor IPv4 format");
783
+ }
784
+ };
785
+ ipaddr2.parseCIDR = function(string) {
786
+ try {
787
+ return ipaddr2.IPv6.parseCIDR(string);
788
+ } catch (e) {
789
+ try {
790
+ return ipaddr2.IPv4.parseCIDR(string);
791
+ } catch (e2) {
792
+ throw new Error("ipaddr: the address has neither IPv6 nor IPv4 CIDR format");
793
+ }
794
+ }
795
+ };
796
+ ipaddr2.process = function(string) {
797
+ const addr = this.parse(string);
798
+ if (addr.kind() === "ipv6" && addr.isIPv4MappedAddress()) {
799
+ return addr.toIPv4Address();
800
+ } else {
801
+ return addr;
802
+ }
803
+ };
804
+ ipaddr2.subnetMatch = function(address, rangeList, defaultName) {
805
+ let i, rangeName, rangeSubnets, subnet;
806
+ if (defaultName === void 0 || defaultName === null) {
807
+ defaultName = "unicast";
808
+ }
809
+ for (rangeName in rangeList) {
810
+ if (Object.prototype.hasOwnProperty.call(rangeList, rangeName)) {
811
+ rangeSubnets = rangeList[rangeName];
812
+ if (rangeSubnets[0] && !(rangeSubnets[0] instanceof Array)) {
813
+ rangeSubnets = [rangeSubnets];
814
+ }
815
+ for (i = 0; i < rangeSubnets.length; i++) {
816
+ subnet = rangeSubnets[i];
817
+ if (address.kind() === subnet[0].kind() && address.match.apply(address, subnet)) {
818
+ return rangeName;
819
+ }
820
+ }
821
+ }
822
+ }
823
+ return defaultName;
824
+ };
825
+ if (typeof module !== "undefined" && module.exports) {
826
+ module.exports = ipaddr2;
827
+ } else {
828
+ root.ipaddr = ipaddr2;
829
+ }
830
+ })(exports$1);
831
+ }
832
+ });
42
833
  var CHROMIUM_BUNDLE_IDS = /* @__PURE__ */ new Set([
43
834
  "com.google.Chrome",
44
835
  "com.google.Chrome.beta",
@@ -1503,6 +2294,9 @@ function formatAriaNodes(nodes, limit) {
1503
2294
  }
1504
2295
  return out;
1505
2296
  }
2297
+
2298
+ // src/security.ts
2299
+ var ipaddr = __toESM(require_ipaddr());
1506
2300
  var InvalidBrowserNavigationUrlError = class extends Error {
1507
2301
  constructor(message) {
1508
2302
  super(message);
@@ -1560,7 +2354,7 @@ var BLOCKED_IPV6_RANGES = /* @__PURE__ */ new Set([
1560
2354
  "uniqueLocal",
1561
2355
  "multicast"
1562
2356
  ]);
1563
- var RFC2544_BENCHMARK_PREFIX = [ipaddr__namespace.IPv4.parse("198.18.0.0"), 15];
2357
+ var RFC2544_BENCHMARK_PREFIX = [ipaddr.IPv4.parse("198.18.0.0"), 15];
1564
2358
  var EMBEDDED_IPV4_SENTINEL_RULES = [
1565
2359
  // IPv4-compatible (::a.b.c.d)
1566
2360
  {
@@ -1600,11 +2394,11 @@ function parseIpv6WithEmbeddedIpv4(raw) {
1600
2394
  const match = /^(.*:)([^:%]+(?:\.[^:%]+){3})(%[0-9A-Za-z]+)?$/i.exec(raw);
1601
2395
  if (!match) return;
1602
2396
  const [, prefix, embeddedIpv4, zoneSuffix = ""] = match;
1603
- if (!ipaddr__namespace.IPv4.isValidFourPartDecimal(embeddedIpv4)) return;
2397
+ if (!ipaddr.IPv4.isValidFourPartDecimal(embeddedIpv4)) return;
1604
2398
  const octets = embeddedIpv4.split(".").map((part) => Number.parseInt(part, 10));
1605
2399
  const normalizedIpv6 = `${prefix}${(octets[0] << 8 | octets[1]).toString(16)}:${(octets[2] << 8 | octets[3]).toString(16)}${zoneSuffix}`;
1606
- if (!ipaddr__namespace.IPv6.isValid(normalizedIpv6)) return;
1607
- return ipaddr__namespace.IPv6.parse(normalizedIpv6);
2400
+ if (!ipaddr.IPv6.isValid(normalizedIpv6)) return;
2401
+ return ipaddr.IPv6.parse(normalizedIpv6);
1608
2402
  }
1609
2403
  function normalizeIpParseInput(raw) {
1610
2404
  const trimmed = raw?.trim();
@@ -1614,17 +2408,17 @@ function normalizeIpParseInput(raw) {
1614
2408
  function parseCanonicalIpAddress(raw) {
1615
2409
  const normalized = normalizeIpParseInput(raw);
1616
2410
  if (!normalized) return;
1617
- if (ipaddr__namespace.IPv4.isValid(normalized)) {
1618
- if (!ipaddr__namespace.IPv4.isValidFourPartDecimal(normalized)) return;
1619
- return ipaddr__namespace.IPv4.parse(normalized);
2411
+ if (ipaddr.IPv4.isValid(normalized)) {
2412
+ if (!ipaddr.IPv4.isValidFourPartDecimal(normalized)) return;
2413
+ return ipaddr.IPv4.parse(normalized);
1620
2414
  }
1621
- if (ipaddr__namespace.IPv6.isValid(normalized)) return ipaddr__namespace.IPv6.parse(normalized);
2415
+ if (ipaddr.IPv6.isValid(normalized)) return ipaddr.IPv6.parse(normalized);
1622
2416
  return parseIpv6WithEmbeddedIpv4(normalized);
1623
2417
  }
1624
2418
  function parseLooseIpAddress(raw) {
1625
2419
  const normalized = normalizeIpParseInput(raw);
1626
2420
  if (!normalized) return;
1627
- if (ipaddr__namespace.isValid(normalized)) return ipaddr__namespace.parse(normalized);
2421
+ if (ipaddr.isValid(normalized)) return ipaddr.parse(normalized);
1628
2422
  return parseIpv6WithEmbeddedIpv4(normalized);
1629
2423
  }
1630
2424
  function isCanonicalDottedDecimalIPv4(raw) {
@@ -1632,7 +2426,7 @@ function isCanonicalDottedDecimalIPv4(raw) {
1632
2426
  if (!trimmed) return false;
1633
2427
  const normalized = stripIpv6Brackets(trimmed);
1634
2428
  if (!normalized) return false;
1635
- return ipaddr__namespace.IPv4.isValidFourPartDecimal(normalized);
2429
+ return ipaddr.IPv4.isValidFourPartDecimal(normalized);
1636
2430
  }
1637
2431
  function isLegacyIpv4Literal(raw) {
1638
2432
  const trimmed = raw?.trim();
@@ -1668,7 +2462,7 @@ function decodeIpv4FromHextets(high, low) {
1668
2462
  low >>> 8 & 255,
1669
2463
  low & 255
1670
2464
  ];
1671
- return ipaddr__namespace.IPv4.parse(octets.join("."));
2465
+ return ipaddr.IPv4.parse(octets.join("."));
1672
2466
  }
1673
2467
  function extractEmbeddedIpv4FromIpv6(address) {
1674
2468
  if (address.isIPv4MappedAddress()) return address.toIPv4Address();