From 5bd4986e1386531c14622e33a58deaa2b501cd6b Mon Sep 17 00:00:00 2001 From: Ville Lautanala Date: Tue, 12 Mar 2024 22:03:35 +0200 Subject: [PATCH 1/4] Use type assertion to check for valid coverage format --- src/index.ts | 31 ++++++++++++++----------------- 1 file changed, 14 insertions(+), 17 deletions(-) diff --git a/src/index.ts b/src/index.ts index 7ccd6b8..adf9643 100644 --- a/src/index.ts +++ b/src/index.ts @@ -2,9 +2,13 @@ import * as core from '@actions/core'; import * as github from '@actions/github'; import * as coverage from './covered'; -const inputFileArgument = 'coverage-file'; -const coverageTypeArgument = 'coverage-format'; -const baseRefArgument = 'base-ref'; +type CoverageFormat = 'lcov' | 'istanbul'; + +function assertCoverageFormat(coverageType: string): asserts coverageType is CoverageFormat { + if (!['lcov', 'istanbul'].includes(coverageType)) { + throw new Error(`Invalid coverage type: ${coverageType}`); + } +} async function publishCheck(opts: { totals: { covered: number; total: number }; token: string }) { const sha = github.context.payload.pull_request?.head?.sha || github.context.sha; @@ -26,24 +30,17 @@ async function publishCheck(opts: { totals: { covered: number; total: number }; await octokit.rest.repos.createCommitStatus(output); } -function parseCoverageType(coverageType: string): 'lcov' | 'istanbul' { - if (!coverageType) { - return 'istanbul'; - } else if (coverageType == 'lcov' || coverageType == 'istanbul') { - return coverageType; - } - throw new Error("coverage-type must be either 'istanbul' or 'lcov'"); -} - async function run() { - const file = core.getInput(inputFileArgument); - const coverageType = parseCoverageType(core.getInput(coverageTypeArgument, { required: false })); + const file = core.getInput('coverage-file', { required: true }); + const coverageFormat = core.getInput('coverage-format', { required: false }); + + assertCoverageFormat(coverageFormat); const result = await coverage.run({ - base: core.getInput(baseRefArgument), + base: core.getInput('base-ref'), head: github.context.sha, coverage: file, - coverageType: coverageType + coverageType: coverageFormat }); let covered = 0; let total = 0; @@ -62,7 +59,7 @@ async function run() { } } await publishCheck({ - token: core.getInput('github-token'), + token: core.getInput('github-token', { required: true }), totals: { covered, total } }); } From 6c177abbb804ea1b82bdf86d0b04cf74b54ab956 Mon Sep 17 00:00:00 2001 From: Ville Lautanala Date: Tue, 12 Mar 2024 22:07:33 +0200 Subject: [PATCH 2/4] Use coverage format terminology internally --- dist/index.js | 38 ++++++++++++++++---------------------- dist/index.js.map | 2 +- dist/src/covered.d.ts | 3 ++- src/covered.ts | 10 ++++++---- src/index.ts | 8 +++----- test.ts | 6 +++--- test/test.spec.ts | 4 ++-- 7 files changed, 33 insertions(+), 38 deletions(-) diff --git a/dist/index.js b/dist/index.js index e0f5781..659cad2 100644 --- a/dist/index.js +++ b/dist/index.js @@ -29479,7 +29479,7 @@ function uncovered(args) { } exports.uncovered = uncovered; async function coveredLines(opts) { - return opts.coverageType === 'lcov' ? lcovCoveredLines(opts) : istanbulCoveredLines(opts); + return opts.coverageFormat === 'lcov' ? lcovCoveredLines(opts) : istanbulCoveredLines(opts); } async function istanbulCoveredLines(opts) { const coverage = JSON.parse(await (0, promises_1.readFile)(opts.coverage, 'utf8')); @@ -29524,14 +29524,14 @@ async function uncoveredLines(opts) { } async function run(opts) { const file = opts.coverage; - if (opts.coverageType === 'istanbul') { + if (opts.coverageFormat === 'istanbul') { assert(/\.json$/.test(file), `input file '${file}' must be json coverage file`); } return await uncoveredLines({ base: opts.base, head: opts.head, coverage: file, - coverageType: opts.coverageType + coverageFormat: opts.coverageFormat }); } exports.run = run; @@ -31451,10 +31451,12 @@ var exports = __webpack_exports__; Object.defineProperty(exports, "__esModule", ({ value: true })); const core = __nccwpck_require__(2186); const github = __nccwpck_require__(5438); -const coverage = __nccwpck_require__(9136); -const inputFileArgument = 'coverage-file'; -const coverageTypeArgument = 'coverage-format'; -const baseRefArgument = 'base-ref'; +const covered_1 = __nccwpck_require__(9136); +function assertCoverageFormat(coverageType) { + if (!['lcov', 'istanbul'].includes(coverageType)) { + throw new Error(`Invalid coverage type: ${coverageType}`); + } +} async function publishCheck(opts) { var _a, _b; const sha = ((_b = (_a = github.context.payload.pull_request) === null || _a === void 0 ? void 0 : _a.head) === null || _b === void 0 ? void 0 : _b.sha) || github.context.sha; @@ -31472,23 +31474,15 @@ async function publishCheck(opts) { }; await octokit.rest.repos.createCommitStatus(output); } -function parseCoverageType(coverageType) { - if (!coverageType) { - return 'istanbul'; - } - else if (coverageType == 'lcov' || coverageType == 'istanbul') { - return coverageType; - } - throw new Error("coverage-type must be either 'istanbul' or 'lcov'"); -} async function run() { - const file = core.getInput(inputFileArgument); - const coverageType = parseCoverageType(core.getInput(coverageTypeArgument, { required: false })); - const result = await coverage.run({ - base: core.getInput(baseRefArgument), + const file = core.getInput('coverage-file', { required: true }); + const coverageFormat = core.getInput('coverage-format', { required: false }); + assertCoverageFormat(coverageFormat); + const result = await (0, covered_1.run)({ + base: core.getInput('base-ref'), head: github.context.sha, coverage: file, - coverageType: coverageType + coverageFormat }); let covered = 0; let total = 0; @@ -31507,7 +31501,7 @@ async function run() { } } await publishCheck({ - token: core.getInput('github-token'), + token: core.getInput('github-token', { required: true }), totals: { covered, total } }); } diff --git a/dist/index.js.map b/dist/index.js.map index dd51497..e59d45a 100644 --- a/dist/index.js.map +++ b/dist/index.js.map @@ -1 +1 @@ -{"version":3,"file":"index.js","mappings":";;;;;;;AAAA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;;;;;;AC3FA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;;;;;;AC/UA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;;;;;;ACzDA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;;;;;;AC5EA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;;;;;;ACzDA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;;;;;;AC1RA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;;;;;;ACvCA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;;;;;;ACtDA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;;;;;;ACxCA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;;;;;;ACrEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;;;;;;AC1DA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;;;;;;AChFA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;;;;;;AC3oBA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;;;;;;ACjFA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;;;;;;;AC5EA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;;;;;;;AChKA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;;;;;;;ACvXA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;;;;;;;ACrJA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;;;;;;;ACxYA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;;;;;;;ACjnEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;;;;;;;ACzFA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;;;;;;AC5NA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;;;;;;AC5DA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;;;;;;AC7CA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;;;;;;AC1BA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;;;;;;;AClBA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;;;;;;ACnBA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;;;;;;AC5LA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;;;;;;;ACzCA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;;;;;;ACvCA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;;;;;;ACzBA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;;;;;;ACzBA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;;;;;AC9EA;;;;;;;;;ACAA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;;;;;;;ACvQA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;;;;;;;ACtKA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;;;;;;ACnJA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;;;;;;;ACrDA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;;;;;;;ACvGA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;;;;;;;ACxPA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;;;;;;;ACnLA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;;;;;;;AC3NA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;;;;;;;ACxGA;AACA;AACA;AACA;AACA;AACA;AACA;;;;;;;;;ACNA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;;;;;;ACjUA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;;;;;;;AC7CA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;;;;;;;AC7LA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;;;;;;;ACr0BA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;;;;;;;AC/IA;AACA;AACA;AACA;AACA;;;;;;;;;ACJA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;;;;;;;AChDA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;;;;;;;AC1uEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;;;;;;;AC/CA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;;;;;;;ACXA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;;;;;;;ACvLA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;;;;;;;AC5TA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;;;;;;;AClSA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;;;;;;;AC5LA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;;;;;;;ACrOA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;;;;;;AClfA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;;;;;;;AC9DA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;;;;;;;AC9fA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;;;;;;;AC/LA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;;;;;;;AClBA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;;;;;;;AC5lBA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;;;;;;ACtJA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;;;;;;;AClnBA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;;;;;;;ACvVA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;;;;;;;ACxQA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;;;;;;;ACvCA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;;;;;;;AC5kBA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;;;;;;;ACnmEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;;;;;;;ACj7BA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;;;;;;;AC1jBA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;;;;;;;ACTA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;;;;;;;AC9iCA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;;;;;;;ACroBA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;;;;;;;ACjSA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;;;;;;;ACvVA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;;;;;;;AC7EA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;;;;;;;ACTA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;;;;;;;ACvYA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;;;;;;;AC/BA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;;;;;;;AClCA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;;;;;;ACvNA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;;;;;;;AC/UA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;;;;;;;ACpBA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;;;;;ACrRA;;;;;;;;ACAA;;;;;;;;;ACAA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;;;;;;ACdA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;;;;;;;AC1KA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;;;;;;;AC1DA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;;;;;;;AChBA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;;;;;;;AC7MA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;;;;;;;AC1DA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;;;;;;;ACtBA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;;;;;;;AC9VA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;;;;;;;ACvCA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;;;;;;;AC5BA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;;;;;;;ACpHA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;;;;;;ACjMA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;;;;;;;ACjCA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;;;;;;;AC7FA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;;;;;;;AC5LA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;;;;;;;AChGA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;;;;;;;AClSA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;;;;;;;AClDA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;;;;;;;AC9SA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;;;;;;;ACxEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;;;;;;;ACvVA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;;;;;;;ACXA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;;;;;;;ACvMA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;;;;;;;AChoBA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;;;;;;;ACjBA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;;;;;;AC9EA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;;;;;;ACtBA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;;;;;;ACPA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;;;;;;AC5CA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;;;;;;ACPA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;;;;;;ACvBA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;;;;;;ACtBA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;;;;;;ACtCA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;;;;;;AC1GA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;;;;;;ACfA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;;;;;;AC7EA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;;;;;;ACpCA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;;;;;;ACfA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;;;;;;AChBA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;;;;;ACpBA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;;;;;;;;;;AChCA;AACA;AACA;AACA;AACA;AACA;AAYA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;AAGA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAEA;;AAIA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AA/CA;AAsDA;AACA;AACA;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAGA;AACA;AACA;AACA;AACA;AAEA;AACA;AACA;AACA;AACA;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AAZA;;;;;;;;;AC5KA;;;;;;;;ACAA;;;;;;;;ACAA;;;;;;;;ACAA;;;;;;;;ACAA;;;;;;;;ACAA;;;;;;;;ACAA;;;;;;;;ACAA;;;;;;;;ACAA;;;;;;;;ACAA;;;;;;;;ACAA;;;;;;;;ACAA;;;;;;;;ACAA;;;;;;;;ACAA;;;;;;;;ACAA;;;;;;;;ACAA;;;;;;;;ACAA;;;;;;;;ACAA;;;;;;;;ACAA;;;;;;;;ACAA;;;;;;;;ACAA;;;;;;;;ACAA;;;;;;;;ACAA;;;;;;;;ACAA;;;;;;;;ACAA;;;;;;;;ACAA;;;;;;;;ACAA;;;;;;;;ACAA;;;;;;;;ACAA;;;;;;;;ACAA;;;;;;;;ACAA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;;;;;;;ACpNA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;;;;;;;ACnGA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;;;;;;;ACZA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;;;;;;;ACnOA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;;;;;;;ACpFA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;;;;;;;ACjTA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;;;;;;;AC7LA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;;;;;;;ACrDA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;;;;;;;ACbA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;;;;;;;ACjHA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;;;;;;;ACfA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;;;;;ACnMA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;AC7BA;AACA;;;;;;;;;;ACDA;AACA;AACA;AAEA;AACA;AACA;AAEA;;AACA;AACA;AAEA;AACA;AAGA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAEA;AACA;AACA;AACA;AAAA;AACA;AACA;AACA;AACA;AAEA;AACA;AACA;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA","sources":[".././node_modules/@actions/core/lib/command.js",".././node_modules/@actions/core/lib/core.js",".././node_modules/@actions/core/lib/file-command.js",".././node_modules/@actions/core/lib/oidc-utils.js",".././node_modules/@actions/core/lib/path-utils.js",".././node_modules/@actions/core/lib/summary.js",".././node_modules/@actions/core/lib/utils.js",".././node_modules/@actions/github/lib/context.js",".././node_modules/@actions/github/lib/github.js",".././node_modules/@actions/github/lib/internal/utils.js",".././node_modules/@actions/github/lib/utils.js",".././node_modules/@actions/http-client/lib/auth.js",".././node_modules/@actions/http-client/lib/index.js",".././node_modules/@actions/http-client/lib/proxy.js",".././node_modules/@octokit/auth-token/dist-node/index.js",".././node_modules/@octokit/core/dist-node/index.js",".././node_modules/@octokit/endpoint/dist-node/index.js",".././node_modules/@octokit/graphql/dist-node/index.js",".././node_modules/@octokit/plugin-paginate-rest/dist-node/index.js",".././node_modules/@octokit/plugin-rest-endpoint-methods/dist-node/index.js",".././node_modules/@octokit/request-error/dist-node/index.js",".././node_modules/@octokit/request/dist-node/index.js",".././node_modules/before-after-hook/index.js",".././node_modules/before-after-hook/lib/add.js",".././node_modules/before-after-hook/lib/register.js",".././node_modules/before-after-hook/lib/remove.js",".././node_modules/deprecation/dist-node/index.js",".././node_modules/drange/lib/index.js",".././node_modules/once/once.js",".././node_modules/parse-lcov/build/index.js",".././node_modules/parse-lcov/build/line.js",".././node_modules/parse-lcov/build/record.js",".././node_modules/parse-lcov/build/transform.js",".././node_modules/tunnel/index.js",".././node_modules/tunnel/lib/tunnel.js",".././node_modules/undici/index.js",".././node_modules/undici/lib/agent.js",".././node_modules/undici/lib/api/abort-signal.js",".././node_modules/undici/lib/api/api-connect.js",".././node_modules/undici/lib/api/api-pipeline.js",".././node_modules/undici/lib/api/api-request.js",".././node_modules/undici/lib/api/api-stream.js",".././node_modules/undici/lib/api/api-upgrade.js",".././node_modules/undici/lib/api/index.js",".././node_modules/undici/lib/api/readable.js",".././node_modules/undici/lib/api/util.js",".././node_modules/undici/lib/balanced-pool.js",".././node_modules/undici/lib/cache/cache.js",".././node_modules/undici/lib/cache/cachestorage.js",".././node_modules/undici/lib/cache/symbols.js",".././node_modules/undici/lib/cache/util.js",".././node_modules/undici/lib/client.js",".././node_modules/undici/lib/compat/dispatcher-weakref.js",".././node_modules/undici/lib/cookies/constants.js",".././node_modules/undici/lib/cookies/index.js",".././node_modules/undici/lib/cookies/parse.js",".././node_modules/undici/lib/cookies/util.js",".././node_modules/undici/lib/core/connect.js",".././node_modules/undici/lib/core/errors.js",".././node_modules/undici/lib/core/request.js",".././node_modules/undici/lib/core/symbols.js",".././node_modules/undici/lib/core/util.js",".././node_modules/undici/lib/dispatcher-base.js",".././node_modules/undici/lib/dispatcher.js",".././node_modules/undici/lib/fetch/body.js",".././node_modules/undici/lib/fetch/constants.js",".././node_modules/undici/lib/fetch/dataURL.js",".././node_modules/undici/lib/fetch/file.js",".././node_modules/undici/lib/fetch/formdata.js",".././node_modules/undici/lib/fetch/global.js",".././node_modules/undici/lib/fetch/headers.js",".././node_modules/undici/lib/fetch/index.js",".././node_modules/undici/lib/fetch/request.js",".././node_modules/undici/lib/fetch/response.js",".././node_modules/undici/lib/fetch/symbols.js",".././node_modules/undici/lib/fetch/util.js",".././node_modules/undici/lib/fetch/webidl.js",".././node_modules/undici/lib/fileapi/encoding.js",".././node_modules/undici/lib/fileapi/filereader.js",".././node_modules/undici/lib/fileapi/progressevent.js",".././node_modules/undici/lib/fileapi/symbols.js",".././node_modules/undici/lib/fileapi/util.js",".././node_modules/undici/lib/global.js",".././node_modules/undici/lib/handler/DecoratorHandler.js",".././node_modules/undici/lib/handler/RedirectHandler.js",".././node_modules/undici/lib/handler/RetryHandler.js",".././node_modules/undici/lib/interceptor/redirectInterceptor.js",".././node_modules/undici/lib/llhttp/constants.js",".././node_modules/undici/lib/llhttp/llhttp-wasm.js",".././node_modules/undici/lib/llhttp/llhttp_simd-wasm.js",".././node_modules/undici/lib/llhttp/utils.js",".././node_modules/undici/lib/mock/mock-agent.js",".././node_modules/undici/lib/mock/mock-client.js",".././node_modules/undici/lib/mock/mock-errors.js",".././node_modules/undici/lib/mock/mock-interceptor.js",".././node_modules/undici/lib/mock/mock-pool.js",".././node_modules/undici/lib/mock/mock-symbols.js",".././node_modules/undici/lib/mock/mock-utils.js",".././node_modules/undici/lib/mock/pending-interceptors-formatter.js",".././node_modules/undici/lib/mock/pluralizer.js",".././node_modules/undici/lib/node/fixed-queue.js",".././node_modules/undici/lib/pool-base.js",".././node_modules/undici/lib/pool-stats.js",".././node_modules/undici/lib/pool.js",".././node_modules/undici/lib/proxy-agent.js",".././node_modules/undici/lib/timers.js",".././node_modules/undici/lib/websocket/connection.js",".././node_modules/undici/lib/websocket/constants.js",".././node_modules/undici/lib/websocket/events.js",".././node_modules/undici/lib/websocket/frame.js",".././node_modules/undici/lib/websocket/receiver.js",".././node_modules/undici/lib/websocket/symbols.js",".././node_modules/undici/lib/websocket/util.js",".././node_modules/undici/lib/websocket/websocket.js",".././node_modules/universal-user-agent/dist-node/index.js",".././node_modules/uuid/dist/index.js",".././node_modules/uuid/dist/md5.js",".././node_modules/uuid/dist/nil.js",".././node_modules/uuid/dist/parse.js",".././node_modules/uuid/dist/regex.js",".././node_modules/uuid/dist/rng.js",".././node_modules/uuid/dist/sha1.js",".././node_modules/uuid/dist/stringify.js",".././node_modules/uuid/dist/v1.js",".././node_modules/uuid/dist/v3.js",".././node_modules/uuid/dist/v35.js",".././node_modules/uuid/dist/v4.js",".././node_modules/uuid/dist/v5.js",".././node_modules/uuid/dist/validate.js",".././node_modules/uuid/dist/version.js",".././node_modules/wrappy/wrappy.js",".././src/covered.ts","../external node-commonjs \"assert\"","../external node-commonjs \"async_hooks\"","../external node-commonjs \"buffer\"","../external node-commonjs \"child_process\"","../external node-commonjs \"console\"","../external node-commonjs \"crypto\"","../external node-commonjs \"diagnostics_channel\"","../external node-commonjs \"events\"","../external node-commonjs \"fs\"","../external node-commonjs \"fs/promises\"","../external node-commonjs \"http\"","../external node-commonjs \"http2\"","../external node-commonjs \"https\"","../external node-commonjs \"net\"","../external node-commonjs \"node:events\"","../external node-commonjs \"node:stream\"","../external node-commonjs \"node:util\"","../external node-commonjs \"os\"","../external node-commonjs \"path\"","../external node-commonjs \"perf_hooks\"","../external node-commonjs \"querystring\"","../external node-commonjs \"stream\"","../external node-commonjs \"stream/web\"","../external node-commonjs \"string_decoder\"","../external node-commonjs \"tls\"","../external node-commonjs \"url\"","../external node-commonjs \"util\"","../external node-commonjs \"util/types\"","../external node-commonjs \"worker_threads\"","../external node-commonjs \"zlib\"",".././node_modules/@fastify/busboy/deps/dicer/lib/Dicer.js",".././node_modules/@fastify/busboy/deps/dicer/lib/HeaderParser.js",".././node_modules/@fastify/busboy/deps/dicer/lib/PartStream.js",".././node_modules/@fastify/busboy/deps/streamsearch/sbmh.js",".././node_modules/@fastify/busboy/lib/main.js",".././node_modules/@fastify/busboy/lib/types/multipart.js",".././node_modules/@fastify/busboy/lib/types/urlencoded.js",".././node_modules/@fastify/busboy/lib/utils/Decoder.js",".././node_modules/@fastify/busboy/lib/utils/basename.js",".././node_modules/@fastify/busboy/lib/utils/decodeText.js",".././node_modules/@fastify/busboy/lib/utils/getLimit.js",".././node_modules/@fastify/busboy/lib/utils/parseParams.js","../webpack/bootstrap","../webpack/runtime/compat",".././src/index.ts"],"sourcesContent":["\"use strict\";\nvar __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {\n if (k2 === undefined) k2 = k;\n Object.defineProperty(o, k2, { enumerable: true, get: function() { return m[k]; } });\n}) : (function(o, m, k, k2) {\n if (k2 === undefined) k2 = k;\n o[k2] = m[k];\n}));\nvar __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) {\n Object.defineProperty(o, \"default\", { enumerable: true, value: v });\n}) : function(o, v) {\n o[\"default\"] = v;\n});\nvar __importStar = (this && this.__importStar) || function (mod) {\n if (mod && mod.__esModule) return mod;\n var result = {};\n if (mod != null) for (var k in mod) if (k !== \"default\" && Object.hasOwnProperty.call(mod, k)) __createBinding(result, mod, k);\n __setModuleDefault(result, mod);\n return result;\n};\nObject.defineProperty(exports, \"__esModule\", { value: true });\nexports.issue = exports.issueCommand = void 0;\nconst os = __importStar(require(\"os\"));\nconst utils_1 = require(\"./utils\");\n/**\n * Commands\n *\n * Command Format:\n * ::name key=value,key=value::message\n *\n * Examples:\n * ::warning::This is the message\n * ::set-env name=MY_VAR::some value\n */\nfunction issueCommand(command, properties, message) {\n const cmd = new Command(command, properties, message);\n process.stdout.write(cmd.toString() + os.EOL);\n}\nexports.issueCommand = issueCommand;\nfunction issue(name, message = '') {\n issueCommand(name, {}, message);\n}\nexports.issue = issue;\nconst CMD_STRING = '::';\nclass Command {\n constructor(command, properties, message) {\n if (!command) {\n command = 'missing.command';\n }\n this.command = command;\n this.properties = properties;\n this.message = message;\n }\n toString() {\n let cmdStr = CMD_STRING + this.command;\n if (this.properties && Object.keys(this.properties).length > 0) {\n cmdStr += ' ';\n let first = true;\n for (const key in this.properties) {\n if (this.properties.hasOwnProperty(key)) {\n const val = this.properties[key];\n if (val) {\n if (first) {\n first = false;\n }\n else {\n cmdStr += ',';\n }\n cmdStr += `${key}=${escapeProperty(val)}`;\n }\n }\n }\n }\n cmdStr += `${CMD_STRING}${escapeData(this.message)}`;\n return cmdStr;\n }\n}\nfunction escapeData(s) {\n return utils_1.toCommandValue(s)\n .replace(/%/g, '%25')\n .replace(/\\r/g, '%0D')\n .replace(/\\n/g, '%0A');\n}\nfunction escapeProperty(s) {\n return utils_1.toCommandValue(s)\n .replace(/%/g, '%25')\n .replace(/\\r/g, '%0D')\n .replace(/\\n/g, '%0A')\n .replace(/:/g, '%3A')\n .replace(/,/g, '%2C');\n}\n//# sourceMappingURL=command.js.map","\"use strict\";\nvar __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {\n if (k2 === undefined) k2 = k;\n Object.defineProperty(o, k2, { enumerable: true, get: function() { return m[k]; } });\n}) : (function(o, m, k, k2) {\n if (k2 === undefined) k2 = k;\n o[k2] = m[k];\n}));\nvar __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) {\n Object.defineProperty(o, \"default\", { enumerable: true, value: v });\n}) : function(o, v) {\n o[\"default\"] = v;\n});\nvar __importStar = (this && this.__importStar) || function (mod) {\n if (mod && mod.__esModule) return mod;\n var result = {};\n if (mod != null) for (var k in mod) if (k !== \"default\" && Object.hasOwnProperty.call(mod, k)) __createBinding(result, mod, k);\n __setModuleDefault(result, mod);\n return result;\n};\nvar __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) {\n function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }\n return new (P || (P = Promise))(function (resolve, reject) {\n function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }\n function rejected(value) { try { step(generator[\"throw\"](value)); } catch (e) { reject(e); } }\n function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); }\n step((generator = generator.apply(thisArg, _arguments || [])).next());\n });\n};\nObject.defineProperty(exports, \"__esModule\", { value: true });\nexports.getIDToken = exports.getState = exports.saveState = exports.group = exports.endGroup = exports.startGroup = exports.info = exports.notice = exports.warning = exports.error = exports.debug = exports.isDebug = exports.setFailed = exports.setCommandEcho = exports.setOutput = exports.getBooleanInput = exports.getMultilineInput = exports.getInput = exports.addPath = exports.setSecret = exports.exportVariable = exports.ExitCode = void 0;\nconst command_1 = require(\"./command\");\nconst file_command_1 = require(\"./file-command\");\nconst utils_1 = require(\"./utils\");\nconst os = __importStar(require(\"os\"));\nconst path = __importStar(require(\"path\"));\nconst oidc_utils_1 = require(\"./oidc-utils\");\n/**\n * The code to exit an action\n */\nvar ExitCode;\n(function (ExitCode) {\n /**\n * A code indicating that the action was successful\n */\n ExitCode[ExitCode[\"Success\"] = 0] = \"Success\";\n /**\n * A code indicating that the action was a failure\n */\n ExitCode[ExitCode[\"Failure\"] = 1] = \"Failure\";\n})(ExitCode = exports.ExitCode || (exports.ExitCode = {}));\n//-----------------------------------------------------------------------\n// Variables\n//-----------------------------------------------------------------------\n/**\n * Sets env variable for this action and future actions in the job\n * @param name the name of the variable to set\n * @param val the value of the variable. Non-string values will be converted to a string via JSON.stringify\n */\n// eslint-disable-next-line @typescript-eslint/no-explicit-any\nfunction exportVariable(name, val) {\n const convertedVal = utils_1.toCommandValue(val);\n process.env[name] = convertedVal;\n const filePath = process.env['GITHUB_ENV'] || '';\n if (filePath) {\n return file_command_1.issueFileCommand('ENV', file_command_1.prepareKeyValueMessage(name, val));\n }\n command_1.issueCommand('set-env', { name }, convertedVal);\n}\nexports.exportVariable = exportVariable;\n/**\n * Registers a secret which will get masked from logs\n * @param secret value of the secret\n */\nfunction setSecret(secret) {\n command_1.issueCommand('add-mask', {}, secret);\n}\nexports.setSecret = setSecret;\n/**\n * Prepends inputPath to the PATH (for this action and future actions)\n * @param inputPath\n */\nfunction addPath(inputPath) {\n const filePath = process.env['GITHUB_PATH'] || '';\n if (filePath) {\n file_command_1.issueFileCommand('PATH', inputPath);\n }\n else {\n command_1.issueCommand('add-path', {}, inputPath);\n }\n process.env['PATH'] = `${inputPath}${path.delimiter}${process.env['PATH']}`;\n}\nexports.addPath = addPath;\n/**\n * Gets the value of an input.\n * Unless trimWhitespace is set to false in InputOptions, the value is also trimmed.\n * Returns an empty string if the value is not defined.\n *\n * @param name name of the input to get\n * @param options optional. See InputOptions.\n * @returns string\n */\nfunction getInput(name, options) {\n const val = process.env[`INPUT_${name.replace(/ /g, '_').toUpperCase()}`] || '';\n if (options && options.required && !val) {\n throw new Error(`Input required and not supplied: ${name}`);\n }\n if (options && options.trimWhitespace === false) {\n return val;\n }\n return val.trim();\n}\nexports.getInput = getInput;\n/**\n * Gets the values of an multiline input. Each value is also trimmed.\n *\n * @param name name of the input to get\n * @param options optional. See InputOptions.\n * @returns string[]\n *\n */\nfunction getMultilineInput(name, options) {\n const inputs = getInput(name, options)\n .split('\\n')\n .filter(x => x !== '');\n if (options && options.trimWhitespace === false) {\n return inputs;\n }\n return inputs.map(input => input.trim());\n}\nexports.getMultilineInput = getMultilineInput;\n/**\n * Gets the input value of the boolean type in the YAML 1.2 \"core schema\" specification.\n * Support boolean input list: `true | True | TRUE | false | False | FALSE` .\n * The return value is also in boolean type.\n * ref: https://yaml.org/spec/1.2/spec.html#id2804923\n *\n * @param name name of the input to get\n * @param options optional. See InputOptions.\n * @returns boolean\n */\nfunction getBooleanInput(name, options) {\n const trueValue = ['true', 'True', 'TRUE'];\n const falseValue = ['false', 'False', 'FALSE'];\n const val = getInput(name, options);\n if (trueValue.includes(val))\n return true;\n if (falseValue.includes(val))\n return false;\n throw new TypeError(`Input does not meet YAML 1.2 \"Core Schema\" specification: ${name}\\n` +\n `Support boolean input list: \\`true | True | TRUE | false | False | FALSE\\``);\n}\nexports.getBooleanInput = getBooleanInput;\n/**\n * Sets the value of an output.\n *\n * @param name name of the output to set\n * @param value value to store. Non-string values will be converted to a string via JSON.stringify\n */\n// eslint-disable-next-line @typescript-eslint/no-explicit-any\nfunction setOutput(name, value) {\n const filePath = process.env['GITHUB_OUTPUT'] || '';\n if (filePath) {\n return file_command_1.issueFileCommand('OUTPUT', file_command_1.prepareKeyValueMessage(name, value));\n }\n process.stdout.write(os.EOL);\n command_1.issueCommand('set-output', { name }, utils_1.toCommandValue(value));\n}\nexports.setOutput = setOutput;\n/**\n * Enables or disables the echoing of commands into stdout for the rest of the step.\n * Echoing is disabled by default if ACTIONS_STEP_DEBUG is not set.\n *\n */\nfunction setCommandEcho(enabled) {\n command_1.issue('echo', enabled ? 'on' : 'off');\n}\nexports.setCommandEcho = setCommandEcho;\n//-----------------------------------------------------------------------\n// Results\n//-----------------------------------------------------------------------\n/**\n * Sets the action status to failed.\n * When the action exits it will be with an exit code of 1\n * @param message add error issue message\n */\nfunction setFailed(message) {\n process.exitCode = ExitCode.Failure;\n error(message);\n}\nexports.setFailed = setFailed;\n//-----------------------------------------------------------------------\n// Logging Commands\n//-----------------------------------------------------------------------\n/**\n * Gets whether Actions Step Debug is on or not\n */\nfunction isDebug() {\n return process.env['RUNNER_DEBUG'] === '1';\n}\nexports.isDebug = isDebug;\n/**\n * Writes debug message to user log\n * @param message debug message\n */\nfunction debug(message) {\n command_1.issueCommand('debug', {}, message);\n}\nexports.debug = debug;\n/**\n * Adds an error issue\n * @param message error issue message. Errors will be converted to string via toString()\n * @param properties optional properties to add to the annotation.\n */\nfunction error(message, properties = {}) {\n command_1.issueCommand('error', utils_1.toCommandProperties(properties), message instanceof Error ? message.toString() : message);\n}\nexports.error = error;\n/**\n * Adds a warning issue\n * @param message warning issue message. Errors will be converted to string via toString()\n * @param properties optional properties to add to the annotation.\n */\nfunction warning(message, properties = {}) {\n command_1.issueCommand('warning', utils_1.toCommandProperties(properties), message instanceof Error ? message.toString() : message);\n}\nexports.warning = warning;\n/**\n * Adds a notice issue\n * @param message notice issue message. Errors will be converted to string via toString()\n * @param properties optional properties to add to the annotation.\n */\nfunction notice(message, properties = {}) {\n command_1.issueCommand('notice', utils_1.toCommandProperties(properties), message instanceof Error ? message.toString() : message);\n}\nexports.notice = notice;\n/**\n * Writes info to log with console.log.\n * @param message info message\n */\nfunction info(message) {\n process.stdout.write(message + os.EOL);\n}\nexports.info = info;\n/**\n * Begin an output group.\n *\n * Output until the next `groupEnd` will be foldable in this group\n *\n * @param name The name of the output group\n */\nfunction startGroup(name) {\n command_1.issue('group', name);\n}\nexports.startGroup = startGroup;\n/**\n * End an output group.\n */\nfunction endGroup() {\n command_1.issue('endgroup');\n}\nexports.endGroup = endGroup;\n/**\n * Wrap an asynchronous function call in a group.\n *\n * Returns the same type as the function itself.\n *\n * @param name The name of the group\n * @param fn The function to wrap in the group\n */\nfunction group(name, fn) {\n return __awaiter(this, void 0, void 0, function* () {\n startGroup(name);\n let result;\n try {\n result = yield fn();\n }\n finally {\n endGroup();\n }\n return result;\n });\n}\nexports.group = group;\n//-----------------------------------------------------------------------\n// Wrapper action state\n//-----------------------------------------------------------------------\n/**\n * Saves state for current action, the state can only be retrieved by this action's post job execution.\n *\n * @param name name of the state to store\n * @param value value to store. Non-string values will be converted to a string via JSON.stringify\n */\n// eslint-disable-next-line @typescript-eslint/no-explicit-any\nfunction saveState(name, value) {\n const filePath = process.env['GITHUB_STATE'] || '';\n if (filePath) {\n return file_command_1.issueFileCommand('STATE', file_command_1.prepareKeyValueMessage(name, value));\n }\n command_1.issueCommand('save-state', { name }, utils_1.toCommandValue(value));\n}\nexports.saveState = saveState;\n/**\n * Gets the value of an state set by this action's main execution.\n *\n * @param name name of the state to get\n * @returns string\n */\nfunction getState(name) {\n return process.env[`STATE_${name}`] || '';\n}\nexports.getState = getState;\nfunction getIDToken(aud) {\n return __awaiter(this, void 0, void 0, function* () {\n return yield oidc_utils_1.OidcClient.getIDToken(aud);\n });\n}\nexports.getIDToken = getIDToken;\n/**\n * Summary exports\n */\nvar summary_1 = require(\"./summary\");\nObject.defineProperty(exports, \"summary\", { enumerable: true, get: function () { return summary_1.summary; } });\n/**\n * @deprecated use core.summary\n */\nvar summary_2 = require(\"./summary\");\nObject.defineProperty(exports, \"markdownSummary\", { enumerable: true, get: function () { return summary_2.markdownSummary; } });\n/**\n * Path exports\n */\nvar path_utils_1 = require(\"./path-utils\");\nObject.defineProperty(exports, \"toPosixPath\", { enumerable: true, get: function () { return path_utils_1.toPosixPath; } });\nObject.defineProperty(exports, \"toWin32Path\", { enumerable: true, get: function () { return path_utils_1.toWin32Path; } });\nObject.defineProperty(exports, \"toPlatformPath\", { enumerable: true, get: function () { return path_utils_1.toPlatformPath; } });\n//# sourceMappingURL=core.js.map","\"use strict\";\n// For internal use, subject to change.\nvar __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {\n if (k2 === undefined) k2 = k;\n Object.defineProperty(o, k2, { enumerable: true, get: function() { return m[k]; } });\n}) : (function(o, m, k, k2) {\n if (k2 === undefined) k2 = k;\n o[k2] = m[k];\n}));\nvar __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) {\n Object.defineProperty(o, \"default\", { enumerable: true, value: v });\n}) : function(o, v) {\n o[\"default\"] = v;\n});\nvar __importStar = (this && this.__importStar) || function (mod) {\n if (mod && mod.__esModule) return mod;\n var result = {};\n if (mod != null) for (var k in mod) if (k !== \"default\" && Object.hasOwnProperty.call(mod, k)) __createBinding(result, mod, k);\n __setModuleDefault(result, mod);\n return result;\n};\nObject.defineProperty(exports, \"__esModule\", { value: true });\nexports.prepareKeyValueMessage = exports.issueFileCommand = void 0;\n// We use any as a valid input type\n/* eslint-disable @typescript-eslint/no-explicit-any */\nconst fs = __importStar(require(\"fs\"));\nconst os = __importStar(require(\"os\"));\nconst uuid_1 = require(\"uuid\");\nconst utils_1 = require(\"./utils\");\nfunction issueFileCommand(command, message) {\n const filePath = process.env[`GITHUB_${command}`];\n if (!filePath) {\n throw new Error(`Unable to find environment variable for file command ${command}`);\n }\n if (!fs.existsSync(filePath)) {\n throw new Error(`Missing file at path: ${filePath}`);\n }\n fs.appendFileSync(filePath, `${utils_1.toCommandValue(message)}${os.EOL}`, {\n encoding: 'utf8'\n });\n}\nexports.issueFileCommand = issueFileCommand;\nfunction prepareKeyValueMessage(key, value) {\n const delimiter = `ghadelimiter_${uuid_1.v4()}`;\n const convertedValue = utils_1.toCommandValue(value);\n // These should realistically never happen, but just in case someone finds a\n // way to exploit uuid generation let's not allow keys or values that contain\n // the delimiter.\n if (key.includes(delimiter)) {\n throw new Error(`Unexpected input: name should not contain the delimiter \"${delimiter}\"`);\n }\n if (convertedValue.includes(delimiter)) {\n throw new Error(`Unexpected input: value should not contain the delimiter \"${delimiter}\"`);\n }\n return `${key}<<${delimiter}${os.EOL}${convertedValue}${os.EOL}${delimiter}`;\n}\nexports.prepareKeyValueMessage = prepareKeyValueMessage;\n//# sourceMappingURL=file-command.js.map","\"use strict\";\nvar __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) {\n function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }\n return new (P || (P = Promise))(function (resolve, reject) {\n function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }\n function rejected(value) { try { step(generator[\"throw\"](value)); } catch (e) { reject(e); } }\n function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); }\n step((generator = generator.apply(thisArg, _arguments || [])).next());\n });\n};\nObject.defineProperty(exports, \"__esModule\", { value: true });\nexports.OidcClient = void 0;\nconst http_client_1 = require(\"@actions/http-client\");\nconst auth_1 = require(\"@actions/http-client/lib/auth\");\nconst core_1 = require(\"./core\");\nclass OidcClient {\n static createHttpClient(allowRetry = true, maxRetry = 10) {\n const requestOptions = {\n allowRetries: allowRetry,\n maxRetries: maxRetry\n };\n return new http_client_1.HttpClient('actions/oidc-client', [new auth_1.BearerCredentialHandler(OidcClient.getRequestToken())], requestOptions);\n }\n static getRequestToken() {\n const token = process.env['ACTIONS_ID_TOKEN_REQUEST_TOKEN'];\n if (!token) {\n throw new Error('Unable to get ACTIONS_ID_TOKEN_REQUEST_TOKEN env variable');\n }\n return token;\n }\n static getIDTokenUrl() {\n const runtimeUrl = process.env['ACTIONS_ID_TOKEN_REQUEST_URL'];\n if (!runtimeUrl) {\n throw new Error('Unable to get ACTIONS_ID_TOKEN_REQUEST_URL env variable');\n }\n return runtimeUrl;\n }\n static getCall(id_token_url) {\n var _a;\n return __awaiter(this, void 0, void 0, function* () {\n const httpclient = OidcClient.createHttpClient();\n const res = yield httpclient\n .getJson(id_token_url)\n .catch(error => {\n throw new Error(`Failed to get ID Token. \\n \n Error Code : ${error.statusCode}\\n \n Error Message: ${error.message}`);\n });\n const id_token = (_a = res.result) === null || _a === void 0 ? void 0 : _a.value;\n if (!id_token) {\n throw new Error('Response json body do not have ID Token field');\n }\n return id_token;\n });\n }\n static getIDToken(audience) {\n return __awaiter(this, void 0, void 0, function* () {\n try {\n // New ID Token is requested from action service\n let id_token_url = OidcClient.getIDTokenUrl();\n if (audience) {\n const encodedAudience = encodeURIComponent(audience);\n id_token_url = `${id_token_url}&audience=${encodedAudience}`;\n }\n core_1.debug(`ID token url is ${id_token_url}`);\n const id_token = yield OidcClient.getCall(id_token_url);\n core_1.setSecret(id_token);\n return id_token;\n }\n catch (error) {\n throw new Error(`Error message: ${error.message}`);\n }\n });\n }\n}\nexports.OidcClient = OidcClient;\n//# sourceMappingURL=oidc-utils.js.map","\"use strict\";\nvar __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {\n if (k2 === undefined) k2 = k;\n Object.defineProperty(o, k2, { enumerable: true, get: function() { return m[k]; } });\n}) : (function(o, m, k, k2) {\n if (k2 === undefined) k2 = k;\n o[k2] = m[k];\n}));\nvar __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) {\n Object.defineProperty(o, \"default\", { enumerable: true, value: v });\n}) : function(o, v) {\n o[\"default\"] = v;\n});\nvar __importStar = (this && this.__importStar) || function (mod) {\n if (mod && mod.__esModule) return mod;\n var result = {};\n if (mod != null) for (var k in mod) if (k !== \"default\" && Object.hasOwnProperty.call(mod, k)) __createBinding(result, mod, k);\n __setModuleDefault(result, mod);\n return result;\n};\nObject.defineProperty(exports, \"__esModule\", { value: true });\nexports.toPlatformPath = exports.toWin32Path = exports.toPosixPath = void 0;\nconst path = __importStar(require(\"path\"));\n/**\n * toPosixPath converts the given path to the posix form. On Windows, \\\\ will be\n * replaced with /.\n *\n * @param pth. Path to transform.\n * @return string Posix path.\n */\nfunction toPosixPath(pth) {\n return pth.replace(/[\\\\]/g, '/');\n}\nexports.toPosixPath = toPosixPath;\n/**\n * toWin32Path converts the given path to the win32 form. On Linux, / will be\n * replaced with \\\\.\n *\n * @param pth. Path to transform.\n * @return string Win32 path.\n */\nfunction toWin32Path(pth) {\n return pth.replace(/[/]/g, '\\\\');\n}\nexports.toWin32Path = toWin32Path;\n/**\n * toPlatformPath converts the given path to a platform-specific path. It does\n * this by replacing instances of / and \\ with the platform-specific path\n * separator.\n *\n * @param pth The path to platformize.\n * @return string The platform-specific path.\n */\nfunction toPlatformPath(pth) {\n return pth.replace(/[/\\\\]/g, path.sep);\n}\nexports.toPlatformPath = toPlatformPath;\n//# sourceMappingURL=path-utils.js.map","\"use strict\";\nvar __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) {\n function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }\n return new (P || (P = Promise))(function (resolve, reject) {\n function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }\n function rejected(value) { try { step(generator[\"throw\"](value)); } catch (e) { reject(e); } }\n function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); }\n step((generator = generator.apply(thisArg, _arguments || [])).next());\n });\n};\nObject.defineProperty(exports, \"__esModule\", { value: true });\nexports.summary = exports.markdownSummary = exports.SUMMARY_DOCS_URL = exports.SUMMARY_ENV_VAR = void 0;\nconst os_1 = require(\"os\");\nconst fs_1 = require(\"fs\");\nconst { access, appendFile, writeFile } = fs_1.promises;\nexports.SUMMARY_ENV_VAR = 'GITHUB_STEP_SUMMARY';\nexports.SUMMARY_DOCS_URL = 'https://docs.github.com/actions/using-workflows/workflow-commands-for-github-actions#adding-a-job-summary';\nclass Summary {\n constructor() {\n this._buffer = '';\n }\n /**\n * Finds the summary file path from the environment, rejects if env var is not found or file does not exist\n * Also checks r/w permissions.\n *\n * @returns step summary file path\n */\n filePath() {\n return __awaiter(this, void 0, void 0, function* () {\n if (this._filePath) {\n return this._filePath;\n }\n const pathFromEnv = process.env[exports.SUMMARY_ENV_VAR];\n if (!pathFromEnv) {\n throw new Error(`Unable to find environment variable for $${exports.SUMMARY_ENV_VAR}. Check if your runtime environment supports job summaries.`);\n }\n try {\n yield access(pathFromEnv, fs_1.constants.R_OK | fs_1.constants.W_OK);\n }\n catch (_a) {\n throw new Error(`Unable to access summary file: '${pathFromEnv}'. Check if the file has correct read/write permissions.`);\n }\n this._filePath = pathFromEnv;\n return this._filePath;\n });\n }\n /**\n * Wraps content in an HTML tag, adding any HTML attributes\n *\n * @param {string} tag HTML tag to wrap\n * @param {string | null} content content within the tag\n * @param {[attribute: string]: string} attrs key-value list of HTML attributes to add\n *\n * @returns {string} content wrapped in HTML element\n */\n wrap(tag, content, attrs = {}) {\n const htmlAttrs = Object.entries(attrs)\n .map(([key, value]) => ` ${key}=\"${value}\"`)\n .join('');\n if (!content) {\n return `<${tag}${htmlAttrs}>`;\n }\n return `<${tag}${htmlAttrs}>${content}`;\n }\n /**\n * Writes text in the buffer to the summary buffer file and empties buffer. Will append by default.\n *\n * @param {SummaryWriteOptions} [options] (optional) options for write operation\n *\n * @returns {Promise} summary instance\n */\n write(options) {\n return __awaiter(this, void 0, void 0, function* () {\n const overwrite = !!(options === null || options === void 0 ? void 0 : options.overwrite);\n const filePath = yield this.filePath();\n const writeFunc = overwrite ? writeFile : appendFile;\n yield writeFunc(filePath, this._buffer, { encoding: 'utf8' });\n return this.emptyBuffer();\n });\n }\n /**\n * Clears the summary buffer and wipes the summary file\n *\n * @returns {Summary} summary instance\n */\n clear() {\n return __awaiter(this, void 0, void 0, function* () {\n return this.emptyBuffer().write({ overwrite: true });\n });\n }\n /**\n * Returns the current summary buffer as a string\n *\n * @returns {string} string of summary buffer\n */\n stringify() {\n return this._buffer;\n }\n /**\n * If the summary buffer is empty\n *\n * @returns {boolen} true if the buffer is empty\n */\n isEmptyBuffer() {\n return this._buffer.length === 0;\n }\n /**\n * Resets the summary buffer without writing to summary file\n *\n * @returns {Summary} summary instance\n */\n emptyBuffer() {\n this._buffer = '';\n return this;\n }\n /**\n * Adds raw text to the summary buffer\n *\n * @param {string} text content to add\n * @param {boolean} [addEOL=false] (optional) append an EOL to the raw text (default: false)\n *\n * @returns {Summary} summary instance\n */\n addRaw(text, addEOL = false) {\n this._buffer += text;\n return addEOL ? this.addEOL() : this;\n }\n /**\n * Adds the operating system-specific end-of-line marker to the buffer\n *\n * @returns {Summary} summary instance\n */\n addEOL() {\n return this.addRaw(os_1.EOL);\n }\n /**\n * Adds an HTML codeblock to the summary buffer\n *\n * @param {string} code content to render within fenced code block\n * @param {string} lang (optional) language to syntax highlight code\n *\n * @returns {Summary} summary instance\n */\n addCodeBlock(code, lang) {\n const attrs = Object.assign({}, (lang && { lang }));\n const element = this.wrap('pre', this.wrap('code', code), attrs);\n return this.addRaw(element).addEOL();\n }\n /**\n * Adds an HTML list to the summary buffer\n *\n * @param {string[]} items list of items to render\n * @param {boolean} [ordered=false] (optional) if the rendered list should be ordered or not (default: false)\n *\n * @returns {Summary} summary instance\n */\n addList(items, ordered = false) {\n const tag = ordered ? 'ol' : 'ul';\n const listItems = items.map(item => this.wrap('li', item)).join('');\n const element = this.wrap(tag, listItems);\n return this.addRaw(element).addEOL();\n }\n /**\n * Adds an HTML table to the summary buffer\n *\n * @param {SummaryTableCell[]} rows table rows\n *\n * @returns {Summary} summary instance\n */\n addTable(rows) {\n const tableBody = rows\n .map(row => {\n const cells = row\n .map(cell => {\n if (typeof cell === 'string') {\n return this.wrap('td', cell);\n }\n const { header, data, colspan, rowspan } = cell;\n const tag = header ? 'th' : 'td';\n const attrs = Object.assign(Object.assign({}, (colspan && { colspan })), (rowspan && { rowspan }));\n return this.wrap(tag, data, attrs);\n })\n .join('');\n return this.wrap('tr', cells);\n })\n .join('');\n const element = this.wrap('table', tableBody);\n return this.addRaw(element).addEOL();\n }\n /**\n * Adds a collapsable HTML details element to the summary buffer\n *\n * @param {string} label text for the closed state\n * @param {string} content collapsable content\n *\n * @returns {Summary} summary instance\n */\n addDetails(label, content) {\n const element = this.wrap('details', this.wrap('summary', label) + content);\n return this.addRaw(element).addEOL();\n }\n /**\n * Adds an HTML image tag to the summary buffer\n *\n * @param {string} src path to the image you to embed\n * @param {string} alt text description of the image\n * @param {SummaryImageOptions} options (optional) addition image attributes\n *\n * @returns {Summary} summary instance\n */\n addImage(src, alt, options) {\n const { width, height } = options || {};\n const attrs = Object.assign(Object.assign({}, (width && { width })), (height && { height }));\n const element = this.wrap('img', null, Object.assign({ src, alt }, attrs));\n return this.addRaw(element).addEOL();\n }\n /**\n * Adds an HTML section heading element\n *\n * @param {string} text heading text\n * @param {number | string} [level=1] (optional) the heading level, default: 1\n *\n * @returns {Summary} summary instance\n */\n addHeading(text, level) {\n const tag = `h${level}`;\n const allowedTag = ['h1', 'h2', 'h3', 'h4', 'h5', 'h6'].includes(tag)\n ? tag\n : 'h1';\n const element = this.wrap(allowedTag, text);\n return this.addRaw(element).addEOL();\n }\n /**\n * Adds an HTML thematic break (
) to the summary buffer\n *\n * @returns {Summary} summary instance\n */\n addSeparator() {\n const element = this.wrap('hr', null);\n return this.addRaw(element).addEOL();\n }\n /**\n * Adds an HTML line break (
) to the summary buffer\n *\n * @returns {Summary} summary instance\n */\n addBreak() {\n const element = this.wrap('br', null);\n return this.addRaw(element).addEOL();\n }\n /**\n * Adds an HTML blockquote to the summary buffer\n *\n * @param {string} text quote text\n * @param {string} cite (optional) citation url\n *\n * @returns {Summary} summary instance\n */\n addQuote(text, cite) {\n const attrs = Object.assign({}, (cite && { cite }));\n const element = this.wrap('blockquote', text, attrs);\n return this.addRaw(element).addEOL();\n }\n /**\n * Adds an HTML anchor tag to the summary buffer\n *\n * @param {string} text link text/content\n * @param {string} href hyperlink\n *\n * @returns {Summary} summary instance\n */\n addLink(text, href) {\n const element = this.wrap('a', text, { href });\n return this.addRaw(element).addEOL();\n }\n}\nconst _summary = new Summary();\n/**\n * @deprecated use `core.summary`\n */\nexports.markdownSummary = _summary;\nexports.summary = _summary;\n//# sourceMappingURL=summary.js.map","\"use strict\";\n// We use any as a valid input type\n/* eslint-disable @typescript-eslint/no-explicit-any */\nObject.defineProperty(exports, \"__esModule\", { value: true });\nexports.toCommandProperties = exports.toCommandValue = void 0;\n/**\n * Sanitizes an input into a string so it can be passed into issueCommand safely\n * @param input input to sanitize into a string\n */\nfunction toCommandValue(input) {\n if (input === null || input === undefined) {\n return '';\n }\n else if (typeof input === 'string' || input instanceof String) {\n return input;\n }\n return JSON.stringify(input);\n}\nexports.toCommandValue = toCommandValue;\n/**\n *\n * @param annotationProperties\n * @returns The command properties to send with the actual annotation command\n * See IssueCommandProperties: https://github.com/actions/runner/blob/main/src/Runner.Worker/ActionCommandManager.cs#L646\n */\nfunction toCommandProperties(annotationProperties) {\n if (!Object.keys(annotationProperties).length) {\n return {};\n }\n return {\n title: annotationProperties.title,\n file: annotationProperties.file,\n line: annotationProperties.startLine,\n endLine: annotationProperties.endLine,\n col: annotationProperties.startColumn,\n endColumn: annotationProperties.endColumn\n };\n}\nexports.toCommandProperties = toCommandProperties;\n//# sourceMappingURL=utils.js.map","\"use strict\";\nObject.defineProperty(exports, \"__esModule\", { value: true });\nexports.Context = void 0;\nconst fs_1 = require(\"fs\");\nconst os_1 = require(\"os\");\nclass Context {\n /**\n * Hydrate the context from the environment\n */\n constructor() {\n var _a, _b, _c;\n this.payload = {};\n if (process.env.GITHUB_EVENT_PATH) {\n if ((0, fs_1.existsSync)(process.env.GITHUB_EVENT_PATH)) {\n this.payload = JSON.parse((0, fs_1.readFileSync)(process.env.GITHUB_EVENT_PATH, { encoding: 'utf8' }));\n }\n else {\n const path = process.env.GITHUB_EVENT_PATH;\n process.stdout.write(`GITHUB_EVENT_PATH ${path} does not exist${os_1.EOL}`);\n }\n }\n this.eventName = process.env.GITHUB_EVENT_NAME;\n this.sha = process.env.GITHUB_SHA;\n this.ref = process.env.GITHUB_REF;\n this.workflow = process.env.GITHUB_WORKFLOW;\n this.action = process.env.GITHUB_ACTION;\n this.actor = process.env.GITHUB_ACTOR;\n this.job = process.env.GITHUB_JOB;\n this.runNumber = parseInt(process.env.GITHUB_RUN_NUMBER, 10);\n this.runId = parseInt(process.env.GITHUB_RUN_ID, 10);\n this.apiUrl = (_a = process.env.GITHUB_API_URL) !== null && _a !== void 0 ? _a : `https://api.github.com`;\n this.serverUrl = (_b = process.env.GITHUB_SERVER_URL) !== null && _b !== void 0 ? _b : `https://github.com`;\n this.graphqlUrl =\n (_c = process.env.GITHUB_GRAPHQL_URL) !== null && _c !== void 0 ? _c : `https://api.github.com/graphql`;\n }\n get issue() {\n const payload = this.payload;\n return Object.assign(Object.assign({}, this.repo), { number: (payload.issue || payload.pull_request || payload).number });\n }\n get repo() {\n if (process.env.GITHUB_REPOSITORY) {\n const [owner, repo] = process.env.GITHUB_REPOSITORY.split('/');\n return { owner, repo };\n }\n if (this.payload.repository) {\n return {\n owner: this.payload.repository.owner.login,\n repo: this.payload.repository.name\n };\n }\n throw new Error(\"context.repo requires a GITHUB_REPOSITORY environment variable like 'owner/repo'\");\n }\n}\nexports.Context = Context;\n//# sourceMappingURL=context.js.map","\"use strict\";\nvar __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {\n if (k2 === undefined) k2 = k;\n var desc = Object.getOwnPropertyDescriptor(m, k);\n if (!desc || (\"get\" in desc ? !m.__esModule : desc.writable || desc.configurable)) {\n desc = { enumerable: true, get: function() { return m[k]; } };\n }\n Object.defineProperty(o, k2, desc);\n}) : (function(o, m, k, k2) {\n if (k2 === undefined) k2 = k;\n o[k2] = m[k];\n}));\nvar __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) {\n Object.defineProperty(o, \"default\", { enumerable: true, value: v });\n}) : function(o, v) {\n o[\"default\"] = v;\n});\nvar __importStar = (this && this.__importStar) || function (mod) {\n if (mod && mod.__esModule) return mod;\n var result = {};\n if (mod != null) for (var k in mod) if (k !== \"default\" && Object.prototype.hasOwnProperty.call(mod, k)) __createBinding(result, mod, k);\n __setModuleDefault(result, mod);\n return result;\n};\nObject.defineProperty(exports, \"__esModule\", { value: true });\nexports.getOctokit = exports.context = void 0;\nconst Context = __importStar(require(\"./context\"));\nconst utils_1 = require(\"./utils\");\nexports.context = new Context.Context();\n/**\n * Returns a hydrated octokit ready to use for GitHub Actions\n *\n * @param token the repo PAT or GITHUB_TOKEN\n * @param options other options to set\n */\nfunction getOctokit(token, options, ...additionalPlugins) {\n const GitHubWithPlugins = utils_1.GitHub.plugin(...additionalPlugins);\n return new GitHubWithPlugins((0, utils_1.getOctokitOptions)(token, options));\n}\nexports.getOctokit = getOctokit;\n//# sourceMappingURL=github.js.map","\"use strict\";\nvar __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {\n if (k2 === undefined) k2 = k;\n var desc = Object.getOwnPropertyDescriptor(m, k);\n if (!desc || (\"get\" in desc ? !m.__esModule : desc.writable || desc.configurable)) {\n desc = { enumerable: true, get: function() { return m[k]; } };\n }\n Object.defineProperty(o, k2, desc);\n}) : (function(o, m, k, k2) {\n if (k2 === undefined) k2 = k;\n o[k2] = m[k];\n}));\nvar __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) {\n Object.defineProperty(o, \"default\", { enumerable: true, value: v });\n}) : function(o, v) {\n o[\"default\"] = v;\n});\nvar __importStar = (this && this.__importStar) || function (mod) {\n if (mod && mod.__esModule) return mod;\n var result = {};\n if (mod != null) for (var k in mod) if (k !== \"default\" && Object.prototype.hasOwnProperty.call(mod, k)) __createBinding(result, mod, k);\n __setModuleDefault(result, mod);\n return result;\n};\nvar __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) {\n function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }\n return new (P || (P = Promise))(function (resolve, reject) {\n function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }\n function rejected(value) { try { step(generator[\"throw\"](value)); } catch (e) { reject(e); } }\n function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); }\n step((generator = generator.apply(thisArg, _arguments || [])).next());\n });\n};\nObject.defineProperty(exports, \"__esModule\", { value: true });\nexports.getApiBaseUrl = exports.getProxyFetch = exports.getProxyAgentDispatcher = exports.getProxyAgent = exports.getAuthString = void 0;\nconst httpClient = __importStar(require(\"@actions/http-client\"));\nconst undici_1 = require(\"undici\");\nfunction getAuthString(token, options) {\n if (!token && !options.auth) {\n throw new Error('Parameter token or opts.auth is required');\n }\n else if (token && options.auth) {\n throw new Error('Parameters token and opts.auth may not both be specified');\n }\n return typeof options.auth === 'string' ? options.auth : `token ${token}`;\n}\nexports.getAuthString = getAuthString;\nfunction getProxyAgent(destinationUrl) {\n const hc = new httpClient.HttpClient();\n return hc.getAgent(destinationUrl);\n}\nexports.getProxyAgent = getProxyAgent;\nfunction getProxyAgentDispatcher(destinationUrl) {\n const hc = new httpClient.HttpClient();\n return hc.getAgentDispatcher(destinationUrl);\n}\nexports.getProxyAgentDispatcher = getProxyAgentDispatcher;\nfunction getProxyFetch(destinationUrl) {\n const httpDispatcher = getProxyAgentDispatcher(destinationUrl);\n const proxyFetch = (url, opts) => __awaiter(this, void 0, void 0, function* () {\n return (0, undici_1.fetch)(url, Object.assign(Object.assign({}, opts), { dispatcher: httpDispatcher }));\n });\n return proxyFetch;\n}\nexports.getProxyFetch = getProxyFetch;\nfunction getApiBaseUrl() {\n return process.env['GITHUB_API_URL'] || 'https://api.github.com';\n}\nexports.getApiBaseUrl = getApiBaseUrl;\n//# sourceMappingURL=utils.js.map","\"use strict\";\nvar __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {\n if (k2 === undefined) k2 = k;\n var desc = Object.getOwnPropertyDescriptor(m, k);\n if (!desc || (\"get\" in desc ? !m.__esModule : desc.writable || desc.configurable)) {\n desc = { enumerable: true, get: function() { return m[k]; } };\n }\n Object.defineProperty(o, k2, desc);\n}) : (function(o, m, k, k2) {\n if (k2 === undefined) k2 = k;\n o[k2] = m[k];\n}));\nvar __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) {\n Object.defineProperty(o, \"default\", { enumerable: true, value: v });\n}) : function(o, v) {\n o[\"default\"] = v;\n});\nvar __importStar = (this && this.__importStar) || function (mod) {\n if (mod && mod.__esModule) return mod;\n var result = {};\n if (mod != null) for (var k in mod) if (k !== \"default\" && Object.prototype.hasOwnProperty.call(mod, k)) __createBinding(result, mod, k);\n __setModuleDefault(result, mod);\n return result;\n};\nObject.defineProperty(exports, \"__esModule\", { value: true });\nexports.getOctokitOptions = exports.GitHub = exports.defaults = exports.context = void 0;\nconst Context = __importStar(require(\"./context\"));\nconst Utils = __importStar(require(\"./internal/utils\"));\n// octokit + plugins\nconst core_1 = require(\"@octokit/core\");\nconst plugin_rest_endpoint_methods_1 = require(\"@octokit/plugin-rest-endpoint-methods\");\nconst plugin_paginate_rest_1 = require(\"@octokit/plugin-paginate-rest\");\nexports.context = new Context.Context();\nconst baseUrl = Utils.getApiBaseUrl();\nexports.defaults = {\n baseUrl,\n request: {\n agent: Utils.getProxyAgent(baseUrl),\n fetch: Utils.getProxyFetch(baseUrl)\n }\n};\nexports.GitHub = core_1.Octokit.plugin(plugin_rest_endpoint_methods_1.restEndpointMethods, plugin_paginate_rest_1.paginateRest).defaults(exports.defaults);\n/**\n * Convience function to correctly format Octokit Options to pass into the constructor.\n *\n * @param token the repo PAT or GITHUB_TOKEN\n * @param options other options to set\n */\nfunction getOctokitOptions(token, options) {\n const opts = Object.assign({}, options || {}); // Shallow clone - don't mutate the object provided by the caller\n // Auth\n const auth = Utils.getAuthString(token, opts);\n if (auth) {\n opts.auth = auth;\n }\n return opts;\n}\nexports.getOctokitOptions = getOctokitOptions;\n//# sourceMappingURL=utils.js.map","\"use strict\";\nvar __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) {\n function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }\n return new (P || (P = Promise))(function (resolve, reject) {\n function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }\n function rejected(value) { try { step(generator[\"throw\"](value)); } catch (e) { reject(e); } }\n function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); }\n step((generator = generator.apply(thisArg, _arguments || [])).next());\n });\n};\nObject.defineProperty(exports, \"__esModule\", { value: true });\nexports.PersonalAccessTokenCredentialHandler = exports.BearerCredentialHandler = exports.BasicCredentialHandler = void 0;\nclass BasicCredentialHandler {\n constructor(username, password) {\n this.username = username;\n this.password = password;\n }\n prepareRequest(options) {\n if (!options.headers) {\n throw Error('The request has no headers');\n }\n options.headers['Authorization'] = `Basic ${Buffer.from(`${this.username}:${this.password}`).toString('base64')}`;\n }\n // This handler cannot handle 401\n canHandleAuthentication() {\n return false;\n }\n handleAuthentication() {\n return __awaiter(this, void 0, void 0, function* () {\n throw new Error('not implemented');\n });\n }\n}\nexports.BasicCredentialHandler = BasicCredentialHandler;\nclass BearerCredentialHandler {\n constructor(token) {\n this.token = token;\n }\n // currently implements pre-authorization\n // TODO: support preAuth = false where it hooks on 401\n prepareRequest(options) {\n if (!options.headers) {\n throw Error('The request has no headers');\n }\n options.headers['Authorization'] = `Bearer ${this.token}`;\n }\n // This handler cannot handle 401\n canHandleAuthentication() {\n return false;\n }\n handleAuthentication() {\n return __awaiter(this, void 0, void 0, function* () {\n throw new Error('not implemented');\n });\n }\n}\nexports.BearerCredentialHandler = BearerCredentialHandler;\nclass PersonalAccessTokenCredentialHandler {\n constructor(token) {\n this.token = token;\n }\n // currently implements pre-authorization\n // TODO: support preAuth = false where it hooks on 401\n prepareRequest(options) {\n if (!options.headers) {\n throw Error('The request has no headers');\n }\n options.headers['Authorization'] = `Basic ${Buffer.from(`PAT:${this.token}`).toString('base64')}`;\n }\n // This handler cannot handle 401\n canHandleAuthentication() {\n return false;\n }\n handleAuthentication() {\n return __awaiter(this, void 0, void 0, function* () {\n throw new Error('not implemented');\n });\n }\n}\nexports.PersonalAccessTokenCredentialHandler = PersonalAccessTokenCredentialHandler;\n//# sourceMappingURL=auth.js.map","\"use strict\";\n/* eslint-disable @typescript-eslint/no-explicit-any */\nvar __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {\n if (k2 === undefined) k2 = k;\n var desc = Object.getOwnPropertyDescriptor(m, k);\n if (!desc || (\"get\" in desc ? !m.__esModule : desc.writable || desc.configurable)) {\n desc = { enumerable: true, get: function() { return m[k]; } };\n }\n Object.defineProperty(o, k2, desc);\n}) : (function(o, m, k, k2) {\n if (k2 === undefined) k2 = k;\n o[k2] = m[k];\n}));\nvar __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) {\n Object.defineProperty(o, \"default\", { enumerable: true, value: v });\n}) : function(o, v) {\n o[\"default\"] = v;\n});\nvar __importStar = (this && this.__importStar) || function (mod) {\n if (mod && mod.__esModule) return mod;\n var result = {};\n if (mod != null) for (var k in mod) if (k !== \"default\" && Object.prototype.hasOwnProperty.call(mod, k)) __createBinding(result, mod, k);\n __setModuleDefault(result, mod);\n return result;\n};\nvar __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) {\n function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }\n return new (P || (P = Promise))(function (resolve, reject) {\n function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }\n function rejected(value) { try { step(generator[\"throw\"](value)); } catch (e) { reject(e); } }\n function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); }\n step((generator = generator.apply(thisArg, _arguments || [])).next());\n });\n};\nObject.defineProperty(exports, \"__esModule\", { value: true });\nexports.HttpClient = exports.isHttps = exports.HttpClientResponse = exports.HttpClientError = exports.getProxyUrl = exports.MediaTypes = exports.Headers = exports.HttpCodes = void 0;\nconst http = __importStar(require(\"http\"));\nconst https = __importStar(require(\"https\"));\nconst pm = __importStar(require(\"./proxy\"));\nconst tunnel = __importStar(require(\"tunnel\"));\nconst undici_1 = require(\"undici\");\nvar HttpCodes;\n(function (HttpCodes) {\n HttpCodes[HttpCodes[\"OK\"] = 200] = \"OK\";\n HttpCodes[HttpCodes[\"MultipleChoices\"] = 300] = \"MultipleChoices\";\n HttpCodes[HttpCodes[\"MovedPermanently\"] = 301] = \"MovedPermanently\";\n HttpCodes[HttpCodes[\"ResourceMoved\"] = 302] = \"ResourceMoved\";\n HttpCodes[HttpCodes[\"SeeOther\"] = 303] = \"SeeOther\";\n HttpCodes[HttpCodes[\"NotModified\"] = 304] = \"NotModified\";\n HttpCodes[HttpCodes[\"UseProxy\"] = 305] = \"UseProxy\";\n HttpCodes[HttpCodes[\"SwitchProxy\"] = 306] = \"SwitchProxy\";\n HttpCodes[HttpCodes[\"TemporaryRedirect\"] = 307] = \"TemporaryRedirect\";\n HttpCodes[HttpCodes[\"PermanentRedirect\"] = 308] = \"PermanentRedirect\";\n HttpCodes[HttpCodes[\"BadRequest\"] = 400] = \"BadRequest\";\n HttpCodes[HttpCodes[\"Unauthorized\"] = 401] = \"Unauthorized\";\n HttpCodes[HttpCodes[\"PaymentRequired\"] = 402] = \"PaymentRequired\";\n HttpCodes[HttpCodes[\"Forbidden\"] = 403] = \"Forbidden\";\n HttpCodes[HttpCodes[\"NotFound\"] = 404] = \"NotFound\";\n HttpCodes[HttpCodes[\"MethodNotAllowed\"] = 405] = \"MethodNotAllowed\";\n HttpCodes[HttpCodes[\"NotAcceptable\"] = 406] = \"NotAcceptable\";\n HttpCodes[HttpCodes[\"ProxyAuthenticationRequired\"] = 407] = \"ProxyAuthenticationRequired\";\n HttpCodes[HttpCodes[\"RequestTimeout\"] = 408] = \"RequestTimeout\";\n HttpCodes[HttpCodes[\"Conflict\"] = 409] = \"Conflict\";\n HttpCodes[HttpCodes[\"Gone\"] = 410] = \"Gone\";\n HttpCodes[HttpCodes[\"TooManyRequests\"] = 429] = \"TooManyRequests\";\n HttpCodes[HttpCodes[\"InternalServerError\"] = 500] = \"InternalServerError\";\n HttpCodes[HttpCodes[\"NotImplemented\"] = 501] = \"NotImplemented\";\n HttpCodes[HttpCodes[\"BadGateway\"] = 502] = \"BadGateway\";\n HttpCodes[HttpCodes[\"ServiceUnavailable\"] = 503] = \"ServiceUnavailable\";\n HttpCodes[HttpCodes[\"GatewayTimeout\"] = 504] = \"GatewayTimeout\";\n})(HttpCodes || (exports.HttpCodes = HttpCodes = {}));\nvar Headers;\n(function (Headers) {\n Headers[\"Accept\"] = \"accept\";\n Headers[\"ContentType\"] = \"content-type\";\n})(Headers || (exports.Headers = Headers = {}));\nvar MediaTypes;\n(function (MediaTypes) {\n MediaTypes[\"ApplicationJson\"] = \"application/json\";\n})(MediaTypes || (exports.MediaTypes = MediaTypes = {}));\n/**\n * Returns the proxy URL, depending upon the supplied url and proxy environment variables.\n * @param serverUrl The server URL where the request will be sent. For example, https://api.github.com\n */\nfunction getProxyUrl(serverUrl) {\n const proxyUrl = pm.getProxyUrl(new URL(serverUrl));\n return proxyUrl ? proxyUrl.href : '';\n}\nexports.getProxyUrl = getProxyUrl;\nconst HttpRedirectCodes = [\n HttpCodes.MovedPermanently,\n HttpCodes.ResourceMoved,\n HttpCodes.SeeOther,\n HttpCodes.TemporaryRedirect,\n HttpCodes.PermanentRedirect\n];\nconst HttpResponseRetryCodes = [\n HttpCodes.BadGateway,\n HttpCodes.ServiceUnavailable,\n HttpCodes.GatewayTimeout\n];\nconst RetryableHttpVerbs = ['OPTIONS', 'GET', 'DELETE', 'HEAD'];\nconst ExponentialBackoffCeiling = 10;\nconst ExponentialBackoffTimeSlice = 5;\nclass HttpClientError extends Error {\n constructor(message, statusCode) {\n super(message);\n this.name = 'HttpClientError';\n this.statusCode = statusCode;\n Object.setPrototypeOf(this, HttpClientError.prototype);\n }\n}\nexports.HttpClientError = HttpClientError;\nclass HttpClientResponse {\n constructor(message) {\n this.message = message;\n }\n readBody() {\n return __awaiter(this, void 0, void 0, function* () {\n return new Promise((resolve) => __awaiter(this, void 0, void 0, function* () {\n let output = Buffer.alloc(0);\n this.message.on('data', (chunk) => {\n output = Buffer.concat([output, chunk]);\n });\n this.message.on('end', () => {\n resolve(output.toString());\n });\n }));\n });\n }\n readBodyBuffer() {\n return __awaiter(this, void 0, void 0, function* () {\n return new Promise((resolve) => __awaiter(this, void 0, void 0, function* () {\n const chunks = [];\n this.message.on('data', (chunk) => {\n chunks.push(chunk);\n });\n this.message.on('end', () => {\n resolve(Buffer.concat(chunks));\n });\n }));\n });\n }\n}\nexports.HttpClientResponse = HttpClientResponse;\nfunction isHttps(requestUrl) {\n const parsedUrl = new URL(requestUrl);\n return parsedUrl.protocol === 'https:';\n}\nexports.isHttps = isHttps;\nclass HttpClient {\n constructor(userAgent, handlers, requestOptions) {\n this._ignoreSslError = false;\n this._allowRedirects = true;\n this._allowRedirectDowngrade = false;\n this._maxRedirects = 50;\n this._allowRetries = false;\n this._maxRetries = 1;\n this._keepAlive = false;\n this._disposed = false;\n this.userAgent = userAgent;\n this.handlers = handlers || [];\n this.requestOptions = requestOptions;\n if (requestOptions) {\n if (requestOptions.ignoreSslError != null) {\n this._ignoreSslError = requestOptions.ignoreSslError;\n }\n this._socketTimeout = requestOptions.socketTimeout;\n if (requestOptions.allowRedirects != null) {\n this._allowRedirects = requestOptions.allowRedirects;\n }\n if (requestOptions.allowRedirectDowngrade != null) {\n this._allowRedirectDowngrade = requestOptions.allowRedirectDowngrade;\n }\n if (requestOptions.maxRedirects != null) {\n this._maxRedirects = Math.max(requestOptions.maxRedirects, 0);\n }\n if (requestOptions.keepAlive != null) {\n this._keepAlive = requestOptions.keepAlive;\n }\n if (requestOptions.allowRetries != null) {\n this._allowRetries = requestOptions.allowRetries;\n }\n if (requestOptions.maxRetries != null) {\n this._maxRetries = requestOptions.maxRetries;\n }\n }\n }\n options(requestUrl, additionalHeaders) {\n return __awaiter(this, void 0, void 0, function* () {\n return this.request('OPTIONS', requestUrl, null, additionalHeaders || {});\n });\n }\n get(requestUrl, additionalHeaders) {\n return __awaiter(this, void 0, void 0, function* () {\n return this.request('GET', requestUrl, null, additionalHeaders || {});\n });\n }\n del(requestUrl, additionalHeaders) {\n return __awaiter(this, void 0, void 0, function* () {\n return this.request('DELETE', requestUrl, null, additionalHeaders || {});\n });\n }\n post(requestUrl, data, additionalHeaders) {\n return __awaiter(this, void 0, void 0, function* () {\n return this.request('POST', requestUrl, data, additionalHeaders || {});\n });\n }\n patch(requestUrl, data, additionalHeaders) {\n return __awaiter(this, void 0, void 0, function* () {\n return this.request('PATCH', requestUrl, data, additionalHeaders || {});\n });\n }\n put(requestUrl, data, additionalHeaders) {\n return __awaiter(this, void 0, void 0, function* () {\n return this.request('PUT', requestUrl, data, additionalHeaders || {});\n });\n }\n head(requestUrl, additionalHeaders) {\n return __awaiter(this, void 0, void 0, function* () {\n return this.request('HEAD', requestUrl, null, additionalHeaders || {});\n });\n }\n sendStream(verb, requestUrl, stream, additionalHeaders) {\n return __awaiter(this, void 0, void 0, function* () {\n return this.request(verb, requestUrl, stream, additionalHeaders);\n });\n }\n /**\n * Gets a typed object from an endpoint\n * Be aware that not found returns a null. Other errors (4xx, 5xx) reject the promise\n */\n getJson(requestUrl, additionalHeaders = {}) {\n return __awaiter(this, void 0, void 0, function* () {\n additionalHeaders[Headers.Accept] = this._getExistingOrDefaultHeader(additionalHeaders, Headers.Accept, MediaTypes.ApplicationJson);\n const res = yield this.get(requestUrl, additionalHeaders);\n return this._processResponse(res, this.requestOptions);\n });\n }\n postJson(requestUrl, obj, additionalHeaders = {}) {\n return __awaiter(this, void 0, void 0, function* () {\n const data = JSON.stringify(obj, null, 2);\n additionalHeaders[Headers.Accept] = this._getExistingOrDefaultHeader(additionalHeaders, Headers.Accept, MediaTypes.ApplicationJson);\n additionalHeaders[Headers.ContentType] = this._getExistingOrDefaultHeader(additionalHeaders, Headers.ContentType, MediaTypes.ApplicationJson);\n const res = yield this.post(requestUrl, data, additionalHeaders);\n return this._processResponse(res, this.requestOptions);\n });\n }\n putJson(requestUrl, obj, additionalHeaders = {}) {\n return __awaiter(this, void 0, void 0, function* () {\n const data = JSON.stringify(obj, null, 2);\n additionalHeaders[Headers.Accept] = this._getExistingOrDefaultHeader(additionalHeaders, Headers.Accept, MediaTypes.ApplicationJson);\n additionalHeaders[Headers.ContentType] = this._getExistingOrDefaultHeader(additionalHeaders, Headers.ContentType, MediaTypes.ApplicationJson);\n const res = yield this.put(requestUrl, data, additionalHeaders);\n return this._processResponse(res, this.requestOptions);\n });\n }\n patchJson(requestUrl, obj, additionalHeaders = {}) {\n return __awaiter(this, void 0, void 0, function* () {\n const data = JSON.stringify(obj, null, 2);\n additionalHeaders[Headers.Accept] = this._getExistingOrDefaultHeader(additionalHeaders, Headers.Accept, MediaTypes.ApplicationJson);\n additionalHeaders[Headers.ContentType] = this._getExistingOrDefaultHeader(additionalHeaders, Headers.ContentType, MediaTypes.ApplicationJson);\n const res = yield this.patch(requestUrl, data, additionalHeaders);\n return this._processResponse(res, this.requestOptions);\n });\n }\n /**\n * Makes a raw http request.\n * All other methods such as get, post, patch, and request ultimately call this.\n * Prefer get, del, post and patch\n */\n request(verb, requestUrl, data, headers) {\n return __awaiter(this, void 0, void 0, function* () {\n if (this._disposed) {\n throw new Error('Client has already been disposed.');\n }\n const parsedUrl = new URL(requestUrl);\n let info = this._prepareRequest(verb, parsedUrl, headers);\n // Only perform retries on reads since writes may not be idempotent.\n const maxTries = this._allowRetries && RetryableHttpVerbs.includes(verb)\n ? this._maxRetries + 1\n : 1;\n let numTries = 0;\n let response;\n do {\n response = yield this.requestRaw(info, data);\n // Check if it's an authentication challenge\n if (response &&\n response.message &&\n response.message.statusCode === HttpCodes.Unauthorized) {\n let authenticationHandler;\n for (const handler of this.handlers) {\n if (handler.canHandleAuthentication(response)) {\n authenticationHandler = handler;\n break;\n }\n }\n if (authenticationHandler) {\n return authenticationHandler.handleAuthentication(this, info, data);\n }\n else {\n // We have received an unauthorized response but have no handlers to handle it.\n // Let the response return to the caller.\n return response;\n }\n }\n let redirectsRemaining = this._maxRedirects;\n while (response.message.statusCode &&\n HttpRedirectCodes.includes(response.message.statusCode) &&\n this._allowRedirects &&\n redirectsRemaining > 0) {\n const redirectUrl = response.message.headers['location'];\n if (!redirectUrl) {\n // if there's no location to redirect to, we won't\n break;\n }\n const parsedRedirectUrl = new URL(redirectUrl);\n if (parsedUrl.protocol === 'https:' &&\n parsedUrl.protocol !== parsedRedirectUrl.protocol &&\n !this._allowRedirectDowngrade) {\n throw new Error('Redirect from HTTPS to HTTP protocol. This downgrade is not allowed for security reasons. If you want to allow this behavior, set the allowRedirectDowngrade option to true.');\n }\n // we need to finish reading the response before reassigning response\n // which will leak the open socket.\n yield response.readBody();\n // strip authorization header if redirected to a different hostname\n if (parsedRedirectUrl.hostname !== parsedUrl.hostname) {\n for (const header in headers) {\n // header names are case insensitive\n if (header.toLowerCase() === 'authorization') {\n delete headers[header];\n }\n }\n }\n // let's make the request with the new redirectUrl\n info = this._prepareRequest(verb, parsedRedirectUrl, headers);\n response = yield this.requestRaw(info, data);\n redirectsRemaining--;\n }\n if (!response.message.statusCode ||\n !HttpResponseRetryCodes.includes(response.message.statusCode)) {\n // If not a retry code, return immediately instead of retrying\n return response;\n }\n numTries += 1;\n if (numTries < maxTries) {\n yield response.readBody();\n yield this._performExponentialBackoff(numTries);\n }\n } while (numTries < maxTries);\n return response;\n });\n }\n /**\n * Needs to be called if keepAlive is set to true in request options.\n */\n dispose() {\n if (this._agent) {\n this._agent.destroy();\n }\n this._disposed = true;\n }\n /**\n * Raw request.\n * @param info\n * @param data\n */\n requestRaw(info, data) {\n return __awaiter(this, void 0, void 0, function* () {\n return new Promise((resolve, reject) => {\n function callbackForResult(err, res) {\n if (err) {\n reject(err);\n }\n else if (!res) {\n // If `err` is not passed, then `res` must be passed.\n reject(new Error('Unknown error'));\n }\n else {\n resolve(res);\n }\n }\n this.requestRawWithCallback(info, data, callbackForResult);\n });\n });\n }\n /**\n * Raw request with callback.\n * @param info\n * @param data\n * @param onResult\n */\n requestRawWithCallback(info, data, onResult) {\n if (typeof data === 'string') {\n if (!info.options.headers) {\n info.options.headers = {};\n }\n info.options.headers['Content-Length'] = Buffer.byteLength(data, 'utf8');\n }\n let callbackCalled = false;\n function handleResult(err, res) {\n if (!callbackCalled) {\n callbackCalled = true;\n onResult(err, res);\n }\n }\n const req = info.httpModule.request(info.options, (msg) => {\n const res = new HttpClientResponse(msg);\n handleResult(undefined, res);\n });\n let socket;\n req.on('socket', sock => {\n socket = sock;\n });\n // If we ever get disconnected, we want the socket to timeout eventually\n req.setTimeout(this._socketTimeout || 3 * 60000, () => {\n if (socket) {\n socket.end();\n }\n handleResult(new Error(`Request timeout: ${info.options.path}`));\n });\n req.on('error', function (err) {\n // err has statusCode property\n // res should have headers\n handleResult(err);\n });\n if (data && typeof data === 'string') {\n req.write(data, 'utf8');\n }\n if (data && typeof data !== 'string') {\n data.on('close', function () {\n req.end();\n });\n data.pipe(req);\n }\n else {\n req.end();\n }\n }\n /**\n * Gets an http agent. This function is useful when you need an http agent that handles\n * routing through a proxy server - depending upon the url and proxy environment variables.\n * @param serverUrl The server URL where the request will be sent. For example, https://api.github.com\n */\n getAgent(serverUrl) {\n const parsedUrl = new URL(serverUrl);\n return this._getAgent(parsedUrl);\n }\n getAgentDispatcher(serverUrl) {\n const parsedUrl = new URL(serverUrl);\n const proxyUrl = pm.getProxyUrl(parsedUrl);\n const useProxy = proxyUrl && proxyUrl.hostname;\n if (!useProxy) {\n return;\n }\n return this._getProxyAgentDispatcher(parsedUrl, proxyUrl);\n }\n _prepareRequest(method, requestUrl, headers) {\n const info = {};\n info.parsedUrl = requestUrl;\n const usingSsl = info.parsedUrl.protocol === 'https:';\n info.httpModule = usingSsl ? https : http;\n const defaultPort = usingSsl ? 443 : 80;\n info.options = {};\n info.options.host = info.parsedUrl.hostname;\n info.options.port = info.parsedUrl.port\n ? parseInt(info.parsedUrl.port)\n : defaultPort;\n info.options.path =\n (info.parsedUrl.pathname || '') + (info.parsedUrl.search || '');\n info.options.method = method;\n info.options.headers = this._mergeHeaders(headers);\n if (this.userAgent != null) {\n info.options.headers['user-agent'] = this.userAgent;\n }\n info.options.agent = this._getAgent(info.parsedUrl);\n // gives handlers an opportunity to participate\n if (this.handlers) {\n for (const handler of this.handlers) {\n handler.prepareRequest(info.options);\n }\n }\n return info;\n }\n _mergeHeaders(headers) {\n if (this.requestOptions && this.requestOptions.headers) {\n return Object.assign({}, lowercaseKeys(this.requestOptions.headers), lowercaseKeys(headers || {}));\n }\n return lowercaseKeys(headers || {});\n }\n _getExistingOrDefaultHeader(additionalHeaders, header, _default) {\n let clientHeader;\n if (this.requestOptions && this.requestOptions.headers) {\n clientHeader = lowercaseKeys(this.requestOptions.headers)[header];\n }\n return additionalHeaders[header] || clientHeader || _default;\n }\n _getAgent(parsedUrl) {\n let agent;\n const proxyUrl = pm.getProxyUrl(parsedUrl);\n const useProxy = proxyUrl && proxyUrl.hostname;\n if (this._keepAlive && useProxy) {\n agent = this._proxyAgent;\n }\n if (!useProxy) {\n agent = this._agent;\n }\n // if agent is already assigned use that agent.\n if (agent) {\n return agent;\n }\n const usingSsl = parsedUrl.protocol === 'https:';\n let maxSockets = 100;\n if (this.requestOptions) {\n maxSockets = this.requestOptions.maxSockets || http.globalAgent.maxSockets;\n }\n // This is `useProxy` again, but we need to check `proxyURl` directly for TypeScripts's flow analysis.\n if (proxyUrl && proxyUrl.hostname) {\n const agentOptions = {\n maxSockets,\n keepAlive: this._keepAlive,\n proxy: Object.assign(Object.assign({}, ((proxyUrl.username || proxyUrl.password) && {\n proxyAuth: `${proxyUrl.username}:${proxyUrl.password}`\n })), { host: proxyUrl.hostname, port: proxyUrl.port })\n };\n let tunnelAgent;\n const overHttps = proxyUrl.protocol === 'https:';\n if (usingSsl) {\n tunnelAgent = overHttps ? tunnel.httpsOverHttps : tunnel.httpsOverHttp;\n }\n else {\n tunnelAgent = overHttps ? tunnel.httpOverHttps : tunnel.httpOverHttp;\n }\n agent = tunnelAgent(agentOptions);\n this._proxyAgent = agent;\n }\n // if tunneling agent isn't assigned create a new agent\n if (!agent) {\n const options = { keepAlive: this._keepAlive, maxSockets };\n agent = usingSsl ? new https.Agent(options) : new http.Agent(options);\n this._agent = agent;\n }\n if (usingSsl && this._ignoreSslError) {\n // we don't want to set NODE_TLS_REJECT_UNAUTHORIZED=0 since that will affect request for entire process\n // http.RequestOptions doesn't expose a way to modify RequestOptions.agent.options\n // we have to cast it to any and change it directly\n agent.options = Object.assign(agent.options || {}, {\n rejectUnauthorized: false\n });\n }\n return agent;\n }\n _getProxyAgentDispatcher(parsedUrl, proxyUrl) {\n let proxyAgent;\n if (this._keepAlive) {\n proxyAgent = this._proxyAgentDispatcher;\n }\n // if agent is already assigned use that agent.\n if (proxyAgent) {\n return proxyAgent;\n }\n const usingSsl = parsedUrl.protocol === 'https:';\n proxyAgent = new undici_1.ProxyAgent(Object.assign({ uri: proxyUrl.href, pipelining: !this._keepAlive ? 0 : 1 }, ((proxyUrl.username || proxyUrl.password) && {\n token: `${proxyUrl.username}:${proxyUrl.password}`\n })));\n this._proxyAgentDispatcher = proxyAgent;\n if (usingSsl && this._ignoreSslError) {\n // we don't want to set NODE_TLS_REJECT_UNAUTHORIZED=0 since that will affect request for entire process\n // http.RequestOptions doesn't expose a way to modify RequestOptions.agent.options\n // we have to cast it to any and change it directly\n proxyAgent.options = Object.assign(proxyAgent.options.requestTls || {}, {\n rejectUnauthorized: false\n });\n }\n return proxyAgent;\n }\n _performExponentialBackoff(retryNumber) {\n return __awaiter(this, void 0, void 0, function* () {\n retryNumber = Math.min(ExponentialBackoffCeiling, retryNumber);\n const ms = ExponentialBackoffTimeSlice * Math.pow(2, retryNumber);\n return new Promise(resolve => setTimeout(() => resolve(), ms));\n });\n }\n _processResponse(res, options) {\n return __awaiter(this, void 0, void 0, function* () {\n return new Promise((resolve, reject) => __awaiter(this, void 0, void 0, function* () {\n const statusCode = res.message.statusCode || 0;\n const response = {\n statusCode,\n result: null,\n headers: {}\n };\n // not found leads to null obj returned\n if (statusCode === HttpCodes.NotFound) {\n resolve(response);\n }\n // get the result from the body\n function dateTimeDeserializer(key, value) {\n if (typeof value === 'string') {\n const a = new Date(value);\n if (!isNaN(a.valueOf())) {\n return a;\n }\n }\n return value;\n }\n let obj;\n let contents;\n try {\n contents = yield res.readBody();\n if (contents && contents.length > 0) {\n if (options && options.deserializeDates) {\n obj = JSON.parse(contents, dateTimeDeserializer);\n }\n else {\n obj = JSON.parse(contents);\n }\n response.result = obj;\n }\n response.headers = res.message.headers;\n }\n catch (err) {\n // Invalid resource (contents not json); leaving result obj null\n }\n // note that 3xx redirects are handled by the http layer.\n if (statusCode > 299) {\n let msg;\n // if exception/error in body, attempt to get better error\n if (obj && obj.message) {\n msg = obj.message;\n }\n else if (contents && contents.length > 0) {\n // it may be the case that the exception is in the body message as string\n msg = contents;\n }\n else {\n msg = `Failed request: (${statusCode})`;\n }\n const err = new HttpClientError(msg, statusCode);\n err.result = response.result;\n reject(err);\n }\n else {\n resolve(response);\n }\n }));\n });\n }\n}\nexports.HttpClient = HttpClient;\nconst lowercaseKeys = (obj) => Object.keys(obj).reduce((c, k) => ((c[k.toLowerCase()] = obj[k]), c), {});\n//# sourceMappingURL=index.js.map","\"use strict\";\nObject.defineProperty(exports, \"__esModule\", { value: true });\nexports.checkBypass = exports.getProxyUrl = void 0;\nfunction getProxyUrl(reqUrl) {\n const usingSsl = reqUrl.protocol === 'https:';\n if (checkBypass(reqUrl)) {\n return undefined;\n }\n const proxyVar = (() => {\n if (usingSsl) {\n return process.env['https_proxy'] || process.env['HTTPS_PROXY'];\n }\n else {\n return process.env['http_proxy'] || process.env['HTTP_PROXY'];\n }\n })();\n if (proxyVar) {\n try {\n return new URL(proxyVar);\n }\n catch (_a) {\n if (!proxyVar.startsWith('http://') && !proxyVar.startsWith('https://'))\n return new URL(`http://${proxyVar}`);\n }\n }\n else {\n return undefined;\n }\n}\nexports.getProxyUrl = getProxyUrl;\nfunction checkBypass(reqUrl) {\n if (!reqUrl.hostname) {\n return false;\n }\n const reqHost = reqUrl.hostname;\n if (isLoopbackAddress(reqHost)) {\n return true;\n }\n const noProxy = process.env['no_proxy'] || process.env['NO_PROXY'] || '';\n if (!noProxy) {\n return false;\n }\n // Determine the request port\n let reqPort;\n if (reqUrl.port) {\n reqPort = Number(reqUrl.port);\n }\n else if (reqUrl.protocol === 'http:') {\n reqPort = 80;\n }\n else if (reqUrl.protocol === 'https:') {\n reqPort = 443;\n }\n // Format the request hostname and hostname with port\n const upperReqHosts = [reqUrl.hostname.toUpperCase()];\n if (typeof reqPort === 'number') {\n upperReqHosts.push(`${upperReqHosts[0]}:${reqPort}`);\n }\n // Compare request host against noproxy\n for (const upperNoProxyItem of noProxy\n .split(',')\n .map(x => x.trim().toUpperCase())\n .filter(x => x)) {\n if (upperNoProxyItem === '*' ||\n upperReqHosts.some(x => x === upperNoProxyItem ||\n x.endsWith(`.${upperNoProxyItem}`) ||\n (upperNoProxyItem.startsWith('.') &&\n x.endsWith(`${upperNoProxyItem}`)))) {\n return true;\n }\n }\n return false;\n}\nexports.checkBypass = checkBypass;\nfunction isLoopbackAddress(host) {\n const hostLower = host.toLowerCase();\n return (hostLower === 'localhost' ||\n hostLower.startsWith('127.') ||\n hostLower.startsWith('[::1]') ||\n hostLower.startsWith('[0:0:0:0:0:0:0:1]'));\n}\n//# sourceMappingURL=proxy.js.map","\"use strict\";\nvar __defProp = Object.defineProperty;\nvar __getOwnPropDesc = Object.getOwnPropertyDescriptor;\nvar __getOwnPropNames = Object.getOwnPropertyNames;\nvar __hasOwnProp = Object.prototype.hasOwnProperty;\nvar __export = (target, all) => {\n for (var name in all)\n __defProp(target, name, { get: all[name], enumerable: true });\n};\nvar __copyProps = (to, from, except, desc) => {\n if (from && typeof from === \"object\" || typeof from === \"function\") {\n for (let key of __getOwnPropNames(from))\n if (!__hasOwnProp.call(to, key) && key !== except)\n __defProp(to, key, { get: () => from[key], enumerable: !(desc = __getOwnPropDesc(from, key)) || desc.enumerable });\n }\n return to;\n};\nvar __toCommonJS = (mod) => __copyProps(__defProp({}, \"__esModule\", { value: true }), mod);\n\n// pkg/dist-src/index.js\nvar dist_src_exports = {};\n__export(dist_src_exports, {\n createTokenAuth: () => createTokenAuth\n});\nmodule.exports = __toCommonJS(dist_src_exports);\n\n// pkg/dist-src/auth.js\nvar REGEX_IS_INSTALLATION_LEGACY = /^v1\\./;\nvar REGEX_IS_INSTALLATION = /^ghs_/;\nvar REGEX_IS_USER_TO_SERVER = /^ghu_/;\nasync function auth(token) {\n const isApp = token.split(/\\./).length === 3;\n const isInstallation = REGEX_IS_INSTALLATION_LEGACY.test(token) || REGEX_IS_INSTALLATION.test(token);\n const isUserToServer = REGEX_IS_USER_TO_SERVER.test(token);\n const tokenType = isApp ? \"app\" : isInstallation ? \"installation\" : isUserToServer ? \"user-to-server\" : \"oauth\";\n return {\n type: \"token\",\n token,\n tokenType\n };\n}\n\n// pkg/dist-src/with-authorization-prefix.js\nfunction withAuthorizationPrefix(token) {\n if (token.split(/\\./).length === 3) {\n return `bearer ${token}`;\n }\n return `token ${token}`;\n}\n\n// pkg/dist-src/hook.js\nasync function hook(token, request, route, parameters) {\n const endpoint = request.endpoint.merge(\n route,\n parameters\n );\n endpoint.headers.authorization = withAuthorizationPrefix(token);\n return request(endpoint);\n}\n\n// pkg/dist-src/index.js\nvar createTokenAuth = function createTokenAuth2(token) {\n if (!token) {\n throw new Error(\"[@octokit/auth-token] No token passed to createTokenAuth\");\n }\n if (typeof token !== \"string\") {\n throw new Error(\n \"[@octokit/auth-token] Token passed to createTokenAuth is not a string\"\n );\n }\n token = token.replace(/^(token|bearer) +/i, \"\");\n return Object.assign(auth.bind(null, token), {\n hook: hook.bind(null, token)\n });\n};\n// Annotate the CommonJS export names for ESM import in node:\n0 && (module.exports = {\n createTokenAuth\n});\n","\"use strict\";\nvar __defProp = Object.defineProperty;\nvar __getOwnPropDesc = Object.getOwnPropertyDescriptor;\nvar __getOwnPropNames = Object.getOwnPropertyNames;\nvar __hasOwnProp = Object.prototype.hasOwnProperty;\nvar __export = (target, all) => {\n for (var name in all)\n __defProp(target, name, { get: all[name], enumerable: true });\n};\nvar __copyProps = (to, from, except, desc) => {\n if (from && typeof from === \"object\" || typeof from === \"function\") {\n for (let key of __getOwnPropNames(from))\n if (!__hasOwnProp.call(to, key) && key !== except)\n __defProp(to, key, { get: () => from[key], enumerable: !(desc = __getOwnPropDesc(from, key)) || desc.enumerable });\n }\n return to;\n};\nvar __toCommonJS = (mod) => __copyProps(__defProp({}, \"__esModule\", { value: true }), mod);\n\n// pkg/dist-src/index.js\nvar dist_src_exports = {};\n__export(dist_src_exports, {\n Octokit: () => Octokit\n});\nmodule.exports = __toCommonJS(dist_src_exports);\nvar import_universal_user_agent = require(\"universal-user-agent\");\nvar import_before_after_hook = require(\"before-after-hook\");\nvar import_request = require(\"@octokit/request\");\nvar import_graphql = require(\"@octokit/graphql\");\nvar import_auth_token = require(\"@octokit/auth-token\");\n\n// pkg/dist-src/version.js\nvar VERSION = \"5.1.0\";\n\n// pkg/dist-src/index.js\nvar noop = () => {\n};\nvar consoleWarn = console.warn.bind(console);\nvar consoleError = console.error.bind(console);\nvar userAgentTrail = `octokit-core.js/${VERSION} ${(0, import_universal_user_agent.getUserAgent)()}`;\nvar Octokit = class {\n static {\n this.VERSION = VERSION;\n }\n static defaults(defaults) {\n const OctokitWithDefaults = class extends this {\n constructor(...args) {\n const options = args[0] || {};\n if (typeof defaults === \"function\") {\n super(defaults(options));\n return;\n }\n super(\n Object.assign(\n {},\n defaults,\n options,\n options.userAgent && defaults.userAgent ? {\n userAgent: `${options.userAgent} ${defaults.userAgent}`\n } : null\n )\n );\n }\n };\n return OctokitWithDefaults;\n }\n static {\n this.plugins = [];\n }\n /**\n * Attach a plugin (or many) to your Octokit instance.\n *\n * @example\n * const API = Octokit.plugin(plugin1, plugin2, plugin3, ...)\n */\n static plugin(...newPlugins) {\n const currentPlugins = this.plugins;\n const NewOctokit = class extends this {\n static {\n this.plugins = currentPlugins.concat(\n newPlugins.filter((plugin) => !currentPlugins.includes(plugin))\n );\n }\n };\n return NewOctokit;\n }\n constructor(options = {}) {\n const hook = new import_before_after_hook.Collection();\n const requestDefaults = {\n baseUrl: import_request.request.endpoint.DEFAULTS.baseUrl,\n headers: {},\n request: Object.assign({}, options.request, {\n // @ts-ignore internal usage only, no need to type\n hook: hook.bind(null, \"request\")\n }),\n mediaType: {\n previews: [],\n format: \"\"\n }\n };\n requestDefaults.headers[\"user-agent\"] = options.userAgent ? `${options.userAgent} ${userAgentTrail}` : userAgentTrail;\n if (options.baseUrl) {\n requestDefaults.baseUrl = options.baseUrl;\n }\n if (options.previews) {\n requestDefaults.mediaType.previews = options.previews;\n }\n if (options.timeZone) {\n requestDefaults.headers[\"time-zone\"] = options.timeZone;\n }\n this.request = import_request.request.defaults(requestDefaults);\n this.graphql = (0, import_graphql.withCustomRequest)(this.request).defaults(requestDefaults);\n this.log = Object.assign(\n {\n debug: noop,\n info: noop,\n warn: consoleWarn,\n error: consoleError\n },\n options.log\n );\n this.hook = hook;\n if (!options.authStrategy) {\n if (!options.auth) {\n this.auth = async () => ({\n type: \"unauthenticated\"\n });\n } else {\n const auth = (0, import_auth_token.createTokenAuth)(options.auth);\n hook.wrap(\"request\", auth.hook);\n this.auth = auth;\n }\n } else {\n const { authStrategy, ...otherOptions } = options;\n const auth = authStrategy(\n Object.assign(\n {\n request: this.request,\n log: this.log,\n // we pass the current octokit instance as well as its constructor options\n // to allow for authentication strategies that return a new octokit instance\n // that shares the same internal state as the current one. The original\n // requirement for this was the \"event-octokit\" authentication strategy\n // of https://github.com/probot/octokit-auth-probot.\n octokit: this,\n octokitOptions: otherOptions\n },\n options.auth\n )\n );\n hook.wrap(\"request\", auth.hook);\n this.auth = auth;\n }\n const classConstructor = this.constructor;\n for (let i = 0; i < classConstructor.plugins.length; ++i) {\n Object.assign(this, classConstructor.plugins[i](this, options));\n }\n }\n};\n// Annotate the CommonJS export names for ESM import in node:\n0 && (module.exports = {\n Octokit\n});\n","\"use strict\";\nvar __defProp = Object.defineProperty;\nvar __getOwnPropDesc = Object.getOwnPropertyDescriptor;\nvar __getOwnPropNames = Object.getOwnPropertyNames;\nvar __hasOwnProp = Object.prototype.hasOwnProperty;\nvar __export = (target, all) => {\n for (var name in all)\n __defProp(target, name, { get: all[name], enumerable: true });\n};\nvar __copyProps = (to, from, except, desc) => {\n if (from && typeof from === \"object\" || typeof from === \"function\") {\n for (let key of __getOwnPropNames(from))\n if (!__hasOwnProp.call(to, key) && key !== except)\n __defProp(to, key, { get: () => from[key], enumerable: !(desc = __getOwnPropDesc(from, key)) || desc.enumerable });\n }\n return to;\n};\nvar __toCommonJS = (mod) => __copyProps(__defProp({}, \"__esModule\", { value: true }), mod);\n\n// pkg/dist-src/index.js\nvar dist_src_exports = {};\n__export(dist_src_exports, {\n endpoint: () => endpoint\n});\nmodule.exports = __toCommonJS(dist_src_exports);\n\n// pkg/dist-src/defaults.js\nvar import_universal_user_agent = require(\"universal-user-agent\");\n\n// pkg/dist-src/version.js\nvar VERSION = \"9.0.4\";\n\n// pkg/dist-src/defaults.js\nvar userAgent = `octokit-endpoint.js/${VERSION} ${(0, import_universal_user_agent.getUserAgent)()}`;\nvar DEFAULTS = {\n method: \"GET\",\n baseUrl: \"https://api.github.com\",\n headers: {\n accept: \"application/vnd.github.v3+json\",\n \"user-agent\": userAgent\n },\n mediaType: {\n format: \"\"\n }\n};\n\n// pkg/dist-src/util/lowercase-keys.js\nfunction lowercaseKeys(object) {\n if (!object) {\n return {};\n }\n return Object.keys(object).reduce((newObj, key) => {\n newObj[key.toLowerCase()] = object[key];\n return newObj;\n }, {});\n}\n\n// pkg/dist-src/util/is-plain-object.js\nfunction isPlainObject(value) {\n if (typeof value !== \"object\" || value === null)\n return false;\n if (Object.prototype.toString.call(value) !== \"[object Object]\")\n return false;\n const proto = Object.getPrototypeOf(value);\n if (proto === null)\n return true;\n const Ctor = Object.prototype.hasOwnProperty.call(proto, \"constructor\") && proto.constructor;\n return typeof Ctor === \"function\" && Ctor instanceof Ctor && Function.prototype.call(Ctor) === Function.prototype.call(value);\n}\n\n// pkg/dist-src/util/merge-deep.js\nfunction mergeDeep(defaults, options) {\n const result = Object.assign({}, defaults);\n Object.keys(options).forEach((key) => {\n if (isPlainObject(options[key])) {\n if (!(key in defaults))\n Object.assign(result, { [key]: options[key] });\n else\n result[key] = mergeDeep(defaults[key], options[key]);\n } else {\n Object.assign(result, { [key]: options[key] });\n }\n });\n return result;\n}\n\n// pkg/dist-src/util/remove-undefined-properties.js\nfunction removeUndefinedProperties(obj) {\n for (const key in obj) {\n if (obj[key] === void 0) {\n delete obj[key];\n }\n }\n return obj;\n}\n\n// pkg/dist-src/merge.js\nfunction merge(defaults, route, options) {\n if (typeof route === \"string\") {\n let [method, url] = route.split(\" \");\n options = Object.assign(url ? { method, url } : { url: method }, options);\n } else {\n options = Object.assign({}, route);\n }\n options.headers = lowercaseKeys(options.headers);\n removeUndefinedProperties(options);\n removeUndefinedProperties(options.headers);\n const mergedOptions = mergeDeep(defaults || {}, options);\n if (options.url === \"/graphql\") {\n if (defaults && defaults.mediaType.previews?.length) {\n mergedOptions.mediaType.previews = defaults.mediaType.previews.filter(\n (preview) => !mergedOptions.mediaType.previews.includes(preview)\n ).concat(mergedOptions.mediaType.previews);\n }\n mergedOptions.mediaType.previews = (mergedOptions.mediaType.previews || []).map((preview) => preview.replace(/-preview/, \"\"));\n }\n return mergedOptions;\n}\n\n// pkg/dist-src/util/add-query-parameters.js\nfunction addQueryParameters(url, parameters) {\n const separator = /\\?/.test(url) ? \"&\" : \"?\";\n const names = Object.keys(parameters);\n if (names.length === 0) {\n return url;\n }\n return url + separator + names.map((name) => {\n if (name === \"q\") {\n return \"q=\" + parameters.q.split(\"+\").map(encodeURIComponent).join(\"+\");\n }\n return `${name}=${encodeURIComponent(parameters[name])}`;\n }).join(\"&\");\n}\n\n// pkg/dist-src/util/extract-url-variable-names.js\nvar urlVariableRegex = /\\{[^}]+\\}/g;\nfunction removeNonChars(variableName) {\n return variableName.replace(/^\\W+|\\W+$/g, \"\").split(/,/);\n}\nfunction extractUrlVariableNames(url) {\n const matches = url.match(urlVariableRegex);\n if (!matches) {\n return [];\n }\n return matches.map(removeNonChars).reduce((a, b) => a.concat(b), []);\n}\n\n// pkg/dist-src/util/omit.js\nfunction omit(object, keysToOmit) {\n const result = { __proto__: null };\n for (const key of Object.keys(object)) {\n if (keysToOmit.indexOf(key) === -1) {\n result[key] = object[key];\n }\n }\n return result;\n}\n\n// pkg/dist-src/util/url-template.js\nfunction encodeReserved(str) {\n return str.split(/(%[0-9A-Fa-f]{2})/g).map(function(part) {\n if (!/%[0-9A-Fa-f]/.test(part)) {\n part = encodeURI(part).replace(/%5B/g, \"[\").replace(/%5D/g, \"]\");\n }\n return part;\n }).join(\"\");\n}\nfunction encodeUnreserved(str) {\n return encodeURIComponent(str).replace(/[!'()*]/g, function(c) {\n return \"%\" + c.charCodeAt(0).toString(16).toUpperCase();\n });\n}\nfunction encodeValue(operator, value, key) {\n value = operator === \"+\" || operator === \"#\" ? encodeReserved(value) : encodeUnreserved(value);\n if (key) {\n return encodeUnreserved(key) + \"=\" + value;\n } else {\n return value;\n }\n}\nfunction isDefined(value) {\n return value !== void 0 && value !== null;\n}\nfunction isKeyOperator(operator) {\n return operator === \";\" || operator === \"&\" || operator === \"?\";\n}\nfunction getValues(context, operator, key, modifier) {\n var value = context[key], result = [];\n if (isDefined(value) && value !== \"\") {\n if (typeof value === \"string\" || typeof value === \"number\" || typeof value === \"boolean\") {\n value = value.toString();\n if (modifier && modifier !== \"*\") {\n value = value.substring(0, parseInt(modifier, 10));\n }\n result.push(\n encodeValue(operator, value, isKeyOperator(operator) ? key : \"\")\n );\n } else {\n if (modifier === \"*\") {\n if (Array.isArray(value)) {\n value.filter(isDefined).forEach(function(value2) {\n result.push(\n encodeValue(operator, value2, isKeyOperator(operator) ? key : \"\")\n );\n });\n } else {\n Object.keys(value).forEach(function(k) {\n if (isDefined(value[k])) {\n result.push(encodeValue(operator, value[k], k));\n }\n });\n }\n } else {\n const tmp = [];\n if (Array.isArray(value)) {\n value.filter(isDefined).forEach(function(value2) {\n tmp.push(encodeValue(operator, value2));\n });\n } else {\n Object.keys(value).forEach(function(k) {\n if (isDefined(value[k])) {\n tmp.push(encodeUnreserved(k));\n tmp.push(encodeValue(operator, value[k].toString()));\n }\n });\n }\n if (isKeyOperator(operator)) {\n result.push(encodeUnreserved(key) + \"=\" + tmp.join(\",\"));\n } else if (tmp.length !== 0) {\n result.push(tmp.join(\",\"));\n }\n }\n }\n } else {\n if (operator === \";\") {\n if (isDefined(value)) {\n result.push(encodeUnreserved(key));\n }\n } else if (value === \"\" && (operator === \"&\" || operator === \"?\")) {\n result.push(encodeUnreserved(key) + \"=\");\n } else if (value === \"\") {\n result.push(\"\");\n }\n }\n return result;\n}\nfunction parseUrl(template) {\n return {\n expand: expand.bind(null, template)\n };\n}\nfunction expand(template, context) {\n var operators = [\"+\", \"#\", \".\", \"/\", \";\", \"?\", \"&\"];\n template = template.replace(\n /\\{([^\\{\\}]+)\\}|([^\\{\\}]+)/g,\n function(_, expression, literal) {\n if (expression) {\n let operator = \"\";\n const values = [];\n if (operators.indexOf(expression.charAt(0)) !== -1) {\n operator = expression.charAt(0);\n expression = expression.substr(1);\n }\n expression.split(/,/g).forEach(function(variable) {\n var tmp = /([^:\\*]*)(?::(\\d+)|(\\*))?/.exec(variable);\n values.push(getValues(context, operator, tmp[1], tmp[2] || tmp[3]));\n });\n if (operator && operator !== \"+\") {\n var separator = \",\";\n if (operator === \"?\") {\n separator = \"&\";\n } else if (operator !== \"#\") {\n separator = operator;\n }\n return (values.length !== 0 ? operator : \"\") + values.join(separator);\n } else {\n return values.join(\",\");\n }\n } else {\n return encodeReserved(literal);\n }\n }\n );\n if (template === \"/\") {\n return template;\n } else {\n return template.replace(/\\/$/, \"\");\n }\n}\n\n// pkg/dist-src/parse.js\nfunction parse(options) {\n let method = options.method.toUpperCase();\n let url = (options.url || \"/\").replace(/:([a-z]\\w+)/g, \"{$1}\");\n let headers = Object.assign({}, options.headers);\n let body;\n let parameters = omit(options, [\n \"method\",\n \"baseUrl\",\n \"url\",\n \"headers\",\n \"request\",\n \"mediaType\"\n ]);\n const urlVariableNames = extractUrlVariableNames(url);\n url = parseUrl(url).expand(parameters);\n if (!/^http/.test(url)) {\n url = options.baseUrl + url;\n }\n const omittedParameters = Object.keys(options).filter((option) => urlVariableNames.includes(option)).concat(\"baseUrl\");\n const remainingParameters = omit(parameters, omittedParameters);\n const isBinaryRequest = /application\\/octet-stream/i.test(headers.accept);\n if (!isBinaryRequest) {\n if (options.mediaType.format) {\n headers.accept = headers.accept.split(/,/).map(\n (format) => format.replace(\n /application\\/vnd(\\.\\w+)(\\.v3)?(\\.\\w+)?(\\+json)?$/,\n `application/vnd$1$2.${options.mediaType.format}`\n )\n ).join(\",\");\n }\n if (url.endsWith(\"/graphql\")) {\n if (options.mediaType.previews?.length) {\n const previewsFromAcceptHeader = headers.accept.match(/[\\w-]+(?=-preview)/g) || [];\n headers.accept = previewsFromAcceptHeader.concat(options.mediaType.previews).map((preview) => {\n const format = options.mediaType.format ? `.${options.mediaType.format}` : \"+json\";\n return `application/vnd.github.${preview}-preview${format}`;\n }).join(\",\");\n }\n }\n }\n if ([\"GET\", \"HEAD\"].includes(method)) {\n url = addQueryParameters(url, remainingParameters);\n } else {\n if (\"data\" in remainingParameters) {\n body = remainingParameters.data;\n } else {\n if (Object.keys(remainingParameters).length) {\n body = remainingParameters;\n }\n }\n }\n if (!headers[\"content-type\"] && typeof body !== \"undefined\") {\n headers[\"content-type\"] = \"application/json; charset=utf-8\";\n }\n if ([\"PATCH\", \"PUT\"].includes(method) && typeof body === \"undefined\") {\n body = \"\";\n }\n return Object.assign(\n { method, url, headers },\n typeof body !== \"undefined\" ? { body } : null,\n options.request ? { request: options.request } : null\n );\n}\n\n// pkg/dist-src/endpoint-with-defaults.js\nfunction endpointWithDefaults(defaults, route, options) {\n return parse(merge(defaults, route, options));\n}\n\n// pkg/dist-src/with-defaults.js\nfunction withDefaults(oldDefaults, newDefaults) {\n const DEFAULTS2 = merge(oldDefaults, newDefaults);\n const endpoint2 = endpointWithDefaults.bind(null, DEFAULTS2);\n return Object.assign(endpoint2, {\n DEFAULTS: DEFAULTS2,\n defaults: withDefaults.bind(null, DEFAULTS2),\n merge: merge.bind(null, DEFAULTS2),\n parse\n });\n}\n\n// pkg/dist-src/index.js\nvar endpoint = withDefaults(null, DEFAULTS);\n// Annotate the CommonJS export names for ESM import in node:\n0 && (module.exports = {\n endpoint\n});\n","\"use strict\";\nvar __defProp = Object.defineProperty;\nvar __getOwnPropDesc = Object.getOwnPropertyDescriptor;\nvar __getOwnPropNames = Object.getOwnPropertyNames;\nvar __hasOwnProp = Object.prototype.hasOwnProperty;\nvar __export = (target, all) => {\n for (var name in all)\n __defProp(target, name, { get: all[name], enumerable: true });\n};\nvar __copyProps = (to, from, except, desc) => {\n if (from && typeof from === \"object\" || typeof from === \"function\") {\n for (let key of __getOwnPropNames(from))\n if (!__hasOwnProp.call(to, key) && key !== except)\n __defProp(to, key, { get: () => from[key], enumerable: !(desc = __getOwnPropDesc(from, key)) || desc.enumerable });\n }\n return to;\n};\nvar __toCommonJS = (mod) => __copyProps(__defProp({}, \"__esModule\", { value: true }), mod);\n\n// pkg/dist-src/index.js\nvar dist_src_exports = {};\n__export(dist_src_exports, {\n GraphqlResponseError: () => GraphqlResponseError,\n graphql: () => graphql2,\n withCustomRequest: () => withCustomRequest\n});\nmodule.exports = __toCommonJS(dist_src_exports);\nvar import_request3 = require(\"@octokit/request\");\nvar import_universal_user_agent = require(\"universal-user-agent\");\n\n// pkg/dist-src/version.js\nvar VERSION = \"7.0.2\";\n\n// pkg/dist-src/with-defaults.js\nvar import_request2 = require(\"@octokit/request\");\n\n// pkg/dist-src/graphql.js\nvar import_request = require(\"@octokit/request\");\n\n// pkg/dist-src/error.js\nfunction _buildMessageForResponseErrors(data) {\n return `Request failed due to following response errors:\n` + data.errors.map((e) => ` - ${e.message}`).join(\"\\n\");\n}\nvar GraphqlResponseError = class extends Error {\n constructor(request2, headers, response) {\n super(_buildMessageForResponseErrors(response));\n this.request = request2;\n this.headers = headers;\n this.response = response;\n this.name = \"GraphqlResponseError\";\n this.errors = response.errors;\n this.data = response.data;\n if (Error.captureStackTrace) {\n Error.captureStackTrace(this, this.constructor);\n }\n }\n};\n\n// pkg/dist-src/graphql.js\nvar NON_VARIABLE_OPTIONS = [\n \"method\",\n \"baseUrl\",\n \"url\",\n \"headers\",\n \"request\",\n \"query\",\n \"mediaType\"\n];\nvar FORBIDDEN_VARIABLE_OPTIONS = [\"query\", \"method\", \"url\"];\nvar GHES_V3_SUFFIX_REGEX = /\\/api\\/v3\\/?$/;\nfunction graphql(request2, query, options) {\n if (options) {\n if (typeof query === \"string\" && \"query\" in options) {\n return Promise.reject(\n new Error(`[@octokit/graphql] \"query\" cannot be used as variable name`)\n );\n }\n for (const key in options) {\n if (!FORBIDDEN_VARIABLE_OPTIONS.includes(key))\n continue;\n return Promise.reject(\n new Error(\n `[@octokit/graphql] \"${key}\" cannot be used as variable name`\n )\n );\n }\n }\n const parsedOptions = typeof query === \"string\" ? Object.assign({ query }, options) : query;\n const requestOptions = Object.keys(\n parsedOptions\n ).reduce((result, key) => {\n if (NON_VARIABLE_OPTIONS.includes(key)) {\n result[key] = parsedOptions[key];\n return result;\n }\n if (!result.variables) {\n result.variables = {};\n }\n result.variables[key] = parsedOptions[key];\n return result;\n }, {});\n const baseUrl = parsedOptions.baseUrl || request2.endpoint.DEFAULTS.baseUrl;\n if (GHES_V3_SUFFIX_REGEX.test(baseUrl)) {\n requestOptions.url = baseUrl.replace(GHES_V3_SUFFIX_REGEX, \"/api/graphql\");\n }\n return request2(requestOptions).then((response) => {\n if (response.data.errors) {\n const headers = {};\n for (const key of Object.keys(response.headers)) {\n headers[key] = response.headers[key];\n }\n throw new GraphqlResponseError(\n requestOptions,\n headers,\n response.data\n );\n }\n return response.data.data;\n });\n}\n\n// pkg/dist-src/with-defaults.js\nfunction withDefaults(request2, newDefaults) {\n const newRequest = request2.defaults(newDefaults);\n const newApi = (query, options) => {\n return graphql(newRequest, query, options);\n };\n return Object.assign(newApi, {\n defaults: withDefaults.bind(null, newRequest),\n endpoint: newRequest.endpoint\n });\n}\n\n// pkg/dist-src/index.js\nvar graphql2 = withDefaults(import_request3.request, {\n headers: {\n \"user-agent\": `octokit-graphql.js/${VERSION} ${(0, import_universal_user_agent.getUserAgent)()}`\n },\n method: \"POST\",\n url: \"/graphql\"\n});\nfunction withCustomRequest(customRequest) {\n return withDefaults(customRequest, {\n method: \"POST\",\n url: \"/graphql\"\n });\n}\n// Annotate the CommonJS export names for ESM import in node:\n0 && (module.exports = {\n GraphqlResponseError,\n graphql,\n withCustomRequest\n});\n","\"use strict\";\nvar __defProp = Object.defineProperty;\nvar __getOwnPropDesc = Object.getOwnPropertyDescriptor;\nvar __getOwnPropNames = Object.getOwnPropertyNames;\nvar __hasOwnProp = Object.prototype.hasOwnProperty;\nvar __export = (target, all) => {\n for (var name in all)\n __defProp(target, name, { get: all[name], enumerable: true });\n};\nvar __copyProps = (to, from, except, desc) => {\n if (from && typeof from === \"object\" || typeof from === \"function\") {\n for (let key of __getOwnPropNames(from))\n if (!__hasOwnProp.call(to, key) && key !== except)\n __defProp(to, key, { get: () => from[key], enumerable: !(desc = __getOwnPropDesc(from, key)) || desc.enumerable });\n }\n return to;\n};\nvar __toCommonJS = (mod) => __copyProps(__defProp({}, \"__esModule\", { value: true }), mod);\n\n// pkg/dist-src/index.js\nvar dist_src_exports = {};\n__export(dist_src_exports, {\n composePaginateRest: () => composePaginateRest,\n isPaginatingEndpoint: () => isPaginatingEndpoint,\n paginateRest: () => paginateRest,\n paginatingEndpoints: () => paginatingEndpoints\n});\nmodule.exports = __toCommonJS(dist_src_exports);\n\n// pkg/dist-src/version.js\nvar VERSION = \"9.2.1\";\n\n// pkg/dist-src/normalize-paginated-list-response.js\nfunction normalizePaginatedListResponse(response) {\n if (!response.data) {\n return {\n ...response,\n data: []\n };\n }\n const responseNeedsNormalization = \"total_count\" in response.data && !(\"url\" in response.data);\n if (!responseNeedsNormalization)\n return response;\n const incompleteResults = response.data.incomplete_results;\n const repositorySelection = response.data.repository_selection;\n const totalCount = response.data.total_count;\n delete response.data.incomplete_results;\n delete response.data.repository_selection;\n delete response.data.total_count;\n const namespaceKey = Object.keys(response.data)[0];\n const data = response.data[namespaceKey];\n response.data = data;\n if (typeof incompleteResults !== \"undefined\") {\n response.data.incomplete_results = incompleteResults;\n }\n if (typeof repositorySelection !== \"undefined\") {\n response.data.repository_selection = repositorySelection;\n }\n response.data.total_count = totalCount;\n return response;\n}\n\n// pkg/dist-src/iterator.js\nfunction iterator(octokit, route, parameters) {\n const options = typeof route === \"function\" ? route.endpoint(parameters) : octokit.request.endpoint(route, parameters);\n const requestMethod = typeof route === \"function\" ? route : octokit.request;\n const method = options.method;\n const headers = options.headers;\n let url = options.url;\n return {\n [Symbol.asyncIterator]: () => ({\n async next() {\n if (!url)\n return { done: true };\n try {\n const response = await requestMethod({ method, url, headers });\n const normalizedResponse = normalizePaginatedListResponse(response);\n url = ((normalizedResponse.headers.link || \"\").match(\n /<([^>]+)>;\\s*rel=\"next\"/\n ) || [])[1];\n return { value: normalizedResponse };\n } catch (error) {\n if (error.status !== 409)\n throw error;\n url = \"\";\n return {\n value: {\n status: 200,\n headers: {},\n data: []\n }\n };\n }\n }\n })\n };\n}\n\n// pkg/dist-src/paginate.js\nfunction paginate(octokit, route, parameters, mapFn) {\n if (typeof parameters === \"function\") {\n mapFn = parameters;\n parameters = void 0;\n }\n return gather(\n octokit,\n [],\n iterator(octokit, route, parameters)[Symbol.asyncIterator](),\n mapFn\n );\n}\nfunction gather(octokit, results, iterator2, mapFn) {\n return iterator2.next().then((result) => {\n if (result.done) {\n return results;\n }\n let earlyExit = false;\n function done() {\n earlyExit = true;\n }\n results = results.concat(\n mapFn ? mapFn(result.value, done) : result.value.data\n );\n if (earlyExit) {\n return results;\n }\n return gather(octokit, results, iterator2, mapFn);\n });\n}\n\n// pkg/dist-src/compose-paginate.js\nvar composePaginateRest = Object.assign(paginate, {\n iterator\n});\n\n// pkg/dist-src/generated/paginating-endpoints.js\nvar paginatingEndpoints = [\n \"GET /advisories\",\n \"GET /app/hook/deliveries\",\n \"GET /app/installation-requests\",\n \"GET /app/installations\",\n \"GET /assignments/{assignment_id}/accepted_assignments\",\n \"GET /classrooms\",\n \"GET /classrooms/{classroom_id}/assignments\",\n \"GET /enterprises/{enterprise}/dependabot/alerts\",\n \"GET /enterprises/{enterprise}/secret-scanning/alerts\",\n \"GET /events\",\n \"GET /gists\",\n \"GET /gists/public\",\n \"GET /gists/starred\",\n \"GET /gists/{gist_id}/comments\",\n \"GET /gists/{gist_id}/commits\",\n \"GET /gists/{gist_id}/forks\",\n \"GET /installation/repositories\",\n \"GET /issues\",\n \"GET /licenses\",\n \"GET /marketplace_listing/plans\",\n \"GET /marketplace_listing/plans/{plan_id}/accounts\",\n \"GET /marketplace_listing/stubbed/plans\",\n \"GET /marketplace_listing/stubbed/plans/{plan_id}/accounts\",\n \"GET /networks/{owner}/{repo}/events\",\n \"GET /notifications\",\n \"GET /organizations\",\n \"GET /orgs/{org}/actions/cache/usage-by-repository\",\n \"GET /orgs/{org}/actions/permissions/repositories\",\n \"GET /orgs/{org}/actions/runners\",\n \"GET /orgs/{org}/actions/secrets\",\n \"GET /orgs/{org}/actions/secrets/{secret_name}/repositories\",\n \"GET /orgs/{org}/actions/variables\",\n \"GET /orgs/{org}/actions/variables/{name}/repositories\",\n \"GET /orgs/{org}/blocks\",\n \"GET /orgs/{org}/code-scanning/alerts\",\n \"GET /orgs/{org}/codespaces\",\n \"GET /orgs/{org}/codespaces/secrets\",\n \"GET /orgs/{org}/codespaces/secrets/{secret_name}/repositories\",\n \"GET /orgs/{org}/copilot/billing/seats\",\n \"GET /orgs/{org}/dependabot/alerts\",\n \"GET /orgs/{org}/dependabot/secrets\",\n \"GET /orgs/{org}/dependabot/secrets/{secret_name}/repositories\",\n \"GET /orgs/{org}/events\",\n \"GET /orgs/{org}/failed_invitations\",\n \"GET /orgs/{org}/hooks\",\n \"GET /orgs/{org}/hooks/{hook_id}/deliveries\",\n \"GET /orgs/{org}/installations\",\n \"GET /orgs/{org}/invitations\",\n \"GET /orgs/{org}/invitations/{invitation_id}/teams\",\n \"GET /orgs/{org}/issues\",\n \"GET /orgs/{org}/members\",\n \"GET /orgs/{org}/members/{username}/codespaces\",\n \"GET /orgs/{org}/migrations\",\n \"GET /orgs/{org}/migrations/{migration_id}/repositories\",\n \"GET /orgs/{org}/organization-roles/{role_id}/teams\",\n \"GET /orgs/{org}/organization-roles/{role_id}/users\",\n \"GET /orgs/{org}/outside_collaborators\",\n \"GET /orgs/{org}/packages\",\n \"GET /orgs/{org}/packages/{package_type}/{package_name}/versions\",\n \"GET /orgs/{org}/personal-access-token-requests\",\n \"GET /orgs/{org}/personal-access-token-requests/{pat_request_id}/repositories\",\n \"GET /orgs/{org}/personal-access-tokens\",\n \"GET /orgs/{org}/personal-access-tokens/{pat_id}/repositories\",\n \"GET /orgs/{org}/projects\",\n \"GET /orgs/{org}/properties/values\",\n \"GET /orgs/{org}/public_members\",\n \"GET /orgs/{org}/repos\",\n \"GET /orgs/{org}/rulesets\",\n \"GET /orgs/{org}/rulesets/rule-suites\",\n \"GET /orgs/{org}/secret-scanning/alerts\",\n \"GET /orgs/{org}/security-advisories\",\n \"GET /orgs/{org}/teams\",\n \"GET /orgs/{org}/teams/{team_slug}/discussions\",\n \"GET /orgs/{org}/teams/{team_slug}/discussions/{discussion_number}/comments\",\n \"GET /orgs/{org}/teams/{team_slug}/discussions/{discussion_number}/comments/{comment_number}/reactions\",\n \"GET /orgs/{org}/teams/{team_slug}/discussions/{discussion_number}/reactions\",\n \"GET /orgs/{org}/teams/{team_slug}/invitations\",\n \"GET /orgs/{org}/teams/{team_slug}/members\",\n \"GET /orgs/{org}/teams/{team_slug}/projects\",\n \"GET /orgs/{org}/teams/{team_slug}/repos\",\n \"GET /orgs/{org}/teams/{team_slug}/teams\",\n \"GET /projects/columns/{column_id}/cards\",\n \"GET /projects/{project_id}/collaborators\",\n \"GET /projects/{project_id}/columns\",\n \"GET /repos/{owner}/{repo}/actions/artifacts\",\n \"GET /repos/{owner}/{repo}/actions/caches\",\n \"GET /repos/{owner}/{repo}/actions/organization-secrets\",\n \"GET /repos/{owner}/{repo}/actions/organization-variables\",\n \"GET /repos/{owner}/{repo}/actions/runners\",\n \"GET /repos/{owner}/{repo}/actions/runs\",\n \"GET /repos/{owner}/{repo}/actions/runs/{run_id}/artifacts\",\n \"GET /repos/{owner}/{repo}/actions/runs/{run_id}/attempts/{attempt_number}/jobs\",\n \"GET /repos/{owner}/{repo}/actions/runs/{run_id}/jobs\",\n \"GET /repos/{owner}/{repo}/actions/secrets\",\n \"GET /repos/{owner}/{repo}/actions/variables\",\n \"GET /repos/{owner}/{repo}/actions/workflows\",\n \"GET /repos/{owner}/{repo}/actions/workflows/{workflow_id}/runs\",\n \"GET /repos/{owner}/{repo}/activity\",\n \"GET /repos/{owner}/{repo}/assignees\",\n \"GET /repos/{owner}/{repo}/branches\",\n \"GET /repos/{owner}/{repo}/check-runs/{check_run_id}/annotations\",\n \"GET /repos/{owner}/{repo}/check-suites/{check_suite_id}/check-runs\",\n \"GET /repos/{owner}/{repo}/code-scanning/alerts\",\n \"GET /repos/{owner}/{repo}/code-scanning/alerts/{alert_number}/instances\",\n \"GET /repos/{owner}/{repo}/code-scanning/analyses\",\n \"GET /repos/{owner}/{repo}/codespaces\",\n \"GET /repos/{owner}/{repo}/codespaces/devcontainers\",\n \"GET /repos/{owner}/{repo}/codespaces/secrets\",\n \"GET /repos/{owner}/{repo}/collaborators\",\n \"GET /repos/{owner}/{repo}/comments\",\n \"GET /repos/{owner}/{repo}/comments/{comment_id}/reactions\",\n \"GET /repos/{owner}/{repo}/commits\",\n \"GET /repos/{owner}/{repo}/commits/{commit_sha}/comments\",\n \"GET /repos/{owner}/{repo}/commits/{commit_sha}/pulls\",\n \"GET /repos/{owner}/{repo}/commits/{ref}/check-runs\",\n \"GET /repos/{owner}/{repo}/commits/{ref}/check-suites\",\n \"GET /repos/{owner}/{repo}/commits/{ref}/status\",\n \"GET /repos/{owner}/{repo}/commits/{ref}/statuses\",\n \"GET /repos/{owner}/{repo}/contributors\",\n \"GET /repos/{owner}/{repo}/dependabot/alerts\",\n \"GET /repos/{owner}/{repo}/dependabot/secrets\",\n \"GET /repos/{owner}/{repo}/deployments\",\n \"GET /repos/{owner}/{repo}/deployments/{deployment_id}/statuses\",\n \"GET /repos/{owner}/{repo}/environments\",\n \"GET /repos/{owner}/{repo}/environments/{environment_name}/deployment-branch-policies\",\n \"GET /repos/{owner}/{repo}/environments/{environment_name}/deployment_protection_rules/apps\",\n \"GET /repos/{owner}/{repo}/events\",\n \"GET /repos/{owner}/{repo}/forks\",\n \"GET /repos/{owner}/{repo}/hooks\",\n \"GET /repos/{owner}/{repo}/hooks/{hook_id}/deliveries\",\n \"GET /repos/{owner}/{repo}/invitations\",\n \"GET /repos/{owner}/{repo}/issues\",\n \"GET /repos/{owner}/{repo}/issues/comments\",\n \"GET /repos/{owner}/{repo}/issues/comments/{comment_id}/reactions\",\n \"GET /repos/{owner}/{repo}/issues/events\",\n \"GET /repos/{owner}/{repo}/issues/{issue_number}/comments\",\n \"GET /repos/{owner}/{repo}/issues/{issue_number}/events\",\n \"GET /repos/{owner}/{repo}/issues/{issue_number}/labels\",\n \"GET /repos/{owner}/{repo}/issues/{issue_number}/reactions\",\n \"GET /repos/{owner}/{repo}/issues/{issue_number}/timeline\",\n \"GET /repos/{owner}/{repo}/keys\",\n \"GET /repos/{owner}/{repo}/labels\",\n \"GET /repos/{owner}/{repo}/milestones\",\n \"GET /repos/{owner}/{repo}/milestones/{milestone_number}/labels\",\n \"GET /repos/{owner}/{repo}/notifications\",\n \"GET /repos/{owner}/{repo}/pages/builds\",\n \"GET /repos/{owner}/{repo}/projects\",\n \"GET /repos/{owner}/{repo}/pulls\",\n \"GET /repos/{owner}/{repo}/pulls/comments\",\n \"GET /repos/{owner}/{repo}/pulls/comments/{comment_id}/reactions\",\n \"GET /repos/{owner}/{repo}/pulls/{pull_number}/comments\",\n \"GET /repos/{owner}/{repo}/pulls/{pull_number}/commits\",\n \"GET /repos/{owner}/{repo}/pulls/{pull_number}/files\",\n \"GET /repos/{owner}/{repo}/pulls/{pull_number}/reviews\",\n \"GET /repos/{owner}/{repo}/pulls/{pull_number}/reviews/{review_id}/comments\",\n \"GET /repos/{owner}/{repo}/releases\",\n \"GET /repos/{owner}/{repo}/releases/{release_id}/assets\",\n \"GET /repos/{owner}/{repo}/releases/{release_id}/reactions\",\n \"GET /repos/{owner}/{repo}/rules/branches/{branch}\",\n \"GET /repos/{owner}/{repo}/rulesets\",\n \"GET /repos/{owner}/{repo}/rulesets/rule-suites\",\n \"GET /repos/{owner}/{repo}/secret-scanning/alerts\",\n \"GET /repos/{owner}/{repo}/secret-scanning/alerts/{alert_number}/locations\",\n \"GET /repos/{owner}/{repo}/security-advisories\",\n \"GET /repos/{owner}/{repo}/stargazers\",\n \"GET /repos/{owner}/{repo}/subscribers\",\n \"GET /repos/{owner}/{repo}/tags\",\n \"GET /repos/{owner}/{repo}/teams\",\n \"GET /repos/{owner}/{repo}/topics\",\n \"GET /repositories\",\n \"GET /repositories/{repository_id}/environments/{environment_name}/secrets\",\n \"GET /repositories/{repository_id}/environments/{environment_name}/variables\",\n \"GET /search/code\",\n \"GET /search/commits\",\n \"GET /search/issues\",\n \"GET /search/labels\",\n \"GET /search/repositories\",\n \"GET /search/topics\",\n \"GET /search/users\",\n \"GET /teams/{team_id}/discussions\",\n \"GET /teams/{team_id}/discussions/{discussion_number}/comments\",\n \"GET /teams/{team_id}/discussions/{discussion_number}/comments/{comment_number}/reactions\",\n \"GET /teams/{team_id}/discussions/{discussion_number}/reactions\",\n \"GET /teams/{team_id}/invitations\",\n \"GET /teams/{team_id}/members\",\n \"GET /teams/{team_id}/projects\",\n \"GET /teams/{team_id}/repos\",\n \"GET /teams/{team_id}/teams\",\n \"GET /user/blocks\",\n \"GET /user/codespaces\",\n \"GET /user/codespaces/secrets\",\n \"GET /user/emails\",\n \"GET /user/followers\",\n \"GET /user/following\",\n \"GET /user/gpg_keys\",\n \"GET /user/installations\",\n \"GET /user/installations/{installation_id}/repositories\",\n \"GET /user/issues\",\n \"GET /user/keys\",\n \"GET /user/marketplace_purchases\",\n \"GET /user/marketplace_purchases/stubbed\",\n \"GET /user/memberships/orgs\",\n \"GET /user/migrations\",\n \"GET /user/migrations/{migration_id}/repositories\",\n \"GET /user/orgs\",\n \"GET /user/packages\",\n \"GET /user/packages/{package_type}/{package_name}/versions\",\n \"GET /user/public_emails\",\n \"GET /user/repos\",\n \"GET /user/repository_invitations\",\n \"GET /user/social_accounts\",\n \"GET /user/ssh_signing_keys\",\n \"GET /user/starred\",\n \"GET /user/subscriptions\",\n \"GET /user/teams\",\n \"GET /users\",\n \"GET /users/{username}/events\",\n \"GET /users/{username}/events/orgs/{org}\",\n \"GET /users/{username}/events/public\",\n \"GET /users/{username}/followers\",\n \"GET /users/{username}/following\",\n \"GET /users/{username}/gists\",\n \"GET /users/{username}/gpg_keys\",\n \"GET /users/{username}/keys\",\n \"GET /users/{username}/orgs\",\n \"GET /users/{username}/packages\",\n \"GET /users/{username}/projects\",\n \"GET /users/{username}/received_events\",\n \"GET /users/{username}/received_events/public\",\n \"GET /users/{username}/repos\",\n \"GET /users/{username}/social_accounts\",\n \"GET /users/{username}/ssh_signing_keys\",\n \"GET /users/{username}/starred\",\n \"GET /users/{username}/subscriptions\"\n];\n\n// pkg/dist-src/paginating-endpoints.js\nfunction isPaginatingEndpoint(arg) {\n if (typeof arg === \"string\") {\n return paginatingEndpoints.includes(arg);\n } else {\n return false;\n }\n}\n\n// pkg/dist-src/index.js\nfunction paginateRest(octokit) {\n return {\n paginate: Object.assign(paginate.bind(null, octokit), {\n iterator: iterator.bind(null, octokit)\n })\n };\n}\npaginateRest.VERSION = VERSION;\n// Annotate the CommonJS export names for ESM import in node:\n0 && (module.exports = {\n composePaginateRest,\n isPaginatingEndpoint,\n paginateRest,\n paginatingEndpoints\n});\n","\"use strict\";\nvar __defProp = Object.defineProperty;\nvar __getOwnPropDesc = Object.getOwnPropertyDescriptor;\nvar __getOwnPropNames = Object.getOwnPropertyNames;\nvar __hasOwnProp = Object.prototype.hasOwnProperty;\nvar __export = (target, all) => {\n for (var name in all)\n __defProp(target, name, { get: all[name], enumerable: true });\n};\nvar __copyProps = (to, from, except, desc) => {\n if (from && typeof from === \"object\" || typeof from === \"function\") {\n for (let key of __getOwnPropNames(from))\n if (!__hasOwnProp.call(to, key) && key !== except)\n __defProp(to, key, { get: () => from[key], enumerable: !(desc = __getOwnPropDesc(from, key)) || desc.enumerable });\n }\n return to;\n};\nvar __toCommonJS = (mod) => __copyProps(__defProp({}, \"__esModule\", { value: true }), mod);\n\n// pkg/dist-src/index.js\nvar dist_src_exports = {};\n__export(dist_src_exports, {\n legacyRestEndpointMethods: () => legacyRestEndpointMethods,\n restEndpointMethods: () => restEndpointMethods\n});\nmodule.exports = __toCommonJS(dist_src_exports);\n\n// pkg/dist-src/version.js\nvar VERSION = \"10.4.1\";\n\n// pkg/dist-src/generated/endpoints.js\nvar Endpoints = {\n actions: {\n addCustomLabelsToSelfHostedRunnerForOrg: [\n \"POST /orgs/{org}/actions/runners/{runner_id}/labels\"\n ],\n addCustomLabelsToSelfHostedRunnerForRepo: [\n \"POST /repos/{owner}/{repo}/actions/runners/{runner_id}/labels\"\n ],\n addSelectedRepoToOrgSecret: [\n \"PUT /orgs/{org}/actions/secrets/{secret_name}/repositories/{repository_id}\"\n ],\n addSelectedRepoToOrgVariable: [\n \"PUT /orgs/{org}/actions/variables/{name}/repositories/{repository_id}\"\n ],\n approveWorkflowRun: [\n \"POST /repos/{owner}/{repo}/actions/runs/{run_id}/approve\"\n ],\n cancelWorkflowRun: [\n \"POST /repos/{owner}/{repo}/actions/runs/{run_id}/cancel\"\n ],\n createEnvironmentVariable: [\n \"POST /repositories/{repository_id}/environments/{environment_name}/variables\"\n ],\n createOrUpdateEnvironmentSecret: [\n \"PUT /repositories/{repository_id}/environments/{environment_name}/secrets/{secret_name}\"\n ],\n createOrUpdateOrgSecret: [\"PUT /orgs/{org}/actions/secrets/{secret_name}\"],\n createOrUpdateRepoSecret: [\n \"PUT /repos/{owner}/{repo}/actions/secrets/{secret_name}\"\n ],\n createOrgVariable: [\"POST /orgs/{org}/actions/variables\"],\n createRegistrationTokenForOrg: [\n \"POST /orgs/{org}/actions/runners/registration-token\"\n ],\n createRegistrationTokenForRepo: [\n \"POST /repos/{owner}/{repo}/actions/runners/registration-token\"\n ],\n createRemoveTokenForOrg: [\"POST /orgs/{org}/actions/runners/remove-token\"],\n createRemoveTokenForRepo: [\n \"POST /repos/{owner}/{repo}/actions/runners/remove-token\"\n ],\n createRepoVariable: [\"POST /repos/{owner}/{repo}/actions/variables\"],\n createWorkflowDispatch: [\n \"POST /repos/{owner}/{repo}/actions/workflows/{workflow_id}/dispatches\"\n ],\n deleteActionsCacheById: [\n \"DELETE /repos/{owner}/{repo}/actions/caches/{cache_id}\"\n ],\n deleteActionsCacheByKey: [\n \"DELETE /repos/{owner}/{repo}/actions/caches{?key,ref}\"\n ],\n deleteArtifact: [\n \"DELETE /repos/{owner}/{repo}/actions/artifacts/{artifact_id}\"\n ],\n deleteEnvironmentSecret: [\n \"DELETE /repositories/{repository_id}/environments/{environment_name}/secrets/{secret_name}\"\n ],\n deleteEnvironmentVariable: [\n \"DELETE /repositories/{repository_id}/environments/{environment_name}/variables/{name}\"\n ],\n deleteOrgSecret: [\"DELETE /orgs/{org}/actions/secrets/{secret_name}\"],\n deleteOrgVariable: [\"DELETE /orgs/{org}/actions/variables/{name}\"],\n deleteRepoSecret: [\n \"DELETE /repos/{owner}/{repo}/actions/secrets/{secret_name}\"\n ],\n deleteRepoVariable: [\n \"DELETE /repos/{owner}/{repo}/actions/variables/{name}\"\n ],\n deleteSelfHostedRunnerFromOrg: [\n \"DELETE /orgs/{org}/actions/runners/{runner_id}\"\n ],\n deleteSelfHostedRunnerFromRepo: [\n \"DELETE /repos/{owner}/{repo}/actions/runners/{runner_id}\"\n ],\n deleteWorkflowRun: [\"DELETE /repos/{owner}/{repo}/actions/runs/{run_id}\"],\n deleteWorkflowRunLogs: [\n \"DELETE /repos/{owner}/{repo}/actions/runs/{run_id}/logs\"\n ],\n disableSelectedRepositoryGithubActionsOrganization: [\n \"DELETE /orgs/{org}/actions/permissions/repositories/{repository_id}\"\n ],\n disableWorkflow: [\n \"PUT /repos/{owner}/{repo}/actions/workflows/{workflow_id}/disable\"\n ],\n downloadArtifact: [\n \"GET /repos/{owner}/{repo}/actions/artifacts/{artifact_id}/{archive_format}\"\n ],\n downloadJobLogsForWorkflowRun: [\n \"GET /repos/{owner}/{repo}/actions/jobs/{job_id}/logs\"\n ],\n downloadWorkflowRunAttemptLogs: [\n \"GET /repos/{owner}/{repo}/actions/runs/{run_id}/attempts/{attempt_number}/logs\"\n ],\n downloadWorkflowRunLogs: [\n \"GET /repos/{owner}/{repo}/actions/runs/{run_id}/logs\"\n ],\n enableSelectedRepositoryGithubActionsOrganization: [\n \"PUT /orgs/{org}/actions/permissions/repositories/{repository_id}\"\n ],\n enableWorkflow: [\n \"PUT /repos/{owner}/{repo}/actions/workflows/{workflow_id}/enable\"\n ],\n forceCancelWorkflowRun: [\n \"POST /repos/{owner}/{repo}/actions/runs/{run_id}/force-cancel\"\n ],\n generateRunnerJitconfigForOrg: [\n \"POST /orgs/{org}/actions/runners/generate-jitconfig\"\n ],\n generateRunnerJitconfigForRepo: [\n \"POST /repos/{owner}/{repo}/actions/runners/generate-jitconfig\"\n ],\n getActionsCacheList: [\"GET /repos/{owner}/{repo}/actions/caches\"],\n getActionsCacheUsage: [\"GET /repos/{owner}/{repo}/actions/cache/usage\"],\n getActionsCacheUsageByRepoForOrg: [\n \"GET /orgs/{org}/actions/cache/usage-by-repository\"\n ],\n getActionsCacheUsageForOrg: [\"GET /orgs/{org}/actions/cache/usage\"],\n getAllowedActionsOrganization: [\n \"GET /orgs/{org}/actions/permissions/selected-actions\"\n ],\n getAllowedActionsRepository: [\n \"GET /repos/{owner}/{repo}/actions/permissions/selected-actions\"\n ],\n getArtifact: [\"GET /repos/{owner}/{repo}/actions/artifacts/{artifact_id}\"],\n getCustomOidcSubClaimForRepo: [\n \"GET /repos/{owner}/{repo}/actions/oidc/customization/sub\"\n ],\n getEnvironmentPublicKey: [\n \"GET /repositories/{repository_id}/environments/{environment_name}/secrets/public-key\"\n ],\n getEnvironmentSecret: [\n \"GET /repositories/{repository_id}/environments/{environment_name}/secrets/{secret_name}\"\n ],\n getEnvironmentVariable: [\n \"GET /repositories/{repository_id}/environments/{environment_name}/variables/{name}\"\n ],\n getGithubActionsDefaultWorkflowPermissionsOrganization: [\n \"GET /orgs/{org}/actions/permissions/workflow\"\n ],\n getGithubActionsDefaultWorkflowPermissionsRepository: [\n \"GET /repos/{owner}/{repo}/actions/permissions/workflow\"\n ],\n getGithubActionsPermissionsOrganization: [\n \"GET /orgs/{org}/actions/permissions\"\n ],\n getGithubActionsPermissionsRepository: [\n \"GET /repos/{owner}/{repo}/actions/permissions\"\n ],\n getJobForWorkflowRun: [\"GET /repos/{owner}/{repo}/actions/jobs/{job_id}\"],\n getOrgPublicKey: [\"GET /orgs/{org}/actions/secrets/public-key\"],\n getOrgSecret: [\"GET /orgs/{org}/actions/secrets/{secret_name}\"],\n getOrgVariable: [\"GET /orgs/{org}/actions/variables/{name}\"],\n getPendingDeploymentsForRun: [\n \"GET /repos/{owner}/{repo}/actions/runs/{run_id}/pending_deployments\"\n ],\n getRepoPermissions: [\n \"GET /repos/{owner}/{repo}/actions/permissions\",\n {},\n { renamed: [\"actions\", \"getGithubActionsPermissionsRepository\"] }\n ],\n getRepoPublicKey: [\"GET /repos/{owner}/{repo}/actions/secrets/public-key\"],\n getRepoSecret: [\"GET /repos/{owner}/{repo}/actions/secrets/{secret_name}\"],\n getRepoVariable: [\"GET /repos/{owner}/{repo}/actions/variables/{name}\"],\n getReviewsForRun: [\n \"GET /repos/{owner}/{repo}/actions/runs/{run_id}/approvals\"\n ],\n getSelfHostedRunnerForOrg: [\"GET /orgs/{org}/actions/runners/{runner_id}\"],\n getSelfHostedRunnerForRepo: [\n \"GET /repos/{owner}/{repo}/actions/runners/{runner_id}\"\n ],\n getWorkflow: [\"GET /repos/{owner}/{repo}/actions/workflows/{workflow_id}\"],\n getWorkflowAccessToRepository: [\n \"GET /repos/{owner}/{repo}/actions/permissions/access\"\n ],\n getWorkflowRun: [\"GET /repos/{owner}/{repo}/actions/runs/{run_id}\"],\n getWorkflowRunAttempt: [\n \"GET /repos/{owner}/{repo}/actions/runs/{run_id}/attempts/{attempt_number}\"\n ],\n getWorkflowRunUsage: [\n \"GET /repos/{owner}/{repo}/actions/runs/{run_id}/timing\"\n ],\n getWorkflowUsage: [\n \"GET /repos/{owner}/{repo}/actions/workflows/{workflow_id}/timing\"\n ],\n listArtifactsForRepo: [\"GET /repos/{owner}/{repo}/actions/artifacts\"],\n listEnvironmentSecrets: [\n \"GET /repositories/{repository_id}/environments/{environment_name}/secrets\"\n ],\n listEnvironmentVariables: [\n \"GET /repositories/{repository_id}/environments/{environment_name}/variables\"\n ],\n listJobsForWorkflowRun: [\n \"GET /repos/{owner}/{repo}/actions/runs/{run_id}/jobs\"\n ],\n listJobsForWorkflowRunAttempt: [\n \"GET /repos/{owner}/{repo}/actions/runs/{run_id}/attempts/{attempt_number}/jobs\"\n ],\n listLabelsForSelfHostedRunnerForOrg: [\n \"GET /orgs/{org}/actions/runners/{runner_id}/labels\"\n ],\n listLabelsForSelfHostedRunnerForRepo: [\n \"GET /repos/{owner}/{repo}/actions/runners/{runner_id}/labels\"\n ],\n listOrgSecrets: [\"GET /orgs/{org}/actions/secrets\"],\n listOrgVariables: [\"GET /orgs/{org}/actions/variables\"],\n listRepoOrganizationSecrets: [\n \"GET /repos/{owner}/{repo}/actions/organization-secrets\"\n ],\n listRepoOrganizationVariables: [\n \"GET /repos/{owner}/{repo}/actions/organization-variables\"\n ],\n listRepoSecrets: [\"GET /repos/{owner}/{repo}/actions/secrets\"],\n listRepoVariables: [\"GET /repos/{owner}/{repo}/actions/variables\"],\n listRepoWorkflows: [\"GET /repos/{owner}/{repo}/actions/workflows\"],\n listRunnerApplicationsForOrg: [\"GET /orgs/{org}/actions/runners/downloads\"],\n listRunnerApplicationsForRepo: [\n \"GET /repos/{owner}/{repo}/actions/runners/downloads\"\n ],\n listSelectedReposForOrgSecret: [\n \"GET /orgs/{org}/actions/secrets/{secret_name}/repositories\"\n ],\n listSelectedReposForOrgVariable: [\n \"GET /orgs/{org}/actions/variables/{name}/repositories\"\n ],\n listSelectedRepositoriesEnabledGithubActionsOrganization: [\n \"GET /orgs/{org}/actions/permissions/repositories\"\n ],\n listSelfHostedRunnersForOrg: [\"GET /orgs/{org}/actions/runners\"],\n listSelfHostedRunnersForRepo: [\"GET /repos/{owner}/{repo}/actions/runners\"],\n listWorkflowRunArtifacts: [\n \"GET /repos/{owner}/{repo}/actions/runs/{run_id}/artifacts\"\n ],\n listWorkflowRuns: [\n \"GET /repos/{owner}/{repo}/actions/workflows/{workflow_id}/runs\"\n ],\n listWorkflowRunsForRepo: [\"GET /repos/{owner}/{repo}/actions/runs\"],\n reRunJobForWorkflowRun: [\n \"POST /repos/{owner}/{repo}/actions/jobs/{job_id}/rerun\"\n ],\n reRunWorkflow: [\"POST /repos/{owner}/{repo}/actions/runs/{run_id}/rerun\"],\n reRunWorkflowFailedJobs: [\n \"POST /repos/{owner}/{repo}/actions/runs/{run_id}/rerun-failed-jobs\"\n ],\n removeAllCustomLabelsFromSelfHostedRunnerForOrg: [\n \"DELETE /orgs/{org}/actions/runners/{runner_id}/labels\"\n ],\n removeAllCustomLabelsFromSelfHostedRunnerForRepo: [\n \"DELETE /repos/{owner}/{repo}/actions/runners/{runner_id}/labels\"\n ],\n removeCustomLabelFromSelfHostedRunnerForOrg: [\n \"DELETE /orgs/{org}/actions/runners/{runner_id}/labels/{name}\"\n ],\n removeCustomLabelFromSelfHostedRunnerForRepo: [\n \"DELETE /repos/{owner}/{repo}/actions/runners/{runner_id}/labels/{name}\"\n ],\n removeSelectedRepoFromOrgSecret: [\n \"DELETE /orgs/{org}/actions/secrets/{secret_name}/repositories/{repository_id}\"\n ],\n removeSelectedRepoFromOrgVariable: [\n \"DELETE /orgs/{org}/actions/variables/{name}/repositories/{repository_id}\"\n ],\n reviewCustomGatesForRun: [\n \"POST /repos/{owner}/{repo}/actions/runs/{run_id}/deployment_protection_rule\"\n ],\n reviewPendingDeploymentsForRun: [\n \"POST /repos/{owner}/{repo}/actions/runs/{run_id}/pending_deployments\"\n ],\n setAllowedActionsOrganization: [\n \"PUT /orgs/{org}/actions/permissions/selected-actions\"\n ],\n setAllowedActionsRepository: [\n \"PUT /repos/{owner}/{repo}/actions/permissions/selected-actions\"\n ],\n setCustomLabelsForSelfHostedRunnerForOrg: [\n \"PUT /orgs/{org}/actions/runners/{runner_id}/labels\"\n ],\n setCustomLabelsForSelfHostedRunnerForRepo: [\n \"PUT /repos/{owner}/{repo}/actions/runners/{runner_id}/labels\"\n ],\n setCustomOidcSubClaimForRepo: [\n \"PUT /repos/{owner}/{repo}/actions/oidc/customization/sub\"\n ],\n setGithubActionsDefaultWorkflowPermissionsOrganization: [\n \"PUT /orgs/{org}/actions/permissions/workflow\"\n ],\n setGithubActionsDefaultWorkflowPermissionsRepository: [\n \"PUT /repos/{owner}/{repo}/actions/permissions/workflow\"\n ],\n setGithubActionsPermissionsOrganization: [\n \"PUT /orgs/{org}/actions/permissions\"\n ],\n setGithubActionsPermissionsRepository: [\n \"PUT /repos/{owner}/{repo}/actions/permissions\"\n ],\n setSelectedReposForOrgSecret: [\n \"PUT /orgs/{org}/actions/secrets/{secret_name}/repositories\"\n ],\n setSelectedReposForOrgVariable: [\n \"PUT /orgs/{org}/actions/variables/{name}/repositories\"\n ],\n setSelectedRepositoriesEnabledGithubActionsOrganization: [\n \"PUT /orgs/{org}/actions/permissions/repositories\"\n ],\n setWorkflowAccessToRepository: [\n \"PUT /repos/{owner}/{repo}/actions/permissions/access\"\n ],\n updateEnvironmentVariable: [\n \"PATCH /repositories/{repository_id}/environments/{environment_name}/variables/{name}\"\n ],\n updateOrgVariable: [\"PATCH /orgs/{org}/actions/variables/{name}\"],\n updateRepoVariable: [\n \"PATCH /repos/{owner}/{repo}/actions/variables/{name}\"\n ]\n },\n activity: {\n checkRepoIsStarredByAuthenticatedUser: [\"GET /user/starred/{owner}/{repo}\"],\n deleteRepoSubscription: [\"DELETE /repos/{owner}/{repo}/subscription\"],\n deleteThreadSubscription: [\n \"DELETE /notifications/threads/{thread_id}/subscription\"\n ],\n getFeeds: [\"GET /feeds\"],\n getRepoSubscription: [\"GET /repos/{owner}/{repo}/subscription\"],\n getThread: [\"GET /notifications/threads/{thread_id}\"],\n getThreadSubscriptionForAuthenticatedUser: [\n \"GET /notifications/threads/{thread_id}/subscription\"\n ],\n listEventsForAuthenticatedUser: [\"GET /users/{username}/events\"],\n listNotificationsForAuthenticatedUser: [\"GET /notifications\"],\n listOrgEventsForAuthenticatedUser: [\n \"GET /users/{username}/events/orgs/{org}\"\n ],\n listPublicEvents: [\"GET /events\"],\n listPublicEventsForRepoNetwork: [\"GET /networks/{owner}/{repo}/events\"],\n listPublicEventsForUser: [\"GET /users/{username}/events/public\"],\n listPublicOrgEvents: [\"GET /orgs/{org}/events\"],\n listReceivedEventsForUser: [\"GET /users/{username}/received_events\"],\n listReceivedPublicEventsForUser: [\n \"GET /users/{username}/received_events/public\"\n ],\n listRepoEvents: [\"GET /repos/{owner}/{repo}/events\"],\n listRepoNotificationsForAuthenticatedUser: [\n \"GET /repos/{owner}/{repo}/notifications\"\n ],\n listReposStarredByAuthenticatedUser: [\"GET /user/starred\"],\n listReposStarredByUser: [\"GET /users/{username}/starred\"],\n listReposWatchedByUser: [\"GET /users/{username}/subscriptions\"],\n listStargazersForRepo: [\"GET /repos/{owner}/{repo}/stargazers\"],\n listWatchedReposForAuthenticatedUser: [\"GET /user/subscriptions\"],\n listWatchersForRepo: [\"GET /repos/{owner}/{repo}/subscribers\"],\n markNotificationsAsRead: [\"PUT /notifications\"],\n markRepoNotificationsAsRead: [\"PUT /repos/{owner}/{repo}/notifications\"],\n markThreadAsDone: [\"DELETE /notifications/threads/{thread_id}\"],\n markThreadAsRead: [\"PATCH /notifications/threads/{thread_id}\"],\n setRepoSubscription: [\"PUT /repos/{owner}/{repo}/subscription\"],\n setThreadSubscription: [\n \"PUT /notifications/threads/{thread_id}/subscription\"\n ],\n starRepoForAuthenticatedUser: [\"PUT /user/starred/{owner}/{repo}\"],\n unstarRepoForAuthenticatedUser: [\"DELETE /user/starred/{owner}/{repo}\"]\n },\n apps: {\n addRepoToInstallation: [\n \"PUT /user/installations/{installation_id}/repositories/{repository_id}\",\n {},\n { renamed: [\"apps\", \"addRepoToInstallationForAuthenticatedUser\"] }\n ],\n addRepoToInstallationForAuthenticatedUser: [\n \"PUT /user/installations/{installation_id}/repositories/{repository_id}\"\n ],\n checkToken: [\"POST /applications/{client_id}/token\"],\n createFromManifest: [\"POST /app-manifests/{code}/conversions\"],\n createInstallationAccessToken: [\n \"POST /app/installations/{installation_id}/access_tokens\"\n ],\n deleteAuthorization: [\"DELETE /applications/{client_id}/grant\"],\n deleteInstallation: [\"DELETE /app/installations/{installation_id}\"],\n deleteToken: [\"DELETE /applications/{client_id}/token\"],\n getAuthenticated: [\"GET /app\"],\n getBySlug: [\"GET /apps/{app_slug}\"],\n getInstallation: [\"GET /app/installations/{installation_id}\"],\n getOrgInstallation: [\"GET /orgs/{org}/installation\"],\n getRepoInstallation: [\"GET /repos/{owner}/{repo}/installation\"],\n getSubscriptionPlanForAccount: [\n \"GET /marketplace_listing/accounts/{account_id}\"\n ],\n getSubscriptionPlanForAccountStubbed: [\n \"GET /marketplace_listing/stubbed/accounts/{account_id}\"\n ],\n getUserInstallation: [\"GET /users/{username}/installation\"],\n getWebhookConfigForApp: [\"GET /app/hook/config\"],\n getWebhookDelivery: [\"GET /app/hook/deliveries/{delivery_id}\"],\n listAccountsForPlan: [\"GET /marketplace_listing/plans/{plan_id}/accounts\"],\n listAccountsForPlanStubbed: [\n \"GET /marketplace_listing/stubbed/plans/{plan_id}/accounts\"\n ],\n listInstallationReposForAuthenticatedUser: [\n \"GET /user/installations/{installation_id}/repositories\"\n ],\n listInstallationRequestsForAuthenticatedApp: [\n \"GET /app/installation-requests\"\n ],\n listInstallations: [\"GET /app/installations\"],\n listInstallationsForAuthenticatedUser: [\"GET /user/installations\"],\n listPlans: [\"GET /marketplace_listing/plans\"],\n listPlansStubbed: [\"GET /marketplace_listing/stubbed/plans\"],\n listReposAccessibleToInstallation: [\"GET /installation/repositories\"],\n listSubscriptionsForAuthenticatedUser: [\"GET /user/marketplace_purchases\"],\n listSubscriptionsForAuthenticatedUserStubbed: [\n \"GET /user/marketplace_purchases/stubbed\"\n ],\n listWebhookDeliveries: [\"GET /app/hook/deliveries\"],\n redeliverWebhookDelivery: [\n \"POST /app/hook/deliveries/{delivery_id}/attempts\"\n ],\n removeRepoFromInstallation: [\n \"DELETE /user/installations/{installation_id}/repositories/{repository_id}\",\n {},\n { renamed: [\"apps\", \"removeRepoFromInstallationForAuthenticatedUser\"] }\n ],\n removeRepoFromInstallationForAuthenticatedUser: [\n \"DELETE /user/installations/{installation_id}/repositories/{repository_id}\"\n ],\n resetToken: [\"PATCH /applications/{client_id}/token\"],\n revokeInstallationAccessToken: [\"DELETE /installation/token\"],\n scopeToken: [\"POST /applications/{client_id}/token/scoped\"],\n suspendInstallation: [\"PUT /app/installations/{installation_id}/suspended\"],\n unsuspendInstallation: [\n \"DELETE /app/installations/{installation_id}/suspended\"\n ],\n updateWebhookConfigForApp: [\"PATCH /app/hook/config\"]\n },\n billing: {\n getGithubActionsBillingOrg: [\"GET /orgs/{org}/settings/billing/actions\"],\n getGithubActionsBillingUser: [\n \"GET /users/{username}/settings/billing/actions\"\n ],\n getGithubPackagesBillingOrg: [\"GET /orgs/{org}/settings/billing/packages\"],\n getGithubPackagesBillingUser: [\n \"GET /users/{username}/settings/billing/packages\"\n ],\n getSharedStorageBillingOrg: [\n \"GET /orgs/{org}/settings/billing/shared-storage\"\n ],\n getSharedStorageBillingUser: [\n \"GET /users/{username}/settings/billing/shared-storage\"\n ]\n },\n checks: {\n create: [\"POST /repos/{owner}/{repo}/check-runs\"],\n createSuite: [\"POST /repos/{owner}/{repo}/check-suites\"],\n get: [\"GET /repos/{owner}/{repo}/check-runs/{check_run_id}\"],\n getSuite: [\"GET /repos/{owner}/{repo}/check-suites/{check_suite_id}\"],\n listAnnotations: [\n \"GET /repos/{owner}/{repo}/check-runs/{check_run_id}/annotations\"\n ],\n listForRef: [\"GET /repos/{owner}/{repo}/commits/{ref}/check-runs\"],\n listForSuite: [\n \"GET /repos/{owner}/{repo}/check-suites/{check_suite_id}/check-runs\"\n ],\n listSuitesForRef: [\"GET /repos/{owner}/{repo}/commits/{ref}/check-suites\"],\n rerequestRun: [\n \"POST /repos/{owner}/{repo}/check-runs/{check_run_id}/rerequest\"\n ],\n rerequestSuite: [\n \"POST /repos/{owner}/{repo}/check-suites/{check_suite_id}/rerequest\"\n ],\n setSuitesPreferences: [\n \"PATCH /repos/{owner}/{repo}/check-suites/preferences\"\n ],\n update: [\"PATCH /repos/{owner}/{repo}/check-runs/{check_run_id}\"]\n },\n codeScanning: {\n deleteAnalysis: [\n \"DELETE /repos/{owner}/{repo}/code-scanning/analyses/{analysis_id}{?confirm_delete}\"\n ],\n getAlert: [\n \"GET /repos/{owner}/{repo}/code-scanning/alerts/{alert_number}\",\n {},\n { renamedParameters: { alert_id: \"alert_number\" } }\n ],\n getAnalysis: [\n \"GET /repos/{owner}/{repo}/code-scanning/analyses/{analysis_id}\"\n ],\n getCodeqlDatabase: [\n \"GET /repos/{owner}/{repo}/code-scanning/codeql/databases/{language}\"\n ],\n getDefaultSetup: [\"GET /repos/{owner}/{repo}/code-scanning/default-setup\"],\n getSarif: [\"GET /repos/{owner}/{repo}/code-scanning/sarifs/{sarif_id}\"],\n listAlertInstances: [\n \"GET /repos/{owner}/{repo}/code-scanning/alerts/{alert_number}/instances\"\n ],\n listAlertsForOrg: [\"GET /orgs/{org}/code-scanning/alerts\"],\n listAlertsForRepo: [\"GET /repos/{owner}/{repo}/code-scanning/alerts\"],\n listAlertsInstances: [\n \"GET /repos/{owner}/{repo}/code-scanning/alerts/{alert_number}/instances\",\n {},\n { renamed: [\"codeScanning\", \"listAlertInstances\"] }\n ],\n listCodeqlDatabases: [\n \"GET /repos/{owner}/{repo}/code-scanning/codeql/databases\"\n ],\n listRecentAnalyses: [\"GET /repos/{owner}/{repo}/code-scanning/analyses\"],\n updateAlert: [\n \"PATCH /repos/{owner}/{repo}/code-scanning/alerts/{alert_number}\"\n ],\n updateDefaultSetup: [\n \"PATCH /repos/{owner}/{repo}/code-scanning/default-setup\"\n ],\n uploadSarif: [\"POST /repos/{owner}/{repo}/code-scanning/sarifs\"]\n },\n codesOfConduct: {\n getAllCodesOfConduct: [\"GET /codes_of_conduct\"],\n getConductCode: [\"GET /codes_of_conduct/{key}\"]\n },\n codespaces: {\n addRepositoryForSecretForAuthenticatedUser: [\n \"PUT /user/codespaces/secrets/{secret_name}/repositories/{repository_id}\"\n ],\n addSelectedRepoToOrgSecret: [\n \"PUT /orgs/{org}/codespaces/secrets/{secret_name}/repositories/{repository_id}\"\n ],\n checkPermissionsForDevcontainer: [\n \"GET /repos/{owner}/{repo}/codespaces/permissions_check\"\n ],\n codespaceMachinesForAuthenticatedUser: [\n \"GET /user/codespaces/{codespace_name}/machines\"\n ],\n createForAuthenticatedUser: [\"POST /user/codespaces\"],\n createOrUpdateOrgSecret: [\n \"PUT /orgs/{org}/codespaces/secrets/{secret_name}\"\n ],\n createOrUpdateRepoSecret: [\n \"PUT /repos/{owner}/{repo}/codespaces/secrets/{secret_name}\"\n ],\n createOrUpdateSecretForAuthenticatedUser: [\n \"PUT /user/codespaces/secrets/{secret_name}\"\n ],\n createWithPrForAuthenticatedUser: [\n \"POST /repos/{owner}/{repo}/pulls/{pull_number}/codespaces\"\n ],\n createWithRepoForAuthenticatedUser: [\n \"POST /repos/{owner}/{repo}/codespaces\"\n ],\n deleteForAuthenticatedUser: [\"DELETE /user/codespaces/{codespace_name}\"],\n deleteFromOrganization: [\n \"DELETE /orgs/{org}/members/{username}/codespaces/{codespace_name}\"\n ],\n deleteOrgSecret: [\"DELETE /orgs/{org}/codespaces/secrets/{secret_name}\"],\n deleteRepoSecret: [\n \"DELETE /repos/{owner}/{repo}/codespaces/secrets/{secret_name}\"\n ],\n deleteSecretForAuthenticatedUser: [\n \"DELETE /user/codespaces/secrets/{secret_name}\"\n ],\n exportForAuthenticatedUser: [\n \"POST /user/codespaces/{codespace_name}/exports\"\n ],\n getCodespacesForUserInOrg: [\n \"GET /orgs/{org}/members/{username}/codespaces\"\n ],\n getExportDetailsForAuthenticatedUser: [\n \"GET /user/codespaces/{codespace_name}/exports/{export_id}\"\n ],\n getForAuthenticatedUser: [\"GET /user/codespaces/{codespace_name}\"],\n getOrgPublicKey: [\"GET /orgs/{org}/codespaces/secrets/public-key\"],\n getOrgSecret: [\"GET /orgs/{org}/codespaces/secrets/{secret_name}\"],\n getPublicKeyForAuthenticatedUser: [\n \"GET /user/codespaces/secrets/public-key\"\n ],\n getRepoPublicKey: [\n \"GET /repos/{owner}/{repo}/codespaces/secrets/public-key\"\n ],\n getRepoSecret: [\n \"GET /repos/{owner}/{repo}/codespaces/secrets/{secret_name}\"\n ],\n getSecretForAuthenticatedUser: [\n \"GET /user/codespaces/secrets/{secret_name}\"\n ],\n listDevcontainersInRepositoryForAuthenticatedUser: [\n \"GET /repos/{owner}/{repo}/codespaces/devcontainers\"\n ],\n listForAuthenticatedUser: [\"GET /user/codespaces\"],\n listInOrganization: [\n \"GET /orgs/{org}/codespaces\",\n {},\n { renamedParameters: { org_id: \"org\" } }\n ],\n listInRepositoryForAuthenticatedUser: [\n \"GET /repos/{owner}/{repo}/codespaces\"\n ],\n listOrgSecrets: [\"GET /orgs/{org}/codespaces/secrets\"],\n listRepoSecrets: [\"GET /repos/{owner}/{repo}/codespaces/secrets\"],\n listRepositoriesForSecretForAuthenticatedUser: [\n \"GET /user/codespaces/secrets/{secret_name}/repositories\"\n ],\n listSecretsForAuthenticatedUser: [\"GET /user/codespaces/secrets\"],\n listSelectedReposForOrgSecret: [\n \"GET /orgs/{org}/codespaces/secrets/{secret_name}/repositories\"\n ],\n preFlightWithRepoForAuthenticatedUser: [\n \"GET /repos/{owner}/{repo}/codespaces/new\"\n ],\n publishForAuthenticatedUser: [\n \"POST /user/codespaces/{codespace_name}/publish\"\n ],\n removeRepositoryForSecretForAuthenticatedUser: [\n \"DELETE /user/codespaces/secrets/{secret_name}/repositories/{repository_id}\"\n ],\n removeSelectedRepoFromOrgSecret: [\n \"DELETE /orgs/{org}/codespaces/secrets/{secret_name}/repositories/{repository_id}\"\n ],\n repoMachinesForAuthenticatedUser: [\n \"GET /repos/{owner}/{repo}/codespaces/machines\"\n ],\n setRepositoriesForSecretForAuthenticatedUser: [\n \"PUT /user/codespaces/secrets/{secret_name}/repositories\"\n ],\n setSelectedReposForOrgSecret: [\n \"PUT /orgs/{org}/codespaces/secrets/{secret_name}/repositories\"\n ],\n startForAuthenticatedUser: [\"POST /user/codespaces/{codespace_name}/start\"],\n stopForAuthenticatedUser: [\"POST /user/codespaces/{codespace_name}/stop\"],\n stopInOrganization: [\n \"POST /orgs/{org}/members/{username}/codespaces/{codespace_name}/stop\"\n ],\n updateForAuthenticatedUser: [\"PATCH /user/codespaces/{codespace_name}\"]\n },\n copilot: {\n addCopilotSeatsForTeams: [\n \"POST /orgs/{org}/copilot/billing/selected_teams\"\n ],\n addCopilotSeatsForUsers: [\n \"POST /orgs/{org}/copilot/billing/selected_users\"\n ],\n cancelCopilotSeatAssignmentForTeams: [\n \"DELETE /orgs/{org}/copilot/billing/selected_teams\"\n ],\n cancelCopilotSeatAssignmentForUsers: [\n \"DELETE /orgs/{org}/copilot/billing/selected_users\"\n ],\n getCopilotOrganizationDetails: [\"GET /orgs/{org}/copilot/billing\"],\n getCopilotSeatDetailsForUser: [\n \"GET /orgs/{org}/members/{username}/copilot\"\n ],\n listCopilotSeats: [\"GET /orgs/{org}/copilot/billing/seats\"]\n },\n dependabot: {\n addSelectedRepoToOrgSecret: [\n \"PUT /orgs/{org}/dependabot/secrets/{secret_name}/repositories/{repository_id}\"\n ],\n createOrUpdateOrgSecret: [\n \"PUT /orgs/{org}/dependabot/secrets/{secret_name}\"\n ],\n createOrUpdateRepoSecret: [\n \"PUT /repos/{owner}/{repo}/dependabot/secrets/{secret_name}\"\n ],\n deleteOrgSecret: [\"DELETE /orgs/{org}/dependabot/secrets/{secret_name}\"],\n deleteRepoSecret: [\n \"DELETE /repos/{owner}/{repo}/dependabot/secrets/{secret_name}\"\n ],\n getAlert: [\"GET /repos/{owner}/{repo}/dependabot/alerts/{alert_number}\"],\n getOrgPublicKey: [\"GET /orgs/{org}/dependabot/secrets/public-key\"],\n getOrgSecret: [\"GET /orgs/{org}/dependabot/secrets/{secret_name}\"],\n getRepoPublicKey: [\n \"GET /repos/{owner}/{repo}/dependabot/secrets/public-key\"\n ],\n getRepoSecret: [\n \"GET /repos/{owner}/{repo}/dependabot/secrets/{secret_name}\"\n ],\n listAlertsForEnterprise: [\n \"GET /enterprises/{enterprise}/dependabot/alerts\"\n ],\n listAlertsForOrg: [\"GET /orgs/{org}/dependabot/alerts\"],\n listAlertsForRepo: [\"GET /repos/{owner}/{repo}/dependabot/alerts\"],\n listOrgSecrets: [\"GET /orgs/{org}/dependabot/secrets\"],\n listRepoSecrets: [\"GET /repos/{owner}/{repo}/dependabot/secrets\"],\n listSelectedReposForOrgSecret: [\n \"GET /orgs/{org}/dependabot/secrets/{secret_name}/repositories\"\n ],\n removeSelectedRepoFromOrgSecret: [\n \"DELETE /orgs/{org}/dependabot/secrets/{secret_name}/repositories/{repository_id}\"\n ],\n setSelectedReposForOrgSecret: [\n \"PUT /orgs/{org}/dependabot/secrets/{secret_name}/repositories\"\n ],\n updateAlert: [\n \"PATCH /repos/{owner}/{repo}/dependabot/alerts/{alert_number}\"\n ]\n },\n dependencyGraph: {\n createRepositorySnapshot: [\n \"POST /repos/{owner}/{repo}/dependency-graph/snapshots\"\n ],\n diffRange: [\n \"GET /repos/{owner}/{repo}/dependency-graph/compare/{basehead}\"\n ],\n exportSbom: [\"GET /repos/{owner}/{repo}/dependency-graph/sbom\"]\n },\n emojis: { get: [\"GET /emojis\"] },\n gists: {\n checkIsStarred: [\"GET /gists/{gist_id}/star\"],\n create: [\"POST /gists\"],\n createComment: [\"POST /gists/{gist_id}/comments\"],\n delete: [\"DELETE /gists/{gist_id}\"],\n deleteComment: [\"DELETE /gists/{gist_id}/comments/{comment_id}\"],\n fork: [\"POST /gists/{gist_id}/forks\"],\n get: [\"GET /gists/{gist_id}\"],\n getComment: [\"GET /gists/{gist_id}/comments/{comment_id}\"],\n getRevision: [\"GET /gists/{gist_id}/{sha}\"],\n list: [\"GET /gists\"],\n listComments: [\"GET /gists/{gist_id}/comments\"],\n listCommits: [\"GET /gists/{gist_id}/commits\"],\n listForUser: [\"GET /users/{username}/gists\"],\n listForks: [\"GET /gists/{gist_id}/forks\"],\n listPublic: [\"GET /gists/public\"],\n listStarred: [\"GET /gists/starred\"],\n star: [\"PUT /gists/{gist_id}/star\"],\n unstar: [\"DELETE /gists/{gist_id}/star\"],\n update: [\"PATCH /gists/{gist_id}\"],\n updateComment: [\"PATCH /gists/{gist_id}/comments/{comment_id}\"]\n },\n git: {\n createBlob: [\"POST /repos/{owner}/{repo}/git/blobs\"],\n createCommit: [\"POST /repos/{owner}/{repo}/git/commits\"],\n createRef: [\"POST /repos/{owner}/{repo}/git/refs\"],\n createTag: [\"POST /repos/{owner}/{repo}/git/tags\"],\n createTree: [\"POST /repos/{owner}/{repo}/git/trees\"],\n deleteRef: [\"DELETE /repos/{owner}/{repo}/git/refs/{ref}\"],\n getBlob: [\"GET /repos/{owner}/{repo}/git/blobs/{file_sha}\"],\n getCommit: [\"GET /repos/{owner}/{repo}/git/commits/{commit_sha}\"],\n getRef: [\"GET /repos/{owner}/{repo}/git/ref/{ref}\"],\n getTag: [\"GET /repos/{owner}/{repo}/git/tags/{tag_sha}\"],\n getTree: [\"GET /repos/{owner}/{repo}/git/trees/{tree_sha}\"],\n listMatchingRefs: [\"GET /repos/{owner}/{repo}/git/matching-refs/{ref}\"],\n updateRef: [\"PATCH /repos/{owner}/{repo}/git/refs/{ref}\"]\n },\n gitignore: {\n getAllTemplates: [\"GET /gitignore/templates\"],\n getTemplate: [\"GET /gitignore/templates/{name}\"]\n },\n interactions: {\n getRestrictionsForAuthenticatedUser: [\"GET /user/interaction-limits\"],\n getRestrictionsForOrg: [\"GET /orgs/{org}/interaction-limits\"],\n getRestrictionsForRepo: [\"GET /repos/{owner}/{repo}/interaction-limits\"],\n getRestrictionsForYourPublicRepos: [\n \"GET /user/interaction-limits\",\n {},\n { renamed: [\"interactions\", \"getRestrictionsForAuthenticatedUser\"] }\n ],\n removeRestrictionsForAuthenticatedUser: [\"DELETE /user/interaction-limits\"],\n removeRestrictionsForOrg: [\"DELETE /orgs/{org}/interaction-limits\"],\n removeRestrictionsForRepo: [\n \"DELETE /repos/{owner}/{repo}/interaction-limits\"\n ],\n removeRestrictionsForYourPublicRepos: [\n \"DELETE /user/interaction-limits\",\n {},\n { renamed: [\"interactions\", \"removeRestrictionsForAuthenticatedUser\"] }\n ],\n setRestrictionsForAuthenticatedUser: [\"PUT /user/interaction-limits\"],\n setRestrictionsForOrg: [\"PUT /orgs/{org}/interaction-limits\"],\n setRestrictionsForRepo: [\"PUT /repos/{owner}/{repo}/interaction-limits\"],\n setRestrictionsForYourPublicRepos: [\n \"PUT /user/interaction-limits\",\n {},\n { renamed: [\"interactions\", \"setRestrictionsForAuthenticatedUser\"] }\n ]\n },\n issues: {\n addAssignees: [\n \"POST /repos/{owner}/{repo}/issues/{issue_number}/assignees\"\n ],\n addLabels: [\"POST /repos/{owner}/{repo}/issues/{issue_number}/labels\"],\n checkUserCanBeAssigned: [\"GET /repos/{owner}/{repo}/assignees/{assignee}\"],\n checkUserCanBeAssignedToIssue: [\n \"GET /repos/{owner}/{repo}/issues/{issue_number}/assignees/{assignee}\"\n ],\n create: [\"POST /repos/{owner}/{repo}/issues\"],\n createComment: [\n \"POST /repos/{owner}/{repo}/issues/{issue_number}/comments\"\n ],\n createLabel: [\"POST /repos/{owner}/{repo}/labels\"],\n createMilestone: [\"POST /repos/{owner}/{repo}/milestones\"],\n deleteComment: [\n \"DELETE /repos/{owner}/{repo}/issues/comments/{comment_id}\"\n ],\n deleteLabel: [\"DELETE /repos/{owner}/{repo}/labels/{name}\"],\n deleteMilestone: [\n \"DELETE /repos/{owner}/{repo}/milestones/{milestone_number}\"\n ],\n get: [\"GET /repos/{owner}/{repo}/issues/{issue_number}\"],\n getComment: [\"GET /repos/{owner}/{repo}/issues/comments/{comment_id}\"],\n getEvent: [\"GET /repos/{owner}/{repo}/issues/events/{event_id}\"],\n getLabel: [\"GET /repos/{owner}/{repo}/labels/{name}\"],\n getMilestone: [\"GET /repos/{owner}/{repo}/milestones/{milestone_number}\"],\n list: [\"GET /issues\"],\n listAssignees: [\"GET /repos/{owner}/{repo}/assignees\"],\n listComments: [\"GET /repos/{owner}/{repo}/issues/{issue_number}/comments\"],\n listCommentsForRepo: [\"GET /repos/{owner}/{repo}/issues/comments\"],\n listEvents: [\"GET /repos/{owner}/{repo}/issues/{issue_number}/events\"],\n listEventsForRepo: [\"GET /repos/{owner}/{repo}/issues/events\"],\n listEventsForTimeline: [\n \"GET /repos/{owner}/{repo}/issues/{issue_number}/timeline\"\n ],\n listForAuthenticatedUser: [\"GET /user/issues\"],\n listForOrg: [\"GET /orgs/{org}/issues\"],\n listForRepo: [\"GET /repos/{owner}/{repo}/issues\"],\n listLabelsForMilestone: [\n \"GET /repos/{owner}/{repo}/milestones/{milestone_number}/labels\"\n ],\n listLabelsForRepo: [\"GET /repos/{owner}/{repo}/labels\"],\n listLabelsOnIssue: [\n \"GET /repos/{owner}/{repo}/issues/{issue_number}/labels\"\n ],\n listMilestones: [\"GET /repos/{owner}/{repo}/milestones\"],\n lock: [\"PUT /repos/{owner}/{repo}/issues/{issue_number}/lock\"],\n removeAllLabels: [\n \"DELETE /repos/{owner}/{repo}/issues/{issue_number}/labels\"\n ],\n removeAssignees: [\n \"DELETE /repos/{owner}/{repo}/issues/{issue_number}/assignees\"\n ],\n removeLabel: [\n \"DELETE /repos/{owner}/{repo}/issues/{issue_number}/labels/{name}\"\n ],\n setLabels: [\"PUT /repos/{owner}/{repo}/issues/{issue_number}/labels\"],\n unlock: [\"DELETE /repos/{owner}/{repo}/issues/{issue_number}/lock\"],\n update: [\"PATCH /repos/{owner}/{repo}/issues/{issue_number}\"],\n updateComment: [\"PATCH /repos/{owner}/{repo}/issues/comments/{comment_id}\"],\n updateLabel: [\"PATCH /repos/{owner}/{repo}/labels/{name}\"],\n updateMilestone: [\n \"PATCH /repos/{owner}/{repo}/milestones/{milestone_number}\"\n ]\n },\n licenses: {\n get: [\"GET /licenses/{license}\"],\n getAllCommonlyUsed: [\"GET /licenses\"],\n getForRepo: [\"GET /repos/{owner}/{repo}/license\"]\n },\n markdown: {\n render: [\"POST /markdown\"],\n renderRaw: [\n \"POST /markdown/raw\",\n { headers: { \"content-type\": \"text/plain; charset=utf-8\" } }\n ]\n },\n meta: {\n get: [\"GET /meta\"],\n getAllVersions: [\"GET /versions\"],\n getOctocat: [\"GET /octocat\"],\n getZen: [\"GET /zen\"],\n root: [\"GET /\"]\n },\n migrations: {\n cancelImport: [\n \"DELETE /repos/{owner}/{repo}/import\",\n {},\n {\n deprecated: \"octokit.rest.migrations.cancelImport() is deprecated, see https://docs.github.com/rest/migrations/source-imports#cancel-an-import\"\n }\n ],\n deleteArchiveForAuthenticatedUser: [\n \"DELETE /user/migrations/{migration_id}/archive\"\n ],\n deleteArchiveForOrg: [\n \"DELETE /orgs/{org}/migrations/{migration_id}/archive\"\n ],\n downloadArchiveForOrg: [\n \"GET /orgs/{org}/migrations/{migration_id}/archive\"\n ],\n getArchiveForAuthenticatedUser: [\n \"GET /user/migrations/{migration_id}/archive\"\n ],\n getCommitAuthors: [\n \"GET /repos/{owner}/{repo}/import/authors\",\n {},\n {\n deprecated: \"octokit.rest.migrations.getCommitAuthors() is deprecated, see https://docs.github.com/rest/migrations/source-imports#get-commit-authors\"\n }\n ],\n getImportStatus: [\n \"GET /repos/{owner}/{repo}/import\",\n {},\n {\n deprecated: \"octokit.rest.migrations.getImportStatus() is deprecated, see https://docs.github.com/rest/migrations/source-imports#get-an-import-status\"\n }\n ],\n getLargeFiles: [\n \"GET /repos/{owner}/{repo}/import/large_files\",\n {},\n {\n deprecated: \"octokit.rest.migrations.getLargeFiles() is deprecated, see https://docs.github.com/rest/migrations/source-imports#get-large-files\"\n }\n ],\n getStatusForAuthenticatedUser: [\"GET /user/migrations/{migration_id}\"],\n getStatusForOrg: [\"GET /orgs/{org}/migrations/{migration_id}\"],\n listForAuthenticatedUser: [\"GET /user/migrations\"],\n listForOrg: [\"GET /orgs/{org}/migrations\"],\n listReposForAuthenticatedUser: [\n \"GET /user/migrations/{migration_id}/repositories\"\n ],\n listReposForOrg: [\"GET /orgs/{org}/migrations/{migration_id}/repositories\"],\n listReposForUser: [\n \"GET /user/migrations/{migration_id}/repositories\",\n {},\n { renamed: [\"migrations\", \"listReposForAuthenticatedUser\"] }\n ],\n mapCommitAuthor: [\n \"PATCH /repos/{owner}/{repo}/import/authors/{author_id}\",\n {},\n {\n deprecated: \"octokit.rest.migrations.mapCommitAuthor() is deprecated, see https://docs.github.com/rest/migrations/source-imports#map-a-commit-author\"\n }\n ],\n setLfsPreference: [\n \"PATCH /repos/{owner}/{repo}/import/lfs\",\n {},\n {\n deprecated: \"octokit.rest.migrations.setLfsPreference() is deprecated, see https://docs.github.com/rest/migrations/source-imports#update-git-lfs-preference\"\n }\n ],\n startForAuthenticatedUser: [\"POST /user/migrations\"],\n startForOrg: [\"POST /orgs/{org}/migrations\"],\n startImport: [\n \"PUT /repos/{owner}/{repo}/import\",\n {},\n {\n deprecated: \"octokit.rest.migrations.startImport() is deprecated, see https://docs.github.com/rest/migrations/source-imports#start-an-import\"\n }\n ],\n unlockRepoForAuthenticatedUser: [\n \"DELETE /user/migrations/{migration_id}/repos/{repo_name}/lock\"\n ],\n unlockRepoForOrg: [\n \"DELETE /orgs/{org}/migrations/{migration_id}/repos/{repo_name}/lock\"\n ],\n updateImport: [\n \"PATCH /repos/{owner}/{repo}/import\",\n {},\n {\n deprecated: \"octokit.rest.migrations.updateImport() is deprecated, see https://docs.github.com/rest/migrations/source-imports#update-an-import\"\n }\n ]\n },\n oidc: {\n getOidcCustomSubTemplateForOrg: [\n \"GET /orgs/{org}/actions/oidc/customization/sub\"\n ],\n updateOidcCustomSubTemplateForOrg: [\n \"PUT /orgs/{org}/actions/oidc/customization/sub\"\n ]\n },\n orgs: {\n addSecurityManagerTeam: [\n \"PUT /orgs/{org}/security-managers/teams/{team_slug}\"\n ],\n assignTeamToOrgRole: [\n \"PUT /orgs/{org}/organization-roles/teams/{team_slug}/{role_id}\"\n ],\n assignUserToOrgRole: [\n \"PUT /orgs/{org}/organization-roles/users/{username}/{role_id}\"\n ],\n blockUser: [\"PUT /orgs/{org}/blocks/{username}\"],\n cancelInvitation: [\"DELETE /orgs/{org}/invitations/{invitation_id}\"],\n checkBlockedUser: [\"GET /orgs/{org}/blocks/{username}\"],\n checkMembershipForUser: [\"GET /orgs/{org}/members/{username}\"],\n checkPublicMembershipForUser: [\"GET /orgs/{org}/public_members/{username}\"],\n convertMemberToOutsideCollaborator: [\n \"PUT /orgs/{org}/outside_collaborators/{username}\"\n ],\n createCustomOrganizationRole: [\"POST /orgs/{org}/organization-roles\"],\n createInvitation: [\"POST /orgs/{org}/invitations\"],\n createOrUpdateCustomProperties: [\"PATCH /orgs/{org}/properties/schema\"],\n createOrUpdateCustomPropertiesValuesForRepos: [\n \"PATCH /orgs/{org}/properties/values\"\n ],\n createOrUpdateCustomProperty: [\n \"PUT /orgs/{org}/properties/schema/{custom_property_name}\"\n ],\n createWebhook: [\"POST /orgs/{org}/hooks\"],\n delete: [\"DELETE /orgs/{org}\"],\n deleteCustomOrganizationRole: [\n \"DELETE /orgs/{org}/organization-roles/{role_id}\"\n ],\n deleteWebhook: [\"DELETE /orgs/{org}/hooks/{hook_id}\"],\n enableOrDisableSecurityProductOnAllOrgRepos: [\n \"POST /orgs/{org}/{security_product}/{enablement}\"\n ],\n get: [\"GET /orgs/{org}\"],\n getAllCustomProperties: [\"GET /orgs/{org}/properties/schema\"],\n getCustomProperty: [\n \"GET /orgs/{org}/properties/schema/{custom_property_name}\"\n ],\n getMembershipForAuthenticatedUser: [\"GET /user/memberships/orgs/{org}\"],\n getMembershipForUser: [\"GET /orgs/{org}/memberships/{username}\"],\n getOrgRole: [\"GET /orgs/{org}/organization-roles/{role_id}\"],\n getWebhook: [\"GET /orgs/{org}/hooks/{hook_id}\"],\n getWebhookConfigForOrg: [\"GET /orgs/{org}/hooks/{hook_id}/config\"],\n getWebhookDelivery: [\n \"GET /orgs/{org}/hooks/{hook_id}/deliveries/{delivery_id}\"\n ],\n list: [\"GET /organizations\"],\n listAppInstallations: [\"GET /orgs/{org}/installations\"],\n listBlockedUsers: [\"GET /orgs/{org}/blocks\"],\n listCustomPropertiesValuesForRepos: [\"GET /orgs/{org}/properties/values\"],\n listFailedInvitations: [\"GET /orgs/{org}/failed_invitations\"],\n listForAuthenticatedUser: [\"GET /user/orgs\"],\n listForUser: [\"GET /users/{username}/orgs\"],\n listInvitationTeams: [\"GET /orgs/{org}/invitations/{invitation_id}/teams\"],\n listMembers: [\"GET /orgs/{org}/members\"],\n listMembershipsForAuthenticatedUser: [\"GET /user/memberships/orgs\"],\n listOrgRoleTeams: [\"GET /orgs/{org}/organization-roles/{role_id}/teams\"],\n listOrgRoleUsers: [\"GET /orgs/{org}/organization-roles/{role_id}/users\"],\n listOrgRoles: [\"GET /orgs/{org}/organization-roles\"],\n listOrganizationFineGrainedPermissions: [\n \"GET /orgs/{org}/organization-fine-grained-permissions\"\n ],\n listOutsideCollaborators: [\"GET /orgs/{org}/outside_collaborators\"],\n listPatGrantRepositories: [\n \"GET /orgs/{org}/personal-access-tokens/{pat_id}/repositories\"\n ],\n listPatGrantRequestRepositories: [\n \"GET /orgs/{org}/personal-access-token-requests/{pat_request_id}/repositories\"\n ],\n listPatGrantRequests: [\"GET /orgs/{org}/personal-access-token-requests\"],\n listPatGrants: [\"GET /orgs/{org}/personal-access-tokens\"],\n listPendingInvitations: [\"GET /orgs/{org}/invitations\"],\n listPublicMembers: [\"GET /orgs/{org}/public_members\"],\n listSecurityManagerTeams: [\"GET /orgs/{org}/security-managers\"],\n listWebhookDeliveries: [\"GET /orgs/{org}/hooks/{hook_id}/deliveries\"],\n listWebhooks: [\"GET /orgs/{org}/hooks\"],\n patchCustomOrganizationRole: [\n \"PATCH /orgs/{org}/organization-roles/{role_id}\"\n ],\n pingWebhook: [\"POST /orgs/{org}/hooks/{hook_id}/pings\"],\n redeliverWebhookDelivery: [\n \"POST /orgs/{org}/hooks/{hook_id}/deliveries/{delivery_id}/attempts\"\n ],\n removeCustomProperty: [\n \"DELETE /orgs/{org}/properties/schema/{custom_property_name}\"\n ],\n removeMember: [\"DELETE /orgs/{org}/members/{username}\"],\n removeMembershipForUser: [\"DELETE /orgs/{org}/memberships/{username}\"],\n removeOutsideCollaborator: [\n \"DELETE /orgs/{org}/outside_collaborators/{username}\"\n ],\n removePublicMembershipForAuthenticatedUser: [\n \"DELETE /orgs/{org}/public_members/{username}\"\n ],\n removeSecurityManagerTeam: [\n \"DELETE /orgs/{org}/security-managers/teams/{team_slug}\"\n ],\n reviewPatGrantRequest: [\n \"POST /orgs/{org}/personal-access-token-requests/{pat_request_id}\"\n ],\n reviewPatGrantRequestsInBulk: [\n \"POST /orgs/{org}/personal-access-token-requests\"\n ],\n revokeAllOrgRolesTeam: [\n \"DELETE /orgs/{org}/organization-roles/teams/{team_slug}\"\n ],\n revokeAllOrgRolesUser: [\n \"DELETE /orgs/{org}/organization-roles/users/{username}\"\n ],\n revokeOrgRoleTeam: [\n \"DELETE /orgs/{org}/organization-roles/teams/{team_slug}/{role_id}\"\n ],\n revokeOrgRoleUser: [\n \"DELETE /orgs/{org}/organization-roles/users/{username}/{role_id}\"\n ],\n setMembershipForUser: [\"PUT /orgs/{org}/memberships/{username}\"],\n setPublicMembershipForAuthenticatedUser: [\n \"PUT /orgs/{org}/public_members/{username}\"\n ],\n unblockUser: [\"DELETE /orgs/{org}/blocks/{username}\"],\n update: [\"PATCH /orgs/{org}\"],\n updateMembershipForAuthenticatedUser: [\n \"PATCH /user/memberships/orgs/{org}\"\n ],\n updatePatAccess: [\"POST /orgs/{org}/personal-access-tokens/{pat_id}\"],\n updatePatAccesses: [\"POST /orgs/{org}/personal-access-tokens\"],\n updateWebhook: [\"PATCH /orgs/{org}/hooks/{hook_id}\"],\n updateWebhookConfigForOrg: [\"PATCH /orgs/{org}/hooks/{hook_id}/config\"]\n },\n packages: {\n deletePackageForAuthenticatedUser: [\n \"DELETE /user/packages/{package_type}/{package_name}\"\n ],\n deletePackageForOrg: [\n \"DELETE /orgs/{org}/packages/{package_type}/{package_name}\"\n ],\n deletePackageForUser: [\n \"DELETE /users/{username}/packages/{package_type}/{package_name}\"\n ],\n deletePackageVersionForAuthenticatedUser: [\n \"DELETE /user/packages/{package_type}/{package_name}/versions/{package_version_id}\"\n ],\n deletePackageVersionForOrg: [\n \"DELETE /orgs/{org}/packages/{package_type}/{package_name}/versions/{package_version_id}\"\n ],\n deletePackageVersionForUser: [\n \"DELETE /users/{username}/packages/{package_type}/{package_name}/versions/{package_version_id}\"\n ],\n getAllPackageVersionsForAPackageOwnedByAnOrg: [\n \"GET /orgs/{org}/packages/{package_type}/{package_name}/versions\",\n {},\n { renamed: [\"packages\", \"getAllPackageVersionsForPackageOwnedByOrg\"] }\n ],\n getAllPackageVersionsForAPackageOwnedByTheAuthenticatedUser: [\n \"GET /user/packages/{package_type}/{package_name}/versions\",\n {},\n {\n renamed: [\n \"packages\",\n \"getAllPackageVersionsForPackageOwnedByAuthenticatedUser\"\n ]\n }\n ],\n getAllPackageVersionsForPackageOwnedByAuthenticatedUser: [\n \"GET /user/packages/{package_type}/{package_name}/versions\"\n ],\n getAllPackageVersionsForPackageOwnedByOrg: [\n \"GET /orgs/{org}/packages/{package_type}/{package_name}/versions\"\n ],\n getAllPackageVersionsForPackageOwnedByUser: [\n \"GET /users/{username}/packages/{package_type}/{package_name}/versions\"\n ],\n getPackageForAuthenticatedUser: [\n \"GET /user/packages/{package_type}/{package_name}\"\n ],\n getPackageForOrganization: [\n \"GET /orgs/{org}/packages/{package_type}/{package_name}\"\n ],\n getPackageForUser: [\n \"GET /users/{username}/packages/{package_type}/{package_name}\"\n ],\n getPackageVersionForAuthenticatedUser: [\n \"GET /user/packages/{package_type}/{package_name}/versions/{package_version_id}\"\n ],\n getPackageVersionForOrganization: [\n \"GET /orgs/{org}/packages/{package_type}/{package_name}/versions/{package_version_id}\"\n ],\n getPackageVersionForUser: [\n \"GET /users/{username}/packages/{package_type}/{package_name}/versions/{package_version_id}\"\n ],\n listDockerMigrationConflictingPackagesForAuthenticatedUser: [\n \"GET /user/docker/conflicts\"\n ],\n listDockerMigrationConflictingPackagesForOrganization: [\n \"GET /orgs/{org}/docker/conflicts\"\n ],\n listDockerMigrationConflictingPackagesForUser: [\n \"GET /users/{username}/docker/conflicts\"\n ],\n listPackagesForAuthenticatedUser: [\"GET /user/packages\"],\n listPackagesForOrganization: [\"GET /orgs/{org}/packages\"],\n listPackagesForUser: [\"GET /users/{username}/packages\"],\n restorePackageForAuthenticatedUser: [\n \"POST /user/packages/{package_type}/{package_name}/restore{?token}\"\n ],\n restorePackageForOrg: [\n \"POST /orgs/{org}/packages/{package_type}/{package_name}/restore{?token}\"\n ],\n restorePackageForUser: [\n \"POST /users/{username}/packages/{package_type}/{package_name}/restore{?token}\"\n ],\n restorePackageVersionForAuthenticatedUser: [\n \"POST /user/packages/{package_type}/{package_name}/versions/{package_version_id}/restore\"\n ],\n restorePackageVersionForOrg: [\n \"POST /orgs/{org}/packages/{package_type}/{package_name}/versions/{package_version_id}/restore\"\n ],\n restorePackageVersionForUser: [\n \"POST /users/{username}/packages/{package_type}/{package_name}/versions/{package_version_id}/restore\"\n ]\n },\n projects: {\n addCollaborator: [\"PUT /projects/{project_id}/collaborators/{username}\"],\n createCard: [\"POST /projects/columns/{column_id}/cards\"],\n createColumn: [\"POST /projects/{project_id}/columns\"],\n createForAuthenticatedUser: [\"POST /user/projects\"],\n createForOrg: [\"POST /orgs/{org}/projects\"],\n createForRepo: [\"POST /repos/{owner}/{repo}/projects\"],\n delete: [\"DELETE /projects/{project_id}\"],\n deleteCard: [\"DELETE /projects/columns/cards/{card_id}\"],\n deleteColumn: [\"DELETE /projects/columns/{column_id}\"],\n get: [\"GET /projects/{project_id}\"],\n getCard: [\"GET /projects/columns/cards/{card_id}\"],\n getColumn: [\"GET /projects/columns/{column_id}\"],\n getPermissionForUser: [\n \"GET /projects/{project_id}/collaborators/{username}/permission\"\n ],\n listCards: [\"GET /projects/columns/{column_id}/cards\"],\n listCollaborators: [\"GET /projects/{project_id}/collaborators\"],\n listColumns: [\"GET /projects/{project_id}/columns\"],\n listForOrg: [\"GET /orgs/{org}/projects\"],\n listForRepo: [\"GET /repos/{owner}/{repo}/projects\"],\n listForUser: [\"GET /users/{username}/projects\"],\n moveCard: [\"POST /projects/columns/cards/{card_id}/moves\"],\n moveColumn: [\"POST /projects/columns/{column_id}/moves\"],\n removeCollaborator: [\n \"DELETE /projects/{project_id}/collaborators/{username}\"\n ],\n update: [\"PATCH /projects/{project_id}\"],\n updateCard: [\"PATCH /projects/columns/cards/{card_id}\"],\n updateColumn: [\"PATCH /projects/columns/{column_id}\"]\n },\n pulls: {\n checkIfMerged: [\"GET /repos/{owner}/{repo}/pulls/{pull_number}/merge\"],\n create: [\"POST /repos/{owner}/{repo}/pulls\"],\n createReplyForReviewComment: [\n \"POST /repos/{owner}/{repo}/pulls/{pull_number}/comments/{comment_id}/replies\"\n ],\n createReview: [\"POST /repos/{owner}/{repo}/pulls/{pull_number}/reviews\"],\n createReviewComment: [\n \"POST /repos/{owner}/{repo}/pulls/{pull_number}/comments\"\n ],\n deletePendingReview: [\n \"DELETE /repos/{owner}/{repo}/pulls/{pull_number}/reviews/{review_id}\"\n ],\n deleteReviewComment: [\n \"DELETE /repos/{owner}/{repo}/pulls/comments/{comment_id}\"\n ],\n dismissReview: [\n \"PUT /repos/{owner}/{repo}/pulls/{pull_number}/reviews/{review_id}/dismissals\"\n ],\n get: [\"GET /repos/{owner}/{repo}/pulls/{pull_number}\"],\n getReview: [\n \"GET /repos/{owner}/{repo}/pulls/{pull_number}/reviews/{review_id}\"\n ],\n getReviewComment: [\"GET /repos/{owner}/{repo}/pulls/comments/{comment_id}\"],\n list: [\"GET /repos/{owner}/{repo}/pulls\"],\n listCommentsForReview: [\n \"GET /repos/{owner}/{repo}/pulls/{pull_number}/reviews/{review_id}/comments\"\n ],\n listCommits: [\"GET /repos/{owner}/{repo}/pulls/{pull_number}/commits\"],\n listFiles: [\"GET /repos/{owner}/{repo}/pulls/{pull_number}/files\"],\n listRequestedReviewers: [\n \"GET /repos/{owner}/{repo}/pulls/{pull_number}/requested_reviewers\"\n ],\n listReviewComments: [\n \"GET /repos/{owner}/{repo}/pulls/{pull_number}/comments\"\n ],\n listReviewCommentsForRepo: [\"GET /repos/{owner}/{repo}/pulls/comments\"],\n listReviews: [\"GET /repos/{owner}/{repo}/pulls/{pull_number}/reviews\"],\n merge: [\"PUT /repos/{owner}/{repo}/pulls/{pull_number}/merge\"],\n removeRequestedReviewers: [\n \"DELETE /repos/{owner}/{repo}/pulls/{pull_number}/requested_reviewers\"\n ],\n requestReviewers: [\n \"POST /repos/{owner}/{repo}/pulls/{pull_number}/requested_reviewers\"\n ],\n submitReview: [\n \"POST /repos/{owner}/{repo}/pulls/{pull_number}/reviews/{review_id}/events\"\n ],\n update: [\"PATCH /repos/{owner}/{repo}/pulls/{pull_number}\"],\n updateBranch: [\n \"PUT /repos/{owner}/{repo}/pulls/{pull_number}/update-branch\"\n ],\n updateReview: [\n \"PUT /repos/{owner}/{repo}/pulls/{pull_number}/reviews/{review_id}\"\n ],\n updateReviewComment: [\n \"PATCH /repos/{owner}/{repo}/pulls/comments/{comment_id}\"\n ]\n },\n rateLimit: { get: [\"GET /rate_limit\"] },\n reactions: {\n createForCommitComment: [\n \"POST /repos/{owner}/{repo}/comments/{comment_id}/reactions\"\n ],\n createForIssue: [\n \"POST /repos/{owner}/{repo}/issues/{issue_number}/reactions\"\n ],\n createForIssueComment: [\n \"POST /repos/{owner}/{repo}/issues/comments/{comment_id}/reactions\"\n ],\n createForPullRequestReviewComment: [\n \"POST /repos/{owner}/{repo}/pulls/comments/{comment_id}/reactions\"\n ],\n createForRelease: [\n \"POST /repos/{owner}/{repo}/releases/{release_id}/reactions\"\n ],\n createForTeamDiscussionCommentInOrg: [\n \"POST /orgs/{org}/teams/{team_slug}/discussions/{discussion_number}/comments/{comment_number}/reactions\"\n ],\n createForTeamDiscussionInOrg: [\n \"POST /orgs/{org}/teams/{team_slug}/discussions/{discussion_number}/reactions\"\n ],\n deleteForCommitComment: [\n \"DELETE /repos/{owner}/{repo}/comments/{comment_id}/reactions/{reaction_id}\"\n ],\n deleteForIssue: [\n \"DELETE /repos/{owner}/{repo}/issues/{issue_number}/reactions/{reaction_id}\"\n ],\n deleteForIssueComment: [\n \"DELETE /repos/{owner}/{repo}/issues/comments/{comment_id}/reactions/{reaction_id}\"\n ],\n deleteForPullRequestComment: [\n \"DELETE /repos/{owner}/{repo}/pulls/comments/{comment_id}/reactions/{reaction_id}\"\n ],\n deleteForRelease: [\n \"DELETE /repos/{owner}/{repo}/releases/{release_id}/reactions/{reaction_id}\"\n ],\n deleteForTeamDiscussion: [\n \"DELETE /orgs/{org}/teams/{team_slug}/discussions/{discussion_number}/reactions/{reaction_id}\"\n ],\n deleteForTeamDiscussionComment: [\n \"DELETE /orgs/{org}/teams/{team_slug}/discussions/{discussion_number}/comments/{comment_number}/reactions/{reaction_id}\"\n ],\n listForCommitComment: [\n \"GET /repos/{owner}/{repo}/comments/{comment_id}/reactions\"\n ],\n listForIssue: [\"GET /repos/{owner}/{repo}/issues/{issue_number}/reactions\"],\n listForIssueComment: [\n \"GET /repos/{owner}/{repo}/issues/comments/{comment_id}/reactions\"\n ],\n listForPullRequestReviewComment: [\n \"GET /repos/{owner}/{repo}/pulls/comments/{comment_id}/reactions\"\n ],\n listForRelease: [\n \"GET /repos/{owner}/{repo}/releases/{release_id}/reactions\"\n ],\n listForTeamDiscussionCommentInOrg: [\n \"GET /orgs/{org}/teams/{team_slug}/discussions/{discussion_number}/comments/{comment_number}/reactions\"\n ],\n listForTeamDiscussionInOrg: [\n \"GET /orgs/{org}/teams/{team_slug}/discussions/{discussion_number}/reactions\"\n ]\n },\n repos: {\n acceptInvitation: [\n \"PATCH /user/repository_invitations/{invitation_id}\",\n {},\n { renamed: [\"repos\", \"acceptInvitationForAuthenticatedUser\"] }\n ],\n acceptInvitationForAuthenticatedUser: [\n \"PATCH /user/repository_invitations/{invitation_id}\"\n ],\n addAppAccessRestrictions: [\n \"POST /repos/{owner}/{repo}/branches/{branch}/protection/restrictions/apps\",\n {},\n { mapToData: \"apps\" }\n ],\n addCollaborator: [\"PUT /repos/{owner}/{repo}/collaborators/{username}\"],\n addStatusCheckContexts: [\n \"POST /repos/{owner}/{repo}/branches/{branch}/protection/required_status_checks/contexts\",\n {},\n { mapToData: \"contexts\" }\n ],\n addTeamAccessRestrictions: [\n \"POST /repos/{owner}/{repo}/branches/{branch}/protection/restrictions/teams\",\n {},\n { mapToData: \"teams\" }\n ],\n addUserAccessRestrictions: [\n \"POST /repos/{owner}/{repo}/branches/{branch}/protection/restrictions/users\",\n {},\n { mapToData: \"users\" }\n ],\n cancelPagesDeployment: [\n \"POST /repos/{owner}/{repo}/pages/deployments/{pages_deployment_id}/cancel\"\n ],\n checkAutomatedSecurityFixes: [\n \"GET /repos/{owner}/{repo}/automated-security-fixes\"\n ],\n checkCollaborator: [\"GET /repos/{owner}/{repo}/collaborators/{username}\"],\n checkVulnerabilityAlerts: [\n \"GET /repos/{owner}/{repo}/vulnerability-alerts\"\n ],\n codeownersErrors: [\"GET /repos/{owner}/{repo}/codeowners/errors\"],\n compareCommits: [\"GET /repos/{owner}/{repo}/compare/{base}...{head}\"],\n compareCommitsWithBasehead: [\n \"GET /repos/{owner}/{repo}/compare/{basehead}\"\n ],\n createAutolink: [\"POST /repos/{owner}/{repo}/autolinks\"],\n createCommitComment: [\n \"POST /repos/{owner}/{repo}/commits/{commit_sha}/comments\"\n ],\n createCommitSignatureProtection: [\n \"POST /repos/{owner}/{repo}/branches/{branch}/protection/required_signatures\"\n ],\n createCommitStatus: [\"POST /repos/{owner}/{repo}/statuses/{sha}\"],\n createDeployKey: [\"POST /repos/{owner}/{repo}/keys\"],\n createDeployment: [\"POST /repos/{owner}/{repo}/deployments\"],\n createDeploymentBranchPolicy: [\n \"POST /repos/{owner}/{repo}/environments/{environment_name}/deployment-branch-policies\"\n ],\n createDeploymentProtectionRule: [\n \"POST /repos/{owner}/{repo}/environments/{environment_name}/deployment_protection_rules\"\n ],\n createDeploymentStatus: [\n \"POST /repos/{owner}/{repo}/deployments/{deployment_id}/statuses\"\n ],\n createDispatchEvent: [\"POST /repos/{owner}/{repo}/dispatches\"],\n createForAuthenticatedUser: [\"POST /user/repos\"],\n createFork: [\"POST /repos/{owner}/{repo}/forks\"],\n createInOrg: [\"POST /orgs/{org}/repos\"],\n createOrUpdateCustomPropertiesValues: [\n \"PATCH /repos/{owner}/{repo}/properties/values\"\n ],\n createOrUpdateEnvironment: [\n \"PUT /repos/{owner}/{repo}/environments/{environment_name}\"\n ],\n createOrUpdateFileContents: [\"PUT /repos/{owner}/{repo}/contents/{path}\"],\n createOrgRuleset: [\"POST /orgs/{org}/rulesets\"],\n createPagesDeployment: [\"POST /repos/{owner}/{repo}/pages/deployments\"],\n createPagesSite: [\"POST /repos/{owner}/{repo}/pages\"],\n createRelease: [\"POST /repos/{owner}/{repo}/releases\"],\n createRepoRuleset: [\"POST /repos/{owner}/{repo}/rulesets\"],\n createTagProtection: [\"POST /repos/{owner}/{repo}/tags/protection\"],\n createUsingTemplate: [\n \"POST /repos/{template_owner}/{template_repo}/generate\"\n ],\n createWebhook: [\"POST /repos/{owner}/{repo}/hooks\"],\n declineInvitation: [\n \"DELETE /user/repository_invitations/{invitation_id}\",\n {},\n { renamed: [\"repos\", \"declineInvitationForAuthenticatedUser\"] }\n ],\n declineInvitationForAuthenticatedUser: [\n \"DELETE /user/repository_invitations/{invitation_id}\"\n ],\n delete: [\"DELETE /repos/{owner}/{repo}\"],\n deleteAccessRestrictions: [\n \"DELETE /repos/{owner}/{repo}/branches/{branch}/protection/restrictions\"\n ],\n deleteAdminBranchProtection: [\n \"DELETE /repos/{owner}/{repo}/branches/{branch}/protection/enforce_admins\"\n ],\n deleteAnEnvironment: [\n \"DELETE /repos/{owner}/{repo}/environments/{environment_name}\"\n ],\n deleteAutolink: [\"DELETE /repos/{owner}/{repo}/autolinks/{autolink_id}\"],\n deleteBranchProtection: [\n \"DELETE /repos/{owner}/{repo}/branches/{branch}/protection\"\n ],\n deleteCommitComment: [\"DELETE /repos/{owner}/{repo}/comments/{comment_id}\"],\n deleteCommitSignatureProtection: [\n \"DELETE /repos/{owner}/{repo}/branches/{branch}/protection/required_signatures\"\n ],\n deleteDeployKey: [\"DELETE /repos/{owner}/{repo}/keys/{key_id}\"],\n deleteDeployment: [\n \"DELETE /repos/{owner}/{repo}/deployments/{deployment_id}\"\n ],\n deleteDeploymentBranchPolicy: [\n \"DELETE /repos/{owner}/{repo}/environments/{environment_name}/deployment-branch-policies/{branch_policy_id}\"\n ],\n deleteFile: [\"DELETE /repos/{owner}/{repo}/contents/{path}\"],\n deleteInvitation: [\n \"DELETE /repos/{owner}/{repo}/invitations/{invitation_id}\"\n ],\n deleteOrgRuleset: [\"DELETE /orgs/{org}/rulesets/{ruleset_id}\"],\n deletePagesSite: [\"DELETE /repos/{owner}/{repo}/pages\"],\n deletePullRequestReviewProtection: [\n \"DELETE /repos/{owner}/{repo}/branches/{branch}/protection/required_pull_request_reviews\"\n ],\n deleteRelease: [\"DELETE /repos/{owner}/{repo}/releases/{release_id}\"],\n deleteReleaseAsset: [\n \"DELETE /repos/{owner}/{repo}/releases/assets/{asset_id}\"\n ],\n deleteRepoRuleset: [\"DELETE /repos/{owner}/{repo}/rulesets/{ruleset_id}\"],\n deleteTagProtection: [\n \"DELETE /repos/{owner}/{repo}/tags/protection/{tag_protection_id}\"\n ],\n deleteWebhook: [\"DELETE /repos/{owner}/{repo}/hooks/{hook_id}\"],\n disableAutomatedSecurityFixes: [\n \"DELETE /repos/{owner}/{repo}/automated-security-fixes\"\n ],\n disableDeploymentProtectionRule: [\n \"DELETE /repos/{owner}/{repo}/environments/{environment_name}/deployment_protection_rules/{protection_rule_id}\"\n ],\n disablePrivateVulnerabilityReporting: [\n \"DELETE /repos/{owner}/{repo}/private-vulnerability-reporting\"\n ],\n disableVulnerabilityAlerts: [\n \"DELETE /repos/{owner}/{repo}/vulnerability-alerts\"\n ],\n downloadArchive: [\n \"GET /repos/{owner}/{repo}/zipball/{ref}\",\n {},\n { renamed: [\"repos\", \"downloadZipballArchive\"] }\n ],\n downloadTarballArchive: [\"GET /repos/{owner}/{repo}/tarball/{ref}\"],\n downloadZipballArchive: [\"GET /repos/{owner}/{repo}/zipball/{ref}\"],\n enableAutomatedSecurityFixes: [\n \"PUT /repos/{owner}/{repo}/automated-security-fixes\"\n ],\n enablePrivateVulnerabilityReporting: [\n \"PUT /repos/{owner}/{repo}/private-vulnerability-reporting\"\n ],\n enableVulnerabilityAlerts: [\n \"PUT /repos/{owner}/{repo}/vulnerability-alerts\"\n ],\n generateReleaseNotes: [\n \"POST /repos/{owner}/{repo}/releases/generate-notes\"\n ],\n get: [\"GET /repos/{owner}/{repo}\"],\n getAccessRestrictions: [\n \"GET /repos/{owner}/{repo}/branches/{branch}/protection/restrictions\"\n ],\n getAdminBranchProtection: [\n \"GET /repos/{owner}/{repo}/branches/{branch}/protection/enforce_admins\"\n ],\n getAllDeploymentProtectionRules: [\n \"GET /repos/{owner}/{repo}/environments/{environment_name}/deployment_protection_rules\"\n ],\n getAllEnvironments: [\"GET /repos/{owner}/{repo}/environments\"],\n getAllStatusCheckContexts: [\n \"GET /repos/{owner}/{repo}/branches/{branch}/protection/required_status_checks/contexts\"\n ],\n getAllTopics: [\"GET /repos/{owner}/{repo}/topics\"],\n getAppsWithAccessToProtectedBranch: [\n \"GET /repos/{owner}/{repo}/branches/{branch}/protection/restrictions/apps\"\n ],\n getAutolink: [\"GET /repos/{owner}/{repo}/autolinks/{autolink_id}\"],\n getBranch: [\"GET /repos/{owner}/{repo}/branches/{branch}\"],\n getBranchProtection: [\n \"GET /repos/{owner}/{repo}/branches/{branch}/protection\"\n ],\n getBranchRules: [\"GET /repos/{owner}/{repo}/rules/branches/{branch}\"],\n getClones: [\"GET /repos/{owner}/{repo}/traffic/clones\"],\n getCodeFrequencyStats: [\"GET /repos/{owner}/{repo}/stats/code_frequency\"],\n getCollaboratorPermissionLevel: [\n \"GET /repos/{owner}/{repo}/collaborators/{username}/permission\"\n ],\n getCombinedStatusForRef: [\"GET /repos/{owner}/{repo}/commits/{ref}/status\"],\n getCommit: [\"GET /repos/{owner}/{repo}/commits/{ref}\"],\n getCommitActivityStats: [\"GET /repos/{owner}/{repo}/stats/commit_activity\"],\n getCommitComment: [\"GET /repos/{owner}/{repo}/comments/{comment_id}\"],\n getCommitSignatureProtection: [\n \"GET /repos/{owner}/{repo}/branches/{branch}/protection/required_signatures\"\n ],\n getCommunityProfileMetrics: [\"GET /repos/{owner}/{repo}/community/profile\"],\n getContent: [\"GET /repos/{owner}/{repo}/contents/{path}\"],\n getContributorsStats: [\"GET /repos/{owner}/{repo}/stats/contributors\"],\n getCustomDeploymentProtectionRule: [\n \"GET /repos/{owner}/{repo}/environments/{environment_name}/deployment_protection_rules/{protection_rule_id}\"\n ],\n getCustomPropertiesValues: [\"GET /repos/{owner}/{repo}/properties/values\"],\n getDeployKey: [\"GET /repos/{owner}/{repo}/keys/{key_id}\"],\n getDeployment: [\"GET /repos/{owner}/{repo}/deployments/{deployment_id}\"],\n getDeploymentBranchPolicy: [\n \"GET /repos/{owner}/{repo}/environments/{environment_name}/deployment-branch-policies/{branch_policy_id}\"\n ],\n getDeploymentStatus: [\n \"GET /repos/{owner}/{repo}/deployments/{deployment_id}/statuses/{status_id}\"\n ],\n getEnvironment: [\n \"GET /repos/{owner}/{repo}/environments/{environment_name}\"\n ],\n getLatestPagesBuild: [\"GET /repos/{owner}/{repo}/pages/builds/latest\"],\n getLatestRelease: [\"GET /repos/{owner}/{repo}/releases/latest\"],\n getOrgRuleSuite: [\"GET /orgs/{org}/rulesets/rule-suites/{rule_suite_id}\"],\n getOrgRuleSuites: [\"GET /orgs/{org}/rulesets/rule-suites\"],\n getOrgRuleset: [\"GET /orgs/{org}/rulesets/{ruleset_id}\"],\n getOrgRulesets: [\"GET /orgs/{org}/rulesets\"],\n getPages: [\"GET /repos/{owner}/{repo}/pages\"],\n getPagesBuild: [\"GET /repos/{owner}/{repo}/pages/builds/{build_id}\"],\n getPagesDeployment: [\n \"GET /repos/{owner}/{repo}/pages/deployments/{pages_deployment_id}\"\n ],\n getPagesHealthCheck: [\"GET /repos/{owner}/{repo}/pages/health\"],\n getParticipationStats: [\"GET /repos/{owner}/{repo}/stats/participation\"],\n getPullRequestReviewProtection: [\n \"GET /repos/{owner}/{repo}/branches/{branch}/protection/required_pull_request_reviews\"\n ],\n getPunchCardStats: [\"GET /repos/{owner}/{repo}/stats/punch_card\"],\n getReadme: [\"GET /repos/{owner}/{repo}/readme\"],\n getReadmeInDirectory: [\"GET /repos/{owner}/{repo}/readme/{dir}\"],\n getRelease: [\"GET /repos/{owner}/{repo}/releases/{release_id}\"],\n getReleaseAsset: [\"GET /repos/{owner}/{repo}/releases/assets/{asset_id}\"],\n getReleaseByTag: [\"GET /repos/{owner}/{repo}/releases/tags/{tag}\"],\n getRepoRuleSuite: [\n \"GET /repos/{owner}/{repo}/rulesets/rule-suites/{rule_suite_id}\"\n ],\n getRepoRuleSuites: [\"GET /repos/{owner}/{repo}/rulesets/rule-suites\"],\n getRepoRuleset: [\"GET /repos/{owner}/{repo}/rulesets/{ruleset_id}\"],\n getRepoRulesets: [\"GET /repos/{owner}/{repo}/rulesets\"],\n getStatusChecksProtection: [\n \"GET /repos/{owner}/{repo}/branches/{branch}/protection/required_status_checks\"\n ],\n getTeamsWithAccessToProtectedBranch: [\n \"GET /repos/{owner}/{repo}/branches/{branch}/protection/restrictions/teams\"\n ],\n getTopPaths: [\"GET /repos/{owner}/{repo}/traffic/popular/paths\"],\n getTopReferrers: [\"GET /repos/{owner}/{repo}/traffic/popular/referrers\"],\n getUsersWithAccessToProtectedBranch: [\n \"GET /repos/{owner}/{repo}/branches/{branch}/protection/restrictions/users\"\n ],\n getViews: [\"GET /repos/{owner}/{repo}/traffic/views\"],\n getWebhook: [\"GET /repos/{owner}/{repo}/hooks/{hook_id}\"],\n getWebhookConfigForRepo: [\n \"GET /repos/{owner}/{repo}/hooks/{hook_id}/config\"\n ],\n getWebhookDelivery: [\n \"GET /repos/{owner}/{repo}/hooks/{hook_id}/deliveries/{delivery_id}\"\n ],\n listActivities: [\"GET /repos/{owner}/{repo}/activity\"],\n listAutolinks: [\"GET /repos/{owner}/{repo}/autolinks\"],\n listBranches: [\"GET /repos/{owner}/{repo}/branches\"],\n listBranchesForHeadCommit: [\n \"GET /repos/{owner}/{repo}/commits/{commit_sha}/branches-where-head\"\n ],\n listCollaborators: [\"GET /repos/{owner}/{repo}/collaborators\"],\n listCommentsForCommit: [\n \"GET /repos/{owner}/{repo}/commits/{commit_sha}/comments\"\n ],\n listCommitCommentsForRepo: [\"GET /repos/{owner}/{repo}/comments\"],\n listCommitStatusesForRef: [\n \"GET /repos/{owner}/{repo}/commits/{ref}/statuses\"\n ],\n listCommits: [\"GET /repos/{owner}/{repo}/commits\"],\n listContributors: [\"GET /repos/{owner}/{repo}/contributors\"],\n listCustomDeploymentRuleIntegrations: [\n \"GET /repos/{owner}/{repo}/environments/{environment_name}/deployment_protection_rules/apps\"\n ],\n listDeployKeys: [\"GET /repos/{owner}/{repo}/keys\"],\n listDeploymentBranchPolicies: [\n \"GET /repos/{owner}/{repo}/environments/{environment_name}/deployment-branch-policies\"\n ],\n listDeploymentStatuses: [\n \"GET /repos/{owner}/{repo}/deployments/{deployment_id}/statuses\"\n ],\n listDeployments: [\"GET /repos/{owner}/{repo}/deployments\"],\n listForAuthenticatedUser: [\"GET /user/repos\"],\n listForOrg: [\"GET /orgs/{org}/repos\"],\n listForUser: [\"GET /users/{username}/repos\"],\n listForks: [\"GET /repos/{owner}/{repo}/forks\"],\n listInvitations: [\"GET /repos/{owner}/{repo}/invitations\"],\n listInvitationsForAuthenticatedUser: [\"GET /user/repository_invitations\"],\n listLanguages: [\"GET /repos/{owner}/{repo}/languages\"],\n listPagesBuilds: [\"GET /repos/{owner}/{repo}/pages/builds\"],\n listPublic: [\"GET /repositories\"],\n listPullRequestsAssociatedWithCommit: [\n \"GET /repos/{owner}/{repo}/commits/{commit_sha}/pulls\"\n ],\n listReleaseAssets: [\n \"GET /repos/{owner}/{repo}/releases/{release_id}/assets\"\n ],\n listReleases: [\"GET /repos/{owner}/{repo}/releases\"],\n listTagProtection: [\"GET /repos/{owner}/{repo}/tags/protection\"],\n listTags: [\"GET /repos/{owner}/{repo}/tags\"],\n listTeams: [\"GET /repos/{owner}/{repo}/teams\"],\n listWebhookDeliveries: [\n \"GET /repos/{owner}/{repo}/hooks/{hook_id}/deliveries\"\n ],\n listWebhooks: [\"GET /repos/{owner}/{repo}/hooks\"],\n merge: [\"POST /repos/{owner}/{repo}/merges\"],\n mergeUpstream: [\"POST /repos/{owner}/{repo}/merge-upstream\"],\n pingWebhook: [\"POST /repos/{owner}/{repo}/hooks/{hook_id}/pings\"],\n redeliverWebhookDelivery: [\n \"POST /repos/{owner}/{repo}/hooks/{hook_id}/deliveries/{delivery_id}/attempts\"\n ],\n removeAppAccessRestrictions: [\n \"DELETE /repos/{owner}/{repo}/branches/{branch}/protection/restrictions/apps\",\n {},\n { mapToData: \"apps\" }\n ],\n removeCollaborator: [\n \"DELETE /repos/{owner}/{repo}/collaborators/{username}\"\n ],\n removeStatusCheckContexts: [\n \"DELETE /repos/{owner}/{repo}/branches/{branch}/protection/required_status_checks/contexts\",\n {},\n { mapToData: \"contexts\" }\n ],\n removeStatusCheckProtection: [\n \"DELETE /repos/{owner}/{repo}/branches/{branch}/protection/required_status_checks\"\n ],\n removeTeamAccessRestrictions: [\n \"DELETE /repos/{owner}/{repo}/branches/{branch}/protection/restrictions/teams\",\n {},\n { mapToData: \"teams\" }\n ],\n removeUserAccessRestrictions: [\n \"DELETE /repos/{owner}/{repo}/branches/{branch}/protection/restrictions/users\",\n {},\n { mapToData: \"users\" }\n ],\n renameBranch: [\"POST /repos/{owner}/{repo}/branches/{branch}/rename\"],\n replaceAllTopics: [\"PUT /repos/{owner}/{repo}/topics\"],\n requestPagesBuild: [\"POST /repos/{owner}/{repo}/pages/builds\"],\n setAdminBranchProtection: [\n \"POST /repos/{owner}/{repo}/branches/{branch}/protection/enforce_admins\"\n ],\n setAppAccessRestrictions: [\n \"PUT /repos/{owner}/{repo}/branches/{branch}/protection/restrictions/apps\",\n {},\n { mapToData: \"apps\" }\n ],\n setStatusCheckContexts: [\n \"PUT /repos/{owner}/{repo}/branches/{branch}/protection/required_status_checks/contexts\",\n {},\n { mapToData: \"contexts\" }\n ],\n setTeamAccessRestrictions: [\n \"PUT /repos/{owner}/{repo}/branches/{branch}/protection/restrictions/teams\",\n {},\n { mapToData: \"teams\" }\n ],\n setUserAccessRestrictions: [\n \"PUT /repos/{owner}/{repo}/branches/{branch}/protection/restrictions/users\",\n {},\n { mapToData: \"users\" }\n ],\n testPushWebhook: [\"POST /repos/{owner}/{repo}/hooks/{hook_id}/tests\"],\n transfer: [\"POST /repos/{owner}/{repo}/transfer\"],\n update: [\"PATCH /repos/{owner}/{repo}\"],\n updateBranchProtection: [\n \"PUT /repos/{owner}/{repo}/branches/{branch}/protection\"\n ],\n updateCommitComment: [\"PATCH /repos/{owner}/{repo}/comments/{comment_id}\"],\n updateDeploymentBranchPolicy: [\n \"PUT /repos/{owner}/{repo}/environments/{environment_name}/deployment-branch-policies/{branch_policy_id}\"\n ],\n updateInformationAboutPagesSite: [\"PUT /repos/{owner}/{repo}/pages\"],\n updateInvitation: [\n \"PATCH /repos/{owner}/{repo}/invitations/{invitation_id}\"\n ],\n updateOrgRuleset: [\"PUT /orgs/{org}/rulesets/{ruleset_id}\"],\n updatePullRequestReviewProtection: [\n \"PATCH /repos/{owner}/{repo}/branches/{branch}/protection/required_pull_request_reviews\"\n ],\n updateRelease: [\"PATCH /repos/{owner}/{repo}/releases/{release_id}\"],\n updateReleaseAsset: [\n \"PATCH /repos/{owner}/{repo}/releases/assets/{asset_id}\"\n ],\n updateRepoRuleset: [\"PUT /repos/{owner}/{repo}/rulesets/{ruleset_id}\"],\n updateStatusCheckPotection: [\n \"PATCH /repos/{owner}/{repo}/branches/{branch}/protection/required_status_checks\",\n {},\n { renamed: [\"repos\", \"updateStatusCheckProtection\"] }\n ],\n updateStatusCheckProtection: [\n \"PATCH /repos/{owner}/{repo}/branches/{branch}/protection/required_status_checks\"\n ],\n updateWebhook: [\"PATCH /repos/{owner}/{repo}/hooks/{hook_id}\"],\n updateWebhookConfigForRepo: [\n \"PATCH /repos/{owner}/{repo}/hooks/{hook_id}/config\"\n ],\n uploadReleaseAsset: [\n \"POST /repos/{owner}/{repo}/releases/{release_id}/assets{?name,label}\",\n { baseUrl: \"https://uploads.github.com\" }\n ]\n },\n search: {\n code: [\"GET /search/code\"],\n commits: [\"GET /search/commits\"],\n issuesAndPullRequests: [\"GET /search/issues\"],\n labels: [\"GET /search/labels\"],\n repos: [\"GET /search/repositories\"],\n topics: [\"GET /search/topics\"],\n users: [\"GET /search/users\"]\n },\n secretScanning: {\n getAlert: [\n \"GET /repos/{owner}/{repo}/secret-scanning/alerts/{alert_number}\"\n ],\n listAlertsForEnterprise: [\n \"GET /enterprises/{enterprise}/secret-scanning/alerts\"\n ],\n listAlertsForOrg: [\"GET /orgs/{org}/secret-scanning/alerts\"],\n listAlertsForRepo: [\"GET /repos/{owner}/{repo}/secret-scanning/alerts\"],\n listLocationsForAlert: [\n \"GET /repos/{owner}/{repo}/secret-scanning/alerts/{alert_number}/locations\"\n ],\n updateAlert: [\n \"PATCH /repos/{owner}/{repo}/secret-scanning/alerts/{alert_number}\"\n ]\n },\n securityAdvisories: {\n createFork: [\n \"POST /repos/{owner}/{repo}/security-advisories/{ghsa_id}/forks\"\n ],\n createPrivateVulnerabilityReport: [\n \"POST /repos/{owner}/{repo}/security-advisories/reports\"\n ],\n createRepositoryAdvisory: [\n \"POST /repos/{owner}/{repo}/security-advisories\"\n ],\n createRepositoryAdvisoryCveRequest: [\n \"POST /repos/{owner}/{repo}/security-advisories/{ghsa_id}/cve\"\n ],\n getGlobalAdvisory: [\"GET /advisories/{ghsa_id}\"],\n getRepositoryAdvisory: [\n \"GET /repos/{owner}/{repo}/security-advisories/{ghsa_id}\"\n ],\n listGlobalAdvisories: [\"GET /advisories\"],\n listOrgRepositoryAdvisories: [\"GET /orgs/{org}/security-advisories\"],\n listRepositoryAdvisories: [\"GET /repos/{owner}/{repo}/security-advisories\"],\n updateRepositoryAdvisory: [\n \"PATCH /repos/{owner}/{repo}/security-advisories/{ghsa_id}\"\n ]\n },\n teams: {\n addOrUpdateMembershipForUserInOrg: [\n \"PUT /orgs/{org}/teams/{team_slug}/memberships/{username}\"\n ],\n addOrUpdateProjectPermissionsInOrg: [\n \"PUT /orgs/{org}/teams/{team_slug}/projects/{project_id}\"\n ],\n addOrUpdateRepoPermissionsInOrg: [\n \"PUT /orgs/{org}/teams/{team_slug}/repos/{owner}/{repo}\"\n ],\n checkPermissionsForProjectInOrg: [\n \"GET /orgs/{org}/teams/{team_slug}/projects/{project_id}\"\n ],\n checkPermissionsForRepoInOrg: [\n \"GET /orgs/{org}/teams/{team_slug}/repos/{owner}/{repo}\"\n ],\n create: [\"POST /orgs/{org}/teams\"],\n createDiscussionCommentInOrg: [\n \"POST /orgs/{org}/teams/{team_slug}/discussions/{discussion_number}/comments\"\n ],\n createDiscussionInOrg: [\"POST /orgs/{org}/teams/{team_slug}/discussions\"],\n deleteDiscussionCommentInOrg: [\n \"DELETE /orgs/{org}/teams/{team_slug}/discussions/{discussion_number}/comments/{comment_number}\"\n ],\n deleteDiscussionInOrg: [\n \"DELETE /orgs/{org}/teams/{team_slug}/discussions/{discussion_number}\"\n ],\n deleteInOrg: [\"DELETE /orgs/{org}/teams/{team_slug}\"],\n getByName: [\"GET /orgs/{org}/teams/{team_slug}\"],\n getDiscussionCommentInOrg: [\n \"GET /orgs/{org}/teams/{team_slug}/discussions/{discussion_number}/comments/{comment_number}\"\n ],\n getDiscussionInOrg: [\n \"GET /orgs/{org}/teams/{team_slug}/discussions/{discussion_number}\"\n ],\n getMembershipForUserInOrg: [\n \"GET /orgs/{org}/teams/{team_slug}/memberships/{username}\"\n ],\n list: [\"GET /orgs/{org}/teams\"],\n listChildInOrg: [\"GET /orgs/{org}/teams/{team_slug}/teams\"],\n listDiscussionCommentsInOrg: [\n \"GET /orgs/{org}/teams/{team_slug}/discussions/{discussion_number}/comments\"\n ],\n listDiscussionsInOrg: [\"GET /orgs/{org}/teams/{team_slug}/discussions\"],\n listForAuthenticatedUser: [\"GET /user/teams\"],\n listMembersInOrg: [\"GET /orgs/{org}/teams/{team_slug}/members\"],\n listPendingInvitationsInOrg: [\n \"GET /orgs/{org}/teams/{team_slug}/invitations\"\n ],\n listProjectsInOrg: [\"GET /orgs/{org}/teams/{team_slug}/projects\"],\n listReposInOrg: [\"GET /orgs/{org}/teams/{team_slug}/repos\"],\n removeMembershipForUserInOrg: [\n \"DELETE /orgs/{org}/teams/{team_slug}/memberships/{username}\"\n ],\n removeProjectInOrg: [\n \"DELETE /orgs/{org}/teams/{team_slug}/projects/{project_id}\"\n ],\n removeRepoInOrg: [\n \"DELETE /orgs/{org}/teams/{team_slug}/repos/{owner}/{repo}\"\n ],\n updateDiscussionCommentInOrg: [\n \"PATCH /orgs/{org}/teams/{team_slug}/discussions/{discussion_number}/comments/{comment_number}\"\n ],\n updateDiscussionInOrg: [\n \"PATCH /orgs/{org}/teams/{team_slug}/discussions/{discussion_number}\"\n ],\n updateInOrg: [\"PATCH /orgs/{org}/teams/{team_slug}\"]\n },\n users: {\n addEmailForAuthenticated: [\n \"POST /user/emails\",\n {},\n { renamed: [\"users\", \"addEmailForAuthenticatedUser\"] }\n ],\n addEmailForAuthenticatedUser: [\"POST /user/emails\"],\n addSocialAccountForAuthenticatedUser: [\"POST /user/social_accounts\"],\n block: [\"PUT /user/blocks/{username}\"],\n checkBlocked: [\"GET /user/blocks/{username}\"],\n checkFollowingForUser: [\"GET /users/{username}/following/{target_user}\"],\n checkPersonIsFollowedByAuthenticated: [\"GET /user/following/{username}\"],\n createGpgKeyForAuthenticated: [\n \"POST /user/gpg_keys\",\n {},\n { renamed: [\"users\", \"createGpgKeyForAuthenticatedUser\"] }\n ],\n createGpgKeyForAuthenticatedUser: [\"POST /user/gpg_keys\"],\n createPublicSshKeyForAuthenticated: [\n \"POST /user/keys\",\n {},\n { renamed: [\"users\", \"createPublicSshKeyForAuthenticatedUser\"] }\n ],\n createPublicSshKeyForAuthenticatedUser: [\"POST /user/keys\"],\n createSshSigningKeyForAuthenticatedUser: [\"POST /user/ssh_signing_keys\"],\n deleteEmailForAuthenticated: [\n \"DELETE /user/emails\",\n {},\n { renamed: [\"users\", \"deleteEmailForAuthenticatedUser\"] }\n ],\n deleteEmailForAuthenticatedUser: [\"DELETE /user/emails\"],\n deleteGpgKeyForAuthenticated: [\n \"DELETE /user/gpg_keys/{gpg_key_id}\",\n {},\n { renamed: [\"users\", \"deleteGpgKeyForAuthenticatedUser\"] }\n ],\n deleteGpgKeyForAuthenticatedUser: [\"DELETE /user/gpg_keys/{gpg_key_id}\"],\n deletePublicSshKeyForAuthenticated: [\n \"DELETE /user/keys/{key_id}\",\n {},\n { renamed: [\"users\", \"deletePublicSshKeyForAuthenticatedUser\"] }\n ],\n deletePublicSshKeyForAuthenticatedUser: [\"DELETE /user/keys/{key_id}\"],\n deleteSocialAccountForAuthenticatedUser: [\"DELETE /user/social_accounts\"],\n deleteSshSigningKeyForAuthenticatedUser: [\n \"DELETE /user/ssh_signing_keys/{ssh_signing_key_id}\"\n ],\n follow: [\"PUT /user/following/{username}\"],\n getAuthenticated: [\"GET /user\"],\n getByUsername: [\"GET /users/{username}\"],\n getContextForUser: [\"GET /users/{username}/hovercard\"],\n getGpgKeyForAuthenticated: [\n \"GET /user/gpg_keys/{gpg_key_id}\",\n {},\n { renamed: [\"users\", \"getGpgKeyForAuthenticatedUser\"] }\n ],\n getGpgKeyForAuthenticatedUser: [\"GET /user/gpg_keys/{gpg_key_id}\"],\n getPublicSshKeyForAuthenticated: [\n \"GET /user/keys/{key_id}\",\n {},\n { renamed: [\"users\", \"getPublicSshKeyForAuthenticatedUser\"] }\n ],\n getPublicSshKeyForAuthenticatedUser: [\"GET /user/keys/{key_id}\"],\n getSshSigningKeyForAuthenticatedUser: [\n \"GET /user/ssh_signing_keys/{ssh_signing_key_id}\"\n ],\n list: [\"GET /users\"],\n listBlockedByAuthenticated: [\n \"GET /user/blocks\",\n {},\n { renamed: [\"users\", \"listBlockedByAuthenticatedUser\"] }\n ],\n listBlockedByAuthenticatedUser: [\"GET /user/blocks\"],\n listEmailsForAuthenticated: [\n \"GET /user/emails\",\n {},\n { renamed: [\"users\", \"listEmailsForAuthenticatedUser\"] }\n ],\n listEmailsForAuthenticatedUser: [\"GET /user/emails\"],\n listFollowedByAuthenticated: [\n \"GET /user/following\",\n {},\n { renamed: [\"users\", \"listFollowedByAuthenticatedUser\"] }\n ],\n listFollowedByAuthenticatedUser: [\"GET /user/following\"],\n listFollowersForAuthenticatedUser: [\"GET /user/followers\"],\n listFollowersForUser: [\"GET /users/{username}/followers\"],\n listFollowingForUser: [\"GET /users/{username}/following\"],\n listGpgKeysForAuthenticated: [\n \"GET /user/gpg_keys\",\n {},\n { renamed: [\"users\", \"listGpgKeysForAuthenticatedUser\"] }\n ],\n listGpgKeysForAuthenticatedUser: [\"GET /user/gpg_keys\"],\n listGpgKeysForUser: [\"GET /users/{username}/gpg_keys\"],\n listPublicEmailsForAuthenticated: [\n \"GET /user/public_emails\",\n {},\n { renamed: [\"users\", \"listPublicEmailsForAuthenticatedUser\"] }\n ],\n listPublicEmailsForAuthenticatedUser: [\"GET /user/public_emails\"],\n listPublicKeysForUser: [\"GET /users/{username}/keys\"],\n listPublicSshKeysForAuthenticated: [\n \"GET /user/keys\",\n {},\n { renamed: [\"users\", \"listPublicSshKeysForAuthenticatedUser\"] }\n ],\n listPublicSshKeysForAuthenticatedUser: [\"GET /user/keys\"],\n listSocialAccountsForAuthenticatedUser: [\"GET /user/social_accounts\"],\n listSocialAccountsForUser: [\"GET /users/{username}/social_accounts\"],\n listSshSigningKeysForAuthenticatedUser: [\"GET /user/ssh_signing_keys\"],\n listSshSigningKeysForUser: [\"GET /users/{username}/ssh_signing_keys\"],\n setPrimaryEmailVisibilityForAuthenticated: [\n \"PATCH /user/email/visibility\",\n {},\n { renamed: [\"users\", \"setPrimaryEmailVisibilityForAuthenticatedUser\"] }\n ],\n setPrimaryEmailVisibilityForAuthenticatedUser: [\n \"PATCH /user/email/visibility\"\n ],\n unblock: [\"DELETE /user/blocks/{username}\"],\n unfollow: [\"DELETE /user/following/{username}\"],\n updateAuthenticated: [\"PATCH /user\"]\n }\n};\nvar endpoints_default = Endpoints;\n\n// pkg/dist-src/endpoints-to-methods.js\nvar endpointMethodsMap = /* @__PURE__ */ new Map();\nfor (const [scope, endpoints] of Object.entries(endpoints_default)) {\n for (const [methodName, endpoint] of Object.entries(endpoints)) {\n const [route, defaults, decorations] = endpoint;\n const [method, url] = route.split(/ /);\n const endpointDefaults = Object.assign(\n {\n method,\n url\n },\n defaults\n );\n if (!endpointMethodsMap.has(scope)) {\n endpointMethodsMap.set(scope, /* @__PURE__ */ new Map());\n }\n endpointMethodsMap.get(scope).set(methodName, {\n scope,\n methodName,\n endpointDefaults,\n decorations\n });\n }\n}\nvar handler = {\n has({ scope }, methodName) {\n return endpointMethodsMap.get(scope).has(methodName);\n },\n getOwnPropertyDescriptor(target, methodName) {\n return {\n value: this.get(target, methodName),\n // ensures method is in the cache\n configurable: true,\n writable: true,\n enumerable: true\n };\n },\n defineProperty(target, methodName, descriptor) {\n Object.defineProperty(target.cache, methodName, descriptor);\n return true;\n },\n deleteProperty(target, methodName) {\n delete target.cache[methodName];\n return true;\n },\n ownKeys({ scope }) {\n return [...endpointMethodsMap.get(scope).keys()];\n },\n set(target, methodName, value) {\n return target.cache[methodName] = value;\n },\n get({ octokit, scope, cache }, methodName) {\n if (cache[methodName]) {\n return cache[methodName];\n }\n const method = endpointMethodsMap.get(scope).get(methodName);\n if (!method) {\n return void 0;\n }\n const { endpointDefaults, decorations } = method;\n if (decorations) {\n cache[methodName] = decorate(\n octokit,\n scope,\n methodName,\n endpointDefaults,\n decorations\n );\n } else {\n cache[methodName] = octokit.request.defaults(endpointDefaults);\n }\n return cache[methodName];\n }\n};\nfunction endpointsToMethods(octokit) {\n const newMethods = {};\n for (const scope of endpointMethodsMap.keys()) {\n newMethods[scope] = new Proxy({ octokit, scope, cache: {} }, handler);\n }\n return newMethods;\n}\nfunction decorate(octokit, scope, methodName, defaults, decorations) {\n const requestWithDefaults = octokit.request.defaults(defaults);\n function withDecorations(...args) {\n let options = requestWithDefaults.endpoint.merge(...args);\n if (decorations.mapToData) {\n options = Object.assign({}, options, {\n data: options[decorations.mapToData],\n [decorations.mapToData]: void 0\n });\n return requestWithDefaults(options);\n }\n if (decorations.renamed) {\n const [newScope, newMethodName] = decorations.renamed;\n octokit.log.warn(\n `octokit.${scope}.${methodName}() has been renamed to octokit.${newScope}.${newMethodName}()`\n );\n }\n if (decorations.deprecated) {\n octokit.log.warn(decorations.deprecated);\n }\n if (decorations.renamedParameters) {\n const options2 = requestWithDefaults.endpoint.merge(...args);\n for (const [name, alias] of Object.entries(\n decorations.renamedParameters\n )) {\n if (name in options2) {\n octokit.log.warn(\n `\"${name}\" parameter is deprecated for \"octokit.${scope}.${methodName}()\". Use \"${alias}\" instead`\n );\n if (!(alias in options2)) {\n options2[alias] = options2[name];\n }\n delete options2[name];\n }\n }\n return requestWithDefaults(options2);\n }\n return requestWithDefaults(...args);\n }\n return Object.assign(withDecorations, requestWithDefaults);\n}\n\n// pkg/dist-src/index.js\nfunction restEndpointMethods(octokit) {\n const api = endpointsToMethods(octokit);\n return {\n rest: api\n };\n}\nrestEndpointMethods.VERSION = VERSION;\nfunction legacyRestEndpointMethods(octokit) {\n const api = endpointsToMethods(octokit);\n return {\n ...api,\n rest: api\n };\n}\nlegacyRestEndpointMethods.VERSION = VERSION;\n// Annotate the CommonJS export names for ESM import in node:\n0 && (module.exports = {\n legacyRestEndpointMethods,\n restEndpointMethods\n});\n","\"use strict\";\nvar __create = Object.create;\nvar __defProp = Object.defineProperty;\nvar __getOwnPropDesc = Object.getOwnPropertyDescriptor;\nvar __getOwnPropNames = Object.getOwnPropertyNames;\nvar __getProtoOf = Object.getPrototypeOf;\nvar __hasOwnProp = Object.prototype.hasOwnProperty;\nvar __export = (target, all) => {\n for (var name in all)\n __defProp(target, name, { get: all[name], enumerable: true });\n};\nvar __copyProps = (to, from, except, desc) => {\n if (from && typeof from === \"object\" || typeof from === \"function\") {\n for (let key of __getOwnPropNames(from))\n if (!__hasOwnProp.call(to, key) && key !== except)\n __defProp(to, key, { get: () => from[key], enumerable: !(desc = __getOwnPropDesc(from, key)) || desc.enumerable });\n }\n return to;\n};\nvar __toESM = (mod, isNodeMode, target) => (target = mod != null ? __create(__getProtoOf(mod)) : {}, __copyProps(\n // If the importer is in node compatibility mode or this is not an ESM\n // file that has been converted to a CommonJS file using a Babel-\n // compatible transform (i.e. \"__esModule\" has not been set), then set\n // \"default\" to the CommonJS \"module.exports\" for node compatibility.\n isNodeMode || !mod || !mod.__esModule ? __defProp(target, \"default\", { value: mod, enumerable: true }) : target,\n mod\n));\nvar __toCommonJS = (mod) => __copyProps(__defProp({}, \"__esModule\", { value: true }), mod);\n\n// pkg/dist-src/index.js\nvar dist_src_exports = {};\n__export(dist_src_exports, {\n RequestError: () => RequestError\n});\nmodule.exports = __toCommonJS(dist_src_exports);\nvar import_deprecation = require(\"deprecation\");\nvar import_once = __toESM(require(\"once\"));\nvar logOnceCode = (0, import_once.default)((deprecation) => console.warn(deprecation));\nvar logOnceHeaders = (0, import_once.default)((deprecation) => console.warn(deprecation));\nvar RequestError = class extends Error {\n constructor(message, statusCode, options) {\n super(message);\n if (Error.captureStackTrace) {\n Error.captureStackTrace(this, this.constructor);\n }\n this.name = \"HttpError\";\n this.status = statusCode;\n let headers;\n if (\"headers\" in options && typeof options.headers !== \"undefined\") {\n headers = options.headers;\n }\n if (\"response\" in options) {\n this.response = options.response;\n headers = options.response.headers;\n }\n const requestCopy = Object.assign({}, options.request);\n if (options.request.headers.authorization) {\n requestCopy.headers = Object.assign({}, options.request.headers, {\n authorization: options.request.headers.authorization.replace(\n / .*$/,\n \" [REDACTED]\"\n )\n });\n }\n requestCopy.url = requestCopy.url.replace(/\\bclient_secret=\\w+/g, \"client_secret=[REDACTED]\").replace(/\\baccess_token=\\w+/g, \"access_token=[REDACTED]\");\n this.request = requestCopy;\n Object.defineProperty(this, \"code\", {\n get() {\n logOnceCode(\n new import_deprecation.Deprecation(\n \"[@octokit/request-error] `error.code` is deprecated, use `error.status`.\"\n )\n );\n return statusCode;\n }\n });\n Object.defineProperty(this, \"headers\", {\n get() {\n logOnceHeaders(\n new import_deprecation.Deprecation(\n \"[@octokit/request-error] `error.headers` is deprecated, use `error.response.headers`.\"\n )\n );\n return headers || {};\n }\n });\n }\n};\n// Annotate the CommonJS export names for ESM import in node:\n0 && (module.exports = {\n RequestError\n});\n","\"use strict\";\nvar __defProp = Object.defineProperty;\nvar __getOwnPropDesc = Object.getOwnPropertyDescriptor;\nvar __getOwnPropNames = Object.getOwnPropertyNames;\nvar __hasOwnProp = Object.prototype.hasOwnProperty;\nvar __export = (target, all) => {\n for (var name in all)\n __defProp(target, name, { get: all[name], enumerable: true });\n};\nvar __copyProps = (to, from, except, desc) => {\n if (from && typeof from === \"object\" || typeof from === \"function\") {\n for (let key of __getOwnPropNames(from))\n if (!__hasOwnProp.call(to, key) && key !== except)\n __defProp(to, key, { get: () => from[key], enumerable: !(desc = __getOwnPropDesc(from, key)) || desc.enumerable });\n }\n return to;\n};\nvar __toCommonJS = (mod) => __copyProps(__defProp({}, \"__esModule\", { value: true }), mod);\n\n// pkg/dist-src/index.js\nvar dist_src_exports = {};\n__export(dist_src_exports, {\n request: () => request\n});\nmodule.exports = __toCommonJS(dist_src_exports);\nvar import_endpoint = require(\"@octokit/endpoint\");\nvar import_universal_user_agent = require(\"universal-user-agent\");\n\n// pkg/dist-src/version.js\nvar VERSION = \"8.2.0\";\n\n// pkg/dist-src/is-plain-object.js\nfunction isPlainObject(value) {\n if (typeof value !== \"object\" || value === null)\n return false;\n if (Object.prototype.toString.call(value) !== \"[object Object]\")\n return false;\n const proto = Object.getPrototypeOf(value);\n if (proto === null)\n return true;\n const Ctor = Object.prototype.hasOwnProperty.call(proto, \"constructor\") && proto.constructor;\n return typeof Ctor === \"function\" && Ctor instanceof Ctor && Function.prototype.call(Ctor) === Function.prototype.call(value);\n}\n\n// pkg/dist-src/fetch-wrapper.js\nvar import_request_error = require(\"@octokit/request-error\");\n\n// pkg/dist-src/get-buffer-response.js\nfunction getBufferResponse(response) {\n return response.arrayBuffer();\n}\n\n// pkg/dist-src/fetch-wrapper.js\nfunction fetchWrapper(requestOptions) {\n var _a, _b, _c;\n const log = requestOptions.request && requestOptions.request.log ? requestOptions.request.log : console;\n const parseSuccessResponseBody = ((_a = requestOptions.request) == null ? void 0 : _a.parseSuccessResponseBody) !== false;\n if (isPlainObject(requestOptions.body) || Array.isArray(requestOptions.body)) {\n requestOptions.body = JSON.stringify(requestOptions.body);\n }\n let headers = {};\n let status;\n let url;\n let { fetch } = globalThis;\n if ((_b = requestOptions.request) == null ? void 0 : _b.fetch) {\n fetch = requestOptions.request.fetch;\n }\n if (!fetch) {\n throw new Error(\n \"fetch is not set. Please pass a fetch implementation as new Octokit({ request: { fetch }}). Learn more at https://github.com/octokit/octokit.js/#fetch-missing\"\n );\n }\n return fetch(requestOptions.url, {\n method: requestOptions.method,\n body: requestOptions.body,\n headers: requestOptions.headers,\n signal: (_c = requestOptions.request) == null ? void 0 : _c.signal,\n // duplex must be set if request.body is ReadableStream or Async Iterables.\n // See https://fetch.spec.whatwg.org/#dom-requestinit-duplex.\n ...requestOptions.body && { duplex: \"half\" }\n }).then(async (response) => {\n url = response.url;\n status = response.status;\n for (const keyAndValue of response.headers) {\n headers[keyAndValue[0]] = keyAndValue[1];\n }\n if (\"deprecation\" in headers) {\n const matches = headers.link && headers.link.match(/<([^>]+)>; rel=\"deprecation\"/);\n const deprecationLink = matches && matches.pop();\n log.warn(\n `[@octokit/request] \"${requestOptions.method} ${requestOptions.url}\" is deprecated. It is scheduled to be removed on ${headers.sunset}${deprecationLink ? `. See ${deprecationLink}` : \"\"}`\n );\n }\n if (status === 204 || status === 205) {\n return;\n }\n if (requestOptions.method === \"HEAD\") {\n if (status < 400) {\n return;\n }\n throw new import_request_error.RequestError(response.statusText, status, {\n response: {\n url,\n status,\n headers,\n data: void 0\n },\n request: requestOptions\n });\n }\n if (status === 304) {\n throw new import_request_error.RequestError(\"Not modified\", status, {\n response: {\n url,\n status,\n headers,\n data: await getResponseData(response)\n },\n request: requestOptions\n });\n }\n if (status >= 400) {\n const data = await getResponseData(response);\n const error = new import_request_error.RequestError(toErrorMessage(data), status, {\n response: {\n url,\n status,\n headers,\n data\n },\n request: requestOptions\n });\n throw error;\n }\n return parseSuccessResponseBody ? await getResponseData(response) : response.body;\n }).then((data) => {\n return {\n status,\n url,\n headers,\n data\n };\n }).catch((error) => {\n if (error instanceof import_request_error.RequestError)\n throw error;\n else if (error.name === \"AbortError\")\n throw error;\n let message = error.message;\n if (error.name === \"TypeError\" && \"cause\" in error) {\n if (error.cause instanceof Error) {\n message = error.cause.message;\n } else if (typeof error.cause === \"string\") {\n message = error.cause;\n }\n }\n throw new import_request_error.RequestError(message, 500, {\n request: requestOptions\n });\n });\n}\nasync function getResponseData(response) {\n const contentType = response.headers.get(\"content-type\");\n if (/application\\/json/.test(contentType)) {\n return response.json().catch(() => response.text()).catch(() => \"\");\n }\n if (!contentType || /^text\\/|charset=utf-8$/.test(contentType)) {\n return response.text();\n }\n return getBufferResponse(response);\n}\nfunction toErrorMessage(data) {\n if (typeof data === \"string\")\n return data;\n let suffix;\n if (\"documentation_url\" in data) {\n suffix = ` - ${data.documentation_url}`;\n } else {\n suffix = \"\";\n }\n if (\"message\" in data) {\n if (Array.isArray(data.errors)) {\n return `${data.message}: ${data.errors.map(JSON.stringify).join(\", \")}${suffix}`;\n }\n return `${data.message}${suffix}`;\n }\n return `Unknown error: ${JSON.stringify(data)}`;\n}\n\n// pkg/dist-src/with-defaults.js\nfunction withDefaults(oldEndpoint, newDefaults) {\n const endpoint2 = oldEndpoint.defaults(newDefaults);\n const newApi = function(route, parameters) {\n const endpointOptions = endpoint2.merge(route, parameters);\n if (!endpointOptions.request || !endpointOptions.request.hook) {\n return fetchWrapper(endpoint2.parse(endpointOptions));\n }\n const request2 = (route2, parameters2) => {\n return fetchWrapper(\n endpoint2.parse(endpoint2.merge(route2, parameters2))\n );\n };\n Object.assign(request2, {\n endpoint: endpoint2,\n defaults: withDefaults.bind(null, endpoint2)\n });\n return endpointOptions.request.hook(request2, endpointOptions);\n };\n return Object.assign(newApi, {\n endpoint: endpoint2,\n defaults: withDefaults.bind(null, endpoint2)\n });\n}\n\n// pkg/dist-src/index.js\nvar request = withDefaults(import_endpoint.endpoint, {\n headers: {\n \"user-agent\": `octokit-request.js/${VERSION} ${(0, import_universal_user_agent.getUserAgent)()}`\n }\n});\n// Annotate the CommonJS export names for ESM import in node:\n0 && (module.exports = {\n request\n});\n","var register = require(\"./lib/register\");\nvar addHook = require(\"./lib/add\");\nvar removeHook = require(\"./lib/remove\");\n\n// bind with array of arguments: https://stackoverflow.com/a/21792913\nvar bind = Function.bind;\nvar bindable = bind.bind(bind);\n\nfunction bindApi(hook, state, name) {\n var removeHookRef = bindable(removeHook, null).apply(\n null,\n name ? [state, name] : [state]\n );\n hook.api = { remove: removeHookRef };\n hook.remove = removeHookRef;\n [\"before\", \"error\", \"after\", \"wrap\"].forEach(function (kind) {\n var args = name ? [state, kind, name] : [state, kind];\n hook[kind] = hook.api[kind] = bindable(addHook, null).apply(null, args);\n });\n}\n\nfunction HookSingular() {\n var singularHookName = \"h\";\n var singularHookState = {\n registry: {},\n };\n var singularHook = register.bind(null, singularHookState, singularHookName);\n bindApi(singularHook, singularHookState, singularHookName);\n return singularHook;\n}\n\nfunction HookCollection() {\n var state = {\n registry: {},\n };\n\n var hook = register.bind(null, state);\n bindApi(hook, state);\n\n return hook;\n}\n\nvar collectionHookDeprecationMessageDisplayed = false;\nfunction Hook() {\n if (!collectionHookDeprecationMessageDisplayed) {\n console.warn(\n '[before-after-hook]: \"Hook()\" repurposing warning, use \"Hook.Collection()\". Read more: https://git.io/upgrade-before-after-hook-to-1.4'\n );\n collectionHookDeprecationMessageDisplayed = true;\n }\n return HookCollection();\n}\n\nHook.Singular = HookSingular.bind();\nHook.Collection = HookCollection.bind();\n\nmodule.exports = Hook;\n// expose constructors as a named property for TypeScript\nmodule.exports.Hook = Hook;\nmodule.exports.Singular = Hook.Singular;\nmodule.exports.Collection = Hook.Collection;\n","module.exports = addHook;\n\nfunction addHook(state, kind, name, hook) {\n var orig = hook;\n if (!state.registry[name]) {\n state.registry[name] = [];\n }\n\n if (kind === \"before\") {\n hook = function (method, options) {\n return Promise.resolve()\n .then(orig.bind(null, options))\n .then(method.bind(null, options));\n };\n }\n\n if (kind === \"after\") {\n hook = function (method, options) {\n var result;\n return Promise.resolve()\n .then(method.bind(null, options))\n .then(function (result_) {\n result = result_;\n return orig(result, options);\n })\n .then(function () {\n return result;\n });\n };\n }\n\n if (kind === \"error\") {\n hook = function (method, options) {\n return Promise.resolve()\n .then(method.bind(null, options))\n .catch(function (error) {\n return orig(error, options);\n });\n };\n }\n\n state.registry[name].push({\n hook: hook,\n orig: orig,\n });\n}\n","module.exports = register;\n\nfunction register(state, name, method, options) {\n if (typeof method !== \"function\") {\n throw new Error(\"method for before hook must be a function\");\n }\n\n if (!options) {\n options = {};\n }\n\n if (Array.isArray(name)) {\n return name.reverse().reduce(function (callback, name) {\n return register.bind(null, state, name, callback, options);\n }, method)();\n }\n\n return Promise.resolve().then(function () {\n if (!state.registry[name]) {\n return method(options);\n }\n\n return state.registry[name].reduce(function (method, registered) {\n return registered.hook.bind(null, method, options);\n }, method)();\n });\n}\n","module.exports = removeHook;\n\nfunction removeHook(state, name, method) {\n if (!state.registry[name]) {\n return;\n }\n\n var index = state.registry[name]\n .map(function (registered) {\n return registered.orig;\n })\n .indexOf(method);\n\n if (index === -1) {\n return;\n }\n\n state.registry[name].splice(index, 1);\n}\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nclass Deprecation extends Error {\n constructor(message) {\n super(message); // Maintains proper stack trace (only available on V8)\n\n /* istanbul ignore next */\n\n if (Error.captureStackTrace) {\n Error.captureStackTrace(this, this.constructor);\n }\n\n this.name = 'Deprecation';\n }\n\n}\n\nexports.Deprecation = Deprecation;\n","/* eslint indent: [\"warn\", 4] */\n\n\n// Private helper class\nclass SubRange {\n constructor(low, high) {\n this.low = low;\n this.high = high;\n this.length = 1 + high - low;\n }\n\n overlaps(range) {\n return range.low <= this.high && this.low <= range.high;\n }\n\n touches(range) {\n return range.low <= this.high + 1 && this.low - 1 <= range.high;\n }\n\n covers(range) {\n return this.low <= range.low && range.high <= this.high;\n }\n\n isInside(range) {\n return range.low < this.low && this.high < range.high;\n }\n\n isBefore(range) {\n return this.high < range.low;\n }\n\n // Returns inclusive combination of SubRanges as a SubRange.\n add(range) {\n return new SubRange(\n Math.min(this.low, range.low),\n Math.max(this.high, range.high)\n );\n }\n\n // Returns subtraction of SubRanges as an array of SubRanges.\n // (There's a case where subtraction divides it in 2)\n subtract(range) {\n if (range.covers(this)) {\n return [];\n } else if (range.isInside(this)) {\n return [\n new SubRange(this.low, range.low - 1),\n new SubRange(range.high + 1, this.high)\n ];\n } else if (range.low <= this.low) {\n return [new SubRange(range.high + 1, this.high)];\n } else {\n return [new SubRange(this.low, range.low - 1)];\n }\n }\n\n toString() {\n return this.low == this.high ?\n this.low.toString() : this.low + '-' + this.high;\n }\n}\n\nclass DRange {\n constructor(a, b) {\n this.ranges = [];\n this.length = 0;\n if (a != null) this.add(a, b);\n }\n\n _update_length() {\n this.length = this.ranges.reduce((previous, range) => {\n return previous + range.length;\n }, 0);\n }\n\n add(a, b) {\n const _add = (subrange) => {\n let i = 0;\n while (i < this.ranges.length && !subrange.touches(this.ranges[i]) &&\n this.ranges[i].isBefore(subrange)) {\n i++;\n }\n const newRanges = this.ranges.slice(0, i);\n while (i < this.ranges.length && subrange.touches(this.ranges[i])) {\n subrange = subrange.add(this.ranges[i]);\n i++;\n }\n newRanges.push(subrange);\n this.ranges = newRanges.concat(this.ranges.slice(i));\n this._update_length();\n };\n\n if (a instanceof DRange) {\n a.ranges.forEach(_add);\n } else {\n if (b == null) b = a;\n _add(new SubRange(a, b));\n }\n return this;\n }\n\n subtract(a, b) {\n const _subtract = (subrange) => {\n let i = 0;\n while (i < this.ranges.length && !subrange.overlaps(this.ranges[i])) {\n i++;\n }\n let newRanges = this.ranges.slice(0, i);\n while (i < this.ranges.length && subrange.overlaps(this.ranges[i])) {\n newRanges = newRanges.concat(this.ranges[i].subtract(subrange));\n i++;\n }\n this.ranges = newRanges.concat(this.ranges.slice(i));\n this._update_length();\n };\n\n if (a instanceof DRange) {\n a.ranges.forEach(_subtract);\n } else {\n if (b == null) b = a;\n _subtract(new SubRange(a, b));\n }\n return this;\n }\n\n intersect(a, b) {\n const newRanges = [];\n const _intersect = (subrange) => {\n let i = 0;\n while (i < this.ranges.length && !subrange.overlaps(this.ranges[i])) {\n i++;\n }\n while (i < this.ranges.length && subrange.overlaps(this.ranges[i])) {\n let low = Math.max(this.ranges[i].low, subrange.low);\n let high = Math.min(this.ranges[i].high, subrange.high);\n newRanges.push(new SubRange(low, high));\n i++;\n }\n };\n\n if (a instanceof DRange) {\n a.ranges.forEach(_intersect);\n } else {\n if (b == null) b = a;\n _intersect(new SubRange(a, b));\n }\n this.ranges = newRanges;\n this._update_length();\n return this;\n }\n\n index(index) {\n let i = 0;\n while (i < this.ranges.length && this.ranges[i].length <= index) {\n index -= this.ranges[i].length;\n i++;\n }\n return this.ranges[i].low + index;\n }\n\n toString() {\n return '[ ' + this.ranges.join(', ') + ' ]';\n }\n\n clone() {\n return new DRange(this);\n }\n\n numbers() {\n return this.ranges.reduce((result, subrange) => {\n let i = subrange.low;\n while (i <= subrange.high) {\n result.push(i);\n i++;\n }\n return result;\n }, []);\n }\n\n subranges() {\n return this.ranges.map((subrange) => ({\n low: subrange.low,\n high: subrange.high,\n length: 1 + subrange.high - subrange.low\n }));\n }\n}\n\nmodule.exports = DRange;\n","var wrappy = require('wrappy')\nmodule.exports = wrappy(once)\nmodule.exports.strict = wrappy(onceStrict)\n\nonce.proto = once(function () {\n Object.defineProperty(Function.prototype, 'once', {\n value: function () {\n return once(this)\n },\n configurable: true\n })\n\n Object.defineProperty(Function.prototype, 'onceStrict', {\n value: function () {\n return onceStrict(this)\n },\n configurable: true\n })\n})\n\nfunction once (fn) {\n var f = function () {\n if (f.called) return f.value\n f.called = true\n return f.value = fn.apply(this, arguments)\n }\n f.called = false\n return f\n}\n\nfunction onceStrict (fn) {\n var f = function () {\n if (f.called)\n throw new Error(f.onceError)\n f.called = true\n return f.value = fn.apply(this, arguments)\n }\n var name = fn.name || 'Function wrapped with `once`'\n f.onceError = name + \" shouldn't be called more than once\"\n f.called = false\n return f\n}\n","\"use strict\";\n\nexports.__esModule = true;\nexports[\"default\"] = parseLCOV;\n\nvar _line = require(\"./line\");\n\nvar _record = require(\"./record\");\n\nexports.LCOVRecord = _record.LCOVRecord;\nexports.FunctionsDetails = _record.FunctionsDetails;\nexports.BranchesDetails = _record.BranchesDetails;\nexports.LinesDetails = _record.LinesDetails;\n\nvar _transform = require(\"./transform\");\n\nfunction _extends() { _extends = Object.assign || function (target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i]; for (var key in source) { if (Object.prototype.hasOwnProperty.call(source, key)) { target[key] = source[key]; } } } return target; }; return _extends.apply(this, arguments); }\n\nfunction parseLCOV(string) {\n if (string === void 0) {\n string = \"\";\n }\n\n var lines = string.split(\"\\n\");\n var record = (0, _record.newRecord)();\n return lines.reduce(function (retval, line) {\n if ((0, _line.isEnd)(line)) {\n retval.push(_extends({}, record));\n record = (0, _record.newRecord)();\n } else {\n var _parseLine = (0, _line.parseLine)(line),\n type = _parseLine.type,\n data = _parseLine.data;\n\n (0, _transform.transform)(record, type, data);\n }\n\n return retval;\n }, []);\n}","\"use strict\";\n\nexports.__esModule = true;\nexports.isLineType = isLineType;\nexports.isEnd = isEnd;\nexports.parseLine = parseLine;\nvar linesTypes = [\"TN\", \"SF\", \"FN\", \"FNDA\", \"FNF\", \"FNH\", \"BRDA\", \"BRF\", \"BRH\", \"DA\", \"LF\", \"LH\"];\n\nfunction isLineType(string) {\n return linesTypes.includes(string);\n}\n\nfunction isEnd(string) {\n return string === \"end_of_record\";\n}\n\nfunction parseLine(line) {\n var _line$split = line.split(\":\"),\n type = _line$split[0],\n data = _line$split[1];\n\n return {\n type: isLineType(type) ? type : undefined,\n data: (data != null ? data : \"\").split(\",\")\n };\n}","\"use strict\";\n\nexports.__esModule = true;\nexports.newRecord = newRecord;\n\nfunction newRecord() {\n return {\n title: \"\",\n file: \"\",\n functions: {\n found: 0,\n hit: 0,\n details: []\n },\n branches: {\n found: 0,\n hit: 0,\n details: []\n },\n lines: {\n found: 0,\n hit: 0,\n details: []\n }\n };\n}","\"use strict\";\n\nexports.__esModule = true;\nexports.transform = transform;\nvar transformers = {\n TN: function TN(record, data) {\n record.title = data[0];\n },\n SF: function SF(record, data) {\n record.file = data[0];\n },\n // Functions\n FNF: function FNF(record, data) {\n record.functions.found = parseInt(data[0]);\n },\n FNH: function FNH(record, data) {\n record.functions.hit = parseInt(data[0]);\n },\n FN: function FN(record, data) {\n var line = data[0],\n name = data[1];\n record.functions.details.push({\n name: name,\n line: parseInt(line)\n });\n },\n FNDA: function FNDA(record, data) {\n var hit = data[0],\n name = data[1];\n record.functions.details.some(function (item) {\n if (item.name === name && item.hit === undefined) {\n item.hit = parseInt(hit);\n return true;\n } else {\n return undefined;\n }\n });\n },\n // Branches\n BRF: function BRF(record, data) {\n record.branches.found = parseInt(data[0]);\n },\n BRH: function BRH(record, data) {\n record.branches.hit = parseInt(data[0]);\n },\n BRDA: function BRDA(record, data) {\n var line = data[0],\n block = data[1],\n branch = data[2],\n taken = data[3];\n record.branches.details.push({\n line: parseInt(line),\n block: parseInt(block),\n branch: parseInt(branch),\n taken: taken === \"-\" ? 0 : parseInt(taken)\n });\n },\n // Lines\n LF: function LF(record, data) {\n record.lines.found = parseInt(data[0]);\n },\n LH: function LH(record, data) {\n record.lines.hit = parseInt(data[0]);\n },\n DA: function DA(record, data) {\n var line = data[0],\n hit = data[1];\n record.lines.details.push({\n line: parseInt(line),\n hit: parseInt(hit)\n });\n }\n};\n\nfunction transform(record, lineType, data) {\n if (lineType) {\n transformers[lineType](record, data);\n }\n}","module.exports = require('./lib/tunnel');\n","'use strict';\n\nvar net = require('net');\nvar tls = require('tls');\nvar http = require('http');\nvar https = require('https');\nvar events = require('events');\nvar assert = require('assert');\nvar util = require('util');\n\n\nexports.httpOverHttp = httpOverHttp;\nexports.httpsOverHttp = httpsOverHttp;\nexports.httpOverHttps = httpOverHttps;\nexports.httpsOverHttps = httpsOverHttps;\n\n\nfunction httpOverHttp(options) {\n var agent = new TunnelingAgent(options);\n agent.request = http.request;\n return agent;\n}\n\nfunction httpsOverHttp(options) {\n var agent = new TunnelingAgent(options);\n agent.request = http.request;\n agent.createSocket = createSecureSocket;\n agent.defaultPort = 443;\n return agent;\n}\n\nfunction httpOverHttps(options) {\n var agent = new TunnelingAgent(options);\n agent.request = https.request;\n return agent;\n}\n\nfunction httpsOverHttps(options) {\n var agent = new TunnelingAgent(options);\n agent.request = https.request;\n agent.createSocket = createSecureSocket;\n agent.defaultPort = 443;\n return agent;\n}\n\n\nfunction TunnelingAgent(options) {\n var self = this;\n self.options = options || {};\n self.proxyOptions = self.options.proxy || {};\n self.maxSockets = self.options.maxSockets || http.Agent.defaultMaxSockets;\n self.requests = [];\n self.sockets = [];\n\n self.on('free', function onFree(socket, host, port, localAddress) {\n var options = toOptions(host, port, localAddress);\n for (var i = 0, len = self.requests.length; i < len; ++i) {\n var pending = self.requests[i];\n if (pending.host === options.host && pending.port === options.port) {\n // Detect the request to connect same origin server,\n // reuse the connection.\n self.requests.splice(i, 1);\n pending.request.onSocket(socket);\n return;\n }\n }\n socket.destroy();\n self.removeSocket(socket);\n });\n}\nutil.inherits(TunnelingAgent, events.EventEmitter);\n\nTunnelingAgent.prototype.addRequest = function addRequest(req, host, port, localAddress) {\n var self = this;\n var options = mergeOptions({request: req}, self.options, toOptions(host, port, localAddress));\n\n if (self.sockets.length >= this.maxSockets) {\n // We are over limit so we'll add it to the queue.\n self.requests.push(options);\n return;\n }\n\n // If we are under maxSockets create a new one.\n self.createSocket(options, function(socket) {\n socket.on('free', onFree);\n socket.on('close', onCloseOrRemove);\n socket.on('agentRemove', onCloseOrRemove);\n req.onSocket(socket);\n\n function onFree() {\n self.emit('free', socket, options);\n }\n\n function onCloseOrRemove(err) {\n self.removeSocket(socket);\n socket.removeListener('free', onFree);\n socket.removeListener('close', onCloseOrRemove);\n socket.removeListener('agentRemove', onCloseOrRemove);\n }\n });\n};\n\nTunnelingAgent.prototype.createSocket = function createSocket(options, cb) {\n var self = this;\n var placeholder = {};\n self.sockets.push(placeholder);\n\n var connectOptions = mergeOptions({}, self.proxyOptions, {\n method: 'CONNECT',\n path: options.host + ':' + options.port,\n agent: false,\n headers: {\n host: options.host + ':' + options.port\n }\n });\n if (options.localAddress) {\n connectOptions.localAddress = options.localAddress;\n }\n if (connectOptions.proxyAuth) {\n connectOptions.headers = connectOptions.headers || {};\n connectOptions.headers['Proxy-Authorization'] = 'Basic ' +\n new Buffer(connectOptions.proxyAuth).toString('base64');\n }\n\n debug('making CONNECT request');\n var connectReq = self.request(connectOptions);\n connectReq.useChunkedEncodingByDefault = false; // for v0.6\n connectReq.once('response', onResponse); // for v0.6\n connectReq.once('upgrade', onUpgrade); // for v0.6\n connectReq.once('connect', onConnect); // for v0.7 or later\n connectReq.once('error', onError);\n connectReq.end();\n\n function onResponse(res) {\n // Very hacky. This is necessary to avoid http-parser leaks.\n res.upgrade = true;\n }\n\n function onUpgrade(res, socket, head) {\n // Hacky.\n process.nextTick(function() {\n onConnect(res, socket, head);\n });\n }\n\n function onConnect(res, socket, head) {\n connectReq.removeAllListeners();\n socket.removeAllListeners();\n\n if (res.statusCode !== 200) {\n debug('tunneling socket could not be established, statusCode=%d',\n res.statusCode);\n socket.destroy();\n var error = new Error('tunneling socket could not be established, ' +\n 'statusCode=' + res.statusCode);\n error.code = 'ECONNRESET';\n options.request.emit('error', error);\n self.removeSocket(placeholder);\n return;\n }\n if (head.length > 0) {\n debug('got illegal response body from proxy');\n socket.destroy();\n var error = new Error('got illegal response body from proxy');\n error.code = 'ECONNRESET';\n options.request.emit('error', error);\n self.removeSocket(placeholder);\n return;\n }\n debug('tunneling connection has established');\n self.sockets[self.sockets.indexOf(placeholder)] = socket;\n return cb(socket);\n }\n\n function onError(cause) {\n connectReq.removeAllListeners();\n\n debug('tunneling socket could not be established, cause=%s\\n',\n cause.message, cause.stack);\n var error = new Error('tunneling socket could not be established, ' +\n 'cause=' + cause.message);\n error.code = 'ECONNRESET';\n options.request.emit('error', error);\n self.removeSocket(placeholder);\n }\n};\n\nTunnelingAgent.prototype.removeSocket = function removeSocket(socket) {\n var pos = this.sockets.indexOf(socket)\n if (pos === -1) {\n return;\n }\n this.sockets.splice(pos, 1);\n\n var pending = this.requests.shift();\n if (pending) {\n // If we have pending requests and a socket gets closed a new one\n // needs to be created to take over in the pool for the one that closed.\n this.createSocket(pending, function(socket) {\n pending.request.onSocket(socket);\n });\n }\n};\n\nfunction createSecureSocket(options, cb) {\n var self = this;\n TunnelingAgent.prototype.createSocket.call(self, options, function(socket) {\n var hostHeader = options.request.getHeader('host');\n var tlsOptions = mergeOptions({}, self.options, {\n socket: socket,\n servername: hostHeader ? hostHeader.replace(/:.*$/, '') : options.host\n });\n\n // 0 is dummy port for v0.6\n var secureSocket = tls.connect(0, tlsOptions);\n self.sockets[self.sockets.indexOf(socket)] = secureSocket;\n cb(secureSocket);\n });\n}\n\n\nfunction toOptions(host, port, localAddress) {\n if (typeof host === 'string') { // since v0.10\n return {\n host: host,\n port: port,\n localAddress: localAddress\n };\n }\n return host; // for v0.11 or later\n}\n\nfunction mergeOptions(target) {\n for (var i = 1, len = arguments.length; i < len; ++i) {\n var overrides = arguments[i];\n if (typeof overrides === 'object') {\n var keys = Object.keys(overrides);\n for (var j = 0, keyLen = keys.length; j < keyLen; ++j) {\n var k = keys[j];\n if (overrides[k] !== undefined) {\n target[k] = overrides[k];\n }\n }\n }\n }\n return target;\n}\n\n\nvar debug;\nif (process.env.NODE_DEBUG && /\\btunnel\\b/.test(process.env.NODE_DEBUG)) {\n debug = function() {\n var args = Array.prototype.slice.call(arguments);\n if (typeof args[0] === 'string') {\n args[0] = 'TUNNEL: ' + args[0];\n } else {\n args.unshift('TUNNEL:');\n }\n console.error.apply(console, args);\n }\n} else {\n debug = function() {};\n}\nexports.debug = debug; // for test\n","'use strict'\n\nconst Client = require('./lib/client')\nconst Dispatcher = require('./lib/dispatcher')\nconst errors = require('./lib/core/errors')\nconst Pool = require('./lib/pool')\nconst BalancedPool = require('./lib/balanced-pool')\nconst Agent = require('./lib/agent')\nconst util = require('./lib/core/util')\nconst { InvalidArgumentError } = errors\nconst api = require('./lib/api')\nconst buildConnector = require('./lib/core/connect')\nconst MockClient = require('./lib/mock/mock-client')\nconst MockAgent = require('./lib/mock/mock-agent')\nconst MockPool = require('./lib/mock/mock-pool')\nconst mockErrors = require('./lib/mock/mock-errors')\nconst ProxyAgent = require('./lib/proxy-agent')\nconst RetryHandler = require('./lib/handler/RetryHandler')\nconst { getGlobalDispatcher, setGlobalDispatcher } = require('./lib/global')\nconst DecoratorHandler = require('./lib/handler/DecoratorHandler')\nconst RedirectHandler = require('./lib/handler/RedirectHandler')\nconst createRedirectInterceptor = require('./lib/interceptor/redirectInterceptor')\n\nlet hasCrypto\ntry {\n require('crypto')\n hasCrypto = true\n} catch {\n hasCrypto = false\n}\n\nObject.assign(Dispatcher.prototype, api)\n\nmodule.exports.Dispatcher = Dispatcher\nmodule.exports.Client = Client\nmodule.exports.Pool = Pool\nmodule.exports.BalancedPool = BalancedPool\nmodule.exports.Agent = Agent\nmodule.exports.ProxyAgent = ProxyAgent\nmodule.exports.RetryHandler = RetryHandler\n\nmodule.exports.DecoratorHandler = DecoratorHandler\nmodule.exports.RedirectHandler = RedirectHandler\nmodule.exports.createRedirectInterceptor = createRedirectInterceptor\n\nmodule.exports.buildConnector = buildConnector\nmodule.exports.errors = errors\n\nfunction makeDispatcher (fn) {\n return (url, opts, handler) => {\n if (typeof opts === 'function') {\n handler = opts\n opts = null\n }\n\n if (!url || (typeof url !== 'string' && typeof url !== 'object' && !(url instanceof URL))) {\n throw new InvalidArgumentError('invalid url')\n }\n\n if (opts != null && typeof opts !== 'object') {\n throw new InvalidArgumentError('invalid opts')\n }\n\n if (opts && opts.path != null) {\n if (typeof opts.path !== 'string') {\n throw new InvalidArgumentError('invalid opts.path')\n }\n\n let path = opts.path\n if (!opts.path.startsWith('/')) {\n path = `/${path}`\n }\n\n url = new URL(util.parseOrigin(url).origin + path)\n } else {\n if (!opts) {\n opts = typeof url === 'object' ? url : {}\n }\n\n url = util.parseURL(url)\n }\n\n const { agent, dispatcher = getGlobalDispatcher() } = opts\n\n if (agent) {\n throw new InvalidArgumentError('unsupported opts.agent. Did you mean opts.client?')\n }\n\n return fn.call(dispatcher, {\n ...opts,\n origin: url.origin,\n path: url.search ? `${url.pathname}${url.search}` : url.pathname,\n method: opts.method || (opts.body ? 'PUT' : 'GET')\n }, handler)\n }\n}\n\nmodule.exports.setGlobalDispatcher = setGlobalDispatcher\nmodule.exports.getGlobalDispatcher = getGlobalDispatcher\n\nif (util.nodeMajor > 16 || (util.nodeMajor === 16 && util.nodeMinor >= 8)) {\n let fetchImpl = null\n module.exports.fetch = async function fetch (resource) {\n if (!fetchImpl) {\n fetchImpl = require('./lib/fetch').fetch\n }\n\n try {\n return await fetchImpl(...arguments)\n } catch (err) {\n if (typeof err === 'object') {\n Error.captureStackTrace(err, this)\n }\n\n throw err\n }\n }\n module.exports.Headers = require('./lib/fetch/headers').Headers\n module.exports.Response = require('./lib/fetch/response').Response\n module.exports.Request = require('./lib/fetch/request').Request\n module.exports.FormData = require('./lib/fetch/formdata').FormData\n module.exports.File = require('./lib/fetch/file').File\n module.exports.FileReader = require('./lib/fileapi/filereader').FileReader\n\n const { setGlobalOrigin, getGlobalOrigin } = require('./lib/fetch/global')\n\n module.exports.setGlobalOrigin = setGlobalOrigin\n module.exports.getGlobalOrigin = getGlobalOrigin\n\n const { CacheStorage } = require('./lib/cache/cachestorage')\n const { kConstruct } = require('./lib/cache/symbols')\n\n // Cache & CacheStorage are tightly coupled with fetch. Even if it may run\n // in an older version of Node, it doesn't have any use without fetch.\n module.exports.caches = new CacheStorage(kConstruct)\n}\n\nif (util.nodeMajor >= 16) {\n const { deleteCookie, getCookies, getSetCookies, setCookie } = require('./lib/cookies')\n\n module.exports.deleteCookie = deleteCookie\n module.exports.getCookies = getCookies\n module.exports.getSetCookies = getSetCookies\n module.exports.setCookie = setCookie\n\n const { parseMIMEType, serializeAMimeType } = require('./lib/fetch/dataURL')\n\n module.exports.parseMIMEType = parseMIMEType\n module.exports.serializeAMimeType = serializeAMimeType\n}\n\nif (util.nodeMajor >= 18 && hasCrypto) {\n const { WebSocket } = require('./lib/websocket/websocket')\n\n module.exports.WebSocket = WebSocket\n}\n\nmodule.exports.request = makeDispatcher(api.request)\nmodule.exports.stream = makeDispatcher(api.stream)\nmodule.exports.pipeline = makeDispatcher(api.pipeline)\nmodule.exports.connect = makeDispatcher(api.connect)\nmodule.exports.upgrade = makeDispatcher(api.upgrade)\n\nmodule.exports.MockClient = MockClient\nmodule.exports.MockPool = MockPool\nmodule.exports.MockAgent = MockAgent\nmodule.exports.mockErrors = mockErrors\n","'use strict'\n\nconst { InvalidArgumentError } = require('./core/errors')\nconst { kClients, kRunning, kClose, kDestroy, kDispatch, kInterceptors } = require('./core/symbols')\nconst DispatcherBase = require('./dispatcher-base')\nconst Pool = require('./pool')\nconst Client = require('./client')\nconst util = require('./core/util')\nconst createRedirectInterceptor = require('./interceptor/redirectInterceptor')\nconst { WeakRef, FinalizationRegistry } = require('./compat/dispatcher-weakref')()\n\nconst kOnConnect = Symbol('onConnect')\nconst kOnDisconnect = Symbol('onDisconnect')\nconst kOnConnectionError = Symbol('onConnectionError')\nconst kMaxRedirections = Symbol('maxRedirections')\nconst kOnDrain = Symbol('onDrain')\nconst kFactory = Symbol('factory')\nconst kFinalizer = Symbol('finalizer')\nconst kOptions = Symbol('options')\n\nfunction defaultFactory (origin, opts) {\n return opts && opts.connections === 1\n ? new Client(origin, opts)\n : new Pool(origin, opts)\n}\n\nclass Agent extends DispatcherBase {\n constructor ({ factory = defaultFactory, maxRedirections = 0, connect, ...options } = {}) {\n super()\n\n if (typeof factory !== 'function') {\n throw new InvalidArgumentError('factory must be a function.')\n }\n\n if (connect != null && typeof connect !== 'function' && typeof connect !== 'object') {\n throw new InvalidArgumentError('connect must be a function or an object')\n }\n\n if (!Number.isInteger(maxRedirections) || maxRedirections < 0) {\n throw new InvalidArgumentError('maxRedirections must be a positive number')\n }\n\n if (connect && typeof connect !== 'function') {\n connect = { ...connect }\n }\n\n this[kInterceptors] = options.interceptors && options.interceptors.Agent && Array.isArray(options.interceptors.Agent)\n ? options.interceptors.Agent\n : [createRedirectInterceptor({ maxRedirections })]\n\n this[kOptions] = { ...util.deepClone(options), connect }\n this[kOptions].interceptors = options.interceptors\n ? { ...options.interceptors }\n : undefined\n this[kMaxRedirections] = maxRedirections\n this[kFactory] = factory\n this[kClients] = new Map()\n this[kFinalizer] = new FinalizationRegistry(/* istanbul ignore next: gc is undeterministic */ key => {\n const ref = this[kClients].get(key)\n if (ref !== undefined && ref.deref() === undefined) {\n this[kClients].delete(key)\n }\n })\n\n const agent = this\n\n this[kOnDrain] = (origin, targets) => {\n agent.emit('drain', origin, [agent, ...targets])\n }\n\n this[kOnConnect] = (origin, targets) => {\n agent.emit('connect', origin, [agent, ...targets])\n }\n\n this[kOnDisconnect] = (origin, targets, err) => {\n agent.emit('disconnect', origin, [agent, ...targets], err)\n }\n\n this[kOnConnectionError] = (origin, targets, err) => {\n agent.emit('connectionError', origin, [agent, ...targets], err)\n }\n }\n\n get [kRunning] () {\n let ret = 0\n for (const ref of this[kClients].values()) {\n const client = ref.deref()\n /* istanbul ignore next: gc is undeterministic */\n if (client) {\n ret += client[kRunning]\n }\n }\n return ret\n }\n\n [kDispatch] (opts, handler) {\n let key\n if (opts.origin && (typeof opts.origin === 'string' || opts.origin instanceof URL)) {\n key = String(opts.origin)\n } else {\n throw new InvalidArgumentError('opts.origin must be a non-empty string or URL.')\n }\n\n const ref = this[kClients].get(key)\n\n let dispatcher = ref ? ref.deref() : null\n if (!dispatcher) {\n dispatcher = this[kFactory](opts.origin, this[kOptions])\n .on('drain', this[kOnDrain])\n .on('connect', this[kOnConnect])\n .on('disconnect', this[kOnDisconnect])\n .on('connectionError', this[kOnConnectionError])\n\n this[kClients].set(key, new WeakRef(dispatcher))\n this[kFinalizer].register(dispatcher, key)\n }\n\n return dispatcher.dispatch(opts, handler)\n }\n\n async [kClose] () {\n const closePromises = []\n for (const ref of this[kClients].values()) {\n const client = ref.deref()\n /* istanbul ignore else: gc is undeterministic */\n if (client) {\n closePromises.push(client.close())\n }\n }\n\n await Promise.all(closePromises)\n }\n\n async [kDestroy] (err) {\n const destroyPromises = []\n for (const ref of this[kClients].values()) {\n const client = ref.deref()\n /* istanbul ignore else: gc is undeterministic */\n if (client) {\n destroyPromises.push(client.destroy(err))\n }\n }\n\n await Promise.all(destroyPromises)\n }\n}\n\nmodule.exports = Agent\n","const { addAbortListener } = require('../core/util')\nconst { RequestAbortedError } = require('../core/errors')\n\nconst kListener = Symbol('kListener')\nconst kSignal = Symbol('kSignal')\n\nfunction abort (self) {\n if (self.abort) {\n self.abort()\n } else {\n self.onError(new RequestAbortedError())\n }\n}\n\nfunction addSignal (self, signal) {\n self[kSignal] = null\n self[kListener] = null\n\n if (!signal) {\n return\n }\n\n if (signal.aborted) {\n abort(self)\n return\n }\n\n self[kSignal] = signal\n self[kListener] = () => {\n abort(self)\n }\n\n addAbortListener(self[kSignal], self[kListener])\n}\n\nfunction removeSignal (self) {\n if (!self[kSignal]) {\n return\n }\n\n if ('removeEventListener' in self[kSignal]) {\n self[kSignal].removeEventListener('abort', self[kListener])\n } else {\n self[kSignal].removeListener('abort', self[kListener])\n }\n\n self[kSignal] = null\n self[kListener] = null\n}\n\nmodule.exports = {\n addSignal,\n removeSignal\n}\n","'use strict'\n\nconst { AsyncResource } = require('async_hooks')\nconst { InvalidArgumentError, RequestAbortedError, SocketError } = require('../core/errors')\nconst util = require('../core/util')\nconst { addSignal, removeSignal } = require('./abort-signal')\n\nclass ConnectHandler extends AsyncResource {\n constructor (opts, callback) {\n if (!opts || typeof opts !== 'object') {\n throw new InvalidArgumentError('invalid opts')\n }\n\n if (typeof callback !== 'function') {\n throw new InvalidArgumentError('invalid callback')\n }\n\n const { signal, opaque, responseHeaders } = opts\n\n if (signal && typeof signal.on !== 'function' && typeof signal.addEventListener !== 'function') {\n throw new InvalidArgumentError('signal must be an EventEmitter or EventTarget')\n }\n\n super('UNDICI_CONNECT')\n\n this.opaque = opaque || null\n this.responseHeaders = responseHeaders || null\n this.callback = callback\n this.abort = null\n\n addSignal(this, signal)\n }\n\n onConnect (abort, context) {\n if (!this.callback) {\n throw new RequestAbortedError()\n }\n\n this.abort = abort\n this.context = context\n }\n\n onHeaders () {\n throw new SocketError('bad connect', null)\n }\n\n onUpgrade (statusCode, rawHeaders, socket) {\n const { callback, opaque, context } = this\n\n removeSignal(this)\n\n this.callback = null\n\n let headers = rawHeaders\n // Indicates is an HTTP2Session\n if (headers != null) {\n headers = this.responseHeaders === 'raw' ? util.parseRawHeaders(rawHeaders) : util.parseHeaders(rawHeaders)\n }\n\n this.runInAsyncScope(callback, null, null, {\n statusCode,\n headers,\n socket,\n opaque,\n context\n })\n }\n\n onError (err) {\n const { callback, opaque } = this\n\n removeSignal(this)\n\n if (callback) {\n this.callback = null\n queueMicrotask(() => {\n this.runInAsyncScope(callback, null, err, { opaque })\n })\n }\n }\n}\n\nfunction connect (opts, callback) {\n if (callback === undefined) {\n return new Promise((resolve, reject) => {\n connect.call(this, opts, (err, data) => {\n return err ? reject(err) : resolve(data)\n })\n })\n }\n\n try {\n const connectHandler = new ConnectHandler(opts, callback)\n this.dispatch({ ...opts, method: 'CONNECT' }, connectHandler)\n } catch (err) {\n if (typeof callback !== 'function') {\n throw err\n }\n const opaque = opts && opts.opaque\n queueMicrotask(() => callback(err, { opaque }))\n }\n}\n\nmodule.exports = connect\n","'use strict'\n\nconst {\n Readable,\n Duplex,\n PassThrough\n} = require('stream')\nconst {\n InvalidArgumentError,\n InvalidReturnValueError,\n RequestAbortedError\n} = require('../core/errors')\nconst util = require('../core/util')\nconst { AsyncResource } = require('async_hooks')\nconst { addSignal, removeSignal } = require('./abort-signal')\nconst assert = require('assert')\n\nconst kResume = Symbol('resume')\n\nclass PipelineRequest extends Readable {\n constructor () {\n super({ autoDestroy: true })\n\n this[kResume] = null\n }\n\n _read () {\n const { [kResume]: resume } = this\n\n if (resume) {\n this[kResume] = null\n resume()\n }\n }\n\n _destroy (err, callback) {\n this._read()\n\n callback(err)\n }\n}\n\nclass PipelineResponse extends Readable {\n constructor (resume) {\n super({ autoDestroy: true })\n this[kResume] = resume\n }\n\n _read () {\n this[kResume]()\n }\n\n _destroy (err, callback) {\n if (!err && !this._readableState.endEmitted) {\n err = new RequestAbortedError()\n }\n\n callback(err)\n }\n}\n\nclass PipelineHandler extends AsyncResource {\n constructor (opts, handler) {\n if (!opts || typeof opts !== 'object') {\n throw new InvalidArgumentError('invalid opts')\n }\n\n if (typeof handler !== 'function') {\n throw new InvalidArgumentError('invalid handler')\n }\n\n const { signal, method, opaque, onInfo, responseHeaders } = opts\n\n if (signal && typeof signal.on !== 'function' && typeof signal.addEventListener !== 'function') {\n throw new InvalidArgumentError('signal must be an EventEmitter or EventTarget')\n }\n\n if (method === 'CONNECT') {\n throw new InvalidArgumentError('invalid method')\n }\n\n if (onInfo && typeof onInfo !== 'function') {\n throw new InvalidArgumentError('invalid onInfo callback')\n }\n\n super('UNDICI_PIPELINE')\n\n this.opaque = opaque || null\n this.responseHeaders = responseHeaders || null\n this.handler = handler\n this.abort = null\n this.context = null\n this.onInfo = onInfo || null\n\n this.req = new PipelineRequest().on('error', util.nop)\n\n this.ret = new Duplex({\n readableObjectMode: opts.objectMode,\n autoDestroy: true,\n read: () => {\n const { body } = this\n\n if (body && body.resume) {\n body.resume()\n }\n },\n write: (chunk, encoding, callback) => {\n const { req } = this\n\n if (req.push(chunk, encoding) || req._readableState.destroyed) {\n callback()\n } else {\n req[kResume] = callback\n }\n },\n destroy: (err, callback) => {\n const { body, req, res, ret, abort } = this\n\n if (!err && !ret._readableState.endEmitted) {\n err = new RequestAbortedError()\n }\n\n if (abort && err) {\n abort()\n }\n\n util.destroy(body, err)\n util.destroy(req, err)\n util.destroy(res, err)\n\n removeSignal(this)\n\n callback(err)\n }\n }).on('prefinish', () => {\n const { req } = this\n\n // Node < 15 does not call _final in same tick.\n req.push(null)\n })\n\n this.res = null\n\n addSignal(this, signal)\n }\n\n onConnect (abort, context) {\n const { ret, res } = this\n\n assert(!res, 'pipeline cannot be retried')\n\n if (ret.destroyed) {\n throw new RequestAbortedError()\n }\n\n this.abort = abort\n this.context = context\n }\n\n onHeaders (statusCode, rawHeaders, resume) {\n const { opaque, handler, context } = this\n\n if (statusCode < 200) {\n if (this.onInfo) {\n const headers = this.responseHeaders === 'raw' ? util.parseRawHeaders(rawHeaders) : util.parseHeaders(rawHeaders)\n this.onInfo({ statusCode, headers })\n }\n return\n }\n\n this.res = new PipelineResponse(resume)\n\n let body\n try {\n this.handler = null\n const headers = this.responseHeaders === 'raw' ? util.parseRawHeaders(rawHeaders) : util.parseHeaders(rawHeaders)\n body = this.runInAsyncScope(handler, null, {\n statusCode,\n headers,\n opaque,\n body: this.res,\n context\n })\n } catch (err) {\n this.res.on('error', util.nop)\n throw err\n }\n\n if (!body || typeof body.on !== 'function') {\n throw new InvalidReturnValueError('expected Readable')\n }\n\n body\n .on('data', (chunk) => {\n const { ret, body } = this\n\n if (!ret.push(chunk) && body.pause) {\n body.pause()\n }\n })\n .on('error', (err) => {\n const { ret } = this\n\n util.destroy(ret, err)\n })\n .on('end', () => {\n const { ret } = this\n\n ret.push(null)\n })\n .on('close', () => {\n const { ret } = this\n\n if (!ret._readableState.ended) {\n util.destroy(ret, new RequestAbortedError())\n }\n })\n\n this.body = body\n }\n\n onData (chunk) {\n const { res } = this\n return res.push(chunk)\n }\n\n onComplete (trailers) {\n const { res } = this\n res.push(null)\n }\n\n onError (err) {\n const { ret } = this\n this.handler = null\n util.destroy(ret, err)\n }\n}\n\nfunction pipeline (opts, handler) {\n try {\n const pipelineHandler = new PipelineHandler(opts, handler)\n this.dispatch({ ...opts, body: pipelineHandler.req }, pipelineHandler)\n return pipelineHandler.ret\n } catch (err) {\n return new PassThrough().destroy(err)\n }\n}\n\nmodule.exports = pipeline\n","'use strict'\n\nconst Readable = require('./readable')\nconst {\n InvalidArgumentError,\n RequestAbortedError\n} = require('../core/errors')\nconst util = require('../core/util')\nconst { getResolveErrorBodyCallback } = require('./util')\nconst { AsyncResource } = require('async_hooks')\nconst { addSignal, removeSignal } = require('./abort-signal')\n\nclass RequestHandler extends AsyncResource {\n constructor (opts, callback) {\n if (!opts || typeof opts !== 'object') {\n throw new InvalidArgumentError('invalid opts')\n }\n\n const { signal, method, opaque, body, onInfo, responseHeaders, throwOnError, highWaterMark } = opts\n\n try {\n if (typeof callback !== 'function') {\n throw new InvalidArgumentError('invalid callback')\n }\n\n if (highWaterMark && (typeof highWaterMark !== 'number' || highWaterMark < 0)) {\n throw new InvalidArgumentError('invalid highWaterMark')\n }\n\n if (signal && typeof signal.on !== 'function' && typeof signal.addEventListener !== 'function') {\n throw new InvalidArgumentError('signal must be an EventEmitter or EventTarget')\n }\n\n if (method === 'CONNECT') {\n throw new InvalidArgumentError('invalid method')\n }\n\n if (onInfo && typeof onInfo !== 'function') {\n throw new InvalidArgumentError('invalid onInfo callback')\n }\n\n super('UNDICI_REQUEST')\n } catch (err) {\n if (util.isStream(body)) {\n util.destroy(body.on('error', util.nop), err)\n }\n throw err\n }\n\n this.responseHeaders = responseHeaders || null\n this.opaque = opaque || null\n this.callback = callback\n this.res = null\n this.abort = null\n this.body = body\n this.trailers = {}\n this.context = null\n this.onInfo = onInfo || null\n this.throwOnError = throwOnError\n this.highWaterMark = highWaterMark\n\n if (util.isStream(body)) {\n body.on('error', (err) => {\n this.onError(err)\n })\n }\n\n addSignal(this, signal)\n }\n\n onConnect (abort, context) {\n if (!this.callback) {\n throw new RequestAbortedError()\n }\n\n this.abort = abort\n this.context = context\n }\n\n onHeaders (statusCode, rawHeaders, resume, statusMessage) {\n const { callback, opaque, abort, context, responseHeaders, highWaterMark } = this\n\n const headers = responseHeaders === 'raw' ? util.parseRawHeaders(rawHeaders) : util.parseHeaders(rawHeaders)\n\n if (statusCode < 200) {\n if (this.onInfo) {\n this.onInfo({ statusCode, headers })\n }\n return\n }\n\n const parsedHeaders = responseHeaders === 'raw' ? util.parseHeaders(rawHeaders) : headers\n const contentType = parsedHeaders['content-type']\n const body = new Readable({ resume, abort, contentType, highWaterMark })\n\n this.callback = null\n this.res = body\n if (callback !== null) {\n if (this.throwOnError && statusCode >= 400) {\n this.runInAsyncScope(getResolveErrorBodyCallback, null,\n { callback, body, contentType, statusCode, statusMessage, headers }\n )\n } else {\n this.runInAsyncScope(callback, null, null, {\n statusCode,\n headers,\n trailers: this.trailers,\n opaque,\n body,\n context\n })\n }\n }\n }\n\n onData (chunk) {\n const { res } = this\n return res.push(chunk)\n }\n\n onComplete (trailers) {\n const { res } = this\n\n removeSignal(this)\n\n util.parseHeaders(trailers, this.trailers)\n\n res.push(null)\n }\n\n onError (err) {\n const { res, callback, body, opaque } = this\n\n removeSignal(this)\n\n if (callback) {\n // TODO: Does this need queueMicrotask?\n this.callback = null\n queueMicrotask(() => {\n this.runInAsyncScope(callback, null, err, { opaque })\n })\n }\n\n if (res) {\n this.res = null\n // Ensure all queued handlers are invoked before destroying res.\n queueMicrotask(() => {\n util.destroy(res, err)\n })\n }\n\n if (body) {\n this.body = null\n util.destroy(body, err)\n }\n }\n}\n\nfunction request (opts, callback) {\n if (callback === undefined) {\n return new Promise((resolve, reject) => {\n request.call(this, opts, (err, data) => {\n return err ? reject(err) : resolve(data)\n })\n })\n }\n\n try {\n this.dispatch(opts, new RequestHandler(opts, callback))\n } catch (err) {\n if (typeof callback !== 'function') {\n throw err\n }\n const opaque = opts && opts.opaque\n queueMicrotask(() => callback(err, { opaque }))\n }\n}\n\nmodule.exports = request\nmodule.exports.RequestHandler = RequestHandler\n","'use strict'\n\nconst { finished, PassThrough } = require('stream')\nconst {\n InvalidArgumentError,\n InvalidReturnValueError,\n RequestAbortedError\n} = require('../core/errors')\nconst util = require('../core/util')\nconst { getResolveErrorBodyCallback } = require('./util')\nconst { AsyncResource } = require('async_hooks')\nconst { addSignal, removeSignal } = require('./abort-signal')\n\nclass StreamHandler extends AsyncResource {\n constructor (opts, factory, callback) {\n if (!opts || typeof opts !== 'object') {\n throw new InvalidArgumentError('invalid opts')\n }\n\n const { signal, method, opaque, body, onInfo, responseHeaders, throwOnError } = opts\n\n try {\n if (typeof callback !== 'function') {\n throw new InvalidArgumentError('invalid callback')\n }\n\n if (typeof factory !== 'function') {\n throw new InvalidArgumentError('invalid factory')\n }\n\n if (signal && typeof signal.on !== 'function' && typeof signal.addEventListener !== 'function') {\n throw new InvalidArgumentError('signal must be an EventEmitter or EventTarget')\n }\n\n if (method === 'CONNECT') {\n throw new InvalidArgumentError('invalid method')\n }\n\n if (onInfo && typeof onInfo !== 'function') {\n throw new InvalidArgumentError('invalid onInfo callback')\n }\n\n super('UNDICI_STREAM')\n } catch (err) {\n if (util.isStream(body)) {\n util.destroy(body.on('error', util.nop), err)\n }\n throw err\n }\n\n this.responseHeaders = responseHeaders || null\n this.opaque = opaque || null\n this.factory = factory\n this.callback = callback\n this.res = null\n this.abort = null\n this.context = null\n this.trailers = null\n this.body = body\n this.onInfo = onInfo || null\n this.throwOnError = throwOnError || false\n\n if (util.isStream(body)) {\n body.on('error', (err) => {\n this.onError(err)\n })\n }\n\n addSignal(this, signal)\n }\n\n onConnect (abort, context) {\n if (!this.callback) {\n throw new RequestAbortedError()\n }\n\n this.abort = abort\n this.context = context\n }\n\n onHeaders (statusCode, rawHeaders, resume, statusMessage) {\n const { factory, opaque, context, callback, responseHeaders } = this\n\n const headers = responseHeaders === 'raw' ? util.parseRawHeaders(rawHeaders) : util.parseHeaders(rawHeaders)\n\n if (statusCode < 200) {\n if (this.onInfo) {\n this.onInfo({ statusCode, headers })\n }\n return\n }\n\n this.factory = null\n\n let res\n\n if (this.throwOnError && statusCode >= 400) {\n const parsedHeaders = responseHeaders === 'raw' ? util.parseHeaders(rawHeaders) : headers\n const contentType = parsedHeaders['content-type']\n res = new PassThrough()\n\n this.callback = null\n this.runInAsyncScope(getResolveErrorBodyCallback, null,\n { callback, body: res, contentType, statusCode, statusMessage, headers }\n )\n } else {\n if (factory === null) {\n return\n }\n\n res = this.runInAsyncScope(factory, null, {\n statusCode,\n headers,\n opaque,\n context\n })\n\n if (\n !res ||\n typeof res.write !== 'function' ||\n typeof res.end !== 'function' ||\n typeof res.on !== 'function'\n ) {\n throw new InvalidReturnValueError('expected Writable')\n }\n\n // TODO: Avoid finished. It registers an unnecessary amount of listeners.\n finished(res, { readable: false }, (err) => {\n const { callback, res, opaque, trailers, abort } = this\n\n this.res = null\n if (err || !res.readable) {\n util.destroy(res, err)\n }\n\n this.callback = null\n this.runInAsyncScope(callback, null, err || null, { opaque, trailers })\n\n if (err) {\n abort()\n }\n })\n }\n\n res.on('drain', resume)\n\n this.res = res\n\n const needDrain = res.writableNeedDrain !== undefined\n ? res.writableNeedDrain\n : res._writableState && res._writableState.needDrain\n\n return needDrain !== true\n }\n\n onData (chunk) {\n const { res } = this\n\n return res ? res.write(chunk) : true\n }\n\n onComplete (trailers) {\n const { res } = this\n\n removeSignal(this)\n\n if (!res) {\n return\n }\n\n this.trailers = util.parseHeaders(trailers)\n\n res.end()\n }\n\n onError (err) {\n const { res, callback, opaque, body } = this\n\n removeSignal(this)\n\n this.factory = null\n\n if (res) {\n this.res = null\n util.destroy(res, err)\n } else if (callback) {\n this.callback = null\n queueMicrotask(() => {\n this.runInAsyncScope(callback, null, err, { opaque })\n })\n }\n\n if (body) {\n this.body = null\n util.destroy(body, err)\n }\n }\n}\n\nfunction stream (opts, factory, callback) {\n if (callback === undefined) {\n return new Promise((resolve, reject) => {\n stream.call(this, opts, factory, (err, data) => {\n return err ? reject(err) : resolve(data)\n })\n })\n }\n\n try {\n this.dispatch(opts, new StreamHandler(opts, factory, callback))\n } catch (err) {\n if (typeof callback !== 'function') {\n throw err\n }\n const opaque = opts && opts.opaque\n queueMicrotask(() => callback(err, { opaque }))\n }\n}\n\nmodule.exports = stream\n","'use strict'\n\nconst { InvalidArgumentError, RequestAbortedError, SocketError } = require('../core/errors')\nconst { AsyncResource } = require('async_hooks')\nconst util = require('../core/util')\nconst { addSignal, removeSignal } = require('./abort-signal')\nconst assert = require('assert')\n\nclass UpgradeHandler extends AsyncResource {\n constructor (opts, callback) {\n if (!opts || typeof opts !== 'object') {\n throw new InvalidArgumentError('invalid opts')\n }\n\n if (typeof callback !== 'function') {\n throw new InvalidArgumentError('invalid callback')\n }\n\n const { signal, opaque, responseHeaders } = opts\n\n if (signal && typeof signal.on !== 'function' && typeof signal.addEventListener !== 'function') {\n throw new InvalidArgumentError('signal must be an EventEmitter or EventTarget')\n }\n\n super('UNDICI_UPGRADE')\n\n this.responseHeaders = responseHeaders || null\n this.opaque = opaque || null\n this.callback = callback\n this.abort = null\n this.context = null\n\n addSignal(this, signal)\n }\n\n onConnect (abort, context) {\n if (!this.callback) {\n throw new RequestAbortedError()\n }\n\n this.abort = abort\n this.context = null\n }\n\n onHeaders () {\n throw new SocketError('bad upgrade', null)\n }\n\n onUpgrade (statusCode, rawHeaders, socket) {\n const { callback, opaque, context } = this\n\n assert.strictEqual(statusCode, 101)\n\n removeSignal(this)\n\n this.callback = null\n const headers = this.responseHeaders === 'raw' ? util.parseRawHeaders(rawHeaders) : util.parseHeaders(rawHeaders)\n this.runInAsyncScope(callback, null, null, {\n headers,\n socket,\n opaque,\n context\n })\n }\n\n onError (err) {\n const { callback, opaque } = this\n\n removeSignal(this)\n\n if (callback) {\n this.callback = null\n queueMicrotask(() => {\n this.runInAsyncScope(callback, null, err, { opaque })\n })\n }\n }\n}\n\nfunction upgrade (opts, callback) {\n if (callback === undefined) {\n return new Promise((resolve, reject) => {\n upgrade.call(this, opts, (err, data) => {\n return err ? reject(err) : resolve(data)\n })\n })\n }\n\n try {\n const upgradeHandler = new UpgradeHandler(opts, callback)\n this.dispatch({\n ...opts,\n method: opts.method || 'GET',\n upgrade: opts.protocol || 'Websocket'\n }, upgradeHandler)\n } catch (err) {\n if (typeof callback !== 'function') {\n throw err\n }\n const opaque = opts && opts.opaque\n queueMicrotask(() => callback(err, { opaque }))\n }\n}\n\nmodule.exports = upgrade\n","'use strict'\n\nmodule.exports.request = require('./api-request')\nmodule.exports.stream = require('./api-stream')\nmodule.exports.pipeline = require('./api-pipeline')\nmodule.exports.upgrade = require('./api-upgrade')\nmodule.exports.connect = require('./api-connect')\n","// Ported from https://github.com/nodejs/undici/pull/907\n\n'use strict'\n\nconst assert = require('assert')\nconst { Readable } = require('stream')\nconst { RequestAbortedError, NotSupportedError, InvalidArgumentError } = require('../core/errors')\nconst util = require('../core/util')\nconst { ReadableStreamFrom, toUSVString } = require('../core/util')\n\nlet Blob\n\nconst kConsume = Symbol('kConsume')\nconst kReading = Symbol('kReading')\nconst kBody = Symbol('kBody')\nconst kAbort = Symbol('abort')\nconst kContentType = Symbol('kContentType')\n\nconst noop = () => {}\n\nmodule.exports = class BodyReadable extends Readable {\n constructor ({\n resume,\n abort,\n contentType = '',\n highWaterMark = 64 * 1024 // Same as nodejs fs streams.\n }) {\n super({\n autoDestroy: true,\n read: resume,\n highWaterMark\n })\n\n this._readableState.dataEmitted = false\n\n this[kAbort] = abort\n this[kConsume] = null\n this[kBody] = null\n this[kContentType] = contentType\n\n // Is stream being consumed through Readable API?\n // This is an optimization so that we avoid checking\n // for 'data' and 'readable' listeners in the hot path\n // inside push().\n this[kReading] = false\n }\n\n destroy (err) {\n if (this.destroyed) {\n // Node < 16\n return this\n }\n\n if (!err && !this._readableState.endEmitted) {\n err = new RequestAbortedError()\n }\n\n if (err) {\n this[kAbort]()\n }\n\n return super.destroy(err)\n }\n\n emit (ev, ...args) {\n if (ev === 'data') {\n // Node < 16.7\n this._readableState.dataEmitted = true\n } else if (ev === 'error') {\n // Node < 16\n this._readableState.errorEmitted = true\n }\n return super.emit(ev, ...args)\n }\n\n on (ev, ...args) {\n if (ev === 'data' || ev === 'readable') {\n this[kReading] = true\n }\n return super.on(ev, ...args)\n }\n\n addListener (ev, ...args) {\n return this.on(ev, ...args)\n }\n\n off (ev, ...args) {\n const ret = super.off(ev, ...args)\n if (ev === 'data' || ev === 'readable') {\n this[kReading] = (\n this.listenerCount('data') > 0 ||\n this.listenerCount('readable') > 0\n )\n }\n return ret\n }\n\n removeListener (ev, ...args) {\n return this.off(ev, ...args)\n }\n\n push (chunk) {\n if (this[kConsume] && chunk !== null && this.readableLength === 0) {\n consumePush(this[kConsume], chunk)\n return this[kReading] ? super.push(chunk) : true\n }\n return super.push(chunk)\n }\n\n // https://fetch.spec.whatwg.org/#dom-body-text\n async text () {\n return consume(this, 'text')\n }\n\n // https://fetch.spec.whatwg.org/#dom-body-json\n async json () {\n return consume(this, 'json')\n }\n\n // https://fetch.spec.whatwg.org/#dom-body-blob\n async blob () {\n return consume(this, 'blob')\n }\n\n // https://fetch.spec.whatwg.org/#dom-body-arraybuffer\n async arrayBuffer () {\n return consume(this, 'arrayBuffer')\n }\n\n // https://fetch.spec.whatwg.org/#dom-body-formdata\n async formData () {\n // TODO: Implement.\n throw new NotSupportedError()\n }\n\n // https://fetch.spec.whatwg.org/#dom-body-bodyused\n get bodyUsed () {\n return util.isDisturbed(this)\n }\n\n // https://fetch.spec.whatwg.org/#dom-body-body\n get body () {\n if (!this[kBody]) {\n this[kBody] = ReadableStreamFrom(this)\n if (this[kConsume]) {\n // TODO: Is this the best way to force a lock?\n this[kBody].getReader() // Ensure stream is locked.\n assert(this[kBody].locked)\n }\n }\n return this[kBody]\n }\n\n dump (opts) {\n let limit = opts && Number.isFinite(opts.limit) ? opts.limit : 262144\n const signal = opts && opts.signal\n\n if (signal) {\n try {\n if (typeof signal !== 'object' || !('aborted' in signal)) {\n throw new InvalidArgumentError('signal must be an AbortSignal')\n }\n util.throwIfAborted(signal)\n } catch (err) {\n return Promise.reject(err)\n }\n }\n\n if (this.closed) {\n return Promise.resolve(null)\n }\n\n return new Promise((resolve, reject) => {\n const signalListenerCleanup = signal\n ? util.addAbortListener(signal, () => {\n this.destroy()\n })\n : noop\n\n this\n .on('close', function () {\n signalListenerCleanup()\n if (signal && signal.aborted) {\n reject(signal.reason || Object.assign(new Error('The operation was aborted'), { name: 'AbortError' }))\n } else {\n resolve(null)\n }\n })\n .on('error', noop)\n .on('data', function (chunk) {\n limit -= chunk.length\n if (limit <= 0) {\n this.destroy()\n }\n })\n .resume()\n })\n }\n}\n\n// https://streams.spec.whatwg.org/#readablestream-locked\nfunction isLocked (self) {\n // Consume is an implicit lock.\n return (self[kBody] && self[kBody].locked === true) || self[kConsume]\n}\n\n// https://fetch.spec.whatwg.org/#body-unusable\nfunction isUnusable (self) {\n return util.isDisturbed(self) || isLocked(self)\n}\n\nasync function consume (stream, type) {\n if (isUnusable(stream)) {\n throw new TypeError('unusable')\n }\n\n assert(!stream[kConsume])\n\n return new Promise((resolve, reject) => {\n stream[kConsume] = {\n type,\n stream,\n resolve,\n reject,\n length: 0,\n body: []\n }\n\n stream\n .on('error', function (err) {\n consumeFinish(this[kConsume], err)\n })\n .on('close', function () {\n if (this[kConsume].body !== null) {\n consumeFinish(this[kConsume], new RequestAbortedError())\n }\n })\n\n process.nextTick(consumeStart, stream[kConsume])\n })\n}\n\nfunction consumeStart (consume) {\n if (consume.body === null) {\n return\n }\n\n const { _readableState: state } = consume.stream\n\n for (const chunk of state.buffer) {\n consumePush(consume, chunk)\n }\n\n if (state.endEmitted) {\n consumeEnd(this[kConsume])\n } else {\n consume.stream.on('end', function () {\n consumeEnd(this[kConsume])\n })\n }\n\n consume.stream.resume()\n\n while (consume.stream.read() != null) {\n // Loop\n }\n}\n\nfunction consumeEnd (consume) {\n const { type, body, resolve, stream, length } = consume\n\n try {\n if (type === 'text') {\n resolve(toUSVString(Buffer.concat(body)))\n } else if (type === 'json') {\n resolve(JSON.parse(Buffer.concat(body)))\n } else if (type === 'arrayBuffer') {\n const dst = new Uint8Array(length)\n\n let pos = 0\n for (const buf of body) {\n dst.set(buf, pos)\n pos += buf.byteLength\n }\n\n resolve(dst.buffer)\n } else if (type === 'blob') {\n if (!Blob) {\n Blob = require('buffer').Blob\n }\n resolve(new Blob(body, { type: stream[kContentType] }))\n }\n\n consumeFinish(consume)\n } catch (err) {\n stream.destroy(err)\n }\n}\n\nfunction consumePush (consume, chunk) {\n consume.length += chunk.length\n consume.body.push(chunk)\n}\n\nfunction consumeFinish (consume, err) {\n if (consume.body === null) {\n return\n }\n\n if (err) {\n consume.reject(err)\n } else {\n consume.resolve()\n }\n\n consume.type = null\n consume.stream = null\n consume.resolve = null\n consume.reject = null\n consume.length = 0\n consume.body = null\n}\n","const assert = require('assert')\nconst {\n ResponseStatusCodeError\n} = require('../core/errors')\nconst { toUSVString } = require('../core/util')\n\nasync function getResolveErrorBodyCallback ({ callback, body, contentType, statusCode, statusMessage, headers }) {\n assert(body)\n\n let chunks = []\n let limit = 0\n\n for await (const chunk of body) {\n chunks.push(chunk)\n limit += chunk.length\n if (limit > 128 * 1024) {\n chunks = null\n break\n }\n }\n\n if (statusCode === 204 || !contentType || !chunks) {\n process.nextTick(callback, new ResponseStatusCodeError(`Response status code ${statusCode}${statusMessage ? `: ${statusMessage}` : ''}`, statusCode, headers))\n return\n }\n\n try {\n if (contentType.startsWith('application/json')) {\n const payload = JSON.parse(toUSVString(Buffer.concat(chunks)))\n process.nextTick(callback, new ResponseStatusCodeError(`Response status code ${statusCode}${statusMessage ? `: ${statusMessage}` : ''}`, statusCode, headers, payload))\n return\n }\n\n if (contentType.startsWith('text/')) {\n const payload = toUSVString(Buffer.concat(chunks))\n process.nextTick(callback, new ResponseStatusCodeError(`Response status code ${statusCode}${statusMessage ? `: ${statusMessage}` : ''}`, statusCode, headers, payload))\n return\n }\n } catch (err) {\n // Process in a fallback if error\n }\n\n process.nextTick(callback, new ResponseStatusCodeError(`Response status code ${statusCode}${statusMessage ? `: ${statusMessage}` : ''}`, statusCode, headers))\n}\n\nmodule.exports = { getResolveErrorBodyCallback }\n","'use strict'\n\nconst {\n BalancedPoolMissingUpstreamError,\n InvalidArgumentError\n} = require('./core/errors')\nconst {\n PoolBase,\n kClients,\n kNeedDrain,\n kAddClient,\n kRemoveClient,\n kGetDispatcher\n} = require('./pool-base')\nconst Pool = require('./pool')\nconst { kUrl, kInterceptors } = require('./core/symbols')\nconst { parseOrigin } = require('./core/util')\nconst kFactory = Symbol('factory')\n\nconst kOptions = Symbol('options')\nconst kGreatestCommonDivisor = Symbol('kGreatestCommonDivisor')\nconst kCurrentWeight = Symbol('kCurrentWeight')\nconst kIndex = Symbol('kIndex')\nconst kWeight = Symbol('kWeight')\nconst kMaxWeightPerServer = Symbol('kMaxWeightPerServer')\nconst kErrorPenalty = Symbol('kErrorPenalty')\n\nfunction getGreatestCommonDivisor (a, b) {\n if (b === 0) return a\n return getGreatestCommonDivisor(b, a % b)\n}\n\nfunction defaultFactory (origin, opts) {\n return new Pool(origin, opts)\n}\n\nclass BalancedPool extends PoolBase {\n constructor (upstreams = [], { factory = defaultFactory, ...opts } = {}) {\n super()\n\n this[kOptions] = opts\n this[kIndex] = -1\n this[kCurrentWeight] = 0\n\n this[kMaxWeightPerServer] = this[kOptions].maxWeightPerServer || 100\n this[kErrorPenalty] = this[kOptions].errorPenalty || 15\n\n if (!Array.isArray(upstreams)) {\n upstreams = [upstreams]\n }\n\n if (typeof factory !== 'function') {\n throw new InvalidArgumentError('factory must be a function.')\n }\n\n this[kInterceptors] = opts.interceptors && opts.interceptors.BalancedPool && Array.isArray(opts.interceptors.BalancedPool)\n ? opts.interceptors.BalancedPool\n : []\n this[kFactory] = factory\n\n for (const upstream of upstreams) {\n this.addUpstream(upstream)\n }\n this._updateBalancedPoolStats()\n }\n\n addUpstream (upstream) {\n const upstreamOrigin = parseOrigin(upstream).origin\n\n if (this[kClients].find((pool) => (\n pool[kUrl].origin === upstreamOrigin &&\n pool.closed !== true &&\n pool.destroyed !== true\n ))) {\n return this\n }\n const pool = this[kFactory](upstreamOrigin, Object.assign({}, this[kOptions]))\n\n this[kAddClient](pool)\n pool.on('connect', () => {\n pool[kWeight] = Math.min(this[kMaxWeightPerServer], pool[kWeight] + this[kErrorPenalty])\n })\n\n pool.on('connectionError', () => {\n pool[kWeight] = Math.max(1, pool[kWeight] - this[kErrorPenalty])\n this._updateBalancedPoolStats()\n })\n\n pool.on('disconnect', (...args) => {\n const err = args[2]\n if (err && err.code === 'UND_ERR_SOCKET') {\n // decrease the weight of the pool.\n pool[kWeight] = Math.max(1, pool[kWeight] - this[kErrorPenalty])\n this._updateBalancedPoolStats()\n }\n })\n\n for (const client of this[kClients]) {\n client[kWeight] = this[kMaxWeightPerServer]\n }\n\n this._updateBalancedPoolStats()\n\n return this\n }\n\n _updateBalancedPoolStats () {\n this[kGreatestCommonDivisor] = this[kClients].map(p => p[kWeight]).reduce(getGreatestCommonDivisor, 0)\n }\n\n removeUpstream (upstream) {\n const upstreamOrigin = parseOrigin(upstream).origin\n\n const pool = this[kClients].find((pool) => (\n pool[kUrl].origin === upstreamOrigin &&\n pool.closed !== true &&\n pool.destroyed !== true\n ))\n\n if (pool) {\n this[kRemoveClient](pool)\n }\n\n return this\n }\n\n get upstreams () {\n return this[kClients]\n .filter(dispatcher => dispatcher.closed !== true && dispatcher.destroyed !== true)\n .map((p) => p[kUrl].origin)\n }\n\n [kGetDispatcher] () {\n // We validate that pools is greater than 0,\n // otherwise we would have to wait until an upstream\n // is added, which might never happen.\n if (this[kClients].length === 0) {\n throw new BalancedPoolMissingUpstreamError()\n }\n\n const dispatcher = this[kClients].find(dispatcher => (\n !dispatcher[kNeedDrain] &&\n dispatcher.closed !== true &&\n dispatcher.destroyed !== true\n ))\n\n if (!dispatcher) {\n return\n }\n\n const allClientsBusy = this[kClients].map(pool => pool[kNeedDrain]).reduce((a, b) => a && b, true)\n\n if (allClientsBusy) {\n return\n }\n\n let counter = 0\n\n let maxWeightIndex = this[kClients].findIndex(pool => !pool[kNeedDrain])\n\n while (counter++ < this[kClients].length) {\n this[kIndex] = (this[kIndex] + 1) % this[kClients].length\n const pool = this[kClients][this[kIndex]]\n\n // find pool index with the largest weight\n if (pool[kWeight] > this[kClients][maxWeightIndex][kWeight] && !pool[kNeedDrain]) {\n maxWeightIndex = this[kIndex]\n }\n\n // decrease the current weight every `this[kClients].length`.\n if (this[kIndex] === 0) {\n // Set the current weight to the next lower weight.\n this[kCurrentWeight] = this[kCurrentWeight] - this[kGreatestCommonDivisor]\n\n if (this[kCurrentWeight] <= 0) {\n this[kCurrentWeight] = this[kMaxWeightPerServer]\n }\n }\n if (pool[kWeight] >= this[kCurrentWeight] && (!pool[kNeedDrain])) {\n return pool\n }\n }\n\n this[kCurrentWeight] = this[kClients][maxWeightIndex][kWeight]\n this[kIndex] = maxWeightIndex\n return this[kClients][maxWeightIndex]\n }\n}\n\nmodule.exports = BalancedPool\n","'use strict'\n\nconst { kConstruct } = require('./symbols')\nconst { urlEquals, fieldValues: getFieldValues } = require('./util')\nconst { kEnumerableProperty, isDisturbed } = require('../core/util')\nconst { kHeadersList } = require('../core/symbols')\nconst { webidl } = require('../fetch/webidl')\nconst { Response, cloneResponse } = require('../fetch/response')\nconst { Request } = require('../fetch/request')\nconst { kState, kHeaders, kGuard, kRealm } = require('../fetch/symbols')\nconst { fetching } = require('../fetch/index')\nconst { urlIsHttpHttpsScheme, createDeferredPromise, readAllBytes } = require('../fetch/util')\nconst assert = require('assert')\nconst { getGlobalDispatcher } = require('../global')\n\n/**\n * @see https://w3c.github.io/ServiceWorker/#dfn-cache-batch-operation\n * @typedef {Object} CacheBatchOperation\n * @property {'delete' | 'put'} type\n * @property {any} request\n * @property {any} response\n * @property {import('../../types/cache').CacheQueryOptions} options\n */\n\n/**\n * @see https://w3c.github.io/ServiceWorker/#dfn-request-response-list\n * @typedef {[any, any][]} requestResponseList\n */\n\nclass Cache {\n /**\n * @see https://w3c.github.io/ServiceWorker/#dfn-relevant-request-response-list\n * @type {requestResponseList}\n */\n #relevantRequestResponseList\n\n constructor () {\n if (arguments[0] !== kConstruct) {\n webidl.illegalConstructor()\n }\n\n this.#relevantRequestResponseList = arguments[1]\n }\n\n async match (request, options = {}) {\n webidl.brandCheck(this, Cache)\n webidl.argumentLengthCheck(arguments, 1, { header: 'Cache.match' })\n\n request = webidl.converters.RequestInfo(request)\n options = webidl.converters.CacheQueryOptions(options)\n\n const p = await this.matchAll(request, options)\n\n if (p.length === 0) {\n return\n }\n\n return p[0]\n }\n\n async matchAll (request = undefined, options = {}) {\n webidl.brandCheck(this, Cache)\n\n if (request !== undefined) request = webidl.converters.RequestInfo(request)\n options = webidl.converters.CacheQueryOptions(options)\n\n // 1.\n let r = null\n\n // 2.\n if (request !== undefined) {\n if (request instanceof Request) {\n // 2.1.1\n r = request[kState]\n\n // 2.1.2\n if (r.method !== 'GET' && !options.ignoreMethod) {\n return []\n }\n } else if (typeof request === 'string') {\n // 2.2.1\n r = new Request(request)[kState]\n }\n }\n\n // 5.\n // 5.1\n const responses = []\n\n // 5.2\n if (request === undefined) {\n // 5.2.1\n for (const requestResponse of this.#relevantRequestResponseList) {\n responses.push(requestResponse[1])\n }\n } else { // 5.3\n // 5.3.1\n const requestResponses = this.#queryCache(r, options)\n\n // 5.3.2\n for (const requestResponse of requestResponses) {\n responses.push(requestResponse[1])\n }\n }\n\n // 5.4\n // We don't implement CORs so we don't need to loop over the responses, yay!\n\n // 5.5.1\n const responseList = []\n\n // 5.5.2\n for (const response of responses) {\n // 5.5.2.1\n const responseObject = new Response(response.body?.source ?? null)\n const body = responseObject[kState].body\n responseObject[kState] = response\n responseObject[kState].body = body\n responseObject[kHeaders][kHeadersList] = response.headersList\n responseObject[kHeaders][kGuard] = 'immutable'\n\n responseList.push(responseObject)\n }\n\n // 6.\n return Object.freeze(responseList)\n }\n\n async add (request) {\n webidl.brandCheck(this, Cache)\n webidl.argumentLengthCheck(arguments, 1, { header: 'Cache.add' })\n\n request = webidl.converters.RequestInfo(request)\n\n // 1.\n const requests = [request]\n\n // 2.\n const responseArrayPromise = this.addAll(requests)\n\n // 3.\n return await responseArrayPromise\n }\n\n async addAll (requests) {\n webidl.brandCheck(this, Cache)\n webidl.argumentLengthCheck(arguments, 1, { header: 'Cache.addAll' })\n\n requests = webidl.converters['sequence'](requests)\n\n // 1.\n const responsePromises = []\n\n // 2.\n const requestList = []\n\n // 3.\n for (const request of requests) {\n if (typeof request === 'string') {\n continue\n }\n\n // 3.1\n const r = request[kState]\n\n // 3.2\n if (!urlIsHttpHttpsScheme(r.url) || r.method !== 'GET') {\n throw webidl.errors.exception({\n header: 'Cache.addAll',\n message: 'Expected http/s scheme when method is not GET.'\n })\n }\n }\n\n // 4.\n /** @type {ReturnType[]} */\n const fetchControllers = []\n\n // 5.\n for (const request of requests) {\n // 5.1\n const r = new Request(request)[kState]\n\n // 5.2\n if (!urlIsHttpHttpsScheme(r.url)) {\n throw webidl.errors.exception({\n header: 'Cache.addAll',\n message: 'Expected http/s scheme.'\n })\n }\n\n // 5.4\n r.initiator = 'fetch'\n r.destination = 'subresource'\n\n // 5.5\n requestList.push(r)\n\n // 5.6\n const responsePromise = createDeferredPromise()\n\n // 5.7\n fetchControllers.push(fetching({\n request: r,\n dispatcher: getGlobalDispatcher(),\n processResponse (response) {\n // 1.\n if (response.type === 'error' || response.status === 206 || response.status < 200 || response.status > 299) {\n responsePromise.reject(webidl.errors.exception({\n header: 'Cache.addAll',\n message: 'Received an invalid status code or the request failed.'\n }))\n } else if (response.headersList.contains('vary')) { // 2.\n // 2.1\n const fieldValues = getFieldValues(response.headersList.get('vary'))\n\n // 2.2\n for (const fieldValue of fieldValues) {\n // 2.2.1\n if (fieldValue === '*') {\n responsePromise.reject(webidl.errors.exception({\n header: 'Cache.addAll',\n message: 'invalid vary field value'\n }))\n\n for (const controller of fetchControllers) {\n controller.abort()\n }\n\n return\n }\n }\n }\n },\n processResponseEndOfBody (response) {\n // 1.\n if (response.aborted) {\n responsePromise.reject(new DOMException('aborted', 'AbortError'))\n return\n }\n\n // 2.\n responsePromise.resolve(response)\n }\n }))\n\n // 5.8\n responsePromises.push(responsePromise.promise)\n }\n\n // 6.\n const p = Promise.all(responsePromises)\n\n // 7.\n const responses = await p\n\n // 7.1\n const operations = []\n\n // 7.2\n let index = 0\n\n // 7.3\n for (const response of responses) {\n // 7.3.1\n /** @type {CacheBatchOperation} */\n const operation = {\n type: 'put', // 7.3.2\n request: requestList[index], // 7.3.3\n response // 7.3.4\n }\n\n operations.push(operation) // 7.3.5\n\n index++ // 7.3.6\n }\n\n // 7.5\n const cacheJobPromise = createDeferredPromise()\n\n // 7.6.1\n let errorData = null\n\n // 7.6.2\n try {\n this.#batchCacheOperations(operations)\n } catch (e) {\n errorData = e\n }\n\n // 7.6.3\n queueMicrotask(() => {\n // 7.6.3.1\n if (errorData === null) {\n cacheJobPromise.resolve(undefined)\n } else {\n // 7.6.3.2\n cacheJobPromise.reject(errorData)\n }\n })\n\n // 7.7\n return cacheJobPromise.promise\n }\n\n async put (request, response) {\n webidl.brandCheck(this, Cache)\n webidl.argumentLengthCheck(arguments, 2, { header: 'Cache.put' })\n\n request = webidl.converters.RequestInfo(request)\n response = webidl.converters.Response(response)\n\n // 1.\n let innerRequest = null\n\n // 2.\n if (request instanceof Request) {\n innerRequest = request[kState]\n } else { // 3.\n innerRequest = new Request(request)[kState]\n }\n\n // 4.\n if (!urlIsHttpHttpsScheme(innerRequest.url) || innerRequest.method !== 'GET') {\n throw webidl.errors.exception({\n header: 'Cache.put',\n message: 'Expected an http/s scheme when method is not GET'\n })\n }\n\n // 5.\n const innerResponse = response[kState]\n\n // 6.\n if (innerResponse.status === 206) {\n throw webidl.errors.exception({\n header: 'Cache.put',\n message: 'Got 206 status'\n })\n }\n\n // 7.\n if (innerResponse.headersList.contains('vary')) {\n // 7.1.\n const fieldValues = getFieldValues(innerResponse.headersList.get('vary'))\n\n // 7.2.\n for (const fieldValue of fieldValues) {\n // 7.2.1\n if (fieldValue === '*') {\n throw webidl.errors.exception({\n header: 'Cache.put',\n message: 'Got * vary field value'\n })\n }\n }\n }\n\n // 8.\n if (innerResponse.body && (isDisturbed(innerResponse.body.stream) || innerResponse.body.stream.locked)) {\n throw webidl.errors.exception({\n header: 'Cache.put',\n message: 'Response body is locked or disturbed'\n })\n }\n\n // 9.\n const clonedResponse = cloneResponse(innerResponse)\n\n // 10.\n const bodyReadPromise = createDeferredPromise()\n\n // 11.\n if (innerResponse.body != null) {\n // 11.1\n const stream = innerResponse.body.stream\n\n // 11.2\n const reader = stream.getReader()\n\n // 11.3\n readAllBytes(reader).then(bodyReadPromise.resolve, bodyReadPromise.reject)\n } else {\n bodyReadPromise.resolve(undefined)\n }\n\n // 12.\n /** @type {CacheBatchOperation[]} */\n const operations = []\n\n // 13.\n /** @type {CacheBatchOperation} */\n const operation = {\n type: 'put', // 14.\n request: innerRequest, // 15.\n response: clonedResponse // 16.\n }\n\n // 17.\n operations.push(operation)\n\n // 19.\n const bytes = await bodyReadPromise.promise\n\n if (clonedResponse.body != null) {\n clonedResponse.body.source = bytes\n }\n\n // 19.1\n const cacheJobPromise = createDeferredPromise()\n\n // 19.2.1\n let errorData = null\n\n // 19.2.2\n try {\n this.#batchCacheOperations(operations)\n } catch (e) {\n errorData = e\n }\n\n // 19.2.3\n queueMicrotask(() => {\n // 19.2.3.1\n if (errorData === null) {\n cacheJobPromise.resolve()\n } else { // 19.2.3.2\n cacheJobPromise.reject(errorData)\n }\n })\n\n return cacheJobPromise.promise\n }\n\n async delete (request, options = {}) {\n webidl.brandCheck(this, Cache)\n webidl.argumentLengthCheck(arguments, 1, { header: 'Cache.delete' })\n\n request = webidl.converters.RequestInfo(request)\n options = webidl.converters.CacheQueryOptions(options)\n\n /**\n * @type {Request}\n */\n let r = null\n\n if (request instanceof Request) {\n r = request[kState]\n\n if (r.method !== 'GET' && !options.ignoreMethod) {\n return false\n }\n } else {\n assert(typeof request === 'string')\n\n r = new Request(request)[kState]\n }\n\n /** @type {CacheBatchOperation[]} */\n const operations = []\n\n /** @type {CacheBatchOperation} */\n const operation = {\n type: 'delete',\n request: r,\n options\n }\n\n operations.push(operation)\n\n const cacheJobPromise = createDeferredPromise()\n\n let errorData = null\n let requestResponses\n\n try {\n requestResponses = this.#batchCacheOperations(operations)\n } catch (e) {\n errorData = e\n }\n\n queueMicrotask(() => {\n if (errorData === null) {\n cacheJobPromise.resolve(!!requestResponses?.length)\n } else {\n cacheJobPromise.reject(errorData)\n }\n })\n\n return cacheJobPromise.promise\n }\n\n /**\n * @see https://w3c.github.io/ServiceWorker/#dom-cache-keys\n * @param {any} request\n * @param {import('../../types/cache').CacheQueryOptions} options\n * @returns {readonly Request[]}\n */\n async keys (request = undefined, options = {}) {\n webidl.brandCheck(this, Cache)\n\n if (request !== undefined) request = webidl.converters.RequestInfo(request)\n options = webidl.converters.CacheQueryOptions(options)\n\n // 1.\n let r = null\n\n // 2.\n if (request !== undefined) {\n // 2.1\n if (request instanceof Request) {\n // 2.1.1\n r = request[kState]\n\n // 2.1.2\n if (r.method !== 'GET' && !options.ignoreMethod) {\n return []\n }\n } else if (typeof request === 'string') { // 2.2\n r = new Request(request)[kState]\n }\n }\n\n // 4.\n const promise = createDeferredPromise()\n\n // 5.\n // 5.1\n const requests = []\n\n // 5.2\n if (request === undefined) {\n // 5.2.1\n for (const requestResponse of this.#relevantRequestResponseList) {\n // 5.2.1.1\n requests.push(requestResponse[0])\n }\n } else { // 5.3\n // 5.3.1\n const requestResponses = this.#queryCache(r, options)\n\n // 5.3.2\n for (const requestResponse of requestResponses) {\n // 5.3.2.1\n requests.push(requestResponse[0])\n }\n }\n\n // 5.4\n queueMicrotask(() => {\n // 5.4.1\n const requestList = []\n\n // 5.4.2\n for (const request of requests) {\n const requestObject = new Request('https://a')\n requestObject[kState] = request\n requestObject[kHeaders][kHeadersList] = request.headersList\n requestObject[kHeaders][kGuard] = 'immutable'\n requestObject[kRealm] = request.client\n\n // 5.4.2.1\n requestList.push(requestObject)\n }\n\n // 5.4.3\n promise.resolve(Object.freeze(requestList))\n })\n\n return promise.promise\n }\n\n /**\n * @see https://w3c.github.io/ServiceWorker/#batch-cache-operations-algorithm\n * @param {CacheBatchOperation[]} operations\n * @returns {requestResponseList}\n */\n #batchCacheOperations (operations) {\n // 1.\n const cache = this.#relevantRequestResponseList\n\n // 2.\n const backupCache = [...cache]\n\n // 3.\n const addedItems = []\n\n // 4.1\n const resultList = []\n\n try {\n // 4.2\n for (const operation of operations) {\n // 4.2.1\n if (operation.type !== 'delete' && operation.type !== 'put') {\n throw webidl.errors.exception({\n header: 'Cache.#batchCacheOperations',\n message: 'operation type does not match \"delete\" or \"put\"'\n })\n }\n\n // 4.2.2\n if (operation.type === 'delete' && operation.response != null) {\n throw webidl.errors.exception({\n header: 'Cache.#batchCacheOperations',\n message: 'delete operation should not have an associated response'\n })\n }\n\n // 4.2.3\n if (this.#queryCache(operation.request, operation.options, addedItems).length) {\n throw new DOMException('???', 'InvalidStateError')\n }\n\n // 4.2.4\n let requestResponses\n\n // 4.2.5\n if (operation.type === 'delete') {\n // 4.2.5.1\n requestResponses = this.#queryCache(operation.request, operation.options)\n\n // TODO: the spec is wrong, this is needed to pass WPTs\n if (requestResponses.length === 0) {\n return []\n }\n\n // 4.2.5.2\n for (const requestResponse of requestResponses) {\n const idx = cache.indexOf(requestResponse)\n assert(idx !== -1)\n\n // 4.2.5.2.1\n cache.splice(idx, 1)\n }\n } else if (operation.type === 'put') { // 4.2.6\n // 4.2.6.1\n if (operation.response == null) {\n throw webidl.errors.exception({\n header: 'Cache.#batchCacheOperations',\n message: 'put operation should have an associated response'\n })\n }\n\n // 4.2.6.2\n const r = operation.request\n\n // 4.2.6.3\n if (!urlIsHttpHttpsScheme(r.url)) {\n throw webidl.errors.exception({\n header: 'Cache.#batchCacheOperations',\n message: 'expected http or https scheme'\n })\n }\n\n // 4.2.6.4\n if (r.method !== 'GET') {\n throw webidl.errors.exception({\n header: 'Cache.#batchCacheOperations',\n message: 'not get method'\n })\n }\n\n // 4.2.6.5\n if (operation.options != null) {\n throw webidl.errors.exception({\n header: 'Cache.#batchCacheOperations',\n message: 'options must not be defined'\n })\n }\n\n // 4.2.6.6\n requestResponses = this.#queryCache(operation.request)\n\n // 4.2.6.7\n for (const requestResponse of requestResponses) {\n const idx = cache.indexOf(requestResponse)\n assert(idx !== -1)\n\n // 4.2.6.7.1\n cache.splice(idx, 1)\n }\n\n // 4.2.6.8\n cache.push([operation.request, operation.response])\n\n // 4.2.6.10\n addedItems.push([operation.request, operation.response])\n }\n\n // 4.2.7\n resultList.push([operation.request, operation.response])\n }\n\n // 4.3\n return resultList\n } catch (e) { // 5.\n // 5.1\n this.#relevantRequestResponseList.length = 0\n\n // 5.2\n this.#relevantRequestResponseList = backupCache\n\n // 5.3\n throw e\n }\n }\n\n /**\n * @see https://w3c.github.io/ServiceWorker/#query-cache\n * @param {any} requestQuery\n * @param {import('../../types/cache').CacheQueryOptions} options\n * @param {requestResponseList} targetStorage\n * @returns {requestResponseList}\n */\n #queryCache (requestQuery, options, targetStorage) {\n /** @type {requestResponseList} */\n const resultList = []\n\n const storage = targetStorage ?? this.#relevantRequestResponseList\n\n for (const requestResponse of storage) {\n const [cachedRequest, cachedResponse] = requestResponse\n if (this.#requestMatchesCachedItem(requestQuery, cachedRequest, cachedResponse, options)) {\n resultList.push(requestResponse)\n }\n }\n\n return resultList\n }\n\n /**\n * @see https://w3c.github.io/ServiceWorker/#request-matches-cached-item-algorithm\n * @param {any} requestQuery\n * @param {any} request\n * @param {any | null} response\n * @param {import('../../types/cache').CacheQueryOptions | undefined} options\n * @returns {boolean}\n */\n #requestMatchesCachedItem (requestQuery, request, response = null, options) {\n // if (options?.ignoreMethod === false && request.method === 'GET') {\n // return false\n // }\n\n const queryURL = new URL(requestQuery.url)\n\n const cachedURL = new URL(request.url)\n\n if (options?.ignoreSearch) {\n cachedURL.search = ''\n\n queryURL.search = ''\n }\n\n if (!urlEquals(queryURL, cachedURL, true)) {\n return false\n }\n\n if (\n response == null ||\n options?.ignoreVary ||\n !response.headersList.contains('vary')\n ) {\n return true\n }\n\n const fieldValues = getFieldValues(response.headersList.get('vary'))\n\n for (const fieldValue of fieldValues) {\n if (fieldValue === '*') {\n return false\n }\n\n const requestValue = request.headersList.get(fieldValue)\n const queryValue = requestQuery.headersList.get(fieldValue)\n\n // If one has the header and the other doesn't, or one has\n // a different value than the other, return false\n if (requestValue !== queryValue) {\n return false\n }\n }\n\n return true\n }\n}\n\nObject.defineProperties(Cache.prototype, {\n [Symbol.toStringTag]: {\n value: 'Cache',\n configurable: true\n },\n match: kEnumerableProperty,\n matchAll: kEnumerableProperty,\n add: kEnumerableProperty,\n addAll: kEnumerableProperty,\n put: kEnumerableProperty,\n delete: kEnumerableProperty,\n keys: kEnumerableProperty\n})\n\nconst cacheQueryOptionConverters = [\n {\n key: 'ignoreSearch',\n converter: webidl.converters.boolean,\n defaultValue: false\n },\n {\n key: 'ignoreMethod',\n converter: webidl.converters.boolean,\n defaultValue: false\n },\n {\n key: 'ignoreVary',\n converter: webidl.converters.boolean,\n defaultValue: false\n }\n]\n\nwebidl.converters.CacheQueryOptions = webidl.dictionaryConverter(cacheQueryOptionConverters)\n\nwebidl.converters.MultiCacheQueryOptions = webidl.dictionaryConverter([\n ...cacheQueryOptionConverters,\n {\n key: 'cacheName',\n converter: webidl.converters.DOMString\n }\n])\n\nwebidl.converters.Response = webidl.interfaceConverter(Response)\n\nwebidl.converters['sequence'] = webidl.sequenceConverter(\n webidl.converters.RequestInfo\n)\n\nmodule.exports = {\n Cache\n}\n","'use strict'\n\nconst { kConstruct } = require('./symbols')\nconst { Cache } = require('./cache')\nconst { webidl } = require('../fetch/webidl')\nconst { kEnumerableProperty } = require('../core/util')\n\nclass CacheStorage {\n /**\n * @see https://w3c.github.io/ServiceWorker/#dfn-relevant-name-to-cache-map\n * @type {Map}\n */\n async has (cacheName) {\n webidl.brandCheck(this, CacheStorage)\n webidl.argumentLengthCheck(arguments, 1, { header: 'CacheStorage.has' })\n\n cacheName = webidl.converters.DOMString(cacheName)\n\n // 2.1.1\n // 2.2\n return this.#caches.has(cacheName)\n }\n\n /**\n * @see https://w3c.github.io/ServiceWorker/#dom-cachestorage-open\n * @param {string} cacheName\n * @returns {Promise}\n */\n async open (cacheName) {\n webidl.brandCheck(this, CacheStorage)\n webidl.argumentLengthCheck(arguments, 1, { header: 'CacheStorage.open' })\n\n cacheName = webidl.converters.DOMString(cacheName)\n\n // 2.1\n if (this.#caches.has(cacheName)) {\n // await caches.open('v1') !== await caches.open('v1')\n\n // 2.1.1\n const cache = this.#caches.get(cacheName)\n\n // 2.1.1.1\n return new Cache(kConstruct, cache)\n }\n\n // 2.2\n const cache = []\n\n // 2.3\n this.#caches.set(cacheName, cache)\n\n // 2.4\n return new Cache(kConstruct, cache)\n }\n\n /**\n * @see https://w3c.github.io/ServiceWorker/#cache-storage-delete\n * @param {string} cacheName\n * @returns {Promise}\n */\n async delete (cacheName) {\n webidl.brandCheck(this, CacheStorage)\n webidl.argumentLengthCheck(arguments, 1, { header: 'CacheStorage.delete' })\n\n cacheName = webidl.converters.DOMString(cacheName)\n\n return this.#caches.delete(cacheName)\n }\n\n /**\n * @see https://w3c.github.io/ServiceWorker/#cache-storage-keys\n * @returns {string[]}\n */\n async keys () {\n webidl.brandCheck(this, CacheStorage)\n\n // 2.1\n const keys = this.#caches.keys()\n\n // 2.2\n return [...keys]\n }\n}\n\nObject.defineProperties(CacheStorage.prototype, {\n [Symbol.toStringTag]: {\n value: 'CacheStorage',\n configurable: true\n },\n match: kEnumerableProperty,\n has: kEnumerableProperty,\n open: kEnumerableProperty,\n delete: kEnumerableProperty,\n keys: kEnumerableProperty\n})\n\nmodule.exports = {\n CacheStorage\n}\n","'use strict'\n\nmodule.exports = {\n kConstruct: require('../core/symbols').kConstruct\n}\n","'use strict'\n\nconst assert = require('assert')\nconst { URLSerializer } = require('../fetch/dataURL')\nconst { isValidHeaderName } = require('../fetch/util')\n\n/**\n * @see https://url.spec.whatwg.org/#concept-url-equals\n * @param {URL} A\n * @param {URL} B\n * @param {boolean | undefined} excludeFragment\n * @returns {boolean}\n */\nfunction urlEquals (A, B, excludeFragment = false) {\n const serializedA = URLSerializer(A, excludeFragment)\n\n const serializedB = URLSerializer(B, excludeFragment)\n\n return serializedA === serializedB\n}\n\n/**\n * @see https://github.com/chromium/chromium/blob/694d20d134cb553d8d89e5500b9148012b1ba299/content/browser/cache_storage/cache_storage_cache.cc#L260-L262\n * @param {string} header\n */\nfunction fieldValues (header) {\n assert(header !== null)\n\n const values = []\n\n for (let value of header.split(',')) {\n value = value.trim()\n\n if (!value.length) {\n continue\n } else if (!isValidHeaderName(value)) {\n continue\n }\n\n values.push(value)\n }\n\n return values\n}\n\nmodule.exports = {\n urlEquals,\n fieldValues\n}\n","// @ts-check\n\n'use strict'\n\n/* global WebAssembly */\n\nconst assert = require('assert')\nconst net = require('net')\nconst http = require('http')\nconst { pipeline } = require('stream')\nconst util = require('./core/util')\nconst timers = require('./timers')\nconst Request = require('./core/request')\nconst DispatcherBase = require('./dispatcher-base')\nconst {\n RequestContentLengthMismatchError,\n ResponseContentLengthMismatchError,\n InvalidArgumentError,\n RequestAbortedError,\n HeadersTimeoutError,\n HeadersOverflowError,\n SocketError,\n InformationalError,\n BodyTimeoutError,\n HTTPParserError,\n ResponseExceededMaxSizeError,\n ClientDestroyedError\n} = require('./core/errors')\nconst buildConnector = require('./core/connect')\nconst {\n kUrl,\n kReset,\n kServerName,\n kClient,\n kBusy,\n kParser,\n kConnect,\n kBlocking,\n kResuming,\n kRunning,\n kPending,\n kSize,\n kWriting,\n kQueue,\n kConnected,\n kConnecting,\n kNeedDrain,\n kNoRef,\n kKeepAliveDefaultTimeout,\n kHostHeader,\n kPendingIdx,\n kRunningIdx,\n kError,\n kPipelining,\n kSocket,\n kKeepAliveTimeoutValue,\n kMaxHeadersSize,\n kKeepAliveMaxTimeout,\n kKeepAliveTimeoutThreshold,\n kHeadersTimeout,\n kBodyTimeout,\n kStrictContentLength,\n kConnector,\n kMaxRedirections,\n kMaxRequests,\n kCounter,\n kClose,\n kDestroy,\n kDispatch,\n kInterceptors,\n kLocalAddress,\n kMaxResponseSize,\n kHTTPConnVersion,\n // HTTP2\n kHost,\n kHTTP2Session,\n kHTTP2SessionState,\n kHTTP2BuildRequest,\n kHTTP2CopyHeaders,\n kHTTP1BuildRequest\n} = require('./core/symbols')\n\n/** @type {import('http2')} */\nlet http2\ntry {\n http2 = require('http2')\n} catch {\n // @ts-ignore\n http2 = { constants: {} }\n}\n\nconst {\n constants: {\n HTTP2_HEADER_AUTHORITY,\n HTTP2_HEADER_METHOD,\n HTTP2_HEADER_PATH,\n HTTP2_HEADER_SCHEME,\n HTTP2_HEADER_CONTENT_LENGTH,\n HTTP2_HEADER_EXPECT,\n HTTP2_HEADER_STATUS\n }\n} = http2\n\n// Experimental\nlet h2ExperimentalWarned = false\n\nconst FastBuffer = Buffer[Symbol.species]\n\nconst kClosedResolve = Symbol('kClosedResolve')\n\nconst channels = {}\n\ntry {\n const diagnosticsChannel = require('diagnostics_channel')\n channels.sendHeaders = diagnosticsChannel.channel('undici:client:sendHeaders')\n channels.beforeConnect = diagnosticsChannel.channel('undici:client:beforeConnect')\n channels.connectError = diagnosticsChannel.channel('undici:client:connectError')\n channels.connected = diagnosticsChannel.channel('undici:client:connected')\n} catch {\n channels.sendHeaders = { hasSubscribers: false }\n channels.beforeConnect = { hasSubscribers: false }\n channels.connectError = { hasSubscribers: false }\n channels.connected = { hasSubscribers: false }\n}\n\n/**\n * @type {import('../types/client').default}\n */\nclass Client extends DispatcherBase {\n /**\n *\n * @param {string|URL} url\n * @param {import('../types/client').Client.Options} options\n */\n constructor (url, {\n interceptors,\n maxHeaderSize,\n headersTimeout,\n socketTimeout,\n requestTimeout,\n connectTimeout,\n bodyTimeout,\n idleTimeout,\n keepAlive,\n keepAliveTimeout,\n maxKeepAliveTimeout,\n keepAliveMaxTimeout,\n keepAliveTimeoutThreshold,\n socketPath,\n pipelining,\n tls,\n strictContentLength,\n maxCachedSessions,\n maxRedirections,\n connect,\n maxRequestsPerClient,\n localAddress,\n maxResponseSize,\n autoSelectFamily,\n autoSelectFamilyAttemptTimeout,\n // h2\n allowH2,\n maxConcurrentStreams\n } = {}) {\n super()\n\n if (keepAlive !== undefined) {\n throw new InvalidArgumentError('unsupported keepAlive, use pipelining=0 instead')\n }\n\n if (socketTimeout !== undefined) {\n throw new InvalidArgumentError('unsupported socketTimeout, use headersTimeout & bodyTimeout instead')\n }\n\n if (requestTimeout !== undefined) {\n throw new InvalidArgumentError('unsupported requestTimeout, use headersTimeout & bodyTimeout instead')\n }\n\n if (idleTimeout !== undefined) {\n throw new InvalidArgumentError('unsupported idleTimeout, use keepAliveTimeout instead')\n }\n\n if (maxKeepAliveTimeout !== undefined) {\n throw new InvalidArgumentError('unsupported maxKeepAliveTimeout, use keepAliveMaxTimeout instead')\n }\n\n if (maxHeaderSize != null && !Number.isFinite(maxHeaderSize)) {\n throw new InvalidArgumentError('invalid maxHeaderSize')\n }\n\n if (socketPath != null && typeof socketPath !== 'string') {\n throw new InvalidArgumentError('invalid socketPath')\n }\n\n if (connectTimeout != null && (!Number.isFinite(connectTimeout) || connectTimeout < 0)) {\n throw new InvalidArgumentError('invalid connectTimeout')\n }\n\n if (keepAliveTimeout != null && (!Number.isFinite(keepAliveTimeout) || keepAliveTimeout <= 0)) {\n throw new InvalidArgumentError('invalid keepAliveTimeout')\n }\n\n if (keepAliveMaxTimeout != null && (!Number.isFinite(keepAliveMaxTimeout) || keepAliveMaxTimeout <= 0)) {\n throw new InvalidArgumentError('invalid keepAliveMaxTimeout')\n }\n\n if (keepAliveTimeoutThreshold != null && !Number.isFinite(keepAliveTimeoutThreshold)) {\n throw new InvalidArgumentError('invalid keepAliveTimeoutThreshold')\n }\n\n if (headersTimeout != null && (!Number.isInteger(headersTimeout) || headersTimeout < 0)) {\n throw new InvalidArgumentError('headersTimeout must be a positive integer or zero')\n }\n\n if (bodyTimeout != null && (!Number.isInteger(bodyTimeout) || bodyTimeout < 0)) {\n throw new InvalidArgumentError('bodyTimeout must be a positive integer or zero')\n }\n\n if (connect != null && typeof connect !== 'function' && typeof connect !== 'object') {\n throw new InvalidArgumentError('connect must be a function or an object')\n }\n\n if (maxRedirections != null && (!Number.isInteger(maxRedirections) || maxRedirections < 0)) {\n throw new InvalidArgumentError('maxRedirections must be a positive number')\n }\n\n if (maxRequestsPerClient != null && (!Number.isInteger(maxRequestsPerClient) || maxRequestsPerClient < 0)) {\n throw new InvalidArgumentError('maxRequestsPerClient must be a positive number')\n }\n\n if (localAddress != null && (typeof localAddress !== 'string' || net.isIP(localAddress) === 0)) {\n throw new InvalidArgumentError('localAddress must be valid string IP address')\n }\n\n if (maxResponseSize != null && (!Number.isInteger(maxResponseSize) || maxResponseSize < -1)) {\n throw new InvalidArgumentError('maxResponseSize must be a positive number')\n }\n\n if (\n autoSelectFamilyAttemptTimeout != null &&\n (!Number.isInteger(autoSelectFamilyAttemptTimeout) || autoSelectFamilyAttemptTimeout < -1)\n ) {\n throw new InvalidArgumentError('autoSelectFamilyAttemptTimeout must be a positive number')\n }\n\n // h2\n if (allowH2 != null && typeof allowH2 !== 'boolean') {\n throw new InvalidArgumentError('allowH2 must be a valid boolean value')\n }\n\n if (maxConcurrentStreams != null && (typeof maxConcurrentStreams !== 'number' || maxConcurrentStreams < 1)) {\n throw new InvalidArgumentError('maxConcurrentStreams must be a possitive integer, greater than 0')\n }\n\n if (typeof connect !== 'function') {\n connect = buildConnector({\n ...tls,\n maxCachedSessions,\n allowH2,\n socketPath,\n timeout: connectTimeout,\n ...(util.nodeHasAutoSelectFamily && autoSelectFamily ? { autoSelectFamily, autoSelectFamilyAttemptTimeout } : undefined),\n ...connect\n })\n }\n\n this[kInterceptors] = interceptors && interceptors.Client && Array.isArray(interceptors.Client)\n ? interceptors.Client\n : [createRedirectInterceptor({ maxRedirections })]\n this[kUrl] = util.parseOrigin(url)\n this[kConnector] = connect\n this[kSocket] = null\n this[kPipelining] = pipelining != null ? pipelining : 1\n this[kMaxHeadersSize] = maxHeaderSize || http.maxHeaderSize\n this[kKeepAliveDefaultTimeout] = keepAliveTimeout == null ? 4e3 : keepAliveTimeout\n this[kKeepAliveMaxTimeout] = keepAliveMaxTimeout == null ? 600e3 : keepAliveMaxTimeout\n this[kKeepAliveTimeoutThreshold] = keepAliveTimeoutThreshold == null ? 1e3 : keepAliveTimeoutThreshold\n this[kKeepAliveTimeoutValue] = this[kKeepAliveDefaultTimeout]\n this[kServerName] = null\n this[kLocalAddress] = localAddress != null ? localAddress : null\n this[kResuming] = 0 // 0, idle, 1, scheduled, 2 resuming\n this[kNeedDrain] = 0 // 0, idle, 1, scheduled, 2 resuming\n this[kHostHeader] = `host: ${this[kUrl].hostname}${this[kUrl].port ? `:${this[kUrl].port}` : ''}\\r\\n`\n this[kBodyTimeout] = bodyTimeout != null ? bodyTimeout : 300e3\n this[kHeadersTimeout] = headersTimeout != null ? headersTimeout : 300e3\n this[kStrictContentLength] = strictContentLength == null ? true : strictContentLength\n this[kMaxRedirections] = maxRedirections\n this[kMaxRequests] = maxRequestsPerClient\n this[kClosedResolve] = null\n this[kMaxResponseSize] = maxResponseSize > -1 ? maxResponseSize : -1\n this[kHTTPConnVersion] = 'h1'\n\n // HTTP/2\n this[kHTTP2Session] = null\n this[kHTTP2SessionState] = !allowH2\n ? null\n : {\n // streams: null, // Fixed queue of streams - For future support of `push`\n openStreams: 0, // Keep track of them to decide wether or not unref the session\n maxConcurrentStreams: maxConcurrentStreams != null ? maxConcurrentStreams : 100 // Max peerConcurrentStreams for a Node h2 server\n }\n this[kHost] = `${this[kUrl].hostname}${this[kUrl].port ? `:${this[kUrl].port}` : ''}`\n\n // kQueue is built up of 3 sections separated by\n // the kRunningIdx and kPendingIdx indices.\n // | complete | running | pending |\n // ^ kRunningIdx ^ kPendingIdx ^ kQueue.length\n // kRunningIdx points to the first running element.\n // kPendingIdx points to the first pending element.\n // This implements a fast queue with an amortized\n // time of O(1).\n\n this[kQueue] = []\n this[kRunningIdx] = 0\n this[kPendingIdx] = 0\n }\n\n get pipelining () {\n return this[kPipelining]\n }\n\n set pipelining (value) {\n this[kPipelining] = value\n resume(this, true)\n }\n\n get [kPending] () {\n return this[kQueue].length - this[kPendingIdx]\n }\n\n get [kRunning] () {\n return this[kPendingIdx] - this[kRunningIdx]\n }\n\n get [kSize] () {\n return this[kQueue].length - this[kRunningIdx]\n }\n\n get [kConnected] () {\n return !!this[kSocket] && !this[kConnecting] && !this[kSocket].destroyed\n }\n\n get [kBusy] () {\n const socket = this[kSocket]\n return (\n (socket && (socket[kReset] || socket[kWriting] || socket[kBlocking])) ||\n (this[kSize] >= (this[kPipelining] || 1)) ||\n this[kPending] > 0\n )\n }\n\n /* istanbul ignore: only used for test */\n [kConnect] (cb) {\n connect(this)\n this.once('connect', cb)\n }\n\n [kDispatch] (opts, handler) {\n const origin = opts.origin || this[kUrl].origin\n\n const request = this[kHTTPConnVersion] === 'h2'\n ? Request[kHTTP2BuildRequest](origin, opts, handler)\n : Request[kHTTP1BuildRequest](origin, opts, handler)\n\n this[kQueue].push(request)\n if (this[kResuming]) {\n // Do nothing.\n } else if (util.bodyLength(request.body) == null && util.isIterable(request.body)) {\n // Wait a tick in case stream/iterator is ended in the same tick.\n this[kResuming] = 1\n process.nextTick(resume, this)\n } else {\n resume(this, true)\n }\n\n if (this[kResuming] && this[kNeedDrain] !== 2 && this[kBusy]) {\n this[kNeedDrain] = 2\n }\n\n return this[kNeedDrain] < 2\n }\n\n async [kClose] () {\n // TODO: for H2 we need to gracefully flush the remaining enqueued\n // request and close each stream.\n return new Promise((resolve) => {\n if (!this[kSize]) {\n resolve(null)\n } else {\n this[kClosedResolve] = resolve\n }\n })\n }\n\n async [kDestroy] (err) {\n return new Promise((resolve) => {\n const requests = this[kQueue].splice(this[kPendingIdx])\n for (let i = 0; i < requests.length; i++) {\n const request = requests[i]\n errorRequest(this, request, err)\n }\n\n const callback = () => {\n if (this[kClosedResolve]) {\n // TODO (fix): Should we error here with ClientDestroyedError?\n this[kClosedResolve]()\n this[kClosedResolve] = null\n }\n resolve()\n }\n\n if (this[kHTTP2Session] != null) {\n util.destroy(this[kHTTP2Session], err)\n this[kHTTP2Session] = null\n this[kHTTP2SessionState] = null\n }\n\n if (!this[kSocket]) {\n queueMicrotask(callback)\n } else {\n util.destroy(this[kSocket].on('close', callback), err)\n }\n\n resume(this)\n })\n }\n}\n\nfunction onHttp2SessionError (err) {\n assert(err.code !== 'ERR_TLS_CERT_ALTNAME_INVALID')\n\n this[kSocket][kError] = err\n\n onError(this[kClient], err)\n}\n\nfunction onHttp2FrameError (type, code, id) {\n const err = new InformationalError(`HTTP/2: \"frameError\" received - type ${type}, code ${code}`)\n\n if (id === 0) {\n this[kSocket][kError] = err\n onError(this[kClient], err)\n }\n}\n\nfunction onHttp2SessionEnd () {\n util.destroy(this, new SocketError('other side closed'))\n util.destroy(this[kSocket], new SocketError('other side closed'))\n}\n\nfunction onHTTP2GoAway (code) {\n const client = this[kClient]\n const err = new InformationalError(`HTTP/2: \"GOAWAY\" frame received with code ${code}`)\n client[kSocket] = null\n client[kHTTP2Session] = null\n\n if (client.destroyed) {\n assert(this[kPending] === 0)\n\n // Fail entire queue.\n const requests = client[kQueue].splice(client[kRunningIdx])\n for (let i = 0; i < requests.length; i++) {\n const request = requests[i]\n errorRequest(this, request, err)\n }\n } else if (client[kRunning] > 0) {\n // Fail head of pipeline.\n const request = client[kQueue][client[kRunningIdx]]\n client[kQueue][client[kRunningIdx]++] = null\n\n errorRequest(client, request, err)\n }\n\n client[kPendingIdx] = client[kRunningIdx]\n\n assert(client[kRunning] === 0)\n\n client.emit('disconnect',\n client[kUrl],\n [client],\n err\n )\n\n resume(client)\n}\n\nconst constants = require('./llhttp/constants')\nconst createRedirectInterceptor = require('./interceptor/redirectInterceptor')\nconst EMPTY_BUF = Buffer.alloc(0)\n\nasync function lazyllhttp () {\n const llhttpWasmData = process.env.JEST_WORKER_ID ? require('./llhttp/llhttp-wasm.js') : undefined\n\n let mod\n try {\n mod = await WebAssembly.compile(Buffer.from(require('./llhttp/llhttp_simd-wasm.js'), 'base64'))\n } catch (e) {\n /* istanbul ignore next */\n\n // We could check if the error was caused by the simd option not\n // being enabled, but the occurring of this other error\n // * https://github.com/emscripten-core/emscripten/issues/11495\n // got me to remove that check to avoid breaking Node 12.\n mod = await WebAssembly.compile(Buffer.from(llhttpWasmData || require('./llhttp/llhttp-wasm.js'), 'base64'))\n }\n\n return await WebAssembly.instantiate(mod, {\n env: {\n /* eslint-disable camelcase */\n\n wasm_on_url: (p, at, len) => {\n /* istanbul ignore next */\n return 0\n },\n wasm_on_status: (p, at, len) => {\n assert.strictEqual(currentParser.ptr, p)\n const start = at - currentBufferPtr + currentBufferRef.byteOffset\n return currentParser.onStatus(new FastBuffer(currentBufferRef.buffer, start, len)) || 0\n },\n wasm_on_message_begin: (p) => {\n assert.strictEqual(currentParser.ptr, p)\n return currentParser.onMessageBegin() || 0\n },\n wasm_on_header_field: (p, at, len) => {\n assert.strictEqual(currentParser.ptr, p)\n const start = at - currentBufferPtr + currentBufferRef.byteOffset\n return currentParser.onHeaderField(new FastBuffer(currentBufferRef.buffer, start, len)) || 0\n },\n wasm_on_header_value: (p, at, len) => {\n assert.strictEqual(currentParser.ptr, p)\n const start = at - currentBufferPtr + currentBufferRef.byteOffset\n return currentParser.onHeaderValue(new FastBuffer(currentBufferRef.buffer, start, len)) || 0\n },\n wasm_on_headers_complete: (p, statusCode, upgrade, shouldKeepAlive) => {\n assert.strictEqual(currentParser.ptr, p)\n return currentParser.onHeadersComplete(statusCode, Boolean(upgrade), Boolean(shouldKeepAlive)) || 0\n },\n wasm_on_body: (p, at, len) => {\n assert.strictEqual(currentParser.ptr, p)\n const start = at - currentBufferPtr + currentBufferRef.byteOffset\n return currentParser.onBody(new FastBuffer(currentBufferRef.buffer, start, len)) || 0\n },\n wasm_on_message_complete: (p) => {\n assert.strictEqual(currentParser.ptr, p)\n return currentParser.onMessageComplete() || 0\n }\n\n /* eslint-enable camelcase */\n }\n })\n}\n\nlet llhttpInstance = null\nlet llhttpPromise = lazyllhttp()\nllhttpPromise.catch()\n\nlet currentParser = null\nlet currentBufferRef = null\nlet currentBufferSize = 0\nlet currentBufferPtr = null\n\nconst TIMEOUT_HEADERS = 1\nconst TIMEOUT_BODY = 2\nconst TIMEOUT_IDLE = 3\n\nclass Parser {\n constructor (client, socket, { exports }) {\n assert(Number.isFinite(client[kMaxHeadersSize]) && client[kMaxHeadersSize] > 0)\n\n this.llhttp = exports\n this.ptr = this.llhttp.llhttp_alloc(constants.TYPE.RESPONSE)\n this.client = client\n this.socket = socket\n this.timeout = null\n this.timeoutValue = null\n this.timeoutType = null\n this.statusCode = null\n this.statusText = ''\n this.upgrade = false\n this.headers = []\n this.headersSize = 0\n this.headersMaxSize = client[kMaxHeadersSize]\n this.shouldKeepAlive = false\n this.paused = false\n this.resume = this.resume.bind(this)\n\n this.bytesRead = 0\n\n this.keepAlive = ''\n this.contentLength = ''\n this.connection = ''\n this.maxResponseSize = client[kMaxResponseSize]\n }\n\n setTimeout (value, type) {\n this.timeoutType = type\n if (value !== this.timeoutValue) {\n timers.clearTimeout(this.timeout)\n if (value) {\n this.timeout = timers.setTimeout(onParserTimeout, value, this)\n // istanbul ignore else: only for jest\n if (this.timeout.unref) {\n this.timeout.unref()\n }\n } else {\n this.timeout = null\n }\n this.timeoutValue = value\n } else if (this.timeout) {\n // istanbul ignore else: only for jest\n if (this.timeout.refresh) {\n this.timeout.refresh()\n }\n }\n }\n\n resume () {\n if (this.socket.destroyed || !this.paused) {\n return\n }\n\n assert(this.ptr != null)\n assert(currentParser == null)\n\n this.llhttp.llhttp_resume(this.ptr)\n\n assert(this.timeoutType === TIMEOUT_BODY)\n if (this.timeout) {\n // istanbul ignore else: only for jest\n if (this.timeout.refresh) {\n this.timeout.refresh()\n }\n }\n\n this.paused = false\n this.execute(this.socket.read() || EMPTY_BUF) // Flush parser.\n this.readMore()\n }\n\n readMore () {\n while (!this.paused && this.ptr) {\n const chunk = this.socket.read()\n if (chunk === null) {\n break\n }\n this.execute(chunk)\n }\n }\n\n execute (data) {\n assert(this.ptr != null)\n assert(currentParser == null)\n assert(!this.paused)\n\n const { socket, llhttp } = this\n\n if (data.length > currentBufferSize) {\n if (currentBufferPtr) {\n llhttp.free(currentBufferPtr)\n }\n currentBufferSize = Math.ceil(data.length / 4096) * 4096\n currentBufferPtr = llhttp.malloc(currentBufferSize)\n }\n\n new Uint8Array(llhttp.memory.buffer, currentBufferPtr, currentBufferSize).set(data)\n\n // Call `execute` on the wasm parser.\n // We pass the `llhttp_parser` pointer address, the pointer address of buffer view data,\n // and finally the length of bytes to parse.\n // The return value is an error code or `constants.ERROR.OK`.\n try {\n let ret\n\n try {\n currentBufferRef = data\n currentParser = this\n ret = llhttp.llhttp_execute(this.ptr, currentBufferPtr, data.length)\n /* eslint-disable-next-line no-useless-catch */\n } catch (err) {\n /* istanbul ignore next: difficult to make a test case for */\n throw err\n } finally {\n currentParser = null\n currentBufferRef = null\n }\n\n const offset = llhttp.llhttp_get_error_pos(this.ptr) - currentBufferPtr\n\n if (ret === constants.ERROR.PAUSED_UPGRADE) {\n this.onUpgrade(data.slice(offset))\n } else if (ret === constants.ERROR.PAUSED) {\n this.paused = true\n socket.unshift(data.slice(offset))\n } else if (ret !== constants.ERROR.OK) {\n const ptr = llhttp.llhttp_get_error_reason(this.ptr)\n let message = ''\n /* istanbul ignore else: difficult to make a test case for */\n if (ptr) {\n const len = new Uint8Array(llhttp.memory.buffer, ptr).indexOf(0)\n message =\n 'Response does not match the HTTP/1.1 protocol (' +\n Buffer.from(llhttp.memory.buffer, ptr, len).toString() +\n ')'\n }\n throw new HTTPParserError(message, constants.ERROR[ret], data.slice(offset))\n }\n } catch (err) {\n util.destroy(socket, err)\n }\n }\n\n destroy () {\n assert(this.ptr != null)\n assert(currentParser == null)\n\n this.llhttp.llhttp_free(this.ptr)\n this.ptr = null\n\n timers.clearTimeout(this.timeout)\n this.timeout = null\n this.timeoutValue = null\n this.timeoutType = null\n\n this.paused = false\n }\n\n onStatus (buf) {\n this.statusText = buf.toString()\n }\n\n onMessageBegin () {\n const { socket, client } = this\n\n /* istanbul ignore next: difficult to make a test case for */\n if (socket.destroyed) {\n return -1\n }\n\n const request = client[kQueue][client[kRunningIdx]]\n if (!request) {\n return -1\n }\n }\n\n onHeaderField (buf) {\n const len = this.headers.length\n\n if ((len & 1) === 0) {\n this.headers.push(buf)\n } else {\n this.headers[len - 1] = Buffer.concat([this.headers[len - 1], buf])\n }\n\n this.trackHeader(buf.length)\n }\n\n onHeaderValue (buf) {\n let len = this.headers.length\n\n if ((len & 1) === 1) {\n this.headers.push(buf)\n len += 1\n } else {\n this.headers[len - 1] = Buffer.concat([this.headers[len - 1], buf])\n }\n\n const key = this.headers[len - 2]\n if (key.length === 10 && key.toString().toLowerCase() === 'keep-alive') {\n this.keepAlive += buf.toString()\n } else if (key.length === 10 && key.toString().toLowerCase() === 'connection') {\n this.connection += buf.toString()\n } else if (key.length === 14 && key.toString().toLowerCase() === 'content-length') {\n this.contentLength += buf.toString()\n }\n\n this.trackHeader(buf.length)\n }\n\n trackHeader (len) {\n this.headersSize += len\n if (this.headersSize >= this.headersMaxSize) {\n util.destroy(this.socket, new HeadersOverflowError())\n }\n }\n\n onUpgrade (head) {\n const { upgrade, client, socket, headers, statusCode } = this\n\n assert(upgrade)\n\n const request = client[kQueue][client[kRunningIdx]]\n assert(request)\n\n assert(!socket.destroyed)\n assert(socket === client[kSocket])\n assert(!this.paused)\n assert(request.upgrade || request.method === 'CONNECT')\n\n this.statusCode = null\n this.statusText = ''\n this.shouldKeepAlive = null\n\n assert(this.headers.length % 2 === 0)\n this.headers = []\n this.headersSize = 0\n\n socket.unshift(head)\n\n socket[kParser].destroy()\n socket[kParser] = null\n\n socket[kClient] = null\n socket[kError] = null\n socket\n .removeListener('error', onSocketError)\n .removeListener('readable', onSocketReadable)\n .removeListener('end', onSocketEnd)\n .removeListener('close', onSocketClose)\n\n client[kSocket] = null\n client[kQueue][client[kRunningIdx]++] = null\n client.emit('disconnect', client[kUrl], [client], new InformationalError('upgrade'))\n\n try {\n request.onUpgrade(statusCode, headers, socket)\n } catch (err) {\n util.destroy(socket, err)\n }\n\n resume(client)\n }\n\n onHeadersComplete (statusCode, upgrade, shouldKeepAlive) {\n const { client, socket, headers, statusText } = this\n\n /* istanbul ignore next: difficult to make a test case for */\n if (socket.destroyed) {\n return -1\n }\n\n const request = client[kQueue][client[kRunningIdx]]\n\n /* istanbul ignore next: difficult to make a test case for */\n if (!request) {\n return -1\n }\n\n assert(!this.upgrade)\n assert(this.statusCode < 200)\n\n if (statusCode === 100) {\n util.destroy(socket, new SocketError('bad response', util.getSocketInfo(socket)))\n return -1\n }\n\n /* this can only happen if server is misbehaving */\n if (upgrade && !request.upgrade) {\n util.destroy(socket, new SocketError('bad upgrade', util.getSocketInfo(socket)))\n return -1\n }\n\n assert.strictEqual(this.timeoutType, TIMEOUT_HEADERS)\n\n this.statusCode = statusCode\n this.shouldKeepAlive = (\n shouldKeepAlive ||\n // Override llhttp value which does not allow keepAlive for HEAD.\n (request.method === 'HEAD' && !socket[kReset] && this.connection.toLowerCase() === 'keep-alive')\n )\n\n if (this.statusCode >= 200) {\n const bodyTimeout = request.bodyTimeout != null\n ? request.bodyTimeout\n : client[kBodyTimeout]\n this.setTimeout(bodyTimeout, TIMEOUT_BODY)\n } else if (this.timeout) {\n // istanbul ignore else: only for jest\n if (this.timeout.refresh) {\n this.timeout.refresh()\n }\n }\n\n if (request.method === 'CONNECT') {\n assert(client[kRunning] === 1)\n this.upgrade = true\n return 2\n }\n\n if (upgrade) {\n assert(client[kRunning] === 1)\n this.upgrade = true\n return 2\n }\n\n assert(this.headers.length % 2 === 0)\n this.headers = []\n this.headersSize = 0\n\n if (this.shouldKeepAlive && client[kPipelining]) {\n const keepAliveTimeout = this.keepAlive ? util.parseKeepAliveTimeout(this.keepAlive) : null\n\n if (keepAliveTimeout != null) {\n const timeout = Math.min(\n keepAliveTimeout - client[kKeepAliveTimeoutThreshold],\n client[kKeepAliveMaxTimeout]\n )\n if (timeout <= 0) {\n socket[kReset] = true\n } else {\n client[kKeepAliveTimeoutValue] = timeout\n }\n } else {\n client[kKeepAliveTimeoutValue] = client[kKeepAliveDefaultTimeout]\n }\n } else {\n // Stop more requests from being dispatched.\n socket[kReset] = true\n }\n\n const pause = request.onHeaders(statusCode, headers, this.resume, statusText) === false\n\n if (request.aborted) {\n return -1\n }\n\n if (request.method === 'HEAD') {\n return 1\n }\n\n if (statusCode < 200) {\n return 1\n }\n\n if (socket[kBlocking]) {\n socket[kBlocking] = false\n resume(client)\n }\n\n return pause ? constants.ERROR.PAUSED : 0\n }\n\n onBody (buf) {\n const { client, socket, statusCode, maxResponseSize } = this\n\n if (socket.destroyed) {\n return -1\n }\n\n const request = client[kQueue][client[kRunningIdx]]\n assert(request)\n\n assert.strictEqual(this.timeoutType, TIMEOUT_BODY)\n if (this.timeout) {\n // istanbul ignore else: only for jest\n if (this.timeout.refresh) {\n this.timeout.refresh()\n }\n }\n\n assert(statusCode >= 200)\n\n if (maxResponseSize > -1 && this.bytesRead + buf.length > maxResponseSize) {\n util.destroy(socket, new ResponseExceededMaxSizeError())\n return -1\n }\n\n this.bytesRead += buf.length\n\n if (request.onData(buf) === false) {\n return constants.ERROR.PAUSED\n }\n }\n\n onMessageComplete () {\n const { client, socket, statusCode, upgrade, headers, contentLength, bytesRead, shouldKeepAlive } = this\n\n if (socket.destroyed && (!statusCode || shouldKeepAlive)) {\n return -1\n }\n\n if (upgrade) {\n return\n }\n\n const request = client[kQueue][client[kRunningIdx]]\n assert(request)\n\n assert(statusCode >= 100)\n\n this.statusCode = null\n this.statusText = ''\n this.bytesRead = 0\n this.contentLength = ''\n this.keepAlive = ''\n this.connection = ''\n\n assert(this.headers.length % 2 === 0)\n this.headers = []\n this.headersSize = 0\n\n if (statusCode < 200) {\n return\n }\n\n /* istanbul ignore next: should be handled by llhttp? */\n if (request.method !== 'HEAD' && contentLength && bytesRead !== parseInt(contentLength, 10)) {\n util.destroy(socket, new ResponseContentLengthMismatchError())\n return -1\n }\n\n request.onComplete(headers)\n\n client[kQueue][client[kRunningIdx]++] = null\n\n if (socket[kWriting]) {\n assert.strictEqual(client[kRunning], 0)\n // Response completed before request.\n util.destroy(socket, new InformationalError('reset'))\n return constants.ERROR.PAUSED\n } else if (!shouldKeepAlive) {\n util.destroy(socket, new InformationalError('reset'))\n return constants.ERROR.PAUSED\n } else if (socket[kReset] && client[kRunning] === 0) {\n // Destroy socket once all requests have completed.\n // The request at the tail of the pipeline is the one\n // that requested reset and no further requests should\n // have been queued since then.\n util.destroy(socket, new InformationalError('reset'))\n return constants.ERROR.PAUSED\n } else if (client[kPipelining] === 1) {\n // We must wait a full event loop cycle to reuse this socket to make sure\n // that non-spec compliant servers are not closing the connection even if they\n // said they won't.\n setImmediate(resume, client)\n } else {\n resume(client)\n }\n }\n}\n\nfunction onParserTimeout (parser) {\n const { socket, timeoutType, client } = parser\n\n /* istanbul ignore else */\n if (timeoutType === TIMEOUT_HEADERS) {\n if (!socket[kWriting] || socket.writableNeedDrain || client[kRunning] > 1) {\n assert(!parser.paused, 'cannot be paused while waiting for headers')\n util.destroy(socket, new HeadersTimeoutError())\n }\n } else if (timeoutType === TIMEOUT_BODY) {\n if (!parser.paused) {\n util.destroy(socket, new BodyTimeoutError())\n }\n } else if (timeoutType === TIMEOUT_IDLE) {\n assert(client[kRunning] === 0 && client[kKeepAliveTimeoutValue])\n util.destroy(socket, new InformationalError('socket idle timeout'))\n }\n}\n\nfunction onSocketReadable () {\n const { [kParser]: parser } = this\n if (parser) {\n parser.readMore()\n }\n}\n\nfunction onSocketError (err) {\n const { [kClient]: client, [kParser]: parser } = this\n\n assert(err.code !== 'ERR_TLS_CERT_ALTNAME_INVALID')\n\n if (client[kHTTPConnVersion] !== 'h2') {\n // On Mac OS, we get an ECONNRESET even if there is a full body to be forwarded\n // to the user.\n if (err.code === 'ECONNRESET' && parser.statusCode && !parser.shouldKeepAlive) {\n // We treat all incoming data so for as a valid response.\n parser.onMessageComplete()\n return\n }\n }\n\n this[kError] = err\n\n onError(this[kClient], err)\n}\n\nfunction onError (client, err) {\n if (\n client[kRunning] === 0 &&\n err.code !== 'UND_ERR_INFO' &&\n err.code !== 'UND_ERR_SOCKET'\n ) {\n // Error is not caused by running request and not a recoverable\n // socket error.\n\n assert(client[kPendingIdx] === client[kRunningIdx])\n\n const requests = client[kQueue].splice(client[kRunningIdx])\n for (let i = 0; i < requests.length; i++) {\n const request = requests[i]\n errorRequest(client, request, err)\n }\n assert(client[kSize] === 0)\n }\n}\n\nfunction onSocketEnd () {\n const { [kParser]: parser, [kClient]: client } = this\n\n if (client[kHTTPConnVersion] !== 'h2') {\n if (parser.statusCode && !parser.shouldKeepAlive) {\n // We treat all incoming data so far as a valid response.\n parser.onMessageComplete()\n return\n }\n }\n\n util.destroy(this, new SocketError('other side closed', util.getSocketInfo(this)))\n}\n\nfunction onSocketClose () {\n const { [kClient]: client, [kParser]: parser } = this\n\n if (client[kHTTPConnVersion] === 'h1' && parser) {\n if (!this[kError] && parser.statusCode && !parser.shouldKeepAlive) {\n // We treat all incoming data so far as a valid response.\n parser.onMessageComplete()\n }\n\n this[kParser].destroy()\n this[kParser] = null\n }\n\n const err = this[kError] || new SocketError('closed', util.getSocketInfo(this))\n\n client[kSocket] = null\n\n if (client.destroyed) {\n assert(client[kPending] === 0)\n\n // Fail entire queue.\n const requests = client[kQueue].splice(client[kRunningIdx])\n for (let i = 0; i < requests.length; i++) {\n const request = requests[i]\n errorRequest(client, request, err)\n }\n } else if (client[kRunning] > 0 && err.code !== 'UND_ERR_INFO') {\n // Fail head of pipeline.\n const request = client[kQueue][client[kRunningIdx]]\n client[kQueue][client[kRunningIdx]++] = null\n\n errorRequest(client, request, err)\n }\n\n client[kPendingIdx] = client[kRunningIdx]\n\n assert(client[kRunning] === 0)\n\n client.emit('disconnect', client[kUrl], [client], err)\n\n resume(client)\n}\n\nasync function connect (client) {\n assert(!client[kConnecting])\n assert(!client[kSocket])\n\n let { host, hostname, protocol, port } = client[kUrl]\n\n // Resolve ipv6\n if (hostname[0] === '[') {\n const idx = hostname.indexOf(']')\n\n assert(idx !== -1)\n const ip = hostname.substring(1, idx)\n\n assert(net.isIP(ip))\n hostname = ip\n }\n\n client[kConnecting] = true\n\n if (channels.beforeConnect.hasSubscribers) {\n channels.beforeConnect.publish({\n connectParams: {\n host,\n hostname,\n protocol,\n port,\n servername: client[kServerName],\n localAddress: client[kLocalAddress]\n },\n connector: client[kConnector]\n })\n }\n\n try {\n const socket = await new Promise((resolve, reject) => {\n client[kConnector]({\n host,\n hostname,\n protocol,\n port,\n servername: client[kServerName],\n localAddress: client[kLocalAddress]\n }, (err, socket) => {\n if (err) {\n reject(err)\n } else {\n resolve(socket)\n }\n })\n })\n\n if (client.destroyed) {\n util.destroy(socket.on('error', () => {}), new ClientDestroyedError())\n return\n }\n\n client[kConnecting] = false\n\n assert(socket)\n\n const isH2 = socket.alpnProtocol === 'h2'\n if (isH2) {\n if (!h2ExperimentalWarned) {\n h2ExperimentalWarned = true\n process.emitWarning('H2 support is experimental, expect them to change at any time.', {\n code: 'UNDICI-H2'\n })\n }\n\n const session = http2.connect(client[kUrl], {\n createConnection: () => socket,\n peerMaxConcurrentStreams: client[kHTTP2SessionState].maxConcurrentStreams\n })\n\n client[kHTTPConnVersion] = 'h2'\n session[kClient] = client\n session[kSocket] = socket\n session.on('error', onHttp2SessionError)\n session.on('frameError', onHttp2FrameError)\n session.on('end', onHttp2SessionEnd)\n session.on('goaway', onHTTP2GoAway)\n session.on('close', onSocketClose)\n session.unref()\n\n client[kHTTP2Session] = session\n socket[kHTTP2Session] = session\n } else {\n if (!llhttpInstance) {\n llhttpInstance = await llhttpPromise\n llhttpPromise = null\n }\n\n socket[kNoRef] = false\n socket[kWriting] = false\n socket[kReset] = false\n socket[kBlocking] = false\n socket[kParser] = new Parser(client, socket, llhttpInstance)\n }\n\n socket[kCounter] = 0\n socket[kMaxRequests] = client[kMaxRequests]\n socket[kClient] = client\n socket[kError] = null\n\n socket\n .on('error', onSocketError)\n .on('readable', onSocketReadable)\n .on('end', onSocketEnd)\n .on('close', onSocketClose)\n\n client[kSocket] = socket\n\n if (channels.connected.hasSubscribers) {\n channels.connected.publish({\n connectParams: {\n host,\n hostname,\n protocol,\n port,\n servername: client[kServerName],\n localAddress: client[kLocalAddress]\n },\n connector: client[kConnector],\n socket\n })\n }\n client.emit('connect', client[kUrl], [client])\n } catch (err) {\n if (client.destroyed) {\n return\n }\n\n client[kConnecting] = false\n\n if (channels.connectError.hasSubscribers) {\n channels.connectError.publish({\n connectParams: {\n host,\n hostname,\n protocol,\n port,\n servername: client[kServerName],\n localAddress: client[kLocalAddress]\n },\n connector: client[kConnector],\n error: err\n })\n }\n\n if (err.code === 'ERR_TLS_CERT_ALTNAME_INVALID') {\n assert(client[kRunning] === 0)\n while (client[kPending] > 0 && client[kQueue][client[kPendingIdx]].servername === client[kServerName]) {\n const request = client[kQueue][client[kPendingIdx]++]\n errorRequest(client, request, err)\n }\n } else {\n onError(client, err)\n }\n\n client.emit('connectionError', client[kUrl], [client], err)\n }\n\n resume(client)\n}\n\nfunction emitDrain (client) {\n client[kNeedDrain] = 0\n client.emit('drain', client[kUrl], [client])\n}\n\nfunction resume (client, sync) {\n if (client[kResuming] === 2) {\n return\n }\n\n client[kResuming] = 2\n\n _resume(client, sync)\n client[kResuming] = 0\n\n if (client[kRunningIdx] > 256) {\n client[kQueue].splice(0, client[kRunningIdx])\n client[kPendingIdx] -= client[kRunningIdx]\n client[kRunningIdx] = 0\n }\n}\n\nfunction _resume (client, sync) {\n while (true) {\n if (client.destroyed) {\n assert(client[kPending] === 0)\n return\n }\n\n if (client[kClosedResolve] && !client[kSize]) {\n client[kClosedResolve]()\n client[kClosedResolve] = null\n return\n }\n\n const socket = client[kSocket]\n\n if (socket && !socket.destroyed && socket.alpnProtocol !== 'h2') {\n if (client[kSize] === 0) {\n if (!socket[kNoRef] && socket.unref) {\n socket.unref()\n socket[kNoRef] = true\n }\n } else if (socket[kNoRef] && socket.ref) {\n socket.ref()\n socket[kNoRef] = false\n }\n\n if (client[kSize] === 0) {\n if (socket[kParser].timeoutType !== TIMEOUT_IDLE) {\n socket[kParser].setTimeout(client[kKeepAliveTimeoutValue], TIMEOUT_IDLE)\n }\n } else if (client[kRunning] > 0 && socket[kParser].statusCode < 200) {\n if (socket[kParser].timeoutType !== TIMEOUT_HEADERS) {\n const request = client[kQueue][client[kRunningIdx]]\n const headersTimeout = request.headersTimeout != null\n ? request.headersTimeout\n : client[kHeadersTimeout]\n socket[kParser].setTimeout(headersTimeout, TIMEOUT_HEADERS)\n }\n }\n }\n\n if (client[kBusy]) {\n client[kNeedDrain] = 2\n } else if (client[kNeedDrain] === 2) {\n if (sync) {\n client[kNeedDrain] = 1\n process.nextTick(emitDrain, client)\n } else {\n emitDrain(client)\n }\n continue\n }\n\n if (client[kPending] === 0) {\n return\n }\n\n if (client[kRunning] >= (client[kPipelining] || 1)) {\n return\n }\n\n const request = client[kQueue][client[kPendingIdx]]\n\n if (client[kUrl].protocol === 'https:' && client[kServerName] !== request.servername) {\n if (client[kRunning] > 0) {\n return\n }\n\n client[kServerName] = request.servername\n\n if (socket && socket.servername !== request.servername) {\n util.destroy(socket, new InformationalError('servername changed'))\n return\n }\n }\n\n if (client[kConnecting]) {\n return\n }\n\n if (!socket && !client[kHTTP2Session]) {\n connect(client)\n return\n }\n\n if (socket.destroyed || socket[kWriting] || socket[kReset] || socket[kBlocking]) {\n return\n }\n\n if (client[kRunning] > 0 && !request.idempotent) {\n // Non-idempotent request cannot be retried.\n // Ensure that no other requests are inflight and\n // could cause failure.\n return\n }\n\n if (client[kRunning] > 0 && (request.upgrade || request.method === 'CONNECT')) {\n // Don't dispatch an upgrade until all preceding requests have completed.\n // A misbehaving server might upgrade the connection before all pipelined\n // request has completed.\n return\n }\n\n if (client[kRunning] > 0 && util.bodyLength(request.body) !== 0 &&\n (util.isStream(request.body) || util.isAsyncIterable(request.body))) {\n // Request with stream or iterator body can error while other requests\n // are inflight and indirectly error those as well.\n // Ensure this doesn't happen by waiting for inflight\n // to complete before dispatching.\n\n // Request with stream or iterator body cannot be retried.\n // Ensure that no other requests are inflight and\n // could cause failure.\n return\n }\n\n if (!request.aborted && write(client, request)) {\n client[kPendingIdx]++\n } else {\n client[kQueue].splice(client[kPendingIdx], 1)\n }\n }\n}\n\n// https://www.rfc-editor.org/rfc/rfc7230#section-3.3.2\nfunction shouldSendContentLength (method) {\n return method !== 'GET' && method !== 'HEAD' && method !== 'OPTIONS' && method !== 'TRACE' && method !== 'CONNECT'\n}\n\nfunction write (client, request) {\n if (client[kHTTPConnVersion] === 'h2') {\n writeH2(client, client[kHTTP2Session], request)\n return\n }\n\n const { body, method, path, host, upgrade, headers, blocking, reset } = request\n\n // https://tools.ietf.org/html/rfc7231#section-4.3.1\n // https://tools.ietf.org/html/rfc7231#section-4.3.2\n // https://tools.ietf.org/html/rfc7231#section-4.3.5\n\n // Sending a payload body on a request that does not\n // expect it can cause undefined behavior on some\n // servers and corrupt connection state. Do not\n // re-use the connection for further requests.\n\n const expectsPayload = (\n method === 'PUT' ||\n method === 'POST' ||\n method === 'PATCH'\n )\n\n if (body && typeof body.read === 'function') {\n // Try to read EOF in order to get length.\n body.read(0)\n }\n\n const bodyLength = util.bodyLength(body)\n\n let contentLength = bodyLength\n\n if (contentLength === null) {\n contentLength = request.contentLength\n }\n\n if (contentLength === 0 && !expectsPayload) {\n // https://tools.ietf.org/html/rfc7230#section-3.3.2\n // A user agent SHOULD NOT send a Content-Length header field when\n // the request message does not contain a payload body and the method\n // semantics do not anticipate such a body.\n\n contentLength = null\n }\n\n // https://github.com/nodejs/undici/issues/2046\n // A user agent may send a Content-Length header with 0 value, this should be allowed.\n if (shouldSendContentLength(method) && contentLength > 0 && request.contentLength !== null && request.contentLength !== contentLength) {\n if (client[kStrictContentLength]) {\n errorRequest(client, request, new RequestContentLengthMismatchError())\n return false\n }\n\n process.emitWarning(new RequestContentLengthMismatchError())\n }\n\n const socket = client[kSocket]\n\n try {\n request.onConnect((err) => {\n if (request.aborted || request.completed) {\n return\n }\n\n errorRequest(client, request, err || new RequestAbortedError())\n\n util.destroy(socket, new InformationalError('aborted'))\n })\n } catch (err) {\n errorRequest(client, request, err)\n }\n\n if (request.aborted) {\n return false\n }\n\n if (method === 'HEAD') {\n // https://github.com/mcollina/undici/issues/258\n // Close after a HEAD request to interop with misbehaving servers\n // that may send a body in the response.\n\n socket[kReset] = true\n }\n\n if (upgrade || method === 'CONNECT') {\n // On CONNECT or upgrade, block pipeline from dispatching further\n // requests on this connection.\n\n socket[kReset] = true\n }\n\n if (reset != null) {\n socket[kReset] = reset\n }\n\n if (client[kMaxRequests] && socket[kCounter]++ >= client[kMaxRequests]) {\n socket[kReset] = true\n }\n\n if (blocking) {\n socket[kBlocking] = true\n }\n\n let header = `${method} ${path} HTTP/1.1\\r\\n`\n\n if (typeof host === 'string') {\n header += `host: ${host}\\r\\n`\n } else {\n header += client[kHostHeader]\n }\n\n if (upgrade) {\n header += `connection: upgrade\\r\\nupgrade: ${upgrade}\\r\\n`\n } else if (client[kPipelining] && !socket[kReset]) {\n header += 'connection: keep-alive\\r\\n'\n } else {\n header += 'connection: close\\r\\n'\n }\n\n if (headers) {\n header += headers\n }\n\n if (channels.sendHeaders.hasSubscribers) {\n channels.sendHeaders.publish({ request, headers: header, socket })\n }\n\n /* istanbul ignore else: assertion */\n if (!body || bodyLength === 0) {\n if (contentLength === 0) {\n socket.write(`${header}content-length: 0\\r\\n\\r\\n`, 'latin1')\n } else {\n assert(contentLength === null, 'no body must not have content length')\n socket.write(`${header}\\r\\n`, 'latin1')\n }\n request.onRequestSent()\n } else if (util.isBuffer(body)) {\n assert(contentLength === body.byteLength, 'buffer body must have content length')\n\n socket.cork()\n socket.write(`${header}content-length: ${contentLength}\\r\\n\\r\\n`, 'latin1')\n socket.write(body)\n socket.uncork()\n request.onBodySent(body)\n request.onRequestSent()\n if (!expectsPayload) {\n socket[kReset] = true\n }\n } else if (util.isBlobLike(body)) {\n if (typeof body.stream === 'function') {\n writeIterable({ body: body.stream(), client, request, socket, contentLength, header, expectsPayload })\n } else {\n writeBlob({ body, client, request, socket, contentLength, header, expectsPayload })\n }\n } else if (util.isStream(body)) {\n writeStream({ body, client, request, socket, contentLength, header, expectsPayload })\n } else if (util.isIterable(body)) {\n writeIterable({ body, client, request, socket, contentLength, header, expectsPayload })\n } else {\n assert(false)\n }\n\n return true\n}\n\nfunction writeH2 (client, session, request) {\n const { body, method, path, host, upgrade, expectContinue, signal, headers: reqHeaders } = request\n\n let headers\n if (typeof reqHeaders === 'string') headers = Request[kHTTP2CopyHeaders](reqHeaders.trim())\n else headers = reqHeaders\n\n if (upgrade) {\n errorRequest(client, request, new Error('Upgrade not supported for H2'))\n return false\n }\n\n try {\n // TODO(HTTP/2): Should we call onConnect immediately or on stream ready event?\n request.onConnect((err) => {\n if (request.aborted || request.completed) {\n return\n }\n\n errorRequest(client, request, err || new RequestAbortedError())\n })\n } catch (err) {\n errorRequest(client, request, err)\n }\n\n if (request.aborted) {\n return false\n }\n\n /** @type {import('node:http2').ClientHttp2Stream} */\n let stream\n const h2State = client[kHTTP2SessionState]\n\n headers[HTTP2_HEADER_AUTHORITY] = host || client[kHost]\n headers[HTTP2_HEADER_METHOD] = method\n\n if (method === 'CONNECT') {\n session.ref()\n // we are already connected, streams are pending, first request\n // will create a new stream. We trigger a request to create the stream and wait until\n // `ready` event is triggered\n // We disabled endStream to allow the user to write to the stream\n stream = session.request(headers, { endStream: false, signal })\n\n if (stream.id && !stream.pending) {\n request.onUpgrade(null, null, stream)\n ++h2State.openStreams\n } else {\n stream.once('ready', () => {\n request.onUpgrade(null, null, stream)\n ++h2State.openStreams\n })\n }\n\n stream.once('close', () => {\n h2State.openStreams -= 1\n // TODO(HTTP/2): unref only if current streams count is 0\n if (h2State.openStreams === 0) session.unref()\n })\n\n return true\n }\n\n // https://tools.ietf.org/html/rfc7540#section-8.3\n // :path and :scheme headers must be omited when sending CONNECT\n\n headers[HTTP2_HEADER_PATH] = path\n headers[HTTP2_HEADER_SCHEME] = 'https'\n\n // https://tools.ietf.org/html/rfc7231#section-4.3.1\n // https://tools.ietf.org/html/rfc7231#section-4.3.2\n // https://tools.ietf.org/html/rfc7231#section-4.3.5\n\n // Sending a payload body on a request that does not\n // expect it can cause undefined behavior on some\n // servers and corrupt connection state. Do not\n // re-use the connection for further requests.\n\n const expectsPayload = (\n method === 'PUT' ||\n method === 'POST' ||\n method === 'PATCH'\n )\n\n if (body && typeof body.read === 'function') {\n // Try to read EOF in order to get length.\n body.read(0)\n }\n\n let contentLength = util.bodyLength(body)\n\n if (contentLength == null) {\n contentLength = request.contentLength\n }\n\n if (contentLength === 0 || !expectsPayload) {\n // https://tools.ietf.org/html/rfc7230#section-3.3.2\n // A user agent SHOULD NOT send a Content-Length header field when\n // the request message does not contain a payload body and the method\n // semantics do not anticipate such a body.\n\n contentLength = null\n }\n\n // https://github.com/nodejs/undici/issues/2046\n // A user agent may send a Content-Length header with 0 value, this should be allowed.\n if (shouldSendContentLength(method) && contentLength > 0 && request.contentLength != null && request.contentLength !== contentLength) {\n if (client[kStrictContentLength]) {\n errorRequest(client, request, new RequestContentLengthMismatchError())\n return false\n }\n\n process.emitWarning(new RequestContentLengthMismatchError())\n }\n\n if (contentLength != null) {\n assert(body, 'no body must not have content length')\n headers[HTTP2_HEADER_CONTENT_LENGTH] = `${contentLength}`\n }\n\n session.ref()\n\n const shouldEndStream = method === 'GET' || method === 'HEAD'\n if (expectContinue) {\n headers[HTTP2_HEADER_EXPECT] = '100-continue'\n stream = session.request(headers, { endStream: shouldEndStream, signal })\n\n stream.once('continue', writeBodyH2)\n } else {\n stream = session.request(headers, {\n endStream: shouldEndStream,\n signal\n })\n writeBodyH2()\n }\n\n // Increment counter as we have new several streams open\n ++h2State.openStreams\n\n stream.once('response', headers => {\n const { [HTTP2_HEADER_STATUS]: statusCode, ...realHeaders } = headers\n\n if (request.onHeaders(Number(statusCode), realHeaders, stream.resume.bind(stream), '') === false) {\n stream.pause()\n }\n })\n\n stream.once('end', () => {\n request.onComplete([])\n })\n\n stream.on('data', (chunk) => {\n if (request.onData(chunk) === false) {\n stream.pause()\n }\n })\n\n stream.once('close', () => {\n h2State.openStreams -= 1\n // TODO(HTTP/2): unref only if current streams count is 0\n if (h2State.openStreams === 0) {\n session.unref()\n }\n })\n\n stream.once('error', function (err) {\n if (client[kHTTP2Session] && !client[kHTTP2Session].destroyed && !this.closed && !this.destroyed) {\n h2State.streams -= 1\n util.destroy(stream, err)\n }\n })\n\n stream.once('frameError', (type, code) => {\n const err = new InformationalError(`HTTP/2: \"frameError\" received - type ${type}, code ${code}`)\n errorRequest(client, request, err)\n\n if (client[kHTTP2Session] && !client[kHTTP2Session].destroyed && !this.closed && !this.destroyed) {\n h2State.streams -= 1\n util.destroy(stream, err)\n }\n })\n\n // stream.on('aborted', () => {\n // // TODO(HTTP/2): Support aborted\n // })\n\n // stream.on('timeout', () => {\n // // TODO(HTTP/2): Support timeout\n // })\n\n // stream.on('push', headers => {\n // // TODO(HTTP/2): Suppor push\n // })\n\n // stream.on('trailers', headers => {\n // // TODO(HTTP/2): Support trailers\n // })\n\n return true\n\n function writeBodyH2 () {\n /* istanbul ignore else: assertion */\n if (!body) {\n request.onRequestSent()\n } else if (util.isBuffer(body)) {\n assert(contentLength === body.byteLength, 'buffer body must have content length')\n stream.cork()\n stream.write(body)\n stream.uncork()\n stream.end()\n request.onBodySent(body)\n request.onRequestSent()\n } else if (util.isBlobLike(body)) {\n if (typeof body.stream === 'function') {\n writeIterable({\n client,\n request,\n contentLength,\n h2stream: stream,\n expectsPayload,\n body: body.stream(),\n socket: client[kSocket],\n header: ''\n })\n } else {\n writeBlob({\n body,\n client,\n request,\n contentLength,\n expectsPayload,\n h2stream: stream,\n header: '',\n socket: client[kSocket]\n })\n }\n } else if (util.isStream(body)) {\n writeStream({\n body,\n client,\n request,\n contentLength,\n expectsPayload,\n socket: client[kSocket],\n h2stream: stream,\n header: ''\n })\n } else if (util.isIterable(body)) {\n writeIterable({\n body,\n client,\n request,\n contentLength,\n expectsPayload,\n header: '',\n h2stream: stream,\n socket: client[kSocket]\n })\n } else {\n assert(false)\n }\n }\n}\n\nfunction writeStream ({ h2stream, body, client, request, socket, contentLength, header, expectsPayload }) {\n assert(contentLength !== 0 || client[kRunning] === 0, 'stream body cannot be pipelined')\n\n if (client[kHTTPConnVersion] === 'h2') {\n // For HTTP/2, is enough to pipe the stream\n const pipe = pipeline(\n body,\n h2stream,\n (err) => {\n if (err) {\n util.destroy(body, err)\n util.destroy(h2stream, err)\n } else {\n request.onRequestSent()\n }\n }\n )\n\n pipe.on('data', onPipeData)\n pipe.once('end', () => {\n pipe.removeListener('data', onPipeData)\n util.destroy(pipe)\n })\n\n function onPipeData (chunk) {\n request.onBodySent(chunk)\n }\n\n return\n }\n\n let finished = false\n\n const writer = new AsyncWriter({ socket, request, contentLength, client, expectsPayload, header })\n\n const onData = function (chunk) {\n if (finished) {\n return\n }\n\n try {\n if (!writer.write(chunk) && this.pause) {\n this.pause()\n }\n } catch (err) {\n util.destroy(this, err)\n }\n }\n const onDrain = function () {\n if (finished) {\n return\n }\n\n if (body.resume) {\n body.resume()\n }\n }\n const onAbort = function () {\n if (finished) {\n return\n }\n const err = new RequestAbortedError()\n queueMicrotask(() => onFinished(err))\n }\n const onFinished = function (err) {\n if (finished) {\n return\n }\n\n finished = true\n\n assert(socket.destroyed || (socket[kWriting] && client[kRunning] <= 1))\n\n socket\n .off('drain', onDrain)\n .off('error', onFinished)\n\n body\n .removeListener('data', onData)\n .removeListener('end', onFinished)\n .removeListener('error', onFinished)\n .removeListener('close', onAbort)\n\n if (!err) {\n try {\n writer.end()\n } catch (er) {\n err = er\n }\n }\n\n writer.destroy(err)\n\n if (err && (err.code !== 'UND_ERR_INFO' || err.message !== 'reset')) {\n util.destroy(body, err)\n } else {\n util.destroy(body)\n }\n }\n\n body\n .on('data', onData)\n .on('end', onFinished)\n .on('error', onFinished)\n .on('close', onAbort)\n\n if (body.resume) {\n body.resume()\n }\n\n socket\n .on('drain', onDrain)\n .on('error', onFinished)\n}\n\nasync function writeBlob ({ h2stream, body, client, request, socket, contentLength, header, expectsPayload }) {\n assert(contentLength === body.size, 'blob body must have content length')\n\n const isH2 = client[kHTTPConnVersion] === 'h2'\n try {\n if (contentLength != null && contentLength !== body.size) {\n throw new RequestContentLengthMismatchError()\n }\n\n const buffer = Buffer.from(await body.arrayBuffer())\n\n if (isH2) {\n h2stream.cork()\n h2stream.write(buffer)\n h2stream.uncork()\n } else {\n socket.cork()\n socket.write(`${header}content-length: ${contentLength}\\r\\n\\r\\n`, 'latin1')\n socket.write(buffer)\n socket.uncork()\n }\n\n request.onBodySent(buffer)\n request.onRequestSent()\n\n if (!expectsPayload) {\n socket[kReset] = true\n }\n\n resume(client)\n } catch (err) {\n util.destroy(isH2 ? h2stream : socket, err)\n }\n}\n\nasync function writeIterable ({ h2stream, body, client, request, socket, contentLength, header, expectsPayload }) {\n assert(contentLength !== 0 || client[kRunning] === 0, 'iterator body cannot be pipelined')\n\n let callback = null\n function onDrain () {\n if (callback) {\n const cb = callback\n callback = null\n cb()\n }\n }\n\n const waitForDrain = () => new Promise((resolve, reject) => {\n assert(callback === null)\n\n if (socket[kError]) {\n reject(socket[kError])\n } else {\n callback = resolve\n }\n })\n\n if (client[kHTTPConnVersion] === 'h2') {\n h2stream\n .on('close', onDrain)\n .on('drain', onDrain)\n\n try {\n // It's up to the user to somehow abort the async iterable.\n for await (const chunk of body) {\n if (socket[kError]) {\n throw socket[kError]\n }\n\n const res = h2stream.write(chunk)\n request.onBodySent(chunk)\n if (!res) {\n await waitForDrain()\n }\n }\n } catch (err) {\n h2stream.destroy(err)\n } finally {\n request.onRequestSent()\n h2stream.end()\n h2stream\n .off('close', onDrain)\n .off('drain', onDrain)\n }\n\n return\n }\n\n socket\n .on('close', onDrain)\n .on('drain', onDrain)\n\n const writer = new AsyncWriter({ socket, request, contentLength, client, expectsPayload, header })\n try {\n // It's up to the user to somehow abort the async iterable.\n for await (const chunk of body) {\n if (socket[kError]) {\n throw socket[kError]\n }\n\n if (!writer.write(chunk)) {\n await waitForDrain()\n }\n }\n\n writer.end()\n } catch (err) {\n writer.destroy(err)\n } finally {\n socket\n .off('close', onDrain)\n .off('drain', onDrain)\n }\n}\n\nclass AsyncWriter {\n constructor ({ socket, request, contentLength, client, expectsPayload, header }) {\n this.socket = socket\n this.request = request\n this.contentLength = contentLength\n this.client = client\n this.bytesWritten = 0\n this.expectsPayload = expectsPayload\n this.header = header\n\n socket[kWriting] = true\n }\n\n write (chunk) {\n const { socket, request, contentLength, client, bytesWritten, expectsPayload, header } = this\n\n if (socket[kError]) {\n throw socket[kError]\n }\n\n if (socket.destroyed) {\n return false\n }\n\n const len = Buffer.byteLength(chunk)\n if (!len) {\n return true\n }\n\n // We should defer writing chunks.\n if (contentLength !== null && bytesWritten + len > contentLength) {\n if (client[kStrictContentLength]) {\n throw new RequestContentLengthMismatchError()\n }\n\n process.emitWarning(new RequestContentLengthMismatchError())\n }\n\n socket.cork()\n\n if (bytesWritten === 0) {\n if (!expectsPayload) {\n socket[kReset] = true\n }\n\n if (contentLength === null) {\n socket.write(`${header}transfer-encoding: chunked\\r\\n`, 'latin1')\n } else {\n socket.write(`${header}content-length: ${contentLength}\\r\\n\\r\\n`, 'latin1')\n }\n }\n\n if (contentLength === null) {\n socket.write(`\\r\\n${len.toString(16)}\\r\\n`, 'latin1')\n }\n\n this.bytesWritten += len\n\n const ret = socket.write(chunk)\n\n socket.uncork()\n\n request.onBodySent(chunk)\n\n if (!ret) {\n if (socket[kParser].timeout && socket[kParser].timeoutType === TIMEOUT_HEADERS) {\n // istanbul ignore else: only for jest\n if (socket[kParser].timeout.refresh) {\n socket[kParser].timeout.refresh()\n }\n }\n }\n\n return ret\n }\n\n end () {\n const { socket, contentLength, client, bytesWritten, expectsPayload, header, request } = this\n request.onRequestSent()\n\n socket[kWriting] = false\n\n if (socket[kError]) {\n throw socket[kError]\n }\n\n if (socket.destroyed) {\n return\n }\n\n if (bytesWritten === 0) {\n if (expectsPayload) {\n // https://tools.ietf.org/html/rfc7230#section-3.3.2\n // A user agent SHOULD send a Content-Length in a request message when\n // no Transfer-Encoding is sent and the request method defines a meaning\n // for an enclosed payload body.\n\n socket.write(`${header}content-length: 0\\r\\n\\r\\n`, 'latin1')\n } else {\n socket.write(`${header}\\r\\n`, 'latin1')\n }\n } else if (contentLength === null) {\n socket.write('\\r\\n0\\r\\n\\r\\n', 'latin1')\n }\n\n if (contentLength !== null && bytesWritten !== contentLength) {\n if (client[kStrictContentLength]) {\n throw new RequestContentLengthMismatchError()\n } else {\n process.emitWarning(new RequestContentLengthMismatchError())\n }\n }\n\n if (socket[kParser].timeout && socket[kParser].timeoutType === TIMEOUT_HEADERS) {\n // istanbul ignore else: only for jest\n if (socket[kParser].timeout.refresh) {\n socket[kParser].timeout.refresh()\n }\n }\n\n resume(client)\n }\n\n destroy (err) {\n const { socket, client } = this\n\n socket[kWriting] = false\n\n if (err) {\n assert(client[kRunning] <= 1, 'pipeline should only contain this request')\n util.destroy(socket, err)\n }\n }\n}\n\nfunction errorRequest (client, request, err) {\n try {\n request.onError(err)\n assert(request.aborted)\n } catch (err) {\n client.emit('error', err)\n }\n}\n\nmodule.exports = Client\n","'use strict'\n\n/* istanbul ignore file: only for Node 12 */\n\nconst { kConnected, kSize } = require('../core/symbols')\n\nclass CompatWeakRef {\n constructor (value) {\n this.value = value\n }\n\n deref () {\n return this.value[kConnected] === 0 && this.value[kSize] === 0\n ? undefined\n : this.value\n }\n}\n\nclass CompatFinalizer {\n constructor (finalizer) {\n this.finalizer = finalizer\n }\n\n register (dispatcher, key) {\n if (dispatcher.on) {\n dispatcher.on('disconnect', () => {\n if (dispatcher[kConnected] === 0 && dispatcher[kSize] === 0) {\n this.finalizer(key)\n }\n })\n }\n }\n}\n\nmodule.exports = function () {\n // FIXME: remove workaround when the Node bug is fixed\n // https://github.com/nodejs/node/issues/49344#issuecomment-1741776308\n if (process.env.NODE_V8_COVERAGE) {\n return {\n WeakRef: CompatWeakRef,\n FinalizationRegistry: CompatFinalizer\n }\n }\n return {\n WeakRef: global.WeakRef || CompatWeakRef,\n FinalizationRegistry: global.FinalizationRegistry || CompatFinalizer\n }\n}\n","'use strict'\n\n// https://wicg.github.io/cookie-store/#cookie-maximum-attribute-value-size\nconst maxAttributeValueSize = 1024\n\n// https://wicg.github.io/cookie-store/#cookie-maximum-name-value-pair-size\nconst maxNameValuePairSize = 4096\n\nmodule.exports = {\n maxAttributeValueSize,\n maxNameValuePairSize\n}\n","'use strict'\n\nconst { parseSetCookie } = require('./parse')\nconst { stringify, getHeadersList } = require('./util')\nconst { webidl } = require('../fetch/webidl')\nconst { Headers } = require('../fetch/headers')\n\n/**\n * @typedef {Object} Cookie\n * @property {string} name\n * @property {string} value\n * @property {Date|number|undefined} expires\n * @property {number|undefined} maxAge\n * @property {string|undefined} domain\n * @property {string|undefined} path\n * @property {boolean|undefined} secure\n * @property {boolean|undefined} httpOnly\n * @property {'Strict'|'Lax'|'None'} sameSite\n * @property {string[]} unparsed\n */\n\n/**\n * @param {Headers} headers\n * @returns {Record}\n */\nfunction getCookies (headers) {\n webidl.argumentLengthCheck(arguments, 1, { header: 'getCookies' })\n\n webidl.brandCheck(headers, Headers, { strict: false })\n\n const cookie = headers.get('cookie')\n const out = {}\n\n if (!cookie) {\n return out\n }\n\n for (const piece of cookie.split(';')) {\n const [name, ...value] = piece.split('=')\n\n out[name.trim()] = value.join('=')\n }\n\n return out\n}\n\n/**\n * @param {Headers} headers\n * @param {string} name\n * @param {{ path?: string, domain?: string }|undefined} attributes\n * @returns {void}\n */\nfunction deleteCookie (headers, name, attributes) {\n webidl.argumentLengthCheck(arguments, 2, { header: 'deleteCookie' })\n\n webidl.brandCheck(headers, Headers, { strict: false })\n\n name = webidl.converters.DOMString(name)\n attributes = webidl.converters.DeleteCookieAttributes(attributes)\n\n // Matches behavior of\n // https://github.com/denoland/deno_std/blob/63827b16330b82489a04614027c33b7904e08be5/http/cookie.ts#L278\n setCookie(headers, {\n name,\n value: '',\n expires: new Date(0),\n ...attributes\n })\n}\n\n/**\n * @param {Headers} headers\n * @returns {Cookie[]}\n */\nfunction getSetCookies (headers) {\n webidl.argumentLengthCheck(arguments, 1, { header: 'getSetCookies' })\n\n webidl.brandCheck(headers, Headers, { strict: false })\n\n const cookies = getHeadersList(headers).cookies\n\n if (!cookies) {\n return []\n }\n\n // In older versions of undici, cookies is a list of name:value.\n return cookies.map((pair) => parseSetCookie(Array.isArray(pair) ? pair[1] : pair))\n}\n\n/**\n * @param {Headers} headers\n * @param {Cookie} cookie\n * @returns {void}\n */\nfunction setCookie (headers, cookie) {\n webidl.argumentLengthCheck(arguments, 2, { header: 'setCookie' })\n\n webidl.brandCheck(headers, Headers, { strict: false })\n\n cookie = webidl.converters.Cookie(cookie)\n\n const str = stringify(cookie)\n\n if (str) {\n headers.append('Set-Cookie', stringify(cookie))\n }\n}\n\nwebidl.converters.DeleteCookieAttributes = webidl.dictionaryConverter([\n {\n converter: webidl.nullableConverter(webidl.converters.DOMString),\n key: 'path',\n defaultValue: null\n },\n {\n converter: webidl.nullableConverter(webidl.converters.DOMString),\n key: 'domain',\n defaultValue: null\n }\n])\n\nwebidl.converters.Cookie = webidl.dictionaryConverter([\n {\n converter: webidl.converters.DOMString,\n key: 'name'\n },\n {\n converter: webidl.converters.DOMString,\n key: 'value'\n },\n {\n converter: webidl.nullableConverter((value) => {\n if (typeof value === 'number') {\n return webidl.converters['unsigned long long'](value)\n }\n\n return new Date(value)\n }),\n key: 'expires',\n defaultValue: null\n },\n {\n converter: webidl.nullableConverter(webidl.converters['long long']),\n key: 'maxAge',\n defaultValue: null\n },\n {\n converter: webidl.nullableConverter(webidl.converters.DOMString),\n key: 'domain',\n defaultValue: null\n },\n {\n converter: webidl.nullableConverter(webidl.converters.DOMString),\n key: 'path',\n defaultValue: null\n },\n {\n converter: webidl.nullableConverter(webidl.converters.boolean),\n key: 'secure',\n defaultValue: null\n },\n {\n converter: webidl.nullableConverter(webidl.converters.boolean),\n key: 'httpOnly',\n defaultValue: null\n },\n {\n converter: webidl.converters.USVString,\n key: 'sameSite',\n allowedValues: ['Strict', 'Lax', 'None']\n },\n {\n converter: webidl.sequenceConverter(webidl.converters.DOMString),\n key: 'unparsed',\n defaultValue: []\n }\n])\n\nmodule.exports = {\n getCookies,\n deleteCookie,\n getSetCookies,\n setCookie\n}\n","'use strict'\n\nconst { maxNameValuePairSize, maxAttributeValueSize } = require('./constants')\nconst { isCTLExcludingHtab } = require('./util')\nconst { collectASequenceOfCodePointsFast } = require('../fetch/dataURL')\nconst assert = require('assert')\n\n/**\n * @description Parses the field-value attributes of a set-cookie header string.\n * @see https://datatracker.ietf.org/doc/html/draft-ietf-httpbis-rfc6265bis#section-5.4\n * @param {string} header\n * @returns if the header is invalid, null will be returned\n */\nfunction parseSetCookie (header) {\n // 1. If the set-cookie-string contains a %x00-08 / %x0A-1F / %x7F\n // character (CTL characters excluding HTAB): Abort these steps and\n // ignore the set-cookie-string entirely.\n if (isCTLExcludingHtab(header)) {\n return null\n }\n\n let nameValuePair = ''\n let unparsedAttributes = ''\n let name = ''\n let value = ''\n\n // 2. If the set-cookie-string contains a %x3B (\";\") character:\n if (header.includes(';')) {\n // 1. The name-value-pair string consists of the characters up to,\n // but not including, the first %x3B (\";\"), and the unparsed-\n // attributes consist of the remainder of the set-cookie-string\n // (including the %x3B (\";\") in question).\n const position = { position: 0 }\n\n nameValuePair = collectASequenceOfCodePointsFast(';', header, position)\n unparsedAttributes = header.slice(position.position)\n } else {\n // Otherwise:\n\n // 1. The name-value-pair string consists of all the characters\n // contained in the set-cookie-string, and the unparsed-\n // attributes is the empty string.\n nameValuePair = header\n }\n\n // 3. If the name-value-pair string lacks a %x3D (\"=\") character, then\n // the name string is empty, and the value string is the value of\n // name-value-pair.\n if (!nameValuePair.includes('=')) {\n value = nameValuePair\n } else {\n // Otherwise, the name string consists of the characters up to, but\n // not including, the first %x3D (\"=\") character, and the (possibly\n // empty) value string consists of the characters after the first\n // %x3D (\"=\") character.\n const position = { position: 0 }\n name = collectASequenceOfCodePointsFast(\n '=',\n nameValuePair,\n position\n )\n value = nameValuePair.slice(position.position + 1)\n }\n\n // 4. Remove any leading or trailing WSP characters from the name\n // string and the value string.\n name = name.trim()\n value = value.trim()\n\n // 5. If the sum of the lengths of the name string and the value string\n // is more than 4096 octets, abort these steps and ignore the set-\n // cookie-string entirely.\n if (name.length + value.length > maxNameValuePairSize) {\n return null\n }\n\n // 6. The cookie-name is the name string, and the cookie-value is the\n // value string.\n return {\n name, value, ...parseUnparsedAttributes(unparsedAttributes)\n }\n}\n\n/**\n * Parses the remaining attributes of a set-cookie header\n * @see https://datatracker.ietf.org/doc/html/draft-ietf-httpbis-rfc6265bis#section-5.4\n * @param {string} unparsedAttributes\n * @param {[Object.]={}} cookieAttributeList\n */\nfunction parseUnparsedAttributes (unparsedAttributes, cookieAttributeList = {}) {\n // 1. If the unparsed-attributes string is empty, skip the rest of\n // these steps.\n if (unparsedAttributes.length === 0) {\n return cookieAttributeList\n }\n\n // 2. Discard the first character of the unparsed-attributes (which\n // will be a %x3B (\";\") character).\n assert(unparsedAttributes[0] === ';')\n unparsedAttributes = unparsedAttributes.slice(1)\n\n let cookieAv = ''\n\n // 3. If the remaining unparsed-attributes contains a %x3B (\";\")\n // character:\n if (unparsedAttributes.includes(';')) {\n // 1. Consume the characters of the unparsed-attributes up to, but\n // not including, the first %x3B (\";\") character.\n cookieAv = collectASequenceOfCodePointsFast(\n ';',\n unparsedAttributes,\n { position: 0 }\n )\n unparsedAttributes = unparsedAttributes.slice(cookieAv.length)\n } else {\n // Otherwise:\n\n // 1. Consume the remainder of the unparsed-attributes.\n cookieAv = unparsedAttributes\n unparsedAttributes = ''\n }\n\n // Let the cookie-av string be the characters consumed in this step.\n\n let attributeName = ''\n let attributeValue = ''\n\n // 4. If the cookie-av string contains a %x3D (\"=\") character:\n if (cookieAv.includes('=')) {\n // 1. The (possibly empty) attribute-name string consists of the\n // characters up to, but not including, the first %x3D (\"=\")\n // character, and the (possibly empty) attribute-value string\n // consists of the characters after the first %x3D (\"=\")\n // character.\n const position = { position: 0 }\n\n attributeName = collectASequenceOfCodePointsFast(\n '=',\n cookieAv,\n position\n )\n attributeValue = cookieAv.slice(position.position + 1)\n } else {\n // Otherwise:\n\n // 1. The attribute-name string consists of the entire cookie-av\n // string, and the attribute-value string is empty.\n attributeName = cookieAv\n }\n\n // 5. Remove any leading or trailing WSP characters from the attribute-\n // name string and the attribute-value string.\n attributeName = attributeName.trim()\n attributeValue = attributeValue.trim()\n\n // 6. If the attribute-value is longer than 1024 octets, ignore the\n // cookie-av string and return to Step 1 of this algorithm.\n if (attributeValue.length > maxAttributeValueSize) {\n return parseUnparsedAttributes(unparsedAttributes, cookieAttributeList)\n }\n\n // 7. Process the attribute-name and attribute-value according to the\n // requirements in the following subsections. (Notice that\n // attributes with unrecognized attribute-names are ignored.)\n const attributeNameLowercase = attributeName.toLowerCase()\n\n // https://datatracker.ietf.org/doc/html/draft-ietf-httpbis-rfc6265bis#section-5.4.1\n // If the attribute-name case-insensitively matches the string\n // \"Expires\", the user agent MUST process the cookie-av as follows.\n if (attributeNameLowercase === 'expires') {\n // 1. Let the expiry-time be the result of parsing the attribute-value\n // as cookie-date (see Section 5.1.1).\n const expiryTime = new Date(attributeValue)\n\n // 2. If the attribute-value failed to parse as a cookie date, ignore\n // the cookie-av.\n\n cookieAttributeList.expires = expiryTime\n } else if (attributeNameLowercase === 'max-age') {\n // https://datatracker.ietf.org/doc/html/draft-ietf-httpbis-rfc6265bis#section-5.4.2\n // If the attribute-name case-insensitively matches the string \"Max-\n // Age\", the user agent MUST process the cookie-av as follows.\n\n // 1. If the first character of the attribute-value is not a DIGIT or a\n // \"-\" character, ignore the cookie-av.\n const charCode = attributeValue.charCodeAt(0)\n\n if ((charCode < 48 || charCode > 57) && attributeValue[0] !== '-') {\n return parseUnparsedAttributes(unparsedAttributes, cookieAttributeList)\n }\n\n // 2. If the remainder of attribute-value contains a non-DIGIT\n // character, ignore the cookie-av.\n if (!/^\\d+$/.test(attributeValue)) {\n return parseUnparsedAttributes(unparsedAttributes, cookieAttributeList)\n }\n\n // 3. Let delta-seconds be the attribute-value converted to an integer.\n const deltaSeconds = Number(attributeValue)\n\n // 4. Let cookie-age-limit be the maximum age of the cookie (which\n // SHOULD be 400 days or less, see Section 4.1.2.2).\n\n // 5. Set delta-seconds to the smaller of its present value and cookie-\n // age-limit.\n // deltaSeconds = Math.min(deltaSeconds * 1000, maxExpiresMs)\n\n // 6. If delta-seconds is less than or equal to zero (0), let expiry-\n // time be the earliest representable date and time. Otherwise, let\n // the expiry-time be the current date and time plus delta-seconds\n // seconds.\n // const expiryTime = deltaSeconds <= 0 ? Date.now() : Date.now() + deltaSeconds\n\n // 7. Append an attribute to the cookie-attribute-list with an\n // attribute-name of Max-Age and an attribute-value of expiry-time.\n cookieAttributeList.maxAge = deltaSeconds\n } else if (attributeNameLowercase === 'domain') {\n // https://datatracker.ietf.org/doc/html/draft-ietf-httpbis-rfc6265bis#section-5.4.3\n // If the attribute-name case-insensitively matches the string \"Domain\",\n // the user agent MUST process the cookie-av as follows.\n\n // 1. Let cookie-domain be the attribute-value.\n let cookieDomain = attributeValue\n\n // 2. If cookie-domain starts with %x2E (\".\"), let cookie-domain be\n // cookie-domain without its leading %x2E (\".\").\n if (cookieDomain[0] === '.') {\n cookieDomain = cookieDomain.slice(1)\n }\n\n // 3. Convert the cookie-domain to lower case.\n cookieDomain = cookieDomain.toLowerCase()\n\n // 4. Append an attribute to the cookie-attribute-list with an\n // attribute-name of Domain and an attribute-value of cookie-domain.\n cookieAttributeList.domain = cookieDomain\n } else if (attributeNameLowercase === 'path') {\n // https://datatracker.ietf.org/doc/html/draft-ietf-httpbis-rfc6265bis#section-5.4.4\n // If the attribute-name case-insensitively matches the string \"Path\",\n // the user agent MUST process the cookie-av as follows.\n\n // 1. If the attribute-value is empty or if the first character of the\n // attribute-value is not %x2F (\"/\"):\n let cookiePath = ''\n if (attributeValue.length === 0 || attributeValue[0] !== '/') {\n // 1. Let cookie-path be the default-path.\n cookiePath = '/'\n } else {\n // Otherwise:\n\n // 1. Let cookie-path be the attribute-value.\n cookiePath = attributeValue\n }\n\n // 2. Append an attribute to the cookie-attribute-list with an\n // attribute-name of Path and an attribute-value of cookie-path.\n cookieAttributeList.path = cookiePath\n } else if (attributeNameLowercase === 'secure') {\n // https://datatracker.ietf.org/doc/html/draft-ietf-httpbis-rfc6265bis#section-5.4.5\n // If the attribute-name case-insensitively matches the string \"Secure\",\n // the user agent MUST append an attribute to the cookie-attribute-list\n // with an attribute-name of Secure and an empty attribute-value.\n\n cookieAttributeList.secure = true\n } else if (attributeNameLowercase === 'httponly') {\n // https://datatracker.ietf.org/doc/html/draft-ietf-httpbis-rfc6265bis#section-5.4.6\n // If the attribute-name case-insensitively matches the string\n // \"HttpOnly\", the user agent MUST append an attribute to the cookie-\n // attribute-list with an attribute-name of HttpOnly and an empty\n // attribute-value.\n\n cookieAttributeList.httpOnly = true\n } else if (attributeNameLowercase === 'samesite') {\n // https://datatracker.ietf.org/doc/html/draft-ietf-httpbis-rfc6265bis#section-5.4.7\n // If the attribute-name case-insensitively matches the string\n // \"SameSite\", the user agent MUST process the cookie-av as follows:\n\n // 1. Let enforcement be \"Default\".\n let enforcement = 'Default'\n\n const attributeValueLowercase = attributeValue.toLowerCase()\n // 2. If cookie-av's attribute-value is a case-insensitive match for\n // \"None\", set enforcement to \"None\".\n if (attributeValueLowercase.includes('none')) {\n enforcement = 'None'\n }\n\n // 3. If cookie-av's attribute-value is a case-insensitive match for\n // \"Strict\", set enforcement to \"Strict\".\n if (attributeValueLowercase.includes('strict')) {\n enforcement = 'Strict'\n }\n\n // 4. If cookie-av's attribute-value is a case-insensitive match for\n // \"Lax\", set enforcement to \"Lax\".\n if (attributeValueLowercase.includes('lax')) {\n enforcement = 'Lax'\n }\n\n // 5. Append an attribute to the cookie-attribute-list with an\n // attribute-name of \"SameSite\" and an attribute-value of\n // enforcement.\n cookieAttributeList.sameSite = enforcement\n } else {\n cookieAttributeList.unparsed ??= []\n\n cookieAttributeList.unparsed.push(`${attributeName}=${attributeValue}`)\n }\n\n // 8. Return to Step 1 of this algorithm.\n return parseUnparsedAttributes(unparsedAttributes, cookieAttributeList)\n}\n\nmodule.exports = {\n parseSetCookie,\n parseUnparsedAttributes\n}\n","'use strict'\n\nconst assert = require('assert')\nconst { kHeadersList } = require('../core/symbols')\n\nfunction isCTLExcludingHtab (value) {\n if (value.length === 0) {\n return false\n }\n\n for (const char of value) {\n const code = char.charCodeAt(0)\n\n if (\n (code >= 0x00 || code <= 0x08) ||\n (code >= 0x0A || code <= 0x1F) ||\n code === 0x7F\n ) {\n return false\n }\n }\n}\n\n/**\n CHAR = \n token = 1*\n separators = \"(\" | \")\" | \"<\" | \">\" | \"@\"\n | \",\" | \";\" | \":\" | \"\\\" | <\">\n | \"/\" | \"[\" | \"]\" | \"?\" | \"=\"\n | \"{\" | \"}\" | SP | HT\n * @param {string} name\n */\nfunction validateCookieName (name) {\n for (const char of name) {\n const code = char.charCodeAt(0)\n\n if (\n (code <= 0x20 || code > 0x7F) ||\n char === '(' ||\n char === ')' ||\n char === '>' ||\n char === '<' ||\n char === '@' ||\n char === ',' ||\n char === ';' ||\n char === ':' ||\n char === '\\\\' ||\n char === '\"' ||\n char === '/' ||\n char === '[' ||\n char === ']' ||\n char === '?' ||\n char === '=' ||\n char === '{' ||\n char === '}'\n ) {\n throw new Error('Invalid cookie name')\n }\n }\n}\n\n/**\n cookie-value = *cookie-octet / ( DQUOTE *cookie-octet DQUOTE )\n cookie-octet = %x21 / %x23-2B / %x2D-3A / %x3C-5B / %x5D-7E\n ; US-ASCII characters excluding CTLs,\n ; whitespace DQUOTE, comma, semicolon,\n ; and backslash\n * @param {string} value\n */\nfunction validateCookieValue (value) {\n for (const char of value) {\n const code = char.charCodeAt(0)\n\n if (\n code < 0x21 || // exclude CTLs (0-31)\n code === 0x22 ||\n code === 0x2C ||\n code === 0x3B ||\n code === 0x5C ||\n code > 0x7E // non-ascii\n ) {\n throw new Error('Invalid header value')\n }\n }\n}\n\n/**\n * path-value = \n * @param {string} path\n */\nfunction validateCookiePath (path) {\n for (const char of path) {\n const code = char.charCodeAt(0)\n\n if (code < 0x21 || char === ';') {\n throw new Error('Invalid cookie path')\n }\n }\n}\n\n/**\n * I have no idea why these values aren't allowed to be honest,\n * but Deno tests these. - Khafra\n * @param {string} domain\n */\nfunction validateCookieDomain (domain) {\n if (\n domain.startsWith('-') ||\n domain.endsWith('.') ||\n domain.endsWith('-')\n ) {\n throw new Error('Invalid cookie domain')\n }\n}\n\n/**\n * @see https://www.rfc-editor.org/rfc/rfc7231#section-7.1.1.1\n * @param {number|Date} date\n IMF-fixdate = day-name \",\" SP date1 SP time-of-day SP GMT\n ; fixed length/zone/capitalization subset of the format\n ; see Section 3.3 of [RFC5322]\n\n day-name = %x4D.6F.6E ; \"Mon\", case-sensitive\n / %x54.75.65 ; \"Tue\", case-sensitive\n / %x57.65.64 ; \"Wed\", case-sensitive\n / %x54.68.75 ; \"Thu\", case-sensitive\n / %x46.72.69 ; \"Fri\", case-sensitive\n / %x53.61.74 ; \"Sat\", case-sensitive\n / %x53.75.6E ; \"Sun\", case-sensitive\n date1 = day SP month SP year\n ; e.g., 02 Jun 1982\n\n day = 2DIGIT\n month = %x4A.61.6E ; \"Jan\", case-sensitive\n / %x46.65.62 ; \"Feb\", case-sensitive\n / %x4D.61.72 ; \"Mar\", case-sensitive\n / %x41.70.72 ; \"Apr\", case-sensitive\n / %x4D.61.79 ; \"May\", case-sensitive\n / %x4A.75.6E ; \"Jun\", case-sensitive\n / %x4A.75.6C ; \"Jul\", case-sensitive\n / %x41.75.67 ; \"Aug\", case-sensitive\n / %x53.65.70 ; \"Sep\", case-sensitive\n / %x4F.63.74 ; \"Oct\", case-sensitive\n / %x4E.6F.76 ; \"Nov\", case-sensitive\n / %x44.65.63 ; \"Dec\", case-sensitive\n year = 4DIGIT\n\n GMT = %x47.4D.54 ; \"GMT\", case-sensitive\n\n time-of-day = hour \":\" minute \":\" second\n ; 00:00:00 - 23:59:60 (leap second)\n\n hour = 2DIGIT\n minute = 2DIGIT\n second = 2DIGIT\n */\nfunction toIMFDate (date) {\n if (typeof date === 'number') {\n date = new Date(date)\n }\n\n const days = [\n 'Sun', 'Mon', 'Tue', 'Wed',\n 'Thu', 'Fri', 'Sat'\n ]\n\n const months = [\n 'Jan', 'Feb', 'Mar', 'Apr', 'May', 'Jun',\n 'Jul', 'Aug', 'Sep', 'Oct', 'Nov', 'Dec'\n ]\n\n const dayName = days[date.getUTCDay()]\n const day = date.getUTCDate().toString().padStart(2, '0')\n const month = months[date.getUTCMonth()]\n const year = date.getUTCFullYear()\n const hour = date.getUTCHours().toString().padStart(2, '0')\n const minute = date.getUTCMinutes().toString().padStart(2, '0')\n const second = date.getUTCSeconds().toString().padStart(2, '0')\n\n return `${dayName}, ${day} ${month} ${year} ${hour}:${minute}:${second} GMT`\n}\n\n/**\n max-age-av = \"Max-Age=\" non-zero-digit *DIGIT\n ; In practice, both expires-av and max-age-av\n ; are limited to dates representable by the\n ; user agent.\n * @param {number} maxAge\n */\nfunction validateCookieMaxAge (maxAge) {\n if (maxAge < 0) {\n throw new Error('Invalid cookie max-age')\n }\n}\n\n/**\n * @see https://www.rfc-editor.org/rfc/rfc6265#section-4.1.1\n * @param {import('./index').Cookie} cookie\n */\nfunction stringify (cookie) {\n if (cookie.name.length === 0) {\n return null\n }\n\n validateCookieName(cookie.name)\n validateCookieValue(cookie.value)\n\n const out = [`${cookie.name}=${cookie.value}`]\n\n // https://datatracker.ietf.org/doc/html/draft-ietf-httpbis-cookie-prefixes-00#section-3.1\n // https://datatracker.ietf.org/doc/html/draft-ietf-httpbis-cookie-prefixes-00#section-3.2\n if (cookie.name.startsWith('__Secure-')) {\n cookie.secure = true\n }\n\n if (cookie.name.startsWith('__Host-')) {\n cookie.secure = true\n cookie.domain = null\n cookie.path = '/'\n }\n\n if (cookie.secure) {\n out.push('Secure')\n }\n\n if (cookie.httpOnly) {\n out.push('HttpOnly')\n }\n\n if (typeof cookie.maxAge === 'number') {\n validateCookieMaxAge(cookie.maxAge)\n out.push(`Max-Age=${cookie.maxAge}`)\n }\n\n if (cookie.domain) {\n validateCookieDomain(cookie.domain)\n out.push(`Domain=${cookie.domain}`)\n }\n\n if (cookie.path) {\n validateCookiePath(cookie.path)\n out.push(`Path=${cookie.path}`)\n }\n\n if (cookie.expires && cookie.expires.toString() !== 'Invalid Date') {\n out.push(`Expires=${toIMFDate(cookie.expires)}`)\n }\n\n if (cookie.sameSite) {\n out.push(`SameSite=${cookie.sameSite}`)\n }\n\n for (const part of cookie.unparsed) {\n if (!part.includes('=')) {\n throw new Error('Invalid unparsed')\n }\n\n const [key, ...value] = part.split('=')\n\n out.push(`${key.trim()}=${value.join('=')}`)\n }\n\n return out.join('; ')\n}\n\nlet kHeadersListNode\n\nfunction getHeadersList (headers) {\n if (headers[kHeadersList]) {\n return headers[kHeadersList]\n }\n\n if (!kHeadersListNode) {\n kHeadersListNode = Object.getOwnPropertySymbols(headers).find(\n (symbol) => symbol.description === 'headers list'\n )\n\n assert(kHeadersListNode, 'Headers cannot be parsed')\n }\n\n const headersList = headers[kHeadersListNode]\n assert(headersList)\n\n return headersList\n}\n\nmodule.exports = {\n isCTLExcludingHtab,\n stringify,\n getHeadersList\n}\n","'use strict'\n\nconst net = require('net')\nconst assert = require('assert')\nconst util = require('./util')\nconst { InvalidArgumentError, ConnectTimeoutError } = require('./errors')\n\nlet tls // include tls conditionally since it is not always available\n\n// TODO: session re-use does not wait for the first\n// connection to resolve the session and might therefore\n// resolve the same servername multiple times even when\n// re-use is enabled.\n\nlet SessionCache\n// FIXME: remove workaround when the Node bug is fixed\n// https://github.com/nodejs/node/issues/49344#issuecomment-1741776308\nif (global.FinalizationRegistry && !process.env.NODE_V8_COVERAGE) {\n SessionCache = class WeakSessionCache {\n constructor (maxCachedSessions) {\n this._maxCachedSessions = maxCachedSessions\n this._sessionCache = new Map()\n this._sessionRegistry = new global.FinalizationRegistry((key) => {\n if (this._sessionCache.size < this._maxCachedSessions) {\n return\n }\n\n const ref = this._sessionCache.get(key)\n if (ref !== undefined && ref.deref() === undefined) {\n this._sessionCache.delete(key)\n }\n })\n }\n\n get (sessionKey) {\n const ref = this._sessionCache.get(sessionKey)\n return ref ? ref.deref() : null\n }\n\n set (sessionKey, session) {\n if (this._maxCachedSessions === 0) {\n return\n }\n\n this._sessionCache.set(sessionKey, new WeakRef(session))\n this._sessionRegistry.register(session, sessionKey)\n }\n }\n} else {\n SessionCache = class SimpleSessionCache {\n constructor (maxCachedSessions) {\n this._maxCachedSessions = maxCachedSessions\n this._sessionCache = new Map()\n }\n\n get (sessionKey) {\n return this._sessionCache.get(sessionKey)\n }\n\n set (sessionKey, session) {\n if (this._maxCachedSessions === 0) {\n return\n }\n\n if (this._sessionCache.size >= this._maxCachedSessions) {\n // remove the oldest session\n const { value: oldestKey } = this._sessionCache.keys().next()\n this._sessionCache.delete(oldestKey)\n }\n\n this._sessionCache.set(sessionKey, session)\n }\n }\n}\n\nfunction buildConnector ({ allowH2, maxCachedSessions, socketPath, timeout, ...opts }) {\n if (maxCachedSessions != null && (!Number.isInteger(maxCachedSessions) || maxCachedSessions < 0)) {\n throw new InvalidArgumentError('maxCachedSessions must be a positive integer or zero')\n }\n\n const options = { path: socketPath, ...opts }\n const sessionCache = new SessionCache(maxCachedSessions == null ? 100 : maxCachedSessions)\n timeout = timeout == null ? 10e3 : timeout\n allowH2 = allowH2 != null ? allowH2 : false\n return function connect ({ hostname, host, protocol, port, servername, localAddress, httpSocket }, callback) {\n let socket\n if (protocol === 'https:') {\n if (!tls) {\n tls = require('tls')\n }\n servername = servername || options.servername || util.getServerName(host) || null\n\n const sessionKey = servername || hostname\n const session = sessionCache.get(sessionKey) || null\n\n assert(sessionKey)\n\n socket = tls.connect({\n highWaterMark: 16384, // TLS in node can't have bigger HWM anyway...\n ...options,\n servername,\n session,\n localAddress,\n // TODO(HTTP/2): Add support for h2c\n ALPNProtocols: allowH2 ? ['http/1.1', 'h2'] : ['http/1.1'],\n socket: httpSocket, // upgrade socket connection\n port: port || 443,\n host: hostname\n })\n\n socket\n .on('session', function (session) {\n // TODO (fix): Can a session become invalid once established? Don't think so?\n sessionCache.set(sessionKey, session)\n })\n } else {\n assert(!httpSocket, 'httpSocket can only be sent on TLS update')\n socket = net.connect({\n highWaterMark: 64 * 1024, // Same as nodejs fs streams.\n ...options,\n localAddress,\n port: port || 80,\n host: hostname\n })\n }\n\n // Set TCP keep alive options on the socket here instead of in connect() for the case of assigning the socket\n if (options.keepAlive == null || options.keepAlive) {\n const keepAliveInitialDelay = options.keepAliveInitialDelay === undefined ? 60e3 : options.keepAliveInitialDelay\n socket.setKeepAlive(true, keepAliveInitialDelay)\n }\n\n const cancelTimeout = setupTimeout(() => onConnectTimeout(socket), timeout)\n\n socket\n .setNoDelay(true)\n .once(protocol === 'https:' ? 'secureConnect' : 'connect', function () {\n cancelTimeout()\n\n if (callback) {\n const cb = callback\n callback = null\n cb(null, this)\n }\n })\n .on('error', function (err) {\n cancelTimeout()\n\n if (callback) {\n const cb = callback\n callback = null\n cb(err)\n }\n })\n\n return socket\n }\n}\n\nfunction setupTimeout (onConnectTimeout, timeout) {\n if (!timeout) {\n return () => {}\n }\n\n let s1 = null\n let s2 = null\n const timeoutId = setTimeout(() => {\n // setImmediate is added to make sure that we priotorise socket error events over timeouts\n s1 = setImmediate(() => {\n if (process.platform === 'win32') {\n // Windows needs an extra setImmediate probably due to implementation differences in the socket logic\n s2 = setImmediate(() => onConnectTimeout())\n } else {\n onConnectTimeout()\n }\n })\n }, timeout)\n return () => {\n clearTimeout(timeoutId)\n clearImmediate(s1)\n clearImmediate(s2)\n }\n}\n\nfunction onConnectTimeout (socket) {\n util.destroy(socket, new ConnectTimeoutError())\n}\n\nmodule.exports = buildConnector\n","'use strict'\n\nclass UndiciError extends Error {\n constructor (message) {\n super(message)\n this.name = 'UndiciError'\n this.code = 'UND_ERR'\n }\n}\n\nclass ConnectTimeoutError extends UndiciError {\n constructor (message) {\n super(message)\n Error.captureStackTrace(this, ConnectTimeoutError)\n this.name = 'ConnectTimeoutError'\n this.message = message || 'Connect Timeout Error'\n this.code = 'UND_ERR_CONNECT_TIMEOUT'\n }\n}\n\nclass HeadersTimeoutError extends UndiciError {\n constructor (message) {\n super(message)\n Error.captureStackTrace(this, HeadersTimeoutError)\n this.name = 'HeadersTimeoutError'\n this.message = message || 'Headers Timeout Error'\n this.code = 'UND_ERR_HEADERS_TIMEOUT'\n }\n}\n\nclass HeadersOverflowError extends UndiciError {\n constructor (message) {\n super(message)\n Error.captureStackTrace(this, HeadersOverflowError)\n this.name = 'HeadersOverflowError'\n this.message = message || 'Headers Overflow Error'\n this.code = 'UND_ERR_HEADERS_OVERFLOW'\n }\n}\n\nclass BodyTimeoutError extends UndiciError {\n constructor (message) {\n super(message)\n Error.captureStackTrace(this, BodyTimeoutError)\n this.name = 'BodyTimeoutError'\n this.message = message || 'Body Timeout Error'\n this.code = 'UND_ERR_BODY_TIMEOUT'\n }\n}\n\nclass ResponseStatusCodeError extends UndiciError {\n constructor (message, statusCode, headers, body) {\n super(message)\n Error.captureStackTrace(this, ResponseStatusCodeError)\n this.name = 'ResponseStatusCodeError'\n this.message = message || 'Response Status Code Error'\n this.code = 'UND_ERR_RESPONSE_STATUS_CODE'\n this.body = body\n this.status = statusCode\n this.statusCode = statusCode\n this.headers = headers\n }\n}\n\nclass InvalidArgumentError extends UndiciError {\n constructor (message) {\n super(message)\n Error.captureStackTrace(this, InvalidArgumentError)\n this.name = 'InvalidArgumentError'\n this.message = message || 'Invalid Argument Error'\n this.code = 'UND_ERR_INVALID_ARG'\n }\n}\n\nclass InvalidReturnValueError extends UndiciError {\n constructor (message) {\n super(message)\n Error.captureStackTrace(this, InvalidReturnValueError)\n this.name = 'InvalidReturnValueError'\n this.message = message || 'Invalid Return Value Error'\n this.code = 'UND_ERR_INVALID_RETURN_VALUE'\n }\n}\n\nclass RequestAbortedError extends UndiciError {\n constructor (message) {\n super(message)\n Error.captureStackTrace(this, RequestAbortedError)\n this.name = 'AbortError'\n this.message = message || 'Request aborted'\n this.code = 'UND_ERR_ABORTED'\n }\n}\n\nclass InformationalError extends UndiciError {\n constructor (message) {\n super(message)\n Error.captureStackTrace(this, InformationalError)\n this.name = 'InformationalError'\n this.message = message || 'Request information'\n this.code = 'UND_ERR_INFO'\n }\n}\n\nclass RequestContentLengthMismatchError extends UndiciError {\n constructor (message) {\n super(message)\n Error.captureStackTrace(this, RequestContentLengthMismatchError)\n this.name = 'RequestContentLengthMismatchError'\n this.message = message || 'Request body length does not match content-length header'\n this.code = 'UND_ERR_REQ_CONTENT_LENGTH_MISMATCH'\n }\n}\n\nclass ResponseContentLengthMismatchError extends UndiciError {\n constructor (message) {\n super(message)\n Error.captureStackTrace(this, ResponseContentLengthMismatchError)\n this.name = 'ResponseContentLengthMismatchError'\n this.message = message || 'Response body length does not match content-length header'\n this.code = 'UND_ERR_RES_CONTENT_LENGTH_MISMATCH'\n }\n}\n\nclass ClientDestroyedError extends UndiciError {\n constructor (message) {\n super(message)\n Error.captureStackTrace(this, ClientDestroyedError)\n this.name = 'ClientDestroyedError'\n this.message = message || 'The client is destroyed'\n this.code = 'UND_ERR_DESTROYED'\n }\n}\n\nclass ClientClosedError extends UndiciError {\n constructor (message) {\n super(message)\n Error.captureStackTrace(this, ClientClosedError)\n this.name = 'ClientClosedError'\n this.message = message || 'The client is closed'\n this.code = 'UND_ERR_CLOSED'\n }\n}\n\nclass SocketError extends UndiciError {\n constructor (message, socket) {\n super(message)\n Error.captureStackTrace(this, SocketError)\n this.name = 'SocketError'\n this.message = message || 'Socket error'\n this.code = 'UND_ERR_SOCKET'\n this.socket = socket\n }\n}\n\nclass NotSupportedError extends UndiciError {\n constructor (message) {\n super(message)\n Error.captureStackTrace(this, NotSupportedError)\n this.name = 'NotSupportedError'\n this.message = message || 'Not supported error'\n this.code = 'UND_ERR_NOT_SUPPORTED'\n }\n}\n\nclass BalancedPoolMissingUpstreamError extends UndiciError {\n constructor (message) {\n super(message)\n Error.captureStackTrace(this, NotSupportedError)\n this.name = 'MissingUpstreamError'\n this.message = message || 'No upstream has been added to the BalancedPool'\n this.code = 'UND_ERR_BPL_MISSING_UPSTREAM'\n }\n}\n\nclass HTTPParserError extends Error {\n constructor (message, code, data) {\n super(message)\n Error.captureStackTrace(this, HTTPParserError)\n this.name = 'HTTPParserError'\n this.code = code ? `HPE_${code}` : undefined\n this.data = data ? data.toString() : undefined\n }\n}\n\nclass ResponseExceededMaxSizeError extends UndiciError {\n constructor (message) {\n super(message)\n Error.captureStackTrace(this, ResponseExceededMaxSizeError)\n this.name = 'ResponseExceededMaxSizeError'\n this.message = message || 'Response content exceeded max size'\n this.code = 'UND_ERR_RES_EXCEEDED_MAX_SIZE'\n }\n}\n\nclass RequestRetryError extends UndiciError {\n constructor (message, code, { headers, data }) {\n super(message)\n Error.captureStackTrace(this, RequestRetryError)\n this.name = 'RequestRetryError'\n this.message = message || 'Request retry error'\n this.code = 'UND_ERR_REQ_RETRY'\n this.statusCode = code\n this.data = data\n this.headers = headers\n }\n}\n\nmodule.exports = {\n HTTPParserError,\n UndiciError,\n HeadersTimeoutError,\n HeadersOverflowError,\n BodyTimeoutError,\n RequestContentLengthMismatchError,\n ConnectTimeoutError,\n ResponseStatusCodeError,\n InvalidArgumentError,\n InvalidReturnValueError,\n RequestAbortedError,\n ClientDestroyedError,\n ClientClosedError,\n InformationalError,\n SocketError,\n NotSupportedError,\n ResponseContentLengthMismatchError,\n BalancedPoolMissingUpstreamError,\n ResponseExceededMaxSizeError,\n RequestRetryError\n}\n","'use strict'\n\nconst {\n InvalidArgumentError,\n NotSupportedError\n} = require('./errors')\nconst assert = require('assert')\nconst { kHTTP2BuildRequest, kHTTP2CopyHeaders, kHTTP1BuildRequest } = require('./symbols')\nconst util = require('./util')\n\n// tokenRegExp and headerCharRegex have been lifted from\n// https://github.com/nodejs/node/blob/main/lib/_http_common.js\n\n/**\n * Verifies that the given val is a valid HTTP token\n * per the rules defined in RFC 7230\n * See https://tools.ietf.org/html/rfc7230#section-3.2.6\n */\nconst tokenRegExp = /^[\\^_`a-zA-Z\\-0-9!#$%&'*+.|~]+$/\n\n/**\n * Matches if val contains an invalid field-vchar\n * field-value = *( field-content / obs-fold )\n * field-content = field-vchar [ 1*( SP / HTAB ) field-vchar ]\n * field-vchar = VCHAR / obs-text\n */\nconst headerCharRegex = /[^\\t\\x20-\\x7e\\x80-\\xff]/\n\n// Verifies that a given path is valid does not contain control chars \\x00 to \\x20\nconst invalidPathRegex = /[^\\u0021-\\u00ff]/\n\nconst kHandler = Symbol('handler')\n\nconst channels = {}\n\nlet extractBody\n\ntry {\n const diagnosticsChannel = require('diagnostics_channel')\n channels.create = diagnosticsChannel.channel('undici:request:create')\n channels.bodySent = diagnosticsChannel.channel('undici:request:bodySent')\n channels.headers = diagnosticsChannel.channel('undici:request:headers')\n channels.trailers = diagnosticsChannel.channel('undici:request:trailers')\n channels.error = diagnosticsChannel.channel('undici:request:error')\n} catch {\n channels.create = { hasSubscribers: false }\n channels.bodySent = { hasSubscribers: false }\n channels.headers = { hasSubscribers: false }\n channels.trailers = { hasSubscribers: false }\n channels.error = { hasSubscribers: false }\n}\n\nclass Request {\n constructor (origin, {\n path,\n method,\n body,\n headers,\n query,\n idempotent,\n blocking,\n upgrade,\n headersTimeout,\n bodyTimeout,\n reset,\n throwOnError,\n expectContinue\n }, handler) {\n if (typeof path !== 'string') {\n throw new InvalidArgumentError('path must be a string')\n } else if (\n path[0] !== '/' &&\n !(path.startsWith('http://') || path.startsWith('https://')) &&\n method !== 'CONNECT'\n ) {\n throw new InvalidArgumentError('path must be an absolute URL or start with a slash')\n } else if (invalidPathRegex.exec(path) !== null) {\n throw new InvalidArgumentError('invalid request path')\n }\n\n if (typeof method !== 'string') {\n throw new InvalidArgumentError('method must be a string')\n } else if (tokenRegExp.exec(method) === null) {\n throw new InvalidArgumentError('invalid request method')\n }\n\n if (upgrade && typeof upgrade !== 'string') {\n throw new InvalidArgumentError('upgrade must be a string')\n }\n\n if (headersTimeout != null && (!Number.isFinite(headersTimeout) || headersTimeout < 0)) {\n throw new InvalidArgumentError('invalid headersTimeout')\n }\n\n if (bodyTimeout != null && (!Number.isFinite(bodyTimeout) || bodyTimeout < 0)) {\n throw new InvalidArgumentError('invalid bodyTimeout')\n }\n\n if (reset != null && typeof reset !== 'boolean') {\n throw new InvalidArgumentError('invalid reset')\n }\n\n if (expectContinue != null && typeof expectContinue !== 'boolean') {\n throw new InvalidArgumentError('invalid expectContinue')\n }\n\n this.headersTimeout = headersTimeout\n\n this.bodyTimeout = bodyTimeout\n\n this.throwOnError = throwOnError === true\n\n this.method = method\n\n this.abort = null\n\n if (body == null) {\n this.body = null\n } else if (util.isStream(body)) {\n this.body = body\n\n const rState = this.body._readableState\n if (!rState || !rState.autoDestroy) {\n this.endHandler = function autoDestroy () {\n util.destroy(this)\n }\n this.body.on('end', this.endHandler)\n }\n\n this.errorHandler = err => {\n if (this.abort) {\n this.abort(err)\n } else {\n this.error = err\n }\n }\n this.body.on('error', this.errorHandler)\n } else if (util.isBuffer(body)) {\n this.body = body.byteLength ? body : null\n } else if (ArrayBuffer.isView(body)) {\n this.body = body.buffer.byteLength ? Buffer.from(body.buffer, body.byteOffset, body.byteLength) : null\n } else if (body instanceof ArrayBuffer) {\n this.body = body.byteLength ? Buffer.from(body) : null\n } else if (typeof body === 'string') {\n this.body = body.length ? Buffer.from(body) : null\n } else if (util.isFormDataLike(body) || util.isIterable(body) || util.isBlobLike(body)) {\n this.body = body\n } else {\n throw new InvalidArgumentError('body must be a string, a Buffer, a Readable stream, an iterable, or an async iterable')\n }\n\n this.completed = false\n\n this.aborted = false\n\n this.upgrade = upgrade || null\n\n this.path = query ? util.buildURL(path, query) : path\n\n this.origin = origin\n\n this.idempotent = idempotent == null\n ? method === 'HEAD' || method === 'GET'\n : idempotent\n\n this.blocking = blocking == null ? false : blocking\n\n this.reset = reset == null ? null : reset\n\n this.host = null\n\n this.contentLength = null\n\n this.contentType = null\n\n this.headers = ''\n\n // Only for H2\n this.expectContinue = expectContinue != null ? expectContinue : false\n\n if (Array.isArray(headers)) {\n if (headers.length % 2 !== 0) {\n throw new InvalidArgumentError('headers array must be even')\n }\n for (let i = 0; i < headers.length; i += 2) {\n processHeader(this, headers[i], headers[i + 1])\n }\n } else if (headers && typeof headers === 'object') {\n const keys = Object.keys(headers)\n for (let i = 0; i < keys.length; i++) {\n const key = keys[i]\n processHeader(this, key, headers[key])\n }\n } else if (headers != null) {\n throw new InvalidArgumentError('headers must be an object or an array')\n }\n\n if (util.isFormDataLike(this.body)) {\n if (util.nodeMajor < 16 || (util.nodeMajor === 16 && util.nodeMinor < 8)) {\n throw new InvalidArgumentError('Form-Data bodies are only supported in node v16.8 and newer.')\n }\n\n if (!extractBody) {\n extractBody = require('../fetch/body.js').extractBody\n }\n\n const [bodyStream, contentType] = extractBody(body)\n if (this.contentType == null) {\n this.contentType = contentType\n this.headers += `content-type: ${contentType}\\r\\n`\n }\n this.body = bodyStream.stream\n this.contentLength = bodyStream.length\n } else if (util.isBlobLike(body) && this.contentType == null && body.type) {\n this.contentType = body.type\n this.headers += `content-type: ${body.type}\\r\\n`\n }\n\n util.validateHandler(handler, method, upgrade)\n\n this.servername = util.getServerName(this.host)\n\n this[kHandler] = handler\n\n if (channels.create.hasSubscribers) {\n channels.create.publish({ request: this })\n }\n }\n\n onBodySent (chunk) {\n if (this[kHandler].onBodySent) {\n try {\n return this[kHandler].onBodySent(chunk)\n } catch (err) {\n this.abort(err)\n }\n }\n }\n\n onRequestSent () {\n if (channels.bodySent.hasSubscribers) {\n channels.bodySent.publish({ request: this })\n }\n\n if (this[kHandler].onRequestSent) {\n try {\n return this[kHandler].onRequestSent()\n } catch (err) {\n this.abort(err)\n }\n }\n }\n\n onConnect (abort) {\n assert(!this.aborted)\n assert(!this.completed)\n\n if (this.error) {\n abort(this.error)\n } else {\n this.abort = abort\n return this[kHandler].onConnect(abort)\n }\n }\n\n onHeaders (statusCode, headers, resume, statusText) {\n assert(!this.aborted)\n assert(!this.completed)\n\n if (channels.headers.hasSubscribers) {\n channels.headers.publish({ request: this, response: { statusCode, headers, statusText } })\n }\n\n try {\n return this[kHandler].onHeaders(statusCode, headers, resume, statusText)\n } catch (err) {\n this.abort(err)\n }\n }\n\n onData (chunk) {\n assert(!this.aborted)\n assert(!this.completed)\n\n try {\n return this[kHandler].onData(chunk)\n } catch (err) {\n this.abort(err)\n return false\n }\n }\n\n onUpgrade (statusCode, headers, socket) {\n assert(!this.aborted)\n assert(!this.completed)\n\n return this[kHandler].onUpgrade(statusCode, headers, socket)\n }\n\n onComplete (trailers) {\n this.onFinally()\n\n assert(!this.aborted)\n\n this.completed = true\n if (channels.trailers.hasSubscribers) {\n channels.trailers.publish({ request: this, trailers })\n }\n\n try {\n return this[kHandler].onComplete(trailers)\n } catch (err) {\n // TODO (fix): This might be a bad idea?\n this.onError(err)\n }\n }\n\n onError (error) {\n this.onFinally()\n\n if (channels.error.hasSubscribers) {\n channels.error.publish({ request: this, error })\n }\n\n if (this.aborted) {\n return\n }\n this.aborted = true\n\n return this[kHandler].onError(error)\n }\n\n onFinally () {\n if (this.errorHandler) {\n this.body.off('error', this.errorHandler)\n this.errorHandler = null\n }\n\n if (this.endHandler) {\n this.body.off('end', this.endHandler)\n this.endHandler = null\n }\n }\n\n // TODO: adjust to support H2\n addHeader (key, value) {\n processHeader(this, key, value)\n return this\n }\n\n static [kHTTP1BuildRequest] (origin, opts, handler) {\n // TODO: Migrate header parsing here, to make Requests\n // HTTP agnostic\n return new Request(origin, opts, handler)\n }\n\n static [kHTTP2BuildRequest] (origin, opts, handler) {\n const headers = opts.headers\n opts = { ...opts, headers: null }\n\n const request = new Request(origin, opts, handler)\n\n request.headers = {}\n\n if (Array.isArray(headers)) {\n if (headers.length % 2 !== 0) {\n throw new InvalidArgumentError('headers array must be even')\n }\n for (let i = 0; i < headers.length; i += 2) {\n processHeader(request, headers[i], headers[i + 1], true)\n }\n } else if (headers && typeof headers === 'object') {\n const keys = Object.keys(headers)\n for (let i = 0; i < keys.length; i++) {\n const key = keys[i]\n processHeader(request, key, headers[key], true)\n }\n } else if (headers != null) {\n throw new InvalidArgumentError('headers must be an object or an array')\n }\n\n return request\n }\n\n static [kHTTP2CopyHeaders] (raw) {\n const rawHeaders = raw.split('\\r\\n')\n const headers = {}\n\n for (const header of rawHeaders) {\n const [key, value] = header.split(': ')\n\n if (value == null || value.length === 0) continue\n\n if (headers[key]) headers[key] += `,${value}`\n else headers[key] = value\n }\n\n return headers\n }\n}\n\nfunction processHeaderValue (key, val, skipAppend) {\n if (val && typeof val === 'object') {\n throw new InvalidArgumentError(`invalid ${key} header`)\n }\n\n val = val != null ? `${val}` : ''\n\n if (headerCharRegex.exec(val) !== null) {\n throw new InvalidArgumentError(`invalid ${key} header`)\n }\n\n return skipAppend ? val : `${key}: ${val}\\r\\n`\n}\n\nfunction processHeader (request, key, val, skipAppend = false) {\n if (val && (typeof val === 'object' && !Array.isArray(val))) {\n throw new InvalidArgumentError(`invalid ${key} header`)\n } else if (val === undefined) {\n return\n }\n\n if (\n request.host === null &&\n key.length === 4 &&\n key.toLowerCase() === 'host'\n ) {\n if (headerCharRegex.exec(val) !== null) {\n throw new InvalidArgumentError(`invalid ${key} header`)\n }\n // Consumed by Client\n request.host = val\n } else if (\n request.contentLength === null &&\n key.length === 14 &&\n key.toLowerCase() === 'content-length'\n ) {\n request.contentLength = parseInt(val, 10)\n if (!Number.isFinite(request.contentLength)) {\n throw new InvalidArgumentError('invalid content-length header')\n }\n } else if (\n request.contentType === null &&\n key.length === 12 &&\n key.toLowerCase() === 'content-type'\n ) {\n request.contentType = val\n if (skipAppend) request.headers[key] = processHeaderValue(key, val, skipAppend)\n else request.headers += processHeaderValue(key, val)\n } else if (\n key.length === 17 &&\n key.toLowerCase() === 'transfer-encoding'\n ) {\n throw new InvalidArgumentError('invalid transfer-encoding header')\n } else if (\n key.length === 10 &&\n key.toLowerCase() === 'connection'\n ) {\n const value = typeof val === 'string' ? val.toLowerCase() : null\n if (value !== 'close' && value !== 'keep-alive') {\n throw new InvalidArgumentError('invalid connection header')\n } else if (value === 'close') {\n request.reset = true\n }\n } else if (\n key.length === 10 &&\n key.toLowerCase() === 'keep-alive'\n ) {\n throw new InvalidArgumentError('invalid keep-alive header')\n } else if (\n key.length === 7 &&\n key.toLowerCase() === 'upgrade'\n ) {\n throw new InvalidArgumentError('invalid upgrade header')\n } else if (\n key.length === 6 &&\n key.toLowerCase() === 'expect'\n ) {\n throw new NotSupportedError('expect header not supported')\n } else if (tokenRegExp.exec(key) === null) {\n throw new InvalidArgumentError('invalid header key')\n } else {\n if (Array.isArray(val)) {\n for (let i = 0; i < val.length; i++) {\n if (skipAppend) {\n if (request.headers[key]) request.headers[key] += `,${processHeaderValue(key, val[i], skipAppend)}`\n else request.headers[key] = processHeaderValue(key, val[i], skipAppend)\n } else {\n request.headers += processHeaderValue(key, val[i])\n }\n }\n } else {\n if (skipAppend) request.headers[key] = processHeaderValue(key, val, skipAppend)\n else request.headers += processHeaderValue(key, val)\n }\n }\n}\n\nmodule.exports = Request\n","module.exports = {\n kClose: Symbol('close'),\n kDestroy: Symbol('destroy'),\n kDispatch: Symbol('dispatch'),\n kUrl: Symbol('url'),\n kWriting: Symbol('writing'),\n kResuming: Symbol('resuming'),\n kQueue: Symbol('queue'),\n kConnect: Symbol('connect'),\n kConnecting: Symbol('connecting'),\n kHeadersList: Symbol('headers list'),\n kKeepAliveDefaultTimeout: Symbol('default keep alive timeout'),\n kKeepAliveMaxTimeout: Symbol('max keep alive timeout'),\n kKeepAliveTimeoutThreshold: Symbol('keep alive timeout threshold'),\n kKeepAliveTimeoutValue: Symbol('keep alive timeout'),\n kKeepAlive: Symbol('keep alive'),\n kHeadersTimeout: Symbol('headers timeout'),\n kBodyTimeout: Symbol('body timeout'),\n kServerName: Symbol('server name'),\n kLocalAddress: Symbol('local address'),\n kHost: Symbol('host'),\n kNoRef: Symbol('no ref'),\n kBodyUsed: Symbol('used'),\n kRunning: Symbol('running'),\n kBlocking: Symbol('blocking'),\n kPending: Symbol('pending'),\n kSize: Symbol('size'),\n kBusy: Symbol('busy'),\n kQueued: Symbol('queued'),\n kFree: Symbol('free'),\n kConnected: Symbol('connected'),\n kClosed: Symbol('closed'),\n kNeedDrain: Symbol('need drain'),\n kReset: Symbol('reset'),\n kDestroyed: Symbol.for('nodejs.stream.destroyed'),\n kMaxHeadersSize: Symbol('max headers size'),\n kRunningIdx: Symbol('running index'),\n kPendingIdx: Symbol('pending index'),\n kError: Symbol('error'),\n kClients: Symbol('clients'),\n kClient: Symbol('client'),\n kParser: Symbol('parser'),\n kOnDestroyed: Symbol('destroy callbacks'),\n kPipelining: Symbol('pipelining'),\n kSocket: Symbol('socket'),\n kHostHeader: Symbol('host header'),\n kConnector: Symbol('connector'),\n kStrictContentLength: Symbol('strict content length'),\n kMaxRedirections: Symbol('maxRedirections'),\n kMaxRequests: Symbol('maxRequestsPerClient'),\n kProxy: Symbol('proxy agent options'),\n kCounter: Symbol('socket request counter'),\n kInterceptors: Symbol('dispatch interceptors'),\n kMaxResponseSize: Symbol('max response size'),\n kHTTP2Session: Symbol('http2Session'),\n kHTTP2SessionState: Symbol('http2Session state'),\n kHTTP2BuildRequest: Symbol('http2 build request'),\n kHTTP1BuildRequest: Symbol('http1 build request'),\n kHTTP2CopyHeaders: Symbol('http2 copy headers'),\n kHTTPConnVersion: Symbol('http connection version'),\n kRetryHandlerDefaultRetry: Symbol('retry agent default retry'),\n kConstruct: Symbol('constructable')\n}\n","'use strict'\n\nconst assert = require('assert')\nconst { kDestroyed, kBodyUsed } = require('./symbols')\nconst { IncomingMessage } = require('http')\nconst stream = require('stream')\nconst net = require('net')\nconst { InvalidArgumentError } = require('./errors')\nconst { Blob } = require('buffer')\nconst nodeUtil = require('util')\nconst { stringify } = require('querystring')\n\nconst [nodeMajor, nodeMinor] = process.versions.node.split('.').map(v => Number(v))\n\nfunction nop () {}\n\nfunction isStream (obj) {\n return obj && typeof obj === 'object' && typeof obj.pipe === 'function' && typeof obj.on === 'function'\n}\n\n// based on https://github.com/node-fetch/fetch-blob/blob/8ab587d34080de94140b54f07168451e7d0b655e/index.js#L229-L241 (MIT License)\nfunction isBlobLike (object) {\n return (Blob && object instanceof Blob) || (\n object &&\n typeof object === 'object' &&\n (typeof object.stream === 'function' ||\n typeof object.arrayBuffer === 'function') &&\n /^(Blob|File)$/.test(object[Symbol.toStringTag])\n )\n}\n\nfunction buildURL (url, queryParams) {\n if (url.includes('?') || url.includes('#')) {\n throw new Error('Query params cannot be passed when url already contains \"?\" or \"#\".')\n }\n\n const stringified = stringify(queryParams)\n\n if (stringified) {\n url += '?' + stringified\n }\n\n return url\n}\n\nfunction parseURL (url) {\n if (typeof url === 'string') {\n url = new URL(url)\n\n if (!/^https?:/.test(url.origin || url.protocol)) {\n throw new InvalidArgumentError('Invalid URL protocol: the URL must start with `http:` or `https:`.')\n }\n\n return url\n }\n\n if (!url || typeof url !== 'object') {\n throw new InvalidArgumentError('Invalid URL: The URL argument must be a non-null object.')\n }\n\n if (!/^https?:/.test(url.origin || url.protocol)) {\n throw new InvalidArgumentError('Invalid URL protocol: the URL must start with `http:` or `https:`.')\n }\n\n if (!(url instanceof URL)) {\n if (url.port != null && url.port !== '' && !Number.isFinite(parseInt(url.port))) {\n throw new InvalidArgumentError('Invalid URL: port must be a valid integer or a string representation of an integer.')\n }\n\n if (url.path != null && typeof url.path !== 'string') {\n throw new InvalidArgumentError('Invalid URL path: the path must be a string or null/undefined.')\n }\n\n if (url.pathname != null && typeof url.pathname !== 'string') {\n throw new InvalidArgumentError('Invalid URL pathname: the pathname must be a string or null/undefined.')\n }\n\n if (url.hostname != null && typeof url.hostname !== 'string') {\n throw new InvalidArgumentError('Invalid URL hostname: the hostname must be a string or null/undefined.')\n }\n\n if (url.origin != null && typeof url.origin !== 'string') {\n throw new InvalidArgumentError('Invalid URL origin: the origin must be a string or null/undefined.')\n }\n\n const port = url.port != null\n ? url.port\n : (url.protocol === 'https:' ? 443 : 80)\n let origin = url.origin != null\n ? url.origin\n : `${url.protocol}//${url.hostname}:${port}`\n let path = url.path != null\n ? url.path\n : `${url.pathname || ''}${url.search || ''}`\n\n if (origin.endsWith('/')) {\n origin = origin.substring(0, origin.length - 1)\n }\n\n if (path && !path.startsWith('/')) {\n path = `/${path}`\n }\n // new URL(path, origin) is unsafe when `path` contains an absolute URL\n // From https://developer.mozilla.org/en-US/docs/Web/API/URL/URL:\n // If first parameter is a relative URL, second param is required, and will be used as the base URL.\n // If first parameter is an absolute URL, a given second param will be ignored.\n url = new URL(origin + path)\n }\n\n return url\n}\n\nfunction parseOrigin (url) {\n url = parseURL(url)\n\n if (url.pathname !== '/' || url.search || url.hash) {\n throw new InvalidArgumentError('invalid url')\n }\n\n return url\n}\n\nfunction getHostname (host) {\n if (host[0] === '[') {\n const idx = host.indexOf(']')\n\n assert(idx !== -1)\n return host.substring(1, idx)\n }\n\n const idx = host.indexOf(':')\n if (idx === -1) return host\n\n return host.substring(0, idx)\n}\n\n// IP addresses are not valid server names per RFC6066\n// > Currently, the only server names supported are DNS hostnames\nfunction getServerName (host) {\n if (!host) {\n return null\n }\n\n assert.strictEqual(typeof host, 'string')\n\n const servername = getHostname(host)\n if (net.isIP(servername)) {\n return ''\n }\n\n return servername\n}\n\nfunction deepClone (obj) {\n return JSON.parse(JSON.stringify(obj))\n}\n\nfunction isAsyncIterable (obj) {\n return !!(obj != null && typeof obj[Symbol.asyncIterator] === 'function')\n}\n\nfunction isIterable (obj) {\n return !!(obj != null && (typeof obj[Symbol.iterator] === 'function' || typeof obj[Symbol.asyncIterator] === 'function'))\n}\n\nfunction bodyLength (body) {\n if (body == null) {\n return 0\n } else if (isStream(body)) {\n const state = body._readableState\n return state && state.objectMode === false && state.ended === true && Number.isFinite(state.length)\n ? state.length\n : null\n } else if (isBlobLike(body)) {\n return body.size != null ? body.size : null\n } else if (isBuffer(body)) {\n return body.byteLength\n }\n\n return null\n}\n\nfunction isDestroyed (stream) {\n return !stream || !!(stream.destroyed || stream[kDestroyed])\n}\n\nfunction isReadableAborted (stream) {\n const state = stream && stream._readableState\n return isDestroyed(stream) && state && !state.endEmitted\n}\n\nfunction destroy (stream, err) {\n if (stream == null || !isStream(stream) || isDestroyed(stream)) {\n return\n }\n\n if (typeof stream.destroy === 'function') {\n if (Object.getPrototypeOf(stream).constructor === IncomingMessage) {\n // See: https://github.com/nodejs/node/pull/38505/files\n stream.socket = null\n }\n\n stream.destroy(err)\n } else if (err) {\n process.nextTick((stream, err) => {\n stream.emit('error', err)\n }, stream, err)\n }\n\n if (stream.destroyed !== true) {\n stream[kDestroyed] = true\n }\n}\n\nconst KEEPALIVE_TIMEOUT_EXPR = /timeout=(\\d+)/\nfunction parseKeepAliveTimeout (val) {\n const m = val.toString().match(KEEPALIVE_TIMEOUT_EXPR)\n return m ? parseInt(m[1], 10) * 1000 : null\n}\n\nfunction parseHeaders (headers, obj = {}) {\n // For H2 support\n if (!Array.isArray(headers)) return headers\n\n for (let i = 0; i < headers.length; i += 2) {\n const key = headers[i].toString().toLowerCase()\n let val = obj[key]\n\n if (!val) {\n if (Array.isArray(headers[i + 1])) {\n obj[key] = headers[i + 1].map(x => x.toString('utf8'))\n } else {\n obj[key] = headers[i + 1].toString('utf8')\n }\n } else {\n if (!Array.isArray(val)) {\n val = [val]\n obj[key] = val\n }\n val.push(headers[i + 1].toString('utf8'))\n }\n }\n\n // See https://github.com/nodejs/node/pull/46528\n if ('content-length' in obj && 'content-disposition' in obj) {\n obj['content-disposition'] = Buffer.from(obj['content-disposition']).toString('latin1')\n }\n\n return obj\n}\n\nfunction parseRawHeaders (headers) {\n const ret = []\n let hasContentLength = false\n let contentDispositionIdx = -1\n\n for (let n = 0; n < headers.length; n += 2) {\n const key = headers[n + 0].toString()\n const val = headers[n + 1].toString('utf8')\n\n if (key.length === 14 && (key === 'content-length' || key.toLowerCase() === 'content-length')) {\n ret.push(key, val)\n hasContentLength = true\n } else if (key.length === 19 && (key === 'content-disposition' || key.toLowerCase() === 'content-disposition')) {\n contentDispositionIdx = ret.push(key, val) - 1\n } else {\n ret.push(key, val)\n }\n }\n\n // See https://github.com/nodejs/node/pull/46528\n if (hasContentLength && contentDispositionIdx !== -1) {\n ret[contentDispositionIdx] = Buffer.from(ret[contentDispositionIdx]).toString('latin1')\n }\n\n return ret\n}\n\nfunction isBuffer (buffer) {\n // See, https://github.com/mcollina/undici/pull/319\n return buffer instanceof Uint8Array || Buffer.isBuffer(buffer)\n}\n\nfunction validateHandler (handler, method, upgrade) {\n if (!handler || typeof handler !== 'object') {\n throw new InvalidArgumentError('handler must be an object')\n }\n\n if (typeof handler.onConnect !== 'function') {\n throw new InvalidArgumentError('invalid onConnect method')\n }\n\n if (typeof handler.onError !== 'function') {\n throw new InvalidArgumentError('invalid onError method')\n }\n\n if (typeof handler.onBodySent !== 'function' && handler.onBodySent !== undefined) {\n throw new InvalidArgumentError('invalid onBodySent method')\n }\n\n if (upgrade || method === 'CONNECT') {\n if (typeof handler.onUpgrade !== 'function') {\n throw new InvalidArgumentError('invalid onUpgrade method')\n }\n } else {\n if (typeof handler.onHeaders !== 'function') {\n throw new InvalidArgumentError('invalid onHeaders method')\n }\n\n if (typeof handler.onData !== 'function') {\n throw new InvalidArgumentError('invalid onData method')\n }\n\n if (typeof handler.onComplete !== 'function') {\n throw new InvalidArgumentError('invalid onComplete method')\n }\n }\n}\n\n// A body is disturbed if it has been read from and it cannot\n// be re-used without losing state or data.\nfunction isDisturbed (body) {\n return !!(body && (\n stream.isDisturbed\n ? stream.isDisturbed(body) || body[kBodyUsed] // TODO (fix): Why is body[kBodyUsed] needed?\n : body[kBodyUsed] ||\n body.readableDidRead ||\n (body._readableState && body._readableState.dataEmitted) ||\n isReadableAborted(body)\n ))\n}\n\nfunction isErrored (body) {\n return !!(body && (\n stream.isErrored\n ? stream.isErrored(body)\n : /state: 'errored'/.test(nodeUtil.inspect(body)\n )))\n}\n\nfunction isReadable (body) {\n return !!(body && (\n stream.isReadable\n ? stream.isReadable(body)\n : /state: 'readable'/.test(nodeUtil.inspect(body)\n )))\n}\n\nfunction getSocketInfo (socket) {\n return {\n localAddress: socket.localAddress,\n localPort: socket.localPort,\n remoteAddress: socket.remoteAddress,\n remotePort: socket.remotePort,\n remoteFamily: socket.remoteFamily,\n timeout: socket.timeout,\n bytesWritten: socket.bytesWritten,\n bytesRead: socket.bytesRead\n }\n}\n\nasync function * convertIterableToBuffer (iterable) {\n for await (const chunk of iterable) {\n yield Buffer.isBuffer(chunk) ? chunk : Buffer.from(chunk)\n }\n}\n\nlet ReadableStream\nfunction ReadableStreamFrom (iterable) {\n if (!ReadableStream) {\n ReadableStream = require('stream/web').ReadableStream\n }\n\n if (ReadableStream.from) {\n return ReadableStream.from(convertIterableToBuffer(iterable))\n }\n\n let iterator\n return new ReadableStream(\n {\n async start () {\n iterator = iterable[Symbol.asyncIterator]()\n },\n async pull (controller) {\n const { done, value } = await iterator.next()\n if (done) {\n queueMicrotask(() => {\n controller.close()\n })\n } else {\n const buf = Buffer.isBuffer(value) ? value : Buffer.from(value)\n controller.enqueue(new Uint8Array(buf))\n }\n return controller.desiredSize > 0\n },\n async cancel (reason) {\n await iterator.return()\n }\n },\n 0\n )\n}\n\n// The chunk should be a FormData instance and contains\n// all the required methods.\nfunction isFormDataLike (object) {\n return (\n object &&\n typeof object === 'object' &&\n typeof object.append === 'function' &&\n typeof object.delete === 'function' &&\n typeof object.get === 'function' &&\n typeof object.getAll === 'function' &&\n typeof object.has === 'function' &&\n typeof object.set === 'function' &&\n object[Symbol.toStringTag] === 'FormData'\n )\n}\n\nfunction throwIfAborted (signal) {\n if (!signal) { return }\n if (typeof signal.throwIfAborted === 'function') {\n signal.throwIfAborted()\n } else {\n if (signal.aborted) {\n // DOMException not available < v17.0.0\n const err = new Error('The operation was aborted')\n err.name = 'AbortError'\n throw err\n }\n }\n}\n\nfunction addAbortListener (signal, listener) {\n if ('addEventListener' in signal) {\n signal.addEventListener('abort', listener, { once: true })\n return () => signal.removeEventListener('abort', listener)\n }\n signal.addListener('abort', listener)\n return () => signal.removeListener('abort', listener)\n}\n\nconst hasToWellFormed = !!String.prototype.toWellFormed\n\n/**\n * @param {string} val\n */\nfunction toUSVString (val) {\n if (hasToWellFormed) {\n return `${val}`.toWellFormed()\n } else if (nodeUtil.toUSVString) {\n return nodeUtil.toUSVString(val)\n }\n\n return `${val}`\n}\n\n// Parsed accordingly to RFC 9110\n// https://www.rfc-editor.org/rfc/rfc9110#field.content-range\nfunction parseRangeHeader (range) {\n if (range == null || range === '') return { start: 0, end: null, size: null }\n\n const m = range ? range.match(/^bytes (\\d+)-(\\d+)\\/(\\d+)?$/) : null\n return m\n ? {\n start: parseInt(m[1]),\n end: m[2] ? parseInt(m[2]) : null,\n size: m[3] ? parseInt(m[3]) : null\n }\n : null\n}\n\nconst kEnumerableProperty = Object.create(null)\nkEnumerableProperty.enumerable = true\n\nmodule.exports = {\n kEnumerableProperty,\n nop,\n isDisturbed,\n isErrored,\n isReadable,\n toUSVString,\n isReadableAborted,\n isBlobLike,\n parseOrigin,\n parseURL,\n getServerName,\n isStream,\n isIterable,\n isAsyncIterable,\n isDestroyed,\n parseRawHeaders,\n parseHeaders,\n parseKeepAliveTimeout,\n destroy,\n bodyLength,\n deepClone,\n ReadableStreamFrom,\n isBuffer,\n validateHandler,\n getSocketInfo,\n isFormDataLike,\n buildURL,\n throwIfAborted,\n addAbortListener,\n parseRangeHeader,\n nodeMajor,\n nodeMinor,\n nodeHasAutoSelectFamily: nodeMajor > 18 || (nodeMajor === 18 && nodeMinor >= 13),\n safeHTTPMethods: ['GET', 'HEAD', 'OPTIONS', 'TRACE']\n}\n","'use strict'\n\nconst Dispatcher = require('./dispatcher')\nconst {\n ClientDestroyedError,\n ClientClosedError,\n InvalidArgumentError\n} = require('./core/errors')\nconst { kDestroy, kClose, kDispatch, kInterceptors } = require('./core/symbols')\n\nconst kDestroyed = Symbol('destroyed')\nconst kClosed = Symbol('closed')\nconst kOnDestroyed = Symbol('onDestroyed')\nconst kOnClosed = Symbol('onClosed')\nconst kInterceptedDispatch = Symbol('Intercepted Dispatch')\n\nclass DispatcherBase extends Dispatcher {\n constructor () {\n super()\n\n this[kDestroyed] = false\n this[kOnDestroyed] = null\n this[kClosed] = false\n this[kOnClosed] = []\n }\n\n get destroyed () {\n return this[kDestroyed]\n }\n\n get closed () {\n return this[kClosed]\n }\n\n get interceptors () {\n return this[kInterceptors]\n }\n\n set interceptors (newInterceptors) {\n if (newInterceptors) {\n for (let i = newInterceptors.length - 1; i >= 0; i--) {\n const interceptor = this[kInterceptors][i]\n if (typeof interceptor !== 'function') {\n throw new InvalidArgumentError('interceptor must be an function')\n }\n }\n }\n\n this[kInterceptors] = newInterceptors\n }\n\n close (callback) {\n if (callback === undefined) {\n return new Promise((resolve, reject) => {\n this.close((err, data) => {\n return err ? reject(err) : resolve(data)\n })\n })\n }\n\n if (typeof callback !== 'function') {\n throw new InvalidArgumentError('invalid callback')\n }\n\n if (this[kDestroyed]) {\n queueMicrotask(() => callback(new ClientDestroyedError(), null))\n return\n }\n\n if (this[kClosed]) {\n if (this[kOnClosed]) {\n this[kOnClosed].push(callback)\n } else {\n queueMicrotask(() => callback(null, null))\n }\n return\n }\n\n this[kClosed] = true\n this[kOnClosed].push(callback)\n\n const onClosed = () => {\n const callbacks = this[kOnClosed]\n this[kOnClosed] = null\n for (let i = 0; i < callbacks.length; i++) {\n callbacks[i](null, null)\n }\n }\n\n // Should not error.\n this[kClose]()\n .then(() => this.destroy())\n .then(() => {\n queueMicrotask(onClosed)\n })\n }\n\n destroy (err, callback) {\n if (typeof err === 'function') {\n callback = err\n err = null\n }\n\n if (callback === undefined) {\n return new Promise((resolve, reject) => {\n this.destroy(err, (err, data) => {\n return err ? /* istanbul ignore next: should never error */ reject(err) : resolve(data)\n })\n })\n }\n\n if (typeof callback !== 'function') {\n throw new InvalidArgumentError('invalid callback')\n }\n\n if (this[kDestroyed]) {\n if (this[kOnDestroyed]) {\n this[kOnDestroyed].push(callback)\n } else {\n queueMicrotask(() => callback(null, null))\n }\n return\n }\n\n if (!err) {\n err = new ClientDestroyedError()\n }\n\n this[kDestroyed] = true\n this[kOnDestroyed] = this[kOnDestroyed] || []\n this[kOnDestroyed].push(callback)\n\n const onDestroyed = () => {\n const callbacks = this[kOnDestroyed]\n this[kOnDestroyed] = null\n for (let i = 0; i < callbacks.length; i++) {\n callbacks[i](null, null)\n }\n }\n\n // Should not error.\n this[kDestroy](err).then(() => {\n queueMicrotask(onDestroyed)\n })\n }\n\n [kInterceptedDispatch] (opts, handler) {\n if (!this[kInterceptors] || this[kInterceptors].length === 0) {\n this[kInterceptedDispatch] = this[kDispatch]\n return this[kDispatch](opts, handler)\n }\n\n let dispatch = this[kDispatch].bind(this)\n for (let i = this[kInterceptors].length - 1; i >= 0; i--) {\n dispatch = this[kInterceptors][i](dispatch)\n }\n this[kInterceptedDispatch] = dispatch\n return dispatch(opts, handler)\n }\n\n dispatch (opts, handler) {\n if (!handler || typeof handler !== 'object') {\n throw new InvalidArgumentError('handler must be an object')\n }\n\n try {\n if (!opts || typeof opts !== 'object') {\n throw new InvalidArgumentError('opts must be an object.')\n }\n\n if (this[kDestroyed] || this[kOnDestroyed]) {\n throw new ClientDestroyedError()\n }\n\n if (this[kClosed]) {\n throw new ClientClosedError()\n }\n\n return this[kInterceptedDispatch](opts, handler)\n } catch (err) {\n if (typeof handler.onError !== 'function') {\n throw new InvalidArgumentError('invalid onError method')\n }\n\n handler.onError(err)\n\n return false\n }\n }\n}\n\nmodule.exports = DispatcherBase\n","'use strict'\n\nconst EventEmitter = require('events')\n\nclass Dispatcher extends EventEmitter {\n dispatch () {\n throw new Error('not implemented')\n }\n\n close () {\n throw new Error('not implemented')\n }\n\n destroy () {\n throw new Error('not implemented')\n }\n}\n\nmodule.exports = Dispatcher\n","'use strict'\n\nconst Busboy = require('@fastify/busboy')\nconst util = require('../core/util')\nconst {\n ReadableStreamFrom,\n isBlobLike,\n isReadableStreamLike,\n readableStreamClose,\n createDeferredPromise,\n fullyReadBody\n} = require('./util')\nconst { FormData } = require('./formdata')\nconst { kState } = require('./symbols')\nconst { webidl } = require('./webidl')\nconst { DOMException, structuredClone } = require('./constants')\nconst { Blob, File: NativeFile } = require('buffer')\nconst { kBodyUsed } = require('../core/symbols')\nconst assert = require('assert')\nconst { isErrored } = require('../core/util')\nconst { isUint8Array, isArrayBuffer } = require('util/types')\nconst { File: UndiciFile } = require('./file')\nconst { parseMIMEType, serializeAMimeType } = require('./dataURL')\n\nlet ReadableStream = globalThis.ReadableStream\n\n/** @type {globalThis['File']} */\nconst File = NativeFile ?? UndiciFile\nconst textEncoder = new TextEncoder()\nconst textDecoder = new TextDecoder()\n\n// https://fetch.spec.whatwg.org/#concept-bodyinit-extract\nfunction extractBody (object, keepalive = false) {\n if (!ReadableStream) {\n ReadableStream = require('stream/web').ReadableStream\n }\n\n // 1. Let stream be null.\n let stream = null\n\n // 2. If object is a ReadableStream object, then set stream to object.\n if (object instanceof ReadableStream) {\n stream = object\n } else if (isBlobLike(object)) {\n // 3. Otherwise, if object is a Blob object, set stream to the\n // result of running object’s get stream.\n stream = object.stream()\n } else {\n // 4. Otherwise, set stream to a new ReadableStream object, and set\n // up stream.\n stream = new ReadableStream({\n async pull (controller) {\n controller.enqueue(\n typeof source === 'string' ? textEncoder.encode(source) : source\n )\n queueMicrotask(() => readableStreamClose(controller))\n },\n start () {},\n type: undefined\n })\n }\n\n // 5. Assert: stream is a ReadableStream object.\n assert(isReadableStreamLike(stream))\n\n // 6. Let action be null.\n let action = null\n\n // 7. Let source be null.\n let source = null\n\n // 8. Let length be null.\n let length = null\n\n // 9. Let type be null.\n let type = null\n\n // 10. Switch on object:\n if (typeof object === 'string') {\n // Set source to the UTF-8 encoding of object.\n // Note: setting source to a Uint8Array here breaks some mocking assumptions.\n source = object\n\n // Set type to `text/plain;charset=UTF-8`.\n type = 'text/plain;charset=UTF-8'\n } else if (object instanceof URLSearchParams) {\n // URLSearchParams\n\n // spec says to run application/x-www-form-urlencoded on body.list\n // this is implemented in Node.js as apart of an URLSearchParams instance toString method\n // See: https://github.com/nodejs/node/blob/e46c680bf2b211bbd52cf959ca17ee98c7f657f5/lib/internal/url.js#L490\n // and https://github.com/nodejs/node/blob/e46c680bf2b211bbd52cf959ca17ee98c7f657f5/lib/internal/url.js#L1100\n\n // Set source to the result of running the application/x-www-form-urlencoded serializer with object’s list.\n source = object.toString()\n\n // Set type to `application/x-www-form-urlencoded;charset=UTF-8`.\n type = 'application/x-www-form-urlencoded;charset=UTF-8'\n } else if (isArrayBuffer(object)) {\n // BufferSource/ArrayBuffer\n\n // Set source to a copy of the bytes held by object.\n source = new Uint8Array(object.slice())\n } else if (ArrayBuffer.isView(object)) {\n // BufferSource/ArrayBufferView\n\n // Set source to a copy of the bytes held by object.\n source = new Uint8Array(object.buffer.slice(object.byteOffset, object.byteOffset + object.byteLength))\n } else if (util.isFormDataLike(object)) {\n const boundary = `----formdata-undici-0${`${Math.floor(Math.random() * 1e11)}`.padStart(11, '0')}`\n const prefix = `--${boundary}\\r\\nContent-Disposition: form-data`\n\n /*! formdata-polyfill. MIT License. Jimmy Wärting */\n const escape = (str) =>\n str.replace(/\\n/g, '%0A').replace(/\\r/g, '%0D').replace(/\"/g, '%22')\n const normalizeLinefeeds = (value) => value.replace(/\\r?\\n|\\r/g, '\\r\\n')\n\n // Set action to this step: run the multipart/form-data\n // encoding algorithm, with object’s entry list and UTF-8.\n // - This ensures that the body is immutable and can't be changed afterwords\n // - That the content-length is calculated in advance.\n // - And that all parts are pre-encoded and ready to be sent.\n\n const blobParts = []\n const rn = new Uint8Array([13, 10]) // '\\r\\n'\n length = 0\n let hasUnknownSizeValue = false\n\n for (const [name, value] of object) {\n if (typeof value === 'string') {\n const chunk = textEncoder.encode(prefix +\n `; name=\"${escape(normalizeLinefeeds(name))}\"` +\n `\\r\\n\\r\\n${normalizeLinefeeds(value)}\\r\\n`)\n blobParts.push(chunk)\n length += chunk.byteLength\n } else {\n const chunk = textEncoder.encode(`${prefix}; name=\"${escape(normalizeLinefeeds(name))}\"` +\n (value.name ? `; filename=\"${escape(value.name)}\"` : '') + '\\r\\n' +\n `Content-Type: ${\n value.type || 'application/octet-stream'\n }\\r\\n\\r\\n`)\n blobParts.push(chunk, value, rn)\n if (typeof value.size === 'number') {\n length += chunk.byteLength + value.size + rn.byteLength\n } else {\n hasUnknownSizeValue = true\n }\n }\n }\n\n const chunk = textEncoder.encode(`--${boundary}--`)\n blobParts.push(chunk)\n length += chunk.byteLength\n if (hasUnknownSizeValue) {\n length = null\n }\n\n // Set source to object.\n source = object\n\n action = async function * () {\n for (const part of blobParts) {\n if (part.stream) {\n yield * part.stream()\n } else {\n yield part\n }\n }\n }\n\n // Set type to `multipart/form-data; boundary=`,\n // followed by the multipart/form-data boundary string generated\n // by the multipart/form-data encoding algorithm.\n type = 'multipart/form-data; boundary=' + boundary\n } else if (isBlobLike(object)) {\n // Blob\n\n // Set source to object.\n source = object\n\n // Set length to object’s size.\n length = object.size\n\n // If object’s type attribute is not the empty byte sequence, set\n // type to its value.\n if (object.type) {\n type = object.type\n }\n } else if (typeof object[Symbol.asyncIterator] === 'function') {\n // If keepalive is true, then throw a TypeError.\n if (keepalive) {\n throw new TypeError('keepalive')\n }\n\n // If object is disturbed or locked, then throw a TypeError.\n if (util.isDisturbed(object) || object.locked) {\n throw new TypeError(\n 'Response body object should not be disturbed or locked'\n )\n }\n\n stream =\n object instanceof ReadableStream ? object : ReadableStreamFrom(object)\n }\n\n // 11. If source is a byte sequence, then set action to a\n // step that returns source and length to source’s length.\n if (typeof source === 'string' || util.isBuffer(source)) {\n length = Buffer.byteLength(source)\n }\n\n // 12. If action is non-null, then run these steps in in parallel:\n if (action != null) {\n // Run action.\n let iterator\n stream = new ReadableStream({\n async start () {\n iterator = action(object)[Symbol.asyncIterator]()\n },\n async pull (controller) {\n const { value, done } = await iterator.next()\n if (done) {\n // When running action is done, close stream.\n queueMicrotask(() => {\n controller.close()\n })\n } else {\n // Whenever one or more bytes are available and stream is not errored,\n // enqueue a Uint8Array wrapping an ArrayBuffer containing the available\n // bytes into stream.\n if (!isErrored(stream)) {\n controller.enqueue(new Uint8Array(value))\n }\n }\n return controller.desiredSize > 0\n },\n async cancel (reason) {\n await iterator.return()\n },\n type: undefined\n })\n }\n\n // 13. Let body be a body whose stream is stream, source is source,\n // and length is length.\n const body = { stream, source, length }\n\n // 14. Return (body, type).\n return [body, type]\n}\n\n// https://fetch.spec.whatwg.org/#bodyinit-safely-extract\nfunction safelyExtractBody (object, keepalive = false) {\n if (!ReadableStream) {\n // istanbul ignore next\n ReadableStream = require('stream/web').ReadableStream\n }\n\n // To safely extract a body and a `Content-Type` value from\n // a byte sequence or BodyInit object object, run these steps:\n\n // 1. If object is a ReadableStream object, then:\n if (object instanceof ReadableStream) {\n // Assert: object is neither disturbed nor locked.\n // istanbul ignore next\n assert(!util.isDisturbed(object), 'The body has already been consumed.')\n // istanbul ignore next\n assert(!object.locked, 'The stream is locked.')\n }\n\n // 2. Return the results of extracting object.\n return extractBody(object, keepalive)\n}\n\nfunction cloneBody (body) {\n // To clone a body body, run these steps:\n\n // https://fetch.spec.whatwg.org/#concept-body-clone\n\n // 1. Let « out1, out2 » be the result of teeing body’s stream.\n const [out1, out2] = body.stream.tee()\n const out2Clone = structuredClone(out2, { transfer: [out2] })\n // This, for whatever reasons, unrefs out2Clone which allows\n // the process to exit by itself.\n const [, finalClone] = out2Clone.tee()\n\n // 2. Set body’s stream to out1.\n body.stream = out1\n\n // 3. Return a body whose stream is out2 and other members are copied from body.\n return {\n stream: finalClone,\n length: body.length,\n source: body.source\n }\n}\n\nasync function * consumeBody (body) {\n if (body) {\n if (isUint8Array(body)) {\n yield body\n } else {\n const stream = body.stream\n\n if (util.isDisturbed(stream)) {\n throw new TypeError('The body has already been consumed.')\n }\n\n if (stream.locked) {\n throw new TypeError('The stream is locked.')\n }\n\n // Compat.\n stream[kBodyUsed] = true\n\n yield * stream\n }\n }\n}\n\nfunction throwIfAborted (state) {\n if (state.aborted) {\n throw new DOMException('The operation was aborted.', 'AbortError')\n }\n}\n\nfunction bodyMixinMethods (instance) {\n const methods = {\n blob () {\n // The blob() method steps are to return the result of\n // running consume body with this and the following step\n // given a byte sequence bytes: return a Blob whose\n // contents are bytes and whose type attribute is this’s\n // MIME type.\n return specConsumeBody(this, (bytes) => {\n let mimeType = bodyMimeType(this)\n\n if (mimeType === 'failure') {\n mimeType = ''\n } else if (mimeType) {\n mimeType = serializeAMimeType(mimeType)\n }\n\n // Return a Blob whose contents are bytes and type attribute\n // is mimeType.\n return new Blob([bytes], { type: mimeType })\n }, instance)\n },\n\n arrayBuffer () {\n // The arrayBuffer() method steps are to return the result\n // of running consume body with this and the following step\n // given a byte sequence bytes: return a new ArrayBuffer\n // whose contents are bytes.\n return specConsumeBody(this, (bytes) => {\n return new Uint8Array(bytes).buffer\n }, instance)\n },\n\n text () {\n // The text() method steps are to return the result of running\n // consume body with this and UTF-8 decode.\n return specConsumeBody(this, utf8DecodeBytes, instance)\n },\n\n json () {\n // The json() method steps are to return the result of running\n // consume body with this and parse JSON from bytes.\n return specConsumeBody(this, parseJSONFromBytes, instance)\n },\n\n async formData () {\n webidl.brandCheck(this, instance)\n\n throwIfAborted(this[kState])\n\n const contentType = this.headers.get('Content-Type')\n\n // If mimeType’s essence is \"multipart/form-data\", then:\n if (/multipart\\/form-data/.test(contentType)) {\n const headers = {}\n for (const [key, value] of this.headers) headers[key.toLowerCase()] = value\n\n const responseFormData = new FormData()\n\n let busboy\n\n try {\n busboy = new Busboy({\n headers,\n preservePath: true\n })\n } catch (err) {\n throw new DOMException(`${err}`, 'AbortError')\n }\n\n busboy.on('field', (name, value) => {\n responseFormData.append(name, value)\n })\n busboy.on('file', (name, value, filename, encoding, mimeType) => {\n const chunks = []\n\n if (encoding === 'base64' || encoding.toLowerCase() === 'base64') {\n let base64chunk = ''\n\n value.on('data', (chunk) => {\n base64chunk += chunk.toString().replace(/[\\r\\n]/gm, '')\n\n const end = base64chunk.length - base64chunk.length % 4\n chunks.push(Buffer.from(base64chunk.slice(0, end), 'base64'))\n\n base64chunk = base64chunk.slice(end)\n })\n value.on('end', () => {\n chunks.push(Buffer.from(base64chunk, 'base64'))\n responseFormData.append(name, new File(chunks, filename, { type: mimeType }))\n })\n } else {\n value.on('data', (chunk) => {\n chunks.push(chunk)\n })\n value.on('end', () => {\n responseFormData.append(name, new File(chunks, filename, { type: mimeType }))\n })\n }\n })\n\n const busboyResolve = new Promise((resolve, reject) => {\n busboy.on('finish', resolve)\n busboy.on('error', (err) => reject(new TypeError(err)))\n })\n\n if (this.body !== null) for await (const chunk of consumeBody(this[kState].body)) busboy.write(chunk)\n busboy.end()\n await busboyResolve\n\n return responseFormData\n } else if (/application\\/x-www-form-urlencoded/.test(contentType)) {\n // Otherwise, if mimeType’s essence is \"application/x-www-form-urlencoded\", then:\n\n // 1. Let entries be the result of parsing bytes.\n let entries\n try {\n let text = ''\n // application/x-www-form-urlencoded parser will keep the BOM.\n // https://url.spec.whatwg.org/#concept-urlencoded-parser\n // Note that streaming decoder is stateful and cannot be reused\n const streamingDecoder = new TextDecoder('utf-8', { ignoreBOM: true })\n\n for await (const chunk of consumeBody(this[kState].body)) {\n if (!isUint8Array(chunk)) {\n throw new TypeError('Expected Uint8Array chunk')\n }\n text += streamingDecoder.decode(chunk, { stream: true })\n }\n text += streamingDecoder.decode()\n entries = new URLSearchParams(text)\n } catch (err) {\n // istanbul ignore next: Unclear when new URLSearchParams can fail on a string.\n // 2. If entries is failure, then throw a TypeError.\n throw Object.assign(new TypeError(), { cause: err })\n }\n\n // 3. Return a new FormData object whose entries are entries.\n const formData = new FormData()\n for (const [name, value] of entries) {\n formData.append(name, value)\n }\n return formData\n } else {\n // Wait a tick before checking if the request has been aborted.\n // Otherwise, a TypeError can be thrown when an AbortError should.\n await Promise.resolve()\n\n throwIfAborted(this[kState])\n\n // Otherwise, throw a TypeError.\n throw webidl.errors.exception({\n header: `${instance.name}.formData`,\n message: 'Could not parse content as FormData.'\n })\n }\n }\n }\n\n return methods\n}\n\nfunction mixinBody (prototype) {\n Object.assign(prototype.prototype, bodyMixinMethods(prototype))\n}\n\n/**\n * @see https://fetch.spec.whatwg.org/#concept-body-consume-body\n * @param {Response|Request} object\n * @param {(value: unknown) => unknown} convertBytesToJSValue\n * @param {Response|Request} instance\n */\nasync function specConsumeBody (object, convertBytesToJSValue, instance) {\n webidl.brandCheck(object, instance)\n\n throwIfAborted(object[kState])\n\n // 1. If object is unusable, then return a promise rejected\n // with a TypeError.\n if (bodyUnusable(object[kState].body)) {\n throw new TypeError('Body is unusable')\n }\n\n // 2. Let promise be a new promise.\n const promise = createDeferredPromise()\n\n // 3. Let errorSteps given error be to reject promise with error.\n const errorSteps = (error) => promise.reject(error)\n\n // 4. Let successSteps given a byte sequence data be to resolve\n // promise with the result of running convertBytesToJSValue\n // with data. If that threw an exception, then run errorSteps\n // with that exception.\n const successSteps = (data) => {\n try {\n promise.resolve(convertBytesToJSValue(data))\n } catch (e) {\n errorSteps(e)\n }\n }\n\n // 5. If object’s body is null, then run successSteps with an\n // empty byte sequence.\n if (object[kState].body == null) {\n successSteps(new Uint8Array())\n return promise.promise\n }\n\n // 6. Otherwise, fully read object’s body given successSteps,\n // errorSteps, and object’s relevant global object.\n await fullyReadBody(object[kState].body, successSteps, errorSteps)\n\n // 7. Return promise.\n return promise.promise\n}\n\n// https://fetch.spec.whatwg.org/#body-unusable\nfunction bodyUnusable (body) {\n // An object including the Body interface mixin is\n // said to be unusable if its body is non-null and\n // its body’s stream is disturbed or locked.\n return body != null && (body.stream.locked || util.isDisturbed(body.stream))\n}\n\n/**\n * @see https://encoding.spec.whatwg.org/#utf-8-decode\n * @param {Buffer} buffer\n */\nfunction utf8DecodeBytes (buffer) {\n if (buffer.length === 0) {\n return ''\n }\n\n // 1. Let buffer be the result of peeking three bytes from\n // ioQueue, converted to a byte sequence.\n\n // 2. If buffer is 0xEF 0xBB 0xBF, then read three\n // bytes from ioQueue. (Do nothing with those bytes.)\n if (buffer[0] === 0xEF && buffer[1] === 0xBB && buffer[2] === 0xBF) {\n buffer = buffer.subarray(3)\n }\n\n // 3. Process a queue with an instance of UTF-8’s\n // decoder, ioQueue, output, and \"replacement\".\n const output = textDecoder.decode(buffer)\n\n // 4. Return output.\n return output\n}\n\n/**\n * @see https://infra.spec.whatwg.org/#parse-json-bytes-to-a-javascript-value\n * @param {Uint8Array} bytes\n */\nfunction parseJSONFromBytes (bytes) {\n return JSON.parse(utf8DecodeBytes(bytes))\n}\n\n/**\n * @see https://fetch.spec.whatwg.org/#concept-body-mime-type\n * @param {import('./response').Response|import('./request').Request} object\n */\nfunction bodyMimeType (object) {\n const { headersList } = object[kState]\n const contentType = headersList.get('content-type')\n\n if (contentType === null) {\n return 'failure'\n }\n\n return parseMIMEType(contentType)\n}\n\nmodule.exports = {\n extractBody,\n safelyExtractBody,\n cloneBody,\n mixinBody\n}\n","'use strict'\n\nconst { MessageChannel, receiveMessageOnPort } = require('worker_threads')\n\nconst corsSafeListedMethods = ['GET', 'HEAD', 'POST']\nconst corsSafeListedMethodsSet = new Set(corsSafeListedMethods)\n\nconst nullBodyStatus = [101, 204, 205, 304]\n\nconst redirectStatus = [301, 302, 303, 307, 308]\nconst redirectStatusSet = new Set(redirectStatus)\n\n// https://fetch.spec.whatwg.org/#block-bad-port\nconst badPorts = [\n '1', '7', '9', '11', '13', '15', '17', '19', '20', '21', '22', '23', '25', '37', '42', '43', '53', '69', '77', '79',\n '87', '95', '101', '102', '103', '104', '109', '110', '111', '113', '115', '117', '119', '123', '135', '137',\n '139', '143', '161', '179', '389', '427', '465', '512', '513', '514', '515', '526', '530', '531', '532',\n '540', '548', '554', '556', '563', '587', '601', '636', '989', '990', '993', '995', '1719', '1720', '1723',\n '2049', '3659', '4045', '5060', '5061', '6000', '6566', '6665', '6666', '6667', '6668', '6669', '6697',\n '10080'\n]\n\nconst badPortsSet = new Set(badPorts)\n\n// https://w3c.github.io/webappsec-referrer-policy/#referrer-policies\nconst referrerPolicy = [\n '',\n 'no-referrer',\n 'no-referrer-when-downgrade',\n 'same-origin',\n 'origin',\n 'strict-origin',\n 'origin-when-cross-origin',\n 'strict-origin-when-cross-origin',\n 'unsafe-url'\n]\nconst referrerPolicySet = new Set(referrerPolicy)\n\nconst requestRedirect = ['follow', 'manual', 'error']\n\nconst safeMethods = ['GET', 'HEAD', 'OPTIONS', 'TRACE']\nconst safeMethodsSet = new Set(safeMethods)\n\nconst requestMode = ['navigate', 'same-origin', 'no-cors', 'cors']\n\nconst requestCredentials = ['omit', 'same-origin', 'include']\n\nconst requestCache = [\n 'default',\n 'no-store',\n 'reload',\n 'no-cache',\n 'force-cache',\n 'only-if-cached'\n]\n\n// https://fetch.spec.whatwg.org/#request-body-header-name\nconst requestBodyHeader = [\n 'content-encoding',\n 'content-language',\n 'content-location',\n 'content-type',\n // See https://github.com/nodejs/undici/issues/2021\n // 'Content-Length' is a forbidden header name, which is typically\n // removed in the Headers implementation. However, undici doesn't\n // filter out headers, so we add it here.\n 'content-length'\n]\n\n// https://fetch.spec.whatwg.org/#enumdef-requestduplex\nconst requestDuplex = [\n 'half'\n]\n\n// http://fetch.spec.whatwg.org/#forbidden-method\nconst forbiddenMethods = ['CONNECT', 'TRACE', 'TRACK']\nconst forbiddenMethodsSet = new Set(forbiddenMethods)\n\nconst subresource = [\n 'audio',\n 'audioworklet',\n 'font',\n 'image',\n 'manifest',\n 'paintworklet',\n 'script',\n 'style',\n 'track',\n 'video',\n 'xslt',\n ''\n]\nconst subresourceSet = new Set(subresource)\n\n/** @type {globalThis['DOMException']} */\nconst DOMException = globalThis.DOMException ?? (() => {\n // DOMException was only made a global in Node v17.0.0,\n // but fetch supports >= v16.8.\n try {\n atob('~')\n } catch (err) {\n return Object.getPrototypeOf(err).constructor\n }\n})()\n\nlet channel\n\n/** @type {globalThis['structuredClone']} */\nconst structuredClone =\n globalThis.structuredClone ??\n // https://github.com/nodejs/node/blob/b27ae24dcc4251bad726d9d84baf678d1f707fed/lib/internal/structured_clone.js\n // structuredClone was added in v17.0.0, but fetch supports v16.8\n function structuredClone (value, options = undefined) {\n if (arguments.length === 0) {\n throw new TypeError('missing argument')\n }\n\n if (!channel) {\n channel = new MessageChannel()\n }\n channel.port1.unref()\n channel.port2.unref()\n channel.port1.postMessage(value, options?.transfer)\n return receiveMessageOnPort(channel.port2).message\n }\n\nmodule.exports = {\n DOMException,\n structuredClone,\n subresource,\n forbiddenMethods,\n requestBodyHeader,\n referrerPolicy,\n requestRedirect,\n requestMode,\n requestCredentials,\n requestCache,\n redirectStatus,\n corsSafeListedMethods,\n nullBodyStatus,\n safeMethods,\n badPorts,\n requestDuplex,\n subresourceSet,\n badPortsSet,\n redirectStatusSet,\n corsSafeListedMethodsSet,\n safeMethodsSet,\n forbiddenMethodsSet,\n referrerPolicySet\n}\n","const assert = require('assert')\nconst { atob } = require('buffer')\nconst { isomorphicDecode } = require('./util')\n\nconst encoder = new TextEncoder()\n\n/**\n * @see https://mimesniff.spec.whatwg.org/#http-token-code-point\n */\nconst HTTP_TOKEN_CODEPOINTS = /^[!#$%&'*+-.^_|~A-Za-z0-9]+$/\nconst HTTP_WHITESPACE_REGEX = /(\\u000A|\\u000D|\\u0009|\\u0020)/ // eslint-disable-line\n/**\n * @see https://mimesniff.spec.whatwg.org/#http-quoted-string-token-code-point\n */\nconst HTTP_QUOTED_STRING_TOKENS = /[\\u0009|\\u0020-\\u007E|\\u0080-\\u00FF]/ // eslint-disable-line\n\n// https://fetch.spec.whatwg.org/#data-url-processor\n/** @param {URL} dataURL */\nfunction dataURLProcessor (dataURL) {\n // 1. Assert: dataURL’s scheme is \"data\".\n assert(dataURL.protocol === 'data:')\n\n // 2. Let input be the result of running the URL\n // serializer on dataURL with exclude fragment\n // set to true.\n let input = URLSerializer(dataURL, true)\n\n // 3. Remove the leading \"data:\" string from input.\n input = input.slice(5)\n\n // 4. Let position point at the start of input.\n const position = { position: 0 }\n\n // 5. Let mimeType be the result of collecting a\n // sequence of code points that are not equal\n // to U+002C (,), given position.\n let mimeType = collectASequenceOfCodePointsFast(\n ',',\n input,\n position\n )\n\n // 6. Strip leading and trailing ASCII whitespace\n // from mimeType.\n // Undici implementation note: we need to store the\n // length because if the mimetype has spaces removed,\n // the wrong amount will be sliced from the input in\n // step #9\n const mimeTypeLength = mimeType.length\n mimeType = removeASCIIWhitespace(mimeType, true, true)\n\n // 7. If position is past the end of input, then\n // return failure\n if (position.position >= input.length) {\n return 'failure'\n }\n\n // 8. Advance position by 1.\n position.position++\n\n // 9. Let encodedBody be the remainder of input.\n const encodedBody = input.slice(mimeTypeLength + 1)\n\n // 10. Let body be the percent-decoding of encodedBody.\n let body = stringPercentDecode(encodedBody)\n\n // 11. If mimeType ends with U+003B (;), followed by\n // zero or more U+0020 SPACE, followed by an ASCII\n // case-insensitive match for \"base64\", then:\n if (/;(\\u0020){0,}base64$/i.test(mimeType)) {\n // 1. Let stringBody be the isomorphic decode of body.\n const stringBody = isomorphicDecode(body)\n\n // 2. Set body to the forgiving-base64 decode of\n // stringBody.\n body = forgivingBase64(stringBody)\n\n // 3. If body is failure, then return failure.\n if (body === 'failure') {\n return 'failure'\n }\n\n // 4. Remove the last 6 code points from mimeType.\n mimeType = mimeType.slice(0, -6)\n\n // 5. Remove trailing U+0020 SPACE code points from mimeType,\n // if any.\n mimeType = mimeType.replace(/(\\u0020)+$/, '')\n\n // 6. Remove the last U+003B (;) code point from mimeType.\n mimeType = mimeType.slice(0, -1)\n }\n\n // 12. If mimeType starts with U+003B (;), then prepend\n // \"text/plain\" to mimeType.\n if (mimeType.startsWith(';')) {\n mimeType = 'text/plain' + mimeType\n }\n\n // 13. Let mimeTypeRecord be the result of parsing\n // mimeType.\n let mimeTypeRecord = parseMIMEType(mimeType)\n\n // 14. If mimeTypeRecord is failure, then set\n // mimeTypeRecord to text/plain;charset=US-ASCII.\n if (mimeTypeRecord === 'failure') {\n mimeTypeRecord = parseMIMEType('text/plain;charset=US-ASCII')\n }\n\n // 15. Return a new data: URL struct whose MIME\n // type is mimeTypeRecord and body is body.\n // https://fetch.spec.whatwg.org/#data-url-struct\n return { mimeType: mimeTypeRecord, body }\n}\n\n// https://url.spec.whatwg.org/#concept-url-serializer\n/**\n * @param {URL} url\n * @param {boolean} excludeFragment\n */\nfunction URLSerializer (url, excludeFragment = false) {\n if (!excludeFragment) {\n return url.href\n }\n\n const href = url.href\n const hashLength = url.hash.length\n\n return hashLength === 0 ? href : href.substring(0, href.length - hashLength)\n}\n\n// https://infra.spec.whatwg.org/#collect-a-sequence-of-code-points\n/**\n * @param {(char: string) => boolean} condition\n * @param {string} input\n * @param {{ position: number }} position\n */\nfunction collectASequenceOfCodePoints (condition, input, position) {\n // 1. Let result be the empty string.\n let result = ''\n\n // 2. While position doesn’t point past the end of input and the\n // code point at position within input meets the condition condition:\n while (position.position < input.length && condition(input[position.position])) {\n // 1. Append that code point to the end of result.\n result += input[position.position]\n\n // 2. Advance position by 1.\n position.position++\n }\n\n // 3. Return result.\n return result\n}\n\n/**\n * A faster collectASequenceOfCodePoints that only works when comparing a single character.\n * @param {string} char\n * @param {string} input\n * @param {{ position: number }} position\n */\nfunction collectASequenceOfCodePointsFast (char, input, position) {\n const idx = input.indexOf(char, position.position)\n const start = position.position\n\n if (idx === -1) {\n position.position = input.length\n return input.slice(start)\n }\n\n position.position = idx\n return input.slice(start, position.position)\n}\n\n// https://url.spec.whatwg.org/#string-percent-decode\n/** @param {string} input */\nfunction stringPercentDecode (input) {\n // 1. Let bytes be the UTF-8 encoding of input.\n const bytes = encoder.encode(input)\n\n // 2. Return the percent-decoding of bytes.\n return percentDecode(bytes)\n}\n\n// https://url.spec.whatwg.org/#percent-decode\n/** @param {Uint8Array} input */\nfunction percentDecode (input) {\n // 1. Let output be an empty byte sequence.\n /** @type {number[]} */\n const output = []\n\n // 2. For each byte byte in input:\n for (let i = 0; i < input.length; i++) {\n const byte = input[i]\n\n // 1. If byte is not 0x25 (%), then append byte to output.\n if (byte !== 0x25) {\n output.push(byte)\n\n // 2. Otherwise, if byte is 0x25 (%) and the next two bytes\n // after byte in input are not in the ranges\n // 0x30 (0) to 0x39 (9), 0x41 (A) to 0x46 (F),\n // and 0x61 (a) to 0x66 (f), all inclusive, append byte\n // to output.\n } else if (\n byte === 0x25 &&\n !/^[0-9A-Fa-f]{2}$/i.test(String.fromCharCode(input[i + 1], input[i + 2]))\n ) {\n output.push(0x25)\n\n // 3. Otherwise:\n } else {\n // 1. Let bytePoint be the two bytes after byte in input,\n // decoded, and then interpreted as hexadecimal number.\n const nextTwoBytes = String.fromCharCode(input[i + 1], input[i + 2])\n const bytePoint = Number.parseInt(nextTwoBytes, 16)\n\n // 2. Append a byte whose value is bytePoint to output.\n output.push(bytePoint)\n\n // 3. Skip the next two bytes in input.\n i += 2\n }\n }\n\n // 3. Return output.\n return Uint8Array.from(output)\n}\n\n// https://mimesniff.spec.whatwg.org/#parse-a-mime-type\n/** @param {string} input */\nfunction parseMIMEType (input) {\n // 1. Remove any leading and trailing HTTP whitespace\n // from input.\n input = removeHTTPWhitespace(input, true, true)\n\n // 2. Let position be a position variable for input,\n // initially pointing at the start of input.\n const position = { position: 0 }\n\n // 3. Let type be the result of collecting a sequence\n // of code points that are not U+002F (/) from\n // input, given position.\n const type = collectASequenceOfCodePointsFast(\n '/',\n input,\n position\n )\n\n // 4. If type is the empty string or does not solely\n // contain HTTP token code points, then return failure.\n // https://mimesniff.spec.whatwg.org/#http-token-code-point\n if (type.length === 0 || !HTTP_TOKEN_CODEPOINTS.test(type)) {\n return 'failure'\n }\n\n // 5. If position is past the end of input, then return\n // failure\n if (position.position > input.length) {\n return 'failure'\n }\n\n // 6. Advance position by 1. (This skips past U+002F (/).)\n position.position++\n\n // 7. Let subtype be the result of collecting a sequence of\n // code points that are not U+003B (;) from input, given\n // position.\n let subtype = collectASequenceOfCodePointsFast(\n ';',\n input,\n position\n )\n\n // 8. Remove any trailing HTTP whitespace from subtype.\n subtype = removeHTTPWhitespace(subtype, false, true)\n\n // 9. If subtype is the empty string or does not solely\n // contain HTTP token code points, then return failure.\n if (subtype.length === 0 || !HTTP_TOKEN_CODEPOINTS.test(subtype)) {\n return 'failure'\n }\n\n const typeLowercase = type.toLowerCase()\n const subtypeLowercase = subtype.toLowerCase()\n\n // 10. Let mimeType be a new MIME type record whose type\n // is type, in ASCII lowercase, and subtype is subtype,\n // in ASCII lowercase.\n // https://mimesniff.spec.whatwg.org/#mime-type\n const mimeType = {\n type: typeLowercase,\n subtype: subtypeLowercase,\n /** @type {Map} */\n parameters: new Map(),\n // https://mimesniff.spec.whatwg.org/#mime-type-essence\n essence: `${typeLowercase}/${subtypeLowercase}`\n }\n\n // 11. While position is not past the end of input:\n while (position.position < input.length) {\n // 1. Advance position by 1. (This skips past U+003B (;).)\n position.position++\n\n // 2. Collect a sequence of code points that are HTTP\n // whitespace from input given position.\n collectASequenceOfCodePoints(\n // https://fetch.spec.whatwg.org/#http-whitespace\n char => HTTP_WHITESPACE_REGEX.test(char),\n input,\n position\n )\n\n // 3. Let parameterName be the result of collecting a\n // sequence of code points that are not U+003B (;)\n // or U+003D (=) from input, given position.\n let parameterName = collectASequenceOfCodePoints(\n (char) => char !== ';' && char !== '=',\n input,\n position\n )\n\n // 4. Set parameterName to parameterName, in ASCII\n // lowercase.\n parameterName = parameterName.toLowerCase()\n\n // 5. If position is not past the end of input, then:\n if (position.position < input.length) {\n // 1. If the code point at position within input is\n // U+003B (;), then continue.\n if (input[position.position] === ';') {\n continue\n }\n\n // 2. Advance position by 1. (This skips past U+003D (=).)\n position.position++\n }\n\n // 6. If position is past the end of input, then break.\n if (position.position > input.length) {\n break\n }\n\n // 7. Let parameterValue be null.\n let parameterValue = null\n\n // 8. If the code point at position within input is\n // U+0022 (\"), then:\n if (input[position.position] === '\"') {\n // 1. Set parameterValue to the result of collecting\n // an HTTP quoted string from input, given position\n // and the extract-value flag.\n parameterValue = collectAnHTTPQuotedString(input, position, true)\n\n // 2. Collect a sequence of code points that are not\n // U+003B (;) from input, given position.\n collectASequenceOfCodePointsFast(\n ';',\n input,\n position\n )\n\n // 9. Otherwise:\n } else {\n // 1. Set parameterValue to the result of collecting\n // a sequence of code points that are not U+003B (;)\n // from input, given position.\n parameterValue = collectASequenceOfCodePointsFast(\n ';',\n input,\n position\n )\n\n // 2. Remove any trailing HTTP whitespace from parameterValue.\n parameterValue = removeHTTPWhitespace(parameterValue, false, true)\n\n // 3. If parameterValue is the empty string, then continue.\n if (parameterValue.length === 0) {\n continue\n }\n }\n\n // 10. If all of the following are true\n // - parameterName is not the empty string\n // - parameterName solely contains HTTP token code points\n // - parameterValue solely contains HTTP quoted-string token code points\n // - mimeType’s parameters[parameterName] does not exist\n // then set mimeType’s parameters[parameterName] to parameterValue.\n if (\n parameterName.length !== 0 &&\n HTTP_TOKEN_CODEPOINTS.test(parameterName) &&\n (parameterValue.length === 0 || HTTP_QUOTED_STRING_TOKENS.test(parameterValue)) &&\n !mimeType.parameters.has(parameterName)\n ) {\n mimeType.parameters.set(parameterName, parameterValue)\n }\n }\n\n // 12. Return mimeType.\n return mimeType\n}\n\n// https://infra.spec.whatwg.org/#forgiving-base64-decode\n/** @param {string} data */\nfunction forgivingBase64 (data) {\n // 1. Remove all ASCII whitespace from data.\n data = data.replace(/[\\u0009\\u000A\\u000C\\u000D\\u0020]/g, '') // eslint-disable-line\n\n // 2. If data’s code point length divides by 4 leaving\n // no remainder, then:\n if (data.length % 4 === 0) {\n // 1. If data ends with one or two U+003D (=) code points,\n // then remove them from data.\n data = data.replace(/=?=$/, '')\n }\n\n // 3. If data’s code point length divides by 4 leaving\n // a remainder of 1, then return failure.\n if (data.length % 4 === 1) {\n return 'failure'\n }\n\n // 4. If data contains a code point that is not one of\n // U+002B (+)\n // U+002F (/)\n // ASCII alphanumeric\n // then return failure.\n if (/[^+/0-9A-Za-z]/.test(data)) {\n return 'failure'\n }\n\n const binary = atob(data)\n const bytes = new Uint8Array(binary.length)\n\n for (let byte = 0; byte < binary.length; byte++) {\n bytes[byte] = binary.charCodeAt(byte)\n }\n\n return bytes\n}\n\n// https://fetch.spec.whatwg.org/#collect-an-http-quoted-string\n// tests: https://fetch.spec.whatwg.org/#example-http-quoted-string\n/**\n * @param {string} input\n * @param {{ position: number }} position\n * @param {boolean?} extractValue\n */\nfunction collectAnHTTPQuotedString (input, position, extractValue) {\n // 1. Let positionStart be position.\n const positionStart = position.position\n\n // 2. Let value be the empty string.\n let value = ''\n\n // 3. Assert: the code point at position within input\n // is U+0022 (\").\n assert(input[position.position] === '\"')\n\n // 4. Advance position by 1.\n position.position++\n\n // 5. While true:\n while (true) {\n // 1. Append the result of collecting a sequence of code points\n // that are not U+0022 (\") or U+005C (\\) from input, given\n // position, to value.\n value += collectASequenceOfCodePoints(\n (char) => char !== '\"' && char !== '\\\\',\n input,\n position\n )\n\n // 2. If position is past the end of input, then break.\n if (position.position >= input.length) {\n break\n }\n\n // 3. Let quoteOrBackslash be the code point at position within\n // input.\n const quoteOrBackslash = input[position.position]\n\n // 4. Advance position by 1.\n position.position++\n\n // 5. If quoteOrBackslash is U+005C (\\), then:\n if (quoteOrBackslash === '\\\\') {\n // 1. If position is past the end of input, then append\n // U+005C (\\) to value and break.\n if (position.position >= input.length) {\n value += '\\\\'\n break\n }\n\n // 2. Append the code point at position within input to value.\n value += input[position.position]\n\n // 3. Advance position by 1.\n position.position++\n\n // 6. Otherwise:\n } else {\n // 1. Assert: quoteOrBackslash is U+0022 (\").\n assert(quoteOrBackslash === '\"')\n\n // 2. Break.\n break\n }\n }\n\n // 6. If the extract-value flag is set, then return value.\n if (extractValue) {\n return value\n }\n\n // 7. Return the code points from positionStart to position,\n // inclusive, within input.\n return input.slice(positionStart, position.position)\n}\n\n/**\n * @see https://mimesniff.spec.whatwg.org/#serialize-a-mime-type\n */\nfunction serializeAMimeType (mimeType) {\n assert(mimeType !== 'failure')\n const { parameters, essence } = mimeType\n\n // 1. Let serialization be the concatenation of mimeType’s\n // type, U+002F (/), and mimeType’s subtype.\n let serialization = essence\n\n // 2. For each name → value of mimeType’s parameters:\n for (let [name, value] of parameters.entries()) {\n // 1. Append U+003B (;) to serialization.\n serialization += ';'\n\n // 2. Append name to serialization.\n serialization += name\n\n // 3. Append U+003D (=) to serialization.\n serialization += '='\n\n // 4. If value does not solely contain HTTP token code\n // points or value is the empty string, then:\n if (!HTTP_TOKEN_CODEPOINTS.test(value)) {\n // 1. Precede each occurence of U+0022 (\") or\n // U+005C (\\) in value with U+005C (\\).\n value = value.replace(/(\\\\|\")/g, '\\\\$1')\n\n // 2. Prepend U+0022 (\") to value.\n value = '\"' + value\n\n // 3. Append U+0022 (\") to value.\n value += '\"'\n }\n\n // 5. Append value to serialization.\n serialization += value\n }\n\n // 3. Return serialization.\n return serialization\n}\n\n/**\n * @see https://fetch.spec.whatwg.org/#http-whitespace\n * @param {string} char\n */\nfunction isHTTPWhiteSpace (char) {\n return char === '\\r' || char === '\\n' || char === '\\t' || char === ' '\n}\n\n/**\n * @see https://fetch.spec.whatwg.org/#http-whitespace\n * @param {string} str\n */\nfunction removeHTTPWhitespace (str, leading = true, trailing = true) {\n let lead = 0\n let trail = str.length - 1\n\n if (leading) {\n for (; lead < str.length && isHTTPWhiteSpace(str[lead]); lead++);\n }\n\n if (trailing) {\n for (; trail > 0 && isHTTPWhiteSpace(str[trail]); trail--);\n }\n\n return str.slice(lead, trail + 1)\n}\n\n/**\n * @see https://infra.spec.whatwg.org/#ascii-whitespace\n * @param {string} char\n */\nfunction isASCIIWhitespace (char) {\n return char === '\\r' || char === '\\n' || char === '\\t' || char === '\\f' || char === ' '\n}\n\n/**\n * @see https://infra.spec.whatwg.org/#strip-leading-and-trailing-ascii-whitespace\n */\nfunction removeASCIIWhitespace (str, leading = true, trailing = true) {\n let lead = 0\n let trail = str.length - 1\n\n if (leading) {\n for (; lead < str.length && isASCIIWhitespace(str[lead]); lead++);\n }\n\n if (trailing) {\n for (; trail > 0 && isASCIIWhitespace(str[trail]); trail--);\n }\n\n return str.slice(lead, trail + 1)\n}\n\nmodule.exports = {\n dataURLProcessor,\n URLSerializer,\n collectASequenceOfCodePoints,\n collectASequenceOfCodePointsFast,\n stringPercentDecode,\n parseMIMEType,\n collectAnHTTPQuotedString,\n serializeAMimeType\n}\n","'use strict'\n\nconst { Blob, File: NativeFile } = require('buffer')\nconst { types } = require('util')\nconst { kState } = require('./symbols')\nconst { isBlobLike } = require('./util')\nconst { webidl } = require('./webidl')\nconst { parseMIMEType, serializeAMimeType } = require('./dataURL')\nconst { kEnumerableProperty } = require('../core/util')\nconst encoder = new TextEncoder()\n\nclass File extends Blob {\n constructor (fileBits, fileName, options = {}) {\n // The File constructor is invoked with two or three parameters, depending\n // on whether the optional dictionary parameter is used. When the File()\n // constructor is invoked, user agents must run the following steps:\n webidl.argumentLengthCheck(arguments, 2, { header: 'File constructor' })\n\n fileBits = webidl.converters['sequence'](fileBits)\n fileName = webidl.converters.USVString(fileName)\n options = webidl.converters.FilePropertyBag(options)\n\n // 1. Let bytes be the result of processing blob parts given fileBits and\n // options.\n // Note: Blob handles this for us\n\n // 2. Let n be the fileName argument to the constructor.\n const n = fileName\n\n // 3. Process FilePropertyBag dictionary argument by running the following\n // substeps:\n\n // 1. If the type member is provided and is not the empty string, let t\n // be set to the type dictionary member. If t contains any characters\n // outside the range U+0020 to U+007E, then set t to the empty string\n // and return from these substeps.\n // 2. Convert every character in t to ASCII lowercase.\n let t = options.type\n let d\n\n // eslint-disable-next-line no-labels\n substep: {\n if (t) {\n t = parseMIMEType(t)\n\n if (t === 'failure') {\n t = ''\n // eslint-disable-next-line no-labels\n break substep\n }\n\n t = serializeAMimeType(t).toLowerCase()\n }\n\n // 3. If the lastModified member is provided, let d be set to the\n // lastModified dictionary member. If it is not provided, set d to the\n // current date and time represented as the number of milliseconds since\n // the Unix Epoch (which is the equivalent of Date.now() [ECMA-262]).\n d = options.lastModified\n }\n\n // 4. Return a new File object F such that:\n // F refers to the bytes byte sequence.\n // F.size is set to the number of total bytes in bytes.\n // F.name is set to n.\n // F.type is set to t.\n // F.lastModified is set to d.\n\n super(processBlobParts(fileBits, options), { type: t })\n this[kState] = {\n name: n,\n lastModified: d,\n type: t\n }\n }\n\n get name () {\n webidl.brandCheck(this, File)\n\n return this[kState].name\n }\n\n get lastModified () {\n webidl.brandCheck(this, File)\n\n return this[kState].lastModified\n }\n\n get type () {\n webidl.brandCheck(this, File)\n\n return this[kState].type\n }\n}\n\nclass FileLike {\n constructor (blobLike, fileName, options = {}) {\n // TODO: argument idl type check\n\n // The File constructor is invoked with two or three parameters, depending\n // on whether the optional dictionary parameter is used. When the File()\n // constructor is invoked, user agents must run the following steps:\n\n // 1. Let bytes be the result of processing blob parts given fileBits and\n // options.\n\n // 2. Let n be the fileName argument to the constructor.\n const n = fileName\n\n // 3. Process FilePropertyBag dictionary argument by running the following\n // substeps:\n\n // 1. If the type member is provided and is not the empty string, let t\n // be set to the type dictionary member. If t contains any characters\n // outside the range U+0020 to U+007E, then set t to the empty string\n // and return from these substeps.\n // TODO\n const t = options.type\n\n // 2. Convert every character in t to ASCII lowercase.\n // TODO\n\n // 3. If the lastModified member is provided, let d be set to the\n // lastModified dictionary member. If it is not provided, set d to the\n // current date and time represented as the number of milliseconds since\n // the Unix Epoch (which is the equivalent of Date.now() [ECMA-262]).\n const d = options.lastModified ?? Date.now()\n\n // 4. Return a new File object F such that:\n // F refers to the bytes byte sequence.\n // F.size is set to the number of total bytes in bytes.\n // F.name is set to n.\n // F.type is set to t.\n // F.lastModified is set to d.\n\n this[kState] = {\n blobLike,\n name: n,\n type: t,\n lastModified: d\n }\n }\n\n stream (...args) {\n webidl.brandCheck(this, FileLike)\n\n return this[kState].blobLike.stream(...args)\n }\n\n arrayBuffer (...args) {\n webidl.brandCheck(this, FileLike)\n\n return this[kState].blobLike.arrayBuffer(...args)\n }\n\n slice (...args) {\n webidl.brandCheck(this, FileLike)\n\n return this[kState].blobLike.slice(...args)\n }\n\n text (...args) {\n webidl.brandCheck(this, FileLike)\n\n return this[kState].blobLike.text(...args)\n }\n\n get size () {\n webidl.brandCheck(this, FileLike)\n\n return this[kState].blobLike.size\n }\n\n get type () {\n webidl.brandCheck(this, FileLike)\n\n return this[kState].blobLike.type\n }\n\n get name () {\n webidl.brandCheck(this, FileLike)\n\n return this[kState].name\n }\n\n get lastModified () {\n webidl.brandCheck(this, FileLike)\n\n return this[kState].lastModified\n }\n\n get [Symbol.toStringTag] () {\n return 'File'\n }\n}\n\nObject.defineProperties(File.prototype, {\n [Symbol.toStringTag]: {\n value: 'File',\n configurable: true\n },\n name: kEnumerableProperty,\n lastModified: kEnumerableProperty\n})\n\nwebidl.converters.Blob = webidl.interfaceConverter(Blob)\n\nwebidl.converters.BlobPart = function (V, opts) {\n if (webidl.util.Type(V) === 'Object') {\n if (isBlobLike(V)) {\n return webidl.converters.Blob(V, { strict: false })\n }\n\n if (\n ArrayBuffer.isView(V) ||\n types.isAnyArrayBuffer(V)\n ) {\n return webidl.converters.BufferSource(V, opts)\n }\n }\n\n return webidl.converters.USVString(V, opts)\n}\n\nwebidl.converters['sequence'] = webidl.sequenceConverter(\n webidl.converters.BlobPart\n)\n\n// https://www.w3.org/TR/FileAPI/#dfn-FilePropertyBag\nwebidl.converters.FilePropertyBag = webidl.dictionaryConverter([\n {\n key: 'lastModified',\n converter: webidl.converters['long long'],\n get defaultValue () {\n return Date.now()\n }\n },\n {\n key: 'type',\n converter: webidl.converters.DOMString,\n defaultValue: ''\n },\n {\n key: 'endings',\n converter: (value) => {\n value = webidl.converters.DOMString(value)\n value = value.toLowerCase()\n\n if (value !== 'native') {\n value = 'transparent'\n }\n\n return value\n },\n defaultValue: 'transparent'\n }\n])\n\n/**\n * @see https://www.w3.org/TR/FileAPI/#process-blob-parts\n * @param {(NodeJS.TypedArray|Blob|string)[]} parts\n * @param {{ type: string, endings: string }} options\n */\nfunction processBlobParts (parts, options) {\n // 1. Let bytes be an empty sequence of bytes.\n /** @type {NodeJS.TypedArray[]} */\n const bytes = []\n\n // 2. For each element in parts:\n for (const element of parts) {\n // 1. If element is a USVString, run the following substeps:\n if (typeof element === 'string') {\n // 1. Let s be element.\n let s = element\n\n // 2. If the endings member of options is \"native\", set s\n // to the result of converting line endings to native\n // of element.\n if (options.endings === 'native') {\n s = convertLineEndingsNative(s)\n }\n\n // 3. Append the result of UTF-8 encoding s to bytes.\n bytes.push(encoder.encode(s))\n } else if (\n types.isAnyArrayBuffer(element) ||\n types.isTypedArray(element)\n ) {\n // 2. If element is a BufferSource, get a copy of the\n // bytes held by the buffer source, and append those\n // bytes to bytes.\n if (!element.buffer) { // ArrayBuffer\n bytes.push(new Uint8Array(element))\n } else {\n bytes.push(\n new Uint8Array(element.buffer, element.byteOffset, element.byteLength)\n )\n }\n } else if (isBlobLike(element)) {\n // 3. If element is a Blob, append the bytes it represents\n // to bytes.\n bytes.push(element)\n }\n }\n\n // 3. Return bytes.\n return bytes\n}\n\n/**\n * @see https://www.w3.org/TR/FileAPI/#convert-line-endings-to-native\n * @param {string} s\n */\nfunction convertLineEndingsNative (s) {\n // 1. Let native line ending be be the code point U+000A LF.\n let nativeLineEnding = '\\n'\n\n // 2. If the underlying platform’s conventions are to\n // represent newlines as a carriage return and line feed\n // sequence, set native line ending to the code point\n // U+000D CR followed by the code point U+000A LF.\n if (process.platform === 'win32') {\n nativeLineEnding = '\\r\\n'\n }\n\n return s.replace(/\\r?\\n/g, nativeLineEnding)\n}\n\n// If this function is moved to ./util.js, some tools (such as\n// rollup) will warn about circular dependencies. See:\n// https://github.com/nodejs/undici/issues/1629\nfunction isFileLike (object) {\n return (\n (NativeFile && object instanceof NativeFile) ||\n object instanceof File || (\n object &&\n (typeof object.stream === 'function' ||\n typeof object.arrayBuffer === 'function') &&\n object[Symbol.toStringTag] === 'File'\n )\n )\n}\n\nmodule.exports = { File, FileLike, isFileLike }\n","'use strict'\n\nconst { isBlobLike, toUSVString, makeIterator } = require('./util')\nconst { kState } = require('./symbols')\nconst { File: UndiciFile, FileLike, isFileLike } = require('./file')\nconst { webidl } = require('./webidl')\nconst { Blob, File: NativeFile } = require('buffer')\n\n/** @type {globalThis['File']} */\nconst File = NativeFile ?? UndiciFile\n\n// https://xhr.spec.whatwg.org/#formdata\nclass FormData {\n constructor (form) {\n if (form !== undefined) {\n throw webidl.errors.conversionFailed({\n prefix: 'FormData constructor',\n argument: 'Argument 1',\n types: ['undefined']\n })\n }\n\n this[kState] = []\n }\n\n append (name, value, filename = undefined) {\n webidl.brandCheck(this, FormData)\n\n webidl.argumentLengthCheck(arguments, 2, { header: 'FormData.append' })\n\n if (arguments.length === 3 && !isBlobLike(value)) {\n throw new TypeError(\n \"Failed to execute 'append' on 'FormData': parameter 2 is not of type 'Blob'\"\n )\n }\n\n // 1. Let value be value if given; otherwise blobValue.\n\n name = webidl.converters.USVString(name)\n value = isBlobLike(value)\n ? webidl.converters.Blob(value, { strict: false })\n : webidl.converters.USVString(value)\n filename = arguments.length === 3\n ? webidl.converters.USVString(filename)\n : undefined\n\n // 2. Let entry be the result of creating an entry with\n // name, value, and filename if given.\n const entry = makeEntry(name, value, filename)\n\n // 3. Append entry to this’s entry list.\n this[kState].push(entry)\n }\n\n delete (name) {\n webidl.brandCheck(this, FormData)\n\n webidl.argumentLengthCheck(arguments, 1, { header: 'FormData.delete' })\n\n name = webidl.converters.USVString(name)\n\n // The delete(name) method steps are to remove all entries whose name\n // is name from this’s entry list.\n this[kState] = this[kState].filter(entry => entry.name !== name)\n }\n\n get (name) {\n webidl.brandCheck(this, FormData)\n\n webidl.argumentLengthCheck(arguments, 1, { header: 'FormData.get' })\n\n name = webidl.converters.USVString(name)\n\n // 1. If there is no entry whose name is name in this’s entry list,\n // then return null.\n const idx = this[kState].findIndex((entry) => entry.name === name)\n if (idx === -1) {\n return null\n }\n\n // 2. Return the value of the first entry whose name is name from\n // this’s entry list.\n return this[kState][idx].value\n }\n\n getAll (name) {\n webidl.brandCheck(this, FormData)\n\n webidl.argumentLengthCheck(arguments, 1, { header: 'FormData.getAll' })\n\n name = webidl.converters.USVString(name)\n\n // 1. If there is no entry whose name is name in this’s entry list,\n // then return the empty list.\n // 2. Return the values of all entries whose name is name, in order,\n // from this’s entry list.\n return this[kState]\n .filter((entry) => entry.name === name)\n .map((entry) => entry.value)\n }\n\n has (name) {\n webidl.brandCheck(this, FormData)\n\n webidl.argumentLengthCheck(arguments, 1, { header: 'FormData.has' })\n\n name = webidl.converters.USVString(name)\n\n // The has(name) method steps are to return true if there is an entry\n // whose name is name in this’s entry list; otherwise false.\n return this[kState].findIndex((entry) => entry.name === name) !== -1\n }\n\n set (name, value, filename = undefined) {\n webidl.brandCheck(this, FormData)\n\n webidl.argumentLengthCheck(arguments, 2, { header: 'FormData.set' })\n\n if (arguments.length === 3 && !isBlobLike(value)) {\n throw new TypeError(\n \"Failed to execute 'set' on 'FormData': parameter 2 is not of type 'Blob'\"\n )\n }\n\n // The set(name, value) and set(name, blobValue, filename) method steps\n // are:\n\n // 1. Let value be value if given; otherwise blobValue.\n\n name = webidl.converters.USVString(name)\n value = isBlobLike(value)\n ? webidl.converters.Blob(value, { strict: false })\n : webidl.converters.USVString(value)\n filename = arguments.length === 3\n ? toUSVString(filename)\n : undefined\n\n // 2. Let entry be the result of creating an entry with name, value, and\n // filename if given.\n const entry = makeEntry(name, value, filename)\n\n // 3. If there are entries in this’s entry list whose name is name, then\n // replace the first such entry with entry and remove the others.\n const idx = this[kState].findIndex((entry) => entry.name === name)\n if (idx !== -1) {\n this[kState] = [\n ...this[kState].slice(0, idx),\n entry,\n ...this[kState].slice(idx + 1).filter((entry) => entry.name !== name)\n ]\n } else {\n // 4. Otherwise, append entry to this’s entry list.\n this[kState].push(entry)\n }\n }\n\n entries () {\n webidl.brandCheck(this, FormData)\n\n return makeIterator(\n () => this[kState].map(pair => [pair.name, pair.value]),\n 'FormData',\n 'key+value'\n )\n }\n\n keys () {\n webidl.brandCheck(this, FormData)\n\n return makeIterator(\n () => this[kState].map(pair => [pair.name, pair.value]),\n 'FormData',\n 'key'\n )\n }\n\n values () {\n webidl.brandCheck(this, FormData)\n\n return makeIterator(\n () => this[kState].map(pair => [pair.name, pair.value]),\n 'FormData',\n 'value'\n )\n }\n\n /**\n * @param {(value: string, key: string, self: FormData) => void} callbackFn\n * @param {unknown} thisArg\n */\n forEach (callbackFn, thisArg = globalThis) {\n webidl.brandCheck(this, FormData)\n\n webidl.argumentLengthCheck(arguments, 1, { header: 'FormData.forEach' })\n\n if (typeof callbackFn !== 'function') {\n throw new TypeError(\n \"Failed to execute 'forEach' on 'FormData': parameter 1 is not of type 'Function'.\"\n )\n }\n\n for (const [key, value] of this) {\n callbackFn.apply(thisArg, [value, key, this])\n }\n }\n}\n\nFormData.prototype[Symbol.iterator] = FormData.prototype.entries\n\nObject.defineProperties(FormData.prototype, {\n [Symbol.toStringTag]: {\n value: 'FormData',\n configurable: true\n }\n})\n\n/**\n * @see https://html.spec.whatwg.org/multipage/form-control-infrastructure.html#create-an-entry\n * @param {string} name\n * @param {string|Blob} value\n * @param {?string} filename\n * @returns\n */\nfunction makeEntry (name, value, filename) {\n // 1. Set name to the result of converting name into a scalar value string.\n // \"To convert a string into a scalar value string, replace any surrogates\n // with U+FFFD.\"\n // see: https://nodejs.org/dist/latest-v18.x/docs/api/buffer.html#buftostringencoding-start-end\n name = Buffer.from(name).toString('utf8')\n\n // 2. If value is a string, then set value to the result of converting\n // value into a scalar value string.\n if (typeof value === 'string') {\n value = Buffer.from(value).toString('utf8')\n } else {\n // 3. Otherwise:\n\n // 1. If value is not a File object, then set value to a new File object,\n // representing the same bytes, whose name attribute value is \"blob\"\n if (!isFileLike(value)) {\n value = value instanceof Blob\n ? new File([value], 'blob', { type: value.type })\n : new FileLike(value, 'blob', { type: value.type })\n }\n\n // 2. If filename is given, then set value to a new File object,\n // representing the same bytes, whose name attribute is filename.\n if (filename !== undefined) {\n /** @type {FilePropertyBag} */\n const options = {\n type: value.type,\n lastModified: value.lastModified\n }\n\n value = (NativeFile && value instanceof NativeFile) || value instanceof UndiciFile\n ? new File([value], filename, options)\n : new FileLike(value, filename, options)\n }\n }\n\n // 4. Return an entry whose name is name and whose value is value.\n return { name, value }\n}\n\nmodule.exports = { FormData }\n","'use strict'\n\n// In case of breaking changes, increase the version\n// number to avoid conflicts.\nconst globalOrigin = Symbol.for('undici.globalOrigin.1')\n\nfunction getGlobalOrigin () {\n return globalThis[globalOrigin]\n}\n\nfunction setGlobalOrigin (newOrigin) {\n if (newOrigin === undefined) {\n Object.defineProperty(globalThis, globalOrigin, {\n value: undefined,\n writable: true,\n enumerable: false,\n configurable: false\n })\n\n return\n }\n\n const parsedURL = new URL(newOrigin)\n\n if (parsedURL.protocol !== 'http:' && parsedURL.protocol !== 'https:') {\n throw new TypeError(`Only http & https urls are allowed, received ${parsedURL.protocol}`)\n }\n\n Object.defineProperty(globalThis, globalOrigin, {\n value: parsedURL,\n writable: true,\n enumerable: false,\n configurable: false\n })\n}\n\nmodule.exports = {\n getGlobalOrigin,\n setGlobalOrigin\n}\n","// https://github.com/Ethan-Arrowood/undici-fetch\n\n'use strict'\n\nconst { kHeadersList, kConstruct } = require('../core/symbols')\nconst { kGuard } = require('./symbols')\nconst { kEnumerableProperty } = require('../core/util')\nconst {\n makeIterator,\n isValidHeaderName,\n isValidHeaderValue\n} = require('./util')\nconst { webidl } = require('./webidl')\nconst assert = require('assert')\n\nconst kHeadersMap = Symbol('headers map')\nconst kHeadersSortedMap = Symbol('headers map sorted')\n\n/**\n * @param {number} code\n */\nfunction isHTTPWhiteSpaceCharCode (code) {\n return code === 0x00a || code === 0x00d || code === 0x009 || code === 0x020\n}\n\n/**\n * @see https://fetch.spec.whatwg.org/#concept-header-value-normalize\n * @param {string} potentialValue\n */\nfunction headerValueNormalize (potentialValue) {\n // To normalize a byte sequence potentialValue, remove\n // any leading and trailing HTTP whitespace bytes from\n // potentialValue.\n let i = 0; let j = potentialValue.length\n\n while (j > i && isHTTPWhiteSpaceCharCode(potentialValue.charCodeAt(j - 1))) --j\n while (j > i && isHTTPWhiteSpaceCharCode(potentialValue.charCodeAt(i))) ++i\n\n return i === 0 && j === potentialValue.length ? potentialValue : potentialValue.substring(i, j)\n}\n\nfunction fill (headers, object) {\n // To fill a Headers object headers with a given object object, run these steps:\n\n // 1. If object is a sequence, then for each header in object:\n // Note: webidl conversion to array has already been done.\n if (Array.isArray(object)) {\n for (let i = 0; i < object.length; ++i) {\n const header = object[i]\n // 1. If header does not contain exactly two items, then throw a TypeError.\n if (header.length !== 2) {\n throw webidl.errors.exception({\n header: 'Headers constructor',\n message: `expected name/value pair to be length 2, found ${header.length}.`\n })\n }\n\n // 2. Append (header’s first item, header’s second item) to headers.\n appendHeader(headers, header[0], header[1])\n }\n } else if (typeof object === 'object' && object !== null) {\n // Note: null should throw\n\n // 2. Otherwise, object is a record, then for each key → value in object,\n // append (key, value) to headers\n const keys = Object.keys(object)\n for (let i = 0; i < keys.length; ++i) {\n appendHeader(headers, keys[i], object[keys[i]])\n }\n } else {\n throw webidl.errors.conversionFailed({\n prefix: 'Headers constructor',\n argument: 'Argument 1',\n types: ['sequence>', 'record']\n })\n }\n}\n\n/**\n * @see https://fetch.spec.whatwg.org/#concept-headers-append\n */\nfunction appendHeader (headers, name, value) {\n // 1. Normalize value.\n value = headerValueNormalize(value)\n\n // 2. If name is not a header name or value is not a\n // header value, then throw a TypeError.\n if (!isValidHeaderName(name)) {\n throw webidl.errors.invalidArgument({\n prefix: 'Headers.append',\n value: name,\n type: 'header name'\n })\n } else if (!isValidHeaderValue(value)) {\n throw webidl.errors.invalidArgument({\n prefix: 'Headers.append',\n value,\n type: 'header value'\n })\n }\n\n // 3. If headers’s guard is \"immutable\", then throw a TypeError.\n // 4. Otherwise, if headers’s guard is \"request\" and name is a\n // forbidden header name, return.\n // Note: undici does not implement forbidden header names\n if (headers[kGuard] === 'immutable') {\n throw new TypeError('immutable')\n } else if (headers[kGuard] === 'request-no-cors') {\n // 5. Otherwise, if headers’s guard is \"request-no-cors\":\n // TODO\n }\n\n // 6. Otherwise, if headers’s guard is \"response\" and name is a\n // forbidden response-header name, return.\n\n // 7. Append (name, value) to headers’s header list.\n return headers[kHeadersList].append(name, value)\n\n // 8. If headers’s guard is \"request-no-cors\", then remove\n // privileged no-CORS request headers from headers\n}\n\nclass HeadersList {\n /** @type {[string, string][]|null} */\n cookies = null\n\n constructor (init) {\n if (init instanceof HeadersList) {\n this[kHeadersMap] = new Map(init[kHeadersMap])\n this[kHeadersSortedMap] = init[kHeadersSortedMap]\n this.cookies = init.cookies === null ? null : [...init.cookies]\n } else {\n this[kHeadersMap] = new Map(init)\n this[kHeadersSortedMap] = null\n }\n }\n\n // https://fetch.spec.whatwg.org/#header-list-contains\n contains (name) {\n // A header list list contains a header name name if list\n // contains a header whose name is a byte-case-insensitive\n // match for name.\n name = name.toLowerCase()\n\n return this[kHeadersMap].has(name)\n }\n\n clear () {\n this[kHeadersMap].clear()\n this[kHeadersSortedMap] = null\n this.cookies = null\n }\n\n // https://fetch.spec.whatwg.org/#concept-header-list-append\n append (name, value) {\n this[kHeadersSortedMap] = null\n\n // 1. If list contains name, then set name to the first such\n // header’s name.\n const lowercaseName = name.toLowerCase()\n const exists = this[kHeadersMap].get(lowercaseName)\n\n // 2. Append (name, value) to list.\n if (exists) {\n const delimiter = lowercaseName === 'cookie' ? '; ' : ', '\n this[kHeadersMap].set(lowercaseName, {\n name: exists.name,\n value: `${exists.value}${delimiter}${value}`\n })\n } else {\n this[kHeadersMap].set(lowercaseName, { name, value })\n }\n\n if (lowercaseName === 'set-cookie') {\n this.cookies ??= []\n this.cookies.push(value)\n }\n }\n\n // https://fetch.spec.whatwg.org/#concept-header-list-set\n set (name, value) {\n this[kHeadersSortedMap] = null\n const lowercaseName = name.toLowerCase()\n\n if (lowercaseName === 'set-cookie') {\n this.cookies = [value]\n }\n\n // 1. If list contains name, then set the value of\n // the first such header to value and remove the\n // others.\n // 2. Otherwise, append header (name, value) to list.\n this[kHeadersMap].set(lowercaseName, { name, value })\n }\n\n // https://fetch.spec.whatwg.org/#concept-header-list-delete\n delete (name) {\n this[kHeadersSortedMap] = null\n\n name = name.toLowerCase()\n\n if (name === 'set-cookie') {\n this.cookies = null\n }\n\n this[kHeadersMap].delete(name)\n }\n\n // https://fetch.spec.whatwg.org/#concept-header-list-get\n get (name) {\n const value = this[kHeadersMap].get(name.toLowerCase())\n\n // 1. If list does not contain name, then return null.\n // 2. Return the values of all headers in list whose name\n // is a byte-case-insensitive match for name,\n // separated from each other by 0x2C 0x20, in order.\n return value === undefined ? null : value.value\n }\n\n * [Symbol.iterator] () {\n // use the lowercased name\n for (const [name, { value }] of this[kHeadersMap]) {\n yield [name, value]\n }\n }\n\n get entries () {\n const headers = {}\n\n if (this[kHeadersMap].size) {\n for (const { name, value } of this[kHeadersMap].values()) {\n headers[name] = value\n }\n }\n\n return headers\n }\n}\n\n// https://fetch.spec.whatwg.org/#headers-class\nclass Headers {\n constructor (init = undefined) {\n if (init === kConstruct) {\n return\n }\n this[kHeadersList] = new HeadersList()\n\n // The new Headers(init) constructor steps are:\n\n // 1. Set this’s guard to \"none\".\n this[kGuard] = 'none'\n\n // 2. If init is given, then fill this with init.\n if (init !== undefined) {\n init = webidl.converters.HeadersInit(init)\n fill(this, init)\n }\n }\n\n // https://fetch.spec.whatwg.org/#dom-headers-append\n append (name, value) {\n webidl.brandCheck(this, Headers)\n\n webidl.argumentLengthCheck(arguments, 2, { header: 'Headers.append' })\n\n name = webidl.converters.ByteString(name)\n value = webidl.converters.ByteString(value)\n\n return appendHeader(this, name, value)\n }\n\n // https://fetch.spec.whatwg.org/#dom-headers-delete\n delete (name) {\n webidl.brandCheck(this, Headers)\n\n webidl.argumentLengthCheck(arguments, 1, { header: 'Headers.delete' })\n\n name = webidl.converters.ByteString(name)\n\n // 1. If name is not a header name, then throw a TypeError.\n if (!isValidHeaderName(name)) {\n throw webidl.errors.invalidArgument({\n prefix: 'Headers.delete',\n value: name,\n type: 'header name'\n })\n }\n\n // 2. If this’s guard is \"immutable\", then throw a TypeError.\n // 3. Otherwise, if this’s guard is \"request\" and name is a\n // forbidden header name, return.\n // 4. Otherwise, if this’s guard is \"request-no-cors\", name\n // is not a no-CORS-safelisted request-header name, and\n // name is not a privileged no-CORS request-header name,\n // return.\n // 5. Otherwise, if this’s guard is \"response\" and name is\n // a forbidden response-header name, return.\n // Note: undici does not implement forbidden header names\n if (this[kGuard] === 'immutable') {\n throw new TypeError('immutable')\n } else if (this[kGuard] === 'request-no-cors') {\n // TODO\n }\n\n // 6. If this’s header list does not contain name, then\n // return.\n if (!this[kHeadersList].contains(name)) {\n return\n }\n\n // 7. Delete name from this’s header list.\n // 8. If this’s guard is \"request-no-cors\", then remove\n // privileged no-CORS request headers from this.\n this[kHeadersList].delete(name)\n }\n\n // https://fetch.spec.whatwg.org/#dom-headers-get\n get (name) {\n webidl.brandCheck(this, Headers)\n\n webidl.argumentLengthCheck(arguments, 1, { header: 'Headers.get' })\n\n name = webidl.converters.ByteString(name)\n\n // 1. If name is not a header name, then throw a TypeError.\n if (!isValidHeaderName(name)) {\n throw webidl.errors.invalidArgument({\n prefix: 'Headers.get',\n value: name,\n type: 'header name'\n })\n }\n\n // 2. Return the result of getting name from this’s header\n // list.\n return this[kHeadersList].get(name)\n }\n\n // https://fetch.spec.whatwg.org/#dom-headers-has\n has (name) {\n webidl.brandCheck(this, Headers)\n\n webidl.argumentLengthCheck(arguments, 1, { header: 'Headers.has' })\n\n name = webidl.converters.ByteString(name)\n\n // 1. If name is not a header name, then throw a TypeError.\n if (!isValidHeaderName(name)) {\n throw webidl.errors.invalidArgument({\n prefix: 'Headers.has',\n value: name,\n type: 'header name'\n })\n }\n\n // 2. Return true if this’s header list contains name;\n // otherwise false.\n return this[kHeadersList].contains(name)\n }\n\n // https://fetch.spec.whatwg.org/#dom-headers-set\n set (name, value) {\n webidl.brandCheck(this, Headers)\n\n webidl.argumentLengthCheck(arguments, 2, { header: 'Headers.set' })\n\n name = webidl.converters.ByteString(name)\n value = webidl.converters.ByteString(value)\n\n // 1. Normalize value.\n value = headerValueNormalize(value)\n\n // 2. If name is not a header name or value is not a\n // header value, then throw a TypeError.\n if (!isValidHeaderName(name)) {\n throw webidl.errors.invalidArgument({\n prefix: 'Headers.set',\n value: name,\n type: 'header name'\n })\n } else if (!isValidHeaderValue(value)) {\n throw webidl.errors.invalidArgument({\n prefix: 'Headers.set',\n value,\n type: 'header value'\n })\n }\n\n // 3. If this’s guard is \"immutable\", then throw a TypeError.\n // 4. Otherwise, if this’s guard is \"request\" and name is a\n // forbidden header name, return.\n // 5. Otherwise, if this’s guard is \"request-no-cors\" and\n // name/value is not a no-CORS-safelisted request-header,\n // return.\n // 6. Otherwise, if this’s guard is \"response\" and name is a\n // forbidden response-header name, return.\n // Note: undici does not implement forbidden header names\n if (this[kGuard] === 'immutable') {\n throw new TypeError('immutable')\n } else if (this[kGuard] === 'request-no-cors') {\n // TODO\n }\n\n // 7. Set (name, value) in this’s header list.\n // 8. If this’s guard is \"request-no-cors\", then remove\n // privileged no-CORS request headers from this\n this[kHeadersList].set(name, value)\n }\n\n // https://fetch.spec.whatwg.org/#dom-headers-getsetcookie\n getSetCookie () {\n webidl.brandCheck(this, Headers)\n\n // 1. If this’s header list does not contain `Set-Cookie`, then return « ».\n // 2. Return the values of all headers in this’s header list whose name is\n // a byte-case-insensitive match for `Set-Cookie`, in order.\n\n const list = this[kHeadersList].cookies\n\n if (list) {\n return [...list]\n }\n\n return []\n }\n\n // https://fetch.spec.whatwg.org/#concept-header-list-sort-and-combine\n get [kHeadersSortedMap] () {\n if (this[kHeadersList][kHeadersSortedMap]) {\n return this[kHeadersList][kHeadersSortedMap]\n }\n\n // 1. Let headers be an empty list of headers with the key being the name\n // and value the value.\n const headers = []\n\n // 2. Let names be the result of convert header names to a sorted-lowercase\n // set with all the names of the headers in list.\n const names = [...this[kHeadersList]].sort((a, b) => a[0] < b[0] ? -1 : 1)\n const cookies = this[kHeadersList].cookies\n\n // 3. For each name of names:\n for (let i = 0; i < names.length; ++i) {\n const [name, value] = names[i]\n // 1. If name is `set-cookie`, then:\n if (name === 'set-cookie') {\n // 1. Let values be a list of all values of headers in list whose name\n // is a byte-case-insensitive match for name, in order.\n\n // 2. For each value of values:\n // 1. Append (name, value) to headers.\n for (let j = 0; j < cookies.length; ++j) {\n headers.push([name, cookies[j]])\n }\n } else {\n // 2. Otherwise:\n\n // 1. Let value be the result of getting name from list.\n\n // 2. Assert: value is non-null.\n assert(value !== null)\n\n // 3. Append (name, value) to headers.\n headers.push([name, value])\n }\n }\n\n this[kHeadersList][kHeadersSortedMap] = headers\n\n // 4. Return headers.\n return headers\n }\n\n keys () {\n webidl.brandCheck(this, Headers)\n\n if (this[kGuard] === 'immutable') {\n const value = this[kHeadersSortedMap]\n return makeIterator(() => value, 'Headers',\n 'key')\n }\n\n return makeIterator(\n () => [...this[kHeadersSortedMap].values()],\n 'Headers',\n 'key'\n )\n }\n\n values () {\n webidl.brandCheck(this, Headers)\n\n if (this[kGuard] === 'immutable') {\n const value = this[kHeadersSortedMap]\n return makeIterator(() => value, 'Headers',\n 'value')\n }\n\n return makeIterator(\n () => [...this[kHeadersSortedMap].values()],\n 'Headers',\n 'value'\n )\n }\n\n entries () {\n webidl.brandCheck(this, Headers)\n\n if (this[kGuard] === 'immutable') {\n const value = this[kHeadersSortedMap]\n return makeIterator(() => value, 'Headers',\n 'key+value')\n }\n\n return makeIterator(\n () => [...this[kHeadersSortedMap].values()],\n 'Headers',\n 'key+value'\n )\n }\n\n /**\n * @param {(value: string, key: string, self: Headers) => void} callbackFn\n * @param {unknown} thisArg\n */\n forEach (callbackFn, thisArg = globalThis) {\n webidl.brandCheck(this, Headers)\n\n webidl.argumentLengthCheck(arguments, 1, { header: 'Headers.forEach' })\n\n if (typeof callbackFn !== 'function') {\n throw new TypeError(\n \"Failed to execute 'forEach' on 'Headers': parameter 1 is not of type 'Function'.\"\n )\n }\n\n for (const [key, value] of this) {\n callbackFn.apply(thisArg, [value, key, this])\n }\n }\n\n [Symbol.for('nodejs.util.inspect.custom')] () {\n webidl.brandCheck(this, Headers)\n\n return this[kHeadersList]\n }\n}\n\nHeaders.prototype[Symbol.iterator] = Headers.prototype.entries\n\nObject.defineProperties(Headers.prototype, {\n append: kEnumerableProperty,\n delete: kEnumerableProperty,\n get: kEnumerableProperty,\n has: kEnumerableProperty,\n set: kEnumerableProperty,\n getSetCookie: kEnumerableProperty,\n keys: kEnumerableProperty,\n values: kEnumerableProperty,\n entries: kEnumerableProperty,\n forEach: kEnumerableProperty,\n [Symbol.iterator]: { enumerable: false },\n [Symbol.toStringTag]: {\n value: 'Headers',\n configurable: true\n }\n})\n\nwebidl.converters.HeadersInit = function (V) {\n if (webidl.util.Type(V) === 'Object') {\n if (V[Symbol.iterator]) {\n return webidl.converters['sequence>'](V)\n }\n\n return webidl.converters['record'](V)\n }\n\n throw webidl.errors.conversionFailed({\n prefix: 'Headers constructor',\n argument: 'Argument 1',\n types: ['sequence>', 'record']\n })\n}\n\nmodule.exports = {\n fill,\n Headers,\n HeadersList\n}\n","// https://github.com/Ethan-Arrowood/undici-fetch\n\n'use strict'\n\nconst {\n Response,\n makeNetworkError,\n makeAppropriateNetworkError,\n filterResponse,\n makeResponse\n} = require('./response')\nconst { Headers } = require('./headers')\nconst { Request, makeRequest } = require('./request')\nconst zlib = require('zlib')\nconst {\n bytesMatch,\n makePolicyContainer,\n clonePolicyContainer,\n requestBadPort,\n TAOCheck,\n appendRequestOriginHeader,\n responseLocationURL,\n requestCurrentURL,\n setRequestReferrerPolicyOnRedirect,\n tryUpgradeRequestToAPotentiallyTrustworthyURL,\n createOpaqueTimingInfo,\n appendFetchMetadata,\n corsCheck,\n crossOriginResourcePolicyCheck,\n determineRequestsReferrer,\n coarsenedSharedCurrentTime,\n createDeferredPromise,\n isBlobLike,\n sameOrigin,\n isCancelled,\n isAborted,\n isErrorLike,\n fullyReadBody,\n readableStreamClose,\n isomorphicEncode,\n urlIsLocal,\n urlIsHttpHttpsScheme,\n urlHasHttpsScheme\n} = require('./util')\nconst { kState, kHeaders, kGuard, kRealm } = require('./symbols')\nconst assert = require('assert')\nconst { safelyExtractBody } = require('./body')\nconst {\n redirectStatusSet,\n nullBodyStatus,\n safeMethodsSet,\n requestBodyHeader,\n subresourceSet,\n DOMException\n} = require('./constants')\nconst { kHeadersList } = require('../core/symbols')\nconst EE = require('events')\nconst { Readable, pipeline } = require('stream')\nconst { addAbortListener, isErrored, isReadable, nodeMajor, nodeMinor } = require('../core/util')\nconst { dataURLProcessor, serializeAMimeType } = require('./dataURL')\nconst { TransformStream } = require('stream/web')\nconst { getGlobalDispatcher } = require('../global')\nconst { webidl } = require('./webidl')\nconst { STATUS_CODES } = require('http')\nconst GET_OR_HEAD = ['GET', 'HEAD']\n\n/** @type {import('buffer').resolveObjectURL} */\nlet resolveObjectURL\nlet ReadableStream = globalThis.ReadableStream\n\nclass Fetch extends EE {\n constructor (dispatcher) {\n super()\n\n this.dispatcher = dispatcher\n this.connection = null\n this.dump = false\n this.state = 'ongoing'\n // 2 terminated listeners get added per request,\n // but only 1 gets removed. If there are 20 redirects,\n // 21 listeners will be added.\n // See https://github.com/nodejs/undici/issues/1711\n // TODO (fix): Find and fix root cause for leaked listener.\n this.setMaxListeners(21)\n }\n\n terminate (reason) {\n if (this.state !== 'ongoing') {\n return\n }\n\n this.state = 'terminated'\n this.connection?.destroy(reason)\n this.emit('terminated', reason)\n }\n\n // https://fetch.spec.whatwg.org/#fetch-controller-abort\n abort (error) {\n if (this.state !== 'ongoing') {\n return\n }\n\n // 1. Set controller’s state to \"aborted\".\n this.state = 'aborted'\n\n // 2. Let fallbackError be an \"AbortError\" DOMException.\n // 3. Set error to fallbackError if it is not given.\n if (!error) {\n error = new DOMException('The operation was aborted.', 'AbortError')\n }\n\n // 4. Let serializedError be StructuredSerialize(error).\n // If that threw an exception, catch it, and let\n // serializedError be StructuredSerialize(fallbackError).\n\n // 5. Set controller’s serialized abort reason to serializedError.\n this.serializedAbortReason = error\n\n this.connection?.destroy(error)\n this.emit('terminated', error)\n }\n}\n\n// https://fetch.spec.whatwg.org/#fetch-method\nfunction fetch (input, init = {}) {\n webidl.argumentLengthCheck(arguments, 1, { header: 'globalThis.fetch' })\n\n // 1. Let p be a new promise.\n const p = createDeferredPromise()\n\n // 2. Let requestObject be the result of invoking the initial value of\n // Request as constructor with input and init as arguments. If this throws\n // an exception, reject p with it and return p.\n let requestObject\n\n try {\n requestObject = new Request(input, init)\n } catch (e) {\n p.reject(e)\n return p.promise\n }\n\n // 3. Let request be requestObject’s request.\n const request = requestObject[kState]\n\n // 4. If requestObject’s signal’s aborted flag is set, then:\n if (requestObject.signal.aborted) {\n // 1. Abort the fetch() call with p, request, null, and\n // requestObject’s signal’s abort reason.\n abortFetch(p, request, null, requestObject.signal.reason)\n\n // 2. Return p.\n return p.promise\n }\n\n // 5. Let globalObject be request’s client’s global object.\n const globalObject = request.client.globalObject\n\n // 6. If globalObject is a ServiceWorkerGlobalScope object, then set\n // request’s service-workers mode to \"none\".\n if (globalObject?.constructor?.name === 'ServiceWorkerGlobalScope') {\n request.serviceWorkers = 'none'\n }\n\n // 7. Let responseObject be null.\n let responseObject = null\n\n // 8. Let relevantRealm be this’s relevant Realm.\n const relevantRealm = null\n\n // 9. Let locallyAborted be false.\n let locallyAborted = false\n\n // 10. Let controller be null.\n let controller = null\n\n // 11. Add the following abort steps to requestObject’s signal:\n addAbortListener(\n requestObject.signal,\n () => {\n // 1. Set locallyAborted to true.\n locallyAborted = true\n\n // 2. Assert: controller is non-null.\n assert(controller != null)\n\n // 3. Abort controller with requestObject’s signal’s abort reason.\n controller.abort(requestObject.signal.reason)\n\n // 4. Abort the fetch() call with p, request, responseObject,\n // and requestObject’s signal’s abort reason.\n abortFetch(p, request, responseObject, requestObject.signal.reason)\n }\n )\n\n // 12. Let handleFetchDone given response response be to finalize and\n // report timing with response, globalObject, and \"fetch\".\n const handleFetchDone = (response) =>\n finalizeAndReportTiming(response, 'fetch')\n\n // 13. Set controller to the result of calling fetch given request,\n // with processResponseEndOfBody set to handleFetchDone, and processResponse\n // given response being these substeps:\n\n const processResponse = (response) => {\n // 1. If locallyAborted is true, terminate these substeps.\n if (locallyAborted) {\n return Promise.resolve()\n }\n\n // 2. If response’s aborted flag is set, then:\n if (response.aborted) {\n // 1. Let deserializedError be the result of deserialize a serialized\n // abort reason given controller’s serialized abort reason and\n // relevantRealm.\n\n // 2. Abort the fetch() call with p, request, responseObject, and\n // deserializedError.\n\n abortFetch(p, request, responseObject, controller.serializedAbortReason)\n return Promise.resolve()\n }\n\n // 3. If response is a network error, then reject p with a TypeError\n // and terminate these substeps.\n if (response.type === 'error') {\n p.reject(\n Object.assign(new TypeError('fetch failed'), { cause: response.error })\n )\n return Promise.resolve()\n }\n\n // 4. Set responseObject to the result of creating a Response object,\n // given response, \"immutable\", and relevantRealm.\n responseObject = new Response()\n responseObject[kState] = response\n responseObject[kRealm] = relevantRealm\n responseObject[kHeaders][kHeadersList] = response.headersList\n responseObject[kHeaders][kGuard] = 'immutable'\n responseObject[kHeaders][kRealm] = relevantRealm\n\n // 5. Resolve p with responseObject.\n p.resolve(responseObject)\n }\n\n controller = fetching({\n request,\n processResponseEndOfBody: handleFetchDone,\n processResponse,\n dispatcher: init.dispatcher ?? getGlobalDispatcher() // undici\n })\n\n // 14. Return p.\n return p.promise\n}\n\n// https://fetch.spec.whatwg.org/#finalize-and-report-timing\nfunction finalizeAndReportTiming (response, initiatorType = 'other') {\n // 1. If response is an aborted network error, then return.\n if (response.type === 'error' && response.aborted) {\n return\n }\n\n // 2. If response’s URL list is null or empty, then return.\n if (!response.urlList?.length) {\n return\n }\n\n // 3. Let originalURL be response’s URL list[0].\n const originalURL = response.urlList[0]\n\n // 4. Let timingInfo be response’s timing info.\n let timingInfo = response.timingInfo\n\n // 5. Let cacheState be response’s cache state.\n let cacheState = response.cacheState\n\n // 6. If originalURL’s scheme is not an HTTP(S) scheme, then return.\n if (!urlIsHttpHttpsScheme(originalURL)) {\n return\n }\n\n // 7. If timingInfo is null, then return.\n if (timingInfo === null) {\n return\n }\n\n // 8. If response’s timing allow passed flag is not set, then:\n if (!response.timingAllowPassed) {\n // 1. Set timingInfo to a the result of creating an opaque timing info for timingInfo.\n timingInfo = createOpaqueTimingInfo({\n startTime: timingInfo.startTime\n })\n\n // 2. Set cacheState to the empty string.\n cacheState = ''\n }\n\n // 9. Set timingInfo’s end time to the coarsened shared current time\n // given global’s relevant settings object’s cross-origin isolated\n // capability.\n // TODO: given global’s relevant settings object’s cross-origin isolated\n // capability?\n timingInfo.endTime = coarsenedSharedCurrentTime()\n\n // 10. Set response’s timing info to timingInfo.\n response.timingInfo = timingInfo\n\n // 11. Mark resource timing for timingInfo, originalURL, initiatorType,\n // global, and cacheState.\n markResourceTiming(\n timingInfo,\n originalURL,\n initiatorType,\n globalThis,\n cacheState\n )\n}\n\n// https://w3c.github.io/resource-timing/#dfn-mark-resource-timing\nfunction markResourceTiming (timingInfo, originalURL, initiatorType, globalThis, cacheState) {\n if (nodeMajor > 18 || (nodeMajor === 18 && nodeMinor >= 2)) {\n performance.markResourceTiming(timingInfo, originalURL.href, initiatorType, globalThis, cacheState)\n }\n}\n\n// https://fetch.spec.whatwg.org/#abort-fetch\nfunction abortFetch (p, request, responseObject, error) {\n // Note: AbortSignal.reason was added in node v17.2.0\n // which would give us an undefined error to reject with.\n // Remove this once node v16 is no longer supported.\n if (!error) {\n error = new DOMException('The operation was aborted.', 'AbortError')\n }\n\n // 1. Reject promise with error.\n p.reject(error)\n\n // 2. If request’s body is not null and is readable, then cancel request’s\n // body with error.\n if (request.body != null && isReadable(request.body?.stream)) {\n request.body.stream.cancel(error).catch((err) => {\n if (err.code === 'ERR_INVALID_STATE') {\n // Node bug?\n return\n }\n throw err\n })\n }\n\n // 3. If responseObject is null, then return.\n if (responseObject == null) {\n return\n }\n\n // 4. Let response be responseObject’s response.\n const response = responseObject[kState]\n\n // 5. If response’s body is not null and is readable, then error response’s\n // body with error.\n if (response.body != null && isReadable(response.body?.stream)) {\n response.body.stream.cancel(error).catch((err) => {\n if (err.code === 'ERR_INVALID_STATE') {\n // Node bug?\n return\n }\n throw err\n })\n }\n}\n\n// https://fetch.spec.whatwg.org/#fetching\nfunction fetching ({\n request,\n processRequestBodyChunkLength,\n processRequestEndOfBody,\n processResponse,\n processResponseEndOfBody,\n processResponseConsumeBody,\n useParallelQueue = false,\n dispatcher // undici\n}) {\n // 1. Let taskDestination be null.\n let taskDestination = null\n\n // 2. Let crossOriginIsolatedCapability be false.\n let crossOriginIsolatedCapability = false\n\n // 3. If request’s client is non-null, then:\n if (request.client != null) {\n // 1. Set taskDestination to request’s client’s global object.\n taskDestination = request.client.globalObject\n\n // 2. Set crossOriginIsolatedCapability to request’s client’s cross-origin\n // isolated capability.\n crossOriginIsolatedCapability =\n request.client.crossOriginIsolatedCapability\n }\n\n // 4. If useParallelQueue is true, then set taskDestination to the result of\n // starting a new parallel queue.\n // TODO\n\n // 5. Let timingInfo be a new fetch timing info whose start time and\n // post-redirect start time are the coarsened shared current time given\n // crossOriginIsolatedCapability.\n const currenTime = coarsenedSharedCurrentTime(crossOriginIsolatedCapability)\n const timingInfo = createOpaqueTimingInfo({\n startTime: currenTime\n })\n\n // 6. Let fetchParams be a new fetch params whose\n // request is request,\n // timing info is timingInfo,\n // process request body chunk length is processRequestBodyChunkLength,\n // process request end-of-body is processRequestEndOfBody,\n // process response is processResponse,\n // process response consume body is processResponseConsumeBody,\n // process response end-of-body is processResponseEndOfBody,\n // task destination is taskDestination,\n // and cross-origin isolated capability is crossOriginIsolatedCapability.\n const fetchParams = {\n controller: new Fetch(dispatcher),\n request,\n timingInfo,\n processRequestBodyChunkLength,\n processRequestEndOfBody,\n processResponse,\n processResponseConsumeBody,\n processResponseEndOfBody,\n taskDestination,\n crossOriginIsolatedCapability\n }\n\n // 7. If request’s body is a byte sequence, then set request’s body to\n // request’s body as a body.\n // NOTE: Since fetching is only called from fetch, body should already be\n // extracted.\n assert(!request.body || request.body.stream)\n\n // 8. If request’s window is \"client\", then set request’s window to request’s\n // client, if request’s client’s global object is a Window object; otherwise\n // \"no-window\".\n if (request.window === 'client') {\n // TODO: What if request.client is null?\n request.window =\n request.client?.globalObject?.constructor?.name === 'Window'\n ? request.client\n : 'no-window'\n }\n\n // 9. If request’s origin is \"client\", then set request’s origin to request’s\n // client’s origin.\n if (request.origin === 'client') {\n // TODO: What if request.client is null?\n request.origin = request.client?.origin\n }\n\n // 10. If all of the following conditions are true:\n // TODO\n\n // 11. If request’s policy container is \"client\", then:\n if (request.policyContainer === 'client') {\n // 1. If request’s client is non-null, then set request’s policy\n // container to a clone of request’s client’s policy container. [HTML]\n if (request.client != null) {\n request.policyContainer = clonePolicyContainer(\n request.client.policyContainer\n )\n } else {\n // 2. Otherwise, set request’s policy container to a new policy\n // container.\n request.policyContainer = makePolicyContainer()\n }\n }\n\n // 12. If request’s header list does not contain `Accept`, then:\n if (!request.headersList.contains('accept')) {\n // 1. Let value be `*/*`.\n const value = '*/*'\n\n // 2. A user agent should set value to the first matching statement, if\n // any, switching on request’s destination:\n // \"document\"\n // \"frame\"\n // \"iframe\"\n // `text/html,application/xhtml+xml,application/xml;q=0.9,*/*;q=0.8`\n // \"image\"\n // `image/png,image/svg+xml,image/*;q=0.8,*/*;q=0.5`\n // \"style\"\n // `text/css,*/*;q=0.1`\n // TODO\n\n // 3. Append `Accept`/value to request’s header list.\n request.headersList.append('accept', value)\n }\n\n // 13. If request’s header list does not contain `Accept-Language`, then\n // user agents should append `Accept-Language`/an appropriate value to\n // request’s header list.\n if (!request.headersList.contains('accept-language')) {\n request.headersList.append('accept-language', '*')\n }\n\n // 14. If request’s priority is null, then use request’s initiator and\n // destination appropriately in setting request’s priority to a\n // user-agent-defined object.\n if (request.priority === null) {\n // TODO\n }\n\n // 15. If request is a subresource request, then:\n if (subresourceSet.has(request.destination)) {\n // TODO\n }\n\n // 16. Run main fetch given fetchParams.\n mainFetch(fetchParams)\n .catch(err => {\n fetchParams.controller.terminate(err)\n })\n\n // 17. Return fetchParam's controller\n return fetchParams.controller\n}\n\n// https://fetch.spec.whatwg.org/#concept-main-fetch\nasync function mainFetch (fetchParams, recursive = false) {\n // 1. Let request be fetchParams’s request.\n const request = fetchParams.request\n\n // 2. Let response be null.\n let response = null\n\n // 3. If request’s local-URLs-only flag is set and request’s current URL is\n // not local, then set response to a network error.\n if (request.localURLsOnly && !urlIsLocal(requestCurrentURL(request))) {\n response = makeNetworkError('local URLs only')\n }\n\n // 4. Run report Content Security Policy violations for request.\n // TODO\n\n // 5. Upgrade request to a potentially trustworthy URL, if appropriate.\n tryUpgradeRequestToAPotentiallyTrustworthyURL(request)\n\n // 6. If should request be blocked due to a bad port, should fetching request\n // be blocked as mixed content, or should request be blocked by Content\n // Security Policy returns blocked, then set response to a network error.\n if (requestBadPort(request) === 'blocked') {\n response = makeNetworkError('bad port')\n }\n // TODO: should fetching request be blocked as mixed content?\n // TODO: should request be blocked by Content Security Policy?\n\n // 7. If request’s referrer policy is the empty string, then set request’s\n // referrer policy to request’s policy container’s referrer policy.\n if (request.referrerPolicy === '') {\n request.referrerPolicy = request.policyContainer.referrerPolicy\n }\n\n // 8. If request’s referrer is not \"no-referrer\", then set request’s\n // referrer to the result of invoking determine request’s referrer.\n if (request.referrer !== 'no-referrer') {\n request.referrer = determineRequestsReferrer(request)\n }\n\n // 9. Set request’s current URL’s scheme to \"https\" if all of the following\n // conditions are true:\n // - request’s current URL’s scheme is \"http\"\n // - request’s current URL’s host is a domain\n // - Matching request’s current URL’s host per Known HSTS Host Domain Name\n // Matching results in either a superdomain match with an asserted\n // includeSubDomains directive or a congruent match (with or without an\n // asserted includeSubDomains directive). [HSTS]\n // TODO\n\n // 10. If recursive is false, then run the remaining steps in parallel.\n // TODO\n\n // 11. If response is null, then set response to the result of running\n // the steps corresponding to the first matching statement:\n if (response === null) {\n response = await (async () => {\n const currentURL = requestCurrentURL(request)\n\n if (\n // - request’s current URL’s origin is same origin with request’s origin,\n // and request’s response tainting is \"basic\"\n (sameOrigin(currentURL, request.url) && request.responseTainting === 'basic') ||\n // request’s current URL’s scheme is \"data\"\n (currentURL.protocol === 'data:') ||\n // - request’s mode is \"navigate\" or \"websocket\"\n (request.mode === 'navigate' || request.mode === 'websocket')\n ) {\n // 1. Set request’s response tainting to \"basic\".\n request.responseTainting = 'basic'\n\n // 2. Return the result of running scheme fetch given fetchParams.\n return await schemeFetch(fetchParams)\n }\n\n // request’s mode is \"same-origin\"\n if (request.mode === 'same-origin') {\n // 1. Return a network error.\n return makeNetworkError('request mode cannot be \"same-origin\"')\n }\n\n // request’s mode is \"no-cors\"\n if (request.mode === 'no-cors') {\n // 1. If request’s redirect mode is not \"follow\", then return a network\n // error.\n if (request.redirect !== 'follow') {\n return makeNetworkError(\n 'redirect mode cannot be \"follow\" for \"no-cors\" request'\n )\n }\n\n // 2. Set request’s response tainting to \"opaque\".\n request.responseTainting = 'opaque'\n\n // 3. Return the result of running scheme fetch given fetchParams.\n return await schemeFetch(fetchParams)\n }\n\n // request’s current URL’s scheme is not an HTTP(S) scheme\n if (!urlIsHttpHttpsScheme(requestCurrentURL(request))) {\n // Return a network error.\n return makeNetworkError('URL scheme must be a HTTP(S) scheme')\n }\n\n // - request’s use-CORS-preflight flag is set\n // - request’s unsafe-request flag is set and either request’s method is\n // not a CORS-safelisted method or CORS-unsafe request-header names with\n // request’s header list is not empty\n // 1. Set request’s response tainting to \"cors\".\n // 2. Let corsWithPreflightResponse be the result of running HTTP fetch\n // given fetchParams and true.\n // 3. If corsWithPreflightResponse is a network error, then clear cache\n // entries using request.\n // 4. Return corsWithPreflightResponse.\n // TODO\n\n // Otherwise\n // 1. Set request’s response tainting to \"cors\".\n request.responseTainting = 'cors'\n\n // 2. Return the result of running HTTP fetch given fetchParams.\n return await httpFetch(fetchParams)\n })()\n }\n\n // 12. If recursive is true, then return response.\n if (recursive) {\n return response\n }\n\n // 13. If response is not a network error and response is not a filtered\n // response, then:\n if (response.status !== 0 && !response.internalResponse) {\n // If request’s response tainting is \"cors\", then:\n if (request.responseTainting === 'cors') {\n // 1. Let headerNames be the result of extracting header list values\n // given `Access-Control-Expose-Headers` and response’s header list.\n // TODO\n // 2. If request’s credentials mode is not \"include\" and headerNames\n // contains `*`, then set response’s CORS-exposed header-name list to\n // all unique header names in response’s header list.\n // TODO\n // 3. Otherwise, if headerNames is not null or failure, then set\n // response’s CORS-exposed header-name list to headerNames.\n // TODO\n }\n\n // Set response to the following filtered response with response as its\n // internal response, depending on request’s response tainting:\n if (request.responseTainting === 'basic') {\n response = filterResponse(response, 'basic')\n } else if (request.responseTainting === 'cors') {\n response = filterResponse(response, 'cors')\n } else if (request.responseTainting === 'opaque') {\n response = filterResponse(response, 'opaque')\n } else {\n assert(false)\n }\n }\n\n // 14. Let internalResponse be response, if response is a network error,\n // and response’s internal response otherwise.\n let internalResponse =\n response.status === 0 ? response : response.internalResponse\n\n // 15. If internalResponse’s URL list is empty, then set it to a clone of\n // request’s URL list.\n if (internalResponse.urlList.length === 0) {\n internalResponse.urlList.push(...request.urlList)\n }\n\n // 16. If request’s timing allow failed flag is unset, then set\n // internalResponse’s timing allow passed flag.\n if (!request.timingAllowFailed) {\n response.timingAllowPassed = true\n }\n\n // 17. If response is not a network error and any of the following returns\n // blocked\n // - should internalResponse to request be blocked as mixed content\n // - should internalResponse to request be blocked by Content Security Policy\n // - should internalResponse to request be blocked due to its MIME type\n // - should internalResponse to request be blocked due to nosniff\n // TODO\n\n // 18. If response’s type is \"opaque\", internalResponse’s status is 206,\n // internalResponse’s range-requested flag is set, and request’s header\n // list does not contain `Range`, then set response and internalResponse\n // to a network error.\n if (\n response.type === 'opaque' &&\n internalResponse.status === 206 &&\n internalResponse.rangeRequested &&\n !request.headers.contains('range')\n ) {\n response = internalResponse = makeNetworkError()\n }\n\n // 19. If response is not a network error and either request’s method is\n // `HEAD` or `CONNECT`, or internalResponse’s status is a null body status,\n // set internalResponse’s body to null and disregard any enqueuing toward\n // it (if any).\n if (\n response.status !== 0 &&\n (request.method === 'HEAD' ||\n request.method === 'CONNECT' ||\n nullBodyStatus.includes(internalResponse.status))\n ) {\n internalResponse.body = null\n fetchParams.controller.dump = true\n }\n\n // 20. If request’s integrity metadata is not the empty string, then:\n if (request.integrity) {\n // 1. Let processBodyError be this step: run fetch finale given fetchParams\n // and a network error.\n const processBodyError = (reason) =>\n fetchFinale(fetchParams, makeNetworkError(reason))\n\n // 2. If request’s response tainting is \"opaque\", or response’s body is null,\n // then run processBodyError and abort these steps.\n if (request.responseTainting === 'opaque' || response.body == null) {\n processBodyError(response.error)\n return\n }\n\n // 3. Let processBody given bytes be these steps:\n const processBody = (bytes) => {\n // 1. If bytes do not match request’s integrity metadata,\n // then run processBodyError and abort these steps. [SRI]\n if (!bytesMatch(bytes, request.integrity)) {\n processBodyError('integrity mismatch')\n return\n }\n\n // 2. Set response’s body to bytes as a body.\n response.body = safelyExtractBody(bytes)[0]\n\n // 3. Run fetch finale given fetchParams and response.\n fetchFinale(fetchParams, response)\n }\n\n // 4. Fully read response’s body given processBody and processBodyError.\n await fullyReadBody(response.body, processBody, processBodyError)\n } else {\n // 21. Otherwise, run fetch finale given fetchParams and response.\n fetchFinale(fetchParams, response)\n }\n}\n\n// https://fetch.spec.whatwg.org/#concept-scheme-fetch\n// given a fetch params fetchParams\nfunction schemeFetch (fetchParams) {\n // Note: since the connection is destroyed on redirect, which sets fetchParams to a\n // cancelled state, we do not want this condition to trigger *unless* there have been\n // no redirects. See https://github.com/nodejs/undici/issues/1776\n // 1. If fetchParams is canceled, then return the appropriate network error for fetchParams.\n if (isCancelled(fetchParams) && fetchParams.request.redirectCount === 0) {\n return Promise.resolve(makeAppropriateNetworkError(fetchParams))\n }\n\n // 2. Let request be fetchParams’s request.\n const { request } = fetchParams\n\n const { protocol: scheme } = requestCurrentURL(request)\n\n // 3. Switch on request’s current URL’s scheme and run the associated steps:\n switch (scheme) {\n case 'about:': {\n // If request’s current URL’s path is the string \"blank\", then return a new response\n // whose status message is `OK`, header list is « (`Content-Type`, `text/html;charset=utf-8`) »,\n // and body is the empty byte sequence as a body.\n\n // Otherwise, return a network error.\n return Promise.resolve(makeNetworkError('about scheme is not supported'))\n }\n case 'blob:': {\n if (!resolveObjectURL) {\n resolveObjectURL = require('buffer').resolveObjectURL\n }\n\n // 1. Let blobURLEntry be request’s current URL’s blob URL entry.\n const blobURLEntry = requestCurrentURL(request)\n\n // https://github.com/web-platform-tests/wpt/blob/7b0ebaccc62b566a1965396e5be7bb2bc06f841f/FileAPI/url/resources/fetch-tests.js#L52-L56\n // Buffer.resolveObjectURL does not ignore URL queries.\n if (blobURLEntry.search.length !== 0) {\n return Promise.resolve(makeNetworkError('NetworkError when attempting to fetch resource.'))\n }\n\n const blobURLEntryObject = resolveObjectURL(blobURLEntry.toString())\n\n // 2. If request’s method is not `GET`, blobURLEntry is null, or blobURLEntry’s\n // object is not a Blob object, then return a network error.\n if (request.method !== 'GET' || !isBlobLike(blobURLEntryObject)) {\n return Promise.resolve(makeNetworkError('invalid method'))\n }\n\n // 3. Let bodyWithType be the result of safely extracting blobURLEntry’s object.\n const bodyWithType = safelyExtractBody(blobURLEntryObject)\n\n // 4. Let body be bodyWithType’s body.\n const body = bodyWithType[0]\n\n // 5. Let length be body’s length, serialized and isomorphic encoded.\n const length = isomorphicEncode(`${body.length}`)\n\n // 6. Let type be bodyWithType’s type if it is non-null; otherwise the empty byte sequence.\n const type = bodyWithType[1] ?? ''\n\n // 7. Return a new response whose status message is `OK`, header list is\n // « (`Content-Length`, length), (`Content-Type`, type) », and body is body.\n const response = makeResponse({\n statusText: 'OK',\n headersList: [\n ['content-length', { name: 'Content-Length', value: length }],\n ['content-type', { name: 'Content-Type', value: type }]\n ]\n })\n\n response.body = body\n\n return Promise.resolve(response)\n }\n case 'data:': {\n // 1. Let dataURLStruct be the result of running the\n // data: URL processor on request’s current URL.\n const currentURL = requestCurrentURL(request)\n const dataURLStruct = dataURLProcessor(currentURL)\n\n // 2. If dataURLStruct is failure, then return a\n // network error.\n if (dataURLStruct === 'failure') {\n return Promise.resolve(makeNetworkError('failed to fetch the data URL'))\n }\n\n // 3. Let mimeType be dataURLStruct’s MIME type, serialized.\n const mimeType = serializeAMimeType(dataURLStruct.mimeType)\n\n // 4. Return a response whose status message is `OK`,\n // header list is « (`Content-Type`, mimeType) »,\n // and body is dataURLStruct’s body as a body.\n return Promise.resolve(makeResponse({\n statusText: 'OK',\n headersList: [\n ['content-type', { name: 'Content-Type', value: mimeType }]\n ],\n body: safelyExtractBody(dataURLStruct.body)[0]\n }))\n }\n case 'file:': {\n // For now, unfortunate as it is, file URLs are left as an exercise for the reader.\n // When in doubt, return a network error.\n return Promise.resolve(makeNetworkError('not implemented... yet...'))\n }\n case 'http:':\n case 'https:': {\n // Return the result of running HTTP fetch given fetchParams.\n\n return httpFetch(fetchParams)\n .catch((err) => makeNetworkError(err))\n }\n default: {\n return Promise.resolve(makeNetworkError('unknown scheme'))\n }\n }\n}\n\n// https://fetch.spec.whatwg.org/#finalize-response\nfunction finalizeResponse (fetchParams, response) {\n // 1. Set fetchParams’s request’s done flag.\n fetchParams.request.done = true\n\n // 2, If fetchParams’s process response done is not null, then queue a fetch\n // task to run fetchParams’s process response done given response, with\n // fetchParams’s task destination.\n if (fetchParams.processResponseDone != null) {\n queueMicrotask(() => fetchParams.processResponseDone(response))\n }\n}\n\n// https://fetch.spec.whatwg.org/#fetch-finale\nfunction fetchFinale (fetchParams, response) {\n // 1. If response is a network error, then:\n if (response.type === 'error') {\n // 1. Set response’s URL list to « fetchParams’s request’s URL list[0] ».\n response.urlList = [fetchParams.request.urlList[0]]\n\n // 2. Set response’s timing info to the result of creating an opaque timing\n // info for fetchParams’s timing info.\n response.timingInfo = createOpaqueTimingInfo({\n startTime: fetchParams.timingInfo.startTime\n })\n }\n\n // 2. Let processResponseEndOfBody be the following steps:\n const processResponseEndOfBody = () => {\n // 1. Set fetchParams’s request’s done flag.\n fetchParams.request.done = true\n\n // If fetchParams’s process response end-of-body is not null,\n // then queue a fetch task to run fetchParams’s process response\n // end-of-body given response with fetchParams’s task destination.\n if (fetchParams.processResponseEndOfBody != null) {\n queueMicrotask(() => fetchParams.processResponseEndOfBody(response))\n }\n }\n\n // 3. If fetchParams’s process response is non-null, then queue a fetch task\n // to run fetchParams’s process response given response, with fetchParams’s\n // task destination.\n if (fetchParams.processResponse != null) {\n queueMicrotask(() => fetchParams.processResponse(response))\n }\n\n // 4. If response’s body is null, then run processResponseEndOfBody.\n if (response.body == null) {\n processResponseEndOfBody()\n } else {\n // 5. Otherwise:\n\n // 1. Let transformStream be a new a TransformStream.\n\n // 2. Let identityTransformAlgorithm be an algorithm which, given chunk,\n // enqueues chunk in transformStream.\n const identityTransformAlgorithm = (chunk, controller) => {\n controller.enqueue(chunk)\n }\n\n // 3. Set up transformStream with transformAlgorithm set to identityTransformAlgorithm\n // and flushAlgorithm set to processResponseEndOfBody.\n const transformStream = new TransformStream({\n start () {},\n transform: identityTransformAlgorithm,\n flush: processResponseEndOfBody\n }, {\n size () {\n return 1\n }\n }, {\n size () {\n return 1\n }\n })\n\n // 4. Set response’s body to the result of piping response’s body through transformStream.\n response.body = { stream: response.body.stream.pipeThrough(transformStream) }\n }\n\n // 6. If fetchParams’s process response consume body is non-null, then:\n if (fetchParams.processResponseConsumeBody != null) {\n // 1. Let processBody given nullOrBytes be this step: run fetchParams’s\n // process response consume body given response and nullOrBytes.\n const processBody = (nullOrBytes) => fetchParams.processResponseConsumeBody(response, nullOrBytes)\n\n // 2. Let processBodyError be this step: run fetchParams’s process\n // response consume body given response and failure.\n const processBodyError = (failure) => fetchParams.processResponseConsumeBody(response, failure)\n\n // 3. If response’s body is null, then queue a fetch task to run processBody\n // given null, with fetchParams’s task destination.\n if (response.body == null) {\n queueMicrotask(() => processBody(null))\n } else {\n // 4. Otherwise, fully read response’s body given processBody, processBodyError,\n // and fetchParams’s task destination.\n return fullyReadBody(response.body, processBody, processBodyError)\n }\n return Promise.resolve()\n }\n}\n\n// https://fetch.spec.whatwg.org/#http-fetch\nasync function httpFetch (fetchParams) {\n // 1. Let request be fetchParams’s request.\n const request = fetchParams.request\n\n // 2. Let response be null.\n let response = null\n\n // 3. Let actualResponse be null.\n let actualResponse = null\n\n // 4. Let timingInfo be fetchParams’s timing info.\n const timingInfo = fetchParams.timingInfo\n\n // 5. If request’s service-workers mode is \"all\", then:\n if (request.serviceWorkers === 'all') {\n // TODO\n }\n\n // 6. If response is null, then:\n if (response === null) {\n // 1. If makeCORSPreflight is true and one of these conditions is true:\n // TODO\n\n // 2. If request’s redirect mode is \"follow\", then set request’s\n // service-workers mode to \"none\".\n if (request.redirect === 'follow') {\n request.serviceWorkers = 'none'\n }\n\n // 3. Set response and actualResponse to the result of running\n // HTTP-network-or-cache fetch given fetchParams.\n actualResponse = response = await httpNetworkOrCacheFetch(fetchParams)\n\n // 4. If request’s response tainting is \"cors\" and a CORS check\n // for request and response returns failure, then return a network error.\n if (\n request.responseTainting === 'cors' &&\n corsCheck(request, response) === 'failure'\n ) {\n return makeNetworkError('cors failure')\n }\n\n // 5. If the TAO check for request and response returns failure, then set\n // request’s timing allow failed flag.\n if (TAOCheck(request, response) === 'failure') {\n request.timingAllowFailed = true\n }\n }\n\n // 7. If either request’s response tainting or response’s type\n // is \"opaque\", and the cross-origin resource policy check with\n // request’s origin, request’s client, request’s destination,\n // and actualResponse returns blocked, then return a network error.\n if (\n (request.responseTainting === 'opaque' || response.type === 'opaque') &&\n crossOriginResourcePolicyCheck(\n request.origin,\n request.client,\n request.destination,\n actualResponse\n ) === 'blocked'\n ) {\n return makeNetworkError('blocked')\n }\n\n // 8. If actualResponse’s status is a redirect status, then:\n if (redirectStatusSet.has(actualResponse.status)) {\n // 1. If actualResponse’s status is not 303, request’s body is not null,\n // and the connection uses HTTP/2, then user agents may, and are even\n // encouraged to, transmit an RST_STREAM frame.\n // See, https://github.com/whatwg/fetch/issues/1288\n if (request.redirect !== 'manual') {\n fetchParams.controller.connection.destroy()\n }\n\n // 2. Switch on request’s redirect mode:\n if (request.redirect === 'error') {\n // Set response to a network error.\n response = makeNetworkError('unexpected redirect')\n } else if (request.redirect === 'manual') {\n // Set response to an opaque-redirect filtered response whose internal\n // response is actualResponse.\n // NOTE(spec): On the web this would return an `opaqueredirect` response,\n // but that doesn't make sense server side.\n // See https://github.com/nodejs/undici/issues/1193.\n response = actualResponse\n } else if (request.redirect === 'follow') {\n // Set response to the result of running HTTP-redirect fetch given\n // fetchParams and response.\n response = await httpRedirectFetch(fetchParams, response)\n } else {\n assert(false)\n }\n }\n\n // 9. Set response’s timing info to timingInfo.\n response.timingInfo = timingInfo\n\n // 10. Return response.\n return response\n}\n\n// https://fetch.spec.whatwg.org/#http-redirect-fetch\nfunction httpRedirectFetch (fetchParams, response) {\n // 1. Let request be fetchParams’s request.\n const request = fetchParams.request\n\n // 2. Let actualResponse be response, if response is not a filtered response,\n // and response’s internal response otherwise.\n const actualResponse = response.internalResponse\n ? response.internalResponse\n : response\n\n // 3. Let locationURL be actualResponse’s location URL given request’s current\n // URL’s fragment.\n let locationURL\n\n try {\n locationURL = responseLocationURL(\n actualResponse,\n requestCurrentURL(request).hash\n )\n\n // 4. If locationURL is null, then return response.\n if (locationURL == null) {\n return response\n }\n } catch (err) {\n // 5. If locationURL is failure, then return a network error.\n return Promise.resolve(makeNetworkError(err))\n }\n\n // 6. If locationURL’s scheme is not an HTTP(S) scheme, then return a network\n // error.\n if (!urlIsHttpHttpsScheme(locationURL)) {\n return Promise.resolve(makeNetworkError('URL scheme must be a HTTP(S) scheme'))\n }\n\n // 7. If request’s redirect count is 20, then return a network error.\n if (request.redirectCount === 20) {\n return Promise.resolve(makeNetworkError('redirect count exceeded'))\n }\n\n // 8. Increase request’s redirect count by 1.\n request.redirectCount += 1\n\n // 9. If request’s mode is \"cors\", locationURL includes credentials, and\n // request’s origin is not same origin with locationURL’s origin, then return\n // a network error.\n if (\n request.mode === 'cors' &&\n (locationURL.username || locationURL.password) &&\n !sameOrigin(request, locationURL)\n ) {\n return Promise.resolve(makeNetworkError('cross origin not allowed for request mode \"cors\"'))\n }\n\n // 10. If request’s response tainting is \"cors\" and locationURL includes\n // credentials, then return a network error.\n if (\n request.responseTainting === 'cors' &&\n (locationURL.username || locationURL.password)\n ) {\n return Promise.resolve(makeNetworkError(\n 'URL cannot contain credentials for request mode \"cors\"'\n ))\n }\n\n // 11. If actualResponse’s status is not 303, request’s body is non-null,\n // and request’s body’s source is null, then return a network error.\n if (\n actualResponse.status !== 303 &&\n request.body != null &&\n request.body.source == null\n ) {\n return Promise.resolve(makeNetworkError())\n }\n\n // 12. If one of the following is true\n // - actualResponse’s status is 301 or 302 and request’s method is `POST`\n // - actualResponse’s status is 303 and request’s method is not `GET` or `HEAD`\n if (\n ([301, 302].includes(actualResponse.status) && request.method === 'POST') ||\n (actualResponse.status === 303 &&\n !GET_OR_HEAD.includes(request.method))\n ) {\n // then:\n // 1. Set request’s method to `GET` and request’s body to null.\n request.method = 'GET'\n request.body = null\n\n // 2. For each headerName of request-body-header name, delete headerName from\n // request’s header list.\n for (const headerName of requestBodyHeader) {\n request.headersList.delete(headerName)\n }\n }\n\n // 13. If request’s current URL’s origin is not same origin with locationURL’s\n // origin, then for each headerName of CORS non-wildcard request-header name,\n // delete headerName from request’s header list.\n if (!sameOrigin(requestCurrentURL(request), locationURL)) {\n // https://fetch.spec.whatwg.org/#cors-non-wildcard-request-header-name\n request.headersList.delete('authorization')\n\n // https://fetch.spec.whatwg.org/#authentication-entries\n request.headersList.delete('proxy-authorization', true)\n\n // \"Cookie\" and \"Host\" are forbidden request-headers, which undici doesn't implement.\n request.headersList.delete('cookie')\n request.headersList.delete('host')\n }\n\n // 14. If request’s body is non-null, then set request’s body to the first return\n // value of safely extracting request’s body’s source.\n if (request.body != null) {\n assert(request.body.source != null)\n request.body = safelyExtractBody(request.body.source)[0]\n }\n\n // 15. Let timingInfo be fetchParams’s timing info.\n const timingInfo = fetchParams.timingInfo\n\n // 16. Set timingInfo’s redirect end time and post-redirect start time to the\n // coarsened shared current time given fetchParams’s cross-origin isolated\n // capability.\n timingInfo.redirectEndTime = timingInfo.postRedirectStartTime =\n coarsenedSharedCurrentTime(fetchParams.crossOriginIsolatedCapability)\n\n // 17. If timingInfo’s redirect start time is 0, then set timingInfo’s\n // redirect start time to timingInfo’s start time.\n if (timingInfo.redirectStartTime === 0) {\n timingInfo.redirectStartTime = timingInfo.startTime\n }\n\n // 18. Append locationURL to request’s URL list.\n request.urlList.push(locationURL)\n\n // 19. Invoke set request’s referrer policy on redirect on request and\n // actualResponse.\n setRequestReferrerPolicyOnRedirect(request, actualResponse)\n\n // 20. Return the result of running main fetch given fetchParams and true.\n return mainFetch(fetchParams, true)\n}\n\n// https://fetch.spec.whatwg.org/#http-network-or-cache-fetch\nasync function httpNetworkOrCacheFetch (\n fetchParams,\n isAuthenticationFetch = false,\n isNewConnectionFetch = false\n) {\n // 1. Let request be fetchParams’s request.\n const request = fetchParams.request\n\n // 2. Let httpFetchParams be null.\n let httpFetchParams = null\n\n // 3. Let httpRequest be null.\n let httpRequest = null\n\n // 4. Let response be null.\n let response = null\n\n // 5. Let storedResponse be null.\n // TODO: cache\n\n // 6. Let httpCache be null.\n const httpCache = null\n\n // 7. Let the revalidatingFlag be unset.\n const revalidatingFlag = false\n\n // 8. Run these steps, but abort when the ongoing fetch is terminated:\n\n // 1. If request’s window is \"no-window\" and request’s redirect mode is\n // \"error\", then set httpFetchParams to fetchParams and httpRequest to\n // request.\n if (request.window === 'no-window' && request.redirect === 'error') {\n httpFetchParams = fetchParams\n httpRequest = request\n } else {\n // Otherwise:\n\n // 1. Set httpRequest to a clone of request.\n httpRequest = makeRequest(request)\n\n // 2. Set httpFetchParams to a copy of fetchParams.\n httpFetchParams = { ...fetchParams }\n\n // 3. Set httpFetchParams’s request to httpRequest.\n httpFetchParams.request = httpRequest\n }\n\n // 3. Let includeCredentials be true if one of\n const includeCredentials =\n request.credentials === 'include' ||\n (request.credentials === 'same-origin' &&\n request.responseTainting === 'basic')\n\n // 4. Let contentLength be httpRequest’s body’s length, if httpRequest’s\n // body is non-null; otherwise null.\n const contentLength = httpRequest.body ? httpRequest.body.length : null\n\n // 5. Let contentLengthHeaderValue be null.\n let contentLengthHeaderValue = null\n\n // 6. If httpRequest’s body is null and httpRequest’s method is `POST` or\n // `PUT`, then set contentLengthHeaderValue to `0`.\n if (\n httpRequest.body == null &&\n ['POST', 'PUT'].includes(httpRequest.method)\n ) {\n contentLengthHeaderValue = '0'\n }\n\n // 7. If contentLength is non-null, then set contentLengthHeaderValue to\n // contentLength, serialized and isomorphic encoded.\n if (contentLength != null) {\n contentLengthHeaderValue = isomorphicEncode(`${contentLength}`)\n }\n\n // 8. If contentLengthHeaderValue is non-null, then append\n // `Content-Length`/contentLengthHeaderValue to httpRequest’s header\n // list.\n if (contentLengthHeaderValue != null) {\n httpRequest.headersList.append('content-length', contentLengthHeaderValue)\n }\n\n // 9. If contentLengthHeaderValue is non-null, then append (`Content-Length`,\n // contentLengthHeaderValue) to httpRequest’s header list.\n\n // 10. If contentLength is non-null and httpRequest’s keepalive is true,\n // then:\n if (contentLength != null && httpRequest.keepalive) {\n // NOTE: keepalive is a noop outside of browser context.\n }\n\n // 11. If httpRequest’s referrer is a URL, then append\n // `Referer`/httpRequest’s referrer, serialized and isomorphic encoded,\n // to httpRequest’s header list.\n if (httpRequest.referrer instanceof URL) {\n httpRequest.headersList.append('referer', isomorphicEncode(httpRequest.referrer.href))\n }\n\n // 12. Append a request `Origin` header for httpRequest.\n appendRequestOriginHeader(httpRequest)\n\n // 13. Append the Fetch metadata headers for httpRequest. [FETCH-METADATA]\n appendFetchMetadata(httpRequest)\n\n // 14. If httpRequest’s header list does not contain `User-Agent`, then\n // user agents should append `User-Agent`/default `User-Agent` value to\n // httpRequest’s header list.\n if (!httpRequest.headersList.contains('user-agent')) {\n httpRequest.headersList.append('user-agent', typeof esbuildDetection === 'undefined' ? 'undici' : 'node')\n }\n\n // 15. If httpRequest’s cache mode is \"default\" and httpRequest’s header\n // list contains `If-Modified-Since`, `If-None-Match`,\n // `If-Unmodified-Since`, `If-Match`, or `If-Range`, then set\n // httpRequest’s cache mode to \"no-store\".\n if (\n httpRequest.cache === 'default' &&\n (httpRequest.headersList.contains('if-modified-since') ||\n httpRequest.headersList.contains('if-none-match') ||\n httpRequest.headersList.contains('if-unmodified-since') ||\n httpRequest.headersList.contains('if-match') ||\n httpRequest.headersList.contains('if-range'))\n ) {\n httpRequest.cache = 'no-store'\n }\n\n // 16. If httpRequest’s cache mode is \"no-cache\", httpRequest’s prevent\n // no-cache cache-control header modification flag is unset, and\n // httpRequest’s header list does not contain `Cache-Control`, then append\n // `Cache-Control`/`max-age=0` to httpRequest’s header list.\n if (\n httpRequest.cache === 'no-cache' &&\n !httpRequest.preventNoCacheCacheControlHeaderModification &&\n !httpRequest.headersList.contains('cache-control')\n ) {\n httpRequest.headersList.append('cache-control', 'max-age=0')\n }\n\n // 17. If httpRequest’s cache mode is \"no-store\" or \"reload\", then:\n if (httpRequest.cache === 'no-store' || httpRequest.cache === 'reload') {\n // 1. If httpRequest’s header list does not contain `Pragma`, then append\n // `Pragma`/`no-cache` to httpRequest’s header list.\n if (!httpRequest.headersList.contains('pragma')) {\n httpRequest.headersList.append('pragma', 'no-cache')\n }\n\n // 2. If httpRequest’s header list does not contain `Cache-Control`,\n // then append `Cache-Control`/`no-cache` to httpRequest’s header list.\n if (!httpRequest.headersList.contains('cache-control')) {\n httpRequest.headersList.append('cache-control', 'no-cache')\n }\n }\n\n // 18. If httpRequest’s header list contains `Range`, then append\n // `Accept-Encoding`/`identity` to httpRequest’s header list.\n if (httpRequest.headersList.contains('range')) {\n httpRequest.headersList.append('accept-encoding', 'identity')\n }\n\n // 19. Modify httpRequest’s header list per HTTP. Do not append a given\n // header if httpRequest’s header list contains that header’s name.\n // TODO: https://github.com/whatwg/fetch/issues/1285#issuecomment-896560129\n if (!httpRequest.headersList.contains('accept-encoding')) {\n if (urlHasHttpsScheme(requestCurrentURL(httpRequest))) {\n httpRequest.headersList.append('accept-encoding', 'br, gzip, deflate')\n } else {\n httpRequest.headersList.append('accept-encoding', 'gzip, deflate')\n }\n }\n\n httpRequest.headersList.delete('host')\n\n // 20. If includeCredentials is true, then:\n if (includeCredentials) {\n // 1. If the user agent is not configured to block cookies for httpRequest\n // (see section 7 of [COOKIES]), then:\n // TODO: credentials\n // 2. If httpRequest’s header list does not contain `Authorization`, then:\n // TODO: credentials\n }\n\n // 21. If there’s a proxy-authentication entry, use it as appropriate.\n // TODO: proxy-authentication\n\n // 22. Set httpCache to the result of determining the HTTP cache\n // partition, given httpRequest.\n // TODO: cache\n\n // 23. If httpCache is null, then set httpRequest’s cache mode to\n // \"no-store\".\n if (httpCache == null) {\n httpRequest.cache = 'no-store'\n }\n\n // 24. If httpRequest’s cache mode is neither \"no-store\" nor \"reload\",\n // then:\n if (httpRequest.mode !== 'no-store' && httpRequest.mode !== 'reload') {\n // TODO: cache\n }\n\n // 9. If aborted, then return the appropriate network error for fetchParams.\n // TODO\n\n // 10. If response is null, then:\n if (response == null) {\n // 1. If httpRequest’s cache mode is \"only-if-cached\", then return a\n // network error.\n if (httpRequest.mode === 'only-if-cached') {\n return makeNetworkError('only if cached')\n }\n\n // 2. Let forwardResponse be the result of running HTTP-network fetch\n // given httpFetchParams, includeCredentials, and isNewConnectionFetch.\n const forwardResponse = await httpNetworkFetch(\n httpFetchParams,\n includeCredentials,\n isNewConnectionFetch\n )\n\n // 3. If httpRequest’s method is unsafe and forwardResponse’s status is\n // in the range 200 to 399, inclusive, invalidate appropriate stored\n // responses in httpCache, as per the \"Invalidation\" chapter of HTTP\n // Caching, and set storedResponse to null. [HTTP-CACHING]\n if (\n !safeMethodsSet.has(httpRequest.method) &&\n forwardResponse.status >= 200 &&\n forwardResponse.status <= 399\n ) {\n // TODO: cache\n }\n\n // 4. If the revalidatingFlag is set and forwardResponse’s status is 304,\n // then:\n if (revalidatingFlag && forwardResponse.status === 304) {\n // TODO: cache\n }\n\n // 5. If response is null, then:\n if (response == null) {\n // 1. Set response to forwardResponse.\n response = forwardResponse\n\n // 2. Store httpRequest and forwardResponse in httpCache, as per the\n // \"Storing Responses in Caches\" chapter of HTTP Caching. [HTTP-CACHING]\n // TODO: cache\n }\n }\n\n // 11. Set response’s URL list to a clone of httpRequest’s URL list.\n response.urlList = [...httpRequest.urlList]\n\n // 12. If httpRequest’s header list contains `Range`, then set response’s\n // range-requested flag.\n if (httpRequest.headersList.contains('range')) {\n response.rangeRequested = true\n }\n\n // 13. Set response’s request-includes-credentials to includeCredentials.\n response.requestIncludesCredentials = includeCredentials\n\n // 14. If response’s status is 401, httpRequest’s response tainting is not\n // \"cors\", includeCredentials is true, and request’s window is an environment\n // settings object, then:\n // TODO\n\n // 15. If response’s status is 407, then:\n if (response.status === 407) {\n // 1. If request’s window is \"no-window\", then return a network error.\n if (request.window === 'no-window') {\n return makeNetworkError()\n }\n\n // 2. ???\n\n // 3. If fetchParams is canceled, then return the appropriate network error for fetchParams.\n if (isCancelled(fetchParams)) {\n return makeAppropriateNetworkError(fetchParams)\n }\n\n // 4. Prompt the end user as appropriate in request’s window and store\n // the result as a proxy-authentication entry. [HTTP-AUTH]\n // TODO: Invoke some kind of callback?\n\n // 5. Set response to the result of running HTTP-network-or-cache fetch given\n // fetchParams.\n // TODO\n return makeNetworkError('proxy authentication required')\n }\n\n // 16. If all of the following are true\n if (\n // response’s status is 421\n response.status === 421 &&\n // isNewConnectionFetch is false\n !isNewConnectionFetch &&\n // request’s body is null, or request’s body is non-null and request’s body’s source is non-null\n (request.body == null || request.body.source != null)\n ) {\n // then:\n\n // 1. If fetchParams is canceled, then return the appropriate network error for fetchParams.\n if (isCancelled(fetchParams)) {\n return makeAppropriateNetworkError(fetchParams)\n }\n\n // 2. Set response to the result of running HTTP-network-or-cache\n // fetch given fetchParams, isAuthenticationFetch, and true.\n\n // TODO (spec): The spec doesn't specify this but we need to cancel\n // the active response before we can start a new one.\n // https://github.com/whatwg/fetch/issues/1293\n fetchParams.controller.connection.destroy()\n\n response = await httpNetworkOrCacheFetch(\n fetchParams,\n isAuthenticationFetch,\n true\n )\n }\n\n // 17. If isAuthenticationFetch is true, then create an authentication entry\n if (isAuthenticationFetch) {\n // TODO\n }\n\n // 18. Return response.\n return response\n}\n\n// https://fetch.spec.whatwg.org/#http-network-fetch\nasync function httpNetworkFetch (\n fetchParams,\n includeCredentials = false,\n forceNewConnection = false\n) {\n assert(!fetchParams.controller.connection || fetchParams.controller.connection.destroyed)\n\n fetchParams.controller.connection = {\n abort: null,\n destroyed: false,\n destroy (err) {\n if (!this.destroyed) {\n this.destroyed = true\n this.abort?.(err ?? new DOMException('The operation was aborted.', 'AbortError'))\n }\n }\n }\n\n // 1. Let request be fetchParams’s request.\n const request = fetchParams.request\n\n // 2. Let response be null.\n let response = null\n\n // 3. Let timingInfo be fetchParams’s timing info.\n const timingInfo = fetchParams.timingInfo\n\n // 4. Let httpCache be the result of determining the HTTP cache partition,\n // given request.\n // TODO: cache\n const httpCache = null\n\n // 5. If httpCache is null, then set request’s cache mode to \"no-store\".\n if (httpCache == null) {\n request.cache = 'no-store'\n }\n\n // 6. Let networkPartitionKey be the result of determining the network\n // partition key given request.\n // TODO\n\n // 7. Let newConnection be \"yes\" if forceNewConnection is true; otherwise\n // \"no\".\n const newConnection = forceNewConnection ? 'yes' : 'no' // eslint-disable-line no-unused-vars\n\n // 8. Switch on request’s mode:\n if (request.mode === 'websocket') {\n // Let connection be the result of obtaining a WebSocket connection,\n // given request’s current URL.\n // TODO\n } else {\n // Let connection be the result of obtaining a connection, given\n // networkPartitionKey, request’s current URL’s origin,\n // includeCredentials, and forceNewConnection.\n // TODO\n }\n\n // 9. Run these steps, but abort when the ongoing fetch is terminated:\n\n // 1. If connection is failure, then return a network error.\n\n // 2. Set timingInfo’s final connection timing info to the result of\n // calling clamp and coarsen connection timing info with connection’s\n // timing info, timingInfo’s post-redirect start time, and fetchParams’s\n // cross-origin isolated capability.\n\n // 3. If connection is not an HTTP/2 connection, request’s body is non-null,\n // and request’s body’s source is null, then append (`Transfer-Encoding`,\n // `chunked`) to request’s header list.\n\n // 4. Set timingInfo’s final network-request start time to the coarsened\n // shared current time given fetchParams’s cross-origin isolated\n // capability.\n\n // 5. Set response to the result of making an HTTP request over connection\n // using request with the following caveats:\n\n // - Follow the relevant requirements from HTTP. [HTTP] [HTTP-SEMANTICS]\n // [HTTP-COND] [HTTP-CACHING] [HTTP-AUTH]\n\n // - If request’s body is non-null, and request’s body’s source is null,\n // then the user agent may have a buffer of up to 64 kibibytes and store\n // a part of request’s body in that buffer. If the user agent reads from\n // request’s body beyond that buffer’s size and the user agent needs to\n // resend request, then instead return a network error.\n\n // - Set timingInfo’s final network-response start time to the coarsened\n // shared current time given fetchParams’s cross-origin isolated capability,\n // immediately after the user agent’s HTTP parser receives the first byte\n // of the response (e.g., frame header bytes for HTTP/2 or response status\n // line for HTTP/1.x).\n\n // - Wait until all the headers are transmitted.\n\n // - Any responses whose status is in the range 100 to 199, inclusive,\n // and is not 101, are to be ignored, except for the purposes of setting\n // timingInfo’s final network-response start time above.\n\n // - If request’s header list contains `Transfer-Encoding`/`chunked` and\n // response is transferred via HTTP/1.0 or older, then return a network\n // error.\n\n // - If the HTTP request results in a TLS client certificate dialog, then:\n\n // 1. If request’s window is an environment settings object, make the\n // dialog available in request’s window.\n\n // 2. Otherwise, return a network error.\n\n // To transmit request’s body body, run these steps:\n let requestBody = null\n // 1. If body is null and fetchParams’s process request end-of-body is\n // non-null, then queue a fetch task given fetchParams’s process request\n // end-of-body and fetchParams’s task destination.\n if (request.body == null && fetchParams.processRequestEndOfBody) {\n queueMicrotask(() => fetchParams.processRequestEndOfBody())\n } else if (request.body != null) {\n // 2. Otherwise, if body is non-null:\n\n // 1. Let processBodyChunk given bytes be these steps:\n const processBodyChunk = async function * (bytes) {\n // 1. If the ongoing fetch is terminated, then abort these steps.\n if (isCancelled(fetchParams)) {\n return\n }\n\n // 2. Run this step in parallel: transmit bytes.\n yield bytes\n\n // 3. If fetchParams’s process request body is non-null, then run\n // fetchParams’s process request body given bytes’s length.\n fetchParams.processRequestBodyChunkLength?.(bytes.byteLength)\n }\n\n // 2. Let processEndOfBody be these steps:\n const processEndOfBody = () => {\n // 1. If fetchParams is canceled, then abort these steps.\n if (isCancelled(fetchParams)) {\n return\n }\n\n // 2. If fetchParams’s process request end-of-body is non-null,\n // then run fetchParams’s process request end-of-body.\n if (fetchParams.processRequestEndOfBody) {\n fetchParams.processRequestEndOfBody()\n }\n }\n\n // 3. Let processBodyError given e be these steps:\n const processBodyError = (e) => {\n // 1. If fetchParams is canceled, then abort these steps.\n if (isCancelled(fetchParams)) {\n return\n }\n\n // 2. If e is an \"AbortError\" DOMException, then abort fetchParams’s controller.\n if (e.name === 'AbortError') {\n fetchParams.controller.abort()\n } else {\n fetchParams.controller.terminate(e)\n }\n }\n\n // 4. Incrementally read request’s body given processBodyChunk, processEndOfBody,\n // processBodyError, and fetchParams’s task destination.\n requestBody = (async function * () {\n try {\n for await (const bytes of request.body.stream) {\n yield * processBodyChunk(bytes)\n }\n processEndOfBody()\n } catch (err) {\n processBodyError(err)\n }\n })()\n }\n\n try {\n // socket is only provided for websockets\n const { body, status, statusText, headersList, socket } = await dispatch({ body: requestBody })\n\n if (socket) {\n response = makeResponse({ status, statusText, headersList, socket })\n } else {\n const iterator = body[Symbol.asyncIterator]()\n fetchParams.controller.next = () => iterator.next()\n\n response = makeResponse({ status, statusText, headersList })\n }\n } catch (err) {\n // 10. If aborted, then:\n if (err.name === 'AbortError') {\n // 1. If connection uses HTTP/2, then transmit an RST_STREAM frame.\n fetchParams.controller.connection.destroy()\n\n // 2. Return the appropriate network error for fetchParams.\n return makeAppropriateNetworkError(fetchParams, err)\n }\n\n return makeNetworkError(err)\n }\n\n // 11. Let pullAlgorithm be an action that resumes the ongoing fetch\n // if it is suspended.\n const pullAlgorithm = () => {\n fetchParams.controller.resume()\n }\n\n // 12. Let cancelAlgorithm be an algorithm that aborts fetchParams’s\n // controller with reason, given reason.\n const cancelAlgorithm = (reason) => {\n fetchParams.controller.abort(reason)\n }\n\n // 13. Let highWaterMark be a non-negative, non-NaN number, chosen by\n // the user agent.\n // TODO\n\n // 14. Let sizeAlgorithm be an algorithm that accepts a chunk object\n // and returns a non-negative, non-NaN, non-infinite number, chosen by the user agent.\n // TODO\n\n // 15. Let stream be a new ReadableStream.\n // 16. Set up stream with pullAlgorithm set to pullAlgorithm,\n // cancelAlgorithm set to cancelAlgorithm, highWaterMark set to\n // highWaterMark, and sizeAlgorithm set to sizeAlgorithm.\n if (!ReadableStream) {\n ReadableStream = require('stream/web').ReadableStream\n }\n\n const stream = new ReadableStream(\n {\n async start (controller) {\n fetchParams.controller.controller = controller\n },\n async pull (controller) {\n await pullAlgorithm(controller)\n },\n async cancel (reason) {\n await cancelAlgorithm(reason)\n }\n },\n {\n highWaterMark: 0,\n size () {\n return 1\n }\n }\n )\n\n // 17. Run these steps, but abort when the ongoing fetch is terminated:\n\n // 1. Set response’s body to a new body whose stream is stream.\n response.body = { stream }\n\n // 2. If response is not a network error and request’s cache mode is\n // not \"no-store\", then update response in httpCache for request.\n // TODO\n\n // 3. If includeCredentials is true and the user agent is not configured\n // to block cookies for request (see section 7 of [COOKIES]), then run the\n // \"set-cookie-string\" parsing algorithm (see section 5.2 of [COOKIES]) on\n // the value of each header whose name is a byte-case-insensitive match for\n // `Set-Cookie` in response’s header list, if any, and request’s current URL.\n // TODO\n\n // 18. If aborted, then:\n // TODO\n\n // 19. Run these steps in parallel:\n\n // 1. Run these steps, but abort when fetchParams is canceled:\n fetchParams.controller.on('terminated', onAborted)\n fetchParams.controller.resume = async () => {\n // 1. While true\n while (true) {\n // 1-3. See onData...\n\n // 4. Set bytes to the result of handling content codings given\n // codings and bytes.\n let bytes\n let isFailure\n try {\n const { done, value } = await fetchParams.controller.next()\n\n if (isAborted(fetchParams)) {\n break\n }\n\n bytes = done ? undefined : value\n } catch (err) {\n if (fetchParams.controller.ended && !timingInfo.encodedBodySize) {\n // zlib doesn't like empty streams.\n bytes = undefined\n } else {\n bytes = err\n\n // err may be propagated from the result of calling readablestream.cancel,\n // which might not be an error. https://github.com/nodejs/undici/issues/2009\n isFailure = true\n }\n }\n\n if (bytes === undefined) {\n // 2. Otherwise, if the bytes transmission for response’s message\n // body is done normally and stream is readable, then close\n // stream, finalize response for fetchParams and response, and\n // abort these in-parallel steps.\n readableStreamClose(fetchParams.controller.controller)\n\n finalizeResponse(fetchParams, response)\n\n return\n }\n\n // 5. Increase timingInfo’s decoded body size by bytes’s length.\n timingInfo.decodedBodySize += bytes?.byteLength ?? 0\n\n // 6. If bytes is failure, then terminate fetchParams’s controller.\n if (isFailure) {\n fetchParams.controller.terminate(bytes)\n return\n }\n\n // 7. Enqueue a Uint8Array wrapping an ArrayBuffer containing bytes\n // into stream.\n fetchParams.controller.controller.enqueue(new Uint8Array(bytes))\n\n // 8. If stream is errored, then terminate the ongoing fetch.\n if (isErrored(stream)) {\n fetchParams.controller.terminate()\n return\n }\n\n // 9. If stream doesn’t need more data ask the user agent to suspend\n // the ongoing fetch.\n if (!fetchParams.controller.controller.desiredSize) {\n return\n }\n }\n }\n\n // 2. If aborted, then:\n function onAborted (reason) {\n // 2. If fetchParams is aborted, then:\n if (isAborted(fetchParams)) {\n // 1. Set response’s aborted flag.\n response.aborted = true\n\n // 2. If stream is readable, then error stream with the result of\n // deserialize a serialized abort reason given fetchParams’s\n // controller’s serialized abort reason and an\n // implementation-defined realm.\n if (isReadable(stream)) {\n fetchParams.controller.controller.error(\n fetchParams.controller.serializedAbortReason\n )\n }\n } else {\n // 3. Otherwise, if stream is readable, error stream with a TypeError.\n if (isReadable(stream)) {\n fetchParams.controller.controller.error(new TypeError('terminated', {\n cause: isErrorLike(reason) ? reason : undefined\n }))\n }\n }\n\n // 4. If connection uses HTTP/2, then transmit an RST_STREAM frame.\n // 5. Otherwise, the user agent should close connection unless it would be bad for performance to do so.\n fetchParams.controller.connection.destroy()\n }\n\n // 20. Return response.\n return response\n\n async function dispatch ({ body }) {\n const url = requestCurrentURL(request)\n /** @type {import('../..').Agent} */\n const agent = fetchParams.controller.dispatcher\n\n return new Promise((resolve, reject) => agent.dispatch(\n {\n path: url.pathname + url.search,\n origin: url.origin,\n method: request.method,\n body: fetchParams.controller.dispatcher.isMockActive ? request.body && (request.body.source || request.body.stream) : body,\n headers: request.headersList.entries,\n maxRedirections: 0,\n upgrade: request.mode === 'websocket' ? 'websocket' : undefined\n },\n {\n body: null,\n abort: null,\n\n onConnect (abort) {\n // TODO (fix): Do we need connection here?\n const { connection } = fetchParams.controller\n\n if (connection.destroyed) {\n abort(new DOMException('The operation was aborted.', 'AbortError'))\n } else {\n fetchParams.controller.on('terminated', abort)\n this.abort = connection.abort = abort\n }\n },\n\n onHeaders (status, headersList, resume, statusText) {\n if (status < 200) {\n return\n }\n\n let codings = []\n let location = ''\n\n const headers = new Headers()\n\n // For H2, the headers are a plain JS object\n // We distinguish between them and iterate accordingly\n if (Array.isArray(headersList)) {\n for (let n = 0; n < headersList.length; n += 2) {\n const key = headersList[n + 0].toString('latin1')\n const val = headersList[n + 1].toString('latin1')\n if (key.toLowerCase() === 'content-encoding') {\n // https://www.rfc-editor.org/rfc/rfc7231#section-3.1.2.1\n // \"All content-coding values are case-insensitive...\"\n codings = val.toLowerCase().split(',').map((x) => x.trim())\n } else if (key.toLowerCase() === 'location') {\n location = val\n }\n\n headers[kHeadersList].append(key, val)\n }\n } else {\n const keys = Object.keys(headersList)\n for (const key of keys) {\n const val = headersList[key]\n if (key.toLowerCase() === 'content-encoding') {\n // https://www.rfc-editor.org/rfc/rfc7231#section-3.1.2.1\n // \"All content-coding values are case-insensitive...\"\n codings = val.toLowerCase().split(',').map((x) => x.trim()).reverse()\n } else if (key.toLowerCase() === 'location') {\n location = val\n }\n\n headers[kHeadersList].append(key, val)\n }\n }\n\n this.body = new Readable({ read: resume })\n\n const decoders = []\n\n const willFollow = request.redirect === 'follow' &&\n location &&\n redirectStatusSet.has(status)\n\n // https://developer.mozilla.org/en-US/docs/Web/HTTP/Headers/Content-Encoding\n if (request.method !== 'HEAD' && request.method !== 'CONNECT' && !nullBodyStatus.includes(status) && !willFollow) {\n for (const coding of codings) {\n // https://www.rfc-editor.org/rfc/rfc9112.html#section-7.2\n if (coding === 'x-gzip' || coding === 'gzip') {\n decoders.push(zlib.createGunzip({\n // Be less strict when decoding compressed responses, since sometimes\n // servers send slightly invalid responses that are still accepted\n // by common browsers.\n // Always using Z_SYNC_FLUSH is what cURL does.\n flush: zlib.constants.Z_SYNC_FLUSH,\n finishFlush: zlib.constants.Z_SYNC_FLUSH\n }))\n } else if (coding === 'deflate') {\n decoders.push(zlib.createInflate())\n } else if (coding === 'br') {\n decoders.push(zlib.createBrotliDecompress())\n } else {\n decoders.length = 0\n break\n }\n }\n }\n\n resolve({\n status,\n statusText,\n headersList: headers[kHeadersList],\n body: decoders.length\n ? pipeline(this.body, ...decoders, () => { })\n : this.body.on('error', () => {})\n })\n\n return true\n },\n\n onData (chunk) {\n if (fetchParams.controller.dump) {\n return\n }\n\n // 1. If one or more bytes have been transmitted from response’s\n // message body, then:\n\n // 1. Let bytes be the transmitted bytes.\n const bytes = chunk\n\n // 2. Let codings be the result of extracting header list values\n // given `Content-Encoding` and response’s header list.\n // See pullAlgorithm.\n\n // 3. Increase timingInfo’s encoded body size by bytes’s length.\n timingInfo.encodedBodySize += bytes.byteLength\n\n // 4. See pullAlgorithm...\n\n return this.body.push(bytes)\n },\n\n onComplete () {\n if (this.abort) {\n fetchParams.controller.off('terminated', this.abort)\n }\n\n fetchParams.controller.ended = true\n\n this.body.push(null)\n },\n\n onError (error) {\n if (this.abort) {\n fetchParams.controller.off('terminated', this.abort)\n }\n\n this.body?.destroy(error)\n\n fetchParams.controller.terminate(error)\n\n reject(error)\n },\n\n onUpgrade (status, headersList, socket) {\n if (status !== 101) {\n return\n }\n\n const headers = new Headers()\n\n for (let n = 0; n < headersList.length; n += 2) {\n const key = headersList[n + 0].toString('latin1')\n const val = headersList[n + 1].toString('latin1')\n\n headers[kHeadersList].append(key, val)\n }\n\n resolve({\n status,\n statusText: STATUS_CODES[status],\n headersList: headers[kHeadersList],\n socket\n })\n\n return true\n }\n }\n ))\n }\n}\n\nmodule.exports = {\n fetch,\n Fetch,\n fetching,\n finalizeAndReportTiming\n}\n","/* globals AbortController */\n\n'use strict'\n\nconst { extractBody, mixinBody, cloneBody } = require('./body')\nconst { Headers, fill: fillHeaders, HeadersList } = require('./headers')\nconst { FinalizationRegistry } = require('../compat/dispatcher-weakref')()\nconst util = require('../core/util')\nconst {\n isValidHTTPToken,\n sameOrigin,\n normalizeMethod,\n makePolicyContainer,\n normalizeMethodRecord\n} = require('./util')\nconst {\n forbiddenMethodsSet,\n corsSafeListedMethodsSet,\n referrerPolicy,\n requestRedirect,\n requestMode,\n requestCredentials,\n requestCache,\n requestDuplex\n} = require('./constants')\nconst { kEnumerableProperty } = util\nconst { kHeaders, kSignal, kState, kGuard, kRealm } = require('./symbols')\nconst { webidl } = require('./webidl')\nconst { getGlobalOrigin } = require('./global')\nconst { URLSerializer } = require('./dataURL')\nconst { kHeadersList, kConstruct } = require('../core/symbols')\nconst assert = require('assert')\nconst { getMaxListeners, setMaxListeners, getEventListeners, defaultMaxListeners } = require('events')\n\nlet TransformStream = globalThis.TransformStream\n\nconst kAbortController = Symbol('abortController')\n\nconst requestFinalizer = new FinalizationRegistry(({ signal, abort }) => {\n signal.removeEventListener('abort', abort)\n})\n\n// https://fetch.spec.whatwg.org/#request-class\nclass Request {\n // https://fetch.spec.whatwg.org/#dom-request\n constructor (input, init = {}) {\n if (input === kConstruct) {\n return\n }\n\n webidl.argumentLengthCheck(arguments, 1, { header: 'Request constructor' })\n\n input = webidl.converters.RequestInfo(input)\n init = webidl.converters.RequestInit(init)\n\n // https://html.spec.whatwg.org/multipage/webappapis.html#environment-settings-object\n this[kRealm] = {\n settingsObject: {\n baseUrl: getGlobalOrigin(),\n get origin () {\n return this.baseUrl?.origin\n },\n policyContainer: makePolicyContainer()\n }\n }\n\n // 1. Let request be null.\n let request = null\n\n // 2. Let fallbackMode be null.\n let fallbackMode = null\n\n // 3. Let baseURL be this’s relevant settings object’s API base URL.\n const baseUrl = this[kRealm].settingsObject.baseUrl\n\n // 4. Let signal be null.\n let signal = null\n\n // 5. If input is a string, then:\n if (typeof input === 'string') {\n // 1. Let parsedURL be the result of parsing input with baseURL.\n // 2. If parsedURL is failure, then throw a TypeError.\n let parsedURL\n try {\n parsedURL = new URL(input, baseUrl)\n } catch (err) {\n throw new TypeError('Failed to parse URL from ' + input, { cause: err })\n }\n\n // 3. If parsedURL includes credentials, then throw a TypeError.\n if (parsedURL.username || parsedURL.password) {\n throw new TypeError(\n 'Request cannot be constructed from a URL that includes credentials: ' +\n input\n )\n }\n\n // 4. Set request to a new request whose URL is parsedURL.\n request = makeRequest({ urlList: [parsedURL] })\n\n // 5. Set fallbackMode to \"cors\".\n fallbackMode = 'cors'\n } else {\n // 6. Otherwise:\n\n // 7. Assert: input is a Request object.\n assert(input instanceof Request)\n\n // 8. Set request to input’s request.\n request = input[kState]\n\n // 9. Set signal to input’s signal.\n signal = input[kSignal]\n }\n\n // 7. Let origin be this’s relevant settings object’s origin.\n const origin = this[kRealm].settingsObject.origin\n\n // 8. Let window be \"client\".\n let window = 'client'\n\n // 9. If request’s window is an environment settings object and its origin\n // is same origin with origin, then set window to request’s window.\n if (\n request.window?.constructor?.name === 'EnvironmentSettingsObject' &&\n sameOrigin(request.window, origin)\n ) {\n window = request.window\n }\n\n // 10. If init[\"window\"] exists and is non-null, then throw a TypeError.\n if (init.window != null) {\n throw new TypeError(`'window' option '${window}' must be null`)\n }\n\n // 11. If init[\"window\"] exists, then set window to \"no-window\".\n if ('window' in init) {\n window = 'no-window'\n }\n\n // 12. Set request to a new request with the following properties:\n request = makeRequest({\n // URL request’s URL.\n // undici implementation note: this is set as the first item in request's urlList in makeRequest\n // method request’s method.\n method: request.method,\n // header list A copy of request’s header list.\n // undici implementation note: headersList is cloned in makeRequest\n headersList: request.headersList,\n // unsafe-request flag Set.\n unsafeRequest: request.unsafeRequest,\n // client This’s relevant settings object.\n client: this[kRealm].settingsObject,\n // window window.\n window,\n // priority request’s priority.\n priority: request.priority,\n // origin request’s origin. The propagation of the origin is only significant for navigation requests\n // being handled by a service worker. In this scenario a request can have an origin that is different\n // from the current client.\n origin: request.origin,\n // referrer request’s referrer.\n referrer: request.referrer,\n // referrer policy request’s referrer policy.\n referrerPolicy: request.referrerPolicy,\n // mode request’s mode.\n mode: request.mode,\n // credentials mode request’s credentials mode.\n credentials: request.credentials,\n // cache mode request’s cache mode.\n cache: request.cache,\n // redirect mode request’s redirect mode.\n redirect: request.redirect,\n // integrity metadata request’s integrity metadata.\n integrity: request.integrity,\n // keepalive request’s keepalive.\n keepalive: request.keepalive,\n // reload-navigation flag request’s reload-navigation flag.\n reloadNavigation: request.reloadNavigation,\n // history-navigation flag request’s history-navigation flag.\n historyNavigation: request.historyNavigation,\n // URL list A clone of request’s URL list.\n urlList: [...request.urlList]\n })\n\n const initHasKey = Object.keys(init).length !== 0\n\n // 13. If init is not empty, then:\n if (initHasKey) {\n // 1. If request’s mode is \"navigate\", then set it to \"same-origin\".\n if (request.mode === 'navigate') {\n request.mode = 'same-origin'\n }\n\n // 2. Unset request’s reload-navigation flag.\n request.reloadNavigation = false\n\n // 3. Unset request’s history-navigation flag.\n request.historyNavigation = false\n\n // 4. Set request’s origin to \"client\".\n request.origin = 'client'\n\n // 5. Set request’s referrer to \"client\"\n request.referrer = 'client'\n\n // 6. Set request’s referrer policy to the empty string.\n request.referrerPolicy = ''\n\n // 7. Set request’s URL to request’s current URL.\n request.url = request.urlList[request.urlList.length - 1]\n\n // 8. Set request’s URL list to « request’s URL ».\n request.urlList = [request.url]\n }\n\n // 14. If init[\"referrer\"] exists, then:\n if (init.referrer !== undefined) {\n // 1. Let referrer be init[\"referrer\"].\n const referrer = init.referrer\n\n // 2. If referrer is the empty string, then set request’s referrer to \"no-referrer\".\n if (referrer === '') {\n request.referrer = 'no-referrer'\n } else {\n // 1. Let parsedReferrer be the result of parsing referrer with\n // baseURL.\n // 2. If parsedReferrer is failure, then throw a TypeError.\n let parsedReferrer\n try {\n parsedReferrer = new URL(referrer, baseUrl)\n } catch (err) {\n throw new TypeError(`Referrer \"${referrer}\" is not a valid URL.`, { cause: err })\n }\n\n // 3. If one of the following is true\n // - parsedReferrer’s scheme is \"about\" and path is the string \"client\"\n // - parsedReferrer’s origin is not same origin with origin\n // then set request’s referrer to \"client\".\n if (\n (parsedReferrer.protocol === 'about:' && parsedReferrer.hostname === 'client') ||\n (origin && !sameOrigin(parsedReferrer, this[kRealm].settingsObject.baseUrl))\n ) {\n request.referrer = 'client'\n } else {\n // 4. Otherwise, set request’s referrer to parsedReferrer.\n request.referrer = parsedReferrer\n }\n }\n }\n\n // 15. If init[\"referrerPolicy\"] exists, then set request’s referrer policy\n // to it.\n if (init.referrerPolicy !== undefined) {\n request.referrerPolicy = init.referrerPolicy\n }\n\n // 16. Let mode be init[\"mode\"] if it exists, and fallbackMode otherwise.\n let mode\n if (init.mode !== undefined) {\n mode = init.mode\n } else {\n mode = fallbackMode\n }\n\n // 17. If mode is \"navigate\", then throw a TypeError.\n if (mode === 'navigate') {\n throw webidl.errors.exception({\n header: 'Request constructor',\n message: 'invalid request mode navigate.'\n })\n }\n\n // 18. If mode is non-null, set request’s mode to mode.\n if (mode != null) {\n request.mode = mode\n }\n\n // 19. If init[\"credentials\"] exists, then set request’s credentials mode\n // to it.\n if (init.credentials !== undefined) {\n request.credentials = init.credentials\n }\n\n // 18. If init[\"cache\"] exists, then set request’s cache mode to it.\n if (init.cache !== undefined) {\n request.cache = init.cache\n }\n\n // 21. If request’s cache mode is \"only-if-cached\" and request’s mode is\n // not \"same-origin\", then throw a TypeError.\n if (request.cache === 'only-if-cached' && request.mode !== 'same-origin') {\n throw new TypeError(\n \"'only-if-cached' can be set only with 'same-origin' mode\"\n )\n }\n\n // 22. If init[\"redirect\"] exists, then set request’s redirect mode to it.\n if (init.redirect !== undefined) {\n request.redirect = init.redirect\n }\n\n // 23. If init[\"integrity\"] exists, then set request’s integrity metadata to it.\n if (init.integrity != null) {\n request.integrity = String(init.integrity)\n }\n\n // 24. If init[\"keepalive\"] exists, then set request’s keepalive to it.\n if (init.keepalive !== undefined) {\n request.keepalive = Boolean(init.keepalive)\n }\n\n // 25. If init[\"method\"] exists, then:\n if (init.method !== undefined) {\n // 1. Let method be init[\"method\"].\n let method = init.method\n\n // 2. If method is not a method or method is a forbidden method, then\n // throw a TypeError.\n if (!isValidHTTPToken(method)) {\n throw new TypeError(`'${method}' is not a valid HTTP method.`)\n }\n\n if (forbiddenMethodsSet.has(method.toUpperCase())) {\n throw new TypeError(`'${method}' HTTP method is unsupported.`)\n }\n\n // 3. Normalize method.\n method = normalizeMethodRecord[method] ?? normalizeMethod(method)\n\n // 4. Set request’s method to method.\n request.method = method\n }\n\n // 26. If init[\"signal\"] exists, then set signal to it.\n if (init.signal !== undefined) {\n signal = init.signal\n }\n\n // 27. Set this’s request to request.\n this[kState] = request\n\n // 28. Set this’s signal to a new AbortSignal object with this’s relevant\n // Realm.\n // TODO: could this be simplified with AbortSignal.any\n // (https://dom.spec.whatwg.org/#dom-abortsignal-any)\n const ac = new AbortController()\n this[kSignal] = ac.signal\n this[kSignal][kRealm] = this[kRealm]\n\n // 29. If signal is not null, then make this’s signal follow signal.\n if (signal != null) {\n if (\n !signal ||\n typeof signal.aborted !== 'boolean' ||\n typeof signal.addEventListener !== 'function'\n ) {\n throw new TypeError(\n \"Failed to construct 'Request': member signal is not of type AbortSignal.\"\n )\n }\n\n if (signal.aborted) {\n ac.abort(signal.reason)\n } else {\n // Keep a strong ref to ac while request object\n // is alive. This is needed to prevent AbortController\n // from being prematurely garbage collected.\n // See, https://github.com/nodejs/undici/issues/1926.\n this[kAbortController] = ac\n\n const acRef = new WeakRef(ac)\n const abort = function () {\n const ac = acRef.deref()\n if (ac !== undefined) {\n ac.abort(this.reason)\n }\n }\n\n // Third-party AbortControllers may not work with these.\n // See, https://github.com/nodejs/undici/pull/1910#issuecomment-1464495619.\n try {\n // If the max amount of listeners is equal to the default, increase it\n // This is only available in node >= v19.9.0\n if (typeof getMaxListeners === 'function' && getMaxListeners(signal) === defaultMaxListeners) {\n setMaxListeners(100, signal)\n } else if (getEventListeners(signal, 'abort').length >= defaultMaxListeners) {\n setMaxListeners(100, signal)\n }\n } catch {}\n\n util.addAbortListener(signal, abort)\n requestFinalizer.register(ac, { signal, abort })\n }\n }\n\n // 30. Set this’s headers to a new Headers object with this’s relevant\n // Realm, whose header list is request’s header list and guard is\n // \"request\".\n this[kHeaders] = new Headers(kConstruct)\n this[kHeaders][kHeadersList] = request.headersList\n this[kHeaders][kGuard] = 'request'\n this[kHeaders][kRealm] = this[kRealm]\n\n // 31. If this’s request’s mode is \"no-cors\", then:\n if (mode === 'no-cors') {\n // 1. If this’s request’s method is not a CORS-safelisted method,\n // then throw a TypeError.\n if (!corsSafeListedMethodsSet.has(request.method)) {\n throw new TypeError(\n `'${request.method} is unsupported in no-cors mode.`\n )\n }\n\n // 2. Set this’s headers’s guard to \"request-no-cors\".\n this[kHeaders][kGuard] = 'request-no-cors'\n }\n\n // 32. If init is not empty, then:\n if (initHasKey) {\n /** @type {HeadersList} */\n const headersList = this[kHeaders][kHeadersList]\n // 1. Let headers be a copy of this’s headers and its associated header\n // list.\n // 2. If init[\"headers\"] exists, then set headers to init[\"headers\"].\n const headers = init.headers !== undefined ? init.headers : new HeadersList(headersList)\n\n // 3. Empty this’s headers’s header list.\n headersList.clear()\n\n // 4. If headers is a Headers object, then for each header in its header\n // list, append header’s name/header’s value to this’s headers.\n if (headers instanceof HeadersList) {\n for (const [key, val] of headers) {\n headersList.append(key, val)\n }\n // Note: Copy the `set-cookie` meta-data.\n headersList.cookies = headers.cookies\n } else {\n // 5. Otherwise, fill this’s headers with headers.\n fillHeaders(this[kHeaders], headers)\n }\n }\n\n // 33. Let inputBody be input’s request’s body if input is a Request\n // object; otherwise null.\n const inputBody = input instanceof Request ? input[kState].body : null\n\n // 34. If either init[\"body\"] exists and is non-null or inputBody is\n // non-null, and request’s method is `GET` or `HEAD`, then throw a\n // TypeError.\n if (\n (init.body != null || inputBody != null) &&\n (request.method === 'GET' || request.method === 'HEAD')\n ) {\n throw new TypeError('Request with GET/HEAD method cannot have body.')\n }\n\n // 35. Let initBody be null.\n let initBody = null\n\n // 36. If init[\"body\"] exists and is non-null, then:\n if (init.body != null) {\n // 1. Let Content-Type be null.\n // 2. Set initBody and Content-Type to the result of extracting\n // init[\"body\"], with keepalive set to request’s keepalive.\n const [extractedBody, contentType] = extractBody(\n init.body,\n request.keepalive\n )\n initBody = extractedBody\n\n // 3, If Content-Type is non-null and this’s headers’s header list does\n // not contain `Content-Type`, then append `Content-Type`/Content-Type to\n // this’s headers.\n if (contentType && !this[kHeaders][kHeadersList].contains('content-type')) {\n this[kHeaders].append('content-type', contentType)\n }\n }\n\n // 37. Let inputOrInitBody be initBody if it is non-null; otherwise\n // inputBody.\n const inputOrInitBody = initBody ?? inputBody\n\n // 38. If inputOrInitBody is non-null and inputOrInitBody’s source is\n // null, then:\n if (inputOrInitBody != null && inputOrInitBody.source == null) {\n // 1. If initBody is non-null and init[\"duplex\"] does not exist,\n // then throw a TypeError.\n if (initBody != null && init.duplex == null) {\n throw new TypeError('RequestInit: duplex option is required when sending a body.')\n }\n\n // 2. If this’s request’s mode is neither \"same-origin\" nor \"cors\",\n // then throw a TypeError.\n if (request.mode !== 'same-origin' && request.mode !== 'cors') {\n throw new TypeError(\n 'If request is made from ReadableStream, mode should be \"same-origin\" or \"cors\"'\n )\n }\n\n // 3. Set this’s request’s use-CORS-preflight flag.\n request.useCORSPreflightFlag = true\n }\n\n // 39. Let finalBody be inputOrInitBody.\n let finalBody = inputOrInitBody\n\n // 40. If initBody is null and inputBody is non-null, then:\n if (initBody == null && inputBody != null) {\n // 1. If input is unusable, then throw a TypeError.\n if (util.isDisturbed(inputBody.stream) || inputBody.stream.locked) {\n throw new TypeError(\n 'Cannot construct a Request with a Request object that has already been used.'\n )\n }\n\n // 2. Set finalBody to the result of creating a proxy for inputBody.\n if (!TransformStream) {\n TransformStream = require('stream/web').TransformStream\n }\n\n // https://streams.spec.whatwg.org/#readablestream-create-a-proxy\n const identityTransform = new TransformStream()\n inputBody.stream.pipeThrough(identityTransform)\n finalBody = {\n source: inputBody.source,\n length: inputBody.length,\n stream: identityTransform.readable\n }\n }\n\n // 41. Set this’s request’s body to finalBody.\n this[kState].body = finalBody\n }\n\n // Returns request’s HTTP method, which is \"GET\" by default.\n get method () {\n webidl.brandCheck(this, Request)\n\n // The method getter steps are to return this’s request’s method.\n return this[kState].method\n }\n\n // Returns the URL of request as a string.\n get url () {\n webidl.brandCheck(this, Request)\n\n // The url getter steps are to return this’s request’s URL, serialized.\n return URLSerializer(this[kState].url)\n }\n\n // Returns a Headers object consisting of the headers associated with request.\n // Note that headers added in the network layer by the user agent will not\n // be accounted for in this object, e.g., the \"Host\" header.\n get headers () {\n webidl.brandCheck(this, Request)\n\n // The headers getter steps are to return this’s headers.\n return this[kHeaders]\n }\n\n // Returns the kind of resource requested by request, e.g., \"document\"\n // or \"script\".\n get destination () {\n webidl.brandCheck(this, Request)\n\n // The destination getter are to return this’s request’s destination.\n return this[kState].destination\n }\n\n // Returns the referrer of request. Its value can be a same-origin URL if\n // explicitly set in init, the empty string to indicate no referrer, and\n // \"about:client\" when defaulting to the global’s default. This is used\n // during fetching to determine the value of the `Referer` header of the\n // request being made.\n get referrer () {\n webidl.brandCheck(this, Request)\n\n // 1. If this’s request’s referrer is \"no-referrer\", then return the\n // empty string.\n if (this[kState].referrer === 'no-referrer') {\n return ''\n }\n\n // 2. If this’s request’s referrer is \"client\", then return\n // \"about:client\".\n if (this[kState].referrer === 'client') {\n return 'about:client'\n }\n\n // Return this’s request’s referrer, serialized.\n return this[kState].referrer.toString()\n }\n\n // Returns the referrer policy associated with request.\n // This is used during fetching to compute the value of the request’s\n // referrer.\n get referrerPolicy () {\n webidl.brandCheck(this, Request)\n\n // The referrerPolicy getter steps are to return this’s request’s referrer policy.\n return this[kState].referrerPolicy\n }\n\n // Returns the mode associated with request, which is a string indicating\n // whether the request will use CORS, or will be restricted to same-origin\n // URLs.\n get mode () {\n webidl.brandCheck(this, Request)\n\n // The mode getter steps are to return this’s request’s mode.\n return this[kState].mode\n }\n\n // Returns the credentials mode associated with request,\n // which is a string indicating whether credentials will be sent with the\n // request always, never, or only when sent to a same-origin URL.\n get credentials () {\n // The credentials getter steps are to return this’s request’s credentials mode.\n return this[kState].credentials\n }\n\n // Returns the cache mode associated with request,\n // which is a string indicating how the request will\n // interact with the browser’s cache when fetching.\n get cache () {\n webidl.brandCheck(this, Request)\n\n // The cache getter steps are to return this’s request’s cache mode.\n return this[kState].cache\n }\n\n // Returns the redirect mode associated with request,\n // which is a string indicating how redirects for the\n // request will be handled during fetching. A request\n // will follow redirects by default.\n get redirect () {\n webidl.brandCheck(this, Request)\n\n // The redirect getter steps are to return this’s request’s redirect mode.\n return this[kState].redirect\n }\n\n // Returns request’s subresource integrity metadata, which is a\n // cryptographic hash of the resource being fetched. Its value\n // consists of multiple hashes separated by whitespace. [SRI]\n get integrity () {\n webidl.brandCheck(this, Request)\n\n // The integrity getter steps are to return this’s request’s integrity\n // metadata.\n return this[kState].integrity\n }\n\n // Returns a boolean indicating whether or not request can outlive the\n // global in which it was created.\n get keepalive () {\n webidl.brandCheck(this, Request)\n\n // The keepalive getter steps are to return this’s request’s keepalive.\n return this[kState].keepalive\n }\n\n // Returns a boolean indicating whether or not request is for a reload\n // navigation.\n get isReloadNavigation () {\n webidl.brandCheck(this, Request)\n\n // The isReloadNavigation getter steps are to return true if this’s\n // request’s reload-navigation flag is set; otherwise false.\n return this[kState].reloadNavigation\n }\n\n // Returns a boolean indicating whether or not request is for a history\n // navigation (a.k.a. back-foward navigation).\n get isHistoryNavigation () {\n webidl.brandCheck(this, Request)\n\n // The isHistoryNavigation getter steps are to return true if this’s request’s\n // history-navigation flag is set; otherwise false.\n return this[kState].historyNavigation\n }\n\n // Returns the signal associated with request, which is an AbortSignal\n // object indicating whether or not request has been aborted, and its\n // abort event handler.\n get signal () {\n webidl.brandCheck(this, Request)\n\n // The signal getter steps are to return this’s signal.\n return this[kSignal]\n }\n\n get body () {\n webidl.brandCheck(this, Request)\n\n return this[kState].body ? this[kState].body.stream : null\n }\n\n get bodyUsed () {\n webidl.brandCheck(this, Request)\n\n return !!this[kState].body && util.isDisturbed(this[kState].body.stream)\n }\n\n get duplex () {\n webidl.brandCheck(this, Request)\n\n return 'half'\n }\n\n // Returns a clone of request.\n clone () {\n webidl.brandCheck(this, Request)\n\n // 1. If this is unusable, then throw a TypeError.\n if (this.bodyUsed || this.body?.locked) {\n throw new TypeError('unusable')\n }\n\n // 2. Let clonedRequest be the result of cloning this’s request.\n const clonedRequest = cloneRequest(this[kState])\n\n // 3. Let clonedRequestObject be the result of creating a Request object,\n // given clonedRequest, this’s headers’s guard, and this’s relevant Realm.\n const clonedRequestObject = new Request(kConstruct)\n clonedRequestObject[kState] = clonedRequest\n clonedRequestObject[kRealm] = this[kRealm]\n clonedRequestObject[kHeaders] = new Headers(kConstruct)\n clonedRequestObject[kHeaders][kHeadersList] = clonedRequest.headersList\n clonedRequestObject[kHeaders][kGuard] = this[kHeaders][kGuard]\n clonedRequestObject[kHeaders][kRealm] = this[kHeaders][kRealm]\n\n // 4. Make clonedRequestObject’s signal follow this’s signal.\n const ac = new AbortController()\n if (this.signal.aborted) {\n ac.abort(this.signal.reason)\n } else {\n util.addAbortListener(\n this.signal,\n () => {\n ac.abort(this.signal.reason)\n }\n )\n }\n clonedRequestObject[kSignal] = ac.signal\n\n // 4. Return clonedRequestObject.\n return clonedRequestObject\n }\n}\n\nmixinBody(Request)\n\nfunction makeRequest (init) {\n // https://fetch.spec.whatwg.org/#requests\n const request = {\n method: 'GET',\n localURLsOnly: false,\n unsafeRequest: false,\n body: null,\n client: null,\n reservedClient: null,\n replacesClientId: '',\n window: 'client',\n keepalive: false,\n serviceWorkers: 'all',\n initiator: '',\n destination: '',\n priority: null,\n origin: 'client',\n policyContainer: 'client',\n referrer: 'client',\n referrerPolicy: '',\n mode: 'no-cors',\n useCORSPreflightFlag: false,\n credentials: 'same-origin',\n useCredentials: false,\n cache: 'default',\n redirect: 'follow',\n integrity: '',\n cryptoGraphicsNonceMetadata: '',\n parserMetadata: '',\n reloadNavigation: false,\n historyNavigation: false,\n userActivation: false,\n taintedOrigin: false,\n redirectCount: 0,\n responseTainting: 'basic',\n preventNoCacheCacheControlHeaderModification: false,\n done: false,\n timingAllowFailed: false,\n ...init,\n headersList: init.headersList\n ? new HeadersList(init.headersList)\n : new HeadersList()\n }\n request.url = request.urlList[0]\n return request\n}\n\n// https://fetch.spec.whatwg.org/#concept-request-clone\nfunction cloneRequest (request) {\n // To clone a request request, run these steps:\n\n // 1. Let newRequest be a copy of request, except for its body.\n const newRequest = makeRequest({ ...request, body: null })\n\n // 2. If request’s body is non-null, set newRequest’s body to the\n // result of cloning request’s body.\n if (request.body != null) {\n newRequest.body = cloneBody(request.body)\n }\n\n // 3. Return newRequest.\n return newRequest\n}\n\nObject.defineProperties(Request.prototype, {\n method: kEnumerableProperty,\n url: kEnumerableProperty,\n headers: kEnumerableProperty,\n redirect: kEnumerableProperty,\n clone: kEnumerableProperty,\n signal: kEnumerableProperty,\n duplex: kEnumerableProperty,\n destination: kEnumerableProperty,\n body: kEnumerableProperty,\n bodyUsed: kEnumerableProperty,\n isHistoryNavigation: kEnumerableProperty,\n isReloadNavigation: kEnumerableProperty,\n keepalive: kEnumerableProperty,\n integrity: kEnumerableProperty,\n cache: kEnumerableProperty,\n credentials: kEnumerableProperty,\n attribute: kEnumerableProperty,\n referrerPolicy: kEnumerableProperty,\n referrer: kEnumerableProperty,\n mode: kEnumerableProperty,\n [Symbol.toStringTag]: {\n value: 'Request',\n configurable: true\n }\n})\n\nwebidl.converters.Request = webidl.interfaceConverter(\n Request\n)\n\n// https://fetch.spec.whatwg.org/#requestinfo\nwebidl.converters.RequestInfo = function (V) {\n if (typeof V === 'string') {\n return webidl.converters.USVString(V)\n }\n\n if (V instanceof Request) {\n return webidl.converters.Request(V)\n }\n\n return webidl.converters.USVString(V)\n}\n\nwebidl.converters.AbortSignal = webidl.interfaceConverter(\n AbortSignal\n)\n\n// https://fetch.spec.whatwg.org/#requestinit\nwebidl.converters.RequestInit = webidl.dictionaryConverter([\n {\n key: 'method',\n converter: webidl.converters.ByteString\n },\n {\n key: 'headers',\n converter: webidl.converters.HeadersInit\n },\n {\n key: 'body',\n converter: webidl.nullableConverter(\n webidl.converters.BodyInit\n )\n },\n {\n key: 'referrer',\n converter: webidl.converters.USVString\n },\n {\n key: 'referrerPolicy',\n converter: webidl.converters.DOMString,\n // https://w3c.github.io/webappsec-referrer-policy/#referrer-policy\n allowedValues: referrerPolicy\n },\n {\n key: 'mode',\n converter: webidl.converters.DOMString,\n // https://fetch.spec.whatwg.org/#concept-request-mode\n allowedValues: requestMode\n },\n {\n key: 'credentials',\n converter: webidl.converters.DOMString,\n // https://fetch.spec.whatwg.org/#requestcredentials\n allowedValues: requestCredentials\n },\n {\n key: 'cache',\n converter: webidl.converters.DOMString,\n // https://fetch.spec.whatwg.org/#requestcache\n allowedValues: requestCache\n },\n {\n key: 'redirect',\n converter: webidl.converters.DOMString,\n // https://fetch.spec.whatwg.org/#requestredirect\n allowedValues: requestRedirect\n },\n {\n key: 'integrity',\n converter: webidl.converters.DOMString\n },\n {\n key: 'keepalive',\n converter: webidl.converters.boolean\n },\n {\n key: 'signal',\n converter: webidl.nullableConverter(\n (signal) => webidl.converters.AbortSignal(\n signal,\n { strict: false }\n )\n )\n },\n {\n key: 'window',\n converter: webidl.converters.any\n },\n {\n key: 'duplex',\n converter: webidl.converters.DOMString,\n allowedValues: requestDuplex\n }\n])\n\nmodule.exports = { Request, makeRequest }\n","'use strict'\n\nconst { Headers, HeadersList, fill } = require('./headers')\nconst { extractBody, cloneBody, mixinBody } = require('./body')\nconst util = require('../core/util')\nconst { kEnumerableProperty } = util\nconst {\n isValidReasonPhrase,\n isCancelled,\n isAborted,\n isBlobLike,\n serializeJavascriptValueToJSONString,\n isErrorLike,\n isomorphicEncode\n} = require('./util')\nconst {\n redirectStatusSet,\n nullBodyStatus,\n DOMException\n} = require('./constants')\nconst { kState, kHeaders, kGuard, kRealm } = require('./symbols')\nconst { webidl } = require('./webidl')\nconst { FormData } = require('./formdata')\nconst { getGlobalOrigin } = require('./global')\nconst { URLSerializer } = require('./dataURL')\nconst { kHeadersList, kConstruct } = require('../core/symbols')\nconst assert = require('assert')\nconst { types } = require('util')\n\nconst ReadableStream = globalThis.ReadableStream || require('stream/web').ReadableStream\nconst textEncoder = new TextEncoder('utf-8')\n\n// https://fetch.spec.whatwg.org/#response-class\nclass Response {\n // Creates network error Response.\n static error () {\n // TODO\n const relevantRealm = { settingsObject: {} }\n\n // The static error() method steps are to return the result of creating a\n // Response object, given a new network error, \"immutable\", and this’s\n // relevant Realm.\n const responseObject = new Response()\n responseObject[kState] = makeNetworkError()\n responseObject[kRealm] = relevantRealm\n responseObject[kHeaders][kHeadersList] = responseObject[kState].headersList\n responseObject[kHeaders][kGuard] = 'immutable'\n responseObject[kHeaders][kRealm] = relevantRealm\n return responseObject\n }\n\n // https://fetch.spec.whatwg.org/#dom-response-json\n static json (data, init = {}) {\n webidl.argumentLengthCheck(arguments, 1, { header: 'Response.json' })\n\n if (init !== null) {\n init = webidl.converters.ResponseInit(init)\n }\n\n // 1. Let bytes the result of running serialize a JavaScript value to JSON bytes on data.\n const bytes = textEncoder.encode(\n serializeJavascriptValueToJSONString(data)\n )\n\n // 2. Let body be the result of extracting bytes.\n const body = extractBody(bytes)\n\n // 3. Let responseObject be the result of creating a Response object, given a new response,\n // \"response\", and this’s relevant Realm.\n const relevantRealm = { settingsObject: {} }\n const responseObject = new Response()\n responseObject[kRealm] = relevantRealm\n responseObject[kHeaders][kGuard] = 'response'\n responseObject[kHeaders][kRealm] = relevantRealm\n\n // 4. Perform initialize a response given responseObject, init, and (body, \"application/json\").\n initializeResponse(responseObject, init, { body: body[0], type: 'application/json' })\n\n // 5. Return responseObject.\n return responseObject\n }\n\n // Creates a redirect Response that redirects to url with status status.\n static redirect (url, status = 302) {\n const relevantRealm = { settingsObject: {} }\n\n webidl.argumentLengthCheck(arguments, 1, { header: 'Response.redirect' })\n\n url = webidl.converters.USVString(url)\n status = webidl.converters['unsigned short'](status)\n\n // 1. Let parsedURL be the result of parsing url with current settings\n // object’s API base URL.\n // 2. If parsedURL is failure, then throw a TypeError.\n // TODO: base-URL?\n let parsedURL\n try {\n parsedURL = new URL(url, getGlobalOrigin())\n } catch (err) {\n throw Object.assign(new TypeError('Failed to parse URL from ' + url), {\n cause: err\n })\n }\n\n // 3. If status is not a redirect status, then throw a RangeError.\n if (!redirectStatusSet.has(status)) {\n throw new RangeError('Invalid status code ' + status)\n }\n\n // 4. Let responseObject be the result of creating a Response object,\n // given a new response, \"immutable\", and this’s relevant Realm.\n const responseObject = new Response()\n responseObject[kRealm] = relevantRealm\n responseObject[kHeaders][kGuard] = 'immutable'\n responseObject[kHeaders][kRealm] = relevantRealm\n\n // 5. Set responseObject’s response’s status to status.\n responseObject[kState].status = status\n\n // 6. Let value be parsedURL, serialized and isomorphic encoded.\n const value = isomorphicEncode(URLSerializer(parsedURL))\n\n // 7. Append `Location`/value to responseObject’s response’s header list.\n responseObject[kState].headersList.append('location', value)\n\n // 8. Return responseObject.\n return responseObject\n }\n\n // https://fetch.spec.whatwg.org/#dom-response\n constructor (body = null, init = {}) {\n if (body !== null) {\n body = webidl.converters.BodyInit(body)\n }\n\n init = webidl.converters.ResponseInit(init)\n\n // TODO\n this[kRealm] = { settingsObject: {} }\n\n // 1. Set this’s response to a new response.\n this[kState] = makeResponse({})\n\n // 2. Set this’s headers to a new Headers object with this’s relevant\n // Realm, whose header list is this’s response’s header list and guard\n // is \"response\".\n this[kHeaders] = new Headers(kConstruct)\n this[kHeaders][kGuard] = 'response'\n this[kHeaders][kHeadersList] = this[kState].headersList\n this[kHeaders][kRealm] = this[kRealm]\n\n // 3. Let bodyWithType be null.\n let bodyWithType = null\n\n // 4. If body is non-null, then set bodyWithType to the result of extracting body.\n if (body != null) {\n const [extractedBody, type] = extractBody(body)\n bodyWithType = { body: extractedBody, type }\n }\n\n // 5. Perform initialize a response given this, init, and bodyWithType.\n initializeResponse(this, init, bodyWithType)\n }\n\n // Returns response’s type, e.g., \"cors\".\n get type () {\n webidl.brandCheck(this, Response)\n\n // The type getter steps are to return this’s response’s type.\n return this[kState].type\n }\n\n // Returns response’s URL, if it has one; otherwise the empty string.\n get url () {\n webidl.brandCheck(this, Response)\n\n const urlList = this[kState].urlList\n\n // The url getter steps are to return the empty string if this’s\n // response’s URL is null; otherwise this’s response’s URL,\n // serialized with exclude fragment set to true.\n const url = urlList[urlList.length - 1] ?? null\n\n if (url === null) {\n return ''\n }\n\n return URLSerializer(url, true)\n }\n\n // Returns whether response was obtained through a redirect.\n get redirected () {\n webidl.brandCheck(this, Response)\n\n // The redirected getter steps are to return true if this’s response’s URL\n // list has more than one item; otherwise false.\n return this[kState].urlList.length > 1\n }\n\n // Returns response’s status.\n get status () {\n webidl.brandCheck(this, Response)\n\n // The status getter steps are to return this’s response’s status.\n return this[kState].status\n }\n\n // Returns whether response’s status is an ok status.\n get ok () {\n webidl.brandCheck(this, Response)\n\n // The ok getter steps are to return true if this’s response’s status is an\n // ok status; otherwise false.\n return this[kState].status >= 200 && this[kState].status <= 299\n }\n\n // Returns response’s status message.\n get statusText () {\n webidl.brandCheck(this, Response)\n\n // The statusText getter steps are to return this’s response’s status\n // message.\n return this[kState].statusText\n }\n\n // Returns response’s headers as Headers.\n get headers () {\n webidl.brandCheck(this, Response)\n\n // The headers getter steps are to return this’s headers.\n return this[kHeaders]\n }\n\n get body () {\n webidl.brandCheck(this, Response)\n\n return this[kState].body ? this[kState].body.stream : null\n }\n\n get bodyUsed () {\n webidl.brandCheck(this, Response)\n\n return !!this[kState].body && util.isDisturbed(this[kState].body.stream)\n }\n\n // Returns a clone of response.\n clone () {\n webidl.brandCheck(this, Response)\n\n // 1. If this is unusable, then throw a TypeError.\n if (this.bodyUsed || (this.body && this.body.locked)) {\n throw webidl.errors.exception({\n header: 'Response.clone',\n message: 'Body has already been consumed.'\n })\n }\n\n // 2. Let clonedResponse be the result of cloning this’s response.\n const clonedResponse = cloneResponse(this[kState])\n\n // 3. Return the result of creating a Response object, given\n // clonedResponse, this’s headers’s guard, and this’s relevant Realm.\n const clonedResponseObject = new Response()\n clonedResponseObject[kState] = clonedResponse\n clonedResponseObject[kRealm] = this[kRealm]\n clonedResponseObject[kHeaders][kHeadersList] = clonedResponse.headersList\n clonedResponseObject[kHeaders][kGuard] = this[kHeaders][kGuard]\n clonedResponseObject[kHeaders][kRealm] = this[kHeaders][kRealm]\n\n return clonedResponseObject\n }\n}\n\nmixinBody(Response)\n\nObject.defineProperties(Response.prototype, {\n type: kEnumerableProperty,\n url: kEnumerableProperty,\n status: kEnumerableProperty,\n ok: kEnumerableProperty,\n redirected: kEnumerableProperty,\n statusText: kEnumerableProperty,\n headers: kEnumerableProperty,\n clone: kEnumerableProperty,\n body: kEnumerableProperty,\n bodyUsed: kEnumerableProperty,\n [Symbol.toStringTag]: {\n value: 'Response',\n configurable: true\n }\n})\n\nObject.defineProperties(Response, {\n json: kEnumerableProperty,\n redirect: kEnumerableProperty,\n error: kEnumerableProperty\n})\n\n// https://fetch.spec.whatwg.org/#concept-response-clone\nfunction cloneResponse (response) {\n // To clone a response response, run these steps:\n\n // 1. If response is a filtered response, then return a new identical\n // filtered response whose internal response is a clone of response’s\n // internal response.\n if (response.internalResponse) {\n return filterResponse(\n cloneResponse(response.internalResponse),\n response.type\n )\n }\n\n // 2. Let newResponse be a copy of response, except for its body.\n const newResponse = makeResponse({ ...response, body: null })\n\n // 3. If response’s body is non-null, then set newResponse’s body to the\n // result of cloning response’s body.\n if (response.body != null) {\n newResponse.body = cloneBody(response.body)\n }\n\n // 4. Return newResponse.\n return newResponse\n}\n\nfunction makeResponse (init) {\n return {\n aborted: false,\n rangeRequested: false,\n timingAllowPassed: false,\n requestIncludesCredentials: false,\n type: 'default',\n status: 200,\n timingInfo: null,\n cacheState: '',\n statusText: '',\n ...init,\n headersList: init.headersList\n ? new HeadersList(init.headersList)\n : new HeadersList(),\n urlList: init.urlList ? [...init.urlList] : []\n }\n}\n\nfunction makeNetworkError (reason) {\n const isError = isErrorLike(reason)\n return makeResponse({\n type: 'error',\n status: 0,\n error: isError\n ? reason\n : new Error(reason ? String(reason) : reason),\n aborted: reason && reason.name === 'AbortError'\n })\n}\n\nfunction makeFilteredResponse (response, state) {\n state = {\n internalResponse: response,\n ...state\n }\n\n return new Proxy(response, {\n get (target, p) {\n return p in state ? state[p] : target[p]\n },\n set (target, p, value) {\n assert(!(p in state))\n target[p] = value\n return true\n }\n })\n}\n\n// https://fetch.spec.whatwg.org/#concept-filtered-response\nfunction filterResponse (response, type) {\n // Set response to the following filtered response with response as its\n // internal response, depending on request’s response tainting:\n if (type === 'basic') {\n // A basic filtered response is a filtered response whose type is \"basic\"\n // and header list excludes any headers in internal response’s header list\n // whose name is a forbidden response-header name.\n\n // Note: undici does not implement forbidden response-header names\n return makeFilteredResponse(response, {\n type: 'basic',\n headersList: response.headersList\n })\n } else if (type === 'cors') {\n // A CORS filtered response is a filtered response whose type is \"cors\"\n // and header list excludes any headers in internal response’s header\n // list whose name is not a CORS-safelisted response-header name, given\n // internal response’s CORS-exposed header-name list.\n\n // Note: undici does not implement CORS-safelisted response-header names\n return makeFilteredResponse(response, {\n type: 'cors',\n headersList: response.headersList\n })\n } else if (type === 'opaque') {\n // An opaque filtered response is a filtered response whose type is\n // \"opaque\", URL list is the empty list, status is 0, status message\n // is the empty byte sequence, header list is empty, and body is null.\n\n return makeFilteredResponse(response, {\n type: 'opaque',\n urlList: Object.freeze([]),\n status: 0,\n statusText: '',\n body: null\n })\n } else if (type === 'opaqueredirect') {\n // An opaque-redirect filtered response is a filtered response whose type\n // is \"opaqueredirect\", status is 0, status message is the empty byte\n // sequence, header list is empty, and body is null.\n\n return makeFilteredResponse(response, {\n type: 'opaqueredirect',\n status: 0,\n statusText: '',\n headersList: [],\n body: null\n })\n } else {\n assert(false)\n }\n}\n\n// https://fetch.spec.whatwg.org/#appropriate-network-error\nfunction makeAppropriateNetworkError (fetchParams, err = null) {\n // 1. Assert: fetchParams is canceled.\n assert(isCancelled(fetchParams))\n\n // 2. Return an aborted network error if fetchParams is aborted;\n // otherwise return a network error.\n return isAborted(fetchParams)\n ? makeNetworkError(Object.assign(new DOMException('The operation was aborted.', 'AbortError'), { cause: err }))\n : makeNetworkError(Object.assign(new DOMException('Request was cancelled.'), { cause: err }))\n}\n\n// https://whatpr.org/fetch/1392.html#initialize-a-response\nfunction initializeResponse (response, init, body) {\n // 1. If init[\"status\"] is not in the range 200 to 599, inclusive, then\n // throw a RangeError.\n if (init.status !== null && (init.status < 200 || init.status > 599)) {\n throw new RangeError('init[\"status\"] must be in the range of 200 to 599, inclusive.')\n }\n\n // 2. If init[\"statusText\"] does not match the reason-phrase token production,\n // then throw a TypeError.\n if ('statusText' in init && init.statusText != null) {\n // See, https://datatracker.ietf.org/doc/html/rfc7230#section-3.1.2:\n // reason-phrase = *( HTAB / SP / VCHAR / obs-text )\n if (!isValidReasonPhrase(String(init.statusText))) {\n throw new TypeError('Invalid statusText')\n }\n }\n\n // 3. Set response’s response’s status to init[\"status\"].\n if ('status' in init && init.status != null) {\n response[kState].status = init.status\n }\n\n // 4. Set response’s response’s status message to init[\"statusText\"].\n if ('statusText' in init && init.statusText != null) {\n response[kState].statusText = init.statusText\n }\n\n // 5. If init[\"headers\"] exists, then fill response’s headers with init[\"headers\"].\n if ('headers' in init && init.headers != null) {\n fill(response[kHeaders], init.headers)\n }\n\n // 6. If body was given, then:\n if (body) {\n // 1. If response's status is a null body status, then throw a TypeError.\n if (nullBodyStatus.includes(response.status)) {\n throw webidl.errors.exception({\n header: 'Response constructor',\n message: 'Invalid response status code ' + response.status\n })\n }\n\n // 2. Set response's body to body's body.\n response[kState].body = body.body\n\n // 3. If body's type is non-null and response's header list does not contain\n // `Content-Type`, then append (`Content-Type`, body's type) to response's header list.\n if (body.type != null && !response[kState].headersList.contains('Content-Type')) {\n response[kState].headersList.append('content-type', body.type)\n }\n }\n}\n\nwebidl.converters.ReadableStream = webidl.interfaceConverter(\n ReadableStream\n)\n\nwebidl.converters.FormData = webidl.interfaceConverter(\n FormData\n)\n\nwebidl.converters.URLSearchParams = webidl.interfaceConverter(\n URLSearchParams\n)\n\n// https://fetch.spec.whatwg.org/#typedefdef-xmlhttprequestbodyinit\nwebidl.converters.XMLHttpRequestBodyInit = function (V) {\n if (typeof V === 'string') {\n return webidl.converters.USVString(V)\n }\n\n if (isBlobLike(V)) {\n return webidl.converters.Blob(V, { strict: false })\n }\n\n if (types.isArrayBuffer(V) || types.isTypedArray(V) || types.isDataView(V)) {\n return webidl.converters.BufferSource(V)\n }\n\n if (util.isFormDataLike(V)) {\n return webidl.converters.FormData(V, { strict: false })\n }\n\n if (V instanceof URLSearchParams) {\n return webidl.converters.URLSearchParams(V)\n }\n\n return webidl.converters.DOMString(V)\n}\n\n// https://fetch.spec.whatwg.org/#bodyinit\nwebidl.converters.BodyInit = function (V) {\n if (V instanceof ReadableStream) {\n return webidl.converters.ReadableStream(V)\n }\n\n // Note: the spec doesn't include async iterables,\n // this is an undici extension.\n if (V?.[Symbol.asyncIterator]) {\n return V\n }\n\n return webidl.converters.XMLHttpRequestBodyInit(V)\n}\n\nwebidl.converters.ResponseInit = webidl.dictionaryConverter([\n {\n key: 'status',\n converter: webidl.converters['unsigned short'],\n defaultValue: 200\n },\n {\n key: 'statusText',\n converter: webidl.converters.ByteString,\n defaultValue: ''\n },\n {\n key: 'headers',\n converter: webidl.converters.HeadersInit\n }\n])\n\nmodule.exports = {\n makeNetworkError,\n makeResponse,\n makeAppropriateNetworkError,\n filterResponse,\n Response,\n cloneResponse\n}\n","'use strict'\n\nmodule.exports = {\n kUrl: Symbol('url'),\n kHeaders: Symbol('headers'),\n kSignal: Symbol('signal'),\n kState: Symbol('state'),\n kGuard: Symbol('guard'),\n kRealm: Symbol('realm')\n}\n","'use strict'\n\nconst { redirectStatusSet, referrerPolicySet: referrerPolicyTokens, badPortsSet } = require('./constants')\nconst { getGlobalOrigin } = require('./global')\nconst { performance } = require('perf_hooks')\nconst { isBlobLike, toUSVString, ReadableStreamFrom } = require('../core/util')\nconst assert = require('assert')\nconst { isUint8Array } = require('util/types')\n\n// https://nodejs.org/api/crypto.html#determining-if-crypto-support-is-unavailable\n/** @type {import('crypto')|undefined} */\nlet crypto\n\ntry {\n crypto = require('crypto')\n} catch {\n\n}\n\nfunction responseURL (response) {\n // https://fetch.spec.whatwg.org/#responses\n // A response has an associated URL. It is a pointer to the last URL\n // in response’s URL list and null if response’s URL list is empty.\n const urlList = response.urlList\n const length = urlList.length\n return length === 0 ? null : urlList[length - 1].toString()\n}\n\n// https://fetch.spec.whatwg.org/#concept-response-location-url\nfunction responseLocationURL (response, requestFragment) {\n // 1. If response’s status is not a redirect status, then return null.\n if (!redirectStatusSet.has(response.status)) {\n return null\n }\n\n // 2. Let location be the result of extracting header list values given\n // `Location` and response’s header list.\n let location = response.headersList.get('location')\n\n // 3. If location is a header value, then set location to the result of\n // parsing location with response’s URL.\n if (location !== null && isValidHeaderValue(location)) {\n location = new URL(location, responseURL(response))\n }\n\n // 4. If location is a URL whose fragment is null, then set location’s\n // fragment to requestFragment.\n if (location && !location.hash) {\n location.hash = requestFragment\n }\n\n // 5. Return location.\n return location\n}\n\n/** @returns {URL} */\nfunction requestCurrentURL (request) {\n return request.urlList[request.urlList.length - 1]\n}\n\nfunction requestBadPort (request) {\n // 1. Let url be request’s current URL.\n const url = requestCurrentURL(request)\n\n // 2. If url’s scheme is an HTTP(S) scheme and url’s port is a bad port,\n // then return blocked.\n if (urlIsHttpHttpsScheme(url) && badPortsSet.has(url.port)) {\n return 'blocked'\n }\n\n // 3. Return allowed.\n return 'allowed'\n}\n\nfunction isErrorLike (object) {\n return object instanceof Error || (\n object?.constructor?.name === 'Error' ||\n object?.constructor?.name === 'DOMException'\n )\n}\n\n// Check whether |statusText| is a ByteString and\n// matches the Reason-Phrase token production.\n// RFC 2616: https://tools.ietf.org/html/rfc2616\n// RFC 7230: https://tools.ietf.org/html/rfc7230\n// \"reason-phrase = *( HTAB / SP / VCHAR / obs-text )\"\n// https://github.com/chromium/chromium/blob/94.0.4604.1/third_party/blink/renderer/core/fetch/response.cc#L116\nfunction isValidReasonPhrase (statusText) {\n for (let i = 0; i < statusText.length; ++i) {\n const c = statusText.charCodeAt(i)\n if (\n !(\n (\n c === 0x09 || // HTAB\n (c >= 0x20 && c <= 0x7e) || // SP / VCHAR\n (c >= 0x80 && c <= 0xff)\n ) // obs-text\n )\n ) {\n return false\n }\n }\n return true\n}\n\n/**\n * @see https://tools.ietf.org/html/rfc7230#section-3.2.6\n * @param {number} c\n */\nfunction isTokenCharCode (c) {\n switch (c) {\n case 0x22:\n case 0x28:\n case 0x29:\n case 0x2c:\n case 0x2f:\n case 0x3a:\n case 0x3b:\n case 0x3c:\n case 0x3d:\n case 0x3e:\n case 0x3f:\n case 0x40:\n case 0x5b:\n case 0x5c:\n case 0x5d:\n case 0x7b:\n case 0x7d:\n // DQUOTE and \"(),/:;<=>?@[\\]{}\"\n return false\n default:\n // VCHAR %x21-7E\n return c >= 0x21 && c <= 0x7e\n }\n}\n\n/**\n * @param {string} characters\n */\nfunction isValidHTTPToken (characters) {\n if (characters.length === 0) {\n return false\n }\n for (let i = 0; i < characters.length; ++i) {\n if (!isTokenCharCode(characters.charCodeAt(i))) {\n return false\n }\n }\n return true\n}\n\n/**\n * @see https://fetch.spec.whatwg.org/#header-name\n * @param {string} potentialValue\n */\nfunction isValidHeaderName (potentialValue) {\n return isValidHTTPToken(potentialValue)\n}\n\n/**\n * @see https://fetch.spec.whatwg.org/#header-value\n * @param {string} potentialValue\n */\nfunction isValidHeaderValue (potentialValue) {\n // - Has no leading or trailing HTTP tab or space bytes.\n // - Contains no 0x00 (NUL) or HTTP newline bytes.\n if (\n potentialValue.startsWith('\\t') ||\n potentialValue.startsWith(' ') ||\n potentialValue.endsWith('\\t') ||\n potentialValue.endsWith(' ')\n ) {\n return false\n }\n\n if (\n potentialValue.includes('\\0') ||\n potentialValue.includes('\\r') ||\n potentialValue.includes('\\n')\n ) {\n return false\n }\n\n return true\n}\n\n// https://w3c.github.io/webappsec-referrer-policy/#set-requests-referrer-policy-on-redirect\nfunction setRequestReferrerPolicyOnRedirect (request, actualResponse) {\n // Given a request request and a response actualResponse, this algorithm\n // updates request’s referrer policy according to the Referrer-Policy\n // header (if any) in actualResponse.\n\n // 1. Let policy be the result of executing § 8.1 Parse a referrer policy\n // from a Referrer-Policy header on actualResponse.\n\n // 8.1 Parse a referrer policy from a Referrer-Policy header\n // 1. Let policy-tokens be the result of extracting header list values given `Referrer-Policy` and response’s header list.\n const { headersList } = actualResponse\n // 2. Let policy be the empty string.\n // 3. For each token in policy-tokens, if token is a referrer policy and token is not the empty string, then set policy to token.\n // 4. Return policy.\n const policyHeader = (headersList.get('referrer-policy') ?? '').split(',')\n\n // Note: As the referrer-policy can contain multiple policies\n // separated by comma, we need to loop through all of them\n // and pick the first valid one.\n // Ref: https://developer.mozilla.org/en-US/docs/Web/HTTP/Headers/Referrer-Policy#specify_a_fallback_policy\n let policy = ''\n if (policyHeader.length > 0) {\n // The right-most policy takes precedence.\n // The left-most policy is the fallback.\n for (let i = policyHeader.length; i !== 0; i--) {\n const token = policyHeader[i - 1].trim()\n if (referrerPolicyTokens.has(token)) {\n policy = token\n break\n }\n }\n }\n\n // 2. If policy is not the empty string, then set request’s referrer policy to policy.\n if (policy !== '') {\n request.referrerPolicy = policy\n }\n}\n\n// https://fetch.spec.whatwg.org/#cross-origin-resource-policy-check\nfunction crossOriginResourcePolicyCheck () {\n // TODO\n return 'allowed'\n}\n\n// https://fetch.spec.whatwg.org/#concept-cors-check\nfunction corsCheck () {\n // TODO\n return 'success'\n}\n\n// https://fetch.spec.whatwg.org/#concept-tao-check\nfunction TAOCheck () {\n // TODO\n return 'success'\n}\n\nfunction appendFetchMetadata (httpRequest) {\n // https://w3c.github.io/webappsec-fetch-metadata/#sec-fetch-dest-header\n // TODO\n\n // https://w3c.github.io/webappsec-fetch-metadata/#sec-fetch-mode-header\n\n // 1. Assert: r’s url is a potentially trustworthy URL.\n // TODO\n\n // 2. Let header be a Structured Header whose value is a token.\n let header = null\n\n // 3. Set header’s value to r’s mode.\n header = httpRequest.mode\n\n // 4. Set a structured field value `Sec-Fetch-Mode`/header in r’s header list.\n httpRequest.headersList.set('sec-fetch-mode', header)\n\n // https://w3c.github.io/webappsec-fetch-metadata/#sec-fetch-site-header\n // TODO\n\n // https://w3c.github.io/webappsec-fetch-metadata/#sec-fetch-user-header\n // TODO\n}\n\n// https://fetch.spec.whatwg.org/#append-a-request-origin-header\nfunction appendRequestOriginHeader (request) {\n // 1. Let serializedOrigin be the result of byte-serializing a request origin with request.\n let serializedOrigin = request.origin\n\n // 2. If request’s response tainting is \"cors\" or request’s mode is \"websocket\", then append (`Origin`, serializedOrigin) to request’s header list.\n if (request.responseTainting === 'cors' || request.mode === 'websocket') {\n if (serializedOrigin) {\n request.headersList.append('origin', serializedOrigin)\n }\n\n // 3. Otherwise, if request’s method is neither `GET` nor `HEAD`, then:\n } else if (request.method !== 'GET' && request.method !== 'HEAD') {\n // 1. Switch on request’s referrer policy:\n switch (request.referrerPolicy) {\n case 'no-referrer':\n // Set serializedOrigin to `null`.\n serializedOrigin = null\n break\n case 'no-referrer-when-downgrade':\n case 'strict-origin':\n case 'strict-origin-when-cross-origin':\n // If request’s origin is a tuple origin, its scheme is \"https\", and request’s current URL’s scheme is not \"https\", then set serializedOrigin to `null`.\n if (request.origin && urlHasHttpsScheme(request.origin) && !urlHasHttpsScheme(requestCurrentURL(request))) {\n serializedOrigin = null\n }\n break\n case 'same-origin':\n // If request’s origin is not same origin with request’s current URL’s origin, then set serializedOrigin to `null`.\n if (!sameOrigin(request, requestCurrentURL(request))) {\n serializedOrigin = null\n }\n break\n default:\n // Do nothing.\n }\n\n if (serializedOrigin) {\n // 2. Append (`Origin`, serializedOrigin) to request’s header list.\n request.headersList.append('origin', serializedOrigin)\n }\n }\n}\n\nfunction coarsenedSharedCurrentTime (crossOriginIsolatedCapability) {\n // TODO\n return performance.now()\n}\n\n// https://fetch.spec.whatwg.org/#create-an-opaque-timing-info\nfunction createOpaqueTimingInfo (timingInfo) {\n return {\n startTime: timingInfo.startTime ?? 0,\n redirectStartTime: 0,\n redirectEndTime: 0,\n postRedirectStartTime: timingInfo.startTime ?? 0,\n finalServiceWorkerStartTime: 0,\n finalNetworkResponseStartTime: 0,\n finalNetworkRequestStartTime: 0,\n endTime: 0,\n encodedBodySize: 0,\n decodedBodySize: 0,\n finalConnectionTimingInfo: null\n }\n}\n\n// https://html.spec.whatwg.org/multipage/origin.html#policy-container\nfunction makePolicyContainer () {\n // Note: the fetch spec doesn't make use of embedder policy or CSP list\n return {\n referrerPolicy: 'strict-origin-when-cross-origin'\n }\n}\n\n// https://html.spec.whatwg.org/multipage/origin.html#clone-a-policy-container\nfunction clonePolicyContainer (policyContainer) {\n return {\n referrerPolicy: policyContainer.referrerPolicy\n }\n}\n\n// https://w3c.github.io/webappsec-referrer-policy/#determine-requests-referrer\nfunction determineRequestsReferrer (request) {\n // 1. Let policy be request's referrer policy.\n const policy = request.referrerPolicy\n\n // Note: policy cannot (shouldn't) be null or an empty string.\n assert(policy)\n\n // 2. Let environment be request’s client.\n\n let referrerSource = null\n\n // 3. Switch on request’s referrer:\n if (request.referrer === 'client') {\n // Note: node isn't a browser and doesn't implement document/iframes,\n // so we bypass this step and replace it with our own.\n\n const globalOrigin = getGlobalOrigin()\n\n if (!globalOrigin || globalOrigin.origin === 'null') {\n return 'no-referrer'\n }\n\n // note: we need to clone it as it's mutated\n referrerSource = new URL(globalOrigin)\n } else if (request.referrer instanceof URL) {\n // Let referrerSource be request’s referrer.\n referrerSource = request.referrer\n }\n\n // 4. Let request’s referrerURL be the result of stripping referrerSource for\n // use as a referrer.\n let referrerURL = stripURLForReferrer(referrerSource)\n\n // 5. Let referrerOrigin be the result of stripping referrerSource for use as\n // a referrer, with the origin-only flag set to true.\n const referrerOrigin = stripURLForReferrer(referrerSource, true)\n\n // 6. If the result of serializing referrerURL is a string whose length is\n // greater than 4096, set referrerURL to referrerOrigin.\n if (referrerURL.toString().length > 4096) {\n referrerURL = referrerOrigin\n }\n\n const areSameOrigin = sameOrigin(request, referrerURL)\n const isNonPotentiallyTrustWorthy = isURLPotentiallyTrustworthy(referrerURL) &&\n !isURLPotentiallyTrustworthy(request.url)\n\n // 8. Execute the switch statements corresponding to the value of policy:\n switch (policy) {\n case 'origin': return referrerOrigin != null ? referrerOrigin : stripURLForReferrer(referrerSource, true)\n case 'unsafe-url': return referrerURL\n case 'same-origin':\n return areSameOrigin ? referrerOrigin : 'no-referrer'\n case 'origin-when-cross-origin':\n return areSameOrigin ? referrerURL : referrerOrigin\n case 'strict-origin-when-cross-origin': {\n const currentURL = requestCurrentURL(request)\n\n // 1. If the origin of referrerURL and the origin of request’s current\n // URL are the same, then return referrerURL.\n if (sameOrigin(referrerURL, currentURL)) {\n return referrerURL\n }\n\n // 2. If referrerURL is a potentially trustworthy URL and request’s\n // current URL is not a potentially trustworthy URL, then return no\n // referrer.\n if (isURLPotentiallyTrustworthy(referrerURL) && !isURLPotentiallyTrustworthy(currentURL)) {\n return 'no-referrer'\n }\n\n // 3. Return referrerOrigin.\n return referrerOrigin\n }\n case 'strict-origin': // eslint-disable-line\n /**\n * 1. If referrerURL is a potentially trustworthy URL and\n * request’s current URL is not a potentially trustworthy URL,\n * then return no referrer.\n * 2. Return referrerOrigin\n */\n case 'no-referrer-when-downgrade': // eslint-disable-line\n /**\n * 1. If referrerURL is a potentially trustworthy URL and\n * request’s current URL is not a potentially trustworthy URL,\n * then return no referrer.\n * 2. Return referrerOrigin\n */\n\n default: // eslint-disable-line\n return isNonPotentiallyTrustWorthy ? 'no-referrer' : referrerOrigin\n }\n}\n\n/**\n * @see https://w3c.github.io/webappsec-referrer-policy/#strip-url\n * @param {URL} url\n * @param {boolean|undefined} originOnly\n */\nfunction stripURLForReferrer (url, originOnly) {\n // 1. Assert: url is a URL.\n assert(url instanceof URL)\n\n // 2. If url’s scheme is a local scheme, then return no referrer.\n if (url.protocol === 'file:' || url.protocol === 'about:' || url.protocol === 'blank:') {\n return 'no-referrer'\n }\n\n // 3. Set url’s username to the empty string.\n url.username = ''\n\n // 4. Set url’s password to the empty string.\n url.password = ''\n\n // 5. Set url’s fragment to null.\n url.hash = ''\n\n // 6. If the origin-only flag is true, then:\n if (originOnly) {\n // 1. Set url’s path to « the empty string ».\n url.pathname = ''\n\n // 2. Set url’s query to null.\n url.search = ''\n }\n\n // 7. Return url.\n return url\n}\n\nfunction isURLPotentiallyTrustworthy (url) {\n if (!(url instanceof URL)) {\n return false\n }\n\n // If child of about, return true\n if (url.href === 'about:blank' || url.href === 'about:srcdoc') {\n return true\n }\n\n // If scheme is data, return true\n if (url.protocol === 'data:') return true\n\n // If file, return true\n if (url.protocol === 'file:') return true\n\n return isOriginPotentiallyTrustworthy(url.origin)\n\n function isOriginPotentiallyTrustworthy (origin) {\n // If origin is explicitly null, return false\n if (origin == null || origin === 'null') return false\n\n const originAsURL = new URL(origin)\n\n // If secure, return true\n if (originAsURL.protocol === 'https:' || originAsURL.protocol === 'wss:') {\n return true\n }\n\n // If localhost or variants, return true\n if (/^127(?:\\.[0-9]+){0,2}\\.[0-9]+$|^\\[(?:0*:)*?:?0*1\\]$/.test(originAsURL.hostname) ||\n (originAsURL.hostname === 'localhost' || originAsURL.hostname.includes('localhost.')) ||\n (originAsURL.hostname.endsWith('.localhost'))) {\n return true\n }\n\n // If any other, return false\n return false\n }\n}\n\n/**\n * @see https://w3c.github.io/webappsec-subresource-integrity/#does-response-match-metadatalist\n * @param {Uint8Array} bytes\n * @param {string} metadataList\n */\nfunction bytesMatch (bytes, metadataList) {\n // If node is not built with OpenSSL support, we cannot check\n // a request's integrity, so allow it by default (the spec will\n // allow requests if an invalid hash is given, as precedence).\n /* istanbul ignore if: only if node is built with --without-ssl */\n if (crypto === undefined) {\n return true\n }\n\n // 1. Let parsedMetadata be the result of parsing metadataList.\n const parsedMetadata = parseMetadata(metadataList)\n\n // 2. If parsedMetadata is no metadata, return true.\n if (parsedMetadata === 'no metadata') {\n return true\n }\n\n // 3. If parsedMetadata is the empty set, return true.\n if (parsedMetadata.length === 0) {\n return true\n }\n\n // 4. Let metadata be the result of getting the strongest\n // metadata from parsedMetadata.\n const list = parsedMetadata.sort((c, d) => d.algo.localeCompare(c.algo))\n // get the strongest algorithm\n const strongest = list[0].algo\n // get all entries that use the strongest algorithm; ignore weaker\n const metadata = list.filter((item) => item.algo === strongest)\n\n // 5. For each item in metadata:\n for (const item of metadata) {\n // 1. Let algorithm be the alg component of item.\n const algorithm = item.algo\n\n // 2. Let expectedValue be the val component of item.\n let expectedValue = item.hash\n\n // See https://github.com/web-platform-tests/wpt/commit/e4c5cc7a5e48093220528dfdd1c4012dc3837a0e\n // \"be liberal with padding\". This is annoying, and it's not even in the spec.\n\n if (expectedValue.endsWith('==')) {\n expectedValue = expectedValue.slice(0, -2)\n }\n\n // 3. Let actualValue be the result of applying algorithm to bytes.\n let actualValue = crypto.createHash(algorithm).update(bytes).digest('base64')\n\n if (actualValue.endsWith('==')) {\n actualValue = actualValue.slice(0, -2)\n }\n\n // 4. If actualValue is a case-sensitive match for expectedValue,\n // return true.\n if (actualValue === expectedValue) {\n return true\n }\n\n let actualBase64URL = crypto.createHash(algorithm).update(bytes).digest('base64url')\n\n if (actualBase64URL.endsWith('==')) {\n actualBase64URL = actualBase64URL.slice(0, -2)\n }\n\n if (actualBase64URL === expectedValue) {\n return true\n }\n }\n\n // 6. Return false.\n return false\n}\n\n// https://w3c.github.io/webappsec-subresource-integrity/#grammardef-hash-with-options\n// https://www.w3.org/TR/CSP2/#source-list-syntax\n// https://www.rfc-editor.org/rfc/rfc5234#appendix-B.1\nconst parseHashWithOptions = /((?sha256|sha384|sha512)-(?[A-z0-9+/]{1}.*={0,2}))( +[\\x21-\\x7e]?)?/i\n\n/**\n * @see https://w3c.github.io/webappsec-subresource-integrity/#parse-metadata\n * @param {string} metadata\n */\nfunction parseMetadata (metadata) {\n // 1. Let result be the empty set.\n /** @type {{ algo: string, hash: string }[]} */\n const result = []\n\n // 2. Let empty be equal to true.\n let empty = true\n\n const supportedHashes = crypto.getHashes()\n\n // 3. For each token returned by splitting metadata on spaces:\n for (const token of metadata.split(' ')) {\n // 1. Set empty to false.\n empty = false\n\n // 2. Parse token as a hash-with-options.\n const parsedToken = parseHashWithOptions.exec(token)\n\n // 3. If token does not parse, continue to the next token.\n if (parsedToken === null || parsedToken.groups === undefined) {\n // Note: Chromium blocks the request at this point, but Firefox\n // gives a warning that an invalid integrity was given. The\n // correct behavior is to ignore these, and subsequently not\n // check the integrity of the resource.\n continue\n }\n\n // 4. Let algorithm be the hash-algo component of token.\n const algorithm = parsedToken.groups.algo\n\n // 5. If algorithm is a hash function recognized by the user\n // agent, add the parsed token to result.\n if (supportedHashes.includes(algorithm.toLowerCase())) {\n result.push(parsedToken.groups)\n }\n }\n\n // 4. Return no metadata if empty is true, otherwise return result.\n if (empty === true) {\n return 'no metadata'\n }\n\n return result\n}\n\n// https://w3c.github.io/webappsec-upgrade-insecure-requests/#upgrade-request\nfunction tryUpgradeRequestToAPotentiallyTrustworthyURL (request) {\n // TODO\n}\n\n/**\n * @link {https://html.spec.whatwg.org/multipage/origin.html#same-origin}\n * @param {URL} A\n * @param {URL} B\n */\nfunction sameOrigin (A, B) {\n // 1. If A and B are the same opaque origin, then return true.\n if (A.origin === B.origin && A.origin === 'null') {\n return true\n }\n\n // 2. If A and B are both tuple origins and their schemes,\n // hosts, and port are identical, then return true.\n if (A.protocol === B.protocol && A.hostname === B.hostname && A.port === B.port) {\n return true\n }\n\n // 3. Return false.\n return false\n}\n\nfunction createDeferredPromise () {\n let res\n let rej\n const promise = new Promise((resolve, reject) => {\n res = resolve\n rej = reject\n })\n\n return { promise, resolve: res, reject: rej }\n}\n\nfunction isAborted (fetchParams) {\n return fetchParams.controller.state === 'aborted'\n}\n\nfunction isCancelled (fetchParams) {\n return fetchParams.controller.state === 'aborted' ||\n fetchParams.controller.state === 'terminated'\n}\n\nconst normalizeMethodRecord = {\n delete: 'DELETE',\n DELETE: 'DELETE',\n get: 'GET',\n GET: 'GET',\n head: 'HEAD',\n HEAD: 'HEAD',\n options: 'OPTIONS',\n OPTIONS: 'OPTIONS',\n post: 'POST',\n POST: 'POST',\n put: 'PUT',\n PUT: 'PUT'\n}\n\n// Note: object prototypes should not be able to be referenced. e.g. `Object#hasOwnProperty`.\nObject.setPrototypeOf(normalizeMethodRecord, null)\n\n/**\n * @see https://fetch.spec.whatwg.org/#concept-method-normalize\n * @param {string} method\n */\nfunction normalizeMethod (method) {\n return normalizeMethodRecord[method.toLowerCase()] ?? method\n}\n\n// https://infra.spec.whatwg.org/#serialize-a-javascript-value-to-a-json-string\nfunction serializeJavascriptValueToJSONString (value) {\n // 1. Let result be ? Call(%JSON.stringify%, undefined, « value »).\n const result = JSON.stringify(value)\n\n // 2. If result is undefined, then throw a TypeError.\n if (result === undefined) {\n throw new TypeError('Value is not JSON serializable')\n }\n\n // 3. Assert: result is a string.\n assert(typeof result === 'string')\n\n // 4. Return result.\n return result\n}\n\n// https://tc39.es/ecma262/#sec-%25iteratorprototype%25-object\nconst esIteratorPrototype = Object.getPrototypeOf(Object.getPrototypeOf([][Symbol.iterator]()))\n\n/**\n * @see https://webidl.spec.whatwg.org/#dfn-iterator-prototype-object\n * @param {() => unknown[]} iterator\n * @param {string} name name of the instance\n * @param {'key'|'value'|'key+value'} kind\n */\nfunction makeIterator (iterator, name, kind) {\n const object = {\n index: 0,\n kind,\n target: iterator\n }\n\n const i = {\n next () {\n // 1. Let interface be the interface for which the iterator prototype object exists.\n\n // 2. Let thisValue be the this value.\n\n // 3. Let object be ? ToObject(thisValue).\n\n // 4. If object is a platform object, then perform a security\n // check, passing:\n\n // 5. If object is not a default iterator object for interface,\n // then throw a TypeError.\n if (Object.getPrototypeOf(this) !== i) {\n throw new TypeError(\n `'next' called on an object that does not implement interface ${name} Iterator.`\n )\n }\n\n // 6. Let index be object’s index.\n // 7. Let kind be object’s kind.\n // 8. Let values be object’s target's value pairs to iterate over.\n const { index, kind, target } = object\n const values = target()\n\n // 9. Let len be the length of values.\n const len = values.length\n\n // 10. If index is greater than or equal to len, then return\n // CreateIterResultObject(undefined, true).\n if (index >= len) {\n return { value: undefined, done: true }\n }\n\n // 11. Let pair be the entry in values at index index.\n const pair = values[index]\n\n // 12. Set object’s index to index + 1.\n object.index = index + 1\n\n // 13. Return the iterator result for pair and kind.\n return iteratorResult(pair, kind)\n },\n // The class string of an iterator prototype object for a given interface is the\n // result of concatenating the identifier of the interface and the string \" Iterator\".\n [Symbol.toStringTag]: `${name} Iterator`\n }\n\n // The [[Prototype]] internal slot of an iterator prototype object must be %IteratorPrototype%.\n Object.setPrototypeOf(i, esIteratorPrototype)\n // esIteratorPrototype needs to be the prototype of i\n // which is the prototype of an empty object. Yes, it's confusing.\n return Object.setPrototypeOf({}, i)\n}\n\n// https://webidl.spec.whatwg.org/#iterator-result\nfunction iteratorResult (pair, kind) {\n let result\n\n // 1. Let result be a value determined by the value of kind:\n switch (kind) {\n case 'key': {\n // 1. Let idlKey be pair’s key.\n // 2. Let key be the result of converting idlKey to an\n // ECMAScript value.\n // 3. result is key.\n result = pair[0]\n break\n }\n case 'value': {\n // 1. Let idlValue be pair’s value.\n // 2. Let value be the result of converting idlValue to\n // an ECMAScript value.\n // 3. result is value.\n result = pair[1]\n break\n }\n case 'key+value': {\n // 1. Let idlKey be pair’s key.\n // 2. Let idlValue be pair’s value.\n // 3. Let key be the result of converting idlKey to an\n // ECMAScript value.\n // 4. Let value be the result of converting idlValue to\n // an ECMAScript value.\n // 5. Let array be ! ArrayCreate(2).\n // 6. Call ! CreateDataProperty(array, \"0\", key).\n // 7. Call ! CreateDataProperty(array, \"1\", value).\n // 8. result is array.\n result = pair\n break\n }\n }\n\n // 2. Return CreateIterResultObject(result, false).\n return { value: result, done: false }\n}\n\n/**\n * @see https://fetch.spec.whatwg.org/#body-fully-read\n */\nasync function fullyReadBody (body, processBody, processBodyError) {\n // 1. If taskDestination is null, then set taskDestination to\n // the result of starting a new parallel queue.\n\n // 2. Let successSteps given a byte sequence bytes be to queue a\n // fetch task to run processBody given bytes, with taskDestination.\n const successSteps = processBody\n\n // 3. Let errorSteps be to queue a fetch task to run processBodyError,\n // with taskDestination.\n const errorSteps = processBodyError\n\n // 4. Let reader be the result of getting a reader for body’s stream.\n // If that threw an exception, then run errorSteps with that\n // exception and return.\n let reader\n\n try {\n reader = body.stream.getReader()\n } catch (e) {\n errorSteps(e)\n return\n }\n\n // 5. Read all bytes from reader, given successSteps and errorSteps.\n try {\n const result = await readAllBytes(reader)\n successSteps(result)\n } catch (e) {\n errorSteps(e)\n }\n}\n\n/** @type {ReadableStream} */\nlet ReadableStream = globalThis.ReadableStream\n\nfunction isReadableStreamLike (stream) {\n if (!ReadableStream) {\n ReadableStream = require('stream/web').ReadableStream\n }\n\n return stream instanceof ReadableStream || (\n stream[Symbol.toStringTag] === 'ReadableStream' &&\n typeof stream.tee === 'function'\n )\n}\n\nconst MAXIMUM_ARGUMENT_LENGTH = 65535\n\n/**\n * @see https://infra.spec.whatwg.org/#isomorphic-decode\n * @param {number[]|Uint8Array} input\n */\nfunction isomorphicDecode (input) {\n // 1. To isomorphic decode a byte sequence input, return a string whose code point\n // length is equal to input’s length and whose code points have the same values\n // as the values of input’s bytes, in the same order.\n\n if (input.length < MAXIMUM_ARGUMENT_LENGTH) {\n return String.fromCharCode(...input)\n }\n\n return input.reduce((previous, current) => previous + String.fromCharCode(current), '')\n}\n\n/**\n * @param {ReadableStreamController} controller\n */\nfunction readableStreamClose (controller) {\n try {\n controller.close()\n } catch (err) {\n // TODO: add comment explaining why this error occurs.\n if (!err.message.includes('Controller is already closed')) {\n throw err\n }\n }\n}\n\n/**\n * @see https://infra.spec.whatwg.org/#isomorphic-encode\n * @param {string} input\n */\nfunction isomorphicEncode (input) {\n // 1. Assert: input contains no code points greater than U+00FF.\n for (let i = 0; i < input.length; i++) {\n assert(input.charCodeAt(i) <= 0xFF)\n }\n\n // 2. Return a byte sequence whose length is equal to input’s code\n // point length and whose bytes have the same values as the\n // values of input’s code points, in the same order\n return input\n}\n\n/**\n * @see https://streams.spec.whatwg.org/#readablestreamdefaultreader-read-all-bytes\n * @see https://streams.spec.whatwg.org/#read-loop\n * @param {ReadableStreamDefaultReader} reader\n */\nasync function readAllBytes (reader) {\n const bytes = []\n let byteLength = 0\n\n while (true) {\n const { done, value: chunk } = await reader.read()\n\n if (done) {\n // 1. Call successSteps with bytes.\n return Buffer.concat(bytes, byteLength)\n }\n\n // 1. If chunk is not a Uint8Array object, call failureSteps\n // with a TypeError and abort these steps.\n if (!isUint8Array(chunk)) {\n throw new TypeError('Received non-Uint8Array chunk')\n }\n\n // 2. Append the bytes represented by chunk to bytes.\n bytes.push(chunk)\n byteLength += chunk.length\n\n // 3. Read-loop given reader, bytes, successSteps, and failureSteps.\n }\n}\n\n/**\n * @see https://fetch.spec.whatwg.org/#is-local\n * @param {URL} url\n */\nfunction urlIsLocal (url) {\n assert('protocol' in url) // ensure it's a url object\n\n const protocol = url.protocol\n\n return protocol === 'about:' || protocol === 'blob:' || protocol === 'data:'\n}\n\n/**\n * @param {string|URL} url\n */\nfunction urlHasHttpsScheme (url) {\n if (typeof url === 'string') {\n return url.startsWith('https:')\n }\n\n return url.protocol === 'https:'\n}\n\n/**\n * @see https://fetch.spec.whatwg.org/#http-scheme\n * @param {URL} url\n */\nfunction urlIsHttpHttpsScheme (url) {\n assert('protocol' in url) // ensure it's a url object\n\n const protocol = url.protocol\n\n return protocol === 'http:' || protocol === 'https:'\n}\n\n/**\n * Fetch supports node >= 16.8.0, but Object.hasOwn was added in v16.9.0.\n */\nconst hasOwn = Object.hasOwn || ((dict, key) => Object.prototype.hasOwnProperty.call(dict, key))\n\nmodule.exports = {\n isAborted,\n isCancelled,\n createDeferredPromise,\n ReadableStreamFrom,\n toUSVString,\n tryUpgradeRequestToAPotentiallyTrustworthyURL,\n coarsenedSharedCurrentTime,\n determineRequestsReferrer,\n makePolicyContainer,\n clonePolicyContainer,\n appendFetchMetadata,\n appendRequestOriginHeader,\n TAOCheck,\n corsCheck,\n crossOriginResourcePolicyCheck,\n createOpaqueTimingInfo,\n setRequestReferrerPolicyOnRedirect,\n isValidHTTPToken,\n requestBadPort,\n requestCurrentURL,\n responseURL,\n responseLocationURL,\n isBlobLike,\n isURLPotentiallyTrustworthy,\n isValidReasonPhrase,\n sameOrigin,\n normalizeMethod,\n serializeJavascriptValueToJSONString,\n makeIterator,\n isValidHeaderName,\n isValidHeaderValue,\n hasOwn,\n isErrorLike,\n fullyReadBody,\n bytesMatch,\n isReadableStreamLike,\n readableStreamClose,\n isomorphicEncode,\n isomorphicDecode,\n urlIsLocal,\n urlHasHttpsScheme,\n urlIsHttpHttpsScheme,\n readAllBytes,\n normalizeMethodRecord\n}\n","'use strict'\n\nconst { types } = require('util')\nconst { hasOwn, toUSVString } = require('./util')\n\n/** @type {import('../../types/webidl').Webidl} */\nconst webidl = {}\nwebidl.converters = {}\nwebidl.util = {}\nwebidl.errors = {}\n\nwebidl.errors.exception = function (message) {\n return new TypeError(`${message.header}: ${message.message}`)\n}\n\nwebidl.errors.conversionFailed = function (context) {\n const plural = context.types.length === 1 ? '' : ' one of'\n const message =\n `${context.argument} could not be converted to` +\n `${plural}: ${context.types.join(', ')}.`\n\n return webidl.errors.exception({\n header: context.prefix,\n message\n })\n}\n\nwebidl.errors.invalidArgument = function (context) {\n return webidl.errors.exception({\n header: context.prefix,\n message: `\"${context.value}\" is an invalid ${context.type}.`\n })\n}\n\n// https://webidl.spec.whatwg.org/#implements\nwebidl.brandCheck = function (V, I, opts = undefined) {\n if (opts?.strict !== false && !(V instanceof I)) {\n throw new TypeError('Illegal invocation')\n } else {\n return V?.[Symbol.toStringTag] === I.prototype[Symbol.toStringTag]\n }\n}\n\nwebidl.argumentLengthCheck = function ({ length }, min, ctx) {\n if (length < min) {\n throw webidl.errors.exception({\n message: `${min} argument${min !== 1 ? 's' : ''} required, ` +\n `but${length ? ' only' : ''} ${length} found.`,\n ...ctx\n })\n }\n}\n\nwebidl.illegalConstructor = function () {\n throw webidl.errors.exception({\n header: 'TypeError',\n message: 'Illegal constructor'\n })\n}\n\n// https://tc39.es/ecma262/#sec-ecmascript-data-types-and-values\nwebidl.util.Type = function (V) {\n switch (typeof V) {\n case 'undefined': return 'Undefined'\n case 'boolean': return 'Boolean'\n case 'string': return 'String'\n case 'symbol': return 'Symbol'\n case 'number': return 'Number'\n case 'bigint': return 'BigInt'\n case 'function':\n case 'object': {\n if (V === null) {\n return 'Null'\n }\n\n return 'Object'\n }\n }\n}\n\n// https://webidl.spec.whatwg.org/#abstract-opdef-converttoint\nwebidl.util.ConvertToInt = function (V, bitLength, signedness, opts = {}) {\n let upperBound\n let lowerBound\n\n // 1. If bitLength is 64, then:\n if (bitLength === 64) {\n // 1. Let upperBound be 2^53 − 1.\n upperBound = Math.pow(2, 53) - 1\n\n // 2. If signedness is \"unsigned\", then let lowerBound be 0.\n if (signedness === 'unsigned') {\n lowerBound = 0\n } else {\n // 3. Otherwise let lowerBound be −2^53 + 1.\n lowerBound = Math.pow(-2, 53) + 1\n }\n } else if (signedness === 'unsigned') {\n // 2. Otherwise, if signedness is \"unsigned\", then:\n\n // 1. Let lowerBound be 0.\n lowerBound = 0\n\n // 2. Let upperBound be 2^bitLength − 1.\n upperBound = Math.pow(2, bitLength) - 1\n } else {\n // 3. Otherwise:\n\n // 1. Let lowerBound be -2^bitLength − 1.\n lowerBound = Math.pow(-2, bitLength) - 1\n\n // 2. Let upperBound be 2^bitLength − 1 − 1.\n upperBound = Math.pow(2, bitLength - 1) - 1\n }\n\n // 4. Let x be ? ToNumber(V).\n let x = Number(V)\n\n // 5. If x is −0, then set x to +0.\n if (x === 0) {\n x = 0\n }\n\n // 6. If the conversion is to an IDL type associated\n // with the [EnforceRange] extended attribute, then:\n if (opts.enforceRange === true) {\n // 1. If x is NaN, +∞, or −∞, then throw a TypeError.\n if (\n Number.isNaN(x) ||\n x === Number.POSITIVE_INFINITY ||\n x === Number.NEGATIVE_INFINITY\n ) {\n throw webidl.errors.exception({\n header: 'Integer conversion',\n message: `Could not convert ${V} to an integer.`\n })\n }\n\n // 2. Set x to IntegerPart(x).\n x = webidl.util.IntegerPart(x)\n\n // 3. If x < lowerBound or x > upperBound, then\n // throw a TypeError.\n if (x < lowerBound || x > upperBound) {\n throw webidl.errors.exception({\n header: 'Integer conversion',\n message: `Value must be between ${lowerBound}-${upperBound}, got ${x}.`\n })\n }\n\n // 4. Return x.\n return x\n }\n\n // 7. If x is not NaN and the conversion is to an IDL\n // type associated with the [Clamp] extended\n // attribute, then:\n if (!Number.isNaN(x) && opts.clamp === true) {\n // 1. Set x to min(max(x, lowerBound), upperBound).\n x = Math.min(Math.max(x, lowerBound), upperBound)\n\n // 2. Round x to the nearest integer, choosing the\n // even integer if it lies halfway between two,\n // and choosing +0 rather than −0.\n if (Math.floor(x) % 2 === 0) {\n x = Math.floor(x)\n } else {\n x = Math.ceil(x)\n }\n\n // 3. Return x.\n return x\n }\n\n // 8. If x is NaN, +0, +∞, or −∞, then return +0.\n if (\n Number.isNaN(x) ||\n (x === 0 && Object.is(0, x)) ||\n x === Number.POSITIVE_INFINITY ||\n x === Number.NEGATIVE_INFINITY\n ) {\n return 0\n }\n\n // 9. Set x to IntegerPart(x).\n x = webidl.util.IntegerPart(x)\n\n // 10. Set x to x modulo 2^bitLength.\n x = x % Math.pow(2, bitLength)\n\n // 11. If signedness is \"signed\" and x ≥ 2^bitLength − 1,\n // then return x − 2^bitLength.\n if (signedness === 'signed' && x >= Math.pow(2, bitLength) - 1) {\n return x - Math.pow(2, bitLength)\n }\n\n // 12. Otherwise, return x.\n return x\n}\n\n// https://webidl.spec.whatwg.org/#abstract-opdef-integerpart\nwebidl.util.IntegerPart = function (n) {\n // 1. Let r be floor(abs(n)).\n const r = Math.floor(Math.abs(n))\n\n // 2. If n < 0, then return -1 × r.\n if (n < 0) {\n return -1 * r\n }\n\n // 3. Otherwise, return r.\n return r\n}\n\n// https://webidl.spec.whatwg.org/#es-sequence\nwebidl.sequenceConverter = function (converter) {\n return (V) => {\n // 1. If Type(V) is not Object, throw a TypeError.\n if (webidl.util.Type(V) !== 'Object') {\n throw webidl.errors.exception({\n header: 'Sequence',\n message: `Value of type ${webidl.util.Type(V)} is not an Object.`\n })\n }\n\n // 2. Let method be ? GetMethod(V, @@iterator).\n /** @type {Generator} */\n const method = V?.[Symbol.iterator]?.()\n const seq = []\n\n // 3. If method is undefined, throw a TypeError.\n if (\n method === undefined ||\n typeof method.next !== 'function'\n ) {\n throw webidl.errors.exception({\n header: 'Sequence',\n message: 'Object is not an iterator.'\n })\n }\n\n // https://webidl.spec.whatwg.org/#create-sequence-from-iterable\n while (true) {\n const { done, value } = method.next()\n\n if (done) {\n break\n }\n\n seq.push(converter(value))\n }\n\n return seq\n }\n}\n\n// https://webidl.spec.whatwg.org/#es-to-record\nwebidl.recordConverter = function (keyConverter, valueConverter) {\n return (O) => {\n // 1. If Type(O) is not Object, throw a TypeError.\n if (webidl.util.Type(O) !== 'Object') {\n throw webidl.errors.exception({\n header: 'Record',\n message: `Value of type ${webidl.util.Type(O)} is not an Object.`\n })\n }\n\n // 2. Let result be a new empty instance of record.\n const result = {}\n\n if (!types.isProxy(O)) {\n // Object.keys only returns enumerable properties\n const keys = Object.keys(O)\n\n for (const key of keys) {\n // 1. Let typedKey be key converted to an IDL value of type K.\n const typedKey = keyConverter(key)\n\n // 2. Let value be ? Get(O, key).\n // 3. Let typedValue be value converted to an IDL value of type V.\n const typedValue = valueConverter(O[key])\n\n // 4. Set result[typedKey] to typedValue.\n result[typedKey] = typedValue\n }\n\n // 5. Return result.\n return result\n }\n\n // 3. Let keys be ? O.[[OwnPropertyKeys]]().\n const keys = Reflect.ownKeys(O)\n\n // 4. For each key of keys.\n for (const key of keys) {\n // 1. Let desc be ? O.[[GetOwnProperty]](key).\n const desc = Reflect.getOwnPropertyDescriptor(O, key)\n\n // 2. If desc is not undefined and desc.[[Enumerable]] is true:\n if (desc?.enumerable) {\n // 1. Let typedKey be key converted to an IDL value of type K.\n const typedKey = keyConverter(key)\n\n // 2. Let value be ? Get(O, key).\n // 3. Let typedValue be value converted to an IDL value of type V.\n const typedValue = valueConverter(O[key])\n\n // 4. Set result[typedKey] to typedValue.\n result[typedKey] = typedValue\n }\n }\n\n // 5. Return result.\n return result\n }\n}\n\nwebidl.interfaceConverter = function (i) {\n return (V, opts = {}) => {\n if (opts.strict !== false && !(V instanceof i)) {\n throw webidl.errors.exception({\n header: i.name,\n message: `Expected ${V} to be an instance of ${i.name}.`\n })\n }\n\n return V\n }\n}\n\nwebidl.dictionaryConverter = function (converters) {\n return (dictionary) => {\n const type = webidl.util.Type(dictionary)\n const dict = {}\n\n if (type === 'Null' || type === 'Undefined') {\n return dict\n } else if (type !== 'Object') {\n throw webidl.errors.exception({\n header: 'Dictionary',\n message: `Expected ${dictionary} to be one of: Null, Undefined, Object.`\n })\n }\n\n for (const options of converters) {\n const { key, defaultValue, required, converter } = options\n\n if (required === true) {\n if (!hasOwn(dictionary, key)) {\n throw webidl.errors.exception({\n header: 'Dictionary',\n message: `Missing required key \"${key}\".`\n })\n }\n }\n\n let value = dictionary[key]\n const hasDefault = hasOwn(options, 'defaultValue')\n\n // Only use defaultValue if value is undefined and\n // a defaultValue options was provided.\n if (hasDefault && value !== null) {\n value = value ?? defaultValue\n }\n\n // A key can be optional and have no default value.\n // When this happens, do not perform a conversion,\n // and do not assign the key a value.\n if (required || hasDefault || value !== undefined) {\n value = converter(value)\n\n if (\n options.allowedValues &&\n !options.allowedValues.includes(value)\n ) {\n throw webidl.errors.exception({\n header: 'Dictionary',\n message: `${value} is not an accepted type. Expected one of ${options.allowedValues.join(', ')}.`\n })\n }\n\n dict[key] = value\n }\n }\n\n return dict\n }\n}\n\nwebidl.nullableConverter = function (converter) {\n return (V) => {\n if (V === null) {\n return V\n }\n\n return converter(V)\n }\n}\n\n// https://webidl.spec.whatwg.org/#es-DOMString\nwebidl.converters.DOMString = function (V, opts = {}) {\n // 1. If V is null and the conversion is to an IDL type\n // associated with the [LegacyNullToEmptyString]\n // extended attribute, then return the DOMString value\n // that represents the empty string.\n if (V === null && opts.legacyNullToEmptyString) {\n return ''\n }\n\n // 2. Let x be ? ToString(V).\n if (typeof V === 'symbol') {\n throw new TypeError('Could not convert argument of type symbol to string.')\n }\n\n // 3. Return the IDL DOMString value that represents the\n // same sequence of code units as the one the\n // ECMAScript String value x represents.\n return String(V)\n}\n\n// https://webidl.spec.whatwg.org/#es-ByteString\nwebidl.converters.ByteString = function (V) {\n // 1. Let x be ? ToString(V).\n // Note: DOMString converter perform ? ToString(V)\n const x = webidl.converters.DOMString(V)\n\n // 2. If the value of any element of x is greater than\n // 255, then throw a TypeError.\n for (let index = 0; index < x.length; index++) {\n if (x.charCodeAt(index) > 255) {\n throw new TypeError(\n 'Cannot convert argument to a ByteString because the character at ' +\n `index ${index} has a value of ${x.charCodeAt(index)} which is greater than 255.`\n )\n }\n }\n\n // 3. Return an IDL ByteString value whose length is the\n // length of x, and where the value of each element is\n // the value of the corresponding element of x.\n return x\n}\n\n// https://webidl.spec.whatwg.org/#es-USVString\nwebidl.converters.USVString = toUSVString\n\n// https://webidl.spec.whatwg.org/#es-boolean\nwebidl.converters.boolean = function (V) {\n // 1. Let x be the result of computing ToBoolean(V).\n const x = Boolean(V)\n\n // 2. Return the IDL boolean value that is the one that represents\n // the same truth value as the ECMAScript Boolean value x.\n return x\n}\n\n// https://webidl.spec.whatwg.org/#es-any\nwebidl.converters.any = function (V) {\n return V\n}\n\n// https://webidl.spec.whatwg.org/#es-long-long\nwebidl.converters['long long'] = function (V) {\n // 1. Let x be ? ConvertToInt(V, 64, \"signed\").\n const x = webidl.util.ConvertToInt(V, 64, 'signed')\n\n // 2. Return the IDL long long value that represents\n // the same numeric value as x.\n return x\n}\n\n// https://webidl.spec.whatwg.org/#es-unsigned-long-long\nwebidl.converters['unsigned long long'] = function (V) {\n // 1. Let x be ? ConvertToInt(V, 64, \"unsigned\").\n const x = webidl.util.ConvertToInt(V, 64, 'unsigned')\n\n // 2. Return the IDL unsigned long long value that\n // represents the same numeric value as x.\n return x\n}\n\n// https://webidl.spec.whatwg.org/#es-unsigned-long\nwebidl.converters['unsigned long'] = function (V) {\n // 1. Let x be ? ConvertToInt(V, 32, \"unsigned\").\n const x = webidl.util.ConvertToInt(V, 32, 'unsigned')\n\n // 2. Return the IDL unsigned long value that\n // represents the same numeric value as x.\n return x\n}\n\n// https://webidl.spec.whatwg.org/#es-unsigned-short\nwebidl.converters['unsigned short'] = function (V, opts) {\n // 1. Let x be ? ConvertToInt(V, 16, \"unsigned\").\n const x = webidl.util.ConvertToInt(V, 16, 'unsigned', opts)\n\n // 2. Return the IDL unsigned short value that represents\n // the same numeric value as x.\n return x\n}\n\n// https://webidl.spec.whatwg.org/#idl-ArrayBuffer\nwebidl.converters.ArrayBuffer = function (V, opts = {}) {\n // 1. If Type(V) is not Object, or V does not have an\n // [[ArrayBufferData]] internal slot, then throw a\n // TypeError.\n // see: https://tc39.es/ecma262/#sec-properties-of-the-arraybuffer-instances\n // see: https://tc39.es/ecma262/#sec-properties-of-the-sharedarraybuffer-instances\n if (\n webidl.util.Type(V) !== 'Object' ||\n !types.isAnyArrayBuffer(V)\n ) {\n throw webidl.errors.conversionFailed({\n prefix: `${V}`,\n argument: `${V}`,\n types: ['ArrayBuffer']\n })\n }\n\n // 2. If the conversion is not to an IDL type associated\n // with the [AllowShared] extended attribute, and\n // IsSharedArrayBuffer(V) is true, then throw a\n // TypeError.\n if (opts.allowShared === false && types.isSharedArrayBuffer(V)) {\n throw webidl.errors.exception({\n header: 'ArrayBuffer',\n message: 'SharedArrayBuffer is not allowed.'\n })\n }\n\n // 3. If the conversion is not to an IDL type associated\n // with the [AllowResizable] extended attribute, and\n // IsResizableArrayBuffer(V) is true, then throw a\n // TypeError.\n // Note: resizable ArrayBuffers are currently a proposal.\n\n // 4. Return the IDL ArrayBuffer value that is a\n // reference to the same object as V.\n return V\n}\n\nwebidl.converters.TypedArray = function (V, T, opts = {}) {\n // 1. Let T be the IDL type V is being converted to.\n\n // 2. If Type(V) is not Object, or V does not have a\n // [[TypedArrayName]] internal slot with a value\n // equal to T’s name, then throw a TypeError.\n if (\n webidl.util.Type(V) !== 'Object' ||\n !types.isTypedArray(V) ||\n V.constructor.name !== T.name\n ) {\n throw webidl.errors.conversionFailed({\n prefix: `${T.name}`,\n argument: `${V}`,\n types: [T.name]\n })\n }\n\n // 3. If the conversion is not to an IDL type associated\n // with the [AllowShared] extended attribute, and\n // IsSharedArrayBuffer(V.[[ViewedArrayBuffer]]) is\n // true, then throw a TypeError.\n if (opts.allowShared === false && types.isSharedArrayBuffer(V.buffer)) {\n throw webidl.errors.exception({\n header: 'ArrayBuffer',\n message: 'SharedArrayBuffer is not allowed.'\n })\n }\n\n // 4. If the conversion is not to an IDL type associated\n // with the [AllowResizable] extended attribute, and\n // IsResizableArrayBuffer(V.[[ViewedArrayBuffer]]) is\n // true, then throw a TypeError.\n // Note: resizable array buffers are currently a proposal\n\n // 5. Return the IDL value of type T that is a reference\n // to the same object as V.\n return V\n}\n\nwebidl.converters.DataView = function (V, opts = {}) {\n // 1. If Type(V) is not Object, or V does not have a\n // [[DataView]] internal slot, then throw a TypeError.\n if (webidl.util.Type(V) !== 'Object' || !types.isDataView(V)) {\n throw webidl.errors.exception({\n header: 'DataView',\n message: 'Object is not a DataView.'\n })\n }\n\n // 2. If the conversion is not to an IDL type associated\n // with the [AllowShared] extended attribute, and\n // IsSharedArrayBuffer(V.[[ViewedArrayBuffer]]) is true,\n // then throw a TypeError.\n if (opts.allowShared === false && types.isSharedArrayBuffer(V.buffer)) {\n throw webidl.errors.exception({\n header: 'ArrayBuffer',\n message: 'SharedArrayBuffer is not allowed.'\n })\n }\n\n // 3. If the conversion is not to an IDL type associated\n // with the [AllowResizable] extended attribute, and\n // IsResizableArrayBuffer(V.[[ViewedArrayBuffer]]) is\n // true, then throw a TypeError.\n // Note: resizable ArrayBuffers are currently a proposal\n\n // 4. Return the IDL DataView value that is a reference\n // to the same object as V.\n return V\n}\n\n// https://webidl.spec.whatwg.org/#BufferSource\nwebidl.converters.BufferSource = function (V, opts = {}) {\n if (types.isAnyArrayBuffer(V)) {\n return webidl.converters.ArrayBuffer(V, opts)\n }\n\n if (types.isTypedArray(V)) {\n return webidl.converters.TypedArray(V, V.constructor)\n }\n\n if (types.isDataView(V)) {\n return webidl.converters.DataView(V, opts)\n }\n\n throw new TypeError(`Could not convert ${V} to a BufferSource.`)\n}\n\nwebidl.converters['sequence'] = webidl.sequenceConverter(\n webidl.converters.ByteString\n)\n\nwebidl.converters['sequence>'] = webidl.sequenceConverter(\n webidl.converters['sequence']\n)\n\nwebidl.converters['record'] = webidl.recordConverter(\n webidl.converters.ByteString,\n webidl.converters.ByteString\n)\n\nmodule.exports = {\n webidl\n}\n","'use strict'\n\n/**\n * @see https://encoding.spec.whatwg.org/#concept-encoding-get\n * @param {string|undefined} label\n */\nfunction getEncoding (label) {\n if (!label) {\n return 'failure'\n }\n\n // 1. Remove any leading and trailing ASCII whitespace from label.\n // 2. If label is an ASCII case-insensitive match for any of the\n // labels listed in the table below, then return the\n // corresponding encoding; otherwise return failure.\n switch (label.trim().toLowerCase()) {\n case 'unicode-1-1-utf-8':\n case 'unicode11utf8':\n case 'unicode20utf8':\n case 'utf-8':\n case 'utf8':\n case 'x-unicode20utf8':\n return 'UTF-8'\n case '866':\n case 'cp866':\n case 'csibm866':\n case 'ibm866':\n return 'IBM866'\n case 'csisolatin2':\n case 'iso-8859-2':\n case 'iso-ir-101':\n case 'iso8859-2':\n case 'iso88592':\n case 'iso_8859-2':\n case 'iso_8859-2:1987':\n case 'l2':\n case 'latin2':\n return 'ISO-8859-2'\n case 'csisolatin3':\n case 'iso-8859-3':\n case 'iso-ir-109':\n case 'iso8859-3':\n case 'iso88593':\n case 'iso_8859-3':\n case 'iso_8859-3:1988':\n case 'l3':\n case 'latin3':\n return 'ISO-8859-3'\n case 'csisolatin4':\n case 'iso-8859-4':\n case 'iso-ir-110':\n case 'iso8859-4':\n case 'iso88594':\n case 'iso_8859-4':\n case 'iso_8859-4:1988':\n case 'l4':\n case 'latin4':\n return 'ISO-8859-4'\n case 'csisolatincyrillic':\n case 'cyrillic':\n case 'iso-8859-5':\n case 'iso-ir-144':\n case 'iso8859-5':\n case 'iso88595':\n case 'iso_8859-5':\n case 'iso_8859-5:1988':\n return 'ISO-8859-5'\n case 'arabic':\n case 'asmo-708':\n case 'csiso88596e':\n case 'csiso88596i':\n case 'csisolatinarabic':\n case 'ecma-114':\n case 'iso-8859-6':\n case 'iso-8859-6-e':\n case 'iso-8859-6-i':\n case 'iso-ir-127':\n case 'iso8859-6':\n case 'iso88596':\n case 'iso_8859-6':\n case 'iso_8859-6:1987':\n return 'ISO-8859-6'\n case 'csisolatingreek':\n case 'ecma-118':\n case 'elot_928':\n case 'greek':\n case 'greek8':\n case 'iso-8859-7':\n case 'iso-ir-126':\n case 'iso8859-7':\n case 'iso88597':\n case 'iso_8859-7':\n case 'iso_8859-7:1987':\n case 'sun_eu_greek':\n return 'ISO-8859-7'\n case 'csiso88598e':\n case 'csisolatinhebrew':\n case 'hebrew':\n case 'iso-8859-8':\n case 'iso-8859-8-e':\n case 'iso-ir-138':\n case 'iso8859-8':\n case 'iso88598':\n case 'iso_8859-8':\n case 'iso_8859-8:1988':\n case 'visual':\n return 'ISO-8859-8'\n case 'csiso88598i':\n case 'iso-8859-8-i':\n case 'logical':\n return 'ISO-8859-8-I'\n case 'csisolatin6':\n case 'iso-8859-10':\n case 'iso-ir-157':\n case 'iso8859-10':\n case 'iso885910':\n case 'l6':\n case 'latin6':\n return 'ISO-8859-10'\n case 'iso-8859-13':\n case 'iso8859-13':\n case 'iso885913':\n return 'ISO-8859-13'\n case 'iso-8859-14':\n case 'iso8859-14':\n case 'iso885914':\n return 'ISO-8859-14'\n case 'csisolatin9':\n case 'iso-8859-15':\n case 'iso8859-15':\n case 'iso885915':\n case 'iso_8859-15':\n case 'l9':\n return 'ISO-8859-15'\n case 'iso-8859-16':\n return 'ISO-8859-16'\n case 'cskoi8r':\n case 'koi':\n case 'koi8':\n case 'koi8-r':\n case 'koi8_r':\n return 'KOI8-R'\n case 'koi8-ru':\n case 'koi8-u':\n return 'KOI8-U'\n case 'csmacintosh':\n case 'mac':\n case 'macintosh':\n case 'x-mac-roman':\n return 'macintosh'\n case 'iso-8859-11':\n case 'iso8859-11':\n case 'iso885911':\n case 'tis-620':\n case 'windows-874':\n return 'windows-874'\n case 'cp1250':\n case 'windows-1250':\n case 'x-cp1250':\n return 'windows-1250'\n case 'cp1251':\n case 'windows-1251':\n case 'x-cp1251':\n return 'windows-1251'\n case 'ansi_x3.4-1968':\n case 'ascii':\n case 'cp1252':\n case 'cp819':\n case 'csisolatin1':\n case 'ibm819':\n case 'iso-8859-1':\n case 'iso-ir-100':\n case 'iso8859-1':\n case 'iso88591':\n case 'iso_8859-1':\n case 'iso_8859-1:1987':\n case 'l1':\n case 'latin1':\n case 'us-ascii':\n case 'windows-1252':\n case 'x-cp1252':\n return 'windows-1252'\n case 'cp1253':\n case 'windows-1253':\n case 'x-cp1253':\n return 'windows-1253'\n case 'cp1254':\n case 'csisolatin5':\n case 'iso-8859-9':\n case 'iso-ir-148':\n case 'iso8859-9':\n case 'iso88599':\n case 'iso_8859-9':\n case 'iso_8859-9:1989':\n case 'l5':\n case 'latin5':\n case 'windows-1254':\n case 'x-cp1254':\n return 'windows-1254'\n case 'cp1255':\n case 'windows-1255':\n case 'x-cp1255':\n return 'windows-1255'\n case 'cp1256':\n case 'windows-1256':\n case 'x-cp1256':\n return 'windows-1256'\n case 'cp1257':\n case 'windows-1257':\n case 'x-cp1257':\n return 'windows-1257'\n case 'cp1258':\n case 'windows-1258':\n case 'x-cp1258':\n return 'windows-1258'\n case 'x-mac-cyrillic':\n case 'x-mac-ukrainian':\n return 'x-mac-cyrillic'\n case 'chinese':\n case 'csgb2312':\n case 'csiso58gb231280':\n case 'gb2312':\n case 'gb_2312':\n case 'gb_2312-80':\n case 'gbk':\n case 'iso-ir-58':\n case 'x-gbk':\n return 'GBK'\n case 'gb18030':\n return 'gb18030'\n case 'big5':\n case 'big5-hkscs':\n case 'cn-big5':\n case 'csbig5':\n case 'x-x-big5':\n return 'Big5'\n case 'cseucpkdfmtjapanese':\n case 'euc-jp':\n case 'x-euc-jp':\n return 'EUC-JP'\n case 'csiso2022jp':\n case 'iso-2022-jp':\n return 'ISO-2022-JP'\n case 'csshiftjis':\n case 'ms932':\n case 'ms_kanji':\n case 'shift-jis':\n case 'shift_jis':\n case 'sjis':\n case 'windows-31j':\n case 'x-sjis':\n return 'Shift_JIS'\n case 'cseuckr':\n case 'csksc56011987':\n case 'euc-kr':\n case 'iso-ir-149':\n case 'korean':\n case 'ks_c_5601-1987':\n case 'ks_c_5601-1989':\n case 'ksc5601':\n case 'ksc_5601':\n case 'windows-949':\n return 'EUC-KR'\n case 'csiso2022kr':\n case 'hz-gb-2312':\n case 'iso-2022-cn':\n case 'iso-2022-cn-ext':\n case 'iso-2022-kr':\n case 'replacement':\n return 'replacement'\n case 'unicodefffe':\n case 'utf-16be':\n return 'UTF-16BE'\n case 'csunicode':\n case 'iso-10646-ucs-2':\n case 'ucs-2':\n case 'unicode':\n case 'unicodefeff':\n case 'utf-16':\n case 'utf-16le':\n return 'UTF-16LE'\n case 'x-user-defined':\n return 'x-user-defined'\n default: return 'failure'\n }\n}\n\nmodule.exports = {\n getEncoding\n}\n","'use strict'\n\nconst {\n staticPropertyDescriptors,\n readOperation,\n fireAProgressEvent\n} = require('./util')\nconst {\n kState,\n kError,\n kResult,\n kEvents,\n kAborted\n} = require('./symbols')\nconst { webidl } = require('../fetch/webidl')\nconst { kEnumerableProperty } = require('../core/util')\n\nclass FileReader extends EventTarget {\n constructor () {\n super()\n\n this[kState] = 'empty'\n this[kResult] = null\n this[kError] = null\n this[kEvents] = {\n loadend: null,\n error: null,\n abort: null,\n load: null,\n progress: null,\n loadstart: null\n }\n }\n\n /**\n * @see https://w3c.github.io/FileAPI/#dfn-readAsArrayBuffer\n * @param {import('buffer').Blob} blob\n */\n readAsArrayBuffer (blob) {\n webidl.brandCheck(this, FileReader)\n\n webidl.argumentLengthCheck(arguments, 1, { header: 'FileReader.readAsArrayBuffer' })\n\n blob = webidl.converters.Blob(blob, { strict: false })\n\n // The readAsArrayBuffer(blob) method, when invoked,\n // must initiate a read operation for blob with ArrayBuffer.\n readOperation(this, blob, 'ArrayBuffer')\n }\n\n /**\n * @see https://w3c.github.io/FileAPI/#readAsBinaryString\n * @param {import('buffer').Blob} blob\n */\n readAsBinaryString (blob) {\n webidl.brandCheck(this, FileReader)\n\n webidl.argumentLengthCheck(arguments, 1, { header: 'FileReader.readAsBinaryString' })\n\n blob = webidl.converters.Blob(blob, { strict: false })\n\n // The readAsBinaryString(blob) method, when invoked,\n // must initiate a read operation for blob with BinaryString.\n readOperation(this, blob, 'BinaryString')\n }\n\n /**\n * @see https://w3c.github.io/FileAPI/#readAsDataText\n * @param {import('buffer').Blob} blob\n * @param {string?} encoding\n */\n readAsText (blob, encoding = undefined) {\n webidl.brandCheck(this, FileReader)\n\n webidl.argumentLengthCheck(arguments, 1, { header: 'FileReader.readAsText' })\n\n blob = webidl.converters.Blob(blob, { strict: false })\n\n if (encoding !== undefined) {\n encoding = webidl.converters.DOMString(encoding)\n }\n\n // The readAsText(blob, encoding) method, when invoked,\n // must initiate a read operation for blob with Text and encoding.\n readOperation(this, blob, 'Text', encoding)\n }\n\n /**\n * @see https://w3c.github.io/FileAPI/#dfn-readAsDataURL\n * @param {import('buffer').Blob} blob\n */\n readAsDataURL (blob) {\n webidl.brandCheck(this, FileReader)\n\n webidl.argumentLengthCheck(arguments, 1, { header: 'FileReader.readAsDataURL' })\n\n blob = webidl.converters.Blob(blob, { strict: false })\n\n // The readAsDataURL(blob) method, when invoked, must\n // initiate a read operation for blob with DataURL.\n readOperation(this, blob, 'DataURL')\n }\n\n /**\n * @see https://w3c.github.io/FileAPI/#dfn-abort\n */\n abort () {\n // 1. If this's state is \"empty\" or if this's state is\n // \"done\" set this's result to null and terminate\n // this algorithm.\n if (this[kState] === 'empty' || this[kState] === 'done') {\n this[kResult] = null\n return\n }\n\n // 2. If this's state is \"loading\" set this's state to\n // \"done\" and set this's result to null.\n if (this[kState] === 'loading') {\n this[kState] = 'done'\n this[kResult] = null\n }\n\n // 3. If there are any tasks from this on the file reading\n // task source in an affiliated task queue, then remove\n // those tasks from that task queue.\n this[kAborted] = true\n\n // 4. Terminate the algorithm for the read method being processed.\n // TODO\n\n // 5. Fire a progress event called abort at this.\n fireAProgressEvent('abort', this)\n\n // 6. If this's state is not \"loading\", fire a progress\n // event called loadend at this.\n if (this[kState] !== 'loading') {\n fireAProgressEvent('loadend', this)\n }\n }\n\n /**\n * @see https://w3c.github.io/FileAPI/#dom-filereader-readystate\n */\n get readyState () {\n webidl.brandCheck(this, FileReader)\n\n switch (this[kState]) {\n case 'empty': return this.EMPTY\n case 'loading': return this.LOADING\n case 'done': return this.DONE\n }\n }\n\n /**\n * @see https://w3c.github.io/FileAPI/#dom-filereader-result\n */\n get result () {\n webidl.brandCheck(this, FileReader)\n\n // The result attribute’s getter, when invoked, must return\n // this's result.\n return this[kResult]\n }\n\n /**\n * @see https://w3c.github.io/FileAPI/#dom-filereader-error\n */\n get error () {\n webidl.brandCheck(this, FileReader)\n\n // The error attribute’s getter, when invoked, must return\n // this's error.\n return this[kError]\n }\n\n get onloadend () {\n webidl.brandCheck(this, FileReader)\n\n return this[kEvents].loadend\n }\n\n set onloadend (fn) {\n webidl.brandCheck(this, FileReader)\n\n if (this[kEvents].loadend) {\n this.removeEventListener('loadend', this[kEvents].loadend)\n }\n\n if (typeof fn === 'function') {\n this[kEvents].loadend = fn\n this.addEventListener('loadend', fn)\n } else {\n this[kEvents].loadend = null\n }\n }\n\n get onerror () {\n webidl.brandCheck(this, FileReader)\n\n return this[kEvents].error\n }\n\n set onerror (fn) {\n webidl.brandCheck(this, FileReader)\n\n if (this[kEvents].error) {\n this.removeEventListener('error', this[kEvents].error)\n }\n\n if (typeof fn === 'function') {\n this[kEvents].error = fn\n this.addEventListener('error', fn)\n } else {\n this[kEvents].error = null\n }\n }\n\n get onloadstart () {\n webidl.brandCheck(this, FileReader)\n\n return this[kEvents].loadstart\n }\n\n set onloadstart (fn) {\n webidl.brandCheck(this, FileReader)\n\n if (this[kEvents].loadstart) {\n this.removeEventListener('loadstart', this[kEvents].loadstart)\n }\n\n if (typeof fn === 'function') {\n this[kEvents].loadstart = fn\n this.addEventListener('loadstart', fn)\n } else {\n this[kEvents].loadstart = null\n }\n }\n\n get onprogress () {\n webidl.brandCheck(this, FileReader)\n\n return this[kEvents].progress\n }\n\n set onprogress (fn) {\n webidl.brandCheck(this, FileReader)\n\n if (this[kEvents].progress) {\n this.removeEventListener('progress', this[kEvents].progress)\n }\n\n if (typeof fn === 'function') {\n this[kEvents].progress = fn\n this.addEventListener('progress', fn)\n } else {\n this[kEvents].progress = null\n }\n }\n\n get onload () {\n webidl.brandCheck(this, FileReader)\n\n return this[kEvents].load\n }\n\n set onload (fn) {\n webidl.brandCheck(this, FileReader)\n\n if (this[kEvents].load) {\n this.removeEventListener('load', this[kEvents].load)\n }\n\n if (typeof fn === 'function') {\n this[kEvents].load = fn\n this.addEventListener('load', fn)\n } else {\n this[kEvents].load = null\n }\n }\n\n get onabort () {\n webidl.brandCheck(this, FileReader)\n\n return this[kEvents].abort\n }\n\n set onabort (fn) {\n webidl.brandCheck(this, FileReader)\n\n if (this[kEvents].abort) {\n this.removeEventListener('abort', this[kEvents].abort)\n }\n\n if (typeof fn === 'function') {\n this[kEvents].abort = fn\n this.addEventListener('abort', fn)\n } else {\n this[kEvents].abort = null\n }\n }\n}\n\n// https://w3c.github.io/FileAPI/#dom-filereader-empty\nFileReader.EMPTY = FileReader.prototype.EMPTY = 0\n// https://w3c.github.io/FileAPI/#dom-filereader-loading\nFileReader.LOADING = FileReader.prototype.LOADING = 1\n// https://w3c.github.io/FileAPI/#dom-filereader-done\nFileReader.DONE = FileReader.prototype.DONE = 2\n\nObject.defineProperties(FileReader.prototype, {\n EMPTY: staticPropertyDescriptors,\n LOADING: staticPropertyDescriptors,\n DONE: staticPropertyDescriptors,\n readAsArrayBuffer: kEnumerableProperty,\n readAsBinaryString: kEnumerableProperty,\n readAsText: kEnumerableProperty,\n readAsDataURL: kEnumerableProperty,\n abort: kEnumerableProperty,\n readyState: kEnumerableProperty,\n result: kEnumerableProperty,\n error: kEnumerableProperty,\n onloadstart: kEnumerableProperty,\n onprogress: kEnumerableProperty,\n onload: kEnumerableProperty,\n onabort: kEnumerableProperty,\n onerror: kEnumerableProperty,\n onloadend: kEnumerableProperty,\n [Symbol.toStringTag]: {\n value: 'FileReader',\n writable: false,\n enumerable: false,\n configurable: true\n }\n})\n\nObject.defineProperties(FileReader, {\n EMPTY: staticPropertyDescriptors,\n LOADING: staticPropertyDescriptors,\n DONE: staticPropertyDescriptors\n})\n\nmodule.exports = {\n FileReader\n}\n","'use strict'\n\nconst { webidl } = require('../fetch/webidl')\n\nconst kState = Symbol('ProgressEvent state')\n\n/**\n * @see https://xhr.spec.whatwg.org/#progressevent\n */\nclass ProgressEvent extends Event {\n constructor (type, eventInitDict = {}) {\n type = webidl.converters.DOMString(type)\n eventInitDict = webidl.converters.ProgressEventInit(eventInitDict ?? {})\n\n super(type, eventInitDict)\n\n this[kState] = {\n lengthComputable: eventInitDict.lengthComputable,\n loaded: eventInitDict.loaded,\n total: eventInitDict.total\n }\n }\n\n get lengthComputable () {\n webidl.brandCheck(this, ProgressEvent)\n\n return this[kState].lengthComputable\n }\n\n get loaded () {\n webidl.brandCheck(this, ProgressEvent)\n\n return this[kState].loaded\n }\n\n get total () {\n webidl.brandCheck(this, ProgressEvent)\n\n return this[kState].total\n }\n}\n\nwebidl.converters.ProgressEventInit = webidl.dictionaryConverter([\n {\n key: 'lengthComputable',\n converter: webidl.converters.boolean,\n defaultValue: false\n },\n {\n key: 'loaded',\n converter: webidl.converters['unsigned long long'],\n defaultValue: 0\n },\n {\n key: 'total',\n converter: webidl.converters['unsigned long long'],\n defaultValue: 0\n },\n {\n key: 'bubbles',\n converter: webidl.converters.boolean,\n defaultValue: false\n },\n {\n key: 'cancelable',\n converter: webidl.converters.boolean,\n defaultValue: false\n },\n {\n key: 'composed',\n converter: webidl.converters.boolean,\n defaultValue: false\n }\n])\n\nmodule.exports = {\n ProgressEvent\n}\n","'use strict'\n\nmodule.exports = {\n kState: Symbol('FileReader state'),\n kResult: Symbol('FileReader result'),\n kError: Symbol('FileReader error'),\n kLastProgressEventFired: Symbol('FileReader last progress event fired timestamp'),\n kEvents: Symbol('FileReader events'),\n kAborted: Symbol('FileReader aborted')\n}\n","'use strict'\n\nconst {\n kState,\n kError,\n kResult,\n kAborted,\n kLastProgressEventFired\n} = require('./symbols')\nconst { ProgressEvent } = require('./progressevent')\nconst { getEncoding } = require('./encoding')\nconst { DOMException } = require('../fetch/constants')\nconst { serializeAMimeType, parseMIMEType } = require('../fetch/dataURL')\nconst { types } = require('util')\nconst { StringDecoder } = require('string_decoder')\nconst { btoa } = require('buffer')\n\n/** @type {PropertyDescriptor} */\nconst staticPropertyDescriptors = {\n enumerable: true,\n writable: false,\n configurable: false\n}\n\n/**\n * @see https://w3c.github.io/FileAPI/#readOperation\n * @param {import('./filereader').FileReader} fr\n * @param {import('buffer').Blob} blob\n * @param {string} type\n * @param {string?} encodingName\n */\nfunction readOperation (fr, blob, type, encodingName) {\n // 1. If fr’s state is \"loading\", throw an InvalidStateError\n // DOMException.\n if (fr[kState] === 'loading') {\n throw new DOMException('Invalid state', 'InvalidStateError')\n }\n\n // 2. Set fr’s state to \"loading\".\n fr[kState] = 'loading'\n\n // 3. Set fr’s result to null.\n fr[kResult] = null\n\n // 4. Set fr’s error to null.\n fr[kError] = null\n\n // 5. Let stream be the result of calling get stream on blob.\n /** @type {import('stream/web').ReadableStream} */\n const stream = blob.stream()\n\n // 6. Let reader be the result of getting a reader from stream.\n const reader = stream.getReader()\n\n // 7. Let bytes be an empty byte sequence.\n /** @type {Uint8Array[]} */\n const bytes = []\n\n // 8. Let chunkPromise be the result of reading a chunk from\n // stream with reader.\n let chunkPromise = reader.read()\n\n // 9. Let isFirstChunk be true.\n let isFirstChunk = true\n\n // 10. In parallel, while true:\n // Note: \"In parallel\" just means non-blocking\n // Note 2: readOperation itself cannot be async as double\n // reading the body would then reject the promise, instead\n // of throwing an error.\n ;(async () => {\n while (!fr[kAborted]) {\n // 1. Wait for chunkPromise to be fulfilled or rejected.\n try {\n const { done, value } = await chunkPromise\n\n // 2. If chunkPromise is fulfilled, and isFirstChunk is\n // true, queue a task to fire a progress event called\n // loadstart at fr.\n if (isFirstChunk && !fr[kAborted]) {\n queueMicrotask(() => {\n fireAProgressEvent('loadstart', fr)\n })\n }\n\n // 3. Set isFirstChunk to false.\n isFirstChunk = false\n\n // 4. If chunkPromise is fulfilled with an object whose\n // done property is false and whose value property is\n // a Uint8Array object, run these steps:\n if (!done && types.isUint8Array(value)) {\n // 1. Let bs be the byte sequence represented by the\n // Uint8Array object.\n\n // 2. Append bs to bytes.\n bytes.push(value)\n\n // 3. If roughly 50ms have passed since these steps\n // were last invoked, queue a task to fire a\n // progress event called progress at fr.\n if (\n (\n fr[kLastProgressEventFired] === undefined ||\n Date.now() - fr[kLastProgressEventFired] >= 50\n ) &&\n !fr[kAborted]\n ) {\n fr[kLastProgressEventFired] = Date.now()\n queueMicrotask(() => {\n fireAProgressEvent('progress', fr)\n })\n }\n\n // 4. Set chunkPromise to the result of reading a\n // chunk from stream with reader.\n chunkPromise = reader.read()\n } else if (done) {\n // 5. Otherwise, if chunkPromise is fulfilled with an\n // object whose done property is true, queue a task\n // to run the following steps and abort this algorithm:\n queueMicrotask(() => {\n // 1. Set fr’s state to \"done\".\n fr[kState] = 'done'\n\n // 2. Let result be the result of package data given\n // bytes, type, blob’s type, and encodingName.\n try {\n const result = packageData(bytes, type, blob.type, encodingName)\n\n // 4. Else:\n\n if (fr[kAborted]) {\n return\n }\n\n // 1. Set fr’s result to result.\n fr[kResult] = result\n\n // 2. Fire a progress event called load at the fr.\n fireAProgressEvent('load', fr)\n } catch (error) {\n // 3. If package data threw an exception error:\n\n // 1. Set fr’s error to error.\n fr[kError] = error\n\n // 2. Fire a progress event called error at fr.\n fireAProgressEvent('error', fr)\n }\n\n // 5. If fr’s state is not \"loading\", fire a progress\n // event called loadend at the fr.\n if (fr[kState] !== 'loading') {\n fireAProgressEvent('loadend', fr)\n }\n })\n\n break\n }\n } catch (error) {\n if (fr[kAborted]) {\n return\n }\n\n // 6. Otherwise, if chunkPromise is rejected with an\n // error error, queue a task to run the following\n // steps and abort this algorithm:\n queueMicrotask(() => {\n // 1. Set fr’s state to \"done\".\n fr[kState] = 'done'\n\n // 2. Set fr’s error to error.\n fr[kError] = error\n\n // 3. Fire a progress event called error at fr.\n fireAProgressEvent('error', fr)\n\n // 4. If fr’s state is not \"loading\", fire a progress\n // event called loadend at fr.\n if (fr[kState] !== 'loading') {\n fireAProgressEvent('loadend', fr)\n }\n })\n\n break\n }\n }\n })()\n}\n\n/**\n * @see https://w3c.github.io/FileAPI/#fire-a-progress-event\n * @see https://dom.spec.whatwg.org/#concept-event-fire\n * @param {string} e The name of the event\n * @param {import('./filereader').FileReader} reader\n */\nfunction fireAProgressEvent (e, reader) {\n // The progress event e does not bubble. e.bubbles must be false\n // The progress event e is NOT cancelable. e.cancelable must be false\n const event = new ProgressEvent(e, {\n bubbles: false,\n cancelable: false\n })\n\n reader.dispatchEvent(event)\n}\n\n/**\n * @see https://w3c.github.io/FileAPI/#blob-package-data\n * @param {Uint8Array[]} bytes\n * @param {string} type\n * @param {string?} mimeType\n * @param {string?} encodingName\n */\nfunction packageData (bytes, type, mimeType, encodingName) {\n // 1. A Blob has an associated package data algorithm, given\n // bytes, a type, a optional mimeType, and a optional\n // encodingName, which switches on type and runs the\n // associated steps:\n\n switch (type) {\n case 'DataURL': {\n // 1. Return bytes as a DataURL [RFC2397] subject to\n // the considerations below:\n // * Use mimeType as part of the Data URL if it is\n // available in keeping with the Data URL\n // specification [RFC2397].\n // * If mimeType is not available return a Data URL\n // without a media-type. [RFC2397].\n\n // https://datatracker.ietf.org/doc/html/rfc2397#section-3\n // dataurl := \"data:\" [ mediatype ] [ \";base64\" ] \",\" data\n // mediatype := [ type \"/\" subtype ] *( \";\" parameter )\n // data := *urlchar\n // parameter := attribute \"=\" value\n let dataURL = 'data:'\n\n const parsed = parseMIMEType(mimeType || 'application/octet-stream')\n\n if (parsed !== 'failure') {\n dataURL += serializeAMimeType(parsed)\n }\n\n dataURL += ';base64,'\n\n const decoder = new StringDecoder('latin1')\n\n for (const chunk of bytes) {\n dataURL += btoa(decoder.write(chunk))\n }\n\n dataURL += btoa(decoder.end())\n\n return dataURL\n }\n case 'Text': {\n // 1. Let encoding be failure\n let encoding = 'failure'\n\n // 2. If the encodingName is present, set encoding to the\n // result of getting an encoding from encodingName.\n if (encodingName) {\n encoding = getEncoding(encodingName)\n }\n\n // 3. If encoding is failure, and mimeType is present:\n if (encoding === 'failure' && mimeType) {\n // 1. Let type be the result of parse a MIME type\n // given mimeType.\n const type = parseMIMEType(mimeType)\n\n // 2. If type is not failure, set encoding to the result\n // of getting an encoding from type’s parameters[\"charset\"].\n if (type !== 'failure') {\n encoding = getEncoding(type.parameters.get('charset'))\n }\n }\n\n // 4. If encoding is failure, then set encoding to UTF-8.\n if (encoding === 'failure') {\n encoding = 'UTF-8'\n }\n\n // 5. Decode bytes using fallback encoding encoding, and\n // return the result.\n return decode(bytes, encoding)\n }\n case 'ArrayBuffer': {\n // Return a new ArrayBuffer whose contents are bytes.\n const sequence = combineByteSequences(bytes)\n\n return sequence.buffer\n }\n case 'BinaryString': {\n // Return bytes as a binary string, in which every byte\n // is represented by a code unit of equal value [0..255].\n let binaryString = ''\n\n const decoder = new StringDecoder('latin1')\n\n for (const chunk of bytes) {\n binaryString += decoder.write(chunk)\n }\n\n binaryString += decoder.end()\n\n return binaryString\n }\n }\n}\n\n/**\n * @see https://encoding.spec.whatwg.org/#decode\n * @param {Uint8Array[]} ioQueue\n * @param {string} encoding\n */\nfunction decode (ioQueue, encoding) {\n const bytes = combineByteSequences(ioQueue)\n\n // 1. Let BOMEncoding be the result of BOM sniffing ioQueue.\n const BOMEncoding = BOMSniffing(bytes)\n\n let slice = 0\n\n // 2. If BOMEncoding is non-null:\n if (BOMEncoding !== null) {\n // 1. Set encoding to BOMEncoding.\n encoding = BOMEncoding\n\n // 2. Read three bytes from ioQueue, if BOMEncoding is\n // UTF-8; otherwise read two bytes.\n // (Do nothing with those bytes.)\n slice = BOMEncoding === 'UTF-8' ? 3 : 2\n }\n\n // 3. Process a queue with an instance of encoding’s\n // decoder, ioQueue, output, and \"replacement\".\n\n // 4. Return output.\n\n const sliced = bytes.slice(slice)\n return new TextDecoder(encoding).decode(sliced)\n}\n\n/**\n * @see https://encoding.spec.whatwg.org/#bom-sniff\n * @param {Uint8Array} ioQueue\n */\nfunction BOMSniffing (ioQueue) {\n // 1. Let BOM be the result of peeking 3 bytes from ioQueue,\n // converted to a byte sequence.\n const [a, b, c] = ioQueue\n\n // 2. For each of the rows in the table below, starting with\n // the first one and going down, if BOM starts with the\n // bytes given in the first column, then return the\n // encoding given in the cell in the second column of that\n // row. Otherwise, return null.\n if (a === 0xEF && b === 0xBB && c === 0xBF) {\n return 'UTF-8'\n } else if (a === 0xFE && b === 0xFF) {\n return 'UTF-16BE'\n } else if (a === 0xFF && b === 0xFE) {\n return 'UTF-16LE'\n }\n\n return null\n}\n\n/**\n * @param {Uint8Array[]} sequences\n */\nfunction combineByteSequences (sequences) {\n const size = sequences.reduce((a, b) => {\n return a + b.byteLength\n }, 0)\n\n let offset = 0\n\n return sequences.reduce((a, b) => {\n a.set(b, offset)\n offset += b.byteLength\n return a\n }, new Uint8Array(size))\n}\n\nmodule.exports = {\n staticPropertyDescriptors,\n readOperation,\n fireAProgressEvent\n}\n","'use strict'\n\n// We include a version number for the Dispatcher API. In case of breaking changes,\n// this version number must be increased to avoid conflicts.\nconst globalDispatcher = Symbol.for('undici.globalDispatcher.1')\nconst { InvalidArgumentError } = require('./core/errors')\nconst Agent = require('./agent')\n\nif (getGlobalDispatcher() === undefined) {\n setGlobalDispatcher(new Agent())\n}\n\nfunction setGlobalDispatcher (agent) {\n if (!agent || typeof agent.dispatch !== 'function') {\n throw new InvalidArgumentError('Argument agent must implement Agent')\n }\n Object.defineProperty(globalThis, globalDispatcher, {\n value: agent,\n writable: true,\n enumerable: false,\n configurable: false\n })\n}\n\nfunction getGlobalDispatcher () {\n return globalThis[globalDispatcher]\n}\n\nmodule.exports = {\n setGlobalDispatcher,\n getGlobalDispatcher\n}\n","'use strict'\n\nmodule.exports = class DecoratorHandler {\n constructor (handler) {\n this.handler = handler\n }\n\n onConnect (...args) {\n return this.handler.onConnect(...args)\n }\n\n onError (...args) {\n return this.handler.onError(...args)\n }\n\n onUpgrade (...args) {\n return this.handler.onUpgrade(...args)\n }\n\n onHeaders (...args) {\n return this.handler.onHeaders(...args)\n }\n\n onData (...args) {\n return this.handler.onData(...args)\n }\n\n onComplete (...args) {\n return this.handler.onComplete(...args)\n }\n\n onBodySent (...args) {\n return this.handler.onBodySent(...args)\n }\n}\n","'use strict'\n\nconst util = require('../core/util')\nconst { kBodyUsed } = require('../core/symbols')\nconst assert = require('assert')\nconst { InvalidArgumentError } = require('../core/errors')\nconst EE = require('events')\n\nconst redirectableStatusCodes = [300, 301, 302, 303, 307, 308]\n\nconst kBody = Symbol('body')\n\nclass BodyAsyncIterable {\n constructor (body) {\n this[kBody] = body\n this[kBodyUsed] = false\n }\n\n async * [Symbol.asyncIterator] () {\n assert(!this[kBodyUsed], 'disturbed')\n this[kBodyUsed] = true\n yield * this[kBody]\n }\n}\n\nclass RedirectHandler {\n constructor (dispatch, maxRedirections, opts, handler) {\n if (maxRedirections != null && (!Number.isInteger(maxRedirections) || maxRedirections < 0)) {\n throw new InvalidArgumentError('maxRedirections must be a positive number')\n }\n\n util.validateHandler(handler, opts.method, opts.upgrade)\n\n this.dispatch = dispatch\n this.location = null\n this.abort = null\n this.opts = { ...opts, maxRedirections: 0 } // opts must be a copy\n this.maxRedirections = maxRedirections\n this.handler = handler\n this.history = []\n\n if (util.isStream(this.opts.body)) {\n // TODO (fix): Provide some way for the user to cache the file to e.g. /tmp\n // so that it can be dispatched again?\n // TODO (fix): Do we need 100-expect support to provide a way to do this properly?\n if (util.bodyLength(this.opts.body) === 0) {\n this.opts.body\n .on('data', function () {\n assert(false)\n })\n }\n\n if (typeof this.opts.body.readableDidRead !== 'boolean') {\n this.opts.body[kBodyUsed] = false\n EE.prototype.on.call(this.opts.body, 'data', function () {\n this[kBodyUsed] = true\n })\n }\n } else if (this.opts.body && typeof this.opts.body.pipeTo === 'function') {\n // TODO (fix): We can't access ReadableStream internal state\n // to determine whether or not it has been disturbed. This is just\n // a workaround.\n this.opts.body = new BodyAsyncIterable(this.opts.body)\n } else if (\n this.opts.body &&\n typeof this.opts.body !== 'string' &&\n !ArrayBuffer.isView(this.opts.body) &&\n util.isIterable(this.opts.body)\n ) {\n // TODO: Should we allow re-using iterable if !this.opts.idempotent\n // or through some other flag?\n this.opts.body = new BodyAsyncIterable(this.opts.body)\n }\n }\n\n onConnect (abort) {\n this.abort = abort\n this.handler.onConnect(abort, { history: this.history })\n }\n\n onUpgrade (statusCode, headers, socket) {\n this.handler.onUpgrade(statusCode, headers, socket)\n }\n\n onError (error) {\n this.handler.onError(error)\n }\n\n onHeaders (statusCode, headers, resume, statusText) {\n this.location = this.history.length >= this.maxRedirections || util.isDisturbed(this.opts.body)\n ? null\n : parseLocation(statusCode, headers)\n\n if (this.opts.origin) {\n this.history.push(new URL(this.opts.path, this.opts.origin))\n }\n\n if (!this.location) {\n return this.handler.onHeaders(statusCode, headers, resume, statusText)\n }\n\n const { origin, pathname, search } = util.parseURL(new URL(this.location, this.opts.origin && new URL(this.opts.path, this.opts.origin)))\n const path = search ? `${pathname}${search}` : pathname\n\n // Remove headers referring to the original URL.\n // By default it is Host only, unless it's a 303 (see below), which removes also all Content-* headers.\n // https://tools.ietf.org/html/rfc7231#section-6.4\n this.opts.headers = cleanRequestHeaders(this.opts.headers, statusCode === 303, this.opts.origin !== origin)\n this.opts.path = path\n this.opts.origin = origin\n this.opts.maxRedirections = 0\n this.opts.query = null\n\n // https://tools.ietf.org/html/rfc7231#section-6.4.4\n // In case of HTTP 303, always replace method to be either HEAD or GET\n if (statusCode === 303 && this.opts.method !== 'HEAD') {\n this.opts.method = 'GET'\n this.opts.body = null\n }\n }\n\n onData (chunk) {\n if (this.location) {\n /*\n https://tools.ietf.org/html/rfc7231#section-6.4\n\n TLDR: undici always ignores 3xx response bodies.\n\n Redirection is used to serve the requested resource from another URL, so it is assumes that\n no body is generated (and thus can be ignored). Even though generating a body is not prohibited.\n\n For status 301, 302, 303, 307 and 308 (the latter from RFC 7238), the specs mention that the body usually\n (which means it's optional and not mandated) contain just an hyperlink to the value of\n the Location response header, so the body can be ignored safely.\n\n For status 300, which is \"Multiple Choices\", the spec mentions both generating a Location\n response header AND a response body with the other possible location to follow.\n Since the spec explicitily chooses not to specify a format for such body and leave it to\n servers and browsers implementors, we ignore the body as there is no specified way to eventually parse it.\n */\n } else {\n return this.handler.onData(chunk)\n }\n }\n\n onComplete (trailers) {\n if (this.location) {\n /*\n https://tools.ietf.org/html/rfc7231#section-6.4\n\n TLDR: undici always ignores 3xx response trailers as they are not expected in case of redirections\n and neither are useful if present.\n\n See comment on onData method above for more detailed informations.\n */\n\n this.location = null\n this.abort = null\n\n this.dispatch(this.opts, this)\n } else {\n this.handler.onComplete(trailers)\n }\n }\n\n onBodySent (chunk) {\n if (this.handler.onBodySent) {\n this.handler.onBodySent(chunk)\n }\n }\n}\n\nfunction parseLocation (statusCode, headers) {\n if (redirectableStatusCodes.indexOf(statusCode) === -1) {\n return null\n }\n\n for (let i = 0; i < headers.length; i += 2) {\n if (headers[i].toString().toLowerCase() === 'location') {\n return headers[i + 1]\n }\n }\n}\n\n// https://tools.ietf.org/html/rfc7231#section-6.4.4\nfunction shouldRemoveHeader (header, removeContent, unknownOrigin) {\n return (\n (header.length === 4 && header.toString().toLowerCase() === 'host') ||\n (removeContent && header.toString().toLowerCase().indexOf('content-') === 0) ||\n (unknownOrigin && header.length === 13 && header.toString().toLowerCase() === 'authorization') ||\n (unknownOrigin && header.length === 6 && header.toString().toLowerCase() === 'cookie')\n )\n}\n\n// https://tools.ietf.org/html/rfc7231#section-6.4\nfunction cleanRequestHeaders (headers, removeContent, unknownOrigin) {\n const ret = []\n if (Array.isArray(headers)) {\n for (let i = 0; i < headers.length; i += 2) {\n if (!shouldRemoveHeader(headers[i], removeContent, unknownOrigin)) {\n ret.push(headers[i], headers[i + 1])\n }\n }\n } else if (headers && typeof headers === 'object') {\n for (const key of Object.keys(headers)) {\n if (!shouldRemoveHeader(key, removeContent, unknownOrigin)) {\n ret.push(key, headers[key])\n }\n }\n } else {\n assert(headers == null, 'headers must be an object or an array')\n }\n return ret\n}\n\nmodule.exports = RedirectHandler\n","const assert = require('assert')\n\nconst { kRetryHandlerDefaultRetry } = require('../core/symbols')\nconst { RequestRetryError } = require('../core/errors')\nconst { isDisturbed, parseHeaders, parseRangeHeader } = require('../core/util')\n\nfunction calculateRetryAfterHeader (retryAfter) {\n const current = Date.now()\n const diff = new Date(retryAfter).getTime() - current\n\n return diff\n}\n\nclass RetryHandler {\n constructor (opts, handlers) {\n const { retryOptions, ...dispatchOpts } = opts\n const {\n // Retry scoped\n retry: retryFn,\n maxRetries,\n maxTimeout,\n minTimeout,\n timeoutFactor,\n // Response scoped\n methods,\n errorCodes,\n retryAfter,\n statusCodes\n } = retryOptions ?? {}\n\n this.dispatch = handlers.dispatch\n this.handler = handlers.handler\n this.opts = dispatchOpts\n this.abort = null\n this.aborted = false\n this.retryOpts = {\n retry: retryFn ?? RetryHandler[kRetryHandlerDefaultRetry],\n retryAfter: retryAfter ?? true,\n maxTimeout: maxTimeout ?? 30 * 1000, // 30s,\n timeout: minTimeout ?? 500, // .5s\n timeoutFactor: timeoutFactor ?? 2,\n maxRetries: maxRetries ?? 5,\n // What errors we should retry\n methods: methods ?? ['GET', 'HEAD', 'OPTIONS', 'PUT', 'DELETE', 'TRACE'],\n // Indicates which errors to retry\n statusCodes: statusCodes ?? [500, 502, 503, 504, 429],\n // List of errors to retry\n errorCodes: errorCodes ?? [\n 'ECONNRESET',\n 'ECONNREFUSED',\n 'ENOTFOUND',\n 'ENETDOWN',\n 'ENETUNREACH',\n 'EHOSTDOWN',\n 'EHOSTUNREACH',\n 'EPIPE'\n ]\n }\n\n this.retryCount = 0\n this.start = 0\n this.end = null\n this.etag = null\n this.resume = null\n\n // Handle possible onConnect duplication\n this.handler.onConnect(reason => {\n this.aborted = true\n if (this.abort) {\n this.abort(reason)\n } else {\n this.reason = reason\n }\n })\n }\n\n onRequestSent () {\n if (this.handler.onRequestSent) {\n this.handler.onRequestSent()\n }\n }\n\n onUpgrade (statusCode, headers, socket) {\n if (this.handler.onUpgrade) {\n this.handler.onUpgrade(statusCode, headers, socket)\n }\n }\n\n onConnect (abort) {\n if (this.aborted) {\n abort(this.reason)\n } else {\n this.abort = abort\n }\n }\n\n onBodySent (chunk) {\n if (this.handler.onBodySent) return this.handler.onBodySent(chunk)\n }\n\n static [kRetryHandlerDefaultRetry] (err, { state, opts }, cb) {\n const { statusCode, code, headers } = err\n const { method, retryOptions } = opts\n const {\n maxRetries,\n timeout,\n maxTimeout,\n timeoutFactor,\n statusCodes,\n errorCodes,\n methods\n } = retryOptions\n let { counter, currentTimeout } = state\n\n currentTimeout =\n currentTimeout != null && currentTimeout > 0 ? currentTimeout : timeout\n\n // Any code that is not a Undici's originated and allowed to retry\n if (\n code &&\n code !== 'UND_ERR_REQ_RETRY' &&\n code !== 'UND_ERR_SOCKET' &&\n !errorCodes.includes(code)\n ) {\n cb(err)\n return\n }\n\n // If a set of method are provided and the current method is not in the list\n if (Array.isArray(methods) && !methods.includes(method)) {\n cb(err)\n return\n }\n\n // If a set of status code are provided and the current status code is not in the list\n if (\n statusCode != null &&\n Array.isArray(statusCodes) &&\n !statusCodes.includes(statusCode)\n ) {\n cb(err)\n return\n }\n\n // If we reached the max number of retries\n if (counter > maxRetries) {\n cb(err)\n return\n }\n\n let retryAfterHeader = headers != null && headers['retry-after']\n if (retryAfterHeader) {\n retryAfterHeader = Number(retryAfterHeader)\n retryAfterHeader = isNaN(retryAfterHeader)\n ? calculateRetryAfterHeader(retryAfterHeader)\n : retryAfterHeader * 1e3 // Retry-After is in seconds\n }\n\n const retryTimeout =\n retryAfterHeader > 0\n ? Math.min(retryAfterHeader, maxTimeout)\n : Math.min(currentTimeout * timeoutFactor ** counter, maxTimeout)\n\n state.currentTimeout = retryTimeout\n\n setTimeout(() => cb(null), retryTimeout)\n }\n\n onHeaders (statusCode, rawHeaders, resume, statusMessage) {\n const headers = parseHeaders(rawHeaders)\n\n this.retryCount += 1\n\n if (statusCode >= 300) {\n this.abort(\n new RequestRetryError('Request failed', statusCode, {\n headers,\n count: this.retryCount\n })\n )\n return false\n }\n\n // Checkpoint for resume from where we left it\n if (this.resume != null) {\n this.resume = null\n\n if (statusCode !== 206) {\n return true\n }\n\n const contentRange = parseRangeHeader(headers['content-range'])\n // If no content range\n if (!contentRange) {\n this.abort(\n new RequestRetryError('Content-Range mismatch', statusCode, {\n headers,\n count: this.retryCount\n })\n )\n return false\n }\n\n // Let's start with a weak etag check\n if (this.etag != null && this.etag !== headers.etag) {\n this.abort(\n new RequestRetryError('ETag mismatch', statusCode, {\n headers,\n count: this.retryCount\n })\n )\n return false\n }\n\n const { start, size, end = size } = contentRange\n\n assert(this.start === start, 'content-range mismatch')\n assert(this.end == null || this.end === end, 'content-range mismatch')\n\n this.resume = resume\n return true\n }\n\n if (this.end == null) {\n if (statusCode === 206) {\n // First time we receive 206\n const range = parseRangeHeader(headers['content-range'])\n\n if (range == null) {\n return this.handler.onHeaders(\n statusCode,\n rawHeaders,\n resume,\n statusMessage\n )\n }\n\n const { start, size, end = size } = range\n\n assert(\n start != null && Number.isFinite(start) && this.start !== start,\n 'content-range mismatch'\n )\n assert(Number.isFinite(start))\n assert(\n end != null && Number.isFinite(end) && this.end !== end,\n 'invalid content-length'\n )\n\n this.start = start\n this.end = end\n }\n\n // We make our best to checkpoint the body for further range headers\n if (this.end == null) {\n const contentLength = headers['content-length']\n this.end = contentLength != null ? Number(contentLength) : null\n }\n\n assert(Number.isFinite(this.start))\n assert(\n this.end == null || Number.isFinite(this.end),\n 'invalid content-length'\n )\n\n this.resume = resume\n this.etag = headers.etag != null ? headers.etag : null\n\n return this.handler.onHeaders(\n statusCode,\n rawHeaders,\n resume,\n statusMessage\n )\n }\n\n const err = new RequestRetryError('Request failed', statusCode, {\n headers,\n count: this.retryCount\n })\n\n this.abort(err)\n\n return false\n }\n\n onData (chunk) {\n this.start += chunk.length\n\n return this.handler.onData(chunk)\n }\n\n onComplete (rawTrailers) {\n this.retryCount = 0\n return this.handler.onComplete(rawTrailers)\n }\n\n onError (err) {\n if (this.aborted || isDisturbed(this.opts.body)) {\n return this.handler.onError(err)\n }\n\n this.retryOpts.retry(\n err,\n {\n state: { counter: this.retryCount++, currentTimeout: this.retryAfter },\n opts: { retryOptions: this.retryOpts, ...this.opts }\n },\n onRetry.bind(this)\n )\n\n function onRetry (err) {\n if (err != null || this.aborted || isDisturbed(this.opts.body)) {\n return this.handler.onError(err)\n }\n\n if (this.start !== 0) {\n this.opts = {\n ...this.opts,\n headers: {\n ...this.opts.headers,\n range: `bytes=${this.start}-${this.end ?? ''}`\n }\n }\n }\n\n try {\n this.dispatch(this.opts, this)\n } catch (err) {\n this.handler.onError(err)\n }\n }\n }\n}\n\nmodule.exports = RetryHandler\n","'use strict'\n\nconst RedirectHandler = require('../handler/RedirectHandler')\n\nfunction createRedirectInterceptor ({ maxRedirections: defaultMaxRedirections }) {\n return (dispatch) => {\n return function Intercept (opts, handler) {\n const { maxRedirections = defaultMaxRedirections } = opts\n\n if (!maxRedirections) {\n return dispatch(opts, handler)\n }\n\n const redirectHandler = new RedirectHandler(dispatch, maxRedirections, opts, handler)\n opts = { ...opts, maxRedirections: 0 } // Stop sub dispatcher from also redirecting.\n return dispatch(opts, redirectHandler)\n }\n }\n}\n\nmodule.exports = createRedirectInterceptor\n","\"use strict\";\nObject.defineProperty(exports, \"__esModule\", { value: true });\nexports.SPECIAL_HEADERS = exports.HEADER_STATE = exports.MINOR = exports.MAJOR = exports.CONNECTION_TOKEN_CHARS = exports.HEADER_CHARS = exports.TOKEN = exports.STRICT_TOKEN = exports.HEX = exports.URL_CHAR = exports.STRICT_URL_CHAR = exports.USERINFO_CHARS = exports.MARK = exports.ALPHANUM = exports.NUM = exports.HEX_MAP = exports.NUM_MAP = exports.ALPHA = exports.FINISH = exports.H_METHOD_MAP = exports.METHOD_MAP = exports.METHODS_RTSP = exports.METHODS_ICE = exports.METHODS_HTTP = exports.METHODS = exports.LENIENT_FLAGS = exports.FLAGS = exports.TYPE = exports.ERROR = void 0;\nconst utils_1 = require(\"./utils\");\n// C headers\nvar ERROR;\n(function (ERROR) {\n ERROR[ERROR[\"OK\"] = 0] = \"OK\";\n ERROR[ERROR[\"INTERNAL\"] = 1] = \"INTERNAL\";\n ERROR[ERROR[\"STRICT\"] = 2] = \"STRICT\";\n ERROR[ERROR[\"LF_EXPECTED\"] = 3] = \"LF_EXPECTED\";\n ERROR[ERROR[\"UNEXPECTED_CONTENT_LENGTH\"] = 4] = \"UNEXPECTED_CONTENT_LENGTH\";\n ERROR[ERROR[\"CLOSED_CONNECTION\"] = 5] = \"CLOSED_CONNECTION\";\n ERROR[ERROR[\"INVALID_METHOD\"] = 6] = \"INVALID_METHOD\";\n ERROR[ERROR[\"INVALID_URL\"] = 7] = \"INVALID_URL\";\n ERROR[ERROR[\"INVALID_CONSTANT\"] = 8] = \"INVALID_CONSTANT\";\n ERROR[ERROR[\"INVALID_VERSION\"] = 9] = \"INVALID_VERSION\";\n ERROR[ERROR[\"INVALID_HEADER_TOKEN\"] = 10] = \"INVALID_HEADER_TOKEN\";\n ERROR[ERROR[\"INVALID_CONTENT_LENGTH\"] = 11] = \"INVALID_CONTENT_LENGTH\";\n ERROR[ERROR[\"INVALID_CHUNK_SIZE\"] = 12] = \"INVALID_CHUNK_SIZE\";\n ERROR[ERROR[\"INVALID_STATUS\"] = 13] = \"INVALID_STATUS\";\n ERROR[ERROR[\"INVALID_EOF_STATE\"] = 14] = \"INVALID_EOF_STATE\";\n ERROR[ERROR[\"INVALID_TRANSFER_ENCODING\"] = 15] = \"INVALID_TRANSFER_ENCODING\";\n ERROR[ERROR[\"CB_MESSAGE_BEGIN\"] = 16] = \"CB_MESSAGE_BEGIN\";\n ERROR[ERROR[\"CB_HEADERS_COMPLETE\"] = 17] = \"CB_HEADERS_COMPLETE\";\n ERROR[ERROR[\"CB_MESSAGE_COMPLETE\"] = 18] = \"CB_MESSAGE_COMPLETE\";\n ERROR[ERROR[\"CB_CHUNK_HEADER\"] = 19] = \"CB_CHUNK_HEADER\";\n ERROR[ERROR[\"CB_CHUNK_COMPLETE\"] = 20] = \"CB_CHUNK_COMPLETE\";\n ERROR[ERROR[\"PAUSED\"] = 21] = \"PAUSED\";\n ERROR[ERROR[\"PAUSED_UPGRADE\"] = 22] = \"PAUSED_UPGRADE\";\n ERROR[ERROR[\"PAUSED_H2_UPGRADE\"] = 23] = \"PAUSED_H2_UPGRADE\";\n ERROR[ERROR[\"USER\"] = 24] = \"USER\";\n})(ERROR = exports.ERROR || (exports.ERROR = {}));\nvar TYPE;\n(function (TYPE) {\n TYPE[TYPE[\"BOTH\"] = 0] = \"BOTH\";\n TYPE[TYPE[\"REQUEST\"] = 1] = \"REQUEST\";\n TYPE[TYPE[\"RESPONSE\"] = 2] = \"RESPONSE\";\n})(TYPE = exports.TYPE || (exports.TYPE = {}));\nvar FLAGS;\n(function (FLAGS) {\n FLAGS[FLAGS[\"CONNECTION_KEEP_ALIVE\"] = 1] = \"CONNECTION_KEEP_ALIVE\";\n FLAGS[FLAGS[\"CONNECTION_CLOSE\"] = 2] = \"CONNECTION_CLOSE\";\n FLAGS[FLAGS[\"CONNECTION_UPGRADE\"] = 4] = \"CONNECTION_UPGRADE\";\n FLAGS[FLAGS[\"CHUNKED\"] = 8] = \"CHUNKED\";\n FLAGS[FLAGS[\"UPGRADE\"] = 16] = \"UPGRADE\";\n FLAGS[FLAGS[\"CONTENT_LENGTH\"] = 32] = \"CONTENT_LENGTH\";\n FLAGS[FLAGS[\"SKIPBODY\"] = 64] = \"SKIPBODY\";\n FLAGS[FLAGS[\"TRAILING\"] = 128] = \"TRAILING\";\n // 1 << 8 is unused\n FLAGS[FLAGS[\"TRANSFER_ENCODING\"] = 512] = \"TRANSFER_ENCODING\";\n})(FLAGS = exports.FLAGS || (exports.FLAGS = {}));\nvar LENIENT_FLAGS;\n(function (LENIENT_FLAGS) {\n LENIENT_FLAGS[LENIENT_FLAGS[\"HEADERS\"] = 1] = \"HEADERS\";\n LENIENT_FLAGS[LENIENT_FLAGS[\"CHUNKED_LENGTH\"] = 2] = \"CHUNKED_LENGTH\";\n LENIENT_FLAGS[LENIENT_FLAGS[\"KEEP_ALIVE\"] = 4] = \"KEEP_ALIVE\";\n})(LENIENT_FLAGS = exports.LENIENT_FLAGS || (exports.LENIENT_FLAGS = {}));\nvar METHODS;\n(function (METHODS) {\n METHODS[METHODS[\"DELETE\"] = 0] = \"DELETE\";\n METHODS[METHODS[\"GET\"] = 1] = \"GET\";\n METHODS[METHODS[\"HEAD\"] = 2] = \"HEAD\";\n METHODS[METHODS[\"POST\"] = 3] = \"POST\";\n METHODS[METHODS[\"PUT\"] = 4] = \"PUT\";\n /* pathological */\n METHODS[METHODS[\"CONNECT\"] = 5] = \"CONNECT\";\n METHODS[METHODS[\"OPTIONS\"] = 6] = \"OPTIONS\";\n METHODS[METHODS[\"TRACE\"] = 7] = \"TRACE\";\n /* WebDAV */\n METHODS[METHODS[\"COPY\"] = 8] = \"COPY\";\n METHODS[METHODS[\"LOCK\"] = 9] = \"LOCK\";\n METHODS[METHODS[\"MKCOL\"] = 10] = \"MKCOL\";\n METHODS[METHODS[\"MOVE\"] = 11] = \"MOVE\";\n METHODS[METHODS[\"PROPFIND\"] = 12] = \"PROPFIND\";\n METHODS[METHODS[\"PROPPATCH\"] = 13] = \"PROPPATCH\";\n METHODS[METHODS[\"SEARCH\"] = 14] = \"SEARCH\";\n METHODS[METHODS[\"UNLOCK\"] = 15] = \"UNLOCK\";\n METHODS[METHODS[\"BIND\"] = 16] = \"BIND\";\n METHODS[METHODS[\"REBIND\"] = 17] = \"REBIND\";\n METHODS[METHODS[\"UNBIND\"] = 18] = \"UNBIND\";\n METHODS[METHODS[\"ACL\"] = 19] = \"ACL\";\n /* subversion */\n METHODS[METHODS[\"REPORT\"] = 20] = \"REPORT\";\n METHODS[METHODS[\"MKACTIVITY\"] = 21] = \"MKACTIVITY\";\n METHODS[METHODS[\"CHECKOUT\"] = 22] = \"CHECKOUT\";\n METHODS[METHODS[\"MERGE\"] = 23] = \"MERGE\";\n /* upnp */\n METHODS[METHODS[\"M-SEARCH\"] = 24] = \"M-SEARCH\";\n METHODS[METHODS[\"NOTIFY\"] = 25] = \"NOTIFY\";\n METHODS[METHODS[\"SUBSCRIBE\"] = 26] = \"SUBSCRIBE\";\n METHODS[METHODS[\"UNSUBSCRIBE\"] = 27] = \"UNSUBSCRIBE\";\n /* RFC-5789 */\n METHODS[METHODS[\"PATCH\"] = 28] = \"PATCH\";\n METHODS[METHODS[\"PURGE\"] = 29] = \"PURGE\";\n /* CalDAV */\n METHODS[METHODS[\"MKCALENDAR\"] = 30] = \"MKCALENDAR\";\n /* RFC-2068, section 19.6.1.2 */\n METHODS[METHODS[\"LINK\"] = 31] = \"LINK\";\n METHODS[METHODS[\"UNLINK\"] = 32] = \"UNLINK\";\n /* icecast */\n METHODS[METHODS[\"SOURCE\"] = 33] = \"SOURCE\";\n /* RFC-7540, section 11.6 */\n METHODS[METHODS[\"PRI\"] = 34] = \"PRI\";\n /* RFC-2326 RTSP */\n METHODS[METHODS[\"DESCRIBE\"] = 35] = \"DESCRIBE\";\n METHODS[METHODS[\"ANNOUNCE\"] = 36] = \"ANNOUNCE\";\n METHODS[METHODS[\"SETUP\"] = 37] = \"SETUP\";\n METHODS[METHODS[\"PLAY\"] = 38] = \"PLAY\";\n METHODS[METHODS[\"PAUSE\"] = 39] = \"PAUSE\";\n METHODS[METHODS[\"TEARDOWN\"] = 40] = \"TEARDOWN\";\n METHODS[METHODS[\"GET_PARAMETER\"] = 41] = \"GET_PARAMETER\";\n METHODS[METHODS[\"SET_PARAMETER\"] = 42] = \"SET_PARAMETER\";\n METHODS[METHODS[\"REDIRECT\"] = 43] = \"REDIRECT\";\n METHODS[METHODS[\"RECORD\"] = 44] = \"RECORD\";\n /* RAOP */\n METHODS[METHODS[\"FLUSH\"] = 45] = \"FLUSH\";\n})(METHODS = exports.METHODS || (exports.METHODS = {}));\nexports.METHODS_HTTP = [\n METHODS.DELETE,\n METHODS.GET,\n METHODS.HEAD,\n METHODS.POST,\n METHODS.PUT,\n METHODS.CONNECT,\n METHODS.OPTIONS,\n METHODS.TRACE,\n METHODS.COPY,\n METHODS.LOCK,\n METHODS.MKCOL,\n METHODS.MOVE,\n METHODS.PROPFIND,\n METHODS.PROPPATCH,\n METHODS.SEARCH,\n METHODS.UNLOCK,\n METHODS.BIND,\n METHODS.REBIND,\n METHODS.UNBIND,\n METHODS.ACL,\n METHODS.REPORT,\n METHODS.MKACTIVITY,\n METHODS.CHECKOUT,\n METHODS.MERGE,\n METHODS['M-SEARCH'],\n METHODS.NOTIFY,\n METHODS.SUBSCRIBE,\n METHODS.UNSUBSCRIBE,\n METHODS.PATCH,\n METHODS.PURGE,\n METHODS.MKCALENDAR,\n METHODS.LINK,\n METHODS.UNLINK,\n METHODS.PRI,\n // TODO(indutny): should we allow it with HTTP?\n METHODS.SOURCE,\n];\nexports.METHODS_ICE = [\n METHODS.SOURCE,\n];\nexports.METHODS_RTSP = [\n METHODS.OPTIONS,\n METHODS.DESCRIBE,\n METHODS.ANNOUNCE,\n METHODS.SETUP,\n METHODS.PLAY,\n METHODS.PAUSE,\n METHODS.TEARDOWN,\n METHODS.GET_PARAMETER,\n METHODS.SET_PARAMETER,\n METHODS.REDIRECT,\n METHODS.RECORD,\n METHODS.FLUSH,\n // For AirPlay\n METHODS.GET,\n METHODS.POST,\n];\nexports.METHOD_MAP = utils_1.enumToMap(METHODS);\nexports.H_METHOD_MAP = {};\nObject.keys(exports.METHOD_MAP).forEach((key) => {\n if (/^H/.test(key)) {\n exports.H_METHOD_MAP[key] = exports.METHOD_MAP[key];\n }\n});\nvar FINISH;\n(function (FINISH) {\n FINISH[FINISH[\"SAFE\"] = 0] = \"SAFE\";\n FINISH[FINISH[\"SAFE_WITH_CB\"] = 1] = \"SAFE_WITH_CB\";\n FINISH[FINISH[\"UNSAFE\"] = 2] = \"UNSAFE\";\n})(FINISH = exports.FINISH || (exports.FINISH = {}));\nexports.ALPHA = [];\nfor (let i = 'A'.charCodeAt(0); i <= 'Z'.charCodeAt(0); i++) {\n // Upper case\n exports.ALPHA.push(String.fromCharCode(i));\n // Lower case\n exports.ALPHA.push(String.fromCharCode(i + 0x20));\n}\nexports.NUM_MAP = {\n 0: 0, 1: 1, 2: 2, 3: 3, 4: 4,\n 5: 5, 6: 6, 7: 7, 8: 8, 9: 9,\n};\nexports.HEX_MAP = {\n 0: 0, 1: 1, 2: 2, 3: 3, 4: 4,\n 5: 5, 6: 6, 7: 7, 8: 8, 9: 9,\n A: 0XA, B: 0XB, C: 0XC, D: 0XD, E: 0XE, F: 0XF,\n a: 0xa, b: 0xb, c: 0xc, d: 0xd, e: 0xe, f: 0xf,\n};\nexports.NUM = [\n '0', '1', '2', '3', '4', '5', '6', '7', '8', '9',\n];\nexports.ALPHANUM = exports.ALPHA.concat(exports.NUM);\nexports.MARK = ['-', '_', '.', '!', '~', '*', '\\'', '(', ')'];\nexports.USERINFO_CHARS = exports.ALPHANUM\n .concat(exports.MARK)\n .concat(['%', ';', ':', '&', '=', '+', '$', ',']);\n// TODO(indutny): use RFC\nexports.STRICT_URL_CHAR = [\n '!', '\"', '$', '%', '&', '\\'',\n '(', ')', '*', '+', ',', '-', '.', '/',\n ':', ';', '<', '=', '>',\n '@', '[', '\\\\', ']', '^', '_',\n '`',\n '{', '|', '}', '~',\n].concat(exports.ALPHANUM);\nexports.URL_CHAR = exports.STRICT_URL_CHAR\n .concat(['\\t', '\\f']);\n// All characters with 0x80 bit set to 1\nfor (let i = 0x80; i <= 0xff; i++) {\n exports.URL_CHAR.push(i);\n}\nexports.HEX = exports.NUM.concat(['a', 'b', 'c', 'd', 'e', 'f', 'A', 'B', 'C', 'D', 'E', 'F']);\n/* Tokens as defined by rfc 2616. Also lowercases them.\n * token = 1*\n * separators = \"(\" | \")\" | \"<\" | \">\" | \"@\"\n * | \",\" | \";\" | \":\" | \"\\\" | <\">\n * | \"/\" | \"[\" | \"]\" | \"?\" | \"=\"\n * | \"{\" | \"}\" | SP | HT\n */\nexports.STRICT_TOKEN = [\n '!', '#', '$', '%', '&', '\\'',\n '*', '+', '-', '.',\n '^', '_', '`',\n '|', '~',\n].concat(exports.ALPHANUM);\nexports.TOKEN = exports.STRICT_TOKEN.concat([' ']);\n/*\n * Verify that a char is a valid visible (printable) US-ASCII\n * character or %x80-FF\n */\nexports.HEADER_CHARS = ['\\t'];\nfor (let i = 32; i <= 255; i++) {\n if (i !== 127) {\n exports.HEADER_CHARS.push(i);\n }\n}\n// ',' = \\x44\nexports.CONNECTION_TOKEN_CHARS = exports.HEADER_CHARS.filter((c) => c !== 44);\nexports.MAJOR = exports.NUM_MAP;\nexports.MINOR = exports.MAJOR;\nvar HEADER_STATE;\n(function (HEADER_STATE) {\n HEADER_STATE[HEADER_STATE[\"GENERAL\"] = 0] = \"GENERAL\";\n HEADER_STATE[HEADER_STATE[\"CONNECTION\"] = 1] = \"CONNECTION\";\n HEADER_STATE[HEADER_STATE[\"CONTENT_LENGTH\"] = 2] = \"CONTENT_LENGTH\";\n HEADER_STATE[HEADER_STATE[\"TRANSFER_ENCODING\"] = 3] = \"TRANSFER_ENCODING\";\n HEADER_STATE[HEADER_STATE[\"UPGRADE\"] = 4] = \"UPGRADE\";\n HEADER_STATE[HEADER_STATE[\"CONNECTION_KEEP_ALIVE\"] = 5] = \"CONNECTION_KEEP_ALIVE\";\n HEADER_STATE[HEADER_STATE[\"CONNECTION_CLOSE\"] = 6] = \"CONNECTION_CLOSE\";\n HEADER_STATE[HEADER_STATE[\"CONNECTION_UPGRADE\"] = 7] = \"CONNECTION_UPGRADE\";\n HEADER_STATE[HEADER_STATE[\"TRANSFER_ENCODING_CHUNKED\"] = 8] = \"TRANSFER_ENCODING_CHUNKED\";\n})(HEADER_STATE = exports.HEADER_STATE || (exports.HEADER_STATE = {}));\nexports.SPECIAL_HEADERS = {\n 'connection': HEADER_STATE.CONNECTION,\n 'content-length': HEADER_STATE.CONTENT_LENGTH,\n 'proxy-connection': HEADER_STATE.CONNECTION,\n 'transfer-encoding': HEADER_STATE.TRANSFER_ENCODING,\n 'upgrade': HEADER_STATE.UPGRADE,\n};\n//# sourceMappingURL=constants.js.map","module.exports = 'AGFzbQEAAAABMAhgAX8Bf2ADf39/AX9gBH9/f38Bf2AAAGADf39/AGABfwBgAn9/AGAGf39/f39/AALLAQgDZW52GHdhc21fb25faGVhZGVyc19jb21wbGV0ZQACA2VudhV3YXNtX29uX21lc3NhZ2VfYmVnaW4AAANlbnYLd2FzbV9vbl91cmwAAQNlbnYOd2FzbV9vbl9zdGF0dXMAAQNlbnYUd2FzbV9vbl9oZWFkZXJfZmllbGQAAQNlbnYUd2FzbV9vbl9oZWFkZXJfdmFsdWUAAQNlbnYMd2FzbV9vbl9ib2R5AAEDZW52GHdhc21fb25fbWVzc2FnZV9jb21wbGV0ZQAAA0ZFAwMEAAAFAAAAAAAABQEFAAUFBQAABgAAAAAGBgYGAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQABAAABAQcAAAUFAwABBAUBcAESEgUDAQACBggBfwFBgNQECwfRBSIGbWVtb3J5AgALX2luaXRpYWxpemUACRlfX2luZGlyZWN0X2Z1bmN0aW9uX3RhYmxlAQALbGxodHRwX2luaXQAChhsbGh0dHBfc2hvdWxkX2tlZXBfYWxpdmUAQQxsbGh0dHBfYWxsb2MADAZtYWxsb2MARgtsbGh0dHBfZnJlZQANBGZyZWUASA9sbGh0dHBfZ2V0X3R5cGUADhVsbGh0dHBfZ2V0X2h0dHBfbWFqb3IADxVsbGh0dHBfZ2V0X2h0dHBfbWlub3IAEBFsbGh0dHBfZ2V0X21ldGhvZAARFmxsaHR0cF9nZXRfc3RhdHVzX2NvZGUAEhJsbGh0dHBfZ2V0X3VwZ3JhZGUAEwxsbGh0dHBfcmVzZXQAFA5sbGh0dHBfZXhlY3V0ZQAVFGxsaHR0cF9zZXR0aW5nc19pbml0ABYNbGxodHRwX2ZpbmlzaAAXDGxsaHR0cF9wYXVzZQAYDWxsaHR0cF9yZXN1bWUAGRtsbGh0dHBfcmVzdW1lX2FmdGVyX3VwZ3JhZGUAGhBsbGh0dHBfZ2V0X2Vycm5vABsXbGxodHRwX2dldF9lcnJvcl9yZWFzb24AHBdsbGh0dHBfc2V0X2Vycm9yX3JlYXNvbgAdFGxsaHR0cF9nZXRfZXJyb3JfcG9zAB4RbGxodHRwX2Vycm5vX25hbWUAHxJsbGh0dHBfbWV0aG9kX25hbWUAIBJs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ADcDACAAQShqQgA3AwAgAEEgakIANwMAIABBEGpCADcDACAAQQhqQgA3AwAgAEHdATYCHEEAC3sBAX8CQCAAKAIMIgMNAAJAIAAoAgRFDQAgACABNgIECwJAIAAgASACEMSAgIAAIgMNACAAKAIMDwsgACADNgIcQQAhAyAAKAIEIgFFDQAgACABIAIgACgCCBGBgICAAAAiAUUNACAAIAI2AhQgACABNgIMIAEhAwsgAwvk8wEDDn8DfgR/I4CAgIAAQRBrIgMkgICAgAAgASEEIAEhBSABIQYgASEHIAEhCCABIQkgASEKIAEhCyABIQwgASENIAEhDiABIQ8CQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkAgACgCHCIQQX9qDt0B2gEB2QECAwQFBgcICQoLDA0O2AEPENcBERLWARMUFRYXGBkaG+AB3wEcHR7VAR8gISIjJCXUASYnKCkqKyzTAdIBLS7RAdABLzAxMjM0NTY3ODk6Ozw9Pj9AQUJDREVG2wFHSElKzwHOAUvNAUzMAU1OT1BRUlNUVVZXWFlaW1xdXl9gYWJjZGVmZ2hpamtsbW5vcHFyc3R1dnd4eXp7fH1+f4ABgQGCAYMBhAGFAYYBhwGIAYkB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QAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkAC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FCAAIBA2AgxBACEQDLIBCyAAKAIEIRAgAEEANgIEAkAgACAQIAEQp4CAgAAiEA0AIAEhAQxNCyAAQdMANgIcIAAgATYCFCAAIBA2AgxBACEQDLEBCyAAKAIEIRAgAEEANgIEAkAgACAQIAEQp4CAgAAiEA0AIAEhAQxRCyAAQeUANgIcIAAgATYCFCAAIBA2AgxBACEQDLABCyAAQQA2AhwgACABNgIUIABBxoqAgAA2AhAgAEEHNgIMQQAhEAyvAQsgACgCBCEQIABBADYCBAJAIAAgECABEKeAgIAAIhANACABIQEMSQsgAEHSADYCHCAAIAE2AhQgACAQNgIMQQAhEAyuAQsgACgCBCEQIABBADYCBAJAIAAgECABEKeAgIAAIhANACABIQEMSQsgAEHTADYCHCAAIAE2AhQgACAQNgIMQQAhEAytAQsgACgCBCEQIABBADYCBAJAIAAgECABEKeAgIAAIhANACABIQEMTQsgAEHlADYCHCAAIAE2AhQgACAQNgIMQQAhEAysAQsgAEEANgIcIAAgATYCFCAAQdyIgIAANgIQIABBBzYCDEEAIRAMqwELIBBBP0cNASABQQFqIQELQQUhEAyQAQtBACEQIABBADYCHCAAIAE2AhQgAEH9koCAADYCECAAQQc2AgwMqAELIAAoAgQhECAAQQA2AgQCQCAAIBAgARCngICAACIQDQAgASEBDEILIABB0gA2AhwgACABNgIUIAAgEDYCDEEAIRAMpwELIAAoAgQhECAAQQA2AgQCQCAAIBAgARCngICAACIQDQAgASEBDEILIABB0wA2AhwgACABNgIUIAAgEDYCDEEAIRAMpgELIAAoAgQhECAAQQA2AgQCQCAAIBAgARCngICAACIQDQAgASEBDEYLIABB5QA2AhwgACABNgIUIAAgEDYCDEEAIRAMpQELIAAoAgQhASAAQQA2AgQCQCAAIAEgFBCngICAACIBDQAgFCEBDD8LIABB0gA2AhwgACAUNgIUIAAgATYCDEEAIRAMpAELIAAoAgQhASAAQQA2AgQCQCAAIAEgFBCngICAACIBDQAgFCEBDD8LIABB0wA2AhwgACAUNgIUIAAgATYCDEEAIRAMowELIAAoAgQhASAAQQA2AgQCQCAAIAEgFBCngICAACIBDQAgFCEBDEMLIABB5QA2AhwgACAU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YWdlX2JlZ2luYCBjYWxsYmFjayBlcnJvcgBgb25fY2h1bmtfZXh0ZW5zaW9uX3ZhbHVlYCBjYWxsYmFjayBlcnJvcgBgb25fc3RhdHVzX2NvbXBsZXRlYCBjYWxsYmFjayBlcnJvcgBgb25fdmVyc2lvbl9jb21wbGV0ZWAgY2FsbGJhY2sgZXJyb3IAYG9uX3VybF9jb21wbGV0ZWAgY2FsbGJhY2sgZXJyb3IAYG9uX2NodW5rX2NvbXBsZXRlYCBjYWxsYmFjayBlcnJvcgBgb25faGVhZGVyX3ZhbHVlX2NvbXBsZXRlYCBjYWxsYmFjayBlcnJvcgBgb25fbWVzc2FnZV9jb21wbGV0ZWAgY2FsbGJhY2sgZXJyb3IAYG9uX21ldGhvZF9jb21wbGV0ZWAgY2FsbGJhY2sgZXJyb3IAYG9uX2hlYWRlcl9maWVsZF9jb21wbGV0ZWAgY2FsbGJhY2sgZXJyb3IAYG9uX2NodW5rX2V4dGVuc2lvbl9uYW1lYCBjYWxsYmFjayBlcnJvcgBVbmV4cGVjdGVkIGNoYXIgaW4gdXJsIHNlcnZlcgBJbnZhbGlkIGhlYWRlciB2YWx1ZSBjaGFyAEludmFsaWQgaGVhZGVyIGZpZWxkIGNoYXIAU3BhbiBjYWxsYmFjayBlcnJvciBpbiBvbl92ZXJzaW9uAEludmFsaWQgbWlub3IgdmVyc2lvbgBJbnZhbGlkIG1ham9yIHZlcnNpb24ARXhwZWN0ZWQgc3BhY2UgYWZ0ZXIgdmVyc2lvbgBFeHBlY3RlZCBDUkxGIGFmdGVyIHZlcnNpb24ASW52YWxpZCBIVFRQIHZlcnNpb24ASW52YWxpZCBoZWFkZXIgdG9rZW4AU3BhbiBjYWxsYmFjayBlcnJvciBpbiBvbl91cmwASW52YWxpZCBjaGFyYWN0ZXJzIGluIHVybABVbmV4cGVjdGVkIHN0YXJ0IGNoYXIgaW4gdXJsAERvdWJsZSBAIGluIHVybABFbXB0eSBDb250ZW50LUxlbmd0aABJbnZhbGlkIGNoYXJhY3RlciBpbiBDb250ZW50LUxlbmd0aABEdXBsaWNhdGUgQ29udGVudC1MZW5ndGgASW52YWxpZCBjaGFyIGluIHVybCBwYXRoAENvbnRlbnQtTGVuZ3RoIGNhbid0IGJlIHByZXNlbnQgd2l0aCBUcmFuc2Zlci1FbmNvZGluZwBJbnZhbGlkIGNoYXJhY3RlciBpbiBjaHVuayBzaXplAFNwYW4gY2FsbGJhY2sgZXJyb3IgaW4gb25faGVhZGVyX3ZhbHVlAFNwYW4gY2FsbGJhY2sgZXJyb3IgaW4gb25fY2h1bmtfZXh0ZW5zaW9uX3ZhbHVlAEludmFsaWQgY2hhcmFjdGVyIGluIGNodW5rIGV4dGVuc2lvbnMgdmFsdWUATWlzc2luZyBleHBlY3RlZCBMRiBhZnRlciBoZWFkZXIgdmFsdWUASW52YWxpZCBgVHJhbnNmZXItRW5jb2RpbmdgIGhlYWRlciB2YWx1ZQBJbnZhbGlkIGNoYXJhY3RlciBpbiBjaHVuayBleHRlbnNpb25zIHF1b3RlIHZhbHVlAEludmFsaWQgY2hhcmFjdGVyIGluIGNodW5rIGV4dGVuc2lvbnMgcXVvdGVkIHZhbHVlAFBhdXNlZCBieSBvbl9oZWFkZXJzX2NvbXBsZXRlAEludmFsaWQgRU9GIHN0YXRlAG9uX3Jlc2V0IHBhdXNlAG9uX2NodW5rX2hlYWRlciBwYXVzZQBvbl9tZXNzYWdlX2JlZ2luIHBhdXNlAG9uX2NodW5rX2V4dGVuc2lvbl92YWx1ZSBwYXVzZQBvbl9zdGF0dXNfY29tcGxldGUgcGF1c2UAb25fdmVyc2lvbl9jb21wbGV0ZSBwYXVzZQBvbl91cmxfY29tcGxldGUgcGF1c2UAb25fY2h1bmtfY29tcGxldGUgcGF1c2UAb25faGVhZGVyX3ZhbHVlX2NvbXBsZXRlIHBhdXNlAG9uX21lc3NhZ2VfY29tcGxldGUgcGF1c2UAb25fbWV0aG9kX2NvbXBsZXRlIHBhdXNlAG9uX2hlYWRlcl9maWVsZF9jb21wbGV0ZSBwYXVzZQBvbl9jaHVua19leHRlbnNpb25fbmFtZSBwYXVzZQBVbmV4cGVjdGVkIHNwYWNlIGFmdGVyIHN0YXJ0IGxpbmUAU3BhbiBjYWxsYmFjayBlcnJvciBpbiBvbl9jaHVua19leHRlbnNpb25fbmFtZQBJbnZhbGlkIGNoYXJhY3RlciBpbiBjaHVuayBleHRlbnNpb25zIG5hbWUAUGF1c2Ugb24gQ09OTkVDVC9VcGdyYWRlAFBhdXNlIG9uIFBSSS9VcGdyYWRlAEV4cGVjdGVkIEhUVFAvMiBDb25uZWN0aW9uIFByZWZhY2UAU3BhbiBjYWxsYmFjayBlcnJvciBpbiBvbl9tZXRob2QARXhwZWN0ZWQgc3BhY2UgYWZ0ZXIgbWV0aG9kAFNwYW4gY2FsbGJhY2sgZXJyb3IgaW4gb25faGVhZGVyX2ZpZWxkAFBhdXNlZABJbnZhbGlkIHdvcmQgZW5jb3VudGVyZWQASW52YWxpZCBtZXRob2QgZW5jb3VudGVyZWQAVW5leHBlY3RlZCBjaGFyIGluIHVybCBzY2hlbWEAUmVxdWVzdCBoYXMgaW52YWxpZCBgVHJhbnNmZXItRW5jb2RpbmdgAFNXSVRDSF9QUk9YWQBVU0VfUFJPWFkATUtBQ1RJVklUWQBVTlBST0NFU1NBQkxFX0VOVElUWQBDT1BZAE1PVkVEX1BFUk1BTkVOVExZAFRPT19FQVJMWQBOT1RJRlkARkFJTEVEX0RFUEVOREVOQ1kAQkFEX0dBVEVXQVkAUExBWQBQVVQAQ0hFQ0tPVVQAR0FURVdBWV9USU1FT1VUAFJFUVVFU1RfVElNRU9VVABORVRXT1JLX0NPTk5FQ1RfVElNRU9VVABDT05ORUNUSU9OX1RJTUVPVVQATE9HSU5fVElNRU9VVABORVRXT1JLX1JFQURfVElNRU9VVABQT1NUAE1JU0RJUkVDVEVEX1JFUVVFU1QAQ0xJRU5UX0NMT1NFRF9SRVFVRVNUAENMSUVOVF9DTE9TRURfTE9BRF9CQUxBTkNFRF9SRVFVRVNUAEJBRF9SRVFVRVNUAEhUVFBfUkVRVUVTVF9TRU5UX1RPX0hUVFBTX1BPUlQAUkVQT1JUAElNX0FfVEVBUE9UAFJFU0VUX0NPTlRFTlQATk9fQ09OVEVOVABQQVJUSUFMX0NPTlRFTlQASFBFX0lOVkFMSURfQ09OU1RBTlQASFBFX0NCX1JFU0VUAEdFVABIUEVfU1RSSUNUAENPTkZMSUNUAFRFTVBPUkFSWV9SRURJUkVDVABQRVJNQU5FTlRfUkVESVJFQ1QAQ09OTkVDVABNVUxUSV9TVEFUVVMASFBFX0lOVkFMSURfU1RBVFVTAFRPT19NQU5ZX1JFUVVFU1RTAEVBUkxZX0hJTlRTAFVOQVZBSUxBQkxFX0ZPUl9MRUdBTF9SRUFTT05TAE9QVElPTlMAU1dJVENISU5HX1BST1RPQ09MUwBWQVJJQU5UX0FMU09fTkVHT1RJQVRFUwBNVUxUSVBMRV9DSE9JQ0VTAElOVEVSTkFMX1NFUlZFUl9FUlJPUgBXRUJfU0VSVkVSX1VOS05PV05fRVJST1IAUkFJTEdVTl9FUlJPUgBJREVOVElUWV9QUk9WSURFUl9BVVRIRU5USUNBVElPTl9FUlJPUgBTU0xfQ0VSVElGSUNBVEVfRVJST1IASU5WQUxJRF9YX0ZPUldBUkRFRF9GT1IAU0VUX1BBUkFNRVRFUgBHRVRfUEFSQU1FVEVSAEhQRV9VU0VSAFNFRV9PVEhFUgBIUEVfQ0JfQ0hVTktfSEVBREVSAE1LQ0FMRU5EQVIAU0VUVVAAV0VCX1NFUlZFUl9JU19ET1dOAFRFQVJET1dOAEhQRV9DTE9TRURfQ09OTkVDVElPTgBIRVVSSVNUSUNfRVhQSVJBVElPTgBESVNDT05ORUNURURfT1BFUkFUSU9OAE5PTl9BVVRIT1JJVEFUSVZFX0lORk9STUFUSU9OAEhQRV9JTlZBTElEX1ZFUlNJT04ASFBFX0NCX01FU1NBR0VfQkVHSU4AU0lURV9JU19GUk9aRU4ASFBFX0lOVkFMSURfSEVBREVSX1RPS0VOAElOVkFMSURfVE9LRU4ARk9SQklEREVOAEVOSEFOQ0VfWU9VUl9DQUxNAEhQRV9JTlZBTElEX1VSTABCTE9DS0VEX0JZX1BBUkVOVEFMX0NPTlRST0wATUtDT0wAQUNMAEhQRV9JTlRFUk5BTABSRVFVRVNUX0hFQURFUl9GSUVMRFNfVE9PX0xBUkdFX1VOT0ZGSUNJQUwASFBFX09LAFVOTElOSwBVTkxPQ0sAUFJJAFJFVFJZX1dJVEgASFBFX0lOVkFMSURfQ09OVEVOVF9MRU5HVEgASFBFX1VORVhQRUNURURfQ09OVEVOVF9MRU5HVEgARkxVU0gAUFJPUFBBVENIAE0tU0VBUkNIAFVSSV9UT09fTE9ORwBQUk9DRVNTSU5HAE1JU0NFTExBTkVPVVNfUEVSU0lTVEVOVF9XQVJOSU5HAE1JU0NFTExBTkVPVVNfV0FSTklORwBIUEVfSU5WQUxJRF9UUkFOU0ZFUl9FTkNPRElORwBFeHBlY3RlZCBDUkxGAEhQRV9JTlZBTElEX0NIVU5LX1NJWkUATU9WRQBDT05USU5VRQBIUEVfQ0JfU1RBVFVTX0NPTVBMRVRFAEhQRV9DQl9IRUFERVJTX0NPTVBMRVRFAEhQRV9DQl9WRVJTSU9OX0NPTVBMRVRFAEhQRV9DQl9VUkxfQ09NUExFVEUASFBFX0NCX0NIVU5LX0NPTVBMRVRFAEhQRV9DQl9IRUFERVJfVkFMVUVfQ09NUExFVEUASFBFX0NCX0NIVU5LX0VYVEVOU0lPTl9WQUxVRV9DT01QTEVURQBIUEVfQ0JfQ0hVTktfRVhURU5TSU9OX05BTUVfQ09NUExFVEUASFBFX0NCX01FU1NBR0VfQ09NUExFVEUASFBFX0NCX01FVEhPRF9DT01QTEVURQBIUEVfQ0JfSEVBREVSX0ZJRUxEX0NPTVBMRVRFAERFTEVURQBIUEVfSU5WQUxJRF9FT0ZfU1RBVEUASU5WQUxJRF9TU0xfQ0VSVElGSUNBVEUAUEFVU0UATk9fUkVTUE9OU0UAVU5TVVBQT1JURURfTUVESUFfVFlQRQBHT05FAE5PVF9BQ0NFUFRBQkxFAFNFUlZJQ0VfVU5BVkFJTEFCTEUAUkFOR0VfTk9UX1NBVElTRklBQkxFAE9SSUdJTl9JU19VTlJFQUNIQUJMRQBSRVNQT05TRV9JU19TVEFMRQBQVVJHRQBNRVJHRQBSRVFVRVNUX0hFQURFUl9GSUVMRFNfVE9PX0xBUkdFAFJFUVVFU1RfSEVBREVSX1RPT19MQVJHRQBQQVlMT0FEX1RPT19MQVJHRQBJTlNVRkZJQ0lFTlRfU1RPUkFHRQBIUEVfUEFVU0VEX1VQR1JBREUASFBFX1BBVVNFRF9IMl9VUEdSQURFAFNPVVJDRQBBTk5PVU5DRQBUUkFDRQBIUEVfVU5FWFBFQ1RFRF9TUEFDRQBERVNDUklCRQBVTlNVQlNDUklCRQBSRUNPUkQASFBFX0lOVkFMSURfTUVUSE9EAE5PVF9GT1VORABQUk9QRklORABVTkJJTkQAUkVCSU5EAFVOQVVUSE9SSVpFRABNRVRIT0RfTk9UX0FMTE9XRUQASFRUUF9WRVJTSU9OX05PVF9TVVBQT1JURUQAQUxSRUFEWV9SRVBPUlRFRABBQ0NFUFRFRABOT1RfSU1QTEVNRU5URUQATE9PUF9ERVRFQ1RFRABIUEVfQ1JfRVhQRUNURUQASFBFX0xGX0VYUEVDVEVEAENSRUFURUQASU1fVVNFRABIUEVfUEFVU0VEAFRJTUVPVVRfT0NDVVJFRABQQVlNRU5UX1JFUVVJUkVEAFBSRUNPTkRJVElPTl9SRVFVSVJFRABQUk9YWV9BVVRIRU5USUNBVElPTl9SRVFVSVJFRABORVRXT1JLX0FVVEhFTlRJQ0FUSU9OX1JFUVVJUkVEAExFTkdUSF9SRVFVSVJFRABTU0xfQ0VSVElGSUNBVEVfUkVRVUlSRUQAVVBHUkFERV9SRVFVSVJFRABQQUdFX0VYUElSRUQAUFJFQ09ORElUSU9OX0ZBSUxFRABFWFBFQ1RBVElPTl9GQUlMRUQAUkVWQUxJREFUSU9OX0ZBSUxFRABTU0xfSEFORFNIQUtFX0ZBSUxFRABMT0NLRUQAVFJBTlNGT1JNQVRJT05fQVBQTElFRABOT1RfTU9ESUZJRUQATk9UX0VYVEVOREVEAEJBTkRXSURUSF9MSU1JVF9FWENFRURFRABTSVRFX0lTX09WRVJMT0FERUQASEVBRABFeHBlY3RlZCBIVFRQLwAAXhMAACYTAAAwEAAA8BcAAJ0TAAAVEgAAORcAAPASAAAKEAAAdRIAAK0SAACCEwAATxQAAH8QAACgFQAAIxQAAIkSAACLFAAATRUAANQRAADPFAAAEBgAAMkWAADcFgAAwREAAOAXAAC7FAAAdBQAAHwVAADlFAAACBcAAB8QAABlFQAAoxQAACgVAAACFQAAmRUAACwQAACLGQAATw8AANQOAABqEAAAzhAAAAIXAACJDgAAbhMAABwTAABmFAAAVhcAAMETAADNEwAAbBMAAGgXAABmFwAAXxcAACITAADODwAAaQ4AANgOAABjFgAAyxMAAKoOAAAoFwAAJhcAAMUTAABdFgAA6BEAAGcTAABlEwAA8hYAAHMTAAAdFwAA+RYAAPMRAADPDgAAzhUAAAwSAACzEQAApREAAGEQAAAyFwAAuxMAAAAAAAAAAAAAAAAAAAAAAAAAAQAAAAAAAAAAAAAAAAAAAAAAAAAAAAABAQIBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEAAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQAAAAAAAAAAAAAAAAABAAAAAAAAAAAAAAAAAAAAAAAAAAIDAgICAgIAAAICAAICAAICAgICAgICAgIABAAAAAAAAgICAgICAgICAgICAgICAgICAgICAgICAgIAAAACAgICAgICAgICAgICAgICAgICAgICAgICAgICAgACAAIAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAQAAAAAAAAAAAAAAAAAAAAAAAAACAAICAgICAAACAgACAgACAgICAgICAgICAAMABAAAAAICAgICAgICAgICAgICAgICAgICAgICAgICAAAAAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIAAgACAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAbG9zZWVlcC1hbGl2ZQAAAAAAAAAAAAAAAAEAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEAAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEAAAAAAAAAAAABAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAEBAQEBAQEBAQEBAQIBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAAEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBY2h1bmtlZAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAQEAAQEBAQEAAAEBAAEBAAEBAQEBAQEBAQEAAAAAAAAAAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEAAAABAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQABAAEAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAABlY3Rpb25lbnQtbGVuZ3Rob25yb3h5LWNvbm5lY3Rpb24AAAAAAAAAAAAAAAAAAAByYW5zZmVyLWVuY29kaW5ncGdyYWRlDQoNCg0KU00NCg0KVFRQL0NFL1RTUC8AAAAAAAAAAAAAAAABAgABAwAAAAAAAAAAAAAAAAAAAAAAAAQBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAAEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAAAAAAAAAAAAAQIAAQMAAAAAAAAAAAAAAAAAAAAAAAAEAQEFAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQABAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQAAAAAAAAAAAAEAAAEAAAAAAAAAAAAAAAAAAAAAAAAAAAEBAAEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQABAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEAAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEAAAAAAAAAAAAAAQAAAgAAAAAAAAAAAAAAAAAAAAAAAAMEAAAEBAQEBAQEBAQEBAUEBAQEBAQEBAQEBAQABAAGBwQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAAEAAQABAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQAAAAEAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAEAAAEAAAAAAAAAAAAAAAAAAAAAAAABAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAIAAAAAAAADAwMDAwMDAwMDAwMDAwMDAwMDAwMDAwMDAwAAAAAAAAMDAwMDAwMDAwMDAwMDAwMDAwMDAwMDAwMDAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAABAAABAAAAAAAAAAAAAAAAAAAAAAAAAQAAAAAAAAAAAAIAAAAAAgAAAAAAAAAAAAAAAAAAAAAAAwMDAwMDAwMDAwMDAwMDAwMDAwMDAwMDAwMAAAAAAAADAwMDAwMDAwMDAwMDAwMDAwMDAwMDAwMDAwAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAABOT1VOQ0VFQ0tPVVRORUNURVRFQ1JJQkVMVVNIRVRFQURTRUFSQ0hSR0VDVElWSVRZTEVOREFSVkVPVElGWVBUSU9OU0NIU0VBWVNUQVRDSEdFT1JESVJFQ1RPUlRSQ0hQQVJBTUVURVJVUkNFQlNDUklCRUFSRE9XTkFDRUlORE5LQ0tVQlNDUklCRUhUVFAvQURUUC8='\n","module.exports = 'AGFzbQEAAAABMAhgAX8Bf2ADf39/AX9gBH9/f38Bf2AAAGADf39/AGABfwBgAn9/AGAGf39/f39/AALLAQgDZW52GHdhc21fb25faGVhZGVyc19jb21wbGV0ZQACA2VudhV3YXNtX29uX21lc3NhZ2VfYmVnaW4AAANlbnYLd2FzbV9vbl91cmwAAQNlbnYOd2FzbV9vbl9zdGF0dXMAAQNlbnYUd2FzbV9vbl9oZWFkZXJfZmllbGQAAQNlbnYUd2FzbV9vbl9oZWFkZXJfdmFsdWUAAQNlbnYMd2FzbV9vbl9ib2R5AAEDZW52GHdhc21fb25fbWVzc2FnZV9jb21wbGV0ZQAAA0ZFAwMEAAAFAAAAAAAABQEFAAUFBQAABgAAAAAGBgYGAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQABAAABAQcAAAUFAwABBAUBcAESEgUDAQACBggBfwFBgNQECwfRBSIGbWVtb3J5AgALX2luaXRpYWxpemUACRlfX2luZGlyZWN0X2Z1bmN0aW9uX3RhYmxlAQALbGxodHRwX2luaXQAChhsbGh0dHBfc2hvdWxkX2tlZXBfYWxpdmUAQQxsbGh0dHBfYWxsb2MADAZtYWxsb2MARgtsbGh0dHBfZnJlZQANBGZyZWUASA9sbGh0dHBfZ2V0X3R5cGUADhVsbGh0dHBfZ2V0X2h0dHBfbWFqb3IADxVsbGh0dHBfZ2V0X2h0dHBfbWlub3IAEBFsbGh0dHBfZ2V0X21ldGhvZAARFmxsaHR0cF9nZXRfc3RhdHVzX2NvZGUAEhJsbGh0dHBfZ2V0X3VwZ3JhZGUAEwxsbGh0dHBfcmVzZXQAFA5sbGh0dHBfZXhlY3V0ZQAVFGxsaHR0cF9zZXR0aW5nc19pbml0ABYNbGxodHRwX2ZpbmlzaAAXDGxsaHR0cF9wYXVzZQAYDWxsaHR0cF9yZXN1bWUAGRtsbGh0dHBfcmVzdW1lX2FmdGVyX3VwZ3JhZGUAGhBsbGh0dHBfZ2V0X2Vycm5vABsXbGxodHRwX2dldF9lcnJvcl9yZWFzb24AHBdsbGh0dHBfc2V0X2Vycm9yX3JlYXNvbgAdFGxsaHR0cF9nZXRfZXJyb3JfcG9zAB4RbGxodHRwX2Vycm5vX25hbWUAHxJsbGh0dHBfbWV0aG9kX25hbWUAIBJs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IAH9CwMAIABBMGogAf0LAwAgAEEgaiAB/QsDACAAQd0BNgIcQQALewEBfwJAIAAoAgwiAw0AAkAgACgCBEUNACAAIAE2AgQLAkAgACABIAIQxICAgAAiAw0AIAAoAgwPCyAAIAM2AhxBACEDIAAoAgQiAUUNACAAIAEgAiAAKAIIEYGAgIAAACIBRQ0AIAAgAjYCFCAAIAE2AgwgASEDCyADC+TzAQMOfwN+BH8jgICAgABBEGsiAySAgICAACABIQQgASEFIAEhBiABIQcgASEIIAEhCSABIQogASELIAEhDCABIQ0gASEOIAEhDwJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQCAAKAIcIhBBf2oO3QHaAQHZAQIDBAUGBwgJCgsMDQ7YAQ8Q1wEREtYBExQVFhcYGRob4AHfARwdHtUBHyAhIiMkJdQBJicoKSorLNMB0gEtLtEB0AEvMDEyMzQ1Njc4OTo7PD0+P0BBQkNERUbbAUdISUrPAc4BS80BTMwBTU5PUFFSU1RVVldYWVpbXF1eX2BhYmNkZWZnaGlqa2xtbm9wcXJzdHV2d3h5ent8fX5/gAGBAYIBgwGEAYUBhgGHAYgBiQGKAYsBjAGNAY4BjwGQAZEB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QAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAIBAOxwEAAQID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YWNrIGVycm9yAGBvbl9jaHVua19leHRlbnNpb25fdmFsdWVgIGNhbGxiYWNrIGVycm9yAGBvbl9zdGF0dXNfY29tcGxldGVgIGNhbGxiYWNrIGVycm9yAGBvbl92ZXJzaW9uX2NvbXBsZXRlYCBjYWxsYmFjayBlcnJvcgBgb25fdXJsX2NvbXBsZXRlYCBjYWxsYmFjayBlcnJvcgBgb25fY2h1bmtfY29tcGxldGVgIGNhbGxiYWNrIGVycm9yAGBvbl9oZWFkZXJfdmFsdWVfY29tcGxldGVgIGNhbGxiYWNrIGVycm9yAGBvbl9tZXNzYWdlX2NvbXBsZXRlYCBjYWxsYmFjayBlcnJvcgBgb25fbWV0aG9kX2NvbXBsZXRlYCBjYWxsYmFjayBlcnJvcgBgb25faGVhZGVyX2ZpZWxkX2NvbXBsZXRlYCBjYWxsYmFjayBlcnJvcgBgb25fY2h1bmtfZXh0ZW5zaW9uX25hbWVgIGNhbGxiYWNrIGVycm9yAFVuZXhwZWN0ZWQgY2hhciBpbiB1cmwgc2VydmVyAEludmFsaWQgaGVhZGVyIHZhbHVlIGNoYXIASW52YWxpZCBoZWFkZXIgZmllbGQgY2hhcgBTcGFuIGNhbGxiYWNrIGVycm9yIGluIG9uX3ZlcnNpb24ASW52YWxpZCBtaW5vciB2ZXJzaW9uAEludmFsaWQgbWFqb3IgdmVyc2lvbgBFeHBlY3RlZCBzcGFjZSBhZnRlciB2ZXJzaW9uAEV4cGVjdGVkIENSTEYgYWZ0ZXIgdmVyc2lvbgBJbnZhbGlkIEhUVFAgdmVyc2lvbgBJbnZhbGlkIGhlYWRlciB0b2tlbgBTcGFuIGNhbGxiYWNrIGVycm9yIGluIG9uX3VybABJbnZhbGlkIGNoYXJhY3RlcnMgaW4gdXJsAFVuZXhwZWN0ZWQgc3RhcnQgY2hhciBpbiB1cmwARG91YmxlIEAgaW4gdXJsAEVtcHR5IENvbnRlbnQtTGVuZ3RoAEludmFsaWQgY2hhcmFjdGVyIGluIENvbnRlbnQtTGVuZ3RoAER1cGxpY2F0ZSBDb250ZW50LUxlbmd0aABJbnZhbGlkIGNoYXIgaW4gdXJsIHBhdGgAQ29udGVudC1MZW5ndGggY2FuJ3QgYmUgcHJlc2VudCB3aXRoIFRyYW5zZmVyLUVuY29kaW5nAEludmFsaWQgY2hhcmFjdGVyIGluIGNodW5rIHNpemUAU3BhbiBjYWxsYmFjayBlcnJvciBpbiBvbl9oZWFkZXJfdmFsdWUAU3BhbiBjYWxsYmFjayBlcnJvciBpbiBvbl9jaHVua19leHRlbnNpb25fdmFsdWUASW52YWxpZCBjaGFyYWN0ZXIgaW4gY2h1bmsgZXh0ZW5zaW9ucyB2YWx1ZQBNaXNzaW5nIGV4cGVjdGVkIExGIGFmdGVyIGhlYWRlciB2YWx1ZQBJbnZhbGlkIGBUcmFuc2Zlci1FbmNvZGluZ2AgaGVhZGVyIHZhbHVlAEludmFsaWQgY2hhcmFjdGVyIGluIGNodW5rIGV4dGVuc2lvbnMgcXVvdGUgdmFsdWUASW52YWxpZCBjaGFyYWN0ZXIgaW4gY2h1bmsgZXh0ZW5zaW9ucyBxdW90ZWQgdmFsdWUAUGF1c2VkIGJ5IG9uX2hlYWRlcnNfY29tcGxldGUASW52YWxpZCBFT0Ygc3RhdGUAb25fcmVzZXQgcGF1c2UAb25fY2h1bmtfaGVhZGVyIHBhdXNlAG9uX21lc3NhZ2VfYmVnaW4gcGF1c2UAb25fY2h1bmtfZXh0ZW5zaW9uX3ZhbHVlIHBhdXNlAG9uX3N0YXR1c19jb21wbGV0ZSBwYXVzZQBvbl92ZXJzaW9uX2NvbXBsZXRlIHBhdXNlAG9uX3VybF9jb21wbGV0ZSBwYXVzZQBvbl9jaHVua19jb21wbGV0ZSBwYXVzZQBvbl9oZWFkZXJfdmFsdWVfY29tcGxldGUgcGF1c2UAb25fbWVzc2FnZV9jb21wbGV0ZSBwYXVzZQBvbl9tZXRob2RfY29tcGxldGUgcGF1c2UAb25faGVhZGVyX2ZpZWxkX2NvbXBsZXRlIHBhdXNlAG9uX2NodW5rX2V4dGVuc2lvbl9uYW1lIHBhdXNlAFVuZXhwZWN0ZWQgc3BhY2UgYWZ0ZXIgc3RhcnQgbGluZQBTcGFuIGNhbGxiYWNrIGVycm9yIGluIG9uX2NodW5rX2V4dGVuc2lvbl9uYW1lAEludmFsaWQgY2hhcmFjdGVyIGluIGNodW5rIGV4dGVuc2lvbnMgbmFtZQBQYXVzZSBvbiBDT05ORUNUL1VwZ3JhZGUAUGF1c2Ugb24gUFJJL1VwZ3JhZGUARXhwZWN0ZWQgSFRUUC8yIENvbm5lY3Rpb24gUHJlZmFjZQBTcGFuIGNhbGxiYWNrIGVycm9yIGluIG9uX21ldGhvZABFeHBlY3RlZCBzcGFjZSBhZnRlciBtZXRob2QAU3BhbiBjYWxsYmFjayBlcnJvciBpbiBvbl9oZWFkZXJfZmllbGQAUGF1c2VkAEludmFsaWQgd29yZCBlbmNvdW50ZXJlZABJbnZhbGlkIG1ldGhvZCBlbmNvdW50ZXJlZABVbmV4cGVjdGVkIGNoYXIgaW4gdXJsIHNjaGVtYQBSZXF1ZXN0IGhhcyBpbnZhbGlkIGBUcmFuc2Zlci1FbmNvZGluZ2AAU1dJVENIX1BST1hZAFVTRV9QUk9YWQBNS0FDVElWSVRZAFVOUFJPQ0VTU0FCTEVfRU5USVRZAENPUFkATU9WRURfUEVSTUFORU5UTFkAVE9PX0VBUkxZAE5PVElGWQBGQUlMRURfREVQRU5ERU5DWQBCQURfR0FURVdBWQBQTEFZAFBVVABDSEVDS09VVABHQVRFV0FZX1RJTUVPVVQAUkVRVUVTVF9USU1FT1VUAE5FVFdPUktfQ09OTkVDVF9USU1FT1VUAENPTk5FQ1RJT05fVElNRU9VVABMT0dJTl9USU1FT1VUAE5FVFdPUktfUkVBRF9USU1FT1VUAFBPU1QATUlTRElSRUNURURfUkVRVUVTVABDTElFTlRfQ0xPU0VEX1JFUVVFU1QAQ0xJRU5UX0NMT1NFRF9MT0FEX0JBTEFOQ0VEX1JFUVVFU1QAQkFEX1JFUVVFU1QASFRUUF9SRVFVRVNUX1NFTlRfVE9fSFRUUFNfUE9SVABSRVBPUlQASU1fQV9URUFQT1QAUkVTRVRfQ09OVEVOVABOT19DT05URU5UAFBBUlRJQUxfQ09OVEVOVABIUEVfSU5WQUxJRF9DT05TVEFOVABIUEVfQ0JfUkVTRVQAR0VUAEhQRV9TVFJJQ1QAQ09ORkxJQ1QAVEVNUE9SQVJZX1JFRElSRUNUAFBFUk1BTkVOVF9SRURJUkVDVABDT05ORUNUAE1VTFRJX1NUQVRVUwBIUEVfSU5WQUxJRF9TVEFUVVMAVE9PX01BTllfUkVRVUVTVFMARUFSTFlfSElOVFMAVU5BVkFJTEFCTEVfRk9SX0xFR0FMX1JFQVNPTlMAT1BUSU9OUwBTV0lUQ0hJTkdfUFJPVE9DT0xTAFZBUklBTlRfQUxTT19ORUdPVElBVEVTAE1VTFRJUExFX0NIT0lDRVMASU5URVJOQUxfU0VSVkVSX0VSUk9SAFdFQl9TRVJWRVJfVU5LTk9XTl9FUlJPUgBSQUlMR1VOX0VSUk9SAElERU5USVRZX1BST1ZJREVSX0FVVEhFTlRJQ0FUSU9OX0VSUk9SAFNTTF9DRVJUSUZJQ0FURV9FUlJPUgBJTlZBTElEX1hfRk9SV0FSREVEX0ZPUgBTRVRfUEFSQU1FVEVSAEdFVF9QQVJBTUVURVIASFBFX1VTRVIAU0VFX09USEVSAEhQRV9DQl9DSFVOS19IRUFERVIATUtDQUxFTkRBUgBTRVRVUABXRUJfU0VSVkVSX0lTX0RPV04AVEVBUkRPV04ASFBFX0NMT1NFRF9DT05ORUNUSU9OAEhFVVJJU1RJQ19FWFBJUkFUSU9OAERJU0NPTk5FQ1RFRF9PUEVSQVRJT04ATk9OX0FVVEhPUklUQVRJVkVfSU5GT1JNQVRJT04ASFBFX0lOVkFMSURfVkVSU0lPTgBIUEVfQ0JfTUVTU0FHRV9CRUdJTgBTSVRFX0lTX0ZST1pFTgBIUEVfSU5WQUxJRF9IRUFERVJfVE9LRU4ASU5WQUxJRF9UT0tFTgBGT1JCSURERU4ARU5IQU5DRV9ZT1VSX0NBTE0ASFBFX0lOVkFMSURfVVJMAEJMT0NLRURfQllfUEFSRU5UQUxfQ09OVFJPTABNS0NPTABBQ0wASFBFX0lOVEVSTkFMAFJFUVVFU1RfSEVBREVSX0ZJRUxEU19UT09fTEFSR0VfVU5PRkZJQ0lBTABIUEVfT0sAVU5MSU5LAFVOTE9DSwBQUkkAUkVUUllfV0lUSABIUEVfSU5WQUxJRF9DT05URU5UX0xFTkdUSABIUEVfVU5FWFBFQ1RFRF9DT05URU5UX0xFTkdUSABGTFVTSABQUk9QUEFUQ0gATS1TRUFSQ0gAVVJJX1RPT19MT05HAFBST0NFU1NJTkcATUlTQ0VMTEFORU9VU19QRVJTSVNURU5UX1dBUk5JTkcATUlTQ0VMTEFORU9VU19XQVJOSU5HAEhQRV9JTlZBTElEX1RSQU5TRkVSX0VOQ09ESU5HAEV4cGVjdGVkIENSTEYASFBFX0lOVkFMSURfQ0hVTktfU0laRQBNT1ZFAENPTlRJTlVFAEhQRV9DQl9TVEFUVVNfQ09NUExFVEUASFBFX0NCX0hFQURFUlNfQ09NUExFVEUASFBFX0NCX1ZFUlNJT05fQ09NUExFVEUASFBFX0NCX1VSTF9DT01QTEVURQBIUEVfQ0JfQ0hVTktfQ09NUExFVEUASFBFX0NCX0hFQURFUl9WQUxVRV9DT01QTEVURQBIUEVfQ0JfQ0hVTktfRVhURU5TSU9OX1ZBTFVFX0NPTVBMRVRFAEhQRV9DQl9DSFVOS19FWFRFTlNJT05fTkFNRV9DT01QTEVURQBIUEVfQ0JfTUVTU0FHRV9DT01QTEVURQBIUEVfQ0JfTUVUSE9EX0NPTVBMRVRFAEhQRV9DQl9IRUFERVJfRklFTERfQ09NUExFVEUAREVMRVRFAEhQRV9JTlZBTElEX0VPRl9TVEFURQBJTlZBTElEX1NTTF9DRVJUSUZJQ0FURQBQQVVTRQBOT19SRVNQT05TRQBVTlNVUFBPUlRFRF9NRURJQV9UWVBFAEdPTkUATk9UX0FDQ0VQVEFCTEUAU0VSVklDRV9VTkFWQUlMQUJMRQBSQU5HRV9OT1RfU0FUSVNGSUFCTEUAT1JJR0lOX0lTX1VOUkVBQ0hBQkxFAFJFU1BPTlNFX0lTX1NUQUxFAFBVUkdFAE1FUkdFAFJFUVVFU1RfSEVBREVSX0ZJRUxEU19UT09fTEFSR0UAUkVRVUVTVF9IRUFERVJfVE9PX0xBUkdFAFBBWUxPQURfVE9PX0xBUkdFAElOU1VGRklDSUVOVF9TVE9SQUdFAEhQRV9QQVVTRURfVVBHUkFERQBIUEVfUEFVU0VEX0gyX1VQR1JBREUAU09VUkNFAEFOTk9VTkNFAFRSQUNFAEhQRV9VTkVYUEVDVEVEX1NQQUNFAERFU0NSSUJFAFVOU1VCU0NSSUJFAFJFQ09SRABIUEVfSU5WQUxJRF9NRVRIT0QATk9UX0ZPVU5EAFBST1BGSU5EAFVOQklORABSRUJJTkQAVU5BVVRIT1JJWkVEAE1FVEhPRF9OT1RfQUxMT1dFRABIVFRQX1ZFUlNJT05fTk9UX1NVUFBPUlRFRABBTFJFQURZX1JFUE9SVEVEAEFDQ0VQVEVEAE5PVF9JTVBMRU1FTlRFRABMT09QX0RFVEVDVEVEAEhQRV9DUl9FWFBFQ1RFRABIUEVfTEZfRVhQRUNURUQAQ1JFQVRFRABJTV9VU0VEAEhQRV9QQVVTRUQAVElNRU9VVF9PQ0NVUkVEAFBBWU1FTlRfUkVRVUlSRUQAUFJFQ09ORElUSU9OX1JFUVVJUkVEAFBST1hZX0FVVEhFTlRJQ0FUSU9OX1JFUVVJUkVEAE5FVFdPUktfQVVUSEVOVElDQVRJT05fUkVRVUlSRUQATEVOR1RIX1JFUVVJUkVEAFNTTF9DRVJUSUZJQ0FURV9SRVFVSVJFRABVUEdSQURFX1JFUVVJUkVEAFBBR0VfRVhQSVJFRABQUkVDT05ESVRJT05fRkFJTEVEAEVYUEVDVEFUSU9OX0ZBSUxFRABSRVZBTElEQVRJT05fRkFJTEVEAFNTTF9IQU5EU0hBS0VfRkFJTEVEAExPQ0tFRABUUkFOU0ZPUk1BVElPTl9BUFBMSUVEAE5PVF9NT0RJRklFRABOT1RfRVhURU5ERUQAQkFORFdJRFRIX0xJTUlUX0VYQ0VFREVEAFNJVEVfSVNfT1ZFUkxPQURFRABIRUFEAEV4cGVjdGVkIEhUVFAvAABeEwAAJhMAADAQAADwFwAAnRMAABUSAAA5FwAA8BIAAAoQAAB1EgAArRIAAIITAABPFAAAfxAAAKAVAAAjFAAAiRIAAIsUAABNFQAA1BEAAM8UAAAQGAAAyRYAANwWAADBEQAA4BcAALsUAAB0FAAAfBUAAOUUAAAIFwAAHxAAAGUVAACjFAAAKBUAAAIVAACZFQAALBAAAIsZAABPDwAA1A4AAGoQAADOEAAAAhcAAIkOAABuEwAAHBMAAGYUAABWFwAAwRMAAM0TAABsEwAAaBcAAGYXAABfFwAAIhMAAM4PAABpDgAA2A4AAGMWAADLEwAAqg4AACgXAAAmFwAAxRMAAF0WAADoEQAAZxMAAGUTAADyFgAAcxMAAB0XAAD5FgAA8xEAAM8OAADOFQAADBIAALMRAAClEQAAYRAAADIXAAC7EwAAAAAAAAAAAAAAAAAAAAAAAAABAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAEBAgEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQABAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAAAAAAAAAAAAAAAAAAEAAAAAAAAAAAAAAAAAAAAAAAAAAgMCAgICAgAAAgIAAgIAAgICAgICAgICAgAEAAAAAAACAgICAgICAgICAgICAgICAgICAgICAgICAgAAAAICAgICAgICAgICAgICAgICAgICAgICAgICAgICAAIAAgAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAABAAAAAAAAAAAAAAAAAAAAAAAAAAIAAgICAgIAAAICAAICAAICAgICAgICAgIAAwAEAAAAAgICAgICAgICAgICAgICAgICAgICAgICAgIAAAACAgICAgICAgICAgICAgICAgICAgICAgICAgICAgACAAIAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAABsb3NlZWVwLWFsaXZlAAAAAAAAAAAAAAAAAQAAAAAAAAAAAAAAAAAAAAAAAAAAAAABAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQABAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQAAAAAAAAAAAAEAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAQEBAQEBAQEBAQEBAgEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEAAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQFjaHVua2VkAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAABAQABAQEBAQAAAQEAAQEAAQEBAQEBAQEBAQAAAAAAAAABAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQAAAAEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAAEAAQAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAGVjdGlvbmVudC1sZW5ndGhvbnJveHktY29ubmVjdGlvbgAAAAAAAAAAAAAAAAAAAHJhbnNmZXItZW5jb2RpbmdwZ3JhZGUNCg0KDQpTTQ0KDQpUVFAvQ0UvVFNQLwAAAAAAAAAAAAAAAAECAAEDAAAAAAAAAAAAAAAAAAAAAAAABAEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEAAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEAAAAAAAAAAAABAgABAwAAAAAAAAAAAAAAAAAAAAAAAAQBAQUBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAAEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAAAAAAAAAAAAAQAAAQAAAAAAAAAAAAAAAAAAAAAAAAAAAQEAAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAAEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQABAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQAAAAAAAAAAAAABAAACAAAAAAAAAAAAAAAAAAAAAAAAAwQAAAQEBAQEBAQEBAQEBQQEBAQEBAQEBAQEBAAEAAYHBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEAAQABAAEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAAAAAQAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAQAAAQAAAAAAAAAAAAAAAAAAAAAAAAEAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAgAAAAAAAAMDAwMDAwMDAwMDAwMDAwMDAwMDAwMDAwMDAAAAAAAAAwMDAwMDAwMDAwMDAwMDAwMDAwMDAwMDAwMAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAEAAAEAAAAAAAAAAAAAAAAAAAAAAAABAAAAAAAAAAAAAgAAAAACAAAAAAAAAAAAAAAAAAAAAAADAwMDAwMDAwMDAwMDAwMDAwMDAwMDAwMDAwAAAAAAAAMDAwMDAwMDAwMDAwMDAwMDAwMDAwMDAwMDAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAE5PVU5DRUVDS09VVE5FQ1RFVEVDUklCRUxVU0hFVEVBRFNFQVJDSFJHRUNUSVZJVFlMRU5EQVJWRU9USUZZUFRJT05TQ0hTRUFZU1RBVENIR0VPUkRJUkVDVE9SVFJDSFBBUkFNRVRFUlVSQ0VCU0NSSUJFQVJET1dOQUNFSU5ETktDS1VCU0NSSUJFSFRUUC9BRFRQLw=='\n","\"use strict\";\nObject.defineProperty(exports, \"__esModule\", { value: true });\nexports.enumToMap = void 0;\nfunction enumToMap(obj) {\n const res = {};\n Object.keys(obj).forEach((key) => {\n const value = obj[key];\n if (typeof value === 'number') {\n res[key] = value;\n }\n });\n return res;\n}\nexports.enumToMap = enumToMap;\n//# sourceMappingURL=utils.js.map","'use strict'\n\nconst { kClients } = require('../core/symbols')\nconst Agent = require('../agent')\nconst {\n kAgent,\n kMockAgentSet,\n kMockAgentGet,\n kDispatches,\n kIsMockActive,\n kNetConnect,\n kGetNetConnect,\n kOptions,\n kFactory\n} = require('./mock-symbols')\nconst MockClient = require('./mock-client')\nconst MockPool = require('./mock-pool')\nconst { matchValue, buildMockOptions } = require('./mock-utils')\nconst { InvalidArgumentError, UndiciError } = require('../core/errors')\nconst Dispatcher = require('../dispatcher')\nconst Pluralizer = require('./pluralizer')\nconst PendingInterceptorsFormatter = require('./pending-interceptors-formatter')\n\nclass FakeWeakRef {\n constructor (value) {\n this.value = value\n }\n\n deref () {\n return this.value\n }\n}\n\nclass MockAgent extends Dispatcher {\n constructor (opts) {\n super(opts)\n\n this[kNetConnect] = true\n this[kIsMockActive] = true\n\n // Instantiate Agent and encapsulate\n if ((opts && opts.agent && typeof opts.agent.dispatch !== 'function')) {\n throw new InvalidArgumentError('Argument opts.agent must implement Agent')\n }\n const agent = opts && opts.agent ? opts.agent : new Agent(opts)\n this[kAgent] = agent\n\n this[kClients] = agent[kClients]\n this[kOptions] = buildMockOptions(opts)\n }\n\n get (origin) {\n let dispatcher = this[kMockAgentGet](origin)\n\n if (!dispatcher) {\n dispatcher = this[kFactory](origin)\n this[kMockAgentSet](origin, dispatcher)\n }\n return dispatcher\n }\n\n dispatch (opts, handler) {\n // Call MockAgent.get to perform additional setup before dispatching as normal\n this.get(opts.origin)\n return this[kAgent].dispatch(opts, handler)\n }\n\n async close () {\n await this[kAgent].close()\n this[kClients].clear()\n }\n\n deactivate () {\n this[kIsMockActive] = false\n }\n\n activate () {\n this[kIsMockActive] = true\n }\n\n enableNetConnect (matcher) {\n if (typeof matcher === 'string' || typeof matcher === 'function' || matcher instanceof RegExp) {\n if (Array.isArray(this[kNetConnect])) {\n this[kNetConnect].push(matcher)\n } else {\n this[kNetConnect] = [matcher]\n }\n } else if (typeof matcher === 'undefined') {\n this[kNetConnect] = true\n } else {\n throw new InvalidArgumentError('Unsupported matcher. Must be one of String|Function|RegExp.')\n }\n }\n\n disableNetConnect () {\n this[kNetConnect] = false\n }\n\n // This is required to bypass issues caused by using global symbols - see:\n // https://github.com/nodejs/undici/issues/1447\n get isMockActive () {\n return this[kIsMockActive]\n }\n\n [kMockAgentSet] (origin, dispatcher) {\n this[kClients].set(origin, new FakeWeakRef(dispatcher))\n }\n\n [kFactory] (origin) {\n const mockOptions = Object.assign({ agent: this }, this[kOptions])\n return this[kOptions] && this[kOptions].connections === 1\n ? new MockClient(origin, mockOptions)\n : new MockPool(origin, mockOptions)\n }\n\n [kMockAgentGet] (origin) {\n // First check if we can immediately find it\n const ref = this[kClients].get(origin)\n if (ref) {\n return ref.deref()\n }\n\n // If the origin is not a string create a dummy parent pool and return to user\n if (typeof origin !== 'string') {\n const dispatcher = this[kFactory]('http://localhost:9999')\n this[kMockAgentSet](origin, dispatcher)\n return dispatcher\n }\n\n // If we match, create a pool and assign the same dispatches\n for (const [keyMatcher, nonExplicitRef] of Array.from(this[kClients])) {\n const nonExplicitDispatcher = nonExplicitRef.deref()\n if (nonExplicitDispatcher && typeof keyMatcher !== 'string' && matchValue(keyMatcher, origin)) {\n const dispatcher = this[kFactory](origin)\n this[kMockAgentSet](origin, dispatcher)\n dispatcher[kDispatches] = nonExplicitDispatcher[kDispatches]\n return dispatcher\n }\n }\n }\n\n [kGetNetConnect] () {\n return this[kNetConnect]\n }\n\n pendingInterceptors () {\n const mockAgentClients = this[kClients]\n\n return Array.from(mockAgentClients.entries())\n .flatMap(([origin, scope]) => scope.deref()[kDispatches].map(dispatch => ({ ...dispatch, origin })))\n .filter(({ pending }) => pending)\n }\n\n assertNoPendingInterceptors ({ pendingInterceptorsFormatter = new PendingInterceptorsFormatter() } = {}) {\n const pending = this.pendingInterceptors()\n\n if (pending.length === 0) {\n return\n }\n\n const pluralizer = new Pluralizer('interceptor', 'interceptors').pluralize(pending.length)\n\n throw new UndiciError(`\n${pluralizer.count} ${pluralizer.noun} ${pluralizer.is} pending:\n\n${pendingInterceptorsFormatter.format(pending)}\n`.trim())\n }\n}\n\nmodule.exports = MockAgent\n","'use strict'\n\nconst { promisify } = require('util')\nconst Client = require('../client')\nconst { buildMockDispatch } = require('./mock-utils')\nconst {\n kDispatches,\n kMockAgent,\n kClose,\n kOriginalClose,\n kOrigin,\n kOriginalDispatch,\n kConnected\n} = require('./mock-symbols')\nconst { MockInterceptor } = require('./mock-interceptor')\nconst Symbols = require('../core/symbols')\nconst { InvalidArgumentError } = require('../core/errors')\n\n/**\n * MockClient provides an API that extends the Client to influence the mockDispatches.\n */\nclass MockClient extends Client {\n constructor (origin, opts) {\n super(origin, opts)\n\n if (!opts || !opts.agent || typeof opts.agent.dispatch !== 'function') {\n throw new InvalidArgumentError('Argument opts.agent must implement Agent')\n }\n\n this[kMockAgent] = opts.agent\n this[kOrigin] = origin\n this[kDispatches] = []\n this[kConnected] = 1\n this[kOriginalDispatch] = this.dispatch\n this[kOriginalClose] = this.close.bind(this)\n\n this.dispatch = buildMockDispatch.call(this)\n this.close = this[kClose]\n }\n\n get [Symbols.kConnected] () {\n return this[kConnected]\n }\n\n /**\n * Sets up the base interceptor for mocking replies from undici.\n */\n intercept (opts) {\n return new MockInterceptor(opts, this[kDispatches])\n }\n\n async [kClose] () {\n await promisify(this[kOriginalClose])()\n this[kConnected] = 0\n this[kMockAgent][Symbols.kClients].delete(this[kOrigin])\n }\n}\n\nmodule.exports = MockClient\n","'use strict'\n\nconst { UndiciError } = require('../core/errors')\n\nclass MockNotMatchedError extends UndiciError {\n constructor (message) {\n super(message)\n Error.captureStackTrace(this, MockNotMatchedError)\n this.name = 'MockNotMatchedError'\n this.message = message || 'The request does not match any registered mock dispatches'\n this.code = 'UND_MOCK_ERR_MOCK_NOT_MATCHED'\n }\n}\n\nmodule.exports = {\n MockNotMatchedError\n}\n","'use strict'\n\nconst { getResponseData, buildKey, addMockDispatch } = require('./mock-utils')\nconst {\n kDispatches,\n kDispatchKey,\n kDefaultHeaders,\n kDefaultTrailers,\n kContentLength,\n kMockDispatch\n} = require('./mock-symbols')\nconst { InvalidArgumentError } = require('../core/errors')\nconst { buildURL } = require('../core/util')\n\n/**\n * Defines the scope API for an interceptor reply\n */\nclass MockScope {\n constructor (mockDispatch) {\n this[kMockDispatch] = mockDispatch\n }\n\n /**\n * Delay a reply by a set amount in ms.\n */\n delay (waitInMs) {\n if (typeof waitInMs !== 'number' || !Number.isInteger(waitInMs) || waitInMs <= 0) {\n throw new InvalidArgumentError('waitInMs must be a valid integer > 0')\n }\n\n this[kMockDispatch].delay = waitInMs\n return this\n }\n\n /**\n * For a defined reply, never mark as consumed.\n */\n persist () {\n this[kMockDispatch].persist = true\n return this\n }\n\n /**\n * Allow one to define a reply for a set amount of matching requests.\n */\n times (repeatTimes) {\n if (typeof repeatTimes !== 'number' || !Number.isInteger(repeatTimes) || repeatTimes <= 0) {\n throw new InvalidArgumentError('repeatTimes must be a valid integer > 0')\n }\n\n this[kMockDispatch].times = repeatTimes\n return this\n }\n}\n\n/**\n * Defines an interceptor for a Mock\n */\nclass MockInterceptor {\n constructor (opts, mockDispatches) {\n if (typeof opts !== 'object') {\n throw new InvalidArgumentError('opts must be an object')\n }\n if (typeof opts.path === 'undefined') {\n throw new InvalidArgumentError('opts.path must be defined')\n }\n if (typeof opts.method === 'undefined') {\n opts.method = 'GET'\n }\n // See https://github.com/nodejs/undici/issues/1245\n // As per RFC 3986, clients are not supposed to send URI\n // fragments to servers when they retrieve a document,\n if (typeof opts.path === 'string') {\n if (opts.query) {\n opts.path = buildURL(opts.path, opts.query)\n } else {\n // Matches https://github.com/nodejs/undici/blob/main/lib/fetch/index.js#L1811\n const parsedURL = new URL(opts.path, 'data://')\n opts.path = parsedURL.pathname + parsedURL.search\n }\n }\n if (typeof opts.method === 'string') {\n opts.method = opts.method.toUpperCase()\n }\n\n this[kDispatchKey] = buildKey(opts)\n this[kDispatches] = mockDispatches\n this[kDefaultHeaders] = {}\n this[kDefaultTrailers] = {}\n this[kContentLength] = false\n }\n\n createMockScopeDispatchData (statusCode, data, responseOptions = {}) {\n const responseData = getResponseData(data)\n const contentLength = this[kContentLength] ? { 'content-length': responseData.length } : {}\n const headers = { ...this[kDefaultHeaders], ...contentLength, ...responseOptions.headers }\n const trailers = { ...this[kDefaultTrailers], ...responseOptions.trailers }\n\n return { statusCode, data, headers, trailers }\n }\n\n validateReplyParameters (statusCode, data, responseOptions) {\n if (typeof statusCode === 'undefined') {\n throw new InvalidArgumentError('statusCode must be defined')\n }\n if (typeof data === 'undefined') {\n throw new InvalidArgumentError('data must be defined')\n }\n if (typeof responseOptions !== 'object') {\n throw new InvalidArgumentError('responseOptions must be an object')\n }\n }\n\n /**\n * Mock an undici request with a defined reply.\n */\n reply (replyData) {\n // Values of reply aren't available right now as they\n // can only be available when the reply callback is invoked.\n if (typeof replyData === 'function') {\n // We'll first wrap the provided callback in another function,\n // this function will properly resolve the data from the callback\n // when invoked.\n const wrappedDefaultsCallback = (opts) => {\n // Our reply options callback contains the parameter for statusCode, data and options.\n const resolvedData = replyData(opts)\n\n // Check if it is in the right format\n if (typeof resolvedData !== 'object') {\n throw new InvalidArgumentError('reply options callback must return an object')\n }\n\n const { statusCode, data = '', responseOptions = {} } = resolvedData\n this.validateReplyParameters(statusCode, data, responseOptions)\n // Since the values can be obtained immediately we return them\n // from this higher order function that will be resolved later.\n return {\n ...this.createMockScopeDispatchData(statusCode, data, responseOptions)\n }\n }\n\n // Add usual dispatch data, but this time set the data parameter to function that will eventually provide data.\n const newMockDispatch = addMockDispatch(this[kDispatches], this[kDispatchKey], wrappedDefaultsCallback)\n return new MockScope(newMockDispatch)\n }\n\n // We can have either one or three parameters, if we get here,\n // we should have 1-3 parameters. So we spread the arguments of\n // this function to obtain the parameters, since replyData will always\n // just be the statusCode.\n const [statusCode, data = '', responseOptions = {}] = [...arguments]\n this.validateReplyParameters(statusCode, data, responseOptions)\n\n // Send in-already provided data like usual\n const dispatchData = this.createMockScopeDispatchData(statusCode, data, responseOptions)\n const newMockDispatch = addMockDispatch(this[kDispatches], this[kDispatchKey], dispatchData)\n return new MockScope(newMockDispatch)\n }\n\n /**\n * Mock an undici request with a defined error.\n */\n replyWithError (error) {\n if (typeof error === 'undefined') {\n throw new InvalidArgumentError('error must be defined')\n }\n\n const newMockDispatch = addMockDispatch(this[kDispatches], this[kDispatchKey], { error })\n return new MockScope(newMockDispatch)\n }\n\n /**\n * Set default reply headers on the interceptor for subsequent replies\n */\n defaultReplyHeaders (headers) {\n if (typeof headers === 'undefined') {\n throw new InvalidArgumentError('headers must be defined')\n }\n\n this[kDefaultHeaders] = headers\n return this\n }\n\n /**\n * Set default reply trailers on the interceptor for subsequent replies\n */\n defaultReplyTrailers (trailers) {\n if (typeof trailers === 'undefined') {\n throw new InvalidArgumentError('trailers must be defined')\n }\n\n this[kDefaultTrailers] = trailers\n return this\n }\n\n /**\n * Set reply content length header for replies on the interceptor\n */\n replyContentLength () {\n this[kContentLength] = true\n return this\n }\n}\n\nmodule.exports.MockInterceptor = MockInterceptor\nmodule.exports.MockScope = MockScope\n","'use strict'\n\nconst { promisify } = require('util')\nconst Pool = require('../pool')\nconst { buildMockDispatch } = require('./mock-utils')\nconst {\n kDispatches,\n kMockAgent,\n kClose,\n kOriginalClose,\n kOrigin,\n kOriginalDispatch,\n kConnected\n} = require('./mock-symbols')\nconst { MockInterceptor } = require('./mock-interceptor')\nconst Symbols = require('../core/symbols')\nconst { InvalidArgumentError } = require('../core/errors')\n\n/**\n * MockPool provides an API that extends the Pool to influence the mockDispatches.\n */\nclass MockPool extends Pool {\n constructor (origin, opts) {\n super(origin, opts)\n\n if (!opts || !opts.agent || typeof opts.agent.dispatch !== 'function') {\n throw new InvalidArgumentError('Argument opts.agent must implement Agent')\n }\n\n this[kMockAgent] = opts.agent\n this[kOrigin] = origin\n this[kDispatches] = []\n this[kConnected] = 1\n this[kOriginalDispatch] = this.dispatch\n this[kOriginalClose] = this.close.bind(this)\n\n this.dispatch = buildMockDispatch.call(this)\n this.close = this[kClose]\n }\n\n get [Symbols.kConnected] () {\n return this[kConnected]\n }\n\n /**\n * Sets up the base interceptor for mocking replies from undici.\n */\n intercept (opts) {\n return new MockInterceptor(opts, this[kDispatches])\n }\n\n async [kClose] () {\n await promisify(this[kOriginalClose])()\n this[kConnected] = 0\n this[kMockAgent][Symbols.kClients].delete(this[kOrigin])\n }\n}\n\nmodule.exports = MockPool\n","'use strict'\n\nmodule.exports = {\n kAgent: Symbol('agent'),\n kOptions: Symbol('options'),\n kFactory: Symbol('factory'),\n kDispatches: Symbol('dispatches'),\n kDispatchKey: Symbol('dispatch key'),\n kDefaultHeaders: Symbol('default headers'),\n kDefaultTrailers: Symbol('default trailers'),\n kContentLength: Symbol('content length'),\n kMockAgent: Symbol('mock agent'),\n kMockAgentSet: Symbol('mock agent set'),\n kMockAgentGet: Symbol('mock agent get'),\n kMockDispatch: Symbol('mock dispatch'),\n kClose: Symbol('close'),\n kOriginalClose: Symbol('original agent close'),\n kOrigin: Symbol('origin'),\n kIsMockActive: Symbol('is mock active'),\n kNetConnect: Symbol('net connect'),\n kGetNetConnect: Symbol('get net connect'),\n kConnected: Symbol('connected')\n}\n","'use strict'\n\nconst { MockNotMatchedError } = require('./mock-errors')\nconst {\n kDispatches,\n kMockAgent,\n kOriginalDispatch,\n kOrigin,\n kGetNetConnect\n} = require('./mock-symbols')\nconst { buildURL, nop } = require('../core/util')\nconst { STATUS_CODES } = require('http')\nconst {\n types: {\n isPromise\n }\n} = require('util')\n\nfunction matchValue (match, value) {\n if (typeof match === 'string') {\n return match === value\n }\n if (match instanceof RegExp) {\n return match.test(value)\n }\n if (typeof match === 'function') {\n return match(value) === true\n }\n return false\n}\n\nfunction lowerCaseEntries (headers) {\n return Object.fromEntries(\n Object.entries(headers).map(([headerName, headerValue]) => {\n return [headerName.toLocaleLowerCase(), headerValue]\n })\n )\n}\n\n/**\n * @param {import('../../index').Headers|string[]|Record} headers\n * @param {string} key\n */\nfunction getHeaderByName (headers, key) {\n if (Array.isArray(headers)) {\n for (let i = 0; i < headers.length; i += 2) {\n if (headers[i].toLocaleLowerCase() === key.toLocaleLowerCase()) {\n return headers[i + 1]\n }\n }\n\n return undefined\n } else if (typeof headers.get === 'function') {\n return headers.get(key)\n } else {\n return lowerCaseEntries(headers)[key.toLocaleLowerCase()]\n }\n}\n\n/** @param {string[]} headers */\nfunction buildHeadersFromArray (headers) { // fetch HeadersList\n const clone = headers.slice()\n const entries = []\n for (let index = 0; index < clone.length; index += 2) {\n entries.push([clone[index], clone[index + 1]])\n }\n return Object.fromEntries(entries)\n}\n\nfunction matchHeaders (mockDispatch, headers) {\n if (typeof mockDispatch.headers === 'function') {\n if (Array.isArray(headers)) { // fetch HeadersList\n headers = buildHeadersFromArray(headers)\n }\n return mockDispatch.headers(headers ? lowerCaseEntries(headers) : {})\n }\n if (typeof mockDispatch.headers === 'undefined') {\n return true\n }\n if (typeof headers !== 'object' || typeof mockDispatch.headers !== 'object') {\n return false\n }\n\n for (const [matchHeaderName, matchHeaderValue] of Object.entries(mockDispatch.headers)) {\n const headerValue = getHeaderByName(headers, matchHeaderName)\n\n if (!matchValue(matchHeaderValue, headerValue)) {\n return false\n }\n }\n return true\n}\n\nfunction safeUrl (path) {\n if (typeof path !== 'string') {\n return path\n }\n\n const pathSegments = path.split('?')\n\n if (pathSegments.length !== 2) {\n return path\n }\n\n const qp = new URLSearchParams(pathSegments.pop())\n qp.sort()\n return [...pathSegments, qp.toString()].join('?')\n}\n\nfunction matchKey (mockDispatch, { path, method, body, headers }) {\n const pathMatch = matchValue(mockDispatch.path, path)\n const methodMatch = matchValue(mockDispatch.method, method)\n const bodyMatch = typeof mockDispatch.body !== 'undefined' ? matchValue(mockDispatch.body, body) : true\n const headersMatch = matchHeaders(mockDispatch, headers)\n return pathMatch && methodMatch && bodyMatch && headersMatch\n}\n\nfunction getResponseData (data) {\n if (Buffer.isBuffer(data)) {\n return data\n } else if (typeof data === 'object') {\n return JSON.stringify(data)\n } else {\n return data.toString()\n }\n}\n\nfunction getMockDispatch (mockDispatches, key) {\n const basePath = key.query ? buildURL(key.path, key.query) : key.path\n const resolvedPath = typeof basePath === 'string' ? safeUrl(basePath) : basePath\n\n // Match path\n let matchedMockDispatches = mockDispatches.filter(({ consumed }) => !consumed).filter(({ path }) => matchValue(safeUrl(path), resolvedPath))\n if (matchedMockDispatches.length === 0) {\n throw new MockNotMatchedError(`Mock dispatch not matched for path '${resolvedPath}'`)\n }\n\n // Match method\n matchedMockDispatches = matchedMockDispatches.filter(({ method }) => matchValue(method, key.method))\n if (matchedMockDispatches.length === 0) {\n throw new MockNotMatchedError(`Mock dispatch not matched for method '${key.method}'`)\n }\n\n // Match body\n matchedMockDispatches = matchedMockDispatches.filter(({ body }) => typeof body !== 'undefined' ? matchValue(body, key.body) : true)\n if (matchedMockDispatches.length === 0) {\n throw new MockNotMatchedError(`Mock dispatch not matched for body '${key.body}'`)\n }\n\n // Match headers\n matchedMockDispatches = matchedMockDispatches.filter((mockDispatch) => matchHeaders(mockDispatch, key.headers))\n if (matchedMockDispatches.length === 0) {\n throw new MockNotMatchedError(`Mock dispatch not matched for headers '${typeof key.headers === 'object' ? JSON.stringify(key.headers) : key.headers}'`)\n }\n\n return matchedMockDispatches[0]\n}\n\nfunction addMockDispatch (mockDispatches, key, data) {\n const baseData = { timesInvoked: 0, times: 1, persist: false, consumed: false }\n const replyData = typeof data === 'function' ? { callback: data } : { ...data }\n const newMockDispatch = { ...baseData, ...key, pending: true, data: { error: null, ...replyData } }\n mockDispatches.push(newMockDispatch)\n return newMockDispatch\n}\n\nfunction deleteMockDispatch (mockDispatches, key) {\n const index = mockDispatches.findIndex(dispatch => {\n if (!dispatch.consumed) {\n return false\n }\n return matchKey(dispatch, key)\n })\n if (index !== -1) {\n mockDispatches.splice(index, 1)\n }\n}\n\nfunction buildKey (opts) {\n const { path, method, body, headers, query } = opts\n return {\n path,\n method,\n body,\n headers,\n query\n }\n}\n\nfunction generateKeyValues (data) {\n return Object.entries(data).reduce((keyValuePairs, [key, value]) => [\n ...keyValuePairs,\n Buffer.from(`${key}`),\n Array.isArray(value) ? value.map(x => Buffer.from(`${x}`)) : Buffer.from(`${value}`)\n ], [])\n}\n\n/**\n * @see https://developer.mozilla.org/en-US/docs/Web/HTTP/Status\n * @param {number} statusCode\n */\nfunction getStatusText (statusCode) {\n return STATUS_CODES[statusCode] || 'unknown'\n}\n\nasync function getResponse (body) {\n const buffers = []\n for await (const data of body) {\n buffers.push(data)\n }\n return Buffer.concat(buffers).toString('utf8')\n}\n\n/**\n * Mock dispatch function used to simulate undici dispatches\n */\nfunction mockDispatch (opts, handler) {\n // Get mock dispatch from built key\n const key = buildKey(opts)\n const mockDispatch = getMockDispatch(this[kDispatches], key)\n\n mockDispatch.timesInvoked++\n\n // Here's where we resolve a callback if a callback is present for the dispatch data.\n if (mockDispatch.data.callback) {\n mockDispatch.data = { ...mockDispatch.data, ...mockDispatch.data.callback(opts) }\n }\n\n // Parse mockDispatch data\n const { data: { statusCode, data, headers, trailers, error }, delay, persist } = mockDispatch\n const { timesInvoked, times } = mockDispatch\n\n // If it's used up and not persistent, mark as consumed\n mockDispatch.consumed = !persist && timesInvoked >= times\n mockDispatch.pending = timesInvoked < times\n\n // If specified, trigger dispatch error\n if (error !== null) {\n deleteMockDispatch(this[kDispatches], key)\n handler.onError(error)\n return true\n }\n\n // Handle the request with a delay if necessary\n if (typeof delay === 'number' && delay > 0) {\n setTimeout(() => {\n handleReply(this[kDispatches])\n }, delay)\n } else {\n handleReply(this[kDispatches])\n }\n\n function handleReply (mockDispatches, _data = data) {\n // fetch's HeadersList is a 1D string array\n const optsHeaders = Array.isArray(opts.headers)\n ? buildHeadersFromArray(opts.headers)\n : opts.headers\n const body = typeof _data === 'function'\n ? _data({ ...opts, headers: optsHeaders })\n : _data\n\n // util.types.isPromise is likely needed for jest.\n if (isPromise(body)) {\n // If handleReply is asynchronous, throwing an error\n // in the callback will reject the promise, rather than\n // synchronously throw the error, which breaks some tests.\n // Rather, we wait for the callback to resolve if it is a\n // promise, and then re-run handleReply with the new body.\n body.then((newData) => handleReply(mockDispatches, newData))\n return\n }\n\n const responseData = getResponseData(body)\n const responseHeaders = generateKeyValues(headers)\n const responseTrailers = generateKeyValues(trailers)\n\n handler.abort = nop\n handler.onHeaders(statusCode, responseHeaders, resume, getStatusText(statusCode))\n handler.onData(Buffer.from(responseData))\n handler.onComplete(responseTrailers)\n deleteMockDispatch(mockDispatches, key)\n }\n\n function resume () {}\n\n return true\n}\n\nfunction buildMockDispatch () {\n const agent = this[kMockAgent]\n const origin = this[kOrigin]\n const originalDispatch = this[kOriginalDispatch]\n\n return function dispatch (opts, handler) {\n if (agent.isMockActive) {\n try {\n mockDispatch.call(this, opts, handler)\n } catch (error) {\n if (error instanceof MockNotMatchedError) {\n const netConnect = agent[kGetNetConnect]()\n if (netConnect === false) {\n throw new MockNotMatchedError(`${error.message}: subsequent request to origin ${origin} was not allowed (net.connect disabled)`)\n }\n if (checkNetConnect(netConnect, origin)) {\n originalDispatch.call(this, opts, handler)\n } else {\n throw new MockNotMatchedError(`${error.message}: subsequent request to origin ${origin} was not allowed (net.connect is not enabled for this origin)`)\n }\n } else {\n throw error\n }\n }\n } else {\n originalDispatch.call(this, opts, handler)\n }\n }\n}\n\nfunction checkNetConnect (netConnect, origin) {\n const url = new URL(origin)\n if (netConnect === true) {\n return true\n } else if (Array.isArray(netConnect) && netConnect.some((matcher) => matchValue(matcher, url.host))) {\n return true\n }\n return false\n}\n\nfunction buildMockOptions (opts) {\n if (opts) {\n const { agent, ...mockOptions } = opts\n return mockOptions\n }\n}\n\nmodule.exports = {\n getResponseData,\n getMockDispatch,\n addMockDispatch,\n deleteMockDispatch,\n buildKey,\n generateKeyValues,\n matchValue,\n getResponse,\n getStatusText,\n mockDispatch,\n buildMockDispatch,\n checkNetConnect,\n buildMockOptions,\n getHeaderByName\n}\n","'use strict'\n\nconst { Transform } = require('stream')\nconst { Console } = require('console')\n\n/**\n * Gets the output of `console.table(…)` as a string.\n */\nmodule.exports = class PendingInterceptorsFormatter {\n constructor ({ disableColors } = {}) {\n this.transform = new Transform({\n transform (chunk, _enc, cb) {\n cb(null, chunk)\n }\n })\n\n this.logger = new Console({\n stdout: this.transform,\n inspectOptions: {\n colors: !disableColors && !process.env.CI\n }\n })\n }\n\n format (pendingInterceptors) {\n const withPrettyHeaders = pendingInterceptors.map(\n ({ method, path, data: { statusCode }, persist, times, timesInvoked, origin }) => ({\n Method: method,\n Origin: origin,\n Path: path,\n 'Status code': statusCode,\n Persistent: persist ? '✅' : '❌',\n Invocations: timesInvoked,\n Remaining: persist ? Infinity : times - timesInvoked\n }))\n\n this.logger.table(withPrettyHeaders)\n return this.transform.read().toString()\n }\n}\n","'use strict'\n\nconst singulars = {\n pronoun: 'it',\n is: 'is',\n was: 'was',\n this: 'this'\n}\n\nconst plurals = {\n pronoun: 'they',\n is: 'are',\n was: 'were',\n this: 'these'\n}\n\nmodule.exports = class Pluralizer {\n constructor (singular, plural) {\n this.singular = singular\n this.plural = plural\n }\n\n pluralize (count) {\n const one = count === 1\n const keys = one ? singulars : plurals\n const noun = one ? this.singular : this.plural\n return { ...keys, count, noun }\n }\n}\n","/* eslint-disable */\n\n'use strict'\n\n// Extracted from node/lib/internal/fixed_queue.js\n\n// Currently optimal queue size, tested on V8 6.0 - 6.6. Must be power of two.\nconst kSize = 2048;\nconst kMask = kSize - 1;\n\n// The FixedQueue is implemented as a singly-linked list of fixed-size\n// circular buffers. It looks something like this:\n//\n// head tail\n// | |\n// v v\n// +-----------+ <-----\\ +-----------+ <------\\ +-----------+\n// | [null] | \\----- | next | \\------- | next |\n// +-----------+ +-----------+ +-----------+\n// | item | <-- bottom | item | <-- bottom | [empty] |\n// | item | | item | | [empty] |\n// | item | | item | | [empty] |\n// | item | | item | | [empty] |\n// | item | | item | bottom --> | item |\n// | item | | item | | item |\n// | ... | | ... | | ... |\n// | item | | item | | item |\n// | item | | item | | item |\n// | [empty] | <-- top | item | | item |\n// | [empty] | | item | | item |\n// | [empty] | | [empty] | <-- top top --> | [empty] |\n// +-----------+ +-----------+ +-----------+\n//\n// Or, if there is only one circular buffer, it looks something\n// like either of these:\n//\n// head tail head tail\n// | | | |\n// v v v v\n// +-----------+ +-----------+\n// | [null] | | [null] |\n// +-----------+ +-----------+\n// | [empty] | | item |\n// | [empty] | | item |\n// | item | <-- bottom top --> | [empty] |\n// | item | | [empty] |\n// | [empty] | <-- top bottom --> | item |\n// | [empty] | | item |\n// +-----------+ +-----------+\n//\n// Adding a value means moving `top` forward by one, removing means\n// moving `bottom` forward by one. After reaching the end, the queue\n// wraps around.\n//\n// When `top === bottom` the current queue is empty and when\n// `top + 1 === bottom` it's full. This wastes a single space of storage\n// but allows much quicker checks.\n\nclass FixedCircularBuffer {\n constructor() {\n this.bottom = 0;\n this.top = 0;\n this.list = new Array(kSize);\n this.next = null;\n }\n\n isEmpty() {\n return this.top === this.bottom;\n }\n\n isFull() {\n return ((this.top + 1) & kMask) === this.bottom;\n }\n\n push(data) {\n this.list[this.top] = data;\n this.top = (this.top + 1) & kMask;\n }\n\n shift() {\n const nextItem = this.list[this.bottom];\n if (nextItem === undefined)\n return null;\n this.list[this.bottom] = undefined;\n this.bottom = (this.bottom + 1) & kMask;\n return nextItem;\n }\n}\n\nmodule.exports = class FixedQueue {\n constructor() {\n this.head = this.tail = new FixedCircularBuffer();\n }\n\n isEmpty() {\n return this.head.isEmpty();\n }\n\n push(data) {\n if (this.head.isFull()) {\n // Head is full: Creates a new queue, sets the old queue's `.next` to it,\n // and sets it as the new main queue.\n this.head = this.head.next = new FixedCircularBuffer();\n }\n this.head.push(data);\n }\n\n shift() {\n const tail = this.tail;\n const next = tail.shift();\n if (tail.isEmpty() && tail.next !== null) {\n // If there is another queue, it forms the new tail.\n this.tail = tail.next;\n }\n return next;\n }\n};\n","'use strict'\n\nconst DispatcherBase = require('./dispatcher-base')\nconst FixedQueue = require('./node/fixed-queue')\nconst { kConnected, kSize, kRunning, kPending, kQueued, kBusy, kFree, kUrl, kClose, kDestroy, kDispatch } = require('./core/symbols')\nconst PoolStats = require('./pool-stats')\n\nconst kClients = Symbol('clients')\nconst kNeedDrain = Symbol('needDrain')\nconst kQueue = Symbol('queue')\nconst kClosedResolve = Symbol('closed resolve')\nconst kOnDrain = Symbol('onDrain')\nconst kOnConnect = Symbol('onConnect')\nconst kOnDisconnect = Symbol('onDisconnect')\nconst kOnConnectionError = Symbol('onConnectionError')\nconst kGetDispatcher = Symbol('get dispatcher')\nconst kAddClient = Symbol('add client')\nconst kRemoveClient = Symbol('remove client')\nconst kStats = Symbol('stats')\n\nclass PoolBase extends DispatcherBase {\n constructor () {\n super()\n\n this[kQueue] = new FixedQueue()\n this[kClients] = []\n this[kQueued] = 0\n\n const pool = this\n\n this[kOnDrain] = function onDrain (origin, targets) {\n const queue = pool[kQueue]\n\n let needDrain = false\n\n while (!needDrain) {\n const item = queue.shift()\n if (!item) {\n break\n }\n pool[kQueued]--\n needDrain = !this.dispatch(item.opts, item.handler)\n }\n\n this[kNeedDrain] = needDrain\n\n if (!this[kNeedDrain] && pool[kNeedDrain]) {\n pool[kNeedDrain] = false\n pool.emit('drain', origin, [pool, ...targets])\n }\n\n if (pool[kClosedResolve] && queue.isEmpty()) {\n Promise\n .all(pool[kClients].map(c => c.close()))\n .then(pool[kClosedResolve])\n }\n }\n\n this[kOnConnect] = (origin, targets) => {\n pool.emit('connect', origin, [pool, ...targets])\n }\n\n this[kOnDisconnect] = (origin, targets, err) => {\n pool.emit('disconnect', origin, [pool, ...targets], err)\n }\n\n this[kOnConnectionError] = (origin, targets, err) => {\n pool.emit('connectionError', origin, [pool, ...targets], err)\n }\n\n this[kStats] = new PoolStats(this)\n }\n\n get [kBusy] () {\n return this[kNeedDrain]\n }\n\n get [kConnected] () {\n return this[kClients].filter(client => client[kConnected]).length\n }\n\n get [kFree] () {\n return this[kClients].filter(client => client[kConnected] && !client[kNeedDrain]).length\n }\n\n get [kPending] () {\n let ret = this[kQueued]\n for (const { [kPending]: pending } of this[kClients]) {\n ret += pending\n }\n return ret\n }\n\n get [kRunning] () {\n let ret = 0\n for (const { [kRunning]: running } of this[kClients]) {\n ret += running\n }\n return ret\n }\n\n get [kSize] () {\n let ret = this[kQueued]\n for (const { [kSize]: size } of this[kClients]) {\n ret += size\n }\n return ret\n }\n\n get stats () {\n return this[kStats]\n }\n\n async [kClose] () {\n if (this[kQueue].isEmpty()) {\n return Promise.all(this[kClients].map(c => c.close()))\n } else {\n return new Promise((resolve) => {\n this[kClosedResolve] = resolve\n })\n }\n }\n\n async [kDestroy] (err) {\n while (true) {\n const item = this[kQueue].shift()\n if (!item) {\n break\n }\n item.handler.onError(err)\n }\n\n return Promise.all(this[kClients].map(c => c.destroy(err)))\n }\n\n [kDispatch] (opts, handler) {\n const dispatcher = this[kGetDispatcher]()\n\n if (!dispatcher) {\n this[kNeedDrain] = true\n this[kQueue].push({ opts, handler })\n this[kQueued]++\n } else if (!dispatcher.dispatch(opts, handler)) {\n dispatcher[kNeedDrain] = true\n this[kNeedDrain] = !this[kGetDispatcher]()\n }\n\n return !this[kNeedDrain]\n }\n\n [kAddClient] (client) {\n client\n .on('drain', this[kOnDrain])\n .on('connect', this[kOnConnect])\n .on('disconnect', this[kOnDisconnect])\n .on('connectionError', this[kOnConnectionError])\n\n this[kClients].push(client)\n\n if (this[kNeedDrain]) {\n process.nextTick(() => {\n if (this[kNeedDrain]) {\n this[kOnDrain](client[kUrl], [this, client])\n }\n })\n }\n\n return this\n }\n\n [kRemoveClient] (client) {\n client.close(() => {\n const idx = this[kClients].indexOf(client)\n if (idx !== -1) {\n this[kClients].splice(idx, 1)\n }\n })\n\n this[kNeedDrain] = this[kClients].some(dispatcher => (\n !dispatcher[kNeedDrain] &&\n dispatcher.closed !== true &&\n dispatcher.destroyed !== true\n ))\n }\n}\n\nmodule.exports = {\n PoolBase,\n kClients,\n kNeedDrain,\n kAddClient,\n kRemoveClient,\n kGetDispatcher\n}\n","const { kFree, kConnected, kPending, kQueued, kRunning, kSize } = require('./core/symbols')\nconst kPool = Symbol('pool')\n\nclass PoolStats {\n constructor (pool) {\n this[kPool] = pool\n }\n\n get connected () {\n return this[kPool][kConnected]\n }\n\n get free () {\n return this[kPool][kFree]\n }\n\n get pending () {\n return this[kPool][kPending]\n }\n\n get queued () {\n return this[kPool][kQueued]\n }\n\n get running () {\n return this[kPool][kRunning]\n }\n\n get size () {\n return this[kPool][kSize]\n }\n}\n\nmodule.exports = PoolStats\n","'use strict'\n\nconst {\n PoolBase,\n kClients,\n kNeedDrain,\n kAddClient,\n kGetDispatcher\n} = require('./pool-base')\nconst Client = require('./client')\nconst {\n InvalidArgumentError\n} = require('./core/errors')\nconst util = require('./core/util')\nconst { kUrl, kInterceptors } = require('./core/symbols')\nconst buildConnector = require('./core/connect')\n\nconst kOptions = Symbol('options')\nconst kConnections = Symbol('connections')\nconst kFactory = Symbol('factory')\n\nfunction defaultFactory (origin, opts) {\n return new Client(origin, opts)\n}\n\nclass Pool extends PoolBase {\n constructor (origin, {\n connections,\n factory = defaultFactory,\n connect,\n connectTimeout,\n tls,\n maxCachedSessions,\n socketPath,\n autoSelectFamily,\n autoSelectFamilyAttemptTimeout,\n allowH2,\n ...options\n } = {}) {\n super()\n\n if (connections != null && (!Number.isFinite(connections) || connections < 0)) {\n throw new InvalidArgumentError('invalid connections')\n }\n\n if (typeof factory !== 'function') {\n throw new InvalidArgumentError('factory must be a function.')\n }\n\n if (connect != null && typeof connect !== 'function' && typeof connect !== 'object') {\n throw new InvalidArgumentError('connect must be a function or an object')\n }\n\n if (typeof connect !== 'function') {\n connect = buildConnector({\n ...tls,\n maxCachedSessions,\n allowH2,\n socketPath,\n timeout: connectTimeout,\n ...(util.nodeHasAutoSelectFamily && autoSelectFamily ? { autoSelectFamily, autoSelectFamilyAttemptTimeout } : undefined),\n ...connect\n })\n }\n\n this[kInterceptors] = options.interceptors && options.interceptors.Pool && Array.isArray(options.interceptors.Pool)\n ? options.interceptors.Pool\n : []\n this[kConnections] = connections || null\n this[kUrl] = util.parseOrigin(origin)\n this[kOptions] = { ...util.deepClone(options), connect, allowH2 }\n this[kOptions].interceptors = options.interceptors\n ? { ...options.interceptors }\n : undefined\n this[kFactory] = factory\n }\n\n [kGetDispatcher] () {\n let dispatcher = this[kClients].find(dispatcher => !dispatcher[kNeedDrain])\n\n if (dispatcher) {\n return dispatcher\n }\n\n if (!this[kConnections] || this[kClients].length < this[kConnections]) {\n dispatcher = this[kFactory](this[kUrl], this[kOptions])\n this[kAddClient](dispatcher)\n }\n\n return dispatcher\n }\n}\n\nmodule.exports = Pool\n","'use strict'\n\nconst { kProxy, kClose, kDestroy, kInterceptors } = require('./core/symbols')\nconst { URL } = require('url')\nconst Agent = require('./agent')\nconst Pool = require('./pool')\nconst DispatcherBase = require('./dispatcher-base')\nconst { InvalidArgumentError, RequestAbortedError } = require('./core/errors')\nconst buildConnector = require('./core/connect')\n\nconst kAgent = Symbol('proxy agent')\nconst kClient = Symbol('proxy client')\nconst kProxyHeaders = Symbol('proxy headers')\nconst kRequestTls = Symbol('request tls settings')\nconst kProxyTls = Symbol('proxy tls settings')\nconst kConnectEndpoint = Symbol('connect endpoint function')\n\nfunction defaultProtocolPort (protocol) {\n return protocol === 'https:' ? 443 : 80\n}\n\nfunction buildProxyOptions (opts) {\n if (typeof opts === 'string') {\n opts = { uri: opts }\n }\n\n if (!opts || !opts.uri) {\n throw new InvalidArgumentError('Proxy opts.uri is mandatory')\n }\n\n return {\n uri: opts.uri,\n protocol: opts.protocol || 'https'\n }\n}\n\nfunction defaultFactory (origin, opts) {\n return new Pool(origin, opts)\n}\n\nclass ProxyAgent extends DispatcherBase {\n constructor (opts) {\n super(opts)\n this[kProxy] = buildProxyOptions(opts)\n this[kAgent] = new Agent(opts)\n this[kInterceptors] = opts.interceptors && opts.interceptors.ProxyAgent && Array.isArray(opts.interceptors.ProxyAgent)\n ? opts.interceptors.ProxyAgent\n : []\n\n if (typeof opts === 'string') {\n opts = { uri: opts }\n }\n\n if (!opts || !opts.uri) {\n throw new InvalidArgumentError('Proxy opts.uri is mandatory')\n }\n\n const { clientFactory = defaultFactory } = opts\n\n if (typeof clientFactory !== 'function') {\n throw new InvalidArgumentError('Proxy opts.clientFactory must be a function.')\n }\n\n this[kRequestTls] = opts.requestTls\n this[kProxyTls] = opts.proxyTls\n this[kProxyHeaders] = opts.headers || {}\n\n const resolvedUrl = new URL(opts.uri)\n const { origin, port, host, username, password } = resolvedUrl\n\n if (opts.auth && opts.token) {\n throw new InvalidArgumentError('opts.auth cannot be used in combination with opts.token')\n } else if (opts.auth) {\n /* @deprecated in favour of opts.token */\n this[kProxyHeaders]['proxy-authorization'] = `Basic ${opts.auth}`\n } else if (opts.token) {\n this[kProxyHeaders]['proxy-authorization'] = opts.token\n } else if (username && password) {\n this[kProxyHeaders]['proxy-authorization'] = `Basic ${Buffer.from(`${decodeURIComponent(username)}:${decodeURIComponent(password)}`).toString('base64')}`\n }\n\n const connect = buildConnector({ ...opts.proxyTls })\n this[kConnectEndpoint] = buildConnector({ ...opts.requestTls })\n this[kClient] = clientFactory(resolvedUrl, { connect })\n this[kAgent] = new Agent({\n ...opts,\n connect: async (opts, callback) => {\n let requestedHost = opts.host\n if (!opts.port) {\n requestedHost += `:${defaultProtocolPort(opts.protocol)}`\n }\n try {\n const { socket, statusCode } = await this[kClient].connect({\n origin,\n port,\n path: requestedHost,\n signal: opts.signal,\n headers: {\n ...this[kProxyHeaders],\n host\n }\n })\n if (statusCode !== 200) {\n socket.on('error', () => {}).destroy()\n callback(new RequestAbortedError(`Proxy response (${statusCode}) !== 200 when HTTP Tunneling`))\n }\n if (opts.protocol !== 'https:') {\n callback(null, socket)\n return\n }\n let servername\n if (this[kRequestTls]) {\n servername = this[kRequestTls].servername\n } else {\n servername = opts.servername\n }\n this[kConnectEndpoint]({ ...opts, servername, httpSocket: socket }, callback)\n } catch (err) {\n callback(err)\n }\n }\n })\n }\n\n dispatch (opts, handler) {\n const { host } = new URL(opts.origin)\n const headers = buildHeaders(opts.headers)\n throwIfProxyAuthIsSent(headers)\n return this[kAgent].dispatch(\n {\n ...opts,\n headers: {\n ...headers,\n host\n }\n },\n handler\n )\n }\n\n async [kClose] () {\n await this[kAgent].close()\n await this[kClient].close()\n }\n\n async [kDestroy] () {\n await this[kAgent].destroy()\n await this[kClient].destroy()\n }\n}\n\n/**\n * @param {string[] | Record} headers\n * @returns {Record}\n */\nfunction buildHeaders (headers) {\n // When using undici.fetch, the headers list is stored\n // as an array.\n if (Array.isArray(headers)) {\n /** @type {Record} */\n const headersPair = {}\n\n for (let i = 0; i < headers.length; i += 2) {\n headersPair[headers[i]] = headers[i + 1]\n }\n\n return headersPair\n }\n\n return headers\n}\n\n/**\n * @param {Record} headers\n *\n * Previous versions of ProxyAgent suggests the Proxy-Authorization in request headers\n * Nevertheless, it was changed and to avoid a security vulnerability by end users\n * this check was created.\n * It should be removed in the next major version for performance reasons\n */\nfunction throwIfProxyAuthIsSent (headers) {\n const existProxyAuth = headers && Object.keys(headers)\n .find((key) => key.toLowerCase() === 'proxy-authorization')\n if (existProxyAuth) {\n throw new InvalidArgumentError('Proxy-Authorization should be sent in ProxyAgent constructor')\n }\n}\n\nmodule.exports = ProxyAgent\n","'use strict'\n\nlet fastNow = Date.now()\nlet fastNowTimeout\n\nconst fastTimers = []\n\nfunction onTimeout () {\n fastNow = Date.now()\n\n let len = fastTimers.length\n let idx = 0\n while (idx < len) {\n const timer = fastTimers[idx]\n\n if (timer.state === 0) {\n timer.state = fastNow + timer.delay\n } else if (timer.state > 0 && fastNow >= timer.state) {\n timer.state = -1\n timer.callback(timer.opaque)\n }\n\n if (timer.state === -1) {\n timer.state = -2\n if (idx !== len - 1) {\n fastTimers[idx] = fastTimers.pop()\n } else {\n fastTimers.pop()\n }\n len -= 1\n } else {\n idx += 1\n }\n }\n\n if (fastTimers.length > 0) {\n refreshTimeout()\n }\n}\n\nfunction refreshTimeout () {\n if (fastNowTimeout && fastNowTimeout.refresh) {\n fastNowTimeout.refresh()\n } else {\n clearTimeout(fastNowTimeout)\n fastNowTimeout = setTimeout(onTimeout, 1e3)\n if (fastNowTimeout.unref) {\n fastNowTimeout.unref()\n }\n }\n}\n\nclass Timeout {\n constructor (callback, delay, opaque) {\n this.callback = callback\n this.delay = delay\n this.opaque = opaque\n\n // -2 not in timer list\n // -1 in timer list but inactive\n // 0 in timer list waiting for time\n // > 0 in timer list waiting for time to expire\n this.state = -2\n\n this.refresh()\n }\n\n refresh () {\n if (this.state === -2) {\n fastTimers.push(this)\n if (!fastNowTimeout || fastTimers.length === 1) {\n refreshTimeout()\n }\n }\n\n this.state = 0\n }\n\n clear () {\n this.state = -1\n }\n}\n\nmodule.exports = {\n setTimeout (callback, delay, opaque) {\n return delay < 1e3\n ? setTimeout(callback, delay, opaque)\n : new Timeout(callback, delay, opaque)\n },\n clearTimeout (timeout) {\n if (timeout instanceof Timeout) {\n timeout.clear()\n } else {\n clearTimeout(timeout)\n }\n }\n}\n","'use strict'\n\nconst diagnosticsChannel = require('diagnostics_channel')\nconst { uid, states } = require('./constants')\nconst {\n kReadyState,\n kSentClose,\n kByteParser,\n kReceivedClose\n} = require('./symbols')\nconst { fireEvent, failWebsocketConnection } = require('./util')\nconst { CloseEvent } = require('./events')\nconst { makeRequest } = require('../fetch/request')\nconst { fetching } = require('../fetch/index')\nconst { Headers } = require('../fetch/headers')\nconst { getGlobalDispatcher } = require('../global')\nconst { kHeadersList } = require('../core/symbols')\n\nconst channels = {}\nchannels.open = diagnosticsChannel.channel('undici:websocket:open')\nchannels.close = diagnosticsChannel.channel('undici:websocket:close')\nchannels.socketError = diagnosticsChannel.channel('undici:websocket:socket_error')\n\n/** @type {import('crypto')} */\nlet crypto\ntry {\n crypto = require('crypto')\n} catch {\n\n}\n\n/**\n * @see https://websockets.spec.whatwg.org/#concept-websocket-establish\n * @param {URL} url\n * @param {string|string[]} protocols\n * @param {import('./websocket').WebSocket} ws\n * @param {(response: any) => void} onEstablish\n * @param {Partial} options\n */\nfunction establishWebSocketConnection (url, protocols, ws, onEstablish, options) {\n // 1. Let requestURL be a copy of url, with its scheme set to \"http\", if url’s\n // scheme is \"ws\", and to \"https\" otherwise.\n const requestURL = url\n\n requestURL.protocol = url.protocol === 'ws:' ? 'http:' : 'https:'\n\n // 2. Let request be a new request, whose URL is requestURL, client is client,\n // service-workers mode is \"none\", referrer is \"no-referrer\", mode is\n // \"websocket\", credentials mode is \"include\", cache mode is \"no-store\" ,\n // and redirect mode is \"error\".\n const request = makeRequest({\n urlList: [requestURL],\n serviceWorkers: 'none',\n referrer: 'no-referrer',\n mode: 'websocket',\n credentials: 'include',\n cache: 'no-store',\n redirect: 'error'\n })\n\n // Note: undici extension, allow setting custom headers.\n if (options.headers) {\n const headersList = new Headers(options.headers)[kHeadersList]\n\n request.headersList = headersList\n }\n\n // 3. Append (`Upgrade`, `websocket`) to request’s header list.\n // 4. Append (`Connection`, `Upgrade`) to request’s header list.\n // Note: both of these are handled by undici currently.\n // https://github.com/nodejs/undici/blob/68c269c4144c446f3f1220951338daef4a6b5ec4/lib/client.js#L1397\n\n // 5. Let keyValue be a nonce consisting of a randomly selected\n // 16-byte value that has been forgiving-base64-encoded and\n // isomorphic encoded.\n const keyValue = crypto.randomBytes(16).toString('base64')\n\n // 6. Append (`Sec-WebSocket-Key`, keyValue) to request’s\n // header list.\n request.headersList.append('sec-websocket-key', keyValue)\n\n // 7. Append (`Sec-WebSocket-Version`, `13`) to request’s\n // header list.\n request.headersList.append('sec-websocket-version', '13')\n\n // 8. For each protocol in protocols, combine\n // (`Sec-WebSocket-Protocol`, protocol) in request’s header\n // list.\n for (const protocol of protocols) {\n request.headersList.append('sec-websocket-protocol', protocol)\n }\n\n // 9. Let permessageDeflate be a user-agent defined\n // \"permessage-deflate\" extension header value.\n // https://github.com/mozilla/gecko-dev/blob/ce78234f5e653a5d3916813ff990f053510227bc/netwerk/protocol/websocket/WebSocketChannel.cpp#L2673\n // TODO: enable once permessage-deflate is supported\n const permessageDeflate = '' // 'permessage-deflate; 15'\n\n // 10. Append (`Sec-WebSocket-Extensions`, permessageDeflate) to\n // request’s header list.\n // request.headersList.append('sec-websocket-extensions', permessageDeflate)\n\n // 11. Fetch request with useParallelQueue set to true, and\n // processResponse given response being these steps:\n const controller = fetching({\n request,\n useParallelQueue: true,\n dispatcher: options.dispatcher ?? getGlobalDispatcher(),\n processResponse (response) {\n // 1. If response is a network error or its status is not 101,\n // fail the WebSocket connection.\n if (response.type === 'error' || response.status !== 101) {\n failWebsocketConnection(ws, 'Received network error or non-101 status code.')\n return\n }\n\n // 2. If protocols is not the empty list and extracting header\n // list values given `Sec-WebSocket-Protocol` and response’s\n // header list results in null, failure, or the empty byte\n // sequence, then fail the WebSocket connection.\n if (protocols.length !== 0 && !response.headersList.get('Sec-WebSocket-Protocol')) {\n failWebsocketConnection(ws, 'Server did not respond with sent protocols.')\n return\n }\n\n // 3. Follow the requirements stated step 2 to step 6, inclusive,\n // of the last set of steps in section 4.1 of The WebSocket\n // Protocol to validate response. This either results in fail\n // the WebSocket connection or the WebSocket connection is\n // established.\n\n // 2. If the response lacks an |Upgrade| header field or the |Upgrade|\n // header field contains a value that is not an ASCII case-\n // insensitive match for the value \"websocket\", the client MUST\n // _Fail the WebSocket Connection_.\n if (response.headersList.get('Upgrade')?.toLowerCase() !== 'websocket') {\n failWebsocketConnection(ws, 'Server did not set Upgrade header to \"websocket\".')\n return\n }\n\n // 3. If the response lacks a |Connection| header field or the\n // |Connection| header field doesn't contain a token that is an\n // ASCII case-insensitive match for the value \"Upgrade\", the client\n // MUST _Fail the WebSocket Connection_.\n if (response.headersList.get('Connection')?.toLowerCase() !== 'upgrade') {\n failWebsocketConnection(ws, 'Server did not set Connection header to \"upgrade\".')\n return\n }\n\n // 4. If the response lacks a |Sec-WebSocket-Accept| header field or\n // the |Sec-WebSocket-Accept| contains a value other than the\n // base64-encoded SHA-1 of the concatenation of the |Sec-WebSocket-\n // Key| (as a string, not base64-decoded) with the string \"258EAFA5-\n // E914-47DA-95CA-C5AB0DC85B11\" but ignoring any leading and\n // trailing whitespace, the client MUST _Fail the WebSocket\n // Connection_.\n const secWSAccept = response.headersList.get('Sec-WebSocket-Accept')\n const digest = crypto.createHash('sha1').update(keyValue + uid).digest('base64')\n if (secWSAccept !== digest) {\n failWebsocketConnection(ws, 'Incorrect hash received in Sec-WebSocket-Accept header.')\n return\n }\n\n // 5. If the response includes a |Sec-WebSocket-Extensions| header\n // field and this header field indicates the use of an extension\n // that was not present in the client's handshake (the server has\n // indicated an extension not requested by the client), the client\n // MUST _Fail the WebSocket Connection_. (The parsing of this\n // header field to determine which extensions are requested is\n // discussed in Section 9.1.)\n const secExtension = response.headersList.get('Sec-WebSocket-Extensions')\n\n if (secExtension !== null && secExtension !== permessageDeflate) {\n failWebsocketConnection(ws, 'Received different permessage-deflate than the one set.')\n return\n }\n\n // 6. If the response includes a |Sec-WebSocket-Protocol| header field\n // and this header field indicates the use of a subprotocol that was\n // not present in the client's handshake (the server has indicated a\n // subprotocol not requested by the client), the client MUST _Fail\n // the WebSocket Connection_.\n const secProtocol = response.headersList.get('Sec-WebSocket-Protocol')\n\n if (secProtocol !== null && secProtocol !== request.headersList.get('Sec-WebSocket-Protocol')) {\n failWebsocketConnection(ws, 'Protocol was not set in the opening handshake.')\n return\n }\n\n response.socket.on('data', onSocketData)\n response.socket.on('close', onSocketClose)\n response.socket.on('error', onSocketError)\n\n if (channels.open.hasSubscribers) {\n channels.open.publish({\n address: response.socket.address(),\n protocol: secProtocol,\n extensions: secExtension\n })\n }\n\n onEstablish(response)\n }\n })\n\n return controller\n}\n\n/**\n * @param {Buffer} chunk\n */\nfunction onSocketData (chunk) {\n if (!this.ws[kByteParser].write(chunk)) {\n this.pause()\n }\n}\n\n/**\n * @see https://websockets.spec.whatwg.org/#feedback-from-the-protocol\n * @see https://datatracker.ietf.org/doc/html/rfc6455#section-7.1.4\n */\nfunction onSocketClose () {\n const { ws } = this\n\n // If the TCP connection was closed after the\n // WebSocket closing handshake was completed, the WebSocket connection\n // is said to have been closed _cleanly_.\n const wasClean = ws[kSentClose] && ws[kReceivedClose]\n\n let code = 1005\n let reason = ''\n\n const result = ws[kByteParser].closingInfo\n\n if (result) {\n code = result.code ?? 1005\n reason = result.reason\n } else if (!ws[kSentClose]) {\n // If _The WebSocket\n // Connection is Closed_ and no Close control frame was received by the\n // endpoint (such as could occur if the underlying transport connection\n // is lost), _The WebSocket Connection Close Code_ is considered to be\n // 1006.\n code = 1006\n }\n\n // 1. Change the ready state to CLOSED (3).\n ws[kReadyState] = states.CLOSED\n\n // 2. If the user agent was required to fail the WebSocket\n // connection, or if the WebSocket connection was closed\n // after being flagged as full, fire an event named error\n // at the WebSocket object.\n // TODO\n\n // 3. Fire an event named close at the WebSocket object,\n // using CloseEvent, with the wasClean attribute\n // initialized to true if the connection closed cleanly\n // and false otherwise, the code attribute initialized to\n // the WebSocket connection close code, and the reason\n // attribute initialized to the result of applying UTF-8\n // decode without BOM to the WebSocket connection close\n // reason.\n fireEvent('close', ws, CloseEvent, {\n wasClean, code, reason\n })\n\n if (channels.close.hasSubscribers) {\n channels.close.publish({\n websocket: ws,\n code,\n reason\n })\n }\n}\n\nfunction onSocketError (error) {\n const { ws } = this\n\n ws[kReadyState] = states.CLOSING\n\n if (channels.socketError.hasSubscribers) {\n channels.socketError.publish(error)\n }\n\n this.destroy()\n}\n\nmodule.exports = {\n establishWebSocketConnection\n}\n","'use strict'\n\n// This is a Globally Unique Identifier unique used\n// to validate that the endpoint accepts websocket\n// connections.\n// See https://www.rfc-editor.org/rfc/rfc6455.html#section-1.3\nconst uid = '258EAFA5-E914-47DA-95CA-C5AB0DC85B11'\n\n/** @type {PropertyDescriptor} */\nconst staticPropertyDescriptors = {\n enumerable: true,\n writable: false,\n configurable: false\n}\n\nconst states = {\n CONNECTING: 0,\n OPEN: 1,\n CLOSING: 2,\n CLOSED: 3\n}\n\nconst opcodes = {\n CONTINUATION: 0x0,\n TEXT: 0x1,\n BINARY: 0x2,\n CLOSE: 0x8,\n PING: 0x9,\n PONG: 0xA\n}\n\nconst maxUnsigned16Bit = 2 ** 16 - 1 // 65535\n\nconst parserStates = {\n INFO: 0,\n PAYLOADLENGTH_16: 2,\n PAYLOADLENGTH_64: 3,\n READ_DATA: 4\n}\n\nconst emptyBuffer = Buffer.allocUnsafe(0)\n\nmodule.exports = {\n uid,\n staticPropertyDescriptors,\n states,\n opcodes,\n maxUnsigned16Bit,\n parserStates,\n emptyBuffer\n}\n","'use strict'\n\nconst { webidl } = require('../fetch/webidl')\nconst { kEnumerableProperty } = require('../core/util')\nconst { MessagePort } = require('worker_threads')\n\n/**\n * @see https://html.spec.whatwg.org/multipage/comms.html#messageevent\n */\nclass MessageEvent extends Event {\n #eventInit\n\n constructor (type, eventInitDict = {}) {\n webidl.argumentLengthCheck(arguments, 1, { header: 'MessageEvent constructor' })\n\n type = webidl.converters.DOMString(type)\n eventInitDict = webidl.converters.MessageEventInit(eventInitDict)\n\n super(type, eventInitDict)\n\n this.#eventInit = eventInitDict\n }\n\n get data () {\n webidl.brandCheck(this, MessageEvent)\n\n return this.#eventInit.data\n }\n\n get origin () {\n webidl.brandCheck(this, MessageEvent)\n\n return this.#eventInit.origin\n }\n\n get lastEventId () {\n webidl.brandCheck(this, MessageEvent)\n\n return this.#eventInit.lastEventId\n }\n\n get source () {\n webidl.brandCheck(this, MessageEvent)\n\n return this.#eventInit.source\n }\n\n get ports () {\n webidl.brandCheck(this, MessageEvent)\n\n if (!Object.isFrozen(this.#eventInit.ports)) {\n Object.freeze(this.#eventInit.ports)\n }\n\n return this.#eventInit.ports\n }\n\n initMessageEvent (\n type,\n bubbles = false,\n cancelable = false,\n data = null,\n origin = '',\n lastEventId = '',\n source = null,\n ports = []\n ) {\n webidl.brandCheck(this, MessageEvent)\n\n webidl.argumentLengthCheck(arguments, 1, { header: 'MessageEvent.initMessageEvent' })\n\n return new MessageEvent(type, {\n bubbles, cancelable, data, origin, lastEventId, source, ports\n })\n }\n}\n\n/**\n * @see https://websockets.spec.whatwg.org/#the-closeevent-interface\n */\nclass CloseEvent extends Event {\n #eventInit\n\n constructor (type, eventInitDict = {}) {\n webidl.argumentLengthCheck(arguments, 1, { header: 'CloseEvent constructor' })\n\n type = webidl.converters.DOMString(type)\n eventInitDict = webidl.converters.CloseEventInit(eventInitDict)\n\n super(type, eventInitDict)\n\n this.#eventInit = eventInitDict\n }\n\n get wasClean () {\n webidl.brandCheck(this, CloseEvent)\n\n return this.#eventInit.wasClean\n }\n\n get code () {\n webidl.brandCheck(this, CloseEvent)\n\n return this.#eventInit.code\n }\n\n get reason () {\n webidl.brandCheck(this, CloseEvent)\n\n return this.#eventInit.reason\n }\n}\n\n// https://html.spec.whatwg.org/multipage/webappapis.html#the-errorevent-interface\nclass ErrorEvent extends Event {\n #eventInit\n\n constructor (type, eventInitDict) {\n webidl.argumentLengthCheck(arguments, 1, { header: 'ErrorEvent constructor' })\n\n super(type, eventInitDict)\n\n type = webidl.converters.DOMString(type)\n eventInitDict = webidl.converters.ErrorEventInit(eventInitDict ?? {})\n\n this.#eventInit = eventInitDict\n }\n\n get message () {\n webidl.brandCheck(this, ErrorEvent)\n\n return this.#eventInit.message\n }\n\n get filename () {\n webidl.brandCheck(this, ErrorEvent)\n\n return this.#eventInit.filename\n }\n\n get lineno () {\n webidl.brandCheck(this, ErrorEvent)\n\n return this.#eventInit.lineno\n }\n\n get colno () {\n webidl.brandCheck(this, ErrorEvent)\n\n return this.#eventInit.colno\n }\n\n get error () {\n webidl.brandCheck(this, ErrorEvent)\n\n return this.#eventInit.error\n }\n}\n\nObject.defineProperties(MessageEvent.prototype, {\n [Symbol.toStringTag]: {\n value: 'MessageEvent',\n configurable: true\n },\n data: kEnumerableProperty,\n origin: kEnumerableProperty,\n lastEventId: kEnumerableProperty,\n source: kEnumerableProperty,\n ports: kEnumerableProperty,\n initMessageEvent: kEnumerableProperty\n})\n\nObject.defineProperties(CloseEvent.prototype, {\n [Symbol.toStringTag]: {\n value: 'CloseEvent',\n configurable: true\n },\n reason: kEnumerableProperty,\n code: kEnumerableProperty,\n wasClean: kEnumerableProperty\n})\n\nObject.defineProperties(ErrorEvent.prototype, {\n [Symbol.toStringTag]: {\n value: 'ErrorEvent',\n configurable: true\n },\n message: kEnumerableProperty,\n filename: kEnumerableProperty,\n lineno: kEnumerableProperty,\n colno: kEnumerableProperty,\n error: kEnumerableProperty\n})\n\nwebidl.converters.MessagePort = webidl.interfaceConverter(MessagePort)\n\nwebidl.converters['sequence'] = webidl.sequenceConverter(\n webidl.converters.MessagePort\n)\n\nconst eventInit = [\n {\n key: 'bubbles',\n converter: webidl.converters.boolean,\n defaultValue: false\n },\n {\n key: 'cancelable',\n converter: webidl.converters.boolean,\n defaultValue: false\n },\n {\n key: 'composed',\n converter: webidl.converters.boolean,\n defaultValue: false\n }\n]\n\nwebidl.converters.MessageEventInit = webidl.dictionaryConverter([\n ...eventInit,\n {\n key: 'data',\n converter: webidl.converters.any,\n defaultValue: null\n },\n {\n key: 'origin',\n converter: webidl.converters.USVString,\n defaultValue: ''\n },\n {\n key: 'lastEventId',\n converter: webidl.converters.DOMString,\n defaultValue: ''\n },\n {\n key: 'source',\n // Node doesn't implement WindowProxy or ServiceWorker, so the only\n // valid value for source is a MessagePort.\n converter: webidl.nullableConverter(webidl.converters.MessagePort),\n defaultValue: null\n },\n {\n key: 'ports',\n converter: webidl.converters['sequence'],\n get defaultValue () {\n return []\n }\n }\n])\n\nwebidl.converters.CloseEventInit = webidl.dictionaryConverter([\n ...eventInit,\n {\n key: 'wasClean',\n converter: webidl.converters.boolean,\n defaultValue: false\n },\n {\n key: 'code',\n converter: webidl.converters['unsigned short'],\n defaultValue: 0\n },\n {\n key: 'reason',\n converter: webidl.converters.USVString,\n defaultValue: ''\n }\n])\n\nwebidl.converters.ErrorEventInit = webidl.dictionaryConverter([\n ...eventInit,\n {\n key: 'message',\n converter: webidl.converters.DOMString,\n defaultValue: ''\n },\n {\n key: 'filename',\n converter: webidl.converters.USVString,\n defaultValue: ''\n },\n {\n key: 'lineno',\n converter: webidl.converters['unsigned long'],\n defaultValue: 0\n },\n {\n key: 'colno',\n converter: webidl.converters['unsigned long'],\n defaultValue: 0\n },\n {\n key: 'error',\n converter: webidl.converters.any\n }\n])\n\nmodule.exports = {\n MessageEvent,\n CloseEvent,\n ErrorEvent\n}\n","'use strict'\n\nconst { maxUnsigned16Bit } = require('./constants')\n\n/** @type {import('crypto')} */\nlet crypto\ntry {\n crypto = require('crypto')\n} catch {\n\n}\n\nclass WebsocketFrameSend {\n /**\n * @param {Buffer|undefined} data\n */\n constructor (data) {\n this.frameData = data\n this.maskKey = crypto.randomBytes(4)\n }\n\n createFrame (opcode) {\n const bodyLength = this.frameData?.byteLength ?? 0\n\n /** @type {number} */\n let payloadLength = bodyLength // 0-125\n let offset = 6\n\n if (bodyLength > maxUnsigned16Bit) {\n offset += 8 // payload length is next 8 bytes\n payloadLength = 127\n } else if (bodyLength > 125) {\n offset += 2 // payload length is next 2 bytes\n payloadLength = 126\n }\n\n const buffer = Buffer.allocUnsafe(bodyLength + offset)\n\n // Clear first 2 bytes, everything else is overwritten\n buffer[0] = buffer[1] = 0\n buffer[0] |= 0x80 // FIN\n buffer[0] = (buffer[0] & 0xF0) + opcode // opcode\n\n /*! ws. MIT License. Einar Otto Stangvik */\n buffer[offset - 4] = this.maskKey[0]\n buffer[offset - 3] = this.maskKey[1]\n buffer[offset - 2] = this.maskKey[2]\n buffer[offset - 1] = this.maskKey[3]\n\n buffer[1] = payloadLength\n\n if (payloadLength === 126) {\n buffer.writeUInt16BE(bodyLength, 2)\n } else if (payloadLength === 127) {\n // Clear extended payload length\n buffer[2] = buffer[3] = 0\n buffer.writeUIntBE(bodyLength, 4, 6)\n }\n\n buffer[1] |= 0x80 // MASK\n\n // mask body\n for (let i = 0; i < bodyLength; i++) {\n buffer[offset + i] = this.frameData[i] ^ this.maskKey[i % 4]\n }\n\n return buffer\n }\n}\n\nmodule.exports = {\n WebsocketFrameSend\n}\n","'use strict'\n\nconst { Writable } = require('stream')\nconst diagnosticsChannel = require('diagnostics_channel')\nconst { parserStates, opcodes, states, emptyBuffer } = require('./constants')\nconst { kReadyState, kSentClose, kResponse, kReceivedClose } = require('./symbols')\nconst { isValidStatusCode, failWebsocketConnection, websocketMessageReceived } = require('./util')\nconst { WebsocketFrameSend } = require('./frame')\n\n// This code was influenced by ws released under the MIT license.\n// Copyright (c) 2011 Einar Otto Stangvik \n// Copyright (c) 2013 Arnout Kazemier and contributors\n// Copyright (c) 2016 Luigi Pinca and contributors\n\nconst channels = {}\nchannels.ping = diagnosticsChannel.channel('undici:websocket:ping')\nchannels.pong = diagnosticsChannel.channel('undici:websocket:pong')\n\nclass ByteParser extends Writable {\n #buffers = []\n #byteOffset = 0\n\n #state = parserStates.INFO\n\n #info = {}\n #fragments = []\n\n constructor (ws) {\n super()\n\n this.ws = ws\n }\n\n /**\n * @param {Buffer} chunk\n * @param {() => void} callback\n */\n _write (chunk, _, callback) {\n this.#buffers.push(chunk)\n this.#byteOffset += chunk.length\n\n this.run(callback)\n }\n\n /**\n * Runs whenever a new chunk is received.\n * Callback is called whenever there are no more chunks buffering,\n * or not enough bytes are buffered to parse.\n */\n run (callback) {\n while (true) {\n if (this.#state === parserStates.INFO) {\n // If there aren't enough bytes to parse the payload length, etc.\n if (this.#byteOffset < 2) {\n return callback()\n }\n\n const buffer = this.consume(2)\n\n this.#info.fin = (buffer[0] & 0x80) !== 0\n this.#info.opcode = buffer[0] & 0x0F\n\n // If we receive a fragmented message, we use the type of the first\n // frame to parse the full message as binary/text, when it's terminated\n this.#info.originalOpcode ??= this.#info.opcode\n\n this.#info.fragmented = !this.#info.fin && this.#info.opcode !== opcodes.CONTINUATION\n\n if (this.#info.fragmented && this.#info.opcode !== opcodes.BINARY && this.#info.opcode !== opcodes.TEXT) {\n // Only text and binary frames can be fragmented\n failWebsocketConnection(this.ws, 'Invalid frame type was fragmented.')\n return\n }\n\n const payloadLength = buffer[1] & 0x7F\n\n if (payloadLength <= 125) {\n this.#info.payloadLength = payloadLength\n this.#state = parserStates.READ_DATA\n } else if (payloadLength === 126) {\n this.#state = parserStates.PAYLOADLENGTH_16\n } else if (payloadLength === 127) {\n this.#state = parserStates.PAYLOADLENGTH_64\n }\n\n if (this.#info.fragmented && payloadLength > 125) {\n // A fragmented frame can't be fragmented itself\n failWebsocketConnection(this.ws, 'Fragmented frame exceeded 125 bytes.')\n return\n } else if (\n (this.#info.opcode === opcodes.PING ||\n this.#info.opcode === opcodes.PONG ||\n this.#info.opcode === opcodes.CLOSE) &&\n payloadLength > 125\n ) {\n // Control frames can have a payload length of 125 bytes MAX\n failWebsocketConnection(this.ws, 'Payload length for control frame exceeded 125 bytes.')\n return\n } else if (this.#info.opcode === opcodes.CLOSE) {\n if (payloadLength === 1) {\n failWebsocketConnection(this.ws, 'Received close frame with a 1-byte body.')\n return\n }\n\n const body = this.consume(payloadLength)\n\n this.#info.closeInfo = this.parseCloseBody(false, body)\n\n if (!this.ws[kSentClose]) {\n // If an endpoint receives a Close frame and did not previously send a\n // Close frame, the endpoint MUST send a Close frame in response. (When\n // sending a Close frame in response, the endpoint typically echos the\n // status code it received.)\n const body = Buffer.allocUnsafe(2)\n body.writeUInt16BE(this.#info.closeInfo.code, 0)\n const closeFrame = new WebsocketFrameSend(body)\n\n this.ws[kResponse].socket.write(\n closeFrame.createFrame(opcodes.CLOSE),\n (err) => {\n if (!err) {\n this.ws[kSentClose] = true\n }\n }\n )\n }\n\n // Upon either sending or receiving a Close control frame, it is said\n // that _The WebSocket Closing Handshake is Started_ and that the\n // WebSocket connection is in the CLOSING state.\n this.ws[kReadyState] = states.CLOSING\n this.ws[kReceivedClose] = true\n\n this.end()\n\n return\n } else if (this.#info.opcode === opcodes.PING) {\n // Upon receipt of a Ping frame, an endpoint MUST send a Pong frame in\n // response, unless it already received a Close frame.\n // A Pong frame sent in response to a Ping frame must have identical\n // \"Application data\"\n\n const body = this.consume(payloadLength)\n\n if (!this.ws[kReceivedClose]) {\n const frame = new WebsocketFrameSend(body)\n\n this.ws[kResponse].socket.write(frame.createFrame(opcodes.PONG))\n\n if (channels.ping.hasSubscribers) {\n channels.ping.publish({\n payload: body\n })\n }\n }\n\n this.#state = parserStates.INFO\n\n if (this.#byteOffset > 0) {\n continue\n } else {\n callback()\n return\n }\n } else if (this.#info.opcode === opcodes.PONG) {\n // A Pong frame MAY be sent unsolicited. This serves as a\n // unidirectional heartbeat. A response to an unsolicited Pong frame is\n // not expected.\n\n const body = this.consume(payloadLength)\n\n if (channels.pong.hasSubscribers) {\n channels.pong.publish({\n payload: body\n })\n }\n\n if (this.#byteOffset > 0) {\n continue\n } else {\n callback()\n return\n }\n }\n } else if (this.#state === parserStates.PAYLOADLENGTH_16) {\n if (this.#byteOffset < 2) {\n return callback()\n }\n\n const buffer = this.consume(2)\n\n this.#info.payloadLength = buffer.readUInt16BE(0)\n this.#state = parserStates.READ_DATA\n } else if (this.#state === parserStates.PAYLOADLENGTH_64) {\n if (this.#byteOffset < 8) {\n return callback()\n }\n\n const buffer = this.consume(8)\n const upper = buffer.readUInt32BE(0)\n\n // 2^31 is the maxinimum bytes an arraybuffer can contain\n // on 32-bit systems. Although, on 64-bit systems, this is\n // 2^53-1 bytes.\n // https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Errors/Invalid_array_length\n // https://source.chromium.org/chromium/chromium/src/+/main:v8/src/common/globals.h;drc=1946212ac0100668f14eb9e2843bdd846e510a1e;bpv=1;bpt=1;l=1275\n // https://source.chromium.org/chromium/chromium/src/+/main:v8/src/objects/js-array-buffer.h;l=34;drc=1946212ac0100668f14eb9e2843bdd846e510a1e\n if (upper > 2 ** 31 - 1) {\n failWebsocketConnection(this.ws, 'Received payload length > 2^31 bytes.')\n return\n }\n\n const lower = buffer.readUInt32BE(4)\n\n this.#info.payloadLength = (upper << 8) + lower\n this.#state = parserStates.READ_DATA\n } else if (this.#state === parserStates.READ_DATA) {\n if (this.#byteOffset < this.#info.payloadLength) {\n // If there is still more data in this chunk that needs to be read\n return callback()\n } else if (this.#byteOffset >= this.#info.payloadLength) {\n // If the server sent multiple frames in a single chunk\n\n const body = this.consume(this.#info.payloadLength)\n\n this.#fragments.push(body)\n\n // If the frame is unfragmented, or a fragmented frame was terminated,\n // a message was received\n if (!this.#info.fragmented || (this.#info.fin && this.#info.opcode === opcodes.CONTINUATION)) {\n const fullMessage = Buffer.concat(this.#fragments)\n\n websocketMessageReceived(this.ws, this.#info.originalOpcode, fullMessage)\n\n this.#info = {}\n this.#fragments.length = 0\n }\n\n this.#state = parserStates.INFO\n }\n }\n\n if (this.#byteOffset > 0) {\n continue\n } else {\n callback()\n break\n }\n }\n }\n\n /**\n * Take n bytes from the buffered Buffers\n * @param {number} n\n * @returns {Buffer|null}\n */\n consume (n) {\n if (n > this.#byteOffset) {\n return null\n } else if (n === 0) {\n return emptyBuffer\n }\n\n if (this.#buffers[0].length === n) {\n this.#byteOffset -= this.#buffers[0].length\n return this.#buffers.shift()\n }\n\n const buffer = Buffer.allocUnsafe(n)\n let offset = 0\n\n while (offset !== n) {\n const next = this.#buffers[0]\n const { length } = next\n\n if (length + offset === n) {\n buffer.set(this.#buffers.shift(), offset)\n break\n } else if (length + offset > n) {\n buffer.set(next.subarray(0, n - offset), offset)\n this.#buffers[0] = next.subarray(n - offset)\n break\n } else {\n buffer.set(this.#buffers.shift(), offset)\n offset += next.length\n }\n }\n\n this.#byteOffset -= n\n\n return buffer\n }\n\n parseCloseBody (onlyCode, data) {\n // https://datatracker.ietf.org/doc/html/rfc6455#section-7.1.5\n /** @type {number|undefined} */\n let code\n\n if (data.length >= 2) {\n // _The WebSocket Connection Close Code_ is\n // defined as the status code (Section 7.4) contained in the first Close\n // control frame received by the application\n code = data.readUInt16BE(0)\n }\n\n if (onlyCode) {\n if (!isValidStatusCode(code)) {\n return null\n }\n\n return { code }\n }\n\n // https://datatracker.ietf.org/doc/html/rfc6455#section-7.1.6\n /** @type {Buffer} */\n let reason = data.subarray(2)\n\n // Remove BOM\n if (reason[0] === 0xEF && reason[1] === 0xBB && reason[2] === 0xBF) {\n reason = reason.subarray(3)\n }\n\n if (code !== undefined && !isValidStatusCode(code)) {\n return null\n }\n\n try {\n // TODO: optimize this\n reason = new TextDecoder('utf-8', { fatal: true }).decode(reason)\n } catch {\n return null\n }\n\n return { code, reason }\n }\n\n get closingInfo () {\n return this.#info.closeInfo\n }\n}\n\nmodule.exports = {\n ByteParser\n}\n","'use strict'\n\nmodule.exports = {\n kWebSocketURL: Symbol('url'),\n kReadyState: Symbol('ready state'),\n kController: Symbol('controller'),\n kResponse: Symbol('response'),\n kBinaryType: Symbol('binary type'),\n kSentClose: Symbol('sent close'),\n kReceivedClose: Symbol('received close'),\n kByteParser: Symbol('byte parser')\n}\n","'use strict'\n\nconst { kReadyState, kController, kResponse, kBinaryType, kWebSocketURL } = require('./symbols')\nconst { states, opcodes } = require('./constants')\nconst { MessageEvent, ErrorEvent } = require('./events')\n\n/* globals Blob */\n\n/**\n * @param {import('./websocket').WebSocket} ws\n */\nfunction isEstablished (ws) {\n // If the server's response is validated as provided for above, it is\n // said that _The WebSocket Connection is Established_ and that the\n // WebSocket Connection is in the OPEN state.\n return ws[kReadyState] === states.OPEN\n}\n\n/**\n * @param {import('./websocket').WebSocket} ws\n */\nfunction isClosing (ws) {\n // Upon either sending or receiving a Close control frame, it is said\n // that _The WebSocket Closing Handshake is Started_ and that the\n // WebSocket connection is in the CLOSING state.\n return ws[kReadyState] === states.CLOSING\n}\n\n/**\n * @param {import('./websocket').WebSocket} ws\n */\nfunction isClosed (ws) {\n return ws[kReadyState] === states.CLOSED\n}\n\n/**\n * @see https://dom.spec.whatwg.org/#concept-event-fire\n * @param {string} e\n * @param {EventTarget} target\n * @param {EventInit | undefined} eventInitDict\n */\nfunction fireEvent (e, target, eventConstructor = Event, eventInitDict) {\n // 1. If eventConstructor is not given, then let eventConstructor be Event.\n\n // 2. Let event be the result of creating an event given eventConstructor,\n // in the relevant realm of target.\n // 3. Initialize event’s type attribute to e.\n const event = new eventConstructor(e, eventInitDict) // eslint-disable-line new-cap\n\n // 4. Initialize any other IDL attributes of event as described in the\n // invocation of this algorithm.\n\n // 5. Return the result of dispatching event at target, with legacy target\n // override flag set if set.\n target.dispatchEvent(event)\n}\n\n/**\n * @see https://websockets.spec.whatwg.org/#feedback-from-the-protocol\n * @param {import('./websocket').WebSocket} ws\n * @param {number} type Opcode\n * @param {Buffer} data application data\n */\nfunction websocketMessageReceived (ws, type, data) {\n // 1. If ready state is not OPEN (1), then return.\n if (ws[kReadyState] !== states.OPEN) {\n return\n }\n\n // 2. Let dataForEvent be determined by switching on type and binary type:\n let dataForEvent\n\n if (type === opcodes.TEXT) {\n // -> type indicates that the data is Text\n // a new DOMString containing data\n try {\n dataForEvent = new TextDecoder('utf-8', { fatal: true }).decode(data)\n } catch {\n failWebsocketConnection(ws, 'Received invalid UTF-8 in text frame.')\n return\n }\n } else if (type === opcodes.BINARY) {\n if (ws[kBinaryType] === 'blob') {\n // -> type indicates that the data is Binary and binary type is \"blob\"\n // a new Blob object, created in the relevant Realm of the WebSocket\n // object, that represents data as its raw data\n dataForEvent = new Blob([data])\n } else {\n // -> type indicates that the data is Binary and binary type is \"arraybuffer\"\n // a new ArrayBuffer object, created in the relevant Realm of the\n // WebSocket object, whose contents are data\n dataForEvent = new Uint8Array(data).buffer\n }\n }\n\n // 3. Fire an event named message at the WebSocket object, using MessageEvent,\n // with the origin attribute initialized to the serialization of the WebSocket\n // object’s url's origin, and the data attribute initialized to dataForEvent.\n fireEvent('message', ws, MessageEvent, {\n origin: ws[kWebSocketURL].origin,\n data: dataForEvent\n })\n}\n\n/**\n * @see https://datatracker.ietf.org/doc/html/rfc6455\n * @see https://datatracker.ietf.org/doc/html/rfc2616\n * @see https://bugs.chromium.org/p/chromium/issues/detail?id=398407\n * @param {string} protocol\n */\nfunction isValidSubprotocol (protocol) {\n // If present, this value indicates one\n // or more comma-separated subprotocol the client wishes to speak,\n // ordered by preference. The elements that comprise this value\n // MUST be non-empty strings with characters in the range U+0021 to\n // U+007E not including separator characters as defined in\n // [RFC2616] and MUST all be unique strings.\n if (protocol.length === 0) {\n return false\n }\n\n for (const char of protocol) {\n const code = char.charCodeAt(0)\n\n if (\n code < 0x21 ||\n code > 0x7E ||\n char === '(' ||\n char === ')' ||\n char === '<' ||\n char === '>' ||\n char === '@' ||\n char === ',' ||\n char === ';' ||\n char === ':' ||\n char === '\\\\' ||\n char === '\"' ||\n char === '/' ||\n char === '[' ||\n char === ']' ||\n char === '?' ||\n char === '=' ||\n char === '{' ||\n char === '}' ||\n code === 32 || // SP\n code === 9 // HT\n ) {\n return false\n }\n }\n\n return true\n}\n\n/**\n * @see https://datatracker.ietf.org/doc/html/rfc6455#section-7-4\n * @param {number} code\n */\nfunction isValidStatusCode (code) {\n if (code >= 1000 && code < 1015) {\n return (\n code !== 1004 && // reserved\n code !== 1005 && // \"MUST NOT be set as a status code\"\n code !== 1006 // \"MUST NOT be set as a status code\"\n )\n }\n\n return code >= 3000 && code <= 4999\n}\n\n/**\n * @param {import('./websocket').WebSocket} ws\n * @param {string|undefined} reason\n */\nfunction failWebsocketConnection (ws, reason) {\n const { [kController]: controller, [kResponse]: response } = ws\n\n controller.abort()\n\n if (response?.socket && !response.socket.destroyed) {\n response.socket.destroy()\n }\n\n if (reason) {\n fireEvent('error', ws, ErrorEvent, {\n error: new Error(reason)\n })\n }\n}\n\nmodule.exports = {\n isEstablished,\n isClosing,\n isClosed,\n fireEvent,\n isValidSubprotocol,\n isValidStatusCode,\n failWebsocketConnection,\n websocketMessageReceived\n}\n","'use strict'\n\nconst { webidl } = require('../fetch/webidl')\nconst { DOMException } = require('../fetch/constants')\nconst { URLSerializer } = require('../fetch/dataURL')\nconst { getGlobalOrigin } = require('../fetch/global')\nconst { staticPropertyDescriptors, states, opcodes, emptyBuffer } = require('./constants')\nconst {\n kWebSocketURL,\n kReadyState,\n kController,\n kBinaryType,\n kResponse,\n kSentClose,\n kByteParser\n} = require('./symbols')\nconst { isEstablished, isClosing, isValidSubprotocol, failWebsocketConnection, fireEvent } = require('./util')\nconst { establishWebSocketConnection } = require('./connection')\nconst { WebsocketFrameSend } = require('./frame')\nconst { ByteParser } = require('./receiver')\nconst { kEnumerableProperty, isBlobLike } = require('../core/util')\nconst { getGlobalDispatcher } = require('../global')\nconst { types } = require('util')\n\nlet experimentalWarned = false\n\n// https://websockets.spec.whatwg.org/#interface-definition\nclass WebSocket extends EventTarget {\n #events = {\n open: null,\n error: null,\n close: null,\n message: null\n }\n\n #bufferedAmount = 0\n #protocol = ''\n #extensions = ''\n\n /**\n * @param {string} url\n * @param {string|string[]} protocols\n */\n constructor (url, protocols = []) {\n super()\n\n webidl.argumentLengthCheck(arguments, 1, { header: 'WebSocket constructor' })\n\n if (!experimentalWarned) {\n experimentalWarned = true\n process.emitWarning('WebSockets are experimental, expect them to change at any time.', {\n code: 'UNDICI-WS'\n })\n }\n\n const options = webidl.converters['DOMString or sequence or WebSocketInit'](protocols)\n\n url = webidl.converters.USVString(url)\n protocols = options.protocols\n\n // 1. Let baseURL be this's relevant settings object's API base URL.\n const baseURL = getGlobalOrigin()\n\n // 1. Let urlRecord be the result of applying the URL parser to url with baseURL.\n let urlRecord\n\n try {\n urlRecord = new URL(url, baseURL)\n } catch (e) {\n // 3. If urlRecord is failure, then throw a \"SyntaxError\" DOMException.\n throw new DOMException(e, 'SyntaxError')\n }\n\n // 4. If urlRecord’s scheme is \"http\", then set urlRecord’s scheme to \"ws\".\n if (urlRecord.protocol === 'http:') {\n urlRecord.protocol = 'ws:'\n } else if (urlRecord.protocol === 'https:') {\n // 5. Otherwise, if urlRecord’s scheme is \"https\", set urlRecord’s scheme to \"wss\".\n urlRecord.protocol = 'wss:'\n }\n\n // 6. If urlRecord’s scheme is not \"ws\" or \"wss\", then throw a \"SyntaxError\" DOMException.\n if (urlRecord.protocol !== 'ws:' && urlRecord.protocol !== 'wss:') {\n throw new DOMException(\n `Expected a ws: or wss: protocol, got ${urlRecord.protocol}`,\n 'SyntaxError'\n )\n }\n\n // 7. If urlRecord’s fragment is non-null, then throw a \"SyntaxError\"\n // DOMException.\n if (urlRecord.hash || urlRecord.href.endsWith('#')) {\n throw new DOMException('Got fragment', 'SyntaxError')\n }\n\n // 8. If protocols is a string, set protocols to a sequence consisting\n // of just that string.\n if (typeof protocols === 'string') {\n protocols = [protocols]\n }\n\n // 9. If any of the values in protocols occur more than once or otherwise\n // fail to match the requirements for elements that comprise the value\n // of `Sec-WebSocket-Protocol` fields as defined by The WebSocket\n // protocol, then throw a \"SyntaxError\" DOMException.\n if (protocols.length !== new Set(protocols.map(p => p.toLowerCase())).size) {\n throw new DOMException('Invalid Sec-WebSocket-Protocol value', 'SyntaxError')\n }\n\n if (protocols.length > 0 && !protocols.every(p => isValidSubprotocol(p))) {\n throw new DOMException('Invalid Sec-WebSocket-Protocol value', 'SyntaxError')\n }\n\n // 10. Set this's url to urlRecord.\n this[kWebSocketURL] = new URL(urlRecord.href)\n\n // 11. Let client be this's relevant settings object.\n\n // 12. Run this step in parallel:\n\n // 1. Establish a WebSocket connection given urlRecord, protocols,\n // and client.\n this[kController] = establishWebSocketConnection(\n urlRecord,\n protocols,\n this,\n (response) => this.#onConnectionEstablished(response),\n options\n )\n\n // Each WebSocket object has an associated ready state, which is a\n // number representing the state of the connection. Initially it must\n // be CONNECTING (0).\n this[kReadyState] = WebSocket.CONNECTING\n\n // The extensions attribute must initially return the empty string.\n\n // The protocol attribute must initially return the empty string.\n\n // Each WebSocket object has an associated binary type, which is a\n // BinaryType. Initially it must be \"blob\".\n this[kBinaryType] = 'blob'\n }\n\n /**\n * @see https://websockets.spec.whatwg.org/#dom-websocket-close\n * @param {number|undefined} code\n * @param {string|undefined} reason\n */\n close (code = undefined, reason = undefined) {\n webidl.brandCheck(this, WebSocket)\n\n if (code !== undefined) {\n code = webidl.converters['unsigned short'](code, { clamp: true })\n }\n\n if (reason !== undefined) {\n reason = webidl.converters.USVString(reason)\n }\n\n // 1. If code is present, but is neither an integer equal to 1000 nor an\n // integer in the range 3000 to 4999, inclusive, throw an\n // \"InvalidAccessError\" DOMException.\n if (code !== undefined) {\n if (code !== 1000 && (code < 3000 || code > 4999)) {\n throw new DOMException('invalid code', 'InvalidAccessError')\n }\n }\n\n let reasonByteLength = 0\n\n // 2. If reason is present, then run these substeps:\n if (reason !== undefined) {\n // 1. Let reasonBytes be the result of encoding reason.\n // 2. If reasonBytes is longer than 123 bytes, then throw a\n // \"SyntaxError\" DOMException.\n reasonByteLength = Buffer.byteLength(reason)\n\n if (reasonByteLength > 123) {\n throw new DOMException(\n `Reason must be less than 123 bytes; received ${reasonByteLength}`,\n 'SyntaxError'\n )\n }\n }\n\n // 3. Run the first matching steps from the following list:\n if (this[kReadyState] === WebSocket.CLOSING || this[kReadyState] === WebSocket.CLOSED) {\n // If this's ready state is CLOSING (2) or CLOSED (3)\n // Do nothing.\n } else if (!isEstablished(this)) {\n // If the WebSocket connection is not yet established\n // Fail the WebSocket connection and set this's ready state\n // to CLOSING (2).\n failWebsocketConnection(this, 'Connection was closed before it was established.')\n this[kReadyState] = WebSocket.CLOSING\n } else if (!isClosing(this)) {\n // If the WebSocket closing handshake has not yet been started\n // Start the WebSocket closing handshake and set this's ready\n // state to CLOSING (2).\n // - If neither code nor reason is present, the WebSocket Close\n // message must not have a body.\n // - If code is present, then the status code to use in the\n // WebSocket Close message must be the integer given by code.\n // - If reason is also present, then reasonBytes must be\n // provided in the Close message after the status code.\n\n const frame = new WebsocketFrameSend()\n\n // If neither code nor reason is present, the WebSocket Close\n // message must not have a body.\n\n // If code is present, then the status code to use in the\n // WebSocket Close message must be the integer given by code.\n if (code !== undefined && reason === undefined) {\n frame.frameData = Buffer.allocUnsafe(2)\n frame.frameData.writeUInt16BE(code, 0)\n } else if (code !== undefined && reason !== undefined) {\n // If reason is also present, then reasonBytes must be\n // provided in the Close message after the status code.\n frame.frameData = Buffer.allocUnsafe(2 + reasonByteLength)\n frame.frameData.writeUInt16BE(code, 0)\n // the body MAY contain UTF-8-encoded data with value /reason/\n frame.frameData.write(reason, 2, 'utf-8')\n } else {\n frame.frameData = emptyBuffer\n }\n\n /** @type {import('stream').Duplex} */\n const socket = this[kResponse].socket\n\n socket.write(frame.createFrame(opcodes.CLOSE), (err) => {\n if (!err) {\n this[kSentClose] = true\n }\n })\n\n // Upon either sending or receiving a Close control frame, it is said\n // that _The WebSocket Closing Handshake is Started_ and that the\n // WebSocket connection is in the CLOSING state.\n this[kReadyState] = states.CLOSING\n } else {\n // Otherwise\n // Set this's ready state to CLOSING (2).\n this[kReadyState] = WebSocket.CLOSING\n }\n }\n\n /**\n * @see https://websockets.spec.whatwg.org/#dom-websocket-send\n * @param {NodeJS.TypedArray|ArrayBuffer|Blob|string} data\n */\n send (data) {\n webidl.brandCheck(this, WebSocket)\n\n webidl.argumentLengthCheck(arguments, 1, { header: 'WebSocket.send' })\n\n data = webidl.converters.WebSocketSendData(data)\n\n // 1. If this's ready state is CONNECTING, then throw an\n // \"InvalidStateError\" DOMException.\n if (this[kReadyState] === WebSocket.CONNECTING) {\n throw new DOMException('Sent before connected.', 'InvalidStateError')\n }\n\n // 2. Run the appropriate set of steps from the following list:\n // https://datatracker.ietf.org/doc/html/rfc6455#section-6.1\n // https://datatracker.ietf.org/doc/html/rfc6455#section-5.2\n\n if (!isEstablished(this) || isClosing(this)) {\n return\n }\n\n /** @type {import('stream').Duplex} */\n const socket = this[kResponse].socket\n\n // If data is a string\n if (typeof data === 'string') {\n // If the WebSocket connection is established and the WebSocket\n // closing handshake has not yet started, then the user agent\n // must send a WebSocket Message comprised of the data argument\n // using a text frame opcode; if the data cannot be sent, e.g.\n // because it would need to be buffered but the buffer is full,\n // the user agent must flag the WebSocket as full and then close\n // the WebSocket connection. Any invocation of this method with a\n // string argument that does not throw an exception must increase\n // the bufferedAmount attribute by the number of bytes needed to\n // express the argument as UTF-8.\n\n const value = Buffer.from(data)\n const frame = new WebsocketFrameSend(value)\n const buffer = frame.createFrame(opcodes.TEXT)\n\n this.#bufferedAmount += value.byteLength\n socket.write(buffer, () => {\n this.#bufferedAmount -= value.byteLength\n })\n } else if (types.isArrayBuffer(data)) {\n // If the WebSocket connection is established, and the WebSocket\n // closing handshake has not yet started, then the user agent must\n // send a WebSocket Message comprised of data using a binary frame\n // opcode; if the data cannot be sent, e.g. because it would need\n // to be buffered but the buffer is full, the user agent must flag\n // the WebSocket as full and then close the WebSocket connection.\n // The data to be sent is the data stored in the buffer described\n // by the ArrayBuffer object. Any invocation of this method with an\n // ArrayBuffer argument that does not throw an exception must\n // increase the bufferedAmount attribute by the length of the\n // ArrayBuffer in bytes.\n\n const value = Buffer.from(data)\n const frame = new WebsocketFrameSend(value)\n const buffer = frame.createFrame(opcodes.BINARY)\n\n this.#bufferedAmount += value.byteLength\n socket.write(buffer, () => {\n this.#bufferedAmount -= value.byteLength\n })\n } else if (ArrayBuffer.isView(data)) {\n // If the WebSocket connection is established, and the WebSocket\n // closing handshake has not yet started, then the user agent must\n // send a WebSocket Message comprised of data using a binary frame\n // opcode; if the data cannot be sent, e.g. because it would need to\n // be buffered but the buffer is full, the user agent must flag the\n // WebSocket as full and then close the WebSocket connection. The\n // data to be sent is the data stored in the section of the buffer\n // described by the ArrayBuffer object that data references. Any\n // invocation of this method with this kind of argument that does\n // not throw an exception must increase the bufferedAmount attribute\n // by the length of data’s buffer in bytes.\n\n const ab = Buffer.from(data, data.byteOffset, data.byteLength)\n\n const frame = new WebsocketFrameSend(ab)\n const buffer = frame.createFrame(opcodes.BINARY)\n\n this.#bufferedAmount += ab.byteLength\n socket.write(buffer, () => {\n this.#bufferedAmount -= ab.byteLength\n })\n } else if (isBlobLike(data)) {\n // If the WebSocket connection is established, and the WebSocket\n // closing handshake has not yet started, then the user agent must\n // send a WebSocket Message comprised of data using a binary frame\n // opcode; if the data cannot be sent, e.g. because it would need to\n // be buffered but the buffer is full, the user agent must flag the\n // WebSocket as full and then close the WebSocket connection. The data\n // to be sent is the raw data represented by the Blob object. Any\n // invocation of this method with a Blob argument that does not throw\n // an exception must increase the bufferedAmount attribute by the size\n // of the Blob object’s raw data, in bytes.\n\n const frame = new WebsocketFrameSend()\n\n data.arrayBuffer().then((ab) => {\n const value = Buffer.from(ab)\n frame.frameData = value\n const buffer = frame.createFrame(opcodes.BINARY)\n\n this.#bufferedAmount += value.byteLength\n socket.write(buffer, () => {\n this.#bufferedAmount -= value.byteLength\n })\n })\n }\n }\n\n get readyState () {\n webidl.brandCheck(this, WebSocket)\n\n // The readyState getter steps are to return this's ready state.\n return this[kReadyState]\n }\n\n get bufferedAmount () {\n webidl.brandCheck(this, WebSocket)\n\n return this.#bufferedAmount\n }\n\n get url () {\n webidl.brandCheck(this, WebSocket)\n\n // The url getter steps are to return this's url, serialized.\n return URLSerializer(this[kWebSocketURL])\n }\n\n get extensions () {\n webidl.brandCheck(this, WebSocket)\n\n return this.#extensions\n }\n\n get protocol () {\n webidl.brandCheck(this, WebSocket)\n\n return this.#protocol\n }\n\n get onopen () {\n webidl.brandCheck(this, WebSocket)\n\n return this.#events.open\n }\n\n set onopen (fn) {\n webidl.brandCheck(this, WebSocket)\n\n if (this.#events.open) {\n this.removeEventListener('open', this.#events.open)\n }\n\n if (typeof fn === 'function') {\n this.#events.open = fn\n this.addEventListener('open', fn)\n } else {\n this.#events.open = null\n }\n }\n\n get onerror () {\n webidl.brandCheck(this, WebSocket)\n\n return this.#events.error\n }\n\n set onerror (fn) {\n webidl.brandCheck(this, WebSocket)\n\n if (this.#events.error) {\n this.removeEventListener('error', this.#events.error)\n }\n\n if (typeof fn === 'function') {\n this.#events.error = fn\n this.addEventListener('error', fn)\n } else {\n this.#events.error = null\n }\n }\n\n get onclose () {\n webidl.brandCheck(this, WebSocket)\n\n return this.#events.close\n }\n\n set onclose (fn) {\n webidl.brandCheck(this, WebSocket)\n\n if (this.#events.close) {\n this.removeEventListener('close', this.#events.close)\n }\n\n if (typeof fn === 'function') {\n this.#events.close = fn\n this.addEventListener('close', fn)\n } else {\n this.#events.close = null\n }\n }\n\n get onmessage () {\n webidl.brandCheck(this, WebSocket)\n\n return this.#events.message\n }\n\n set onmessage (fn) {\n webidl.brandCheck(this, WebSocket)\n\n if (this.#events.message) {\n this.removeEventListener('message', this.#events.message)\n }\n\n if (typeof fn === 'function') {\n this.#events.message = fn\n this.addEventListener('message', fn)\n } else {\n this.#events.message = null\n }\n }\n\n get binaryType () {\n webidl.brandCheck(this, WebSocket)\n\n return this[kBinaryType]\n }\n\n set binaryType (type) {\n webidl.brandCheck(this, WebSocket)\n\n if (type !== 'blob' && type !== 'arraybuffer') {\n this[kBinaryType] = 'blob'\n } else {\n this[kBinaryType] = type\n }\n }\n\n /**\n * @see https://websockets.spec.whatwg.org/#feedback-from-the-protocol\n */\n #onConnectionEstablished (response) {\n // processResponse is called when the \"response’s header list has been received and initialized.\"\n // once this happens, the connection is open\n this[kResponse] = response\n\n const parser = new ByteParser(this)\n parser.on('drain', function onParserDrain () {\n this.ws[kResponse].socket.resume()\n })\n\n response.socket.ws = this\n this[kByteParser] = parser\n\n // 1. Change the ready state to OPEN (1).\n this[kReadyState] = states.OPEN\n\n // 2. Change the extensions attribute’s value to the extensions in use, if\n // it is not the null value.\n // https://datatracker.ietf.org/doc/html/rfc6455#section-9.1\n const extensions = response.headersList.get('sec-websocket-extensions')\n\n if (extensions !== null) {\n this.#extensions = extensions\n }\n\n // 3. Change the protocol attribute’s value to the subprotocol in use, if\n // it is not the null value.\n // https://datatracker.ietf.org/doc/html/rfc6455#section-1.9\n const protocol = response.headersList.get('sec-websocket-protocol')\n\n if (protocol !== null) {\n this.#protocol = protocol\n }\n\n // 4. Fire an event named open at the WebSocket object.\n fireEvent('open', this)\n }\n}\n\n// https://websockets.spec.whatwg.org/#dom-websocket-connecting\nWebSocket.CONNECTING = WebSocket.prototype.CONNECTING = states.CONNECTING\n// https://websockets.spec.whatwg.org/#dom-websocket-open\nWebSocket.OPEN = WebSocket.prototype.OPEN = states.OPEN\n// https://websockets.spec.whatwg.org/#dom-websocket-closing\nWebSocket.CLOSING = WebSocket.prototype.CLOSING = states.CLOSING\n// https://websockets.spec.whatwg.org/#dom-websocket-closed\nWebSocket.CLOSED = WebSocket.prototype.CLOSED = states.CLOSED\n\nObject.defineProperties(WebSocket.prototype, {\n CONNECTING: staticPropertyDescriptors,\n OPEN: staticPropertyDescriptors,\n CLOSING: staticPropertyDescriptors,\n CLOSED: staticPropertyDescriptors,\n url: kEnumerableProperty,\n readyState: kEnumerableProperty,\n bufferedAmount: kEnumerableProperty,\n onopen: kEnumerableProperty,\n onerror: kEnumerableProperty,\n onclose: kEnumerableProperty,\n close: kEnumerableProperty,\n onmessage: kEnumerableProperty,\n binaryType: kEnumerableProperty,\n send: kEnumerableProperty,\n extensions: kEnumerableProperty,\n protocol: kEnumerableProperty,\n [Symbol.toStringTag]: {\n value: 'WebSocket',\n writable: false,\n enumerable: false,\n configurable: true\n }\n})\n\nObject.defineProperties(WebSocket, {\n CONNECTING: staticPropertyDescriptors,\n OPEN: staticPropertyDescriptors,\n CLOSING: staticPropertyDescriptors,\n CLOSED: staticPropertyDescriptors\n})\n\nwebidl.converters['sequence'] = webidl.sequenceConverter(\n webidl.converters.DOMString\n)\n\nwebidl.converters['DOMString or sequence'] = function (V) {\n if (webidl.util.Type(V) === 'Object' && Symbol.iterator in V) {\n return webidl.converters['sequence'](V)\n }\n\n return webidl.converters.DOMString(V)\n}\n\n// This implements the propsal made in https://github.com/whatwg/websockets/issues/42\nwebidl.converters.WebSocketInit = webidl.dictionaryConverter([\n {\n key: 'protocols',\n converter: webidl.converters['DOMString or sequence'],\n get defaultValue () {\n return []\n }\n },\n {\n key: 'dispatcher',\n converter: (V) => V,\n get defaultValue () {\n return getGlobalDispatcher()\n }\n },\n {\n key: 'headers',\n converter: webidl.nullableConverter(webidl.converters.HeadersInit)\n }\n])\n\nwebidl.converters['DOMString or sequence or WebSocketInit'] = function (V) {\n if (webidl.util.Type(V) === 'Object' && !(Symbol.iterator in V)) {\n return webidl.converters.WebSocketInit(V)\n }\n\n return { protocols: webidl.converters['DOMString or sequence'](V) }\n}\n\nwebidl.converters.WebSocketSendData = function (V) {\n if (webidl.util.Type(V) === 'Object') {\n if (isBlobLike(V)) {\n return webidl.converters.Blob(V, { strict: false })\n }\n\n if (ArrayBuffer.isView(V) || types.isAnyArrayBuffer(V)) {\n return webidl.converters.BufferSource(V)\n }\n }\n\n return webidl.converters.USVString(V)\n}\n\nmodule.exports = {\n WebSocket\n}\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nfunction getUserAgent() {\n if (typeof navigator === \"object\" && \"userAgent\" in navigator) {\n return navigator.userAgent;\n }\n\n if (typeof process === \"object\" && process.version !== undefined) {\n return `Node.js/${process.version.substr(1)} (${process.platform}; ${process.arch})`;\n }\n\n return \"\";\n}\n\nexports.getUserAgent = getUserAgent;\n//# sourceMappingURL=index.js.map\n","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nObject.defineProperty(exports, \"v1\", {\n enumerable: true,\n get: function () {\n return _v.default;\n }\n});\nObject.defineProperty(exports, \"v3\", {\n enumerable: true,\n get: function () {\n return _v2.default;\n }\n});\nObject.defineProperty(exports, \"v4\", {\n enumerable: true,\n get: function () {\n return _v3.default;\n }\n});\nObject.defineProperty(exports, \"v5\", {\n enumerable: true,\n get: function () {\n return _v4.default;\n }\n});\nObject.defineProperty(exports, \"NIL\", {\n enumerable: true,\n get: function () {\n return _nil.default;\n }\n});\nObject.defineProperty(exports, \"version\", {\n enumerable: true,\n get: function () {\n return _version.default;\n }\n});\nObject.defineProperty(exports, \"validate\", {\n enumerable: true,\n get: function () {\n return _validate.default;\n }\n});\nObject.defineProperty(exports, \"stringify\", {\n enumerable: true,\n get: function () {\n return _stringify.default;\n }\n});\nObject.defineProperty(exports, \"parse\", {\n enumerable: true,\n get: function () {\n return _parse.default;\n }\n});\n\nvar _v = _interopRequireDefault(require(\"./v1.js\"));\n\nvar _v2 = _interopRequireDefault(require(\"./v3.js\"));\n\nvar _v3 = _interopRequireDefault(require(\"./v4.js\"));\n\nvar _v4 = _interopRequireDefault(require(\"./v5.js\"));\n\nvar _nil = _interopRequireDefault(require(\"./nil.js\"));\n\nvar _version = _interopRequireDefault(require(\"./version.js\"));\n\nvar _validate = _interopRequireDefault(require(\"./validate.js\"));\n\nvar _stringify = _interopRequireDefault(require(\"./stringify.js\"));\n\nvar _parse = _interopRequireDefault(require(\"./parse.js\"));\n\nfunction _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.default = void 0;\n\nvar _crypto = _interopRequireDefault(require(\"crypto\"));\n\nfunction _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }\n\nfunction md5(bytes) {\n if (Array.isArray(bytes)) {\n bytes = Buffer.from(bytes);\n } else if (typeof bytes === 'string') {\n bytes = Buffer.from(bytes, 'utf8');\n }\n\n return _crypto.default.createHash('md5').update(bytes).digest();\n}\n\nvar _default = md5;\nexports.default = _default;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.default = void 0;\nvar _default = '00000000-0000-0000-0000-000000000000';\nexports.default = _default;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.default = void 0;\n\nvar _validate = _interopRequireDefault(require(\"./validate.js\"));\n\nfunction _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }\n\nfunction parse(uuid) {\n if (!(0, _validate.default)(uuid)) {\n throw TypeError('Invalid UUID');\n }\n\n let v;\n const arr = new Uint8Array(16); // Parse ########-....-....-....-............\n\n arr[0] = (v = parseInt(uuid.slice(0, 8), 16)) >>> 24;\n arr[1] = v >>> 16 & 0xff;\n arr[2] = v >>> 8 & 0xff;\n arr[3] = v & 0xff; // Parse ........-####-....-....-............\n\n arr[4] = (v = parseInt(uuid.slice(9, 13), 16)) >>> 8;\n arr[5] = v & 0xff; // Parse ........-....-####-....-............\n\n arr[6] = (v = parseInt(uuid.slice(14, 18), 16)) >>> 8;\n arr[7] = v & 0xff; // Parse ........-....-....-####-............\n\n arr[8] = (v = parseInt(uuid.slice(19, 23), 16)) >>> 8;\n arr[9] = v & 0xff; // Parse ........-....-....-....-############\n // (Use \"/\" to avoid 32-bit truncation when bit-shifting high-order bytes)\n\n arr[10] = (v = parseInt(uuid.slice(24, 36), 16)) / 0x10000000000 & 0xff;\n arr[11] = v / 0x100000000 & 0xff;\n arr[12] = v >>> 24 & 0xff;\n arr[13] = v >>> 16 & 0xff;\n arr[14] = v >>> 8 & 0xff;\n arr[15] = v & 0xff;\n return arr;\n}\n\nvar _default = parse;\nexports.default = _default;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.default = void 0;\nvar _default = /^(?:[0-9a-f]{8}-[0-9a-f]{4}-[1-5][0-9a-f]{3}-[89ab][0-9a-f]{3}-[0-9a-f]{12}|00000000-0000-0000-0000-000000000000)$/i;\nexports.default = _default;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.default = rng;\n\nvar _crypto = _interopRequireDefault(require(\"crypto\"));\n\nfunction _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }\n\nconst rnds8Pool = new Uint8Array(256); // # of random values to pre-allocate\n\nlet poolPtr = rnds8Pool.length;\n\nfunction rng() {\n if (poolPtr > rnds8Pool.length - 16) {\n _crypto.default.randomFillSync(rnds8Pool);\n\n poolPtr = 0;\n }\n\n return rnds8Pool.slice(poolPtr, poolPtr += 16);\n}","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.default = void 0;\n\nvar _crypto = _interopRequireDefault(require(\"crypto\"));\n\nfunction _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }\n\nfunction sha1(bytes) {\n if (Array.isArray(bytes)) {\n bytes = Buffer.from(bytes);\n } else if (typeof bytes === 'string') {\n bytes = Buffer.from(bytes, 'utf8');\n }\n\n return _crypto.default.createHash('sha1').update(bytes).digest();\n}\n\nvar _default = sha1;\nexports.default = _default;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.default = void 0;\n\nvar _validate = _interopRequireDefault(require(\"./validate.js\"));\n\nfunction _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }\n\n/**\n * Convert array of 16 byte values to UUID string format of the form:\n * XXXXXXXX-XXXX-XXXX-XXXX-XXXXXXXXXXXX\n */\nconst byteToHex = [];\n\nfor (let i = 0; i < 256; ++i) {\n byteToHex.push((i + 0x100).toString(16).substr(1));\n}\n\nfunction stringify(arr, offset = 0) {\n // Note: Be careful editing this code! It's been tuned for performance\n // and works in ways you may not expect. See https://github.com/uuidjs/uuid/pull/434\n const uuid = (byteToHex[arr[offset + 0]] + byteToHex[arr[offset + 1]] + byteToHex[arr[offset + 2]] + byteToHex[arr[offset + 3]] + '-' + byteToHex[arr[offset + 4]] + byteToHex[arr[offset + 5]] + '-' + byteToHex[arr[offset + 6]] + byteToHex[arr[offset + 7]] + '-' + byteToHex[arr[offset + 8]] + byteToHex[arr[offset + 9]] + '-' + byteToHex[arr[offset + 10]] + byteToHex[arr[offset + 11]] + byteToHex[arr[offset + 12]] + byteToHex[arr[offset + 13]] + byteToHex[arr[offset + 14]] + byteToHex[arr[offset + 15]]).toLowerCase(); // Consistency check for valid UUID. If this throws, it's likely due to one\n // of the following:\n // - One or more input array values don't map to a hex octet (leading to\n // \"undefined\" in the uuid)\n // - Invalid input values for the RFC `version` or `variant` fields\n\n if (!(0, _validate.default)(uuid)) {\n throw TypeError('Stringified UUID is invalid');\n }\n\n return uuid;\n}\n\nvar _default = stringify;\nexports.default = _default;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.default = void 0;\n\nvar _rng = _interopRequireDefault(require(\"./rng.js\"));\n\nvar _stringify = _interopRequireDefault(require(\"./stringify.js\"));\n\nfunction _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }\n\n// **`v1()` - Generate time-based UUID**\n//\n// Inspired by https://github.com/LiosK/UUID.js\n// and http://docs.python.org/library/uuid.html\nlet _nodeId;\n\nlet _clockseq; // Previous uuid creation time\n\n\nlet _lastMSecs = 0;\nlet _lastNSecs = 0; // See https://github.com/uuidjs/uuid for API details\n\nfunction v1(options, buf, offset) {\n let i = buf && offset || 0;\n const b = buf || new Array(16);\n options = options || {};\n let node = options.node || _nodeId;\n let clockseq = options.clockseq !== undefined ? options.clockseq : _clockseq; // node and clockseq need to be initialized to random values if they're not\n // specified. We do this lazily to minimize issues related to insufficient\n // system entropy. See #189\n\n if (node == null || clockseq == null) {\n const seedBytes = options.random || (options.rng || _rng.default)();\n\n if (node == null) {\n // Per 4.5, create and 48-bit node id, (47 random bits + multicast bit = 1)\n node = _nodeId = [seedBytes[0] | 0x01, seedBytes[1], seedBytes[2], seedBytes[3], seedBytes[4], seedBytes[5]];\n }\n\n if (clockseq == null) {\n // Per 4.2.2, randomize (14 bit) clockseq\n clockseq = _clockseq = (seedBytes[6] << 8 | seedBytes[7]) & 0x3fff;\n }\n } // UUID timestamps are 100 nano-second units since the Gregorian epoch,\n // (1582-10-15 00:00). JSNumbers aren't precise enough for this, so\n // time is handled internally as 'msecs' (integer milliseconds) and 'nsecs'\n // (100-nanoseconds offset from msecs) since unix epoch, 1970-01-01 00:00.\n\n\n let msecs = options.msecs !== undefined ? options.msecs : Date.now(); // Per 4.2.1.2, use count of uuid's generated during the current clock\n // cycle to simulate higher resolution clock\n\n let nsecs = options.nsecs !== undefined ? options.nsecs : _lastNSecs + 1; // Time since last uuid creation (in msecs)\n\n const dt = msecs - _lastMSecs + (nsecs - _lastNSecs) / 10000; // Per 4.2.1.2, Bump clockseq on clock regression\n\n if (dt < 0 && options.clockseq === undefined) {\n clockseq = clockseq + 1 & 0x3fff;\n } // Reset nsecs if clock regresses (new clockseq) or we've moved onto a new\n // time interval\n\n\n if ((dt < 0 || msecs > _lastMSecs) && options.nsecs === undefined) {\n nsecs = 0;\n } // Per 4.2.1.2 Throw error if too many uuids are requested\n\n\n if (nsecs >= 10000) {\n throw new Error(\"uuid.v1(): Can't create more than 10M uuids/sec\");\n }\n\n _lastMSecs = msecs;\n _lastNSecs = nsecs;\n _clockseq = clockseq; // Per 4.1.4 - Convert from unix epoch to Gregorian epoch\n\n msecs += 12219292800000; // `time_low`\n\n const tl = ((msecs & 0xfffffff) * 10000 + nsecs) % 0x100000000;\n b[i++] = tl >>> 24 & 0xff;\n b[i++] = tl >>> 16 & 0xff;\n b[i++] = tl >>> 8 & 0xff;\n b[i++] = tl & 0xff; // `time_mid`\n\n const tmh = msecs / 0x100000000 * 10000 & 0xfffffff;\n b[i++] = tmh >>> 8 & 0xff;\n b[i++] = tmh & 0xff; // `time_high_and_version`\n\n b[i++] = tmh >>> 24 & 0xf | 0x10; // include version\n\n b[i++] = tmh >>> 16 & 0xff; // `clock_seq_hi_and_reserved` (Per 4.2.2 - include variant)\n\n b[i++] = clockseq >>> 8 | 0x80; // `clock_seq_low`\n\n b[i++] = clockseq & 0xff; // `node`\n\n for (let n = 0; n < 6; ++n) {\n b[i + n] = node[n];\n }\n\n return buf || (0, _stringify.default)(b);\n}\n\nvar _default = v1;\nexports.default = _default;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.default = void 0;\n\nvar _v = _interopRequireDefault(require(\"./v35.js\"));\n\nvar _md = _interopRequireDefault(require(\"./md5.js\"));\n\nfunction _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }\n\nconst v3 = (0, _v.default)('v3', 0x30, _md.default);\nvar _default = v3;\nexports.default = _default;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.default = _default;\nexports.URL = exports.DNS = void 0;\n\nvar _stringify = _interopRequireDefault(require(\"./stringify.js\"));\n\nvar _parse = _interopRequireDefault(require(\"./parse.js\"));\n\nfunction _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }\n\nfunction stringToBytes(str) {\n str = unescape(encodeURIComponent(str)); // UTF8 escape\n\n const bytes = [];\n\n for (let i = 0; i < str.length; ++i) {\n bytes.push(str.charCodeAt(i));\n }\n\n return bytes;\n}\n\nconst DNS = '6ba7b810-9dad-11d1-80b4-00c04fd430c8';\nexports.DNS = DNS;\nconst URL = '6ba7b811-9dad-11d1-80b4-00c04fd430c8';\nexports.URL = URL;\n\nfunction _default(name, version, hashfunc) {\n function generateUUID(value, namespace, buf, offset) {\n if (typeof value === 'string') {\n value = stringToBytes(value);\n }\n\n if (typeof namespace === 'string') {\n namespace = (0, _parse.default)(namespace);\n }\n\n if (namespace.length !== 16) {\n throw TypeError('Namespace must be array-like (16 iterable integer values, 0-255)');\n } // Compute hash of namespace and value, Per 4.3\n // Future: Use spread syntax when supported on all platforms, e.g. `bytes =\n // hashfunc([...namespace, ... value])`\n\n\n let bytes = new Uint8Array(16 + value.length);\n bytes.set(namespace);\n bytes.set(value, namespace.length);\n bytes = hashfunc(bytes);\n bytes[6] = bytes[6] & 0x0f | version;\n bytes[8] = bytes[8] & 0x3f | 0x80;\n\n if (buf) {\n offset = offset || 0;\n\n for (let i = 0; i < 16; ++i) {\n buf[offset + i] = bytes[i];\n }\n\n return buf;\n }\n\n return (0, _stringify.default)(bytes);\n } // Function#name is not settable on some platforms (#270)\n\n\n try {\n generateUUID.name = name; // eslint-disable-next-line no-empty\n } catch (err) {} // For CommonJS default export support\n\n\n generateUUID.DNS = DNS;\n generateUUID.URL = URL;\n return generateUUID;\n}","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.default = void 0;\n\nvar _rng = _interopRequireDefault(require(\"./rng.js\"));\n\nvar _stringify = _interopRequireDefault(require(\"./stringify.js\"));\n\nfunction _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }\n\nfunction v4(options, buf, offset) {\n options = options || {};\n\n const rnds = options.random || (options.rng || _rng.default)(); // Per 4.4, set bits for version and `clock_seq_hi_and_reserved`\n\n\n rnds[6] = rnds[6] & 0x0f | 0x40;\n rnds[8] = rnds[8] & 0x3f | 0x80; // Copy bytes to buffer, if provided\n\n if (buf) {\n offset = offset || 0;\n\n for (let i = 0; i < 16; ++i) {\n buf[offset + i] = rnds[i];\n }\n\n return buf;\n }\n\n return (0, _stringify.default)(rnds);\n}\n\nvar _default = v4;\nexports.default = _default;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.default = void 0;\n\nvar _v = _interopRequireDefault(require(\"./v35.js\"));\n\nvar _sha = _interopRequireDefault(require(\"./sha1.js\"));\n\nfunction _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }\n\nconst v5 = (0, _v.default)('v5', 0x50, _sha.default);\nvar _default = v5;\nexports.default = _default;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.default = void 0;\n\nvar _regex = _interopRequireDefault(require(\"./regex.js\"));\n\nfunction _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }\n\nfunction validate(uuid) {\n return typeof uuid === 'string' && _regex.default.test(uuid);\n}\n\nvar _default = validate;\nexports.default = _default;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.default = void 0;\n\nvar _validate = _interopRequireDefault(require(\"./validate.js\"));\n\nfunction _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }\n\nfunction version(uuid) {\n if (!(0, _validate.default)(uuid)) {\n throw TypeError('Invalid UUID');\n }\n\n return parseInt(uuid.substr(14, 1), 16);\n}\n\nvar _default = version;\nexports.default = _default;","// Returns a wrapper function that returns a wrapped callback\n// The wrapper function should do some stuff, and return a\n// presumably different callback function.\n// This makes sure that own properties are retained, so that\n// decorations and such are not lost along the way.\nmodule.exports = wrappy\nfunction wrappy (fn, cb) {\n if (fn && cb) return wrappy(fn)(cb)\n\n if (typeof fn !== 'function')\n throw new TypeError('need wrapper function')\n\n Object.keys(fn).forEach(function (k) {\n wrapper[k] = fn[k]\n })\n\n return wrapper\n\n function wrapper() {\n var args = new Array(arguments.length)\n for (var i = 0; i < args.length; i++) {\n args[i] = arguments[i]\n }\n var ret = fn.apply(this, args)\n var cb = args[args.length-1]\n if (typeof ret === 'function' && ret !== cb) {\n Object.keys(cb).forEach(function (k) {\n ret[k] = cb[k]\n })\n }\n return ret\n }\n}\n","import { readFile } from 'fs/promises';\nimport * as child from 'child_process';\nimport * as pathFs from 'path';\nimport * as Range from 'drange';\nimport * as assert from 'assert';\nimport parseLCOV from 'parse-lcov';\n\ntype Opts = {\n base: string;\n coverage: string;\n head: string;\n coverageType: 'istanbul' | 'lcov';\n};\n\nexport type Lines = Range;\nexport type Path = string;\n\nasync function runGit(command: string): Promise {\n const [ex, ...args] = command.split(' ');\n return new Promise((ok, fail) => {\n const collected: string[] = [];\n const errors: string[] = [];\n const run = child.spawn(ex, args);\n run.stderr.setEncoding('utf8');\n run.stderr.on('data', (msg: string) => {\n errors.push(msg);\n });\n run.stdout.setEncoding('utf8');\n run.stdout.on('data', (msg: string) => collected.push(msg));\n run.on('close', () => {\n ok(collected.join(''));\n });\n run.on('error', (err: Error) => {\n fail(`got error from rungit \"${err.message}\" ${err.stack}\n\n stderr:\n ${errors.join('')}`);\n });\n });\n}\nasync function changedLines(opts: Opts): Promise> {\n const stdout = await runGit(`git diff -w -U0 ${opts.base}...${opts.head}`);\n const result: Record = {};\n let currentFile: Path | null = null;\n for (const line of stdout.split('\\n')) {\n const fileHeader = line.match(/^\\+\\+\\+ b\\/(.*)/);\n if (fileHeader && fileHeader[1]) {\n currentFile = fileHeader[1];\n result[currentFile] = new Range();\n continue;\n }\n const changeHeader = line.match(/^@@ .* \\+(\\d+)(,\\d+)?/);\n if (changeHeader) {\n const start = Number(changeHeader[1]);\n const count = changeHeader[2] ? Number(changeHeader[2].slice(1)) : 1;\n if (!currentFile) {\n continue;\n }\n const head = result[currentFile];\n if (!head) {\n continue;\n }\n const high = start + count - 1;\n head.add(Math.min(start, high), Math.max(start, high));\n }\n }\n return result;\n}\n\nexport function uncovered(args: {\n coverage: Record;\n changes: Record;\n}): Result {\n const result: Record = {};\n let coveredChanges = 0;\n let totalChanges = 0;\n for (const path of Object.keys(args.changes)) {\n const uncovered = new Range();\n const changes = args.changes[path] ?? new Range();\n const hits = args.coverage[path]?.sort((a, b) => a.start - b.start);\n if (!hits) {\n continue;\n }\n let lowerBoundIndex = 0;\n for (const subrange of changes.subranges().sort((a, b) => a.low - b.low)) {\n for (let i = lowerBoundIndex; i < hits.length && hits[i].start < subrange.high; i++) {\n const hit = hits[i];\n if (subrange.low > hit.end) {\n // all following subranges will have 'low > current range 'low so\n // no need to consider prior hits for those\n lowerBoundIndex++;\n // lets consider next hit\n continue;\n }\n if (subrange.high < hit.start) {\n // subrange ends before next hit starts\n // all following hits will have 'start > current hit 'start\n // so we are done with the current subrange\n break;\n }\n if (hit.hits === 0) {\n uncovered.add(new Range(subrange.low, subrange.high).intersect(hit.start, hit.end));\n }\n }\n }\n totalChanges += changes.length;\n coveredChanges += changes.length - uncovered.length;\n if (uncovered.length) {\n result[path] = uncovered;\n }\n }\n return {\n covered: coveredChanges,\n total: totalChanges,\n uncoveredLines: result\n };\n}\n\ntype Hits = Array<{\n hits: number;\n start: number;\n end: number;\n}>;\nasync function coveredLines(opts: Opts): Promise> {\n return opts.coverageType === 'lcov' ? lcovCoveredLines(opts) : istanbulCoveredLines(opts);\n}\n\nasync function istanbulCoveredLines(opts: Opts): Promise> {\n const coverage = JSON.parse(await readFile(opts.coverage, 'utf8'));\n const result: Record = {};\n for (const absolutePath of Object.keys(coverage)) {\n const path = pathFs.relative(process.cwd(), absolutePath);\n const collect: Hits = [];\n result[path] = collect;\n for (const statementIndex of Object.keys(coverage[absolutePath].s)) {\n const hit = coverage[absolutePath].statementMap[statementIndex];\n if (!hit) {\n continue;\n }\n collect.push({\n hits: coverage[absolutePath].s[statementIndex],\n start: Math.min(hit.start.line, hit.end.line),\n end: Math.max(hit.start.line, hit.end.line)\n });\n }\n }\n return result;\n}\n\nasync function lcovCoveredLines(opts: Opts): Promise> {\n const fileContents = await readFile(opts.coverage, 'utf8');\n const lcovData = parseLCOV(fileContents);\n return lcovData.reduce>((result, fileEntry) => {\n const path = pathFs.isAbsolute(fileEntry.file)\n ? pathFs.normalize(pathFs.relative(process.cwd(), fileEntry.file))\n : pathFs.normalize(fileEntry.file);\n result[path] = fileEntry.lines.details.map(({ line, hit }) => ({\n hits: hit,\n start: line,\n end: line\n }));\n return result;\n }, {});\n}\n\nexport type Result = { covered: number; total: number; uncoveredLines: Record };\nasync function uncoveredLines(opts: Opts): Promise {\n const coverage = await coveredLines(opts);\n const changes = await changedLines(opts);\n return uncovered({ coverage, changes });\n}\n\nexport async function run(opts: Opts): Promise {\n const file = opts.coverage;\n if (opts.coverageType === 'istanbul') {\n assert(/\\.json$/.test(file), `input file '${file}' must be json coverage file`);\n }\n\n return await uncoveredLines({\n base: opts.base,\n head: opts.head,\n coverage: file,\n coverageType: opts.coverageType\n });\n}\n","module.exports = require(\"assert\");","module.exports = require(\"async_hooks\");","module.exports = require(\"buffer\");","module.exports = require(\"child_process\");","module.exports = require(\"console\");","module.exports = require(\"crypto\");","module.exports = require(\"diagnostics_channel\");","module.exports = require(\"events\");","module.exports = require(\"fs\");","module.exports = require(\"fs/promises\");","module.exports = require(\"http\");","module.exports = require(\"http2\");","module.exports = require(\"https\");","module.exports = require(\"net\");","module.exports = require(\"node:events\");","module.exports = require(\"node:stream\");","module.exports = require(\"node:util\");","module.exports = require(\"os\");","module.exports = require(\"path\");","module.exports = require(\"perf_hooks\");","module.exports = require(\"querystring\");","module.exports = require(\"stream\");","module.exports = require(\"stream/web\");","module.exports = require(\"string_decoder\");","module.exports = require(\"tls\");","module.exports = require(\"url\");","module.exports = require(\"util\");","module.exports = require(\"util/types\");","module.exports = require(\"worker_threads\");","module.exports = require(\"zlib\");","'use strict'\n\nconst WritableStream = require('node:stream').Writable\nconst inherits = require('node:util').inherits\n\nconst StreamSearch = require('../../streamsearch/sbmh')\n\nconst PartStream = require('./PartStream')\nconst HeaderParser = require('./HeaderParser')\n\nconst DASH = 45\nconst B_ONEDASH = Buffer.from('-')\nconst B_CRLF = Buffer.from('\\r\\n')\nconst EMPTY_FN = function () {}\n\nfunction Dicer (cfg) {\n if (!(this instanceof Dicer)) { return new Dicer(cfg) }\n WritableStream.call(this, cfg)\n\n if (!cfg || (!cfg.headerFirst && typeof cfg.boundary !== 'string')) { throw new TypeError('Boundary required') }\n\n if (typeof cfg.boundary === 'string') { this.setBoundary(cfg.boundary) } else { this._bparser = undefined }\n\n this._headerFirst = cfg.headerFirst\n\n this._dashes = 0\n this._parts = 0\n this._finished = false\n this._realFinish = false\n this._isPreamble = true\n this._justMatched = false\n this._firstWrite = true\n this._inHeader = true\n this._part = undefined\n this._cb = undefined\n this._ignoreData = false\n this._partOpts = { highWaterMark: cfg.partHwm }\n this._pause = false\n\n const self = this\n this._hparser = new HeaderParser(cfg)\n this._hparser.on('header', function (header) {\n self._inHeader = false\n self._part.emit('header', header)\n })\n}\ninherits(Dicer, WritableStream)\n\nDicer.prototype.emit = function (ev) {\n if (ev === 'finish' && !this._realFinish) {\n if (!this._finished) {\n const self = this\n process.nextTick(function () {\n self.emit('error', new Error('Unexpected end of multipart data'))\n if (self._part && !self._ignoreData) {\n const type = (self._isPreamble ? 'Preamble' : 'Part')\n self._part.emit('error', new Error(type + ' terminated early due to unexpected end of multipart data'))\n self._part.push(null)\n process.nextTick(function () {\n self._realFinish = true\n self.emit('finish')\n self._realFinish = false\n })\n return\n }\n self._realFinish = true\n self.emit('finish')\n self._realFinish = false\n })\n }\n } else { WritableStream.prototype.emit.apply(this, arguments) }\n}\n\nDicer.prototype._write = function (data, encoding, cb) {\n // ignore unexpected data (e.g. extra trailer data after finished)\n if (!this._hparser && !this._bparser) { return cb() }\n\n if (this._headerFirst && this._isPreamble) {\n if (!this._part) {\n this._part = new PartStream(this._partOpts)\n if (this.listenerCount('preamble') !== 0) { this.emit('preamble', this._part) } else { this._ignore() }\n }\n const r = this._hparser.push(data)\n if (!this._inHeader && r !== undefined && r < data.length) { data = data.slice(r) } else { return cb() }\n }\n\n // allows for \"easier\" testing\n if (this._firstWrite) {\n this._bparser.push(B_CRLF)\n this._firstWrite = false\n }\n\n this._bparser.push(data)\n\n if (this._pause) { this._cb = cb } else { cb() }\n}\n\nDicer.prototype.reset = function () {\n this._part = undefined\n this._bparser = undefined\n this._hparser = undefined\n}\n\nDicer.prototype.setBoundary = function (boundary) {\n const self = this\n this._bparser = new StreamSearch('\\r\\n--' + boundary)\n this._bparser.on('info', function (isMatch, data, start, end) {\n self._oninfo(isMatch, data, start, end)\n })\n}\n\nDicer.prototype._ignore = function () {\n if (this._part && !this._ignoreData) {\n this._ignoreData = true\n this._part.on('error', EMPTY_FN)\n // we must perform some kind of read on the stream even though we are\n // ignoring the data, otherwise node's Readable stream will not emit 'end'\n // after pushing null to the stream\n this._part.resume()\n }\n}\n\nDicer.prototype._oninfo = function (isMatch, data, start, end) {\n let buf; const self = this; let i = 0; let r; let shouldWriteMore = true\n\n if (!this._part && this._justMatched && data) {\n while (this._dashes < 2 && (start + i) < end) {\n if (data[start + i] === DASH) {\n ++i\n ++this._dashes\n } else {\n if (this._dashes) { buf = B_ONEDASH }\n this._dashes = 0\n break\n }\n }\n if (this._dashes === 2) {\n if ((start + i) < end && this.listenerCount('trailer') !== 0) { this.emit('trailer', data.slice(start + i, end)) }\n this.reset()\n this._finished = true\n // no more parts will be added\n if (self._parts === 0) {\n self._realFinish = true\n self.emit('finish')\n self._realFinish = false\n }\n }\n if (this._dashes) { return }\n }\n if (this._justMatched) { this._justMatched = false }\n if (!this._part) {\n this._part = new PartStream(this._partOpts)\n this._part._read = function (n) {\n self._unpause()\n }\n if (this._isPreamble && this.listenerCount('preamble') !== 0) {\n this.emit('preamble', this._part)\n } else if (this._isPreamble !== true && this.listenerCount('part') !== 0) {\n this.emit('part', this._part)\n } else {\n this._ignore()\n }\n if (!this._isPreamble) { this._inHeader = true }\n }\n if (data && start < end && !this._ignoreData) {\n if (this._isPreamble || !this._inHeader) {\n if (buf) { shouldWriteMore = this._part.push(buf) }\n shouldWriteMore = this._part.push(data.slice(start, end))\n if (!shouldWriteMore) { this._pause = true }\n } else if (!this._isPreamble && this._inHeader) {\n if (buf) { this._hparser.push(buf) }\n r = this._hparser.push(data.slice(start, end))\n if (!this._inHeader && r !== undefined && r < end) { this._oninfo(false, data, start + r, end) }\n }\n }\n if (isMatch) {\n this._hparser.reset()\n if (this._isPreamble) { this._isPreamble = false } else {\n if (start !== end) {\n ++this._parts\n this._part.on('end', function () {\n if (--self._parts === 0) {\n if (self._finished) {\n self._realFinish = true\n self.emit('finish')\n self._realFinish = false\n } else {\n self._unpause()\n }\n }\n })\n }\n }\n this._part.push(null)\n this._part = undefined\n this._ignoreData = false\n this._justMatched = true\n this._dashes = 0\n }\n}\n\nDicer.prototype._unpause = function () {\n if (!this._pause) { return }\n\n this._pause = false\n if (this._cb) {\n const cb = this._cb\n this._cb = undefined\n cb()\n }\n}\n\nmodule.exports = Dicer\n","'use strict'\n\nconst EventEmitter = require('node:events').EventEmitter\nconst inherits = require('node:util').inherits\nconst getLimit = require('../../../lib/utils/getLimit')\n\nconst StreamSearch = require('../../streamsearch/sbmh')\n\nconst B_DCRLF = Buffer.from('\\r\\n\\r\\n')\nconst RE_CRLF = /\\r\\n/g\nconst RE_HDR = /^([^:]+):[ \\t]?([\\x00-\\xFF]+)?$/ // eslint-disable-line no-control-regex\n\nfunction HeaderParser (cfg) {\n EventEmitter.call(this)\n\n cfg = cfg || {}\n const self = this\n this.nread = 0\n this.maxed = false\n this.npairs = 0\n this.maxHeaderPairs = getLimit(cfg, 'maxHeaderPairs', 2000)\n this.maxHeaderSize = getLimit(cfg, 'maxHeaderSize', 80 * 1024)\n this.buffer = ''\n this.header = {}\n this.finished = false\n this.ss = new StreamSearch(B_DCRLF)\n this.ss.on('info', function (isMatch, data, start, end) {\n if (data && !self.maxed) {\n if (self.nread + end - start >= self.maxHeaderSize) {\n end = self.maxHeaderSize - self.nread + start\n self.nread = self.maxHeaderSize\n self.maxed = true\n } else { self.nread += (end - start) }\n\n self.buffer += data.toString('binary', start, end)\n }\n if (isMatch) { self._finish() }\n })\n}\ninherits(HeaderParser, EventEmitter)\n\nHeaderParser.prototype.push = function (data) {\n const r = this.ss.push(data)\n if (this.finished) { return r }\n}\n\nHeaderParser.prototype.reset = function () {\n this.finished = false\n this.buffer = ''\n this.header = {}\n this.ss.reset()\n}\n\nHeaderParser.prototype._finish = function () {\n if (this.buffer) { this._parseHeader() }\n this.ss.matches = this.ss.maxMatches\n const header = this.header\n this.header = {}\n this.buffer = ''\n this.finished = true\n this.nread = this.npairs = 0\n this.maxed = false\n this.emit('header', header)\n}\n\nHeaderParser.prototype._parseHeader = function () {\n if (this.npairs === this.maxHeaderPairs) { return }\n\n const lines = this.buffer.split(RE_CRLF)\n const len = lines.length\n let m, h\n\n for (var i = 0; i < len; ++i) { // eslint-disable-line no-var\n if (lines[i].length === 0) { continue }\n if (lines[i][0] === '\\t' || lines[i][0] === ' ') {\n // folded header content\n // RFC2822 says to just remove the CRLF and not the whitespace following\n // it, so we follow the RFC and include the leading whitespace ...\n if (h) {\n this.header[h][this.header[h].length - 1] += lines[i]\n continue\n }\n }\n\n const posColon = lines[i].indexOf(':')\n if (\n posColon === -1 ||\n posColon === 0\n ) {\n return\n }\n m = RE_HDR.exec(lines[i])\n h = m[1].toLowerCase()\n this.header[h] = this.header[h] || []\n this.header[h].push((m[2] || ''))\n if (++this.npairs === this.maxHeaderPairs) { break }\n }\n}\n\nmodule.exports = HeaderParser\n","'use strict'\n\nconst inherits = require('node:util').inherits\nconst ReadableStream = require('node:stream').Readable\n\nfunction PartStream (opts) {\n ReadableStream.call(this, opts)\n}\ninherits(PartStream, ReadableStream)\n\nPartStream.prototype._read = function (n) {}\n\nmodule.exports = PartStream\n","'use strict'\n\n/**\n * Copyright Brian White. All rights reserved.\n *\n * @see https://github.com/mscdex/streamsearch\n *\n * Permission is hereby granted, free of charge, to any person obtaining a copy\n * of this software and associated documentation files (the \"Software\"), to\n * deal in the Software without restriction, including without limitation the\n * rights to use, copy, modify, merge, publish, distribute, sublicense, and/or\n * sell copies of the Software, and to permit persons to whom the Software is\n * furnished to do so, subject to the following conditions:\n *\n * The above copyright notice and this permission notice shall be included in\n * all copies or substantial portions of the Software.\n *\n * THE SOFTWARE IS PROVIDED \"AS IS\", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR\n * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,\n * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE\n * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER\n * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING\n * FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS\n * IN THE SOFTWARE.\n *\n * Based heavily on the Streaming Boyer-Moore-Horspool C++ implementation\n * by Hongli Lai at: https://github.com/FooBarWidget/boyer-moore-horspool\n */\nconst EventEmitter = require('node:events').EventEmitter\nconst inherits = require('node:util').inherits\n\nfunction SBMH (needle) {\n if (typeof needle === 'string') {\n needle = Buffer.from(needle)\n }\n\n if (!Buffer.isBuffer(needle)) {\n throw new TypeError('The needle has to be a String or a Buffer.')\n }\n\n const needleLength = needle.length\n\n if (needleLength === 0) {\n throw new Error('The needle cannot be an empty String/Buffer.')\n }\n\n if (needleLength > 256) {\n throw new Error('The needle cannot have a length bigger than 256.')\n }\n\n this.maxMatches = Infinity\n this.matches = 0\n\n this._occ = new Array(256)\n .fill(needleLength) // Initialize occurrence table.\n this._lookbehind_size = 0\n this._needle = needle\n this._bufpos = 0\n\n this._lookbehind = Buffer.alloc(needleLength)\n\n // Populate occurrence table with analysis of the needle,\n // ignoring last letter.\n for (var i = 0; i < needleLength - 1; ++i) { // eslint-disable-line no-var\n this._occ[needle[i]] = needleLength - 1 - i\n }\n}\ninherits(SBMH, EventEmitter)\n\nSBMH.prototype.reset = function () {\n this._lookbehind_size = 0\n this.matches = 0\n this._bufpos = 0\n}\n\nSBMH.prototype.push = function (chunk, pos) {\n if (!Buffer.isBuffer(chunk)) {\n chunk = Buffer.from(chunk, 'binary')\n }\n const chlen = chunk.length\n this._bufpos = pos || 0\n let r\n while (r !== chlen && this.matches < this.maxMatches) { r = this._sbmh_feed(chunk) }\n return r\n}\n\nSBMH.prototype._sbmh_feed = function (data) {\n const len = data.length\n const needle = this._needle\n const needleLength = needle.length\n const lastNeedleChar = needle[needleLength - 1]\n\n // Positive: points to a position in `data`\n // pos == 3 points to data[3]\n // Negative: points to a position in the lookbehind buffer\n // pos == -2 points to lookbehind[lookbehind_size - 2]\n let pos = -this._lookbehind_size\n let ch\n\n if (pos < 0) {\n // Lookbehind buffer is not empty. Perform Boyer-Moore-Horspool\n // search with character lookup code that considers both the\n // lookbehind buffer and the current round's haystack data.\n //\n // Loop until\n // there is a match.\n // or until\n // we've moved past the position that requires the\n // lookbehind buffer. In this case we switch to the\n // optimized loop.\n // or until\n // the character to look at lies outside the haystack.\n while (pos < 0 && pos <= len - needleLength) {\n ch = this._sbmh_lookup_char(data, pos + needleLength - 1)\n\n if (\n ch === lastNeedleChar &&\n this._sbmh_memcmp(data, pos, needleLength - 1)\n ) {\n this._lookbehind_size = 0\n ++this.matches\n this.emit('info', true)\n\n return (this._bufpos = pos + needleLength)\n }\n pos += this._occ[ch]\n }\n\n // No match.\n\n if (pos < 0) {\n // There's too few data for Boyer-Moore-Horspool to run,\n // so let's use a different algorithm to skip as much as\n // we can.\n // Forward pos until\n // the trailing part of lookbehind + data\n // looks like the beginning of the needle\n // or until\n // pos == 0\n while (pos < 0 && !this._sbmh_memcmp(data, pos, len - pos)) { ++pos }\n }\n\n if (pos >= 0) {\n // Discard lookbehind buffer.\n this.emit('info', false, this._lookbehind, 0, this._lookbehind_size)\n this._lookbehind_size = 0\n } else {\n // Cut off part of the lookbehind buffer that has\n // been processed and append the entire haystack\n // into it.\n const bytesToCutOff = this._lookbehind_size + pos\n if (bytesToCutOff > 0) {\n // The cut off data is guaranteed not to contain the needle.\n this.emit('info', false, this._lookbehind, 0, bytesToCutOff)\n }\n\n this._lookbehind.copy(this._lookbehind, 0, bytesToCutOff,\n this._lookbehind_size - bytesToCutOff)\n this._lookbehind_size -= bytesToCutOff\n\n data.copy(this._lookbehind, this._lookbehind_size)\n this._lookbehind_size += len\n\n this._bufpos = len\n return len\n }\n }\n\n pos += (pos >= 0) * this._bufpos\n\n // Lookbehind buffer is now empty. We only need to check if the\n // needle is in the haystack.\n if (data.indexOf(needle, pos) !== -1) {\n pos = data.indexOf(needle, pos)\n ++this.matches\n if (pos > 0) { this.emit('info', true, data, this._bufpos, pos) } else { this.emit('info', true) }\n\n return (this._bufpos = pos + needleLength)\n } else {\n pos = len - needleLength\n }\n\n // There was no match. If there's trailing haystack data that we cannot\n // match yet using the Boyer-Moore-Horspool algorithm (because the trailing\n // data is less than the needle size) then match using a modified\n // algorithm that starts matching from the beginning instead of the end.\n // Whatever trailing data is left after running this algorithm is added to\n // the lookbehind buffer.\n while (\n pos < len &&\n (\n data[pos] !== needle[0] ||\n (\n (Buffer.compare(\n data.subarray(pos, pos + len - pos),\n needle.subarray(0, len - pos)\n ) !== 0)\n )\n )\n ) {\n ++pos\n }\n if (pos < len) {\n data.copy(this._lookbehind, 0, pos, pos + (len - pos))\n this._lookbehind_size = len - pos\n }\n\n // Everything until pos is guaranteed not to contain needle data.\n if (pos > 0) { this.emit('info', false, data, this._bufpos, pos < len ? pos : len) }\n\n this._bufpos = len\n return len\n}\n\nSBMH.prototype._sbmh_lookup_char = function (data, pos) {\n return (pos < 0)\n ? this._lookbehind[this._lookbehind_size + pos]\n : data[pos]\n}\n\nSBMH.prototype._sbmh_memcmp = function (data, pos, len) {\n for (var i = 0; i < len; ++i) { // eslint-disable-line no-var\n if (this._sbmh_lookup_char(data, pos + i) !== this._needle[i]) { return false }\n }\n return true\n}\n\nmodule.exports = SBMH\n","'use strict'\n\nconst WritableStream = require('node:stream').Writable\nconst { inherits } = require('node:util')\nconst Dicer = require('../deps/dicer/lib/Dicer')\n\nconst MultipartParser = require('./types/multipart')\nconst UrlencodedParser = require('./types/urlencoded')\nconst parseParams = require('./utils/parseParams')\n\nfunction Busboy (opts) {\n if (!(this instanceof Busboy)) { return new Busboy(opts) }\n\n if (typeof opts !== 'object') {\n throw new TypeError('Busboy expected an options-Object.')\n }\n if (typeof opts.headers !== 'object') {\n throw new TypeError('Busboy expected an options-Object with headers-attribute.')\n }\n if (typeof opts.headers['content-type'] !== 'string') {\n throw new TypeError('Missing Content-Type-header.')\n }\n\n const {\n headers,\n ...streamOptions\n } = opts\n\n this.opts = {\n autoDestroy: false,\n ...streamOptions\n }\n WritableStream.call(this, this.opts)\n\n this._done = false\n this._parser = this.getParserByHeaders(headers)\n this._finished = false\n}\ninherits(Busboy, WritableStream)\n\nBusboy.prototype.emit = function (ev) {\n if (ev === 'finish') {\n if (!this._done) {\n this._parser?.end()\n return\n } else if (this._finished) {\n return\n }\n this._finished = true\n }\n WritableStream.prototype.emit.apply(this, arguments)\n}\n\nBusboy.prototype.getParserByHeaders = function (headers) {\n const parsed = parseParams(headers['content-type'])\n\n const cfg = {\n defCharset: this.opts.defCharset,\n fileHwm: this.opts.fileHwm,\n headers,\n highWaterMark: this.opts.highWaterMark,\n isPartAFile: this.opts.isPartAFile,\n limits: this.opts.limits,\n parsedConType: parsed,\n preservePath: this.opts.preservePath\n }\n\n if (MultipartParser.detect.test(parsed[0])) {\n return new MultipartParser(this, cfg)\n }\n if (UrlencodedParser.detect.test(parsed[0])) {\n return new UrlencodedParser(this, cfg)\n }\n throw new Error('Unsupported Content-Type.')\n}\n\nBusboy.prototype._write = function (chunk, encoding, cb) {\n this._parser.write(chunk, cb)\n}\n\nmodule.exports = Busboy\nmodule.exports.default = Busboy\nmodule.exports.Busboy = Busboy\n\nmodule.exports.Dicer = Dicer\n","'use strict'\n\n// TODO:\n// * support 1 nested multipart level\n// (see second multipart example here:\n// http://www.w3.org/TR/html401/interact/forms.html#didx-multipartform-data)\n// * support limits.fieldNameSize\n// -- this will require modifications to utils.parseParams\n\nconst { Readable } = require('node:stream')\nconst { inherits } = require('node:util')\n\nconst Dicer = require('../../deps/dicer/lib/Dicer')\n\nconst parseParams = require('../utils/parseParams')\nconst decodeText = require('../utils/decodeText')\nconst basename = require('../utils/basename')\nconst getLimit = require('../utils/getLimit')\n\nconst RE_BOUNDARY = /^boundary$/i\nconst RE_FIELD = /^form-data$/i\nconst RE_CHARSET = /^charset$/i\nconst RE_FILENAME = /^filename$/i\nconst RE_NAME = /^name$/i\n\nMultipart.detect = /^multipart\\/form-data/i\nfunction Multipart (boy, cfg) {\n let i\n let len\n const self = this\n let boundary\n const limits = cfg.limits\n const isPartAFile = cfg.isPartAFile || ((fieldName, contentType, fileName) => (contentType === 'application/octet-stream' || fileName !== undefined))\n const parsedConType = cfg.parsedConType || []\n const defCharset = cfg.defCharset || 'utf8'\n const preservePath = cfg.preservePath\n const fileOpts = { highWaterMark: cfg.fileHwm }\n\n for (i = 0, len = parsedConType.length; i < len; ++i) {\n if (Array.isArray(parsedConType[i]) &&\n RE_BOUNDARY.test(parsedConType[i][0])) {\n boundary = parsedConType[i][1]\n break\n }\n }\n\n function checkFinished () {\n if (nends === 0 && finished && !boy._done) {\n finished = false\n self.end()\n }\n }\n\n if (typeof boundary !== 'string') { throw new Error('Multipart: Boundary not found') }\n\n const fieldSizeLimit = getLimit(limits, 'fieldSize', 1 * 1024 * 1024)\n const fileSizeLimit = getLimit(limits, 'fileSize', Infinity)\n const filesLimit = getLimit(limits, 'files', Infinity)\n const fieldsLimit = getLimit(limits, 'fields', Infinity)\n const partsLimit = getLimit(limits, 'parts', Infinity)\n const headerPairsLimit = getLimit(limits, 'headerPairs', 2000)\n const headerSizeLimit = getLimit(limits, 'headerSize', 80 * 1024)\n\n let nfiles = 0\n let nfields = 0\n let nends = 0\n let curFile\n let curField\n let finished = false\n\n this._needDrain = false\n this._pause = false\n this._cb = undefined\n this._nparts = 0\n this._boy = boy\n\n const parserCfg = {\n boundary,\n maxHeaderPairs: headerPairsLimit,\n maxHeaderSize: headerSizeLimit,\n partHwm: fileOpts.highWaterMark,\n highWaterMark: cfg.highWaterMark\n }\n\n this.parser = new Dicer(parserCfg)\n this.parser.on('drain', function () {\n self._needDrain = false\n if (self._cb && !self._pause) {\n const cb = self._cb\n self._cb = undefined\n cb()\n }\n }).on('part', function onPart (part) {\n if (++self._nparts > partsLimit) {\n self.parser.removeListener('part', onPart)\n self.parser.on('part', skipPart)\n boy.hitPartsLimit = true\n boy.emit('partsLimit')\n return skipPart(part)\n }\n\n // hack because streams2 _always_ doesn't emit 'end' until nextTick, so let\n // us emit 'end' early since we know the part has ended if we are already\n // seeing the next part\n if (curField) {\n const field = curField\n field.emit('end')\n field.removeAllListeners('end')\n }\n\n part.on('header', function (header) {\n let contype\n let fieldname\n let parsed\n let charset\n let encoding\n let filename\n let nsize = 0\n\n if (header['content-type']) {\n parsed = parseParams(header['content-type'][0])\n if (parsed[0]) {\n contype = parsed[0].toLowerCase()\n for (i = 0, len = parsed.length; i < len; ++i) {\n if (RE_CHARSET.test(parsed[i][0])) {\n charset = parsed[i][1].toLowerCase()\n break\n }\n }\n }\n }\n\n if (contype === undefined) { contype = 'text/plain' }\n if (charset === undefined) { charset = defCharset }\n\n if (header['content-disposition']) {\n parsed = parseParams(header['content-disposition'][0])\n if (!RE_FIELD.test(parsed[0])) { return skipPart(part) }\n for (i = 0, len = parsed.length; i < len; ++i) {\n if (RE_NAME.test(parsed[i][0])) {\n fieldname = parsed[i][1]\n } else if (RE_FILENAME.test(parsed[i][0])) {\n filename = parsed[i][1]\n if (!preservePath) { filename = basename(filename) }\n }\n }\n } else { return skipPart(part) }\n\n if (header['content-transfer-encoding']) { encoding = header['content-transfer-encoding'][0].toLowerCase() } else { encoding = '7bit' }\n\n let onData,\n onEnd\n\n if (isPartAFile(fieldname, contype, filename)) {\n // file/binary field\n if (nfiles === filesLimit) {\n if (!boy.hitFilesLimit) {\n boy.hitFilesLimit = true\n boy.emit('filesLimit')\n }\n return skipPart(part)\n }\n\n ++nfiles\n\n if (boy.listenerCount('file') === 0) {\n self.parser._ignore()\n return\n }\n\n ++nends\n const file = new FileStream(fileOpts)\n curFile = file\n file.on('end', function () {\n --nends\n self._pause = false\n checkFinished()\n if (self._cb && !self._needDrain) {\n const cb = self._cb\n self._cb = undefined\n cb()\n }\n })\n file._read = function (n) {\n if (!self._pause) { return }\n self._pause = false\n if (self._cb && !self._needDrain) {\n const cb = self._cb\n self._cb = undefined\n cb()\n }\n }\n boy.emit('file', fieldname, file, filename, encoding, contype)\n\n onData = function (data) {\n if ((nsize += data.length) > fileSizeLimit) {\n const extralen = fileSizeLimit - nsize + data.length\n if (extralen > 0) { file.push(data.slice(0, extralen)) }\n file.truncated = true\n file.bytesRead = fileSizeLimit\n part.removeAllListeners('data')\n file.emit('limit')\n return\n } else if (!file.push(data)) { self._pause = true }\n\n file.bytesRead = nsize\n }\n\n onEnd = function () {\n curFile = undefined\n file.push(null)\n }\n } else {\n // non-file field\n if (nfields === fieldsLimit) {\n if (!boy.hitFieldsLimit) {\n boy.hitFieldsLimit = true\n boy.emit('fieldsLimit')\n }\n return skipPart(part)\n }\n\n ++nfields\n ++nends\n let buffer = ''\n let truncated = false\n curField = part\n\n onData = function (data) {\n if ((nsize += data.length) > fieldSizeLimit) {\n const extralen = (fieldSizeLimit - (nsize - data.length))\n buffer += data.toString('binary', 0, extralen)\n truncated = true\n part.removeAllListeners('data')\n } else { buffer += data.toString('binary') }\n }\n\n onEnd = function () {\n curField = undefined\n if (buffer.length) { buffer = decodeText(buffer, 'binary', charset) }\n boy.emit('field', fieldname, buffer, false, truncated, encoding, contype)\n --nends\n checkFinished()\n }\n }\n\n /* As of node@2efe4ab761666 (v0.10.29+/v0.11.14+), busboy had become\n broken. Streams2/streams3 is a huge black box of confusion, but\n somehow overriding the sync state seems to fix things again (and still\n seems to work for previous node versions).\n */\n part._readableState.sync = false\n\n part.on('data', onData)\n part.on('end', onEnd)\n }).on('error', function (err) {\n if (curFile) { curFile.emit('error', err) }\n })\n }).on('error', function (err) {\n boy.emit('error', err)\n }).on('finish', function () {\n finished = true\n checkFinished()\n })\n}\n\nMultipart.prototype.write = function (chunk, cb) {\n const r = this.parser.write(chunk)\n if (r && !this._pause) {\n cb()\n } else {\n this._needDrain = !r\n this._cb = cb\n }\n}\n\nMultipart.prototype.end = function () {\n const self = this\n\n if (self.parser.writable) {\n self.parser.end()\n } else if (!self._boy._done) {\n process.nextTick(function () {\n self._boy._done = true\n self._boy.emit('finish')\n })\n }\n}\n\nfunction skipPart (part) {\n part.resume()\n}\n\nfunction FileStream (opts) {\n Readable.call(this, opts)\n\n this.bytesRead = 0\n\n this.truncated = false\n}\n\ninherits(FileStream, Readable)\n\nFileStream.prototype._read = function (n) {}\n\nmodule.exports = Multipart\n","'use strict'\n\nconst Decoder = require('../utils/Decoder')\nconst decodeText = require('../utils/decodeText')\nconst getLimit = require('../utils/getLimit')\n\nconst RE_CHARSET = /^charset$/i\n\nUrlEncoded.detect = /^application\\/x-www-form-urlencoded/i\nfunction UrlEncoded (boy, cfg) {\n const limits = cfg.limits\n const parsedConType = cfg.parsedConType\n this.boy = boy\n\n this.fieldSizeLimit = getLimit(limits, 'fieldSize', 1 * 1024 * 1024)\n this.fieldNameSizeLimit = getLimit(limits, 'fieldNameSize', 100)\n this.fieldsLimit = getLimit(limits, 'fields', Infinity)\n\n let charset\n for (var i = 0, len = parsedConType.length; i < len; ++i) { // eslint-disable-line no-var\n if (Array.isArray(parsedConType[i]) &&\n RE_CHARSET.test(parsedConType[i][0])) {\n charset = parsedConType[i][1].toLowerCase()\n break\n }\n }\n\n if (charset === undefined) { charset = cfg.defCharset || 'utf8' }\n\n this.decoder = new Decoder()\n this.charset = charset\n this._fields = 0\n this._state = 'key'\n this._checkingBytes = true\n this._bytesKey = 0\n this._bytesVal = 0\n this._key = ''\n this._val = ''\n this._keyTrunc = false\n this._valTrunc = false\n this._hitLimit = false\n}\n\nUrlEncoded.prototype.write = function (data, cb) {\n if (this._fields === this.fieldsLimit) {\n if (!this.boy.hitFieldsLimit) {\n this.boy.hitFieldsLimit = true\n this.boy.emit('fieldsLimit')\n }\n return cb()\n }\n\n let idxeq; let idxamp; let i; let p = 0; const len = data.length\n\n while (p < len) {\n if (this._state === 'key') {\n idxeq = idxamp = undefined\n for (i = p; i < len; ++i) {\n if (!this._checkingBytes) { ++p }\n if (data[i] === 0x3D/* = */) {\n idxeq = i\n break\n } else if (data[i] === 0x26/* & */) {\n idxamp = i\n break\n }\n if (this._checkingBytes && this._bytesKey === this.fieldNameSizeLimit) {\n this._hitLimit = true\n break\n } else if (this._checkingBytes) { ++this._bytesKey }\n }\n\n if (idxeq !== undefined) {\n // key with assignment\n if (idxeq > p) { this._key += this.decoder.write(data.toString('binary', p, idxeq)) }\n this._state = 'val'\n\n this._hitLimit = false\n this._checkingBytes = true\n this._val = ''\n this._bytesVal = 0\n this._valTrunc = false\n this.decoder.reset()\n\n p = idxeq + 1\n } else if (idxamp !== undefined) {\n // key with no assignment\n ++this._fields\n let key; const keyTrunc = this._keyTrunc\n if (idxamp > p) { key = (this._key += this.decoder.write(data.toString('binary', p, idxamp))) } else { key = this._key }\n\n this._hitLimit = false\n this._checkingBytes = true\n this._key = ''\n this._bytesKey = 0\n this._keyTrunc = false\n this.decoder.reset()\n\n if (key.length) {\n this.boy.emit('field', decodeText(key, 'binary', this.charset),\n '',\n keyTrunc,\n false)\n }\n\n p = idxamp + 1\n if (this._fields === this.fieldsLimit) { return cb() }\n } else if (this._hitLimit) {\n // we may not have hit the actual limit if there are encoded bytes...\n if (i > p) { this._key += this.decoder.write(data.toString('binary', p, i)) }\n p = i\n if ((this._bytesKey = this._key.length) === this.fieldNameSizeLimit) {\n // yep, we actually did hit the limit\n this._checkingBytes = false\n this._keyTrunc = true\n }\n } else {\n if (p < len) { this._key += this.decoder.write(data.toString('binary', p)) }\n p = len\n }\n } else {\n idxamp = undefined\n for (i = p; i < len; ++i) {\n if (!this._checkingBytes) { ++p }\n if (data[i] === 0x26/* & */) {\n idxamp = i\n break\n }\n if (this._checkingBytes && this._bytesVal === this.fieldSizeLimit) {\n this._hitLimit = true\n break\n } else if (this._checkingBytes) { ++this._bytesVal }\n }\n\n if (idxamp !== undefined) {\n ++this._fields\n if (idxamp > p) { this._val += this.decoder.write(data.toString('binary', p, idxamp)) }\n this.boy.emit('field', decodeText(this._key, 'binary', this.charset),\n decodeText(this._val, 'binary', this.charset),\n this._keyTrunc,\n this._valTrunc)\n this._state = 'key'\n\n this._hitLimit = false\n this._checkingBytes = true\n this._key = ''\n this._bytesKey = 0\n this._keyTrunc = false\n this.decoder.reset()\n\n p = idxamp + 1\n if (this._fields === this.fieldsLimit) { return cb() }\n } else if (this._hitLimit) {\n // we may not have hit the actual limit if there are encoded bytes...\n if (i > p) { this._val += this.decoder.write(data.toString('binary', p, i)) }\n p = i\n if ((this._val === '' && this.fieldSizeLimit === 0) ||\n (this._bytesVal = this._val.length) === this.fieldSizeLimit) {\n // yep, we actually did hit the limit\n this._checkingBytes = false\n this._valTrunc = true\n }\n } else {\n if (p < len) { this._val += this.decoder.write(data.toString('binary', p)) }\n p = len\n }\n }\n }\n cb()\n}\n\nUrlEncoded.prototype.end = function () {\n if (this.boy._done) { return }\n\n if (this._state === 'key' && this._key.length > 0) {\n this.boy.emit('field', decodeText(this._key, 'binary', this.charset),\n '',\n this._keyTrunc,\n false)\n } else if (this._state === 'val') {\n this.boy.emit('field', decodeText(this._key, 'binary', this.charset),\n decodeText(this._val, 'binary', this.charset),\n this._keyTrunc,\n this._valTrunc)\n }\n this.boy._done = true\n this.boy.emit('finish')\n}\n\nmodule.exports = UrlEncoded\n","'use strict'\n\nconst RE_PLUS = /\\+/g\n\nconst HEX = [\n 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,\n 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,\n 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,\n 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0,\n 0, 1, 1, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0,\n 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,\n 0, 1, 1, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0,\n 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0\n]\n\nfunction Decoder () {\n this.buffer = undefined\n}\nDecoder.prototype.write = function (str) {\n // Replace '+' with ' ' before decoding\n str = str.replace(RE_PLUS, ' ')\n let res = ''\n let i = 0; let p = 0; const len = str.length\n for (; i < len; ++i) {\n if (this.buffer !== undefined) {\n if (!HEX[str.charCodeAt(i)]) {\n res += '%' + this.buffer\n this.buffer = undefined\n --i // retry character\n } else {\n this.buffer += str[i]\n ++p\n if (this.buffer.length === 2) {\n res += String.fromCharCode(parseInt(this.buffer, 16))\n this.buffer = undefined\n }\n }\n } else if (str[i] === '%') {\n if (i > p) {\n res += str.substring(p, i)\n p = i\n }\n this.buffer = ''\n ++p\n }\n }\n if (p < len && this.buffer === undefined) { res += str.substring(p) }\n return res\n}\nDecoder.prototype.reset = function () {\n this.buffer = undefined\n}\n\nmodule.exports = Decoder\n","'use strict'\n\nmodule.exports = function basename (path) {\n if (typeof path !== 'string') { return '' }\n for (var i = path.length - 1; i >= 0; --i) { // eslint-disable-line no-var\n switch (path.charCodeAt(i)) {\n case 0x2F: // '/'\n case 0x5C: // '\\'\n path = path.slice(i + 1)\n return (path === '..' || path === '.' ? '' : path)\n }\n }\n return (path === '..' || path === '.' ? '' : path)\n}\n","'use strict'\n\n// Node has always utf-8\nconst utf8Decoder = new TextDecoder('utf-8')\nconst textDecoders = new Map([\n ['utf-8', utf8Decoder],\n ['utf8', utf8Decoder]\n])\n\nfunction getDecoder (charset) {\n let lc\n while (true) {\n switch (charset) {\n case 'utf-8':\n case 'utf8':\n return decoders.utf8\n case 'latin1':\n case 'ascii': // TODO: Make these a separate, strict decoder?\n case 'us-ascii':\n case 'iso-8859-1':\n case 'iso8859-1':\n case 'iso88591':\n case 'iso_8859-1':\n case 'windows-1252':\n case 'iso_8859-1:1987':\n case 'cp1252':\n case 'x-cp1252':\n return decoders.latin1\n case 'utf16le':\n case 'utf-16le':\n case 'ucs2':\n case 'ucs-2':\n return decoders.utf16le\n case 'base64':\n return decoders.base64\n default:\n if (lc === undefined) {\n lc = true\n charset = charset.toLowerCase()\n continue\n }\n return decoders.other.bind(charset)\n }\n }\n}\n\nconst decoders = {\n utf8: (data, sourceEncoding) => {\n if (data.length === 0) {\n return ''\n }\n if (typeof data === 'string') {\n data = Buffer.from(data, sourceEncoding)\n }\n return data.utf8Slice(0, data.length)\n },\n\n latin1: (data, sourceEncoding) => {\n if (data.length === 0) {\n return ''\n }\n if (typeof data === 'string') {\n return data\n }\n return data.latin1Slice(0, data.length)\n },\n\n utf16le: (data, sourceEncoding) => {\n if (data.length === 0) {\n return ''\n }\n if (typeof data === 'string') {\n data = Buffer.from(data, sourceEncoding)\n }\n return data.ucs2Slice(0, data.length)\n },\n\n base64: (data, sourceEncoding) => {\n if (data.length === 0) {\n return ''\n }\n if (typeof data === 'string') {\n data = Buffer.from(data, sourceEncoding)\n }\n return data.base64Slice(0, data.length)\n },\n\n other: (data, sourceEncoding) => {\n if (data.length === 0) {\n return ''\n }\n if (typeof data === 'string') {\n data = Buffer.from(data, sourceEncoding)\n }\n\n if (textDecoders.has(this.toString())) {\n try {\n return textDecoders.get(this).decode(data)\n } catch {}\n }\n return typeof data === 'string'\n ? data\n : data.toString()\n }\n}\n\nfunction decodeText (text, sourceEncoding, destEncoding) {\n if (text) {\n return getDecoder(destEncoding)(text, sourceEncoding)\n }\n return text\n}\n\nmodule.exports = decodeText\n","'use strict'\n\nmodule.exports = function getLimit (limits, name, defaultLimit) {\n if (\n !limits ||\n limits[name] === undefined ||\n limits[name] === null\n ) { return defaultLimit }\n\n if (\n typeof limits[name] !== 'number' ||\n isNaN(limits[name])\n ) { throw new TypeError('Limit ' + name + ' is not a valid number') }\n\n return limits[name]\n}\n","/* eslint-disable object-property-newline */\n'use strict'\n\nconst decodeText = require('./decodeText')\n\nconst RE_ENCODED = /%[a-fA-F0-9][a-fA-F0-9]/g\n\nconst EncodedLookup = {\n '%00': '\\x00', '%01': '\\x01', '%02': '\\x02', '%03': '\\x03', '%04': '\\x04',\n '%05': '\\x05', '%06': '\\x06', '%07': '\\x07', '%08': '\\x08', '%09': '\\x09',\n '%0a': '\\x0a', '%0A': '\\x0a', '%0b': '\\x0b', '%0B': '\\x0b', '%0c': '\\x0c',\n '%0C': '\\x0c', '%0d': '\\x0d', '%0D': '\\x0d', '%0e': '\\x0e', '%0E': '\\x0e',\n '%0f': '\\x0f', '%0F': '\\x0f', '%10': '\\x10', '%11': '\\x11', '%12': '\\x12',\n '%13': '\\x13', '%14': '\\x14', '%15': '\\x15', '%16': '\\x16', '%17': '\\x17',\n '%18': '\\x18', '%19': '\\x19', '%1a': '\\x1a', '%1A': '\\x1a', '%1b': '\\x1b',\n '%1B': '\\x1b', '%1c': '\\x1c', '%1C': '\\x1c', '%1d': '\\x1d', '%1D': '\\x1d',\n '%1e': '\\x1e', '%1E': '\\x1e', '%1f': '\\x1f', '%1F': '\\x1f', '%20': '\\x20',\n '%21': '\\x21', '%22': '\\x22', '%23': '\\x23', '%24': '\\x24', '%25': '\\x25',\n '%26': '\\x26', '%27': '\\x27', '%28': '\\x28', '%29': '\\x29', '%2a': '\\x2a',\n '%2A': '\\x2a', '%2b': '\\x2b', '%2B': '\\x2b', '%2c': '\\x2c', '%2C': '\\x2c',\n '%2d': '\\x2d', '%2D': '\\x2d', '%2e': '\\x2e', '%2E': '\\x2e', '%2f': '\\x2f',\n '%2F': '\\x2f', '%30': '\\x30', '%31': '\\x31', '%32': '\\x32', '%33': '\\x33',\n '%34': '\\x34', '%35': '\\x35', '%36': '\\x36', '%37': '\\x37', '%38': '\\x38',\n '%39': '\\x39', '%3a': '\\x3a', '%3A': '\\x3a', '%3b': '\\x3b', '%3B': '\\x3b',\n '%3c': '\\x3c', '%3C': '\\x3c', '%3d': '\\x3d', '%3D': '\\x3d', '%3e': '\\x3e',\n '%3E': '\\x3e', '%3f': '\\x3f', '%3F': '\\x3f', '%40': '\\x40', '%41': '\\x41',\n '%42': '\\x42', '%43': '\\x43', '%44': '\\x44', '%45': '\\x45', '%46': '\\x46',\n '%47': '\\x47', '%48': '\\x48', '%49': '\\x49', '%4a': '\\x4a', '%4A': '\\x4a',\n '%4b': '\\x4b', '%4B': '\\x4b', '%4c': '\\x4c', '%4C': '\\x4c', '%4d': '\\x4d',\n '%4D': '\\x4d', '%4e': '\\x4e', '%4E': '\\x4e', '%4f': '\\x4f', '%4F': '\\x4f',\n '%50': '\\x50', '%51': '\\x51', '%52': '\\x52', '%53': '\\x53', '%54': '\\x54',\n '%55': '\\x55', '%56': '\\x56', '%57': '\\x57', '%58': '\\x58', '%59': '\\x59',\n '%5a': '\\x5a', '%5A': '\\x5a', '%5b': '\\x5b', '%5B': '\\x5b', '%5c': '\\x5c',\n '%5C': '\\x5c', '%5d': '\\x5d', '%5D': '\\x5d', '%5e': '\\x5e', '%5E': '\\x5e',\n '%5f': '\\x5f', '%5F': '\\x5f', '%60': '\\x60', '%61': '\\x61', '%62': '\\x62',\n '%63': '\\x63', '%64': '\\x64', '%65': '\\x65', '%66': '\\x66', '%67': '\\x67',\n '%68': '\\x68', '%69': '\\x69', '%6a': '\\x6a', '%6A': '\\x6a', '%6b': '\\x6b',\n '%6B': '\\x6b', '%6c': '\\x6c', '%6C': '\\x6c', '%6d': '\\x6d', '%6D': '\\x6d',\n '%6e': '\\x6e', '%6E': '\\x6e', '%6f': '\\x6f', '%6F': '\\x6f', '%70': '\\x70',\n '%71': '\\x71', '%72': '\\x72', '%73': '\\x73', '%74': '\\x74', '%75': '\\x75',\n '%76': '\\x76', '%77': '\\x77', '%78': '\\x78', '%79': '\\x79', '%7a': '\\x7a',\n '%7A': '\\x7a', '%7b': '\\x7b', '%7B': '\\x7b', '%7c': '\\x7c', '%7C': '\\x7c',\n '%7d': '\\x7d', '%7D': '\\x7d', '%7e': '\\x7e', '%7E': '\\x7e', '%7f': '\\x7f',\n '%7F': '\\x7f', '%80': '\\x80', '%81': '\\x81', '%82': '\\x82', '%83': '\\x83',\n '%84': '\\x84', '%85': '\\x85', '%86': '\\x86', '%87': '\\x87', '%88': '\\x88',\n '%89': '\\x89', '%8a': '\\x8a', '%8A': '\\x8a', '%8b': '\\x8b', '%8B': '\\x8b',\n '%8c': '\\x8c', '%8C': '\\x8c', '%8d': '\\x8d', '%8D': '\\x8d', '%8e': '\\x8e',\n '%8E': '\\x8e', '%8f': '\\x8f', '%8F': '\\x8f', '%90': '\\x90', '%91': '\\x91',\n '%92': '\\x92', '%93': '\\x93', '%94': '\\x94', '%95': '\\x95', '%96': '\\x96',\n '%97': '\\x97', '%98': '\\x98', '%99': '\\x99', '%9a': '\\x9a', '%9A': '\\x9a',\n '%9b': '\\x9b', '%9B': '\\x9b', '%9c': '\\x9c', '%9C': '\\x9c', '%9d': '\\x9d',\n '%9D': '\\x9d', '%9e': '\\x9e', '%9E': '\\x9e', '%9f': '\\x9f', '%9F': '\\x9f',\n '%a0': '\\xa0', '%A0': '\\xa0', '%a1': '\\xa1', '%A1': '\\xa1', '%a2': '\\xa2',\n '%A2': '\\xa2', '%a3': '\\xa3', '%A3': '\\xa3', '%a4': '\\xa4', '%A4': '\\xa4',\n '%a5': '\\xa5', '%A5': '\\xa5', '%a6': '\\xa6', '%A6': '\\xa6', '%a7': '\\xa7',\n '%A7': '\\xa7', '%a8': '\\xa8', '%A8': '\\xa8', '%a9': '\\xa9', '%A9': '\\xa9',\n '%aa': '\\xaa', '%Aa': '\\xaa', '%aA': '\\xaa', '%AA': '\\xaa', '%ab': '\\xab',\n '%Ab': '\\xab', '%aB': '\\xab', '%AB': '\\xab', '%ac': '\\xac', '%Ac': '\\xac',\n '%aC': '\\xac', '%AC': '\\xac', '%ad': '\\xad', '%Ad': '\\xad', '%aD': '\\xad',\n '%AD': '\\xad', '%ae': '\\xae', '%Ae': '\\xae', '%aE': '\\xae', '%AE': '\\xae',\n '%af': '\\xaf', '%Af': '\\xaf', '%aF': '\\xaf', '%AF': '\\xaf', '%b0': '\\xb0',\n '%B0': '\\xb0', '%b1': '\\xb1', '%B1': '\\xb1', '%b2': '\\xb2', '%B2': '\\xb2',\n '%b3': '\\xb3', '%B3': '\\xb3', '%b4': '\\xb4', '%B4': '\\xb4', '%b5': '\\xb5',\n '%B5': '\\xb5', '%b6': '\\xb6', '%B6': '\\xb6', '%b7': '\\xb7', '%B7': '\\xb7',\n '%b8': '\\xb8', '%B8': '\\xb8', '%b9': '\\xb9', '%B9': '\\xb9', '%ba': '\\xba',\n '%Ba': '\\xba', '%bA': '\\xba', '%BA': '\\xba', '%bb': '\\xbb', '%Bb': '\\xbb',\n '%bB': '\\xbb', '%BB': '\\xbb', '%bc': '\\xbc', '%Bc': '\\xbc', '%bC': '\\xbc',\n '%BC': '\\xbc', '%bd': '\\xbd', '%Bd': '\\xbd', '%bD': '\\xbd', '%BD': '\\xbd',\n '%be': '\\xbe', '%Be': '\\xbe', '%bE': '\\xbe', '%BE': '\\xbe', '%bf': '\\xbf',\n '%Bf': '\\xbf', '%bF': '\\xbf', '%BF': '\\xbf', '%c0': '\\xc0', '%C0': '\\xc0',\n '%c1': '\\xc1', '%C1': '\\xc1', '%c2': '\\xc2', '%C2': '\\xc2', '%c3': '\\xc3',\n '%C3': '\\xc3', '%c4': '\\xc4', '%C4': '\\xc4', '%c5': '\\xc5', '%C5': '\\xc5',\n '%c6': '\\xc6', '%C6': '\\xc6', '%c7': '\\xc7', '%C7': '\\xc7', '%c8': '\\xc8',\n '%C8': '\\xc8', '%c9': '\\xc9', '%C9': '\\xc9', '%ca': '\\xca', '%Ca': '\\xca',\n '%cA': '\\xca', '%CA': '\\xca', '%cb': '\\xcb', '%Cb': '\\xcb', '%cB': '\\xcb',\n '%CB': '\\xcb', '%cc': '\\xcc', '%Cc': '\\xcc', '%cC': '\\xcc', '%CC': '\\xcc',\n '%cd': '\\xcd', '%Cd': '\\xcd', '%cD': '\\xcd', '%CD': '\\xcd', '%ce': '\\xce',\n '%Ce': '\\xce', '%cE': '\\xce', '%CE': '\\xce', '%cf': '\\xcf', '%Cf': '\\xcf',\n '%cF': '\\xcf', '%CF': '\\xcf', '%d0': '\\xd0', '%D0': '\\xd0', '%d1': '\\xd1',\n '%D1': '\\xd1', '%d2': '\\xd2', '%D2': '\\xd2', '%d3': '\\xd3', '%D3': '\\xd3',\n '%d4': '\\xd4', '%D4': '\\xd4', '%d5': '\\xd5', '%D5': '\\xd5', '%d6': '\\xd6',\n '%D6': '\\xd6', '%d7': '\\xd7', '%D7': '\\xd7', '%d8': '\\xd8', '%D8': '\\xd8',\n '%d9': '\\xd9', '%D9': '\\xd9', '%da': '\\xda', '%Da': '\\xda', '%dA': '\\xda',\n '%DA': '\\xda', '%db': '\\xdb', '%Db': '\\xdb', '%dB': '\\xdb', '%DB': '\\xdb',\n '%dc': '\\xdc', '%Dc': '\\xdc', '%dC': '\\xdc', '%DC': '\\xdc', '%dd': '\\xdd',\n '%Dd': '\\xdd', '%dD': '\\xdd', '%DD': '\\xdd', '%de': '\\xde', '%De': '\\xde',\n '%dE': '\\xde', '%DE': '\\xde', '%df': '\\xdf', '%Df': '\\xdf', '%dF': '\\xdf',\n '%DF': '\\xdf', '%e0': '\\xe0', '%E0': '\\xe0', '%e1': '\\xe1', '%E1': '\\xe1',\n '%e2': '\\xe2', '%E2': '\\xe2', '%e3': '\\xe3', '%E3': '\\xe3', '%e4': '\\xe4',\n '%E4': '\\xe4', '%e5': '\\xe5', '%E5': '\\xe5', '%e6': '\\xe6', '%E6': '\\xe6',\n '%e7': '\\xe7', '%E7': '\\xe7', '%e8': '\\xe8', '%E8': '\\xe8', '%e9': '\\xe9',\n '%E9': '\\xe9', '%ea': '\\xea', '%Ea': '\\xea', '%eA': '\\xea', '%EA': '\\xea',\n '%eb': '\\xeb', '%Eb': '\\xeb', '%eB': '\\xeb', '%EB': '\\xeb', '%ec': '\\xec',\n '%Ec': '\\xec', '%eC': '\\xec', '%EC': '\\xec', '%ed': '\\xed', '%Ed': '\\xed',\n '%eD': '\\xed', '%ED': '\\xed', '%ee': '\\xee', '%Ee': '\\xee', '%eE': '\\xee',\n '%EE': '\\xee', '%ef': '\\xef', '%Ef': '\\xef', '%eF': '\\xef', '%EF': '\\xef',\n '%f0': '\\xf0', '%F0': '\\xf0', '%f1': '\\xf1', '%F1': '\\xf1', '%f2': '\\xf2',\n '%F2': '\\xf2', '%f3': '\\xf3', '%F3': '\\xf3', '%f4': '\\xf4', '%F4': '\\xf4',\n '%f5': '\\xf5', '%F5': '\\xf5', '%f6': '\\xf6', '%F6': '\\xf6', '%f7': '\\xf7',\n '%F7': '\\xf7', '%f8': '\\xf8', '%F8': '\\xf8', '%f9': '\\xf9', '%F9': '\\xf9',\n '%fa': '\\xfa', '%Fa': '\\xfa', '%fA': '\\xfa', '%FA': '\\xfa', '%fb': '\\xfb',\n '%Fb': '\\xfb', '%fB': '\\xfb', '%FB': '\\xfb', '%fc': '\\xfc', '%Fc': '\\xfc',\n '%fC': '\\xfc', '%FC': '\\xfc', '%fd': '\\xfd', '%Fd': '\\xfd', '%fD': '\\xfd',\n '%FD': '\\xfd', '%fe': '\\xfe', '%Fe': '\\xfe', '%fE': '\\xfe', '%FE': '\\xfe',\n '%ff': '\\xff', '%Ff': '\\xff', '%fF': '\\xff', '%FF': '\\xff'\n}\n\nfunction encodedReplacer (match) {\n return EncodedLookup[match]\n}\n\nconst STATE_KEY = 0\nconst STATE_VALUE = 1\nconst STATE_CHARSET = 2\nconst STATE_LANG = 3\n\nfunction parseParams (str) {\n const res = []\n let state = STATE_KEY\n let charset = ''\n let inquote = false\n let escaping = false\n let p = 0\n let tmp = ''\n const len = str.length\n\n for (var i = 0; i < len; ++i) { // eslint-disable-line no-var\n const char = str[i]\n if (char === '\\\\' && inquote) {\n if (escaping) { escaping = false } else {\n escaping = true\n continue\n }\n } else if (char === '\"') {\n if (!escaping) {\n if (inquote) {\n inquote = false\n state = STATE_KEY\n } else { inquote = true }\n continue\n } else { escaping = false }\n } else {\n if (escaping && inquote) { tmp += '\\\\' }\n escaping = false\n if ((state === STATE_CHARSET || state === STATE_LANG) && char === \"'\") {\n if (state === STATE_CHARSET) {\n state = STATE_LANG\n charset = tmp.substring(1)\n } else { state = STATE_VALUE }\n tmp = ''\n continue\n } else if (state === STATE_KEY &&\n (char === '*' || char === '=') &&\n res.length) {\n state = char === '*'\n ? STATE_CHARSET\n : STATE_VALUE\n res[p] = [tmp, undefined]\n tmp = ''\n continue\n } else if (!inquote && char === ';') {\n state = STATE_KEY\n if (charset) {\n if (tmp.length) {\n tmp = decodeText(tmp.replace(RE_ENCODED, encodedReplacer),\n 'binary',\n charset)\n }\n charset = ''\n } else if (tmp.length) {\n tmp = decodeText(tmp, 'binary', 'utf8')\n }\n if (res[p] === undefined) { res[p] = tmp } else { res[p][1] = tmp }\n tmp = ''\n ++p\n continue\n } else if (!inquote && (char === ' ' || char === '\\t')) { continue }\n }\n tmp += char\n }\n if (charset && tmp.length) {\n tmp = decodeText(tmp.replace(RE_ENCODED, encodedReplacer),\n 'binary',\n charset)\n } else if (tmp) {\n tmp = decodeText(tmp, 'binary', 'utf8')\n }\n\n if (res[p] === undefined) {\n if (tmp) { res[p] = tmp }\n } else { res[p][1] = tmp }\n\n return res\n}\n\nmodule.exports = parseParams\n","// The module cache\nvar __webpack_module_cache__ = {};\n\n// The require function\nfunction __webpack_require__(moduleId) {\n\t// Check if module is in cache\n\tvar cachedModule = __webpack_module_cache__[moduleId];\n\tif (cachedModule !== undefined) {\n\t\treturn cachedModule.exports;\n\t}\n\t// Create a new module (and put it into the cache)\n\tvar module = __webpack_module_cache__[moduleId] = {\n\t\t// no module.id needed\n\t\t// no module.loaded needed\n\t\texports: {}\n\t};\n\n\t// Execute the module function\n\tvar threw = true;\n\ttry {\n\t\t__webpack_modules__[moduleId].call(module.exports, module, module.exports, __webpack_require__);\n\t\tthrew = false;\n\t} finally {\n\t\tif(threw) delete __webpack_module_cache__[moduleId];\n\t}\n\n\t// Return the exports of the module\n\treturn module.exports;\n}\n\n","\nif (typeof __webpack_require__ !== 'undefined') __webpack_require__.ab = __dirname + \"/\";","import * as core from '@actions/core';\nimport * as github from '@actions/github';\nimport * as coverage from './covered';\n\nconst inputFileArgument = 'coverage-file';\nconst coverageTypeArgument = 'coverage-format';\nconst baseRefArgument = 'base-ref';\n\nasync function publishCheck(opts: { totals: { covered: number; total: number }; token: string }) {\n const sha = github.context.payload.pull_request?.head?.sha || github.context.sha;\n const octokit = github.getOctokit(opts.token);\n\n const description = opts.totals.total\n ? `${((opts.totals.covered / opts.totals.total) * 100).toFixed(\n 2\n )}% of changed statements covered by tests`\n : `No changes`;\n const output = {\n owner: github.context.repo.owner,\n repo: github.context.repo.repo,\n context: 'Change coverage',\n sha,\n state: 'success' as const,\n description\n };\n await octokit.rest.repos.createCommitStatus(output);\n}\n\nfunction parseCoverageType(coverageType: string): 'lcov' | 'istanbul' {\n if (!coverageType) {\n return 'istanbul';\n } else if (coverageType == 'lcov' || coverageType == 'istanbul') {\n return coverageType;\n }\n throw new Error(\"coverage-type must be either 'istanbul' or 'lcov'\");\n}\n\nasync function run() {\n const file = core.getInput(inputFileArgument);\n const coverageType = parseCoverageType(core.getInput(coverageTypeArgument, { required: false }));\n\n const result = await coverage.run({\n base: core.getInput(baseRefArgument),\n head: github.context.sha,\n coverage: file,\n coverageType: coverageType\n });\n let covered = 0;\n let total = 0;\n covered += result.covered;\n total += result.total;\n for (const [file, lines] of Object.entries(result.uncoveredLines)) {\n for (const line of lines.subranges()) {\n const data = {\n file,\n startLine: line.low,\n endLine: line.high\n };\n // eslint-disable-next-line no-console\n console.log(data);\n core.warning('This change is not covered by tests', data);\n }\n }\n await publishCheck({\n token: core.getInput('github-token'),\n totals: { covered, total }\n });\n}\nvoid run();\n"],"names":[],"sourceRoot":""} \ No newline at end of file +{"version":3,"file":"index.js","mappings":";;;;;;;AAAA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;;;;;;AC3FA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;;;;;;AC/UA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;;;;;;ACzDA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;;;;;;AC5EA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;;;;;;ACzDA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;;;;;;AC1RA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;;;;;;ACvCA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;;;;;;ACtDA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;;;;;;ACxCA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;;;;;;ACrEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;;;;;;AC1DA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;;;;;;AChFA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;;;;;;AC3oBA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;;;;;;ACjFA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;;;;;;;AC5EA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;;;;;;;AChKA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;;;;;;;ACvXA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;;;;;;;ACrJA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;;;;;;;ACxYA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;;;;;;;ACjnEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;;;;;;;ACzFA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;;;;;;AC5NA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;;;;;;AC5DA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;;;;;;AC7CA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;;;;;;AC1BA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;;;;;;;AClBA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;;;;;;ACnBA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;;;;;;AC5LA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;;;;;;;ACzCA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;;;;;;ACvCA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;;;;;;ACzBA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;;;;;;ACzBA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;;;;;AC9EA;;;;;;;;;ACAA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;;;;;;;ACvQA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;;;;;;;ACtKA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;;;;;;ACnJA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;;;;;;;ACrDA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;;;;;;;ACvGA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;;;;;;;ACxPA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;;;;;;;ACnLA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;;;;;;;AC3NA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;;;;;;;ACxGA;AACA;AACA;AACA;AACA;AACA;AACA;;;;;;;;;ACNA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;;;;;;ACjUA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;;;;;;;AC7CA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;;;;;;;AC7LA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;;;;;;;ACr0BA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;;;;;;;AC/IA;AACA;AACA;AACA;AACA;;;;;;;;;ACJA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;;;;;;;AChDA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;;;;;;;AC1uEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;;;;;;;AC/CA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;;;;;;;ACXA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;;;;;;;ACvLA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;;;;;;;AC5TA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;;;;;;;AClSA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;;;;;;;AC5LA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;;;;;;;ACrOA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;;;;;;AClfA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;;;;;;;AC9DA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;;;;;;;AC9fA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;;;;;;;AC/LA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;;;;;;;AClBA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;;;;;;;AC5lBA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;;;;;;ACtJA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;;;;;;;AClnBA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;;;;;;;ACvVA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;;;;;;;ACxQA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;;;;;;;ACvCA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;;;;;;;AC5kBA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;;;;;;;ACnmEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;;;;;;;ACj7BA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;;;;;;;AC1jBA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;;;;;;;ACTA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;;;;;;;AC9iCA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;;;;;;;ACroBA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;;;;;;;ACjSA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;;;;;;;ACvVA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;;;;;;;AC7EA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;;;;;;;ACTA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;;;;;;;ACvYA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;;;;;;;AC/BA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;;;;;;;AClCA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;;;;;;ACvNA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;;;;;;;AC/UA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;;;;;;;ACpBA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;;;;;ACrRA;;;;;;;;ACAA;;;;;;;;;ACAA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;;;;;;ACdA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;;;;;;;AC1KA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;;;;;;;AC1DA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;;;;;;;AChBA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;;;;;;;AC7MA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;;;;;;;AC1DA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;;;;;;;ACtBA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;;;;;;;AC9VA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;;;;;;;ACvCA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;;;;;;;AC5BA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;;;;;;;ACpHA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;;;;;;ACjMA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;;;;;;;ACjCA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;;;;;;;AC7FA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;;;;;;;AC5LA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;;;;;;;AChGA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;;;;;;;AClSA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;;;;;;;AClDA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;;;;;;;AC9SA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;;;;;;;ACxEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;;;;;;;ACvVA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;;;;;;;ACXA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;;;;;;;ACvMA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;;;;;;;AChoBA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;;;;;;;ACjBA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;;;;;;AC9EA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;;;;;;ACtBA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;;;;;;ACPA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;;;;;;AC5CA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;;;;;;ACPA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;;;;;;ACvBA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;;;;;;ACtBA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;;;;;;ACtCA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;;;;;;AC1GA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;;;;;;ACfA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;;;;;;AC7EA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;;;;;;ACpCA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;;;;;;ACfA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;;;;;;AChBA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;;;;;ACpBA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;;;;;;;;;;AChCA;AACA;AACA;AACA;AACA;AACA;AAcA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;AAGA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAEA;;AAIA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AA/CA;AAsDA;AACA;AACA;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAGA;AACA;AACA;AACA;AACA;AAEA;AACA;AACA;AACA;AACA;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AAZA;;;;;;;;;AC9KA;;;;;;;;ACAA;;;;;;;;ACAA;;;;;;;;ACAA;;;;;;;;ACAA;;;;;;;;ACAA;;;;;;;;ACAA;;;;;;;;ACAA;;;;;;;;ACAA;;;;;;;;ACAA;;;;;;;;ACAA;;;;;;;;ACAA;;;;;;;;ACAA;;;;;;;;ACAA;;;;;;;;ACAA;;;;;;;;ACAA;;;;;;;;ACAA;;;;;;;;ACAA;;;;;;;;ACAA;;;;;;;;ACAA;;;;;;;;ACAA;;;;;;;;ACAA;;;;;;;;ACAA;;;;;;;;ACAA;;;;;;;;ACAA;;;;;;;;ACAA;;;;;;;;ACAA;;;;;;;;ACAA;;;;;;;;ACAA;;;;;;;;ACAA;;;;;;;;ACAA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;;;;;;;ACpNA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;;;;;;;ACnGA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;;;;;;;ACZA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;;;;;;;ACnOA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;;;;;;;ACpFA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;;;;;;;ACjTA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;;;;;;;AC7LA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;;;;;;;ACrDA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;;;;;;;ACbA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;;;;;;;ACjHA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;;;;;;;ACfA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;;;;;ACnMA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;AC7BA;AACA;;;;;;;;;;ACDA;AACA;AACA;AAEA;AACA;AACA;AACA;AACA;AAEA;;AACA;AACA;AAEA;AACA;AAGA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAEA;AACA;AACA;AAEA;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA","sources":[".././node_modules/@actions/core/lib/command.js",".././node_modules/@actions/core/lib/core.js",".././node_modules/@actions/core/lib/file-command.js",".././node_modules/@actions/core/lib/oidc-utils.js",".././node_modules/@actions/core/lib/path-utils.js",".././node_modules/@actions/core/lib/summary.js",".././node_modules/@actions/core/lib/utils.js",".././node_modules/@actions/github/lib/context.js",".././node_modules/@actions/github/lib/github.js",".././node_modules/@actions/github/lib/internal/utils.js",".././node_modules/@actions/github/lib/utils.js",".././node_modules/@actions/http-client/lib/auth.js",".././node_modules/@actions/http-client/lib/index.js",".././node_modules/@actions/http-client/lib/proxy.js",".././node_modules/@octokit/auth-token/dist-node/index.js",".././node_modules/@octokit/core/dist-node/index.js",".././node_modules/@octokit/endpoint/dist-node/index.js",".././node_modules/@octokit/graphql/dist-node/index.js",".././node_modules/@octokit/plugin-paginate-rest/dist-node/index.js",".././node_modules/@octokit/plugin-rest-endpoint-methods/dist-node/index.js",".././node_modules/@octokit/request-error/dist-node/index.js",".././node_modules/@octokit/request/dist-node/index.js",".././node_modules/before-after-hook/index.js",".././node_modules/before-after-hook/lib/add.js",".././node_modules/before-after-hook/lib/register.js",".././node_modules/before-after-hook/lib/remove.js",".././node_modules/deprecation/dist-node/index.js",".././node_modules/drange/lib/index.js",".././node_modules/once/once.js",".././node_modules/parse-lcov/build/index.js",".././node_modules/parse-lcov/build/line.js",".././node_modules/parse-lcov/build/record.js",".././node_modules/parse-lcov/build/transform.js",".././node_modules/tunnel/index.js",".././node_modules/tunnel/lib/tunnel.js",".././node_modules/undici/index.js",".././node_modules/undici/lib/agent.js",".././node_modules/undici/lib/api/abort-signal.js",".././node_modules/undici/lib/api/api-connect.js",".././node_modules/undici/lib/api/api-pipeline.js",".././node_modules/undici/lib/api/api-request.js",".././node_modules/undici/lib/api/api-stream.js",".././node_modules/undici/lib/api/api-upgrade.js",".././node_modules/undici/lib/api/index.js",".././node_modules/undici/lib/api/readable.js",".././node_modules/undici/lib/api/util.js",".././node_modules/undici/lib/balanced-pool.js",".././node_modules/undici/lib/cache/cache.js",".././node_modules/undici/lib/cache/cachestorage.js",".././node_modules/undici/lib/cache/symbols.js",".././node_modules/undici/lib/cache/util.js",".././node_modules/undici/lib/client.js",".././node_modules/undici/lib/compat/dispatcher-weakref.js",".././node_modules/undici/lib/cookies/constants.js",".././node_modules/undici/lib/cookies/index.js",".././node_modules/undici/lib/cookies/parse.js",".././node_modules/undici/lib/cookies/util.js",".././node_modules/undici/lib/core/connect.js",".././node_modules/undici/lib/core/errors.js",".././node_modules/undici/lib/core/request.js",".././node_modules/undici/lib/core/symbols.js",".././node_modules/undici/lib/core/util.js",".././node_modules/undici/lib/dispatcher-base.js",".././node_modules/undici/lib/dispatcher.js",".././node_modules/undici/lib/fetch/body.js",".././node_modules/undici/lib/fetch/constants.js",".././node_modules/undici/lib/fetch/dataURL.js",".././node_modules/undici/lib/fetch/file.js",".././node_modules/undici/lib/fetch/formdata.js",".././node_modules/undici/lib/fetch/global.js",".././node_modules/undici/lib/fetch/headers.js",".././node_modules/undici/lib/fetch/index.js",".././node_modules/undici/lib/fetch/request.js",".././node_modules/undici/lib/fetch/response.js",".././node_modules/undici/lib/fetch/symbols.js",".././node_modules/undici/lib/fetch/util.js",".././node_modules/undici/lib/fetch/webidl.js",".././node_modules/undici/lib/fileapi/encoding.js",".././node_modules/undici/lib/fileapi/filereader.js",".././node_modules/undici/lib/fileapi/progressevent.js",".././node_modules/undici/lib/fileapi/symbols.js",".././node_modules/undici/lib/fileapi/util.js",".././node_modules/undici/lib/global.js",".././node_modules/undici/lib/handler/DecoratorHandler.js",".././node_modules/undici/lib/handler/RedirectHandler.js",".././node_modules/undici/lib/handler/RetryHandler.js",".././node_modules/undici/lib/interceptor/redirectInterceptor.js",".././node_modules/undici/lib/llhttp/constants.js",".././node_modules/undici/lib/llhttp/llhttp-wasm.js",".././node_modules/undici/lib/llhttp/llhttp_simd-wasm.js",".././node_modules/undici/lib/llhttp/utils.js",".././node_modules/undici/lib/mock/mock-agent.js",".././node_modules/undici/lib/mock/mock-client.js",".././node_modules/undici/lib/mock/mock-errors.js",".././node_modules/undici/lib/mock/mock-interceptor.js",".././node_modules/undici/lib/mock/mock-pool.js",".././node_modules/undici/lib/mock/mock-symbols.js",".././node_modules/undici/lib/mock/mock-utils.js",".././node_modules/undici/lib/mock/pending-interceptors-formatter.js",".././node_modules/undici/lib/mock/pluralizer.js",".././node_modules/undici/lib/node/fixed-queue.js",".././node_modules/undici/lib/pool-base.js",".././node_modules/undici/lib/pool-stats.js",".././node_modules/undici/lib/pool.js",".././node_modules/undici/lib/proxy-agent.js",".././node_modules/undici/lib/timers.js",".././node_modules/undici/lib/websocket/connection.js",".././node_modules/undici/lib/websocket/constants.js",".././node_modules/undici/lib/websocket/events.js",".././node_modules/undici/lib/websocket/frame.js",".././node_modules/undici/lib/websocket/receiver.js",".././node_modules/undici/lib/websocket/symbols.js",".././node_modules/undici/lib/websocket/util.js",".././node_modules/undici/lib/websocket/websocket.js",".././node_modules/universal-user-agent/dist-node/index.js",".././node_modules/uuid/dist/index.js",".././node_modules/uuid/dist/md5.js",".././node_modules/uuid/dist/nil.js",".././node_modules/uuid/dist/parse.js",".././node_modules/uuid/dist/regex.js",".././node_modules/uuid/dist/rng.js",".././node_modules/uuid/dist/sha1.js",".././node_modules/uuid/dist/stringify.js",".././node_modules/uuid/dist/v1.js",".././node_modules/uuid/dist/v3.js",".././node_modules/uuid/dist/v35.js",".././node_modules/uuid/dist/v4.js",".././node_modules/uuid/dist/v5.js",".././node_modules/uuid/dist/validate.js",".././node_modules/uuid/dist/version.js",".././node_modules/wrappy/wrappy.js",".././src/covered.ts","../external node-commonjs \"assert\"","../external node-commonjs \"async_hooks\"","../external node-commonjs \"buffer\"","../external node-commonjs \"child_process\"","../external node-commonjs \"console\"","../external node-commonjs \"crypto\"","../external node-commonjs \"diagnostics_channel\"","../external node-commonjs \"events\"","../external node-commonjs \"fs\"","../external node-commonjs \"fs/promises\"","../external node-commonjs \"http\"","../external node-commonjs \"http2\"","../external node-commonjs \"https\"","../external node-commonjs \"net\"","../external node-commonjs \"node:events\"","../external node-commonjs \"node:stream\"","../external node-commonjs \"node:util\"","../external node-commonjs \"os\"","../external node-commonjs \"path\"","../external node-commonjs \"perf_hooks\"","../external node-commonjs \"querystring\"","../external node-commonjs \"stream\"","../external node-commonjs \"stream/web\"","../external node-commonjs \"string_decoder\"","../external node-commonjs \"tls\"","../external node-commonjs \"url\"","../external node-commonjs \"util\"","../external node-commonjs \"util/types\"","../external node-commonjs \"worker_threads\"","../external node-commonjs \"zlib\"",".././node_modules/@fastify/busboy/deps/dicer/lib/Dicer.js",".././node_modules/@fastify/busboy/deps/dicer/lib/HeaderParser.js",".././node_modules/@fastify/busboy/deps/dicer/lib/PartStream.js",".././node_modules/@fastify/busboy/deps/streamsearch/sbmh.js",".././node_modules/@fastify/busboy/lib/main.js",".././node_modules/@fastify/busboy/lib/types/multipart.js",".././node_modules/@fastify/busboy/lib/types/urlencoded.js",".././node_modules/@fastify/busboy/lib/utils/Decoder.js",".././node_modules/@fastify/busboy/lib/utils/basename.js",".././node_modules/@fastify/busboy/lib/utils/decodeText.js",".././node_modules/@fastify/busboy/lib/utils/getLimit.js",".././node_modules/@fastify/busboy/lib/utils/parseParams.js","../webpack/bootstrap","../webpack/runtime/compat",".././src/index.ts"],"sourcesContent":["\"use strict\";\nvar __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {\n if (k2 === undefined) k2 = k;\n Object.defineProperty(o, k2, { enumerable: true, get: function() { return m[k]; } });\n}) : (function(o, m, k, k2) {\n if (k2 === undefined) k2 = k;\n o[k2] = m[k];\n}));\nvar __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) {\n Object.defineProperty(o, \"default\", { enumerable: true, value: v });\n}) : function(o, v) {\n o[\"default\"] = v;\n});\nvar __importStar = (this && this.__importStar) || function (mod) {\n if (mod && mod.__esModule) return mod;\n var result = {};\n if (mod != null) for (var k in mod) if (k !== \"default\" && Object.hasOwnProperty.call(mod, k)) __createBinding(result, mod, k);\n __setModuleDefault(result, mod);\n return result;\n};\nObject.defineProperty(exports, \"__esModule\", { value: true });\nexports.issue = exports.issueCommand = void 0;\nconst os = __importStar(require(\"os\"));\nconst utils_1 = require(\"./utils\");\n/**\n * Commands\n *\n * Command Format:\n * ::name key=value,key=value::message\n *\n * Examples:\n * ::warning::This is the message\n * ::set-env name=MY_VAR::some value\n */\nfunction issueCommand(command, properties, message) {\n const cmd = new Command(command, properties, message);\n process.stdout.write(cmd.toString() + os.EOL);\n}\nexports.issueCommand = issueCommand;\nfunction issue(name, message = '') {\n issueCommand(name, {}, message);\n}\nexports.issue = issue;\nconst CMD_STRING = '::';\nclass Command {\n constructor(command, properties, message) {\n if (!command) {\n command = 'missing.command';\n }\n this.command = command;\n this.properties = properties;\n this.message = message;\n }\n toString() {\n let cmdStr = CMD_STRING + this.command;\n if (this.properties && Object.keys(this.properties).length > 0) {\n cmdStr += ' ';\n let first = true;\n for (const key in this.properties) {\n if (this.properties.hasOwnProperty(key)) {\n const val = this.properties[key];\n if (val) {\n if (first) {\n first = false;\n }\n else {\n cmdStr += ',';\n }\n cmdStr += `${key}=${escapeProperty(val)}`;\n }\n }\n }\n }\n cmdStr += `${CMD_STRING}${escapeData(this.message)}`;\n return cmdStr;\n }\n}\nfunction escapeData(s) {\n return utils_1.toCommandValue(s)\n .replace(/%/g, '%25')\n .replace(/\\r/g, '%0D')\n .replace(/\\n/g, '%0A');\n}\nfunction escapeProperty(s) {\n return utils_1.toCommandValue(s)\n .replace(/%/g, '%25')\n .replace(/\\r/g, '%0D')\n .replace(/\\n/g, '%0A')\n .replace(/:/g, '%3A')\n .replace(/,/g, '%2C');\n}\n//# sourceMappingURL=command.js.map","\"use strict\";\nvar __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {\n if (k2 === undefined) k2 = k;\n Object.defineProperty(o, k2, { enumerable: true, get: function() { return m[k]; } });\n}) : (function(o, m, k, k2) {\n if (k2 === undefined) k2 = k;\n o[k2] = m[k];\n}));\nvar __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) {\n Object.defineProperty(o, \"default\", { enumerable: true, value: v });\n}) : function(o, v) {\n o[\"default\"] = v;\n});\nvar __importStar = (this && this.__importStar) || function (mod) {\n if (mod && mod.__esModule) return mod;\n var result = {};\n if (mod != null) for (var k in mod) if (k !== \"default\" && Object.hasOwnProperty.call(mod, k)) __createBinding(result, mod, k);\n __setModuleDefault(result, mod);\n return result;\n};\nvar __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) {\n function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }\n return new (P || (P = Promise))(function (resolve, reject) {\n function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }\n function rejected(value) { try { step(generator[\"throw\"](value)); } catch (e) { reject(e); } }\n function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); }\n step((generator = generator.apply(thisArg, _arguments || [])).next());\n });\n};\nObject.defineProperty(exports, \"__esModule\", { value: true });\nexports.getIDToken = exports.getState = exports.saveState = exports.group = exports.endGroup = exports.startGroup = exports.info = exports.notice = exports.warning = exports.error = exports.debug = exports.isDebug = exports.setFailed = exports.setCommandEcho = exports.setOutput = exports.getBooleanInput = exports.getMultilineInput = exports.getInput = exports.addPath = exports.setSecret = exports.exportVariable = exports.ExitCode = void 0;\nconst command_1 = require(\"./command\");\nconst file_command_1 = require(\"./file-command\");\nconst utils_1 = require(\"./utils\");\nconst os = __importStar(require(\"os\"));\nconst path = __importStar(require(\"path\"));\nconst oidc_utils_1 = require(\"./oidc-utils\");\n/**\n * The code to exit an action\n */\nvar ExitCode;\n(function (ExitCode) {\n /**\n * A code indicating that the action was successful\n */\n ExitCode[ExitCode[\"Success\"] = 0] = \"Success\";\n /**\n * A code indicating that the action was a failure\n */\n ExitCode[ExitCode[\"Failure\"] = 1] = \"Failure\";\n})(ExitCode = exports.ExitCode || (exports.ExitCode = {}));\n//-----------------------------------------------------------------------\n// Variables\n//-----------------------------------------------------------------------\n/**\n * Sets env variable for this action and future actions in the job\n * @param name the name of the variable to set\n * @param val the value of the variable. Non-string values will be converted to a string via JSON.stringify\n */\n// eslint-disable-next-line @typescript-eslint/no-explicit-any\nfunction exportVariable(name, val) {\n const convertedVal = utils_1.toCommandValue(val);\n process.env[name] = convertedVal;\n const filePath = process.env['GITHUB_ENV'] || '';\n if (filePath) {\n return file_command_1.issueFileCommand('ENV', file_command_1.prepareKeyValueMessage(name, val));\n }\n command_1.issueCommand('set-env', { name }, convertedVal);\n}\nexports.exportVariable = exportVariable;\n/**\n * Registers a secret which will get masked from logs\n * @param secret value of the secret\n */\nfunction setSecret(secret) {\n command_1.issueCommand('add-mask', {}, secret);\n}\nexports.setSecret = setSecret;\n/**\n * Prepends inputPath to the PATH (for this action and future actions)\n * @param inputPath\n */\nfunction addPath(inputPath) {\n const filePath = process.env['GITHUB_PATH'] || '';\n if (filePath) {\n file_command_1.issueFileCommand('PATH', inputPath);\n }\n else {\n command_1.issueCommand('add-path', {}, inputPath);\n }\n process.env['PATH'] = `${inputPath}${path.delimiter}${process.env['PATH']}`;\n}\nexports.addPath = addPath;\n/**\n * Gets the value of an input.\n * Unless trimWhitespace is set to false in InputOptions, the value is also trimmed.\n * Returns an empty string if the value is not defined.\n *\n * @param name name of the input to get\n * @param options optional. See InputOptions.\n * @returns string\n */\nfunction getInput(name, options) {\n const val = process.env[`INPUT_${name.replace(/ /g, '_').toUpperCase()}`] || '';\n if (options && options.required && !val) {\n throw new Error(`Input required and not supplied: ${name}`);\n }\n if (options && options.trimWhitespace === false) {\n return val;\n }\n return val.trim();\n}\nexports.getInput = getInput;\n/**\n * Gets the values of an multiline input. Each value is also trimmed.\n *\n * @param name name of the input to get\n * @param options optional. See InputOptions.\n * @returns string[]\n *\n */\nfunction getMultilineInput(name, options) {\n const inputs = getInput(name, options)\n .split('\\n')\n .filter(x => x !== '');\n if (options && options.trimWhitespace === false) {\n return inputs;\n }\n return inputs.map(input => input.trim());\n}\nexports.getMultilineInput = getMultilineInput;\n/**\n * Gets the input value of the boolean type in the YAML 1.2 \"core schema\" specification.\n * Support boolean input list: `true | True | TRUE | false | False | FALSE` .\n * The return value is also in boolean type.\n * ref: https://yaml.org/spec/1.2/spec.html#id2804923\n *\n * @param name name of the input to get\n * @param options optional. See InputOptions.\n * @returns boolean\n */\nfunction getBooleanInput(name, options) {\n const trueValue = ['true', 'True', 'TRUE'];\n const falseValue = ['false', 'False', 'FALSE'];\n const val = getInput(name, options);\n if (trueValue.includes(val))\n return true;\n if (falseValue.includes(val))\n return false;\n throw new TypeError(`Input does not meet YAML 1.2 \"Core Schema\" specification: ${name}\\n` +\n `Support boolean input list: \\`true | True | TRUE | false | False | FALSE\\``);\n}\nexports.getBooleanInput = getBooleanInput;\n/**\n * Sets the value of an output.\n *\n * @param name name of the output to set\n * @param value value to store. Non-string values will be converted to a string via JSON.stringify\n */\n// eslint-disable-next-line @typescript-eslint/no-explicit-any\nfunction setOutput(name, value) {\n const filePath = process.env['GITHUB_OUTPUT'] || '';\n if (filePath) {\n return file_command_1.issueFileCommand('OUTPUT', file_command_1.prepareKeyValueMessage(name, value));\n }\n process.stdout.write(os.EOL);\n command_1.issueCommand('set-output', { name }, utils_1.toCommandValue(value));\n}\nexports.setOutput = setOutput;\n/**\n * Enables or disables the echoing of commands into stdout for the rest of the step.\n * Echoing is disabled by default if ACTIONS_STEP_DEBUG is not set.\n *\n */\nfunction setCommandEcho(enabled) {\n command_1.issue('echo', enabled ? 'on' : 'off');\n}\nexports.setCommandEcho = setCommandEcho;\n//-----------------------------------------------------------------------\n// Results\n//-----------------------------------------------------------------------\n/**\n * Sets the action status to failed.\n * When the action exits it will be with an exit code of 1\n * @param message add error issue message\n */\nfunction setFailed(message) {\n process.exitCode = ExitCode.Failure;\n error(message);\n}\nexports.setFailed = setFailed;\n//-----------------------------------------------------------------------\n// Logging Commands\n//-----------------------------------------------------------------------\n/**\n * Gets whether Actions Step Debug is on or not\n */\nfunction isDebug() {\n return process.env['RUNNER_DEBUG'] === '1';\n}\nexports.isDebug = isDebug;\n/**\n * Writes debug message to user log\n * @param message debug message\n */\nfunction debug(message) {\n command_1.issueCommand('debug', {}, message);\n}\nexports.debug = debug;\n/**\n * Adds an error issue\n * @param message error issue message. Errors will be converted to string via toString()\n * @param properties optional properties to add to the annotation.\n */\nfunction error(message, properties = {}) {\n command_1.issueCommand('error', utils_1.toCommandProperties(properties), message instanceof Error ? message.toString() : message);\n}\nexports.error = error;\n/**\n * Adds a warning issue\n * @param message warning issue message. Errors will be converted to string via toString()\n * @param properties optional properties to add to the annotation.\n */\nfunction warning(message, properties = {}) {\n command_1.issueCommand('warning', utils_1.toCommandProperties(properties), message instanceof Error ? message.toString() : message);\n}\nexports.warning = warning;\n/**\n * Adds a notice issue\n * @param message notice issue message. Errors will be converted to string via toString()\n * @param properties optional properties to add to the annotation.\n */\nfunction notice(message, properties = {}) {\n command_1.issueCommand('notice', utils_1.toCommandProperties(properties), message instanceof Error ? message.toString() : message);\n}\nexports.notice = notice;\n/**\n * Writes info to log with console.log.\n * @param message info message\n */\nfunction info(message) {\n process.stdout.write(message + os.EOL);\n}\nexports.info = info;\n/**\n * Begin an output group.\n *\n * Output until the next `groupEnd` will be foldable in this group\n *\n * @param name The name of the output group\n */\nfunction startGroup(name) {\n command_1.issue('group', name);\n}\nexports.startGroup = startGroup;\n/**\n * End an output group.\n */\nfunction endGroup() {\n command_1.issue('endgroup');\n}\nexports.endGroup = endGroup;\n/**\n * Wrap an asynchronous function call in a group.\n *\n * Returns the same type as the function itself.\n *\n * @param name The name of the group\n * @param fn The function to wrap in the group\n */\nfunction group(name, fn) {\n return __awaiter(this, void 0, void 0, function* () {\n startGroup(name);\n let result;\n try {\n result = yield fn();\n }\n finally {\n endGroup();\n }\n return result;\n });\n}\nexports.group = group;\n//-----------------------------------------------------------------------\n// Wrapper action state\n//-----------------------------------------------------------------------\n/**\n * Saves state for current action, the state can only be retrieved by this action's post job execution.\n *\n * @param name name of the state to store\n * @param value value to store. Non-string values will be converted to a string via JSON.stringify\n */\n// eslint-disable-next-line @typescript-eslint/no-explicit-any\nfunction saveState(name, value) {\n const filePath = process.env['GITHUB_STATE'] || '';\n if (filePath) {\n return file_command_1.issueFileCommand('STATE', file_command_1.prepareKeyValueMessage(name, value));\n }\n command_1.issueCommand('save-state', { name }, utils_1.toCommandValue(value));\n}\nexports.saveState = saveState;\n/**\n * Gets the value of an state set by this action's main execution.\n *\n * @param name name of the state to get\n * @returns string\n */\nfunction getState(name) {\n return process.env[`STATE_${name}`] || '';\n}\nexports.getState = getState;\nfunction getIDToken(aud) {\n return __awaiter(this, void 0, void 0, function* () {\n return yield oidc_utils_1.OidcClient.getIDToken(aud);\n });\n}\nexports.getIDToken = getIDToken;\n/**\n * Summary exports\n */\nvar summary_1 = require(\"./summary\");\nObject.defineProperty(exports, \"summary\", { enumerable: true, get: function () { return summary_1.summary; } });\n/**\n * @deprecated use core.summary\n */\nvar summary_2 = require(\"./summary\");\nObject.defineProperty(exports, \"markdownSummary\", { enumerable: true, get: function () { return summary_2.markdownSummary; } });\n/**\n * Path exports\n */\nvar path_utils_1 = require(\"./path-utils\");\nObject.defineProperty(exports, \"toPosixPath\", { enumerable: true, get: function () { return path_utils_1.toPosixPath; } });\nObject.defineProperty(exports, \"toWin32Path\", { enumerable: true, get: function () { return path_utils_1.toWin32Path; } });\nObject.defineProperty(exports, \"toPlatformPath\", { enumerable: true, get: function () { return path_utils_1.toPlatformPath; } });\n//# sourceMappingURL=core.js.map","\"use strict\";\n// For internal use, subject to change.\nvar __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {\n if (k2 === undefined) k2 = k;\n Object.defineProperty(o, k2, { enumerable: true, get: function() { return m[k]; } });\n}) : (function(o, m, k, k2) {\n if (k2 === undefined) k2 = k;\n o[k2] = m[k];\n}));\nvar __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) {\n Object.defineProperty(o, \"default\", { enumerable: true, value: v });\n}) : function(o, v) {\n o[\"default\"] = v;\n});\nvar __importStar = (this && this.__importStar) || function (mod) {\n if (mod && mod.__esModule) return mod;\n var result = {};\n if (mod != null) for (var k in mod) if (k !== \"default\" && Object.hasOwnProperty.call(mod, k)) __createBinding(result, mod, k);\n __setModuleDefault(result, mod);\n return result;\n};\nObject.defineProperty(exports, \"__esModule\", { value: true });\nexports.prepareKeyValueMessage = exports.issueFileCommand = void 0;\n// We use any as a valid input type\n/* eslint-disable @typescript-eslint/no-explicit-any */\nconst fs = __importStar(require(\"fs\"));\nconst os = __importStar(require(\"os\"));\nconst uuid_1 = require(\"uuid\");\nconst utils_1 = require(\"./utils\");\nfunction issueFileCommand(command, message) {\n const filePath = process.env[`GITHUB_${command}`];\n if (!filePath) {\n throw new Error(`Unable to find environment variable for file command ${command}`);\n }\n if (!fs.existsSync(filePath)) {\n throw new Error(`Missing file at path: ${filePath}`);\n }\n fs.appendFileSync(filePath, `${utils_1.toCommandValue(message)}${os.EOL}`, {\n encoding: 'utf8'\n });\n}\nexports.issueFileCommand = issueFileCommand;\nfunction prepareKeyValueMessage(key, value) {\n const delimiter = `ghadelimiter_${uuid_1.v4()}`;\n const convertedValue = utils_1.toCommandValue(value);\n // These should realistically never happen, but just in case someone finds a\n // way to exploit uuid generation let's not allow keys or values that contain\n // the delimiter.\n if (key.includes(delimiter)) {\n throw new Error(`Unexpected input: name should not contain the delimiter \"${delimiter}\"`);\n }\n if (convertedValue.includes(delimiter)) {\n throw new Error(`Unexpected input: value should not contain the delimiter \"${delimiter}\"`);\n }\n return `${key}<<${delimiter}${os.EOL}${convertedValue}${os.EOL}${delimiter}`;\n}\nexports.prepareKeyValueMessage = prepareKeyValueMessage;\n//# sourceMappingURL=file-command.js.map","\"use strict\";\nvar __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) {\n function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }\n return new (P || (P = Promise))(function (resolve, reject) {\n function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }\n function rejected(value) { try { step(generator[\"throw\"](value)); } catch (e) { reject(e); } }\n function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); }\n step((generator = generator.apply(thisArg, _arguments || [])).next());\n });\n};\nObject.defineProperty(exports, \"__esModule\", { value: true });\nexports.OidcClient = void 0;\nconst http_client_1 = require(\"@actions/http-client\");\nconst auth_1 = require(\"@actions/http-client/lib/auth\");\nconst core_1 = require(\"./core\");\nclass OidcClient {\n static createHttpClient(allowRetry = true, maxRetry = 10) {\n const requestOptions = {\n allowRetries: allowRetry,\n maxRetries: maxRetry\n };\n return new http_client_1.HttpClient('actions/oidc-client', [new auth_1.BearerCredentialHandler(OidcClient.getRequestToken())], requestOptions);\n }\n static getRequestToken() {\n const token = process.env['ACTIONS_ID_TOKEN_REQUEST_TOKEN'];\n if (!token) {\n throw new Error('Unable to get ACTIONS_ID_TOKEN_REQUEST_TOKEN env variable');\n }\n return token;\n }\n static getIDTokenUrl() {\n const runtimeUrl = process.env['ACTIONS_ID_TOKEN_REQUEST_URL'];\n if (!runtimeUrl) {\n throw new Error('Unable to get ACTIONS_ID_TOKEN_REQUEST_URL env variable');\n }\n return runtimeUrl;\n }\n static getCall(id_token_url) {\n var _a;\n return __awaiter(this, void 0, void 0, function* () {\n const httpclient = OidcClient.createHttpClient();\n const res = yield httpclient\n .getJson(id_token_url)\n .catch(error => {\n throw new Error(`Failed to get ID Token. \\n \n Error Code : ${error.statusCode}\\n \n Error Message: ${error.message}`);\n });\n const id_token = (_a = res.result) === null || _a === void 0 ? void 0 : _a.value;\n if (!id_token) {\n throw new Error('Response json body do not have ID Token field');\n }\n return id_token;\n });\n }\n static getIDToken(audience) {\n return __awaiter(this, void 0, void 0, function* () {\n try {\n // New ID Token is requested from action service\n let id_token_url = OidcClient.getIDTokenUrl();\n if (audience) {\n const encodedAudience = encodeURIComponent(audience);\n id_token_url = `${id_token_url}&audience=${encodedAudience}`;\n }\n core_1.debug(`ID token url is ${id_token_url}`);\n const id_token = yield OidcClient.getCall(id_token_url);\n core_1.setSecret(id_token);\n return id_token;\n }\n catch (error) {\n throw new Error(`Error message: ${error.message}`);\n }\n });\n }\n}\nexports.OidcClient = OidcClient;\n//# sourceMappingURL=oidc-utils.js.map","\"use strict\";\nvar __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {\n if (k2 === undefined) k2 = k;\n Object.defineProperty(o, k2, { enumerable: true, get: function() { return m[k]; } });\n}) : (function(o, m, k, k2) {\n if (k2 === undefined) k2 = k;\n o[k2] = m[k];\n}));\nvar __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) {\n Object.defineProperty(o, \"default\", { enumerable: true, value: v });\n}) : function(o, v) {\n o[\"default\"] = v;\n});\nvar __importStar = (this && this.__importStar) || function (mod) {\n if (mod && mod.__esModule) return mod;\n var result = {};\n if (mod != null) for (var k in mod) if (k !== \"default\" && Object.hasOwnProperty.call(mod, k)) __createBinding(result, mod, k);\n __setModuleDefault(result, mod);\n return result;\n};\nObject.defineProperty(exports, \"__esModule\", { value: true });\nexports.toPlatformPath = exports.toWin32Path = exports.toPosixPath = void 0;\nconst path = __importStar(require(\"path\"));\n/**\n * toPosixPath converts the given path to the posix form. On Windows, \\\\ will be\n * replaced with /.\n *\n * @param pth. Path to transform.\n * @return string Posix path.\n */\nfunction toPosixPath(pth) {\n return pth.replace(/[\\\\]/g, '/');\n}\nexports.toPosixPath = toPosixPath;\n/**\n * toWin32Path converts the given path to the win32 form. On Linux, / will be\n * replaced with \\\\.\n *\n * @param pth. Path to transform.\n * @return string Win32 path.\n */\nfunction toWin32Path(pth) {\n return pth.replace(/[/]/g, '\\\\');\n}\nexports.toWin32Path = toWin32Path;\n/**\n * toPlatformPath converts the given path to a platform-specific path. It does\n * this by replacing instances of / and \\ with the platform-specific path\n * separator.\n *\n * @param pth The path to platformize.\n * @return string The platform-specific path.\n */\nfunction toPlatformPath(pth) {\n return pth.replace(/[/\\\\]/g, path.sep);\n}\nexports.toPlatformPath = toPlatformPath;\n//# sourceMappingURL=path-utils.js.map","\"use strict\";\nvar __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) {\n function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }\n return new (P || (P = Promise))(function (resolve, reject) {\n function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }\n function rejected(value) { try { step(generator[\"throw\"](value)); } catch (e) { reject(e); } }\n function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); }\n step((generator = generator.apply(thisArg, _arguments || [])).next());\n });\n};\nObject.defineProperty(exports, \"__esModule\", { value: true });\nexports.summary = exports.markdownSummary = exports.SUMMARY_DOCS_URL = exports.SUMMARY_ENV_VAR = void 0;\nconst os_1 = require(\"os\");\nconst fs_1 = require(\"fs\");\nconst { access, appendFile, writeFile } = fs_1.promises;\nexports.SUMMARY_ENV_VAR = 'GITHUB_STEP_SUMMARY';\nexports.SUMMARY_DOCS_URL = 'https://docs.github.com/actions/using-workflows/workflow-commands-for-github-actions#adding-a-job-summary';\nclass Summary {\n constructor() {\n this._buffer = '';\n }\n /**\n * Finds the summary file path from the environment, rejects if env var is not found or file does not exist\n * Also checks r/w permissions.\n *\n * @returns step summary file path\n */\n filePath() {\n return __awaiter(this, void 0, void 0, function* () {\n if (this._filePath) {\n return this._filePath;\n }\n const pathFromEnv = process.env[exports.SUMMARY_ENV_VAR];\n if (!pathFromEnv) {\n throw new Error(`Unable to find environment variable for $${exports.SUMMARY_ENV_VAR}. Check if your runtime environment supports job summaries.`);\n }\n try {\n yield access(pathFromEnv, fs_1.constants.R_OK | fs_1.constants.W_OK);\n }\n catch (_a) {\n throw new Error(`Unable to access summary file: '${pathFromEnv}'. Check if the file has correct read/write permissions.`);\n }\n this._filePath = pathFromEnv;\n return this._filePath;\n });\n }\n /**\n * Wraps content in an HTML tag, adding any HTML attributes\n *\n * @param {string} tag HTML tag to wrap\n * @param {string | null} content content within the tag\n * @param {[attribute: string]: string} attrs key-value list of HTML attributes to add\n *\n * @returns {string} content wrapped in HTML element\n */\n wrap(tag, content, attrs = {}) {\n const htmlAttrs = Object.entries(attrs)\n .map(([key, value]) => ` ${key}=\"${value}\"`)\n .join('');\n if (!content) {\n return `<${tag}${htmlAttrs}>`;\n }\n return `<${tag}${htmlAttrs}>${content}`;\n }\n /**\n * Writes text in the buffer to the summary buffer file and empties buffer. Will append by default.\n *\n * @param {SummaryWriteOptions} [options] (optional) options for write operation\n *\n * @returns {Promise} summary instance\n */\n write(options) {\n return __awaiter(this, void 0, void 0, function* () {\n const overwrite = !!(options === null || options === void 0 ? void 0 : options.overwrite);\n const filePath = yield this.filePath();\n const writeFunc = overwrite ? writeFile : appendFile;\n yield writeFunc(filePath, this._buffer, { encoding: 'utf8' });\n return this.emptyBuffer();\n });\n }\n /**\n * Clears the summary buffer and wipes the summary file\n *\n * @returns {Summary} summary instance\n */\n clear() {\n return __awaiter(this, void 0, void 0, function* () {\n return this.emptyBuffer().write({ overwrite: true });\n });\n }\n /**\n * Returns the current summary buffer as a string\n *\n * @returns {string} string of summary buffer\n */\n stringify() {\n return this._buffer;\n }\n /**\n * If the summary buffer is empty\n *\n * @returns {boolen} true if the buffer is empty\n */\n isEmptyBuffer() {\n return this._buffer.length === 0;\n }\n /**\n * Resets the summary buffer without writing to summary file\n *\n * @returns {Summary} summary instance\n */\n emptyBuffer() {\n this._buffer = '';\n return this;\n }\n /**\n * Adds raw text to the summary buffer\n *\n * @param {string} text content to add\n * @param {boolean} [addEOL=false] (optional) append an EOL to the raw text (default: false)\n *\n * @returns {Summary} summary instance\n */\n addRaw(text, addEOL = false) {\n this._buffer += text;\n return addEOL ? this.addEOL() : this;\n }\n /**\n * Adds the operating system-specific end-of-line marker to the buffer\n *\n * @returns {Summary} summary instance\n */\n addEOL() {\n return this.addRaw(os_1.EOL);\n }\n /**\n * Adds an HTML codeblock to the summary buffer\n *\n * @param {string} code content to render within fenced code block\n * @param {string} lang (optional) language to syntax highlight code\n *\n * @returns {Summary} summary instance\n */\n addCodeBlock(code, lang) {\n const attrs = Object.assign({}, (lang && { lang }));\n const element = this.wrap('pre', this.wrap('code', code), attrs);\n return this.addRaw(element).addEOL();\n }\n /**\n * Adds an HTML list to the summary buffer\n *\n * @param {string[]} items list of items to render\n * @param {boolean} [ordered=false] (optional) if the rendered list should be ordered or not (default: false)\n *\n * @returns {Summary} summary instance\n */\n addList(items, ordered = false) {\n const tag = ordered ? 'ol' : 'ul';\n const listItems = items.map(item => this.wrap('li', item)).join('');\n const element = this.wrap(tag, listItems);\n return this.addRaw(element).addEOL();\n }\n /**\n * Adds an HTML table to the summary buffer\n *\n * @param {SummaryTableCell[]} rows table rows\n *\n * @returns {Summary} summary instance\n */\n addTable(rows) {\n const tableBody = rows\n .map(row => {\n const cells = row\n .map(cell => {\n if (typeof cell === 'string') {\n return this.wrap('td', cell);\n }\n const { header, data, colspan, rowspan } = cell;\n const tag = header ? 'th' : 'td';\n const attrs = Object.assign(Object.assign({}, (colspan && { colspan })), (rowspan && { rowspan }));\n return this.wrap(tag, data, attrs);\n })\n .join('');\n return this.wrap('tr', cells);\n })\n .join('');\n const element = this.wrap('table', tableBody);\n return this.addRaw(element).addEOL();\n }\n /**\n * Adds a collapsable HTML details element to the summary buffer\n *\n * @param {string} label text for the closed state\n * @param {string} content collapsable content\n *\n * @returns {Summary} summary instance\n */\n addDetails(label, content) {\n const element = this.wrap('details', this.wrap('summary', label) + content);\n return this.addRaw(element).addEOL();\n }\n /**\n * Adds an HTML image tag to the summary buffer\n *\n * @param {string} src path to the image you to embed\n * @param {string} alt text description of the image\n * @param {SummaryImageOptions} options (optional) addition image attributes\n *\n * @returns {Summary} summary instance\n */\n addImage(src, alt, options) {\n const { width, height } = options || {};\n const attrs = Object.assign(Object.assign({}, (width && { width })), (height && { height }));\n const element = this.wrap('img', null, Object.assign({ src, alt }, attrs));\n return this.addRaw(element).addEOL();\n }\n /**\n * Adds an HTML section heading element\n *\n * @param {string} text heading text\n * @param {number | string} [level=1] (optional) the heading level, default: 1\n *\n * @returns {Summary} summary instance\n */\n addHeading(text, level) {\n const tag = `h${level}`;\n const allowedTag = ['h1', 'h2', 'h3', 'h4', 'h5', 'h6'].includes(tag)\n ? tag\n : 'h1';\n const element = this.wrap(allowedTag, text);\n return this.addRaw(element).addEOL();\n }\n /**\n * Adds an HTML thematic break (
) to the summary buffer\n *\n * @returns {Summary} summary instance\n */\n addSeparator() {\n const element = this.wrap('hr', null);\n return this.addRaw(element).addEOL();\n }\n /**\n * Adds an HTML line break (
) to the summary buffer\n *\n * @returns {Summary} summary instance\n */\n addBreak() {\n const element = this.wrap('br', null);\n return this.addRaw(element).addEOL();\n }\n /**\n * Adds an HTML blockquote to the summary buffer\n *\n * @param {string} text quote text\n * @param {string} cite (optional) citation url\n *\n * @returns {Summary} summary instance\n */\n addQuote(text, cite) {\n const attrs = Object.assign({}, (cite && { cite }));\n const element = this.wrap('blockquote', text, attrs);\n return this.addRaw(element).addEOL();\n }\n /**\n * Adds an HTML anchor tag to the summary buffer\n *\n * @param {string} text link text/content\n * @param {string} href hyperlink\n *\n * @returns {Summary} summary instance\n */\n addLink(text, href) {\n const element = this.wrap('a', text, { href });\n return this.addRaw(element).addEOL();\n }\n}\nconst _summary = new Summary();\n/**\n * @deprecated use `core.summary`\n */\nexports.markdownSummary = _summary;\nexports.summary = _summary;\n//# sourceMappingURL=summary.js.map","\"use strict\";\n// We use any as a valid input type\n/* eslint-disable @typescript-eslint/no-explicit-any */\nObject.defineProperty(exports, \"__esModule\", { value: true });\nexports.toCommandProperties = exports.toCommandValue = void 0;\n/**\n * Sanitizes an input into a string so it can be passed into issueCommand safely\n * @param input input to sanitize into a string\n */\nfunction toCommandValue(input) {\n if (input === null || input === undefined) {\n return '';\n }\n else if (typeof input === 'string' || input instanceof String) {\n return input;\n }\n return JSON.stringify(input);\n}\nexports.toCommandValue = toCommandValue;\n/**\n *\n * @param annotationProperties\n * @returns The command properties to send with the actual annotation command\n * See IssueCommandProperties: https://github.com/actions/runner/blob/main/src/Runner.Worker/ActionCommandManager.cs#L646\n */\nfunction toCommandProperties(annotationProperties) {\n if (!Object.keys(annotationProperties).length) {\n return {};\n }\n return {\n title: annotationProperties.title,\n file: annotationProperties.file,\n line: annotationProperties.startLine,\n endLine: annotationProperties.endLine,\n col: annotationProperties.startColumn,\n endColumn: annotationProperties.endColumn\n };\n}\nexports.toCommandProperties = toCommandProperties;\n//# sourceMappingURL=utils.js.map","\"use strict\";\nObject.defineProperty(exports, \"__esModule\", { value: true });\nexports.Context = void 0;\nconst fs_1 = require(\"fs\");\nconst os_1 = require(\"os\");\nclass Context {\n /**\n * Hydrate the context from the environment\n */\n constructor() {\n var _a, _b, _c;\n this.payload = {};\n if (process.env.GITHUB_EVENT_PATH) {\n if ((0, fs_1.existsSync)(process.env.GITHUB_EVENT_PATH)) {\n this.payload = JSON.parse((0, fs_1.readFileSync)(process.env.GITHUB_EVENT_PATH, { encoding: 'utf8' }));\n }\n else {\n const path = process.env.GITHUB_EVENT_PATH;\n process.stdout.write(`GITHUB_EVENT_PATH ${path} does not exist${os_1.EOL}`);\n }\n }\n this.eventName = process.env.GITHUB_EVENT_NAME;\n this.sha = process.env.GITHUB_SHA;\n this.ref = process.env.GITHUB_REF;\n this.workflow = process.env.GITHUB_WORKFLOW;\n this.action = process.env.GITHUB_ACTION;\n this.actor = process.env.GITHUB_ACTOR;\n this.job = process.env.GITHUB_JOB;\n this.runNumber = parseInt(process.env.GITHUB_RUN_NUMBER, 10);\n this.runId = parseInt(process.env.GITHUB_RUN_ID, 10);\n this.apiUrl = (_a = process.env.GITHUB_API_URL) !== null && _a !== void 0 ? _a : `https://api.github.com`;\n this.serverUrl = (_b = process.env.GITHUB_SERVER_URL) !== null && _b !== void 0 ? _b : `https://github.com`;\n this.graphqlUrl =\n (_c = process.env.GITHUB_GRAPHQL_URL) !== null && _c !== void 0 ? _c : `https://api.github.com/graphql`;\n }\n get issue() {\n const payload = this.payload;\n return Object.assign(Object.assign({}, this.repo), { number: (payload.issue || payload.pull_request || payload).number });\n }\n get repo() {\n if (process.env.GITHUB_REPOSITORY) {\n const [owner, repo] = process.env.GITHUB_REPOSITORY.split('/');\n return { owner, repo };\n }\n if (this.payload.repository) {\n return {\n owner: this.payload.repository.owner.login,\n repo: this.payload.repository.name\n };\n }\n throw new Error(\"context.repo requires a GITHUB_REPOSITORY environment variable like 'owner/repo'\");\n }\n}\nexports.Context = Context;\n//# sourceMappingURL=context.js.map","\"use strict\";\nvar __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {\n if (k2 === undefined) k2 = k;\n var desc = Object.getOwnPropertyDescriptor(m, k);\n if (!desc || (\"get\" in desc ? !m.__esModule : desc.writable || desc.configurable)) {\n desc = { enumerable: true, get: function() { return m[k]; } };\n }\n Object.defineProperty(o, k2, desc);\n}) : (function(o, m, k, k2) {\n if (k2 === undefined) k2 = k;\n o[k2] = m[k];\n}));\nvar __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) {\n Object.defineProperty(o, \"default\", { enumerable: true, value: v });\n}) : function(o, v) {\n o[\"default\"] = v;\n});\nvar __importStar = (this && this.__importStar) || function (mod) {\n if (mod && mod.__esModule) return mod;\n var result = {};\n if (mod != null) for (var k in mod) if (k !== \"default\" && Object.prototype.hasOwnProperty.call(mod, k)) __createBinding(result, mod, k);\n __setModuleDefault(result, mod);\n return result;\n};\nObject.defineProperty(exports, \"__esModule\", { value: true });\nexports.getOctokit = exports.context = void 0;\nconst Context = __importStar(require(\"./context\"));\nconst utils_1 = require(\"./utils\");\nexports.context = new Context.Context();\n/**\n * Returns a hydrated octokit ready to use for GitHub Actions\n *\n * @param token the repo PAT or GITHUB_TOKEN\n * @param options other options to set\n */\nfunction getOctokit(token, options, ...additionalPlugins) {\n const GitHubWithPlugins = utils_1.GitHub.plugin(...additionalPlugins);\n return new GitHubWithPlugins((0, utils_1.getOctokitOptions)(token, options));\n}\nexports.getOctokit = getOctokit;\n//# sourceMappingURL=github.js.map","\"use strict\";\nvar __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {\n if (k2 === undefined) k2 = k;\n var desc = Object.getOwnPropertyDescriptor(m, k);\n if (!desc || (\"get\" in desc ? !m.__esModule : desc.writable || desc.configurable)) {\n desc = { enumerable: true, get: function() { return m[k]; } };\n }\n Object.defineProperty(o, k2, desc);\n}) : (function(o, m, k, k2) {\n if (k2 === undefined) k2 = k;\n o[k2] = m[k];\n}));\nvar __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) {\n Object.defineProperty(o, \"default\", { enumerable: true, value: v });\n}) : function(o, v) {\n o[\"default\"] = v;\n});\nvar __importStar = (this && this.__importStar) || function (mod) {\n if (mod && mod.__esModule) return mod;\n var result = {};\n if (mod != null) for (var k in mod) if (k !== \"default\" && Object.prototype.hasOwnProperty.call(mod, k)) __createBinding(result, mod, k);\n __setModuleDefault(result, mod);\n return result;\n};\nvar __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) {\n function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }\n return new (P || (P = Promise))(function (resolve, reject) {\n function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }\n function rejected(value) { try { step(generator[\"throw\"](value)); } catch (e) { reject(e); } }\n function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); }\n step((generator = generator.apply(thisArg, _arguments || [])).next());\n });\n};\nObject.defineProperty(exports, \"__esModule\", { value: true });\nexports.getApiBaseUrl = exports.getProxyFetch = exports.getProxyAgentDispatcher = exports.getProxyAgent = exports.getAuthString = void 0;\nconst httpClient = __importStar(require(\"@actions/http-client\"));\nconst undici_1 = require(\"undici\");\nfunction getAuthString(token, options) {\n if (!token && !options.auth) {\n throw new Error('Parameter token or opts.auth is required');\n }\n else if (token && options.auth) {\n throw new Error('Parameters token and opts.auth may not both be specified');\n }\n return typeof options.auth === 'string' ? options.auth : `token ${token}`;\n}\nexports.getAuthString = getAuthString;\nfunction getProxyAgent(destinationUrl) {\n const hc = new httpClient.HttpClient();\n return hc.getAgent(destinationUrl);\n}\nexports.getProxyAgent = getProxyAgent;\nfunction getProxyAgentDispatcher(destinationUrl) {\n const hc = new httpClient.HttpClient();\n return hc.getAgentDispatcher(destinationUrl);\n}\nexports.getProxyAgentDispatcher = getProxyAgentDispatcher;\nfunction getProxyFetch(destinationUrl) {\n const httpDispatcher = getProxyAgentDispatcher(destinationUrl);\n const proxyFetch = (url, opts) => __awaiter(this, void 0, void 0, function* () {\n return (0, undici_1.fetch)(url, Object.assign(Object.assign({}, opts), { dispatcher: httpDispatcher }));\n });\n return proxyFetch;\n}\nexports.getProxyFetch = getProxyFetch;\nfunction getApiBaseUrl() {\n return process.env['GITHUB_API_URL'] || 'https://api.github.com';\n}\nexports.getApiBaseUrl = getApiBaseUrl;\n//# sourceMappingURL=utils.js.map","\"use strict\";\nvar __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {\n if (k2 === undefined) k2 = k;\n var desc = Object.getOwnPropertyDescriptor(m, k);\n if (!desc || (\"get\" in desc ? !m.__esModule : desc.writable || desc.configurable)) {\n desc = { enumerable: true, get: function() { return m[k]; } };\n }\n Object.defineProperty(o, k2, desc);\n}) : (function(o, m, k, k2) {\n if (k2 === undefined) k2 = k;\n o[k2] = m[k];\n}));\nvar __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) {\n Object.defineProperty(o, \"default\", { enumerable: true, value: v });\n}) : function(o, v) {\n o[\"default\"] = v;\n});\nvar __importStar = (this && this.__importStar) || function (mod) {\n if (mod && mod.__esModule) return mod;\n var result = {};\n if (mod != null) for (var k in mod) if (k !== \"default\" && Object.prototype.hasOwnProperty.call(mod, k)) __createBinding(result, mod, k);\n __setModuleDefault(result, mod);\n return result;\n};\nObject.defineProperty(exports, \"__esModule\", { value: true });\nexports.getOctokitOptions = exports.GitHub = exports.defaults = exports.context = void 0;\nconst Context = __importStar(require(\"./context\"));\nconst Utils = __importStar(require(\"./internal/utils\"));\n// octokit + plugins\nconst core_1 = require(\"@octokit/core\");\nconst plugin_rest_endpoint_methods_1 = require(\"@octokit/plugin-rest-endpoint-methods\");\nconst plugin_paginate_rest_1 = require(\"@octokit/plugin-paginate-rest\");\nexports.context = new Context.Context();\nconst baseUrl = Utils.getApiBaseUrl();\nexports.defaults = {\n baseUrl,\n request: {\n agent: Utils.getProxyAgent(baseUrl),\n fetch: Utils.getProxyFetch(baseUrl)\n }\n};\nexports.GitHub = core_1.Octokit.plugin(plugin_rest_endpoint_methods_1.restEndpointMethods, plugin_paginate_rest_1.paginateRest).defaults(exports.defaults);\n/**\n * Convience function to correctly format Octokit Options to pass into the constructor.\n *\n * @param token the repo PAT or GITHUB_TOKEN\n * @param options other options to set\n */\nfunction getOctokitOptions(token, options) {\n const opts = Object.assign({}, options || {}); // Shallow clone - don't mutate the object provided by the caller\n // Auth\n const auth = Utils.getAuthString(token, opts);\n if (auth) {\n opts.auth = auth;\n }\n return opts;\n}\nexports.getOctokitOptions = getOctokitOptions;\n//# sourceMappingURL=utils.js.map","\"use strict\";\nvar __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) {\n function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }\n return new (P || (P = Promise))(function (resolve, reject) {\n function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }\n function rejected(value) { try { step(generator[\"throw\"](value)); } catch (e) { reject(e); } }\n function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); }\n step((generator = generator.apply(thisArg, _arguments || [])).next());\n });\n};\nObject.defineProperty(exports, \"__esModule\", { value: true });\nexports.PersonalAccessTokenCredentialHandler = exports.BearerCredentialHandler = exports.BasicCredentialHandler = void 0;\nclass BasicCredentialHandler {\n constructor(username, password) {\n this.username = username;\n this.password = password;\n }\n prepareRequest(options) {\n if (!options.headers) {\n throw Error('The request has no headers');\n }\n options.headers['Authorization'] = `Basic ${Buffer.from(`${this.username}:${this.password}`).toString('base64')}`;\n }\n // This handler cannot handle 401\n canHandleAuthentication() {\n return false;\n }\n handleAuthentication() {\n return __awaiter(this, void 0, void 0, function* () {\n throw new Error('not implemented');\n });\n }\n}\nexports.BasicCredentialHandler = BasicCredentialHandler;\nclass BearerCredentialHandler {\n constructor(token) {\n this.token = token;\n }\n // currently implements pre-authorization\n // TODO: support preAuth = false where it hooks on 401\n prepareRequest(options) {\n if (!options.headers) {\n throw Error('The request has no headers');\n }\n options.headers['Authorization'] = `Bearer ${this.token}`;\n }\n // This handler cannot handle 401\n canHandleAuthentication() {\n return false;\n }\n handleAuthentication() {\n return __awaiter(this, void 0, void 0, function* () {\n throw new Error('not implemented');\n });\n }\n}\nexports.BearerCredentialHandler = BearerCredentialHandler;\nclass PersonalAccessTokenCredentialHandler {\n constructor(token) {\n this.token = token;\n }\n // currently implements pre-authorization\n // TODO: support preAuth = false where it hooks on 401\n prepareRequest(options) {\n if (!options.headers) {\n throw Error('The request has no headers');\n }\n options.headers['Authorization'] = `Basic ${Buffer.from(`PAT:${this.token}`).toString('base64')}`;\n }\n // This handler cannot handle 401\n canHandleAuthentication() {\n return false;\n }\n handleAuthentication() {\n return __awaiter(this, void 0, void 0, function* () {\n throw new Error('not implemented');\n });\n }\n}\nexports.PersonalAccessTokenCredentialHandler = PersonalAccessTokenCredentialHandler;\n//# sourceMappingURL=auth.js.map","\"use strict\";\n/* eslint-disable @typescript-eslint/no-explicit-any */\nvar __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {\n if (k2 === undefined) k2 = k;\n var desc = Object.getOwnPropertyDescriptor(m, k);\n if (!desc || (\"get\" in desc ? !m.__esModule : desc.writable || desc.configurable)) {\n desc = { enumerable: true, get: function() { return m[k]; } };\n }\n Object.defineProperty(o, k2, desc);\n}) : (function(o, m, k, k2) {\n if (k2 === undefined) k2 = k;\n o[k2] = m[k];\n}));\nvar __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) {\n Object.defineProperty(o, \"default\", { enumerable: true, value: v });\n}) : function(o, v) {\n o[\"default\"] = v;\n});\nvar __importStar = (this && this.__importStar) || function (mod) {\n if (mod && mod.__esModule) return mod;\n var result = {};\n if (mod != null) for (var k in mod) if (k !== \"default\" && Object.prototype.hasOwnProperty.call(mod, k)) __createBinding(result, mod, k);\n __setModuleDefault(result, mod);\n return result;\n};\nvar __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) {\n function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }\n return new (P || (P = Promise))(function (resolve, reject) {\n function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }\n function rejected(value) { try { step(generator[\"throw\"](value)); } catch (e) { reject(e); } }\n function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); }\n step((generator = generator.apply(thisArg, _arguments || [])).next());\n });\n};\nObject.defineProperty(exports, \"__esModule\", { value: true });\nexports.HttpClient = exports.isHttps = exports.HttpClientResponse = exports.HttpClientError = exports.getProxyUrl = exports.MediaTypes = exports.Headers = exports.HttpCodes = void 0;\nconst http = __importStar(require(\"http\"));\nconst https = __importStar(require(\"https\"));\nconst pm = __importStar(require(\"./proxy\"));\nconst tunnel = __importStar(require(\"tunnel\"));\nconst undici_1 = require(\"undici\");\nvar HttpCodes;\n(function (HttpCodes) {\n HttpCodes[HttpCodes[\"OK\"] = 200] = \"OK\";\n HttpCodes[HttpCodes[\"MultipleChoices\"] = 300] = \"MultipleChoices\";\n HttpCodes[HttpCodes[\"MovedPermanently\"] = 301] = \"MovedPermanently\";\n HttpCodes[HttpCodes[\"ResourceMoved\"] = 302] = \"ResourceMoved\";\n HttpCodes[HttpCodes[\"SeeOther\"] = 303] = \"SeeOther\";\n HttpCodes[HttpCodes[\"NotModified\"] = 304] = \"NotModified\";\n HttpCodes[HttpCodes[\"UseProxy\"] = 305] = \"UseProxy\";\n HttpCodes[HttpCodes[\"SwitchProxy\"] = 306] = \"SwitchProxy\";\n HttpCodes[HttpCodes[\"TemporaryRedirect\"] = 307] = \"TemporaryRedirect\";\n HttpCodes[HttpCodes[\"PermanentRedirect\"] = 308] = \"PermanentRedirect\";\n HttpCodes[HttpCodes[\"BadRequest\"] = 400] = \"BadRequest\";\n HttpCodes[HttpCodes[\"Unauthorized\"] = 401] = \"Unauthorized\";\n HttpCodes[HttpCodes[\"PaymentRequired\"] = 402] = \"PaymentRequired\";\n HttpCodes[HttpCodes[\"Forbidden\"] = 403] = \"Forbidden\";\n HttpCodes[HttpCodes[\"NotFound\"] = 404] = \"NotFound\";\n HttpCodes[HttpCodes[\"MethodNotAllowed\"] = 405] = \"MethodNotAllowed\";\n HttpCodes[HttpCodes[\"NotAcceptable\"] = 406] = \"NotAcceptable\";\n HttpCodes[HttpCodes[\"ProxyAuthenticationRequired\"] = 407] = \"ProxyAuthenticationRequired\";\n HttpCodes[HttpCodes[\"RequestTimeout\"] = 408] = \"RequestTimeout\";\n HttpCodes[HttpCodes[\"Conflict\"] = 409] = \"Conflict\";\n HttpCodes[HttpCodes[\"Gone\"] = 410] = \"Gone\";\n HttpCodes[HttpCodes[\"TooManyRequests\"] = 429] = \"TooManyRequests\";\n HttpCodes[HttpCodes[\"InternalServerError\"] = 500] = \"InternalServerError\";\n HttpCodes[HttpCodes[\"NotImplemented\"] = 501] = \"NotImplemented\";\n HttpCodes[HttpCodes[\"BadGateway\"] = 502] = \"BadGateway\";\n HttpCodes[HttpCodes[\"ServiceUnavailable\"] = 503] = \"ServiceUnavailable\";\n HttpCodes[HttpCodes[\"GatewayTimeout\"] = 504] = \"GatewayTimeout\";\n})(HttpCodes || (exports.HttpCodes = HttpCodes = {}));\nvar Headers;\n(function (Headers) {\n Headers[\"Accept\"] = \"accept\";\n Headers[\"ContentType\"] = \"content-type\";\n})(Headers || (exports.Headers = Headers = {}));\nvar MediaTypes;\n(function (MediaTypes) {\n MediaTypes[\"ApplicationJson\"] = \"application/json\";\n})(MediaTypes || (exports.MediaTypes = MediaTypes = {}));\n/**\n * Returns the proxy URL, depending upon the supplied url and proxy environment variables.\n * @param serverUrl The server URL where the request will be sent. For example, https://api.github.com\n */\nfunction getProxyUrl(serverUrl) {\n const proxyUrl = pm.getProxyUrl(new URL(serverUrl));\n return proxyUrl ? proxyUrl.href : '';\n}\nexports.getProxyUrl = getProxyUrl;\nconst HttpRedirectCodes = [\n HttpCodes.MovedPermanently,\n HttpCodes.ResourceMoved,\n HttpCodes.SeeOther,\n HttpCodes.TemporaryRedirect,\n HttpCodes.PermanentRedirect\n];\nconst HttpResponseRetryCodes = [\n HttpCodes.BadGateway,\n HttpCodes.ServiceUnavailable,\n HttpCodes.GatewayTimeout\n];\nconst RetryableHttpVerbs = ['OPTIONS', 'GET', 'DELETE', 'HEAD'];\nconst ExponentialBackoffCeiling = 10;\nconst ExponentialBackoffTimeSlice = 5;\nclass HttpClientError extends Error {\n constructor(message, statusCode) {\n super(message);\n this.name = 'HttpClientError';\n this.statusCode = statusCode;\n Object.setPrototypeOf(this, HttpClientError.prototype);\n }\n}\nexports.HttpClientError = HttpClientError;\nclass HttpClientResponse {\n constructor(message) {\n this.message = message;\n }\n readBody() {\n return __awaiter(this, void 0, void 0, function* () {\n return new Promise((resolve) => __awaiter(this, void 0, void 0, function* () {\n let output = Buffer.alloc(0);\n this.message.on('data', (chunk) => {\n output = Buffer.concat([output, chunk]);\n });\n this.message.on('end', () => {\n resolve(output.toString());\n });\n }));\n });\n }\n readBodyBuffer() {\n return __awaiter(this, void 0, void 0, function* () {\n return new Promise((resolve) => __awaiter(this, void 0, void 0, function* () {\n const chunks = [];\n this.message.on('data', (chunk) => {\n chunks.push(chunk);\n });\n this.message.on('end', () => {\n resolve(Buffer.concat(chunks));\n });\n }));\n });\n }\n}\nexports.HttpClientResponse = HttpClientResponse;\nfunction isHttps(requestUrl) {\n const parsedUrl = new URL(requestUrl);\n return parsedUrl.protocol === 'https:';\n}\nexports.isHttps = isHttps;\nclass HttpClient {\n constructor(userAgent, handlers, requestOptions) {\n this._ignoreSslError = false;\n this._allowRedirects = true;\n this._allowRedirectDowngrade = false;\n this._maxRedirects = 50;\n this._allowRetries = false;\n this._maxRetries = 1;\n this._keepAlive = false;\n this._disposed = false;\n this.userAgent = userAgent;\n this.handlers = handlers || [];\n this.requestOptions = requestOptions;\n if (requestOptions) {\n if (requestOptions.ignoreSslError != null) {\n this._ignoreSslError = requestOptions.ignoreSslError;\n }\n this._socketTimeout = requestOptions.socketTimeout;\n if (requestOptions.allowRedirects != null) {\n this._allowRedirects = requestOptions.allowRedirects;\n }\n if (requestOptions.allowRedirectDowngrade != null) {\n this._allowRedirectDowngrade = requestOptions.allowRedirectDowngrade;\n }\n if (requestOptions.maxRedirects != null) {\n this._maxRedirects = Math.max(requestOptions.maxRedirects, 0);\n }\n if (requestOptions.keepAlive != null) {\n this._keepAlive = requestOptions.keepAlive;\n }\n if (requestOptions.allowRetries != null) {\n this._allowRetries = requestOptions.allowRetries;\n }\n if (requestOptions.maxRetries != null) {\n this._maxRetries = requestOptions.maxRetries;\n }\n }\n }\n options(requestUrl, additionalHeaders) {\n return __awaiter(this, void 0, void 0, function* () {\n return this.request('OPTIONS', requestUrl, null, additionalHeaders || {});\n });\n }\n get(requestUrl, additionalHeaders) {\n return __awaiter(this, void 0, void 0, function* () {\n return this.request('GET', requestUrl, null, additionalHeaders || {});\n });\n }\n del(requestUrl, additionalHeaders) {\n return __awaiter(this, void 0, void 0, function* () {\n return this.request('DELETE', requestUrl, null, additionalHeaders || {});\n });\n }\n post(requestUrl, data, additionalHeaders) {\n return __awaiter(this, void 0, void 0, function* () {\n return this.request('POST', requestUrl, data, additionalHeaders || {});\n });\n }\n patch(requestUrl, data, additionalHeaders) {\n return __awaiter(this, void 0, void 0, function* () {\n return this.request('PATCH', requestUrl, data, additionalHeaders || {});\n });\n }\n put(requestUrl, data, additionalHeaders) {\n return __awaiter(this, void 0, void 0, function* () {\n return this.request('PUT', requestUrl, data, additionalHeaders || {});\n });\n }\n head(requestUrl, additionalHeaders) {\n return __awaiter(this, void 0, void 0, function* () {\n return this.request('HEAD', requestUrl, null, additionalHeaders || {});\n });\n }\n sendStream(verb, requestUrl, stream, additionalHeaders) {\n return __awaiter(this, void 0, void 0, function* () {\n return this.request(verb, requestUrl, stream, additionalHeaders);\n });\n }\n /**\n * Gets a typed object from an endpoint\n * Be aware that not found returns a null. Other errors (4xx, 5xx) reject the promise\n */\n getJson(requestUrl, additionalHeaders = {}) {\n return __awaiter(this, void 0, void 0, function* () {\n additionalHeaders[Headers.Accept] = this._getExistingOrDefaultHeader(additionalHeaders, Headers.Accept, MediaTypes.ApplicationJson);\n const res = yield this.get(requestUrl, additionalHeaders);\n return this._processResponse(res, this.requestOptions);\n });\n }\n postJson(requestUrl, obj, additionalHeaders = {}) {\n return __awaiter(this, void 0, void 0, function* () {\n const data = JSON.stringify(obj, null, 2);\n additionalHeaders[Headers.Accept] = this._getExistingOrDefaultHeader(additionalHeaders, Headers.Accept, MediaTypes.ApplicationJson);\n additionalHeaders[Headers.ContentType] = this._getExistingOrDefaultHeader(additionalHeaders, Headers.ContentType, MediaTypes.ApplicationJson);\n const res = yield this.post(requestUrl, data, additionalHeaders);\n return this._processResponse(res, this.requestOptions);\n });\n }\n putJson(requestUrl, obj, additionalHeaders = {}) {\n return __awaiter(this, void 0, void 0, function* () {\n const data = JSON.stringify(obj, null, 2);\n additionalHeaders[Headers.Accept] = this._getExistingOrDefaultHeader(additionalHeaders, Headers.Accept, MediaTypes.ApplicationJson);\n additionalHeaders[Headers.ContentType] = this._getExistingOrDefaultHeader(additionalHeaders, Headers.ContentType, MediaTypes.ApplicationJson);\n const res = yield this.put(requestUrl, data, additionalHeaders);\n return this._processResponse(res, this.requestOptions);\n });\n }\n patchJson(requestUrl, obj, additionalHeaders = {}) {\n return __awaiter(this, void 0, void 0, function* () {\n const data = JSON.stringify(obj, null, 2);\n additionalHeaders[Headers.Accept] = this._getExistingOrDefaultHeader(additionalHeaders, Headers.Accept, MediaTypes.ApplicationJson);\n additionalHeaders[Headers.ContentType] = this._getExistingOrDefaultHeader(additionalHeaders, Headers.ContentType, MediaTypes.ApplicationJson);\n const res = yield this.patch(requestUrl, data, additionalHeaders);\n return this._processResponse(res, this.requestOptions);\n });\n }\n /**\n * Makes a raw http request.\n * All other methods such as get, post, patch, and request ultimately call this.\n * Prefer get, del, post and patch\n */\n request(verb, requestUrl, data, headers) {\n return __awaiter(this, void 0, void 0, function* () {\n if (this._disposed) {\n throw new Error('Client has already been disposed.');\n }\n const parsedUrl = new URL(requestUrl);\n let info = this._prepareRequest(verb, parsedUrl, headers);\n // Only perform retries on reads since writes may not be idempotent.\n const maxTries = this._allowRetries && RetryableHttpVerbs.includes(verb)\n ? this._maxRetries + 1\n : 1;\n let numTries = 0;\n let response;\n do {\n response = yield this.requestRaw(info, data);\n // Check if it's an authentication challenge\n if (response &&\n response.message &&\n response.message.statusCode === HttpCodes.Unauthorized) {\n let authenticationHandler;\n for (const handler of this.handlers) {\n if (handler.canHandleAuthentication(response)) {\n authenticationHandler = handler;\n break;\n }\n }\n if (authenticationHandler) {\n return authenticationHandler.handleAuthentication(this, info, data);\n }\n else {\n // We have received an unauthorized response but have no handlers to handle it.\n // Let the response return to the caller.\n return response;\n }\n }\n let redirectsRemaining = this._maxRedirects;\n while (response.message.statusCode &&\n HttpRedirectCodes.includes(response.message.statusCode) &&\n this._allowRedirects &&\n redirectsRemaining > 0) {\n const redirectUrl = response.message.headers['location'];\n if (!redirectUrl) {\n // if there's no location to redirect to, we won't\n break;\n }\n const parsedRedirectUrl = new URL(redirectUrl);\n if (parsedUrl.protocol === 'https:' &&\n parsedUrl.protocol !== parsedRedirectUrl.protocol &&\n !this._allowRedirectDowngrade) {\n throw new Error('Redirect from HTTPS to HTTP protocol. This downgrade is not allowed for security reasons. If you want to allow this behavior, set the allowRedirectDowngrade option to true.');\n }\n // we need to finish reading the response before reassigning response\n // which will leak the open socket.\n yield response.readBody();\n // strip authorization header if redirected to a different hostname\n if (parsedRedirectUrl.hostname !== parsedUrl.hostname) {\n for (const header in headers) {\n // header names are case insensitive\n if (header.toLowerCase() === 'authorization') {\n delete headers[header];\n }\n }\n }\n // let's make the request with the new redirectUrl\n info = this._prepareRequest(verb, parsedRedirectUrl, headers);\n response = yield this.requestRaw(info, data);\n redirectsRemaining--;\n }\n if (!response.message.statusCode ||\n !HttpResponseRetryCodes.includes(response.message.statusCode)) {\n // If not a retry code, return immediately instead of retrying\n return response;\n }\n numTries += 1;\n if (numTries < maxTries) {\n yield response.readBody();\n yield this._performExponentialBackoff(numTries);\n }\n } while (numTries < maxTries);\n return response;\n });\n }\n /**\n * Needs to be called if keepAlive is set to true in request options.\n */\n dispose() {\n if (this._agent) {\n this._agent.destroy();\n }\n this._disposed = true;\n }\n /**\n * Raw request.\n * @param info\n * @param data\n */\n requestRaw(info, data) {\n return __awaiter(this, void 0, void 0, function* () {\n return new Promise((resolve, reject) => {\n function callbackForResult(err, res) {\n if (err) {\n reject(err);\n }\n else if (!res) {\n // If `err` is not passed, then `res` must be passed.\n reject(new Error('Unknown error'));\n }\n else {\n resolve(res);\n }\n }\n this.requestRawWithCallback(info, data, callbackForResult);\n });\n });\n }\n /**\n * Raw request with callback.\n * @param info\n * @param data\n * @param onResult\n */\n requestRawWithCallback(info, data, onResult) {\n if (typeof data === 'string') {\n if (!info.options.headers) {\n info.options.headers = {};\n }\n info.options.headers['Content-Length'] = Buffer.byteLength(data, 'utf8');\n }\n let callbackCalled = false;\n function handleResult(err, res) {\n if (!callbackCalled) {\n callbackCalled = true;\n onResult(err, res);\n }\n }\n const req = info.httpModule.request(info.options, (msg) => {\n const res = new HttpClientResponse(msg);\n handleResult(undefined, res);\n });\n let socket;\n req.on('socket', sock => {\n socket = sock;\n });\n // If we ever get disconnected, we want the socket to timeout eventually\n req.setTimeout(this._socketTimeout || 3 * 60000, () => {\n if (socket) {\n socket.end();\n }\n handleResult(new Error(`Request timeout: ${info.options.path}`));\n });\n req.on('error', function (err) {\n // err has statusCode property\n // res should have headers\n handleResult(err);\n });\n if (data && typeof data === 'string') {\n req.write(data, 'utf8');\n }\n if (data && typeof data !== 'string') {\n data.on('close', function () {\n req.end();\n });\n data.pipe(req);\n }\n else {\n req.end();\n }\n }\n /**\n * Gets an http agent. This function is useful when you need an http agent that handles\n * routing through a proxy server - depending upon the url and proxy environment variables.\n * @param serverUrl The server URL where the request will be sent. For example, https://api.github.com\n */\n getAgent(serverUrl) {\n const parsedUrl = new URL(serverUrl);\n return this._getAgent(parsedUrl);\n }\n getAgentDispatcher(serverUrl) {\n const parsedUrl = new URL(serverUrl);\n const proxyUrl = pm.getProxyUrl(parsedUrl);\n const useProxy = proxyUrl && proxyUrl.hostname;\n if (!useProxy) {\n return;\n }\n return this._getProxyAgentDispatcher(parsedUrl, proxyUrl);\n }\n _prepareRequest(method, requestUrl, headers) {\n const info = {};\n info.parsedUrl = requestUrl;\n const usingSsl = info.parsedUrl.protocol === 'https:';\n info.httpModule = usingSsl ? https : http;\n const defaultPort = usingSsl ? 443 : 80;\n info.options = {};\n info.options.host = info.parsedUrl.hostname;\n info.options.port = info.parsedUrl.port\n ? parseInt(info.parsedUrl.port)\n : defaultPort;\n info.options.path =\n (info.parsedUrl.pathname || '') + (info.parsedUrl.search || '');\n info.options.method = method;\n info.options.headers = this._mergeHeaders(headers);\n if (this.userAgent != null) {\n info.options.headers['user-agent'] = this.userAgent;\n }\n info.options.agent = this._getAgent(info.parsedUrl);\n // gives handlers an opportunity to participate\n if (this.handlers) {\n for (const handler of this.handlers) {\n handler.prepareRequest(info.options);\n }\n }\n return info;\n }\n _mergeHeaders(headers) {\n if (this.requestOptions && this.requestOptions.headers) {\n return Object.assign({}, lowercaseKeys(this.requestOptions.headers), lowercaseKeys(headers || {}));\n }\n return lowercaseKeys(headers || {});\n }\n _getExistingOrDefaultHeader(additionalHeaders, header, _default) {\n let clientHeader;\n if (this.requestOptions && this.requestOptions.headers) {\n clientHeader = lowercaseKeys(this.requestOptions.headers)[header];\n }\n return additionalHeaders[header] || clientHeader || _default;\n }\n _getAgent(parsedUrl) {\n let agent;\n const proxyUrl = pm.getProxyUrl(parsedUrl);\n const useProxy = proxyUrl && proxyUrl.hostname;\n if (this._keepAlive && useProxy) {\n agent = this._proxyAgent;\n }\n if (!useProxy) {\n agent = this._agent;\n }\n // if agent is already assigned use that agent.\n if (agent) {\n return agent;\n }\n const usingSsl = parsedUrl.protocol === 'https:';\n let maxSockets = 100;\n if (this.requestOptions) {\n maxSockets = this.requestOptions.maxSockets || http.globalAgent.maxSockets;\n }\n // This is `useProxy` again, but we need to check `proxyURl` directly for TypeScripts's flow analysis.\n if (proxyUrl && proxyUrl.hostname) {\n const agentOptions = {\n maxSockets,\n keepAlive: this._keepAlive,\n proxy: Object.assign(Object.assign({}, ((proxyUrl.username || proxyUrl.password) && {\n proxyAuth: `${proxyUrl.username}:${proxyUrl.password}`\n })), { host: proxyUrl.hostname, port: proxyUrl.port })\n };\n let tunnelAgent;\n const overHttps = proxyUrl.protocol === 'https:';\n if (usingSsl) {\n tunnelAgent = overHttps ? tunnel.httpsOverHttps : tunnel.httpsOverHttp;\n }\n else {\n tunnelAgent = overHttps ? tunnel.httpOverHttps : tunnel.httpOverHttp;\n }\n agent = tunnelAgent(agentOptions);\n this._proxyAgent = agent;\n }\n // if tunneling agent isn't assigned create a new agent\n if (!agent) {\n const options = { keepAlive: this._keepAlive, maxSockets };\n agent = usingSsl ? new https.Agent(options) : new http.Agent(options);\n this._agent = agent;\n }\n if (usingSsl && this._ignoreSslError) {\n // we don't want to set NODE_TLS_REJECT_UNAUTHORIZED=0 since that will affect request for entire process\n // http.RequestOptions doesn't expose a way to modify RequestOptions.agent.options\n // we have to cast it to any and change it directly\n agent.options = Object.assign(agent.options || {}, {\n rejectUnauthorized: false\n });\n }\n return agent;\n }\n _getProxyAgentDispatcher(parsedUrl, proxyUrl) {\n let proxyAgent;\n if (this._keepAlive) {\n proxyAgent = this._proxyAgentDispatcher;\n }\n // if agent is already assigned use that agent.\n if (proxyAgent) {\n return proxyAgent;\n }\n const usingSsl = parsedUrl.protocol === 'https:';\n proxyAgent = new undici_1.ProxyAgent(Object.assign({ uri: proxyUrl.href, pipelining: !this._keepAlive ? 0 : 1 }, ((proxyUrl.username || proxyUrl.password) && {\n token: `${proxyUrl.username}:${proxyUrl.password}`\n })));\n this._proxyAgentDispatcher = proxyAgent;\n if (usingSsl && this._ignoreSslError) {\n // we don't want to set NODE_TLS_REJECT_UNAUTHORIZED=0 since that will affect request for entire process\n // http.RequestOptions doesn't expose a way to modify RequestOptions.agent.options\n // we have to cast it to any and change it directly\n proxyAgent.options = Object.assign(proxyAgent.options.requestTls || {}, {\n rejectUnauthorized: false\n });\n }\n return proxyAgent;\n }\n _performExponentialBackoff(retryNumber) {\n return __awaiter(this, void 0, void 0, function* () {\n retryNumber = Math.min(ExponentialBackoffCeiling, retryNumber);\n const ms = ExponentialBackoffTimeSlice * Math.pow(2, retryNumber);\n return new Promise(resolve => setTimeout(() => resolve(), ms));\n });\n }\n _processResponse(res, options) {\n return __awaiter(this, void 0, void 0, function* () {\n return new Promise((resolve, reject) => __awaiter(this, void 0, void 0, function* () {\n const statusCode = res.message.statusCode || 0;\n const response = {\n statusCode,\n result: null,\n headers: {}\n };\n // not found leads to null obj returned\n if (statusCode === HttpCodes.NotFound) {\n resolve(response);\n }\n // get the result from the body\n function dateTimeDeserializer(key, value) {\n if (typeof value === 'string') {\n const a = new Date(value);\n if (!isNaN(a.valueOf())) {\n return a;\n }\n }\n return value;\n }\n let obj;\n let contents;\n try {\n contents = yield res.readBody();\n if (contents && contents.length > 0) {\n if (options && options.deserializeDates) {\n obj = JSON.parse(contents, dateTimeDeserializer);\n }\n else {\n obj = JSON.parse(contents);\n }\n response.result = obj;\n }\n response.headers = res.message.headers;\n }\n catch (err) {\n // Invalid resource (contents not json); leaving result obj null\n }\n // note that 3xx redirects are handled by the http layer.\n if (statusCode > 299) {\n let msg;\n // if exception/error in body, attempt to get better error\n if (obj && obj.message) {\n msg = obj.message;\n }\n else if (contents && contents.length > 0) {\n // it may be the case that the exception is in the body message as string\n msg = contents;\n }\n else {\n msg = `Failed request: (${statusCode})`;\n }\n const err = new HttpClientError(msg, statusCode);\n err.result = response.result;\n reject(err);\n }\n else {\n resolve(response);\n }\n }));\n });\n }\n}\nexports.HttpClient = HttpClient;\nconst lowercaseKeys = (obj) => Object.keys(obj).reduce((c, k) => ((c[k.toLowerCase()] = obj[k]), c), {});\n//# sourceMappingURL=index.js.map","\"use strict\";\nObject.defineProperty(exports, \"__esModule\", { value: true });\nexports.checkBypass = exports.getProxyUrl = void 0;\nfunction getProxyUrl(reqUrl) {\n const usingSsl = reqUrl.protocol === 'https:';\n if (checkBypass(reqUrl)) {\n return undefined;\n }\n const proxyVar = (() => {\n if (usingSsl) {\n return process.env['https_proxy'] || process.env['HTTPS_PROXY'];\n }\n else {\n return process.env['http_proxy'] || process.env['HTTP_PROXY'];\n }\n })();\n if (proxyVar) {\n try {\n return new URL(proxyVar);\n }\n catch (_a) {\n if (!proxyVar.startsWith('http://') && !proxyVar.startsWith('https://'))\n return new URL(`http://${proxyVar}`);\n }\n }\n else {\n return undefined;\n }\n}\nexports.getProxyUrl = getProxyUrl;\nfunction checkBypass(reqUrl) {\n if (!reqUrl.hostname) {\n return false;\n }\n const reqHost = reqUrl.hostname;\n if (isLoopbackAddress(reqHost)) {\n return true;\n }\n const noProxy = process.env['no_proxy'] || process.env['NO_PROXY'] || '';\n if (!noProxy) {\n return false;\n }\n // Determine the request port\n let reqPort;\n if (reqUrl.port) {\n reqPort = Number(reqUrl.port);\n }\n else if (reqUrl.protocol === 'http:') {\n reqPort = 80;\n }\n else if (reqUrl.protocol === 'https:') {\n reqPort = 443;\n }\n // Format the request hostname and hostname with port\n const upperReqHosts = [reqUrl.hostname.toUpperCase()];\n if (typeof reqPort === 'number') {\n upperReqHosts.push(`${upperReqHosts[0]}:${reqPort}`);\n }\n // Compare request host against noproxy\n for (const upperNoProxyItem of noProxy\n .split(',')\n .map(x => x.trim().toUpperCase())\n .filter(x => x)) {\n if (upperNoProxyItem === '*' ||\n upperReqHosts.some(x => x === upperNoProxyItem ||\n x.endsWith(`.${upperNoProxyItem}`) ||\n (upperNoProxyItem.startsWith('.') &&\n x.endsWith(`${upperNoProxyItem}`)))) {\n return true;\n }\n }\n return false;\n}\nexports.checkBypass = checkBypass;\nfunction isLoopbackAddress(host) {\n const hostLower = host.toLowerCase();\n return (hostLower === 'localhost' ||\n hostLower.startsWith('127.') ||\n hostLower.startsWith('[::1]') ||\n hostLower.startsWith('[0:0:0:0:0:0:0:1]'));\n}\n//# sourceMappingURL=proxy.js.map","\"use strict\";\nvar __defProp = Object.defineProperty;\nvar __getOwnPropDesc = Object.getOwnPropertyDescriptor;\nvar __getOwnPropNames = Object.getOwnPropertyNames;\nvar __hasOwnProp = Object.prototype.hasOwnProperty;\nvar __export = (target, all) => {\n for (var name in all)\n __defProp(target, name, { get: all[name], enumerable: true });\n};\nvar __copyProps = (to, from, except, desc) => {\n if (from && typeof from === \"object\" || typeof from === \"function\") {\n for (let key of __getOwnPropNames(from))\n if (!__hasOwnProp.call(to, key) && key !== except)\n __defProp(to, key, { get: () => from[key], enumerable: !(desc = __getOwnPropDesc(from, key)) || desc.enumerable });\n }\n return to;\n};\nvar __toCommonJS = (mod) => __copyProps(__defProp({}, \"__esModule\", { value: true }), mod);\n\n// pkg/dist-src/index.js\nvar dist_src_exports = {};\n__export(dist_src_exports, {\n createTokenAuth: () => createTokenAuth\n});\nmodule.exports = __toCommonJS(dist_src_exports);\n\n// pkg/dist-src/auth.js\nvar REGEX_IS_INSTALLATION_LEGACY = /^v1\\./;\nvar REGEX_IS_INSTALLATION = /^ghs_/;\nvar REGEX_IS_USER_TO_SERVER = /^ghu_/;\nasync function auth(token) {\n const isApp = token.split(/\\./).length === 3;\n const isInstallation = REGEX_IS_INSTALLATION_LEGACY.test(token) || REGEX_IS_INSTALLATION.test(token);\n const isUserToServer = REGEX_IS_USER_TO_SERVER.test(token);\n const tokenType = isApp ? \"app\" : isInstallation ? \"installation\" : isUserToServer ? \"user-to-server\" : \"oauth\";\n return {\n type: \"token\",\n token,\n tokenType\n };\n}\n\n// pkg/dist-src/with-authorization-prefix.js\nfunction withAuthorizationPrefix(token) {\n if (token.split(/\\./).length === 3) {\n return `bearer ${token}`;\n }\n return `token ${token}`;\n}\n\n// pkg/dist-src/hook.js\nasync function hook(token, request, route, parameters) {\n const endpoint = request.endpoint.merge(\n route,\n parameters\n );\n endpoint.headers.authorization = withAuthorizationPrefix(token);\n return request(endpoint);\n}\n\n// pkg/dist-src/index.js\nvar createTokenAuth = function createTokenAuth2(token) {\n if (!token) {\n throw new Error(\"[@octokit/auth-token] No token passed to createTokenAuth\");\n }\n if (typeof token !== \"string\") {\n throw new Error(\n \"[@octokit/auth-token] Token passed to createTokenAuth is not a string\"\n );\n }\n token = token.replace(/^(token|bearer) +/i, \"\");\n return Object.assign(auth.bind(null, token), {\n hook: hook.bind(null, token)\n });\n};\n// Annotate the CommonJS export names for ESM import in node:\n0 && (module.exports = {\n createTokenAuth\n});\n","\"use strict\";\nvar __defProp = Object.defineProperty;\nvar __getOwnPropDesc = Object.getOwnPropertyDescriptor;\nvar __getOwnPropNames = Object.getOwnPropertyNames;\nvar __hasOwnProp = Object.prototype.hasOwnProperty;\nvar __export = (target, all) => {\n for (var name in all)\n __defProp(target, name, { get: all[name], enumerable: true });\n};\nvar __copyProps = (to, from, except, desc) => {\n if (from && typeof from === \"object\" || typeof from === \"function\") {\n for (let key of __getOwnPropNames(from))\n if (!__hasOwnProp.call(to, key) && key !== except)\n __defProp(to, key, { get: () => from[key], enumerable: !(desc = __getOwnPropDesc(from, key)) || desc.enumerable });\n }\n return to;\n};\nvar __toCommonJS = (mod) => __copyProps(__defProp({}, \"__esModule\", { value: true }), mod);\n\n// pkg/dist-src/index.js\nvar dist_src_exports = {};\n__export(dist_src_exports, {\n Octokit: () => Octokit\n});\nmodule.exports = __toCommonJS(dist_src_exports);\nvar import_universal_user_agent = require(\"universal-user-agent\");\nvar import_before_after_hook = require(\"before-after-hook\");\nvar import_request = require(\"@octokit/request\");\nvar import_graphql = require(\"@octokit/graphql\");\nvar import_auth_token = require(\"@octokit/auth-token\");\n\n// pkg/dist-src/version.js\nvar VERSION = \"5.1.0\";\n\n// pkg/dist-src/index.js\nvar noop = () => {\n};\nvar consoleWarn = console.warn.bind(console);\nvar consoleError = console.error.bind(console);\nvar userAgentTrail = `octokit-core.js/${VERSION} ${(0, import_universal_user_agent.getUserAgent)()}`;\nvar Octokit = class {\n static {\n this.VERSION = VERSION;\n }\n static defaults(defaults) {\n const OctokitWithDefaults = class extends this {\n constructor(...args) {\n const options = args[0] || {};\n if (typeof defaults === \"function\") {\n super(defaults(options));\n return;\n }\n super(\n Object.assign(\n {},\n defaults,\n options,\n options.userAgent && defaults.userAgent ? {\n userAgent: `${options.userAgent} ${defaults.userAgent}`\n } : null\n )\n );\n }\n };\n return OctokitWithDefaults;\n }\n static {\n this.plugins = [];\n }\n /**\n * Attach a plugin (or many) to your Octokit instance.\n *\n * @example\n * const API = Octokit.plugin(plugin1, plugin2, plugin3, ...)\n */\n static plugin(...newPlugins) {\n const currentPlugins = this.plugins;\n const NewOctokit = class extends this {\n static {\n this.plugins = currentPlugins.concat(\n newPlugins.filter((plugin) => !currentPlugins.includes(plugin))\n );\n }\n };\n return NewOctokit;\n }\n constructor(options = {}) {\n const hook = new import_before_after_hook.Collection();\n const requestDefaults = {\n baseUrl: import_request.request.endpoint.DEFAULTS.baseUrl,\n headers: {},\n request: Object.assign({}, options.request, {\n // @ts-ignore internal usage only, no need to type\n hook: hook.bind(null, \"request\")\n }),\n mediaType: {\n previews: [],\n format: \"\"\n }\n };\n requestDefaults.headers[\"user-agent\"] = options.userAgent ? `${options.userAgent} ${userAgentTrail}` : userAgentTrail;\n if (options.baseUrl) {\n requestDefaults.baseUrl = options.baseUrl;\n }\n if (options.previews) {\n requestDefaults.mediaType.previews = options.previews;\n }\n if (options.timeZone) {\n requestDefaults.headers[\"time-zone\"] = options.timeZone;\n }\n this.request = import_request.request.defaults(requestDefaults);\n this.graphql = (0, import_graphql.withCustomRequest)(this.request).defaults(requestDefaults);\n this.log = Object.assign(\n {\n debug: noop,\n info: noop,\n warn: consoleWarn,\n error: consoleError\n },\n options.log\n );\n this.hook = hook;\n if (!options.authStrategy) {\n if (!options.auth) {\n this.auth = async () => ({\n type: \"unauthenticated\"\n });\n } else {\n const auth = (0, import_auth_token.createTokenAuth)(options.auth);\n hook.wrap(\"request\", auth.hook);\n this.auth = auth;\n }\n } else {\n const { authStrategy, ...otherOptions } = options;\n const auth = authStrategy(\n Object.assign(\n {\n request: this.request,\n log: this.log,\n // we pass the current octokit instance as well as its constructor options\n // to allow for authentication strategies that return a new octokit instance\n // that shares the same internal state as the current one. The original\n // requirement for this was the \"event-octokit\" authentication strategy\n // of https://github.com/probot/octokit-auth-probot.\n octokit: this,\n octokitOptions: otherOptions\n },\n options.auth\n )\n );\n hook.wrap(\"request\", auth.hook);\n this.auth = auth;\n }\n const classConstructor = this.constructor;\n for (let i = 0; i < classConstructor.plugins.length; ++i) {\n Object.assign(this, classConstructor.plugins[i](this, options));\n }\n }\n};\n// Annotate the CommonJS export names for ESM import in node:\n0 && (module.exports = {\n Octokit\n});\n","\"use strict\";\nvar __defProp = Object.defineProperty;\nvar __getOwnPropDesc = Object.getOwnPropertyDescriptor;\nvar __getOwnPropNames = Object.getOwnPropertyNames;\nvar __hasOwnProp = Object.prototype.hasOwnProperty;\nvar __export = (target, all) => {\n for (var name in all)\n __defProp(target, name, { get: all[name], enumerable: true });\n};\nvar __copyProps = (to, from, except, desc) => {\n if (from && typeof from === \"object\" || typeof from === \"function\") {\n for (let key of __getOwnPropNames(from))\n if (!__hasOwnProp.call(to, key) && key !== except)\n __defProp(to, key, { get: () => from[key], enumerable: !(desc = __getOwnPropDesc(from, key)) || desc.enumerable });\n }\n return to;\n};\nvar __toCommonJS = (mod) => __copyProps(__defProp({}, \"__esModule\", { value: true }), mod);\n\n// pkg/dist-src/index.js\nvar dist_src_exports = {};\n__export(dist_src_exports, {\n endpoint: () => endpoint\n});\nmodule.exports = __toCommonJS(dist_src_exports);\n\n// pkg/dist-src/defaults.js\nvar import_universal_user_agent = require(\"universal-user-agent\");\n\n// pkg/dist-src/version.js\nvar VERSION = \"9.0.4\";\n\n// pkg/dist-src/defaults.js\nvar userAgent = `octokit-endpoint.js/${VERSION} ${(0, import_universal_user_agent.getUserAgent)()}`;\nvar DEFAULTS = {\n method: \"GET\",\n baseUrl: \"https://api.github.com\",\n headers: {\n accept: \"application/vnd.github.v3+json\",\n \"user-agent\": userAgent\n },\n mediaType: {\n format: \"\"\n }\n};\n\n// pkg/dist-src/util/lowercase-keys.js\nfunction lowercaseKeys(object) {\n if (!object) {\n return {};\n }\n return Object.keys(object).reduce((newObj, key) => {\n newObj[key.toLowerCase()] = object[key];\n return newObj;\n }, {});\n}\n\n// pkg/dist-src/util/is-plain-object.js\nfunction isPlainObject(value) {\n if (typeof value !== \"object\" || value === null)\n return false;\n if (Object.prototype.toString.call(value) !== \"[object Object]\")\n return false;\n const proto = Object.getPrototypeOf(value);\n if (proto === null)\n return true;\n const Ctor = Object.prototype.hasOwnProperty.call(proto, \"constructor\") && proto.constructor;\n return typeof Ctor === \"function\" && Ctor instanceof Ctor && Function.prototype.call(Ctor) === Function.prototype.call(value);\n}\n\n// pkg/dist-src/util/merge-deep.js\nfunction mergeDeep(defaults, options) {\n const result = Object.assign({}, defaults);\n Object.keys(options).forEach((key) => {\n if (isPlainObject(options[key])) {\n if (!(key in defaults))\n Object.assign(result, { [key]: options[key] });\n else\n result[key] = mergeDeep(defaults[key], options[key]);\n } else {\n Object.assign(result, { [key]: options[key] });\n }\n });\n return result;\n}\n\n// pkg/dist-src/util/remove-undefined-properties.js\nfunction removeUndefinedProperties(obj) {\n for (const key in obj) {\n if (obj[key] === void 0) {\n delete obj[key];\n }\n }\n return obj;\n}\n\n// pkg/dist-src/merge.js\nfunction merge(defaults, route, options) {\n if (typeof route === \"string\") {\n let [method, url] = route.split(\" \");\n options = Object.assign(url ? { method, url } : { url: method }, options);\n } else {\n options = Object.assign({}, route);\n }\n options.headers = lowercaseKeys(options.headers);\n removeUndefinedProperties(options);\n removeUndefinedProperties(options.headers);\n const mergedOptions = mergeDeep(defaults || {}, options);\n if (options.url === \"/graphql\") {\n if (defaults && defaults.mediaType.previews?.length) {\n mergedOptions.mediaType.previews = defaults.mediaType.previews.filter(\n (preview) => !mergedOptions.mediaType.previews.includes(preview)\n ).concat(mergedOptions.mediaType.previews);\n }\n mergedOptions.mediaType.previews = (mergedOptions.mediaType.previews || []).map((preview) => preview.replace(/-preview/, \"\"));\n }\n return mergedOptions;\n}\n\n// pkg/dist-src/util/add-query-parameters.js\nfunction addQueryParameters(url, parameters) {\n const separator = /\\?/.test(url) ? \"&\" : \"?\";\n const names = Object.keys(parameters);\n if (names.length === 0) {\n return url;\n }\n return url + separator + names.map((name) => {\n if (name === \"q\") {\n return \"q=\" + parameters.q.split(\"+\").map(encodeURIComponent).join(\"+\");\n }\n return `${name}=${encodeURIComponent(parameters[name])}`;\n }).join(\"&\");\n}\n\n// pkg/dist-src/util/extract-url-variable-names.js\nvar urlVariableRegex = /\\{[^}]+\\}/g;\nfunction removeNonChars(variableName) {\n return variableName.replace(/^\\W+|\\W+$/g, \"\").split(/,/);\n}\nfunction extractUrlVariableNames(url) {\n const matches = url.match(urlVariableRegex);\n if (!matches) {\n return [];\n }\n return matches.map(removeNonChars).reduce((a, b) => a.concat(b), []);\n}\n\n// pkg/dist-src/util/omit.js\nfunction omit(object, keysToOmit) {\n const result = { __proto__: null };\n for (const key of Object.keys(object)) {\n if (keysToOmit.indexOf(key) === -1) {\n result[key] = object[key];\n }\n }\n return result;\n}\n\n// pkg/dist-src/util/url-template.js\nfunction encodeReserved(str) {\n return str.split(/(%[0-9A-Fa-f]{2})/g).map(function(part) {\n if (!/%[0-9A-Fa-f]/.test(part)) {\n part = encodeURI(part).replace(/%5B/g, \"[\").replace(/%5D/g, \"]\");\n }\n return part;\n }).join(\"\");\n}\nfunction encodeUnreserved(str) {\n return encodeURIComponent(str).replace(/[!'()*]/g, function(c) {\n return \"%\" + c.charCodeAt(0).toString(16).toUpperCase();\n });\n}\nfunction encodeValue(operator, value, key) {\n value = operator === \"+\" || operator === \"#\" ? encodeReserved(value) : encodeUnreserved(value);\n if (key) {\n return encodeUnreserved(key) + \"=\" + value;\n } else {\n return value;\n }\n}\nfunction isDefined(value) {\n return value !== void 0 && value !== null;\n}\nfunction isKeyOperator(operator) {\n return operator === \";\" || operator === \"&\" || operator === \"?\";\n}\nfunction getValues(context, operator, key, modifier) {\n var value = context[key], result = [];\n if (isDefined(value) && value !== \"\") {\n if (typeof value === \"string\" || typeof value === \"number\" || typeof value === \"boolean\") {\n value = value.toString();\n if (modifier && modifier !== \"*\") {\n value = value.substring(0, parseInt(modifier, 10));\n }\n result.push(\n encodeValue(operator, value, isKeyOperator(operator) ? key : \"\")\n );\n } else {\n if (modifier === \"*\") {\n if (Array.isArray(value)) {\n value.filter(isDefined).forEach(function(value2) {\n result.push(\n encodeValue(operator, value2, isKeyOperator(operator) ? key : \"\")\n );\n });\n } else {\n Object.keys(value).forEach(function(k) {\n if (isDefined(value[k])) {\n result.push(encodeValue(operator, value[k], k));\n }\n });\n }\n } else {\n const tmp = [];\n if (Array.isArray(value)) {\n value.filter(isDefined).forEach(function(value2) {\n tmp.push(encodeValue(operator, value2));\n });\n } else {\n Object.keys(value).forEach(function(k) {\n if (isDefined(value[k])) {\n tmp.push(encodeUnreserved(k));\n tmp.push(encodeValue(operator, value[k].toString()));\n }\n });\n }\n if (isKeyOperator(operator)) {\n result.push(encodeUnreserved(key) + \"=\" + tmp.join(\",\"));\n } else if (tmp.length !== 0) {\n result.push(tmp.join(\",\"));\n }\n }\n }\n } else {\n if (operator === \";\") {\n if (isDefined(value)) {\n result.push(encodeUnreserved(key));\n }\n } else if (value === \"\" && (operator === \"&\" || operator === \"?\")) {\n result.push(encodeUnreserved(key) + \"=\");\n } else if (value === \"\") {\n result.push(\"\");\n }\n }\n return result;\n}\nfunction parseUrl(template) {\n return {\n expand: expand.bind(null, template)\n };\n}\nfunction expand(template, context) {\n var operators = [\"+\", \"#\", \".\", \"/\", \";\", \"?\", \"&\"];\n template = template.replace(\n /\\{([^\\{\\}]+)\\}|([^\\{\\}]+)/g,\n function(_, expression, literal) {\n if (expression) {\n let operator = \"\";\n const values = [];\n if (operators.indexOf(expression.charAt(0)) !== -1) {\n operator = expression.charAt(0);\n expression = expression.substr(1);\n }\n expression.split(/,/g).forEach(function(variable) {\n var tmp = /([^:\\*]*)(?::(\\d+)|(\\*))?/.exec(variable);\n values.push(getValues(context, operator, tmp[1], tmp[2] || tmp[3]));\n });\n if (operator && operator !== \"+\") {\n var separator = \",\";\n if (operator === \"?\") {\n separator = \"&\";\n } else if (operator !== \"#\") {\n separator = operator;\n }\n return (values.length !== 0 ? operator : \"\") + values.join(separator);\n } else {\n return values.join(\",\");\n }\n } else {\n return encodeReserved(literal);\n }\n }\n );\n if (template === \"/\") {\n return template;\n } else {\n return template.replace(/\\/$/, \"\");\n }\n}\n\n// pkg/dist-src/parse.js\nfunction parse(options) {\n let method = options.method.toUpperCase();\n let url = (options.url || \"/\").replace(/:([a-z]\\w+)/g, \"{$1}\");\n let headers = Object.assign({}, options.headers);\n let body;\n let parameters = omit(options, [\n \"method\",\n \"baseUrl\",\n \"url\",\n \"headers\",\n \"request\",\n \"mediaType\"\n ]);\n const urlVariableNames = extractUrlVariableNames(url);\n url = parseUrl(url).expand(parameters);\n if (!/^http/.test(url)) {\n url = options.baseUrl + url;\n }\n const omittedParameters = Object.keys(options).filter((option) => urlVariableNames.includes(option)).concat(\"baseUrl\");\n const remainingParameters = omit(parameters, omittedParameters);\n const isBinaryRequest = /application\\/octet-stream/i.test(headers.accept);\n if (!isBinaryRequest) {\n if (options.mediaType.format) {\n headers.accept = headers.accept.split(/,/).map(\n (format) => format.replace(\n /application\\/vnd(\\.\\w+)(\\.v3)?(\\.\\w+)?(\\+json)?$/,\n `application/vnd$1$2.${options.mediaType.format}`\n )\n ).join(\",\");\n }\n if (url.endsWith(\"/graphql\")) {\n if (options.mediaType.previews?.length) {\n const previewsFromAcceptHeader = headers.accept.match(/[\\w-]+(?=-preview)/g) || [];\n headers.accept = previewsFromAcceptHeader.concat(options.mediaType.previews).map((preview) => {\n const format = options.mediaType.format ? `.${options.mediaType.format}` : \"+json\";\n return `application/vnd.github.${preview}-preview${format}`;\n }).join(\",\");\n }\n }\n }\n if ([\"GET\", \"HEAD\"].includes(method)) {\n url = addQueryParameters(url, remainingParameters);\n } else {\n if (\"data\" in remainingParameters) {\n body = remainingParameters.data;\n } else {\n if (Object.keys(remainingParameters).length) {\n body = remainingParameters;\n }\n }\n }\n if (!headers[\"content-type\"] && typeof body !== \"undefined\") {\n headers[\"content-type\"] = \"application/json; charset=utf-8\";\n }\n if ([\"PATCH\", \"PUT\"].includes(method) && typeof body === \"undefined\") {\n body = \"\";\n }\n return Object.assign(\n { method, url, headers },\n typeof body !== \"undefined\" ? { body } : null,\n options.request ? { request: options.request } : null\n );\n}\n\n// pkg/dist-src/endpoint-with-defaults.js\nfunction endpointWithDefaults(defaults, route, options) {\n return parse(merge(defaults, route, options));\n}\n\n// pkg/dist-src/with-defaults.js\nfunction withDefaults(oldDefaults, newDefaults) {\n const DEFAULTS2 = merge(oldDefaults, newDefaults);\n const endpoint2 = endpointWithDefaults.bind(null, DEFAULTS2);\n return Object.assign(endpoint2, {\n DEFAULTS: DEFAULTS2,\n defaults: withDefaults.bind(null, DEFAULTS2),\n merge: merge.bind(null, DEFAULTS2),\n parse\n });\n}\n\n// pkg/dist-src/index.js\nvar endpoint = withDefaults(null, DEFAULTS);\n// Annotate the CommonJS export names for ESM import in node:\n0 && (module.exports = {\n endpoint\n});\n","\"use strict\";\nvar __defProp = Object.defineProperty;\nvar __getOwnPropDesc = Object.getOwnPropertyDescriptor;\nvar __getOwnPropNames = Object.getOwnPropertyNames;\nvar __hasOwnProp = Object.prototype.hasOwnProperty;\nvar __export = (target, all) => {\n for (var name in all)\n __defProp(target, name, { get: all[name], enumerable: true });\n};\nvar __copyProps = (to, from, except, desc) => {\n if (from && typeof from === \"object\" || typeof from === \"function\") {\n for (let key of __getOwnPropNames(from))\n if (!__hasOwnProp.call(to, key) && key !== except)\n __defProp(to, key, { get: () => from[key], enumerable: !(desc = __getOwnPropDesc(from, key)) || desc.enumerable });\n }\n return to;\n};\nvar __toCommonJS = (mod) => __copyProps(__defProp({}, \"__esModule\", { value: true }), mod);\n\n// pkg/dist-src/index.js\nvar dist_src_exports = {};\n__export(dist_src_exports, {\n GraphqlResponseError: () => GraphqlResponseError,\n graphql: () => graphql2,\n withCustomRequest: () => withCustomRequest\n});\nmodule.exports = __toCommonJS(dist_src_exports);\nvar import_request3 = require(\"@octokit/request\");\nvar import_universal_user_agent = require(\"universal-user-agent\");\n\n// pkg/dist-src/version.js\nvar VERSION = \"7.0.2\";\n\n// pkg/dist-src/with-defaults.js\nvar import_request2 = require(\"@octokit/request\");\n\n// pkg/dist-src/graphql.js\nvar import_request = require(\"@octokit/request\");\n\n// pkg/dist-src/error.js\nfunction _buildMessageForResponseErrors(data) {\n return `Request failed due to following response errors:\n` + data.errors.map((e) => ` - ${e.message}`).join(\"\\n\");\n}\nvar GraphqlResponseError = class extends Error {\n constructor(request2, headers, response) {\n super(_buildMessageForResponseErrors(response));\n this.request = request2;\n this.headers = headers;\n this.response = response;\n this.name = \"GraphqlResponseError\";\n this.errors = response.errors;\n this.data = response.data;\n if (Error.captureStackTrace) {\n Error.captureStackTrace(this, this.constructor);\n }\n }\n};\n\n// pkg/dist-src/graphql.js\nvar NON_VARIABLE_OPTIONS = [\n \"method\",\n \"baseUrl\",\n \"url\",\n \"headers\",\n \"request\",\n \"query\",\n \"mediaType\"\n];\nvar FORBIDDEN_VARIABLE_OPTIONS = [\"query\", \"method\", \"url\"];\nvar GHES_V3_SUFFIX_REGEX = /\\/api\\/v3\\/?$/;\nfunction graphql(request2, query, options) {\n if (options) {\n if (typeof query === \"string\" && \"query\" in options) {\n return Promise.reject(\n new Error(`[@octokit/graphql] \"query\" cannot be used as variable name`)\n );\n }\n for (const key in options) {\n if (!FORBIDDEN_VARIABLE_OPTIONS.includes(key))\n continue;\n return Promise.reject(\n new Error(\n `[@octokit/graphql] \"${key}\" cannot be used as variable name`\n )\n );\n }\n }\n const parsedOptions = typeof query === \"string\" ? Object.assign({ query }, options) : query;\n const requestOptions = Object.keys(\n parsedOptions\n ).reduce((result, key) => {\n if (NON_VARIABLE_OPTIONS.includes(key)) {\n result[key] = parsedOptions[key];\n return result;\n }\n if (!result.variables) {\n result.variables = {};\n }\n result.variables[key] = parsedOptions[key];\n return result;\n }, {});\n const baseUrl = parsedOptions.baseUrl || request2.endpoint.DEFAULTS.baseUrl;\n if (GHES_V3_SUFFIX_REGEX.test(baseUrl)) {\n requestOptions.url = baseUrl.replace(GHES_V3_SUFFIX_REGEX, \"/api/graphql\");\n }\n return request2(requestOptions).then((response) => {\n if (response.data.errors) {\n const headers = {};\n for (const key of Object.keys(response.headers)) {\n headers[key] = response.headers[key];\n }\n throw new GraphqlResponseError(\n requestOptions,\n headers,\n response.data\n );\n }\n return response.data.data;\n });\n}\n\n// pkg/dist-src/with-defaults.js\nfunction withDefaults(request2, newDefaults) {\n const newRequest = request2.defaults(newDefaults);\n const newApi = (query, options) => {\n return graphql(newRequest, query, options);\n };\n return Object.assign(newApi, {\n defaults: withDefaults.bind(null, newRequest),\n endpoint: newRequest.endpoint\n });\n}\n\n// pkg/dist-src/index.js\nvar graphql2 = withDefaults(import_request3.request, {\n headers: {\n \"user-agent\": `octokit-graphql.js/${VERSION} ${(0, import_universal_user_agent.getUserAgent)()}`\n },\n method: \"POST\",\n url: \"/graphql\"\n});\nfunction withCustomRequest(customRequest) {\n return withDefaults(customRequest, {\n method: \"POST\",\n url: \"/graphql\"\n });\n}\n// Annotate the CommonJS export names for ESM import in node:\n0 && (module.exports = {\n GraphqlResponseError,\n graphql,\n withCustomRequest\n});\n","\"use strict\";\nvar __defProp = Object.defineProperty;\nvar __getOwnPropDesc = Object.getOwnPropertyDescriptor;\nvar __getOwnPropNames = Object.getOwnPropertyNames;\nvar __hasOwnProp = Object.prototype.hasOwnProperty;\nvar __export = (target, all) => {\n for (var name in all)\n __defProp(target, name, { get: all[name], enumerable: true });\n};\nvar __copyProps = (to, from, except, desc) => {\n if (from && typeof from === \"object\" || typeof from === \"function\") {\n for (let key of __getOwnPropNames(from))\n if (!__hasOwnProp.call(to, key) && key !== except)\n __defProp(to, key, { get: () => from[key], enumerable: !(desc = __getOwnPropDesc(from, key)) || desc.enumerable });\n }\n return to;\n};\nvar __toCommonJS = (mod) => __copyProps(__defProp({}, \"__esModule\", { value: true }), mod);\n\n// pkg/dist-src/index.js\nvar dist_src_exports = {};\n__export(dist_src_exports, {\n composePaginateRest: () => composePaginateRest,\n isPaginatingEndpoint: () => isPaginatingEndpoint,\n paginateRest: () => paginateRest,\n paginatingEndpoints: () => paginatingEndpoints\n});\nmodule.exports = __toCommonJS(dist_src_exports);\n\n// pkg/dist-src/version.js\nvar VERSION = \"9.2.1\";\n\n// pkg/dist-src/normalize-paginated-list-response.js\nfunction normalizePaginatedListResponse(response) {\n if (!response.data) {\n return {\n ...response,\n data: []\n };\n }\n const responseNeedsNormalization = \"total_count\" in response.data && !(\"url\" in response.data);\n if (!responseNeedsNormalization)\n return response;\n const incompleteResults = response.data.incomplete_results;\n const repositorySelection = response.data.repository_selection;\n const totalCount = response.data.total_count;\n delete response.data.incomplete_results;\n delete response.data.repository_selection;\n delete response.data.total_count;\n const namespaceKey = Object.keys(response.data)[0];\n const data = response.data[namespaceKey];\n response.data = data;\n if (typeof incompleteResults !== \"undefined\") {\n response.data.incomplete_results = incompleteResults;\n }\n if (typeof repositorySelection !== \"undefined\") {\n response.data.repository_selection = repositorySelection;\n }\n response.data.total_count = totalCount;\n return response;\n}\n\n// pkg/dist-src/iterator.js\nfunction iterator(octokit, route, parameters) {\n const options = typeof route === \"function\" ? route.endpoint(parameters) : octokit.request.endpoint(route, parameters);\n const requestMethod = typeof route === \"function\" ? route : octokit.request;\n const method = options.method;\n const headers = options.headers;\n let url = options.url;\n return {\n [Symbol.asyncIterator]: () => ({\n async next() {\n if (!url)\n return { done: true };\n try {\n const response = await requestMethod({ method, url, headers });\n const normalizedResponse = normalizePaginatedListResponse(response);\n url = ((normalizedResponse.headers.link || \"\").match(\n /<([^>]+)>;\\s*rel=\"next\"/\n ) || [])[1];\n return { value: normalizedResponse };\n } catch (error) {\n if (error.status !== 409)\n throw error;\n url = \"\";\n return {\n value: {\n status: 200,\n headers: {},\n data: []\n }\n };\n }\n }\n })\n };\n}\n\n// pkg/dist-src/paginate.js\nfunction paginate(octokit, route, parameters, mapFn) {\n if (typeof parameters === \"function\") {\n mapFn = parameters;\n parameters = void 0;\n }\n return gather(\n octokit,\n [],\n iterator(octokit, route, parameters)[Symbol.asyncIterator](),\n mapFn\n );\n}\nfunction gather(octokit, results, iterator2, mapFn) {\n return iterator2.next().then((result) => {\n if (result.done) {\n return results;\n }\n let earlyExit = false;\n function done() {\n earlyExit = true;\n }\n results = results.concat(\n mapFn ? mapFn(result.value, done) : result.value.data\n );\n if (earlyExit) {\n return results;\n }\n return gather(octokit, results, iterator2, mapFn);\n });\n}\n\n// pkg/dist-src/compose-paginate.js\nvar composePaginateRest = Object.assign(paginate, {\n iterator\n});\n\n// pkg/dist-src/generated/paginating-endpoints.js\nvar paginatingEndpoints = [\n \"GET /advisories\",\n \"GET /app/hook/deliveries\",\n \"GET /app/installation-requests\",\n \"GET /app/installations\",\n \"GET /assignments/{assignment_id}/accepted_assignments\",\n \"GET /classrooms\",\n \"GET /classrooms/{classroom_id}/assignments\",\n \"GET /enterprises/{enterprise}/dependabot/alerts\",\n \"GET /enterprises/{enterprise}/secret-scanning/alerts\",\n \"GET /events\",\n \"GET /gists\",\n \"GET /gists/public\",\n \"GET /gists/starred\",\n \"GET /gists/{gist_id}/comments\",\n \"GET /gists/{gist_id}/commits\",\n \"GET /gists/{gist_id}/forks\",\n \"GET /installation/repositories\",\n \"GET /issues\",\n \"GET /licenses\",\n \"GET /marketplace_listing/plans\",\n \"GET /marketplace_listing/plans/{plan_id}/accounts\",\n \"GET /marketplace_listing/stubbed/plans\",\n \"GET /marketplace_listing/stubbed/plans/{plan_id}/accounts\",\n \"GET /networks/{owner}/{repo}/events\",\n \"GET /notifications\",\n \"GET /organizations\",\n \"GET /orgs/{org}/actions/cache/usage-by-repository\",\n \"GET /orgs/{org}/actions/permissions/repositories\",\n \"GET /orgs/{org}/actions/runners\",\n \"GET /orgs/{org}/actions/secrets\",\n \"GET /orgs/{org}/actions/secrets/{secret_name}/repositories\",\n \"GET /orgs/{org}/actions/variables\",\n \"GET /orgs/{org}/actions/variables/{name}/repositories\",\n \"GET /orgs/{org}/blocks\",\n \"GET /orgs/{org}/code-scanning/alerts\",\n \"GET /orgs/{org}/codespaces\",\n \"GET /orgs/{org}/codespaces/secrets\",\n \"GET /orgs/{org}/codespaces/secrets/{secret_name}/repositories\",\n \"GET /orgs/{org}/copilot/billing/seats\",\n \"GET /orgs/{org}/dependabot/alerts\",\n \"GET /orgs/{org}/dependabot/secrets\",\n \"GET /orgs/{org}/dependabot/secrets/{secret_name}/repositories\",\n \"GET /orgs/{org}/events\",\n \"GET /orgs/{org}/failed_invitations\",\n \"GET /orgs/{org}/hooks\",\n \"GET /orgs/{org}/hooks/{hook_id}/deliveries\",\n \"GET /orgs/{org}/installations\",\n \"GET /orgs/{org}/invitations\",\n \"GET /orgs/{org}/invitations/{invitation_id}/teams\",\n \"GET /orgs/{org}/issues\",\n \"GET /orgs/{org}/members\",\n \"GET /orgs/{org}/members/{username}/codespaces\",\n \"GET /orgs/{org}/migrations\",\n \"GET /orgs/{org}/migrations/{migration_id}/repositories\",\n \"GET /orgs/{org}/organization-roles/{role_id}/teams\",\n \"GET /orgs/{org}/organization-roles/{role_id}/users\",\n \"GET /orgs/{org}/outside_collaborators\",\n \"GET /orgs/{org}/packages\",\n \"GET /orgs/{org}/packages/{package_type}/{package_name}/versions\",\n \"GET /orgs/{org}/personal-access-token-requests\",\n \"GET /orgs/{org}/personal-access-token-requests/{pat_request_id}/repositories\",\n \"GET /orgs/{org}/personal-access-tokens\",\n \"GET /orgs/{org}/personal-access-tokens/{pat_id}/repositories\",\n \"GET /orgs/{org}/projects\",\n \"GET /orgs/{org}/properties/values\",\n \"GET /orgs/{org}/public_members\",\n \"GET /orgs/{org}/repos\",\n \"GET /orgs/{org}/rulesets\",\n \"GET /orgs/{org}/rulesets/rule-suites\",\n \"GET /orgs/{org}/secret-scanning/alerts\",\n \"GET /orgs/{org}/security-advisories\",\n \"GET /orgs/{org}/teams\",\n \"GET /orgs/{org}/teams/{team_slug}/discussions\",\n \"GET /orgs/{org}/teams/{team_slug}/discussions/{discussion_number}/comments\",\n \"GET /orgs/{org}/teams/{team_slug}/discussions/{discussion_number}/comments/{comment_number}/reactions\",\n \"GET /orgs/{org}/teams/{team_slug}/discussions/{discussion_number}/reactions\",\n \"GET /orgs/{org}/teams/{team_slug}/invitations\",\n \"GET /orgs/{org}/teams/{team_slug}/members\",\n \"GET /orgs/{org}/teams/{team_slug}/projects\",\n \"GET /orgs/{org}/teams/{team_slug}/repos\",\n \"GET /orgs/{org}/teams/{team_slug}/teams\",\n \"GET /projects/columns/{column_id}/cards\",\n \"GET /projects/{project_id}/collaborators\",\n \"GET /projects/{project_id}/columns\",\n \"GET /repos/{owner}/{repo}/actions/artifacts\",\n \"GET /repos/{owner}/{repo}/actions/caches\",\n \"GET /repos/{owner}/{repo}/actions/organization-secrets\",\n \"GET /repos/{owner}/{repo}/actions/organization-variables\",\n \"GET /repos/{owner}/{repo}/actions/runners\",\n \"GET /repos/{owner}/{repo}/actions/runs\",\n \"GET /repos/{owner}/{repo}/actions/runs/{run_id}/artifacts\",\n \"GET /repos/{owner}/{repo}/actions/runs/{run_id}/attempts/{attempt_number}/jobs\",\n \"GET /repos/{owner}/{repo}/actions/runs/{run_id}/jobs\",\n \"GET /repos/{owner}/{repo}/actions/secrets\",\n \"GET /repos/{owner}/{repo}/actions/variables\",\n \"GET /repos/{owner}/{repo}/actions/workflows\",\n \"GET /repos/{owner}/{repo}/actions/workflows/{workflow_id}/runs\",\n \"GET /repos/{owner}/{repo}/activity\",\n \"GET /repos/{owner}/{repo}/assignees\",\n \"GET /repos/{owner}/{repo}/branches\",\n \"GET /repos/{owner}/{repo}/check-runs/{check_run_id}/annotations\",\n \"GET /repos/{owner}/{repo}/check-suites/{check_suite_id}/check-runs\",\n \"GET /repos/{owner}/{repo}/code-scanning/alerts\",\n \"GET /repos/{owner}/{repo}/code-scanning/alerts/{alert_number}/instances\",\n \"GET /repos/{owner}/{repo}/code-scanning/analyses\",\n \"GET /repos/{owner}/{repo}/codespaces\",\n \"GET /repos/{owner}/{repo}/codespaces/devcontainers\",\n \"GET /repos/{owner}/{repo}/codespaces/secrets\",\n \"GET /repos/{owner}/{repo}/collaborators\",\n \"GET /repos/{owner}/{repo}/comments\",\n \"GET /repos/{owner}/{repo}/comments/{comment_id}/reactions\",\n \"GET /repos/{owner}/{repo}/commits\",\n \"GET /repos/{owner}/{repo}/commits/{commit_sha}/comments\",\n \"GET /repos/{owner}/{repo}/commits/{commit_sha}/pulls\",\n \"GET /repos/{owner}/{repo}/commits/{ref}/check-runs\",\n \"GET /repos/{owner}/{repo}/commits/{ref}/check-suites\",\n \"GET /repos/{owner}/{repo}/commits/{ref}/status\",\n \"GET /repos/{owner}/{repo}/commits/{ref}/statuses\",\n \"GET /repos/{owner}/{repo}/contributors\",\n \"GET /repos/{owner}/{repo}/dependabot/alerts\",\n \"GET /repos/{owner}/{repo}/dependabot/secrets\",\n \"GET /repos/{owner}/{repo}/deployments\",\n \"GET /repos/{owner}/{repo}/deployments/{deployment_id}/statuses\",\n \"GET /repos/{owner}/{repo}/environments\",\n \"GET /repos/{owner}/{repo}/environments/{environment_name}/deployment-branch-policies\",\n \"GET /repos/{owner}/{repo}/environments/{environment_name}/deployment_protection_rules/apps\",\n \"GET /repos/{owner}/{repo}/events\",\n \"GET /repos/{owner}/{repo}/forks\",\n \"GET /repos/{owner}/{repo}/hooks\",\n \"GET /repos/{owner}/{repo}/hooks/{hook_id}/deliveries\",\n \"GET /repos/{owner}/{repo}/invitations\",\n \"GET /repos/{owner}/{repo}/issues\",\n \"GET /repos/{owner}/{repo}/issues/comments\",\n \"GET /repos/{owner}/{repo}/issues/comments/{comment_id}/reactions\",\n \"GET /repos/{owner}/{repo}/issues/events\",\n \"GET /repos/{owner}/{repo}/issues/{issue_number}/comments\",\n \"GET /repos/{owner}/{repo}/issues/{issue_number}/events\",\n \"GET /repos/{owner}/{repo}/issues/{issue_number}/labels\",\n \"GET /repos/{owner}/{repo}/issues/{issue_number}/reactions\",\n \"GET /repos/{owner}/{repo}/issues/{issue_number}/timeline\",\n \"GET /repos/{owner}/{repo}/keys\",\n \"GET /repos/{owner}/{repo}/labels\",\n \"GET /repos/{owner}/{repo}/milestones\",\n \"GET /repos/{owner}/{repo}/milestones/{milestone_number}/labels\",\n \"GET /repos/{owner}/{repo}/notifications\",\n \"GET /repos/{owner}/{repo}/pages/builds\",\n \"GET /repos/{owner}/{repo}/projects\",\n \"GET /repos/{owner}/{repo}/pulls\",\n \"GET /repos/{owner}/{repo}/pulls/comments\",\n \"GET /repos/{owner}/{repo}/pulls/comments/{comment_id}/reactions\",\n \"GET /repos/{owner}/{repo}/pulls/{pull_number}/comments\",\n \"GET /repos/{owner}/{repo}/pulls/{pull_number}/commits\",\n \"GET /repos/{owner}/{repo}/pulls/{pull_number}/files\",\n \"GET /repos/{owner}/{repo}/pulls/{pull_number}/reviews\",\n \"GET /repos/{owner}/{repo}/pulls/{pull_number}/reviews/{review_id}/comments\",\n \"GET /repos/{owner}/{repo}/releases\",\n \"GET /repos/{owner}/{repo}/releases/{release_id}/assets\",\n \"GET /repos/{owner}/{repo}/releases/{release_id}/reactions\",\n \"GET /repos/{owner}/{repo}/rules/branches/{branch}\",\n \"GET /repos/{owner}/{repo}/rulesets\",\n \"GET /repos/{owner}/{repo}/rulesets/rule-suites\",\n \"GET /repos/{owner}/{repo}/secret-scanning/alerts\",\n \"GET /repos/{owner}/{repo}/secret-scanning/alerts/{alert_number}/locations\",\n \"GET /repos/{owner}/{repo}/security-advisories\",\n \"GET /repos/{owner}/{repo}/stargazers\",\n \"GET /repos/{owner}/{repo}/subscribers\",\n \"GET /repos/{owner}/{repo}/tags\",\n \"GET /repos/{owner}/{repo}/teams\",\n \"GET /repos/{owner}/{repo}/topics\",\n \"GET /repositories\",\n \"GET /repositories/{repository_id}/environments/{environment_name}/secrets\",\n \"GET /repositories/{repository_id}/environments/{environment_name}/variables\",\n \"GET /search/code\",\n \"GET /search/commits\",\n \"GET /search/issues\",\n \"GET /search/labels\",\n \"GET /search/repositories\",\n \"GET /search/topics\",\n \"GET /search/users\",\n \"GET /teams/{team_id}/discussions\",\n \"GET /teams/{team_id}/discussions/{discussion_number}/comments\",\n \"GET /teams/{team_id}/discussions/{discussion_number}/comments/{comment_number}/reactions\",\n \"GET /teams/{team_id}/discussions/{discussion_number}/reactions\",\n \"GET /teams/{team_id}/invitations\",\n \"GET /teams/{team_id}/members\",\n \"GET /teams/{team_id}/projects\",\n \"GET /teams/{team_id}/repos\",\n \"GET /teams/{team_id}/teams\",\n \"GET /user/blocks\",\n \"GET /user/codespaces\",\n \"GET /user/codespaces/secrets\",\n \"GET /user/emails\",\n \"GET /user/followers\",\n \"GET /user/following\",\n \"GET /user/gpg_keys\",\n \"GET /user/installations\",\n \"GET /user/installations/{installation_id}/repositories\",\n \"GET /user/issues\",\n \"GET /user/keys\",\n \"GET /user/marketplace_purchases\",\n \"GET /user/marketplace_purchases/stubbed\",\n \"GET /user/memberships/orgs\",\n \"GET /user/migrations\",\n \"GET /user/migrations/{migration_id}/repositories\",\n \"GET /user/orgs\",\n \"GET /user/packages\",\n \"GET /user/packages/{package_type}/{package_name}/versions\",\n \"GET /user/public_emails\",\n \"GET /user/repos\",\n \"GET /user/repository_invitations\",\n \"GET /user/social_accounts\",\n \"GET /user/ssh_signing_keys\",\n \"GET /user/starred\",\n \"GET /user/subscriptions\",\n \"GET /user/teams\",\n \"GET /users\",\n \"GET /users/{username}/events\",\n \"GET /users/{username}/events/orgs/{org}\",\n \"GET /users/{username}/events/public\",\n \"GET /users/{username}/followers\",\n \"GET /users/{username}/following\",\n \"GET /users/{username}/gists\",\n \"GET /users/{username}/gpg_keys\",\n \"GET /users/{username}/keys\",\n \"GET /users/{username}/orgs\",\n \"GET /users/{username}/packages\",\n \"GET /users/{username}/projects\",\n \"GET /users/{username}/received_events\",\n \"GET /users/{username}/received_events/public\",\n \"GET /users/{username}/repos\",\n \"GET /users/{username}/social_accounts\",\n \"GET /users/{username}/ssh_signing_keys\",\n \"GET /users/{username}/starred\",\n \"GET /users/{username}/subscriptions\"\n];\n\n// pkg/dist-src/paginating-endpoints.js\nfunction isPaginatingEndpoint(arg) {\n if (typeof arg === \"string\") {\n return paginatingEndpoints.includes(arg);\n } else {\n return false;\n }\n}\n\n// pkg/dist-src/index.js\nfunction paginateRest(octokit) {\n return {\n paginate: Object.assign(paginate.bind(null, octokit), {\n iterator: iterator.bind(null, octokit)\n })\n };\n}\npaginateRest.VERSION = VERSION;\n// Annotate the CommonJS export names for ESM import in node:\n0 && (module.exports = {\n composePaginateRest,\n isPaginatingEndpoint,\n paginateRest,\n paginatingEndpoints\n});\n","\"use strict\";\nvar __defProp = Object.defineProperty;\nvar __getOwnPropDesc = Object.getOwnPropertyDescriptor;\nvar __getOwnPropNames = Object.getOwnPropertyNames;\nvar __hasOwnProp = Object.prototype.hasOwnProperty;\nvar __export = (target, all) => {\n for (var name in all)\n __defProp(target, name, { get: all[name], enumerable: true });\n};\nvar __copyProps = (to, from, except, desc) => {\n if (from && typeof from === \"object\" || typeof from === \"function\") {\n for (let key of __getOwnPropNames(from))\n if (!__hasOwnProp.call(to, key) && key !== except)\n __defProp(to, key, { get: () => from[key], enumerable: !(desc = __getOwnPropDesc(from, key)) || desc.enumerable });\n }\n return to;\n};\nvar __toCommonJS = (mod) => __copyProps(__defProp({}, \"__esModule\", { value: true }), mod);\n\n// pkg/dist-src/index.js\nvar dist_src_exports = {};\n__export(dist_src_exports, {\n legacyRestEndpointMethods: () => legacyRestEndpointMethods,\n restEndpointMethods: () => restEndpointMethods\n});\nmodule.exports = __toCommonJS(dist_src_exports);\n\n// pkg/dist-src/version.js\nvar VERSION = \"10.4.1\";\n\n// pkg/dist-src/generated/endpoints.js\nvar Endpoints = {\n actions: {\n addCustomLabelsToSelfHostedRunnerForOrg: [\n \"POST /orgs/{org}/actions/runners/{runner_id}/labels\"\n ],\n addCustomLabelsToSelfHostedRunnerForRepo: [\n \"POST /repos/{owner}/{repo}/actions/runners/{runner_id}/labels\"\n ],\n addSelectedRepoToOrgSecret: [\n \"PUT /orgs/{org}/actions/secrets/{secret_name}/repositories/{repository_id}\"\n ],\n addSelectedRepoToOrgVariable: [\n \"PUT /orgs/{org}/actions/variables/{name}/repositories/{repository_id}\"\n ],\n approveWorkflowRun: [\n \"POST /repos/{owner}/{repo}/actions/runs/{run_id}/approve\"\n ],\n cancelWorkflowRun: [\n \"POST /repos/{owner}/{repo}/actions/runs/{run_id}/cancel\"\n ],\n createEnvironmentVariable: [\n \"POST /repositories/{repository_id}/environments/{environment_name}/variables\"\n ],\n createOrUpdateEnvironmentSecret: [\n \"PUT /repositories/{repository_id}/environments/{environment_name}/secrets/{secret_name}\"\n ],\n createOrUpdateOrgSecret: [\"PUT /orgs/{org}/actions/secrets/{secret_name}\"],\n createOrUpdateRepoSecret: [\n \"PUT /repos/{owner}/{repo}/actions/secrets/{secret_name}\"\n ],\n createOrgVariable: [\"POST /orgs/{org}/actions/variables\"],\n createRegistrationTokenForOrg: [\n \"POST /orgs/{org}/actions/runners/registration-token\"\n ],\n createRegistrationTokenForRepo: [\n \"POST /repos/{owner}/{repo}/actions/runners/registration-token\"\n ],\n createRemoveTokenForOrg: [\"POST /orgs/{org}/actions/runners/remove-token\"],\n createRemoveTokenForRepo: [\n \"POST /repos/{owner}/{repo}/actions/runners/remove-token\"\n ],\n createRepoVariable: [\"POST /repos/{owner}/{repo}/actions/variables\"],\n createWorkflowDispatch: [\n \"POST /repos/{owner}/{repo}/actions/workflows/{workflow_id}/dispatches\"\n ],\n deleteActionsCacheById: [\n \"DELETE /repos/{owner}/{repo}/actions/caches/{cache_id}\"\n ],\n deleteActionsCacheByKey: [\n \"DELETE /repos/{owner}/{repo}/actions/caches{?key,ref}\"\n ],\n deleteArtifact: [\n \"DELETE /repos/{owner}/{repo}/actions/artifacts/{artifact_id}\"\n ],\n deleteEnvironmentSecret: [\n \"DELETE /repositories/{repository_id}/environments/{environment_name}/secrets/{secret_name}\"\n ],\n deleteEnvironmentVariable: [\n \"DELETE /repositories/{repository_id}/environments/{environment_name}/variables/{name}\"\n ],\n deleteOrgSecret: [\"DELETE /orgs/{org}/actions/secrets/{secret_name}\"],\n deleteOrgVariable: [\"DELETE /orgs/{org}/actions/variables/{name}\"],\n deleteRepoSecret: [\n \"DELETE /repos/{owner}/{repo}/actions/secrets/{secret_name}\"\n ],\n deleteRepoVariable: [\n \"DELETE /repos/{owner}/{repo}/actions/variables/{name}\"\n ],\n deleteSelfHostedRunnerFromOrg: [\n \"DELETE /orgs/{org}/actions/runners/{runner_id}\"\n ],\n deleteSelfHostedRunnerFromRepo: [\n \"DELETE /repos/{owner}/{repo}/actions/runners/{runner_id}\"\n ],\n deleteWorkflowRun: [\"DELETE /repos/{owner}/{repo}/actions/runs/{run_id}\"],\n deleteWorkflowRunLogs: [\n \"DELETE /repos/{owner}/{repo}/actions/runs/{run_id}/logs\"\n ],\n disableSelectedRepositoryGithubActionsOrganization: [\n \"DELETE /orgs/{org}/actions/permissions/repositories/{repository_id}\"\n ],\n disableWorkflow: [\n \"PUT /repos/{owner}/{repo}/actions/workflows/{workflow_id}/disable\"\n ],\n downloadArtifact: [\n \"GET /repos/{owner}/{repo}/actions/artifacts/{artifact_id}/{archive_format}\"\n ],\n downloadJobLogsForWorkflowRun: [\n \"GET /repos/{owner}/{repo}/actions/jobs/{job_id}/logs\"\n ],\n downloadWorkflowRunAttemptLogs: [\n \"GET /repos/{owner}/{repo}/actions/runs/{run_id}/attempts/{attempt_number}/logs\"\n ],\n downloadWorkflowRunLogs: [\n \"GET /repos/{owner}/{repo}/actions/runs/{run_id}/logs\"\n ],\n enableSelectedRepositoryGithubActionsOrganization: [\n \"PUT /orgs/{org}/actions/permissions/repositories/{repository_id}\"\n ],\n enableWorkflow: [\n \"PUT /repos/{owner}/{repo}/actions/workflows/{workflow_id}/enable\"\n ],\n forceCancelWorkflowRun: [\n \"POST /repos/{owner}/{repo}/actions/runs/{run_id}/force-cancel\"\n ],\n generateRunnerJitconfigForOrg: [\n \"POST /orgs/{org}/actions/runners/generate-jitconfig\"\n ],\n generateRunnerJitconfigForRepo: [\n \"POST /repos/{owner}/{repo}/actions/runners/generate-jitconfig\"\n ],\n getActionsCacheList: [\"GET /repos/{owner}/{repo}/actions/caches\"],\n getActionsCacheUsage: [\"GET /repos/{owner}/{repo}/actions/cache/usage\"],\n getActionsCacheUsageByRepoForOrg: [\n \"GET /orgs/{org}/actions/cache/usage-by-repository\"\n ],\n getActionsCacheUsageForOrg: [\"GET /orgs/{org}/actions/cache/usage\"],\n getAllowedActionsOrganization: [\n \"GET /orgs/{org}/actions/permissions/selected-actions\"\n ],\n getAllowedActionsRepository: [\n \"GET /repos/{owner}/{repo}/actions/permissions/selected-actions\"\n ],\n getArtifact: [\"GET /repos/{owner}/{repo}/actions/artifacts/{artifact_id}\"],\n getCustomOidcSubClaimForRepo: [\n \"GET /repos/{owner}/{repo}/actions/oidc/customization/sub\"\n ],\n getEnvironmentPublicKey: [\n \"GET /repositories/{repository_id}/environments/{environment_name}/secrets/public-key\"\n ],\n getEnvironmentSecret: [\n \"GET /repositories/{repository_id}/environments/{environment_name}/secrets/{secret_name}\"\n ],\n getEnvironmentVariable: [\n \"GET /repositories/{repository_id}/environments/{environment_name}/variables/{name}\"\n ],\n getGithubActionsDefaultWorkflowPermissionsOrganization: [\n \"GET /orgs/{org}/actions/permissions/workflow\"\n ],\n getGithubActionsDefaultWorkflowPermissionsRepository: [\n \"GET /repos/{owner}/{repo}/actions/permissions/workflow\"\n ],\n getGithubActionsPermissionsOrganization: [\n \"GET /orgs/{org}/actions/permissions\"\n ],\n getGithubActionsPermissionsRepository: [\n \"GET /repos/{owner}/{repo}/actions/permissions\"\n ],\n getJobForWorkflowRun: [\"GET /repos/{owner}/{repo}/actions/jobs/{job_id}\"],\n getOrgPublicKey: [\"GET /orgs/{org}/actions/secrets/public-key\"],\n getOrgSecret: [\"GET /orgs/{org}/actions/secrets/{secret_name}\"],\n getOrgVariable: [\"GET /orgs/{org}/actions/variables/{name}\"],\n getPendingDeploymentsForRun: [\n \"GET /repos/{owner}/{repo}/actions/runs/{run_id}/pending_deployments\"\n ],\n getRepoPermissions: [\n \"GET /repos/{owner}/{repo}/actions/permissions\",\n {},\n { renamed: [\"actions\", \"getGithubActionsPermissionsRepository\"] }\n ],\n getRepoPublicKey: [\"GET /repos/{owner}/{repo}/actions/secrets/public-key\"],\n getRepoSecret: [\"GET /repos/{owner}/{repo}/actions/secrets/{secret_name}\"],\n getRepoVariable: [\"GET /repos/{owner}/{repo}/actions/variables/{name}\"],\n getReviewsForRun: [\n \"GET /repos/{owner}/{repo}/actions/runs/{run_id}/approvals\"\n ],\n getSelfHostedRunnerForOrg: [\"GET /orgs/{org}/actions/runners/{runner_id}\"],\n getSelfHostedRunnerForRepo: [\n \"GET /repos/{owner}/{repo}/actions/runners/{runner_id}\"\n ],\n getWorkflow: [\"GET /repos/{owner}/{repo}/actions/workflows/{workflow_id}\"],\n getWorkflowAccessToRepository: [\n \"GET /repos/{owner}/{repo}/actions/permissions/access\"\n ],\n getWorkflowRun: [\"GET /repos/{owner}/{repo}/actions/runs/{run_id}\"],\n getWorkflowRunAttempt: [\n \"GET /repos/{owner}/{repo}/actions/runs/{run_id}/attempts/{attempt_number}\"\n ],\n getWorkflowRunUsage: [\n \"GET /repos/{owner}/{repo}/actions/runs/{run_id}/timing\"\n ],\n getWorkflowUsage: [\n \"GET /repos/{owner}/{repo}/actions/workflows/{workflow_id}/timing\"\n ],\n listArtifactsForRepo: [\"GET /repos/{owner}/{repo}/actions/artifacts\"],\n listEnvironmentSecrets: [\n \"GET /repositories/{repository_id}/environments/{environment_name}/secrets\"\n ],\n listEnvironmentVariables: [\n \"GET /repositories/{repository_id}/environments/{environment_name}/variables\"\n ],\n listJobsForWorkflowRun: [\n \"GET /repos/{owner}/{repo}/actions/runs/{run_id}/jobs\"\n ],\n listJobsForWorkflowRunAttempt: [\n \"GET /repos/{owner}/{repo}/actions/runs/{run_id}/attempts/{attempt_number}/jobs\"\n ],\n listLabelsForSelfHostedRunnerForOrg: [\n \"GET /orgs/{org}/actions/runners/{runner_id}/labels\"\n ],\n listLabelsForSelfHostedRunnerForRepo: [\n \"GET /repos/{owner}/{repo}/actions/runners/{runner_id}/labels\"\n ],\n listOrgSecrets: [\"GET /orgs/{org}/actions/secrets\"],\n listOrgVariables: [\"GET /orgs/{org}/actions/variables\"],\n listRepoOrganizationSecrets: [\n \"GET /repos/{owner}/{repo}/actions/organization-secrets\"\n ],\n listRepoOrganizationVariables: [\n \"GET /repos/{owner}/{repo}/actions/organization-variables\"\n ],\n listRepoSecrets: [\"GET /repos/{owner}/{repo}/actions/secrets\"],\n listRepoVariables: [\"GET /repos/{owner}/{repo}/actions/variables\"],\n listRepoWorkflows: [\"GET /repos/{owner}/{repo}/actions/workflows\"],\n listRunnerApplicationsForOrg: [\"GET /orgs/{org}/actions/runners/downloads\"],\n listRunnerApplicationsForRepo: [\n \"GET /repos/{owner}/{repo}/actions/runners/downloads\"\n ],\n listSelectedReposForOrgSecret: [\n \"GET /orgs/{org}/actions/secrets/{secret_name}/repositories\"\n ],\n listSelectedReposForOrgVariable: [\n \"GET /orgs/{org}/actions/variables/{name}/repositories\"\n ],\n listSelectedRepositoriesEnabledGithubActionsOrganization: [\n \"GET /orgs/{org}/actions/permissions/repositories\"\n ],\n listSelfHostedRunnersForOrg: [\"GET /orgs/{org}/actions/runners\"],\n listSelfHostedRunnersForRepo: [\"GET /repos/{owner}/{repo}/actions/runners\"],\n listWorkflowRunArtifacts: [\n \"GET /repos/{owner}/{repo}/actions/runs/{run_id}/artifacts\"\n ],\n listWorkflowRuns: [\n \"GET /repos/{owner}/{repo}/actions/workflows/{workflow_id}/runs\"\n ],\n listWorkflowRunsForRepo: [\"GET /repos/{owner}/{repo}/actions/runs\"],\n reRunJobForWorkflowRun: [\n \"POST /repos/{owner}/{repo}/actions/jobs/{job_id}/rerun\"\n ],\n reRunWorkflow: [\"POST /repos/{owner}/{repo}/actions/runs/{run_id}/rerun\"],\n reRunWorkflowFailedJobs: [\n \"POST /repos/{owner}/{repo}/actions/runs/{run_id}/rerun-failed-jobs\"\n ],\n removeAllCustomLabelsFromSelfHostedRunnerForOrg: [\n \"DELETE /orgs/{org}/actions/runners/{runner_id}/labels\"\n ],\n removeAllCustomLabelsFromSelfHostedRunnerForRepo: [\n \"DELETE /repos/{owner}/{repo}/actions/runners/{runner_id}/labels\"\n ],\n removeCustomLabelFromSelfHostedRunnerForOrg: [\n \"DELETE /orgs/{org}/actions/runners/{runner_id}/labels/{name}\"\n ],\n removeCustomLabelFromSelfHostedRunnerForRepo: [\n \"DELETE /repos/{owner}/{repo}/actions/runners/{runner_id}/labels/{name}\"\n ],\n removeSelectedRepoFromOrgSecret: [\n \"DELETE /orgs/{org}/actions/secrets/{secret_name}/repositories/{repository_id}\"\n ],\n removeSelectedRepoFromOrgVariable: [\n \"DELETE /orgs/{org}/actions/variables/{name}/repositories/{repository_id}\"\n ],\n reviewCustomGatesForRun: [\n \"POST /repos/{owner}/{repo}/actions/runs/{run_id}/deployment_protection_rule\"\n ],\n reviewPendingDeploymentsForRun: [\n \"POST /repos/{owner}/{repo}/actions/runs/{run_id}/pending_deployments\"\n ],\n setAllowedActionsOrganization: [\n \"PUT /orgs/{org}/actions/permissions/selected-actions\"\n ],\n setAllowedActionsRepository: [\n \"PUT /repos/{owner}/{repo}/actions/permissions/selected-actions\"\n ],\n setCustomLabelsForSelfHostedRunnerForOrg: [\n \"PUT /orgs/{org}/actions/runners/{runner_id}/labels\"\n ],\n setCustomLabelsForSelfHostedRunnerForRepo: [\n \"PUT /repos/{owner}/{repo}/actions/runners/{runner_id}/labels\"\n ],\n setCustomOidcSubClaimForRepo: [\n \"PUT /repos/{owner}/{repo}/actions/oidc/customization/sub\"\n ],\n setGithubActionsDefaultWorkflowPermissionsOrganization: [\n \"PUT /orgs/{org}/actions/permissions/workflow\"\n ],\n setGithubActionsDefaultWorkflowPermissionsRepository: [\n \"PUT /repos/{owner}/{repo}/actions/permissions/workflow\"\n ],\n setGithubActionsPermissionsOrganization: [\n \"PUT /orgs/{org}/actions/permissions\"\n ],\n setGithubActionsPermissionsRepository: [\n \"PUT /repos/{owner}/{repo}/actions/permissions\"\n ],\n setSelectedReposForOrgSecret: [\n \"PUT /orgs/{org}/actions/secrets/{secret_name}/repositories\"\n ],\n setSelectedReposForOrgVariable: [\n \"PUT /orgs/{org}/actions/variables/{name}/repositories\"\n ],\n setSelectedRepositoriesEnabledGithubActionsOrganization: [\n \"PUT /orgs/{org}/actions/permissions/repositories\"\n ],\n setWorkflowAccessToRepository: [\n \"PUT /repos/{owner}/{repo}/actions/permissions/access\"\n ],\n updateEnvironmentVariable: [\n \"PATCH /repositories/{repository_id}/environments/{environment_name}/variables/{name}\"\n ],\n updateOrgVariable: [\"PATCH /orgs/{org}/actions/variables/{name}\"],\n updateRepoVariable: [\n \"PATCH /repos/{owner}/{repo}/actions/variables/{name}\"\n ]\n },\n activity: {\n checkRepoIsStarredByAuthenticatedUser: [\"GET /user/starred/{owner}/{repo}\"],\n deleteRepoSubscription: [\"DELETE /repos/{owner}/{repo}/subscription\"],\n deleteThreadSubscription: [\n \"DELETE /notifications/threads/{thread_id}/subscription\"\n ],\n getFeeds: [\"GET /feeds\"],\n getRepoSubscription: [\"GET /repos/{owner}/{repo}/subscription\"],\n getThread: [\"GET /notifications/threads/{thread_id}\"],\n getThreadSubscriptionForAuthenticatedUser: [\n \"GET /notifications/threads/{thread_id}/subscription\"\n ],\n listEventsForAuthenticatedUser: [\"GET /users/{username}/events\"],\n listNotificationsForAuthenticatedUser: [\"GET /notifications\"],\n listOrgEventsForAuthenticatedUser: [\n \"GET /users/{username}/events/orgs/{org}\"\n ],\n listPublicEvents: [\"GET /events\"],\n listPublicEventsForRepoNetwork: [\"GET /networks/{owner}/{repo}/events\"],\n listPublicEventsForUser: [\"GET /users/{username}/events/public\"],\n listPublicOrgEvents: [\"GET /orgs/{org}/events\"],\n listReceivedEventsForUser: [\"GET /users/{username}/received_events\"],\n listReceivedPublicEventsForUser: [\n \"GET /users/{username}/received_events/public\"\n ],\n listRepoEvents: [\"GET /repos/{owner}/{repo}/events\"],\n listRepoNotificationsForAuthenticatedUser: [\n \"GET /repos/{owner}/{repo}/notifications\"\n ],\n listReposStarredByAuthenticatedUser: [\"GET /user/starred\"],\n listReposStarredByUser: [\"GET /users/{username}/starred\"],\n listReposWatchedByUser: [\"GET /users/{username}/subscriptions\"],\n listStargazersForRepo: [\"GET /repos/{owner}/{repo}/stargazers\"],\n listWatchedReposForAuthenticatedUser: [\"GET /user/subscriptions\"],\n listWatchersForRepo: [\"GET /repos/{owner}/{repo}/subscribers\"],\n markNotificationsAsRead: [\"PUT /notifications\"],\n markRepoNotificationsAsRead: [\"PUT /repos/{owner}/{repo}/notifications\"],\n markThreadAsDone: [\"DELETE /notifications/threads/{thread_id}\"],\n markThreadAsRead: [\"PATCH /notifications/threads/{thread_id}\"],\n setRepoSubscription: [\"PUT /repos/{owner}/{repo}/subscription\"],\n setThreadSubscription: [\n \"PUT /notifications/threads/{thread_id}/subscription\"\n ],\n starRepoForAuthenticatedUser: [\"PUT /user/starred/{owner}/{repo}\"],\n unstarRepoForAuthenticatedUser: [\"DELETE /user/starred/{owner}/{repo}\"]\n },\n apps: {\n addRepoToInstallation: [\n \"PUT /user/installations/{installation_id}/repositories/{repository_id}\",\n {},\n { renamed: [\"apps\", \"addRepoToInstallationForAuthenticatedUser\"] }\n ],\n addRepoToInstallationForAuthenticatedUser: [\n \"PUT /user/installations/{installation_id}/repositories/{repository_id}\"\n ],\n checkToken: [\"POST /applications/{client_id}/token\"],\n createFromManifest: [\"POST /app-manifests/{code}/conversions\"],\n createInstallationAccessToken: [\n \"POST /app/installations/{installation_id}/access_tokens\"\n ],\n deleteAuthorization: [\"DELETE /applications/{client_id}/grant\"],\n deleteInstallation: [\"DELETE /app/installations/{installation_id}\"],\n deleteToken: [\"DELETE /applications/{client_id}/token\"],\n getAuthenticated: [\"GET /app\"],\n getBySlug: [\"GET /apps/{app_slug}\"],\n getInstallation: [\"GET /app/installations/{installation_id}\"],\n getOrgInstallation: [\"GET /orgs/{org}/installation\"],\n getRepoInstallation: [\"GET /repos/{owner}/{repo}/installation\"],\n getSubscriptionPlanForAccount: [\n \"GET /marketplace_listing/accounts/{account_id}\"\n ],\n getSubscriptionPlanForAccountStubbed: [\n \"GET /marketplace_listing/stubbed/accounts/{account_id}\"\n ],\n getUserInstallation: [\"GET /users/{username}/installation\"],\n getWebhookConfigForApp: [\"GET /app/hook/config\"],\n getWebhookDelivery: [\"GET /app/hook/deliveries/{delivery_id}\"],\n listAccountsForPlan: [\"GET /marketplace_listing/plans/{plan_id}/accounts\"],\n listAccountsForPlanStubbed: [\n \"GET /marketplace_listing/stubbed/plans/{plan_id}/accounts\"\n ],\n listInstallationReposForAuthenticatedUser: [\n \"GET /user/installations/{installation_id}/repositories\"\n ],\n listInstallationRequestsForAuthenticatedApp: [\n \"GET /app/installation-requests\"\n ],\n listInstallations: [\"GET /app/installations\"],\n listInstallationsForAuthenticatedUser: [\"GET /user/installations\"],\n listPlans: [\"GET /marketplace_listing/plans\"],\n listPlansStubbed: [\"GET /marketplace_listing/stubbed/plans\"],\n listReposAccessibleToInstallation: [\"GET /installation/repositories\"],\n listSubscriptionsForAuthenticatedUser: [\"GET /user/marketplace_purchases\"],\n listSubscriptionsForAuthenticatedUserStubbed: [\n \"GET /user/marketplace_purchases/stubbed\"\n ],\n listWebhookDeliveries: [\"GET /app/hook/deliveries\"],\n redeliverWebhookDelivery: [\n \"POST /app/hook/deliveries/{delivery_id}/attempts\"\n ],\n removeRepoFromInstallation: [\n \"DELETE /user/installations/{installation_id}/repositories/{repository_id}\",\n {},\n { renamed: [\"apps\", \"removeRepoFromInstallationForAuthenticatedUser\"] }\n ],\n removeRepoFromInstallationForAuthenticatedUser: [\n \"DELETE /user/installations/{installation_id}/repositories/{repository_id}\"\n ],\n resetToken: [\"PATCH /applications/{client_id}/token\"],\n revokeInstallationAccessToken: [\"DELETE /installation/token\"],\n scopeToken: [\"POST /applications/{client_id}/token/scoped\"],\n suspendInstallation: [\"PUT /app/installations/{installation_id}/suspended\"],\n unsuspendInstallation: [\n \"DELETE /app/installations/{installation_id}/suspended\"\n ],\n updateWebhookConfigForApp: [\"PATCH /app/hook/config\"]\n },\n billing: {\n getGithubActionsBillingOrg: [\"GET /orgs/{org}/settings/billing/actions\"],\n getGithubActionsBillingUser: [\n \"GET /users/{username}/settings/billing/actions\"\n ],\n getGithubPackagesBillingOrg: [\"GET /orgs/{org}/settings/billing/packages\"],\n getGithubPackagesBillingUser: [\n \"GET /users/{username}/settings/billing/packages\"\n ],\n getSharedStorageBillingOrg: [\n \"GET /orgs/{org}/settings/billing/shared-storage\"\n ],\n getSharedStorageBillingUser: [\n \"GET /users/{username}/settings/billing/shared-storage\"\n ]\n },\n checks: {\n create: [\"POST /repos/{owner}/{repo}/check-runs\"],\n createSuite: [\"POST /repos/{owner}/{repo}/check-suites\"],\n get: [\"GET /repos/{owner}/{repo}/check-runs/{check_run_id}\"],\n getSuite: [\"GET /repos/{owner}/{repo}/check-suites/{check_suite_id}\"],\n listAnnotations: [\n \"GET /repos/{owner}/{repo}/check-runs/{check_run_id}/annotations\"\n ],\n listForRef: [\"GET /repos/{owner}/{repo}/commits/{ref}/check-runs\"],\n listForSuite: [\n \"GET /repos/{owner}/{repo}/check-suites/{check_suite_id}/check-runs\"\n ],\n listSuitesForRef: [\"GET /repos/{owner}/{repo}/commits/{ref}/check-suites\"],\n rerequestRun: [\n \"POST /repos/{owner}/{repo}/check-runs/{check_run_id}/rerequest\"\n ],\n rerequestSuite: [\n \"POST /repos/{owner}/{repo}/check-suites/{check_suite_id}/rerequest\"\n ],\n setSuitesPreferences: [\n \"PATCH /repos/{owner}/{repo}/check-suites/preferences\"\n ],\n update: [\"PATCH /repos/{owner}/{repo}/check-runs/{check_run_id}\"]\n },\n codeScanning: {\n deleteAnalysis: [\n \"DELETE /repos/{owner}/{repo}/code-scanning/analyses/{analysis_id}{?confirm_delete}\"\n ],\n getAlert: [\n \"GET /repos/{owner}/{repo}/code-scanning/alerts/{alert_number}\",\n {},\n { renamedParameters: { alert_id: \"alert_number\" } }\n ],\n getAnalysis: [\n \"GET /repos/{owner}/{repo}/code-scanning/analyses/{analysis_id}\"\n ],\n getCodeqlDatabase: [\n \"GET /repos/{owner}/{repo}/code-scanning/codeql/databases/{language}\"\n ],\n getDefaultSetup: [\"GET /repos/{owner}/{repo}/code-scanning/default-setup\"],\n getSarif: [\"GET /repos/{owner}/{repo}/code-scanning/sarifs/{sarif_id}\"],\n listAlertInstances: [\n \"GET /repos/{owner}/{repo}/code-scanning/alerts/{alert_number}/instances\"\n ],\n listAlertsForOrg: [\"GET /orgs/{org}/code-scanning/alerts\"],\n listAlertsForRepo: [\"GET /repos/{owner}/{repo}/code-scanning/alerts\"],\n listAlertsInstances: [\n \"GET /repos/{owner}/{repo}/code-scanning/alerts/{alert_number}/instances\",\n {},\n { renamed: [\"codeScanning\", \"listAlertInstances\"] }\n ],\n listCodeqlDatabases: [\n \"GET /repos/{owner}/{repo}/code-scanning/codeql/databases\"\n ],\n listRecentAnalyses: [\"GET /repos/{owner}/{repo}/code-scanning/analyses\"],\n updateAlert: [\n \"PATCH /repos/{owner}/{repo}/code-scanning/alerts/{alert_number}\"\n ],\n updateDefaultSetup: [\n \"PATCH /repos/{owner}/{repo}/code-scanning/default-setup\"\n ],\n uploadSarif: [\"POST /repos/{owner}/{repo}/code-scanning/sarifs\"]\n },\n codesOfConduct: {\n getAllCodesOfConduct: [\"GET /codes_of_conduct\"],\n getConductCode: [\"GET /codes_of_conduct/{key}\"]\n },\n codespaces: {\n addRepositoryForSecretForAuthenticatedUser: [\n \"PUT /user/codespaces/secrets/{secret_name}/repositories/{repository_id}\"\n ],\n addSelectedRepoToOrgSecret: [\n \"PUT /orgs/{org}/codespaces/secrets/{secret_name}/repositories/{repository_id}\"\n ],\n checkPermissionsForDevcontainer: [\n \"GET /repos/{owner}/{repo}/codespaces/permissions_check\"\n ],\n codespaceMachinesForAuthenticatedUser: [\n \"GET /user/codespaces/{codespace_name}/machines\"\n ],\n createForAuthenticatedUser: [\"POST /user/codespaces\"],\n createOrUpdateOrgSecret: [\n \"PUT /orgs/{org}/codespaces/secrets/{secret_name}\"\n ],\n createOrUpdateRepoSecret: [\n \"PUT /repos/{owner}/{repo}/codespaces/secrets/{secret_name}\"\n ],\n createOrUpdateSecretForAuthenticatedUser: [\n \"PUT /user/codespaces/secrets/{secret_name}\"\n ],\n createWithPrForAuthenticatedUser: [\n \"POST /repos/{owner}/{repo}/pulls/{pull_number}/codespaces\"\n ],\n createWithRepoForAuthenticatedUser: [\n \"POST /repos/{owner}/{repo}/codespaces\"\n ],\n deleteForAuthenticatedUser: [\"DELETE /user/codespaces/{codespace_name}\"],\n deleteFromOrganization: [\n \"DELETE /orgs/{org}/members/{username}/codespaces/{codespace_name}\"\n ],\n deleteOrgSecret: [\"DELETE /orgs/{org}/codespaces/secrets/{secret_name}\"],\n deleteRepoSecret: [\n \"DELETE /repos/{owner}/{repo}/codespaces/secrets/{secret_name}\"\n ],\n deleteSecretForAuthenticatedUser: [\n \"DELETE /user/codespaces/secrets/{secret_name}\"\n ],\n exportForAuthenticatedUser: [\n \"POST /user/codespaces/{codespace_name}/exports\"\n ],\n getCodespacesForUserInOrg: [\n \"GET /orgs/{org}/members/{username}/codespaces\"\n ],\n getExportDetailsForAuthenticatedUser: [\n \"GET /user/codespaces/{codespace_name}/exports/{export_id}\"\n ],\n getForAuthenticatedUser: [\"GET /user/codespaces/{codespace_name}\"],\n getOrgPublicKey: [\"GET /orgs/{org}/codespaces/secrets/public-key\"],\n getOrgSecret: [\"GET /orgs/{org}/codespaces/secrets/{secret_name}\"],\n getPublicKeyForAuthenticatedUser: [\n \"GET /user/codespaces/secrets/public-key\"\n ],\n getRepoPublicKey: [\n \"GET /repos/{owner}/{repo}/codespaces/secrets/public-key\"\n ],\n getRepoSecret: [\n \"GET /repos/{owner}/{repo}/codespaces/secrets/{secret_name}\"\n ],\n getSecretForAuthenticatedUser: [\n \"GET /user/codespaces/secrets/{secret_name}\"\n ],\n listDevcontainersInRepositoryForAuthenticatedUser: [\n \"GET /repos/{owner}/{repo}/codespaces/devcontainers\"\n ],\n listForAuthenticatedUser: [\"GET /user/codespaces\"],\n listInOrganization: [\n \"GET /orgs/{org}/codespaces\",\n {},\n { renamedParameters: { org_id: \"org\" } }\n ],\n listInRepositoryForAuthenticatedUser: [\n \"GET /repos/{owner}/{repo}/codespaces\"\n ],\n listOrgSecrets: [\"GET /orgs/{org}/codespaces/secrets\"],\n listRepoSecrets: [\"GET /repos/{owner}/{repo}/codespaces/secrets\"],\n listRepositoriesForSecretForAuthenticatedUser: [\n \"GET /user/codespaces/secrets/{secret_name}/repositories\"\n ],\n listSecretsForAuthenticatedUser: [\"GET /user/codespaces/secrets\"],\n listSelectedReposForOrgSecret: [\n \"GET /orgs/{org}/codespaces/secrets/{secret_name}/repositories\"\n ],\n preFlightWithRepoForAuthenticatedUser: [\n \"GET /repos/{owner}/{repo}/codespaces/new\"\n ],\n publishForAuthenticatedUser: [\n \"POST /user/codespaces/{codespace_name}/publish\"\n ],\n removeRepositoryForSecretForAuthenticatedUser: [\n \"DELETE /user/codespaces/secrets/{secret_name}/repositories/{repository_id}\"\n ],\n removeSelectedRepoFromOrgSecret: [\n \"DELETE /orgs/{org}/codespaces/secrets/{secret_name}/repositories/{repository_id}\"\n ],\n repoMachinesForAuthenticatedUser: [\n \"GET /repos/{owner}/{repo}/codespaces/machines\"\n ],\n setRepositoriesForSecretForAuthenticatedUser: [\n \"PUT /user/codespaces/secrets/{secret_name}/repositories\"\n ],\n setSelectedReposForOrgSecret: [\n \"PUT /orgs/{org}/codespaces/secrets/{secret_name}/repositories\"\n ],\n startForAuthenticatedUser: [\"POST /user/codespaces/{codespace_name}/start\"],\n stopForAuthenticatedUser: [\"POST /user/codespaces/{codespace_name}/stop\"],\n stopInOrganization: [\n \"POST /orgs/{org}/members/{username}/codespaces/{codespace_name}/stop\"\n ],\n updateForAuthenticatedUser: [\"PATCH /user/codespaces/{codespace_name}\"]\n },\n copilot: {\n addCopilotSeatsForTeams: [\n \"POST /orgs/{org}/copilot/billing/selected_teams\"\n ],\n addCopilotSeatsForUsers: [\n \"POST /orgs/{org}/copilot/billing/selected_users\"\n ],\n cancelCopilotSeatAssignmentForTeams: [\n \"DELETE /orgs/{org}/copilot/billing/selected_teams\"\n ],\n cancelCopilotSeatAssignmentForUsers: [\n \"DELETE /orgs/{org}/copilot/billing/selected_users\"\n ],\n getCopilotOrganizationDetails: [\"GET /orgs/{org}/copilot/billing\"],\n getCopilotSeatDetailsForUser: [\n \"GET /orgs/{org}/members/{username}/copilot\"\n ],\n listCopilotSeats: [\"GET /orgs/{org}/copilot/billing/seats\"]\n },\n dependabot: {\n addSelectedRepoToOrgSecret: [\n \"PUT /orgs/{org}/dependabot/secrets/{secret_name}/repositories/{repository_id}\"\n ],\n createOrUpdateOrgSecret: [\n \"PUT /orgs/{org}/dependabot/secrets/{secret_name}\"\n ],\n createOrUpdateRepoSecret: [\n \"PUT /repos/{owner}/{repo}/dependabot/secrets/{secret_name}\"\n ],\n deleteOrgSecret: [\"DELETE /orgs/{org}/dependabot/secrets/{secret_name}\"],\n deleteRepoSecret: [\n \"DELETE /repos/{owner}/{repo}/dependabot/secrets/{secret_name}\"\n ],\n getAlert: [\"GET /repos/{owner}/{repo}/dependabot/alerts/{alert_number}\"],\n getOrgPublicKey: [\"GET /orgs/{org}/dependabot/secrets/public-key\"],\n getOrgSecret: [\"GET /orgs/{org}/dependabot/secrets/{secret_name}\"],\n getRepoPublicKey: [\n \"GET /repos/{owner}/{repo}/dependabot/secrets/public-key\"\n ],\n getRepoSecret: [\n \"GET /repos/{owner}/{repo}/dependabot/secrets/{secret_name}\"\n ],\n listAlertsForEnterprise: [\n \"GET /enterprises/{enterprise}/dependabot/alerts\"\n ],\n listAlertsForOrg: [\"GET /orgs/{org}/dependabot/alerts\"],\n listAlertsForRepo: [\"GET /repos/{owner}/{repo}/dependabot/alerts\"],\n listOrgSecrets: [\"GET /orgs/{org}/dependabot/secrets\"],\n listRepoSecrets: [\"GET /repos/{owner}/{repo}/dependabot/secrets\"],\n listSelectedReposForOrgSecret: [\n \"GET /orgs/{org}/dependabot/secrets/{secret_name}/repositories\"\n ],\n removeSelectedRepoFromOrgSecret: [\n \"DELETE /orgs/{org}/dependabot/secrets/{secret_name}/repositories/{repository_id}\"\n ],\n setSelectedReposForOrgSecret: [\n \"PUT /orgs/{org}/dependabot/secrets/{secret_name}/repositories\"\n ],\n updateAlert: [\n \"PATCH /repos/{owner}/{repo}/dependabot/alerts/{alert_number}\"\n ]\n },\n dependencyGraph: {\n createRepositorySnapshot: [\n \"POST /repos/{owner}/{repo}/dependency-graph/snapshots\"\n ],\n diffRange: [\n \"GET /repos/{owner}/{repo}/dependency-graph/compare/{basehead}\"\n ],\n exportSbom: [\"GET /repos/{owner}/{repo}/dependency-graph/sbom\"]\n },\n emojis: { get: [\"GET /emojis\"] },\n gists: {\n checkIsStarred: [\"GET /gists/{gist_id}/star\"],\n create: [\"POST /gists\"],\n createComment: [\"POST /gists/{gist_id}/comments\"],\n delete: [\"DELETE /gists/{gist_id}\"],\n deleteComment: [\"DELETE /gists/{gist_id}/comments/{comment_id}\"],\n fork: [\"POST /gists/{gist_id}/forks\"],\n get: [\"GET /gists/{gist_id}\"],\n getComment: [\"GET /gists/{gist_id}/comments/{comment_id}\"],\n getRevision: [\"GET /gists/{gist_id}/{sha}\"],\n list: [\"GET /gists\"],\n listComments: [\"GET /gists/{gist_id}/comments\"],\n listCommits: [\"GET /gists/{gist_id}/commits\"],\n listForUser: [\"GET /users/{username}/gists\"],\n listForks: [\"GET /gists/{gist_id}/forks\"],\n listPublic: [\"GET /gists/public\"],\n listStarred: [\"GET /gists/starred\"],\n star: [\"PUT /gists/{gist_id}/star\"],\n unstar: [\"DELETE /gists/{gist_id}/star\"],\n update: [\"PATCH /gists/{gist_id}\"],\n updateComment: [\"PATCH /gists/{gist_id}/comments/{comment_id}\"]\n },\n git: {\n createBlob: [\"POST /repos/{owner}/{repo}/git/blobs\"],\n createCommit: [\"POST /repos/{owner}/{repo}/git/commits\"],\n createRef: [\"POST /repos/{owner}/{repo}/git/refs\"],\n createTag: [\"POST /repos/{owner}/{repo}/git/tags\"],\n createTree: [\"POST /repos/{owner}/{repo}/git/trees\"],\n deleteRef: [\"DELETE /repos/{owner}/{repo}/git/refs/{ref}\"],\n getBlob: [\"GET /repos/{owner}/{repo}/git/blobs/{file_sha}\"],\n getCommit: [\"GET /repos/{owner}/{repo}/git/commits/{commit_sha}\"],\n getRef: [\"GET /repos/{owner}/{repo}/git/ref/{ref}\"],\n getTag: [\"GET /repos/{owner}/{repo}/git/tags/{tag_sha}\"],\n getTree: [\"GET /repos/{owner}/{repo}/git/trees/{tree_sha}\"],\n listMatchingRefs: [\"GET /repos/{owner}/{repo}/git/matching-refs/{ref}\"],\n updateRef: [\"PATCH /repos/{owner}/{repo}/git/refs/{ref}\"]\n },\n gitignore: {\n getAllTemplates: [\"GET /gitignore/templates\"],\n getTemplate: [\"GET /gitignore/templates/{name}\"]\n },\n interactions: {\n getRestrictionsForAuthenticatedUser: [\"GET /user/interaction-limits\"],\n getRestrictionsForOrg: [\"GET /orgs/{org}/interaction-limits\"],\n getRestrictionsForRepo: [\"GET /repos/{owner}/{repo}/interaction-limits\"],\n getRestrictionsForYourPublicRepos: [\n \"GET /user/interaction-limits\",\n {},\n { renamed: [\"interactions\", \"getRestrictionsForAuthenticatedUser\"] }\n ],\n removeRestrictionsForAuthenticatedUser: [\"DELETE /user/interaction-limits\"],\n removeRestrictionsForOrg: [\"DELETE /orgs/{org}/interaction-limits\"],\n removeRestrictionsForRepo: [\n \"DELETE /repos/{owner}/{repo}/interaction-limits\"\n ],\n removeRestrictionsForYourPublicRepos: [\n \"DELETE /user/interaction-limits\",\n {},\n { renamed: [\"interactions\", \"removeRestrictionsForAuthenticatedUser\"] }\n ],\n setRestrictionsForAuthenticatedUser: [\"PUT /user/interaction-limits\"],\n setRestrictionsForOrg: [\"PUT /orgs/{org}/interaction-limits\"],\n setRestrictionsForRepo: [\"PUT /repos/{owner}/{repo}/interaction-limits\"],\n setRestrictionsForYourPublicRepos: [\n \"PUT /user/interaction-limits\",\n {},\n { renamed: [\"interactions\", \"setRestrictionsForAuthenticatedUser\"] }\n ]\n },\n issues: {\n addAssignees: [\n \"POST /repos/{owner}/{repo}/issues/{issue_number}/assignees\"\n ],\n addLabels: [\"POST /repos/{owner}/{repo}/issues/{issue_number}/labels\"],\n checkUserCanBeAssigned: [\"GET /repos/{owner}/{repo}/assignees/{assignee}\"],\n checkUserCanBeAssignedToIssue: [\n \"GET /repos/{owner}/{repo}/issues/{issue_number}/assignees/{assignee}\"\n ],\n create: [\"POST /repos/{owner}/{repo}/issues\"],\n createComment: [\n \"POST /repos/{owner}/{repo}/issues/{issue_number}/comments\"\n ],\n createLabel: [\"POST /repos/{owner}/{repo}/labels\"],\n createMilestone: [\"POST /repos/{owner}/{repo}/milestones\"],\n deleteComment: [\n \"DELETE /repos/{owner}/{repo}/issues/comments/{comment_id}\"\n ],\n deleteLabel: [\"DELETE /repos/{owner}/{repo}/labels/{name}\"],\n deleteMilestone: [\n \"DELETE /repos/{owner}/{repo}/milestones/{milestone_number}\"\n ],\n get: [\"GET /repos/{owner}/{repo}/issues/{issue_number}\"],\n getComment: [\"GET /repos/{owner}/{repo}/issues/comments/{comment_id}\"],\n getEvent: [\"GET /repos/{owner}/{repo}/issues/events/{event_id}\"],\n getLabel: [\"GET /repos/{owner}/{repo}/labels/{name}\"],\n getMilestone: [\"GET /repos/{owner}/{repo}/milestones/{milestone_number}\"],\n list: [\"GET /issues\"],\n listAssignees: [\"GET /repos/{owner}/{repo}/assignees\"],\n listComments: [\"GET /repos/{owner}/{repo}/issues/{issue_number}/comments\"],\n listCommentsForRepo: [\"GET /repos/{owner}/{repo}/issues/comments\"],\n listEvents: [\"GET /repos/{owner}/{repo}/issues/{issue_number}/events\"],\n listEventsForRepo: [\"GET /repos/{owner}/{repo}/issues/events\"],\n listEventsForTimeline: [\n \"GET /repos/{owner}/{repo}/issues/{issue_number}/timeline\"\n ],\n listForAuthenticatedUser: [\"GET /user/issues\"],\n listForOrg: [\"GET /orgs/{org}/issues\"],\n listForRepo: [\"GET /repos/{owner}/{repo}/issues\"],\n listLabelsForMilestone: [\n \"GET /repos/{owner}/{repo}/milestones/{milestone_number}/labels\"\n ],\n listLabelsForRepo: [\"GET /repos/{owner}/{repo}/labels\"],\n listLabelsOnIssue: [\n \"GET /repos/{owner}/{repo}/issues/{issue_number}/labels\"\n ],\n listMilestones: [\"GET /repos/{owner}/{repo}/milestones\"],\n lock: [\"PUT /repos/{owner}/{repo}/issues/{issue_number}/lock\"],\n removeAllLabels: [\n \"DELETE /repos/{owner}/{repo}/issues/{issue_number}/labels\"\n ],\n removeAssignees: [\n \"DELETE /repos/{owner}/{repo}/issues/{issue_number}/assignees\"\n ],\n removeLabel: [\n \"DELETE /repos/{owner}/{repo}/issues/{issue_number}/labels/{name}\"\n ],\n setLabels: [\"PUT /repos/{owner}/{repo}/issues/{issue_number}/labels\"],\n unlock: [\"DELETE /repos/{owner}/{repo}/issues/{issue_number}/lock\"],\n update: [\"PATCH /repos/{owner}/{repo}/issues/{issue_number}\"],\n updateComment: [\"PATCH /repos/{owner}/{repo}/issues/comments/{comment_id}\"],\n updateLabel: [\"PATCH /repos/{owner}/{repo}/labels/{name}\"],\n updateMilestone: [\n \"PATCH /repos/{owner}/{repo}/milestones/{milestone_number}\"\n ]\n },\n licenses: {\n get: [\"GET /licenses/{license}\"],\n getAllCommonlyUsed: [\"GET /licenses\"],\n getForRepo: [\"GET /repos/{owner}/{repo}/license\"]\n },\n markdown: {\n render: [\"POST /markdown\"],\n renderRaw: [\n \"POST /markdown/raw\",\n { headers: { \"content-type\": \"text/plain; charset=utf-8\" } }\n ]\n },\n meta: {\n get: [\"GET /meta\"],\n getAllVersions: [\"GET /versions\"],\n getOctocat: [\"GET /octocat\"],\n getZen: [\"GET /zen\"],\n root: [\"GET /\"]\n },\n migrations: {\n cancelImport: [\n \"DELETE /repos/{owner}/{repo}/import\",\n {},\n {\n deprecated: \"octokit.rest.migrations.cancelImport() is deprecated, see https://docs.github.com/rest/migrations/source-imports#cancel-an-import\"\n }\n ],\n deleteArchiveForAuthenticatedUser: [\n \"DELETE /user/migrations/{migration_id}/archive\"\n ],\n deleteArchiveForOrg: [\n \"DELETE /orgs/{org}/migrations/{migration_id}/archive\"\n ],\n downloadArchiveForOrg: [\n \"GET /orgs/{org}/migrations/{migration_id}/archive\"\n ],\n getArchiveForAuthenticatedUser: [\n \"GET /user/migrations/{migration_id}/archive\"\n ],\n getCommitAuthors: [\n \"GET /repos/{owner}/{repo}/import/authors\",\n {},\n {\n deprecated: \"octokit.rest.migrations.getCommitAuthors() is deprecated, see https://docs.github.com/rest/migrations/source-imports#get-commit-authors\"\n }\n ],\n getImportStatus: [\n \"GET /repos/{owner}/{repo}/import\",\n {},\n {\n deprecated: \"octokit.rest.migrations.getImportStatus() is deprecated, see https://docs.github.com/rest/migrations/source-imports#get-an-import-status\"\n }\n ],\n getLargeFiles: [\n \"GET /repos/{owner}/{repo}/import/large_files\",\n {},\n {\n deprecated: \"octokit.rest.migrations.getLargeFiles() is deprecated, see https://docs.github.com/rest/migrations/source-imports#get-large-files\"\n }\n ],\n getStatusForAuthenticatedUser: [\"GET /user/migrations/{migration_id}\"],\n getStatusForOrg: [\"GET /orgs/{org}/migrations/{migration_id}\"],\n listForAuthenticatedUser: [\"GET /user/migrations\"],\n listForOrg: [\"GET /orgs/{org}/migrations\"],\n listReposForAuthenticatedUser: [\n \"GET /user/migrations/{migration_id}/repositories\"\n ],\n listReposForOrg: [\"GET /orgs/{org}/migrations/{migration_id}/repositories\"],\n listReposForUser: [\n \"GET /user/migrations/{migration_id}/repositories\",\n {},\n { renamed: [\"migrations\", \"listReposForAuthenticatedUser\"] }\n ],\n mapCommitAuthor: [\n \"PATCH /repos/{owner}/{repo}/import/authors/{author_id}\",\n {},\n {\n deprecated: \"octokit.rest.migrations.mapCommitAuthor() is deprecated, see https://docs.github.com/rest/migrations/source-imports#map-a-commit-author\"\n }\n ],\n setLfsPreference: [\n \"PATCH /repos/{owner}/{repo}/import/lfs\",\n {},\n {\n deprecated: \"octokit.rest.migrations.setLfsPreference() is deprecated, see https://docs.github.com/rest/migrations/source-imports#update-git-lfs-preference\"\n }\n ],\n startForAuthenticatedUser: [\"POST /user/migrations\"],\n startForOrg: [\"POST /orgs/{org}/migrations\"],\n startImport: [\n \"PUT /repos/{owner}/{repo}/import\",\n {},\n {\n deprecated: \"octokit.rest.migrations.startImport() is deprecated, see https://docs.github.com/rest/migrations/source-imports#start-an-import\"\n }\n ],\n unlockRepoForAuthenticatedUser: [\n \"DELETE /user/migrations/{migration_id}/repos/{repo_name}/lock\"\n ],\n unlockRepoForOrg: [\n \"DELETE /orgs/{org}/migrations/{migration_id}/repos/{repo_name}/lock\"\n ],\n updateImport: [\n \"PATCH /repos/{owner}/{repo}/import\",\n {},\n {\n deprecated: \"octokit.rest.migrations.updateImport() is deprecated, see https://docs.github.com/rest/migrations/source-imports#update-an-import\"\n }\n ]\n },\n oidc: {\n getOidcCustomSubTemplateForOrg: [\n \"GET /orgs/{org}/actions/oidc/customization/sub\"\n ],\n updateOidcCustomSubTemplateForOrg: [\n \"PUT /orgs/{org}/actions/oidc/customization/sub\"\n ]\n },\n orgs: {\n addSecurityManagerTeam: [\n \"PUT /orgs/{org}/security-managers/teams/{team_slug}\"\n ],\n assignTeamToOrgRole: [\n \"PUT /orgs/{org}/organization-roles/teams/{team_slug}/{role_id}\"\n ],\n assignUserToOrgRole: [\n \"PUT /orgs/{org}/organization-roles/users/{username}/{role_id}\"\n ],\n blockUser: [\"PUT /orgs/{org}/blocks/{username}\"],\n cancelInvitation: [\"DELETE /orgs/{org}/invitations/{invitation_id}\"],\n checkBlockedUser: [\"GET /orgs/{org}/blocks/{username}\"],\n checkMembershipForUser: [\"GET /orgs/{org}/members/{username}\"],\n checkPublicMembershipForUser: [\"GET /orgs/{org}/public_members/{username}\"],\n convertMemberToOutsideCollaborator: [\n \"PUT /orgs/{org}/outside_collaborators/{username}\"\n ],\n createCustomOrganizationRole: [\"POST /orgs/{org}/organization-roles\"],\n createInvitation: [\"POST /orgs/{org}/invitations\"],\n createOrUpdateCustomProperties: [\"PATCH /orgs/{org}/properties/schema\"],\n createOrUpdateCustomPropertiesValuesForRepos: [\n \"PATCH /orgs/{org}/properties/values\"\n ],\n createOrUpdateCustomProperty: [\n \"PUT /orgs/{org}/properties/schema/{custom_property_name}\"\n ],\n createWebhook: [\"POST /orgs/{org}/hooks\"],\n delete: [\"DELETE /orgs/{org}\"],\n deleteCustomOrganizationRole: [\n \"DELETE /orgs/{org}/organization-roles/{role_id}\"\n ],\n deleteWebhook: [\"DELETE /orgs/{org}/hooks/{hook_id}\"],\n enableOrDisableSecurityProductOnAllOrgRepos: [\n \"POST /orgs/{org}/{security_product}/{enablement}\"\n ],\n get: [\"GET /orgs/{org}\"],\n getAllCustomProperties: [\"GET /orgs/{org}/properties/schema\"],\n getCustomProperty: [\n \"GET /orgs/{org}/properties/schema/{custom_property_name}\"\n ],\n getMembershipForAuthenticatedUser: [\"GET /user/memberships/orgs/{org}\"],\n getMembershipForUser: [\"GET /orgs/{org}/memberships/{username}\"],\n getOrgRole: [\"GET /orgs/{org}/organization-roles/{role_id}\"],\n getWebhook: [\"GET /orgs/{org}/hooks/{hook_id}\"],\n getWebhookConfigForOrg: [\"GET /orgs/{org}/hooks/{hook_id}/config\"],\n getWebhookDelivery: [\n \"GET /orgs/{org}/hooks/{hook_id}/deliveries/{delivery_id}\"\n ],\n list: [\"GET /organizations\"],\n listAppInstallations: [\"GET /orgs/{org}/installations\"],\n listBlockedUsers: [\"GET /orgs/{org}/blocks\"],\n listCustomPropertiesValuesForRepos: [\"GET /orgs/{org}/properties/values\"],\n listFailedInvitations: [\"GET /orgs/{org}/failed_invitations\"],\n listForAuthenticatedUser: [\"GET /user/orgs\"],\n listForUser: [\"GET /users/{username}/orgs\"],\n listInvitationTeams: [\"GET /orgs/{org}/invitations/{invitation_id}/teams\"],\n listMembers: [\"GET /orgs/{org}/members\"],\n listMembershipsForAuthenticatedUser: [\"GET /user/memberships/orgs\"],\n listOrgRoleTeams: [\"GET /orgs/{org}/organization-roles/{role_id}/teams\"],\n listOrgRoleUsers: [\"GET /orgs/{org}/organization-roles/{role_id}/users\"],\n listOrgRoles: [\"GET /orgs/{org}/organization-roles\"],\n listOrganizationFineGrainedPermissions: [\n \"GET /orgs/{org}/organization-fine-grained-permissions\"\n ],\n listOutsideCollaborators: [\"GET /orgs/{org}/outside_collaborators\"],\n listPatGrantRepositories: [\n \"GET /orgs/{org}/personal-access-tokens/{pat_id}/repositories\"\n ],\n listPatGrantRequestRepositories: [\n \"GET /orgs/{org}/personal-access-token-requests/{pat_request_id}/repositories\"\n ],\n listPatGrantRequests: [\"GET /orgs/{org}/personal-access-token-requests\"],\n listPatGrants: [\"GET /orgs/{org}/personal-access-tokens\"],\n listPendingInvitations: [\"GET /orgs/{org}/invitations\"],\n listPublicMembers: [\"GET /orgs/{org}/public_members\"],\n listSecurityManagerTeams: [\"GET /orgs/{org}/security-managers\"],\n listWebhookDeliveries: [\"GET /orgs/{org}/hooks/{hook_id}/deliveries\"],\n listWebhooks: [\"GET /orgs/{org}/hooks\"],\n patchCustomOrganizationRole: [\n \"PATCH /orgs/{org}/organization-roles/{role_id}\"\n ],\n pingWebhook: [\"POST /orgs/{org}/hooks/{hook_id}/pings\"],\n redeliverWebhookDelivery: [\n \"POST /orgs/{org}/hooks/{hook_id}/deliveries/{delivery_id}/attempts\"\n ],\n removeCustomProperty: [\n \"DELETE /orgs/{org}/properties/schema/{custom_property_name}\"\n ],\n removeMember: [\"DELETE /orgs/{org}/members/{username}\"],\n removeMembershipForUser: [\"DELETE /orgs/{org}/memberships/{username}\"],\n removeOutsideCollaborator: [\n \"DELETE /orgs/{org}/outside_collaborators/{username}\"\n ],\n removePublicMembershipForAuthenticatedUser: [\n \"DELETE /orgs/{org}/public_members/{username}\"\n ],\n removeSecurityManagerTeam: [\n \"DELETE /orgs/{org}/security-managers/teams/{team_slug}\"\n ],\n reviewPatGrantRequest: [\n \"POST /orgs/{org}/personal-access-token-requests/{pat_request_id}\"\n ],\n reviewPatGrantRequestsInBulk: [\n \"POST /orgs/{org}/personal-access-token-requests\"\n ],\n revokeAllOrgRolesTeam: [\n \"DELETE /orgs/{org}/organization-roles/teams/{team_slug}\"\n ],\n revokeAllOrgRolesUser: [\n \"DELETE /orgs/{org}/organization-roles/users/{username}\"\n ],\n revokeOrgRoleTeam: [\n \"DELETE /orgs/{org}/organization-roles/teams/{team_slug}/{role_id}\"\n ],\n revokeOrgRoleUser: [\n \"DELETE /orgs/{org}/organization-roles/users/{username}/{role_id}\"\n ],\n setMembershipForUser: [\"PUT /orgs/{org}/memberships/{username}\"],\n setPublicMembershipForAuthenticatedUser: [\n \"PUT /orgs/{org}/public_members/{username}\"\n ],\n unblockUser: [\"DELETE /orgs/{org}/blocks/{username}\"],\n update: [\"PATCH /orgs/{org}\"],\n updateMembershipForAuthenticatedUser: [\n \"PATCH /user/memberships/orgs/{org}\"\n ],\n updatePatAccess: [\"POST /orgs/{org}/personal-access-tokens/{pat_id}\"],\n updatePatAccesses: [\"POST /orgs/{org}/personal-access-tokens\"],\n updateWebhook: [\"PATCH /orgs/{org}/hooks/{hook_id}\"],\n updateWebhookConfigForOrg: [\"PATCH /orgs/{org}/hooks/{hook_id}/config\"]\n },\n packages: {\n deletePackageForAuthenticatedUser: [\n \"DELETE /user/packages/{package_type}/{package_name}\"\n ],\n deletePackageForOrg: [\n \"DELETE /orgs/{org}/packages/{package_type}/{package_name}\"\n ],\n deletePackageForUser: [\n \"DELETE /users/{username}/packages/{package_type}/{package_name}\"\n ],\n deletePackageVersionForAuthenticatedUser: [\n \"DELETE /user/packages/{package_type}/{package_name}/versions/{package_version_id}\"\n ],\n deletePackageVersionForOrg: [\n \"DELETE /orgs/{org}/packages/{package_type}/{package_name}/versions/{package_version_id}\"\n ],\n deletePackageVersionForUser: [\n \"DELETE /users/{username}/packages/{package_type}/{package_name}/versions/{package_version_id}\"\n ],\n getAllPackageVersionsForAPackageOwnedByAnOrg: [\n \"GET /orgs/{org}/packages/{package_type}/{package_name}/versions\",\n {},\n { renamed: [\"packages\", \"getAllPackageVersionsForPackageOwnedByOrg\"] }\n ],\n getAllPackageVersionsForAPackageOwnedByTheAuthenticatedUser: [\n \"GET /user/packages/{package_type}/{package_name}/versions\",\n {},\n {\n renamed: [\n \"packages\",\n \"getAllPackageVersionsForPackageOwnedByAuthenticatedUser\"\n ]\n }\n ],\n getAllPackageVersionsForPackageOwnedByAuthenticatedUser: [\n \"GET /user/packages/{package_type}/{package_name}/versions\"\n ],\n getAllPackageVersionsForPackageOwnedByOrg: [\n \"GET /orgs/{org}/packages/{package_type}/{package_name}/versions\"\n ],\n getAllPackageVersionsForPackageOwnedByUser: [\n \"GET /users/{username}/packages/{package_type}/{package_name}/versions\"\n ],\n getPackageForAuthenticatedUser: [\n \"GET /user/packages/{package_type}/{package_name}\"\n ],\n getPackageForOrganization: [\n \"GET /orgs/{org}/packages/{package_type}/{package_name}\"\n ],\n getPackageForUser: [\n \"GET /users/{username}/packages/{package_type}/{package_name}\"\n ],\n getPackageVersionForAuthenticatedUser: [\n \"GET /user/packages/{package_type}/{package_name}/versions/{package_version_id}\"\n ],\n getPackageVersionForOrganization: [\n \"GET /orgs/{org}/packages/{package_type}/{package_name}/versions/{package_version_id}\"\n ],\n getPackageVersionForUser: [\n \"GET /users/{username}/packages/{package_type}/{package_name}/versions/{package_version_id}\"\n ],\n listDockerMigrationConflictingPackagesForAuthenticatedUser: [\n \"GET /user/docker/conflicts\"\n ],\n listDockerMigrationConflictingPackagesForOrganization: [\n \"GET /orgs/{org}/docker/conflicts\"\n ],\n listDockerMigrationConflictingPackagesForUser: [\n \"GET /users/{username}/docker/conflicts\"\n ],\n listPackagesForAuthenticatedUser: [\"GET /user/packages\"],\n listPackagesForOrganization: [\"GET /orgs/{org}/packages\"],\n listPackagesForUser: [\"GET /users/{username}/packages\"],\n restorePackageForAuthenticatedUser: [\n \"POST /user/packages/{package_type}/{package_name}/restore{?token}\"\n ],\n restorePackageForOrg: [\n \"POST /orgs/{org}/packages/{package_type}/{package_name}/restore{?token}\"\n ],\n restorePackageForUser: [\n \"POST /users/{username}/packages/{package_type}/{package_name}/restore{?token}\"\n ],\n restorePackageVersionForAuthenticatedUser: [\n \"POST /user/packages/{package_type}/{package_name}/versions/{package_version_id}/restore\"\n ],\n restorePackageVersionForOrg: [\n \"POST /orgs/{org}/packages/{package_type}/{package_name}/versions/{package_version_id}/restore\"\n ],\n restorePackageVersionForUser: [\n \"POST /users/{username}/packages/{package_type}/{package_name}/versions/{package_version_id}/restore\"\n ]\n },\n projects: {\n addCollaborator: [\"PUT /projects/{project_id}/collaborators/{username}\"],\n createCard: [\"POST /projects/columns/{column_id}/cards\"],\n createColumn: [\"POST /projects/{project_id}/columns\"],\n createForAuthenticatedUser: [\"POST /user/projects\"],\n createForOrg: [\"POST /orgs/{org}/projects\"],\n createForRepo: [\"POST /repos/{owner}/{repo}/projects\"],\n delete: [\"DELETE /projects/{project_id}\"],\n deleteCard: [\"DELETE /projects/columns/cards/{card_id}\"],\n deleteColumn: [\"DELETE /projects/columns/{column_id}\"],\n get: [\"GET /projects/{project_id}\"],\n getCard: [\"GET /projects/columns/cards/{card_id}\"],\n getColumn: [\"GET /projects/columns/{column_id}\"],\n getPermissionForUser: [\n \"GET /projects/{project_id}/collaborators/{username}/permission\"\n ],\n listCards: [\"GET /projects/columns/{column_id}/cards\"],\n listCollaborators: [\"GET /projects/{project_id}/collaborators\"],\n listColumns: [\"GET /projects/{project_id}/columns\"],\n listForOrg: [\"GET /orgs/{org}/projects\"],\n listForRepo: [\"GET /repos/{owner}/{repo}/projects\"],\n listForUser: [\"GET /users/{username}/projects\"],\n moveCard: [\"POST /projects/columns/cards/{card_id}/moves\"],\n moveColumn: [\"POST /projects/columns/{column_id}/moves\"],\n removeCollaborator: [\n \"DELETE /projects/{project_id}/collaborators/{username}\"\n ],\n update: [\"PATCH /projects/{project_id}\"],\n updateCard: [\"PATCH /projects/columns/cards/{card_id}\"],\n updateColumn: [\"PATCH /projects/columns/{column_id}\"]\n },\n pulls: {\n checkIfMerged: [\"GET /repos/{owner}/{repo}/pulls/{pull_number}/merge\"],\n create: [\"POST /repos/{owner}/{repo}/pulls\"],\n createReplyForReviewComment: [\n \"POST /repos/{owner}/{repo}/pulls/{pull_number}/comments/{comment_id}/replies\"\n ],\n createReview: [\"POST /repos/{owner}/{repo}/pulls/{pull_number}/reviews\"],\n createReviewComment: [\n \"POST /repos/{owner}/{repo}/pulls/{pull_number}/comments\"\n ],\n deletePendingReview: [\n \"DELETE /repos/{owner}/{repo}/pulls/{pull_number}/reviews/{review_id}\"\n ],\n deleteReviewComment: [\n \"DELETE /repos/{owner}/{repo}/pulls/comments/{comment_id}\"\n ],\n dismissReview: [\n \"PUT /repos/{owner}/{repo}/pulls/{pull_number}/reviews/{review_id}/dismissals\"\n ],\n get: [\"GET /repos/{owner}/{repo}/pulls/{pull_number}\"],\n getReview: [\n \"GET /repos/{owner}/{repo}/pulls/{pull_number}/reviews/{review_id}\"\n ],\n getReviewComment: [\"GET /repos/{owner}/{repo}/pulls/comments/{comment_id}\"],\n list: [\"GET /repos/{owner}/{repo}/pulls\"],\n listCommentsForReview: [\n \"GET /repos/{owner}/{repo}/pulls/{pull_number}/reviews/{review_id}/comments\"\n ],\n listCommits: [\"GET /repos/{owner}/{repo}/pulls/{pull_number}/commits\"],\n listFiles: [\"GET /repos/{owner}/{repo}/pulls/{pull_number}/files\"],\n listRequestedReviewers: [\n \"GET /repos/{owner}/{repo}/pulls/{pull_number}/requested_reviewers\"\n ],\n listReviewComments: [\n \"GET /repos/{owner}/{repo}/pulls/{pull_number}/comments\"\n ],\n listReviewCommentsForRepo: [\"GET /repos/{owner}/{repo}/pulls/comments\"],\n listReviews: [\"GET /repos/{owner}/{repo}/pulls/{pull_number}/reviews\"],\n merge: [\"PUT /repos/{owner}/{repo}/pulls/{pull_number}/merge\"],\n removeRequestedReviewers: [\n \"DELETE /repos/{owner}/{repo}/pulls/{pull_number}/requested_reviewers\"\n ],\n requestReviewers: [\n \"POST /repos/{owner}/{repo}/pulls/{pull_number}/requested_reviewers\"\n ],\n submitReview: [\n \"POST /repos/{owner}/{repo}/pulls/{pull_number}/reviews/{review_id}/events\"\n ],\n update: [\"PATCH /repos/{owner}/{repo}/pulls/{pull_number}\"],\n updateBranch: [\n \"PUT /repos/{owner}/{repo}/pulls/{pull_number}/update-branch\"\n ],\n updateReview: [\n \"PUT /repos/{owner}/{repo}/pulls/{pull_number}/reviews/{review_id}\"\n ],\n updateReviewComment: [\n \"PATCH /repos/{owner}/{repo}/pulls/comments/{comment_id}\"\n ]\n },\n rateLimit: { get: [\"GET /rate_limit\"] },\n reactions: {\n createForCommitComment: [\n \"POST /repos/{owner}/{repo}/comments/{comment_id}/reactions\"\n ],\n createForIssue: [\n \"POST /repos/{owner}/{repo}/issues/{issue_number}/reactions\"\n ],\n createForIssueComment: [\n \"POST /repos/{owner}/{repo}/issues/comments/{comment_id}/reactions\"\n ],\n createForPullRequestReviewComment: [\n \"POST /repos/{owner}/{repo}/pulls/comments/{comment_id}/reactions\"\n ],\n createForRelease: [\n \"POST /repos/{owner}/{repo}/releases/{release_id}/reactions\"\n ],\n createForTeamDiscussionCommentInOrg: [\n \"POST /orgs/{org}/teams/{team_slug}/discussions/{discussion_number}/comments/{comment_number}/reactions\"\n ],\n createForTeamDiscussionInOrg: [\n \"POST /orgs/{org}/teams/{team_slug}/discussions/{discussion_number}/reactions\"\n ],\n deleteForCommitComment: [\n \"DELETE /repos/{owner}/{repo}/comments/{comment_id}/reactions/{reaction_id}\"\n ],\n deleteForIssue: [\n \"DELETE /repos/{owner}/{repo}/issues/{issue_number}/reactions/{reaction_id}\"\n ],\n deleteForIssueComment: [\n \"DELETE /repos/{owner}/{repo}/issues/comments/{comment_id}/reactions/{reaction_id}\"\n ],\n deleteForPullRequestComment: [\n \"DELETE /repos/{owner}/{repo}/pulls/comments/{comment_id}/reactions/{reaction_id}\"\n ],\n deleteForRelease: [\n \"DELETE /repos/{owner}/{repo}/releases/{release_id}/reactions/{reaction_id}\"\n ],\n deleteForTeamDiscussion: [\n \"DELETE /orgs/{org}/teams/{team_slug}/discussions/{discussion_number}/reactions/{reaction_id}\"\n ],\n deleteForTeamDiscussionComment: [\n \"DELETE /orgs/{org}/teams/{team_slug}/discussions/{discussion_number}/comments/{comment_number}/reactions/{reaction_id}\"\n ],\n listForCommitComment: [\n \"GET /repos/{owner}/{repo}/comments/{comment_id}/reactions\"\n ],\n listForIssue: [\"GET /repos/{owner}/{repo}/issues/{issue_number}/reactions\"],\n listForIssueComment: [\n \"GET /repos/{owner}/{repo}/issues/comments/{comment_id}/reactions\"\n ],\n listForPullRequestReviewComment: [\n \"GET /repos/{owner}/{repo}/pulls/comments/{comment_id}/reactions\"\n ],\n listForRelease: [\n \"GET /repos/{owner}/{repo}/releases/{release_id}/reactions\"\n ],\n listForTeamDiscussionCommentInOrg: [\n \"GET /orgs/{org}/teams/{team_slug}/discussions/{discussion_number}/comments/{comment_number}/reactions\"\n ],\n listForTeamDiscussionInOrg: [\n \"GET /orgs/{org}/teams/{team_slug}/discussions/{discussion_number}/reactions\"\n ]\n },\n repos: {\n acceptInvitation: [\n \"PATCH /user/repository_invitations/{invitation_id}\",\n {},\n { renamed: [\"repos\", \"acceptInvitationForAuthenticatedUser\"] }\n ],\n acceptInvitationForAuthenticatedUser: [\n \"PATCH /user/repository_invitations/{invitation_id}\"\n ],\n addAppAccessRestrictions: [\n \"POST /repos/{owner}/{repo}/branches/{branch}/protection/restrictions/apps\",\n {},\n { mapToData: \"apps\" }\n ],\n addCollaborator: [\"PUT /repos/{owner}/{repo}/collaborators/{username}\"],\n addStatusCheckContexts: [\n \"POST /repos/{owner}/{repo}/branches/{branch}/protection/required_status_checks/contexts\",\n {},\n { mapToData: \"contexts\" }\n ],\n addTeamAccessRestrictions: [\n \"POST /repos/{owner}/{repo}/branches/{branch}/protection/restrictions/teams\",\n {},\n { mapToData: \"teams\" }\n ],\n addUserAccessRestrictions: [\n \"POST /repos/{owner}/{repo}/branches/{branch}/protection/restrictions/users\",\n {},\n { mapToData: \"users\" }\n ],\n cancelPagesDeployment: [\n \"POST /repos/{owner}/{repo}/pages/deployments/{pages_deployment_id}/cancel\"\n ],\n checkAutomatedSecurityFixes: [\n \"GET /repos/{owner}/{repo}/automated-security-fixes\"\n ],\n checkCollaborator: [\"GET /repos/{owner}/{repo}/collaborators/{username}\"],\n checkVulnerabilityAlerts: [\n \"GET /repos/{owner}/{repo}/vulnerability-alerts\"\n ],\n codeownersErrors: [\"GET /repos/{owner}/{repo}/codeowners/errors\"],\n compareCommits: [\"GET /repos/{owner}/{repo}/compare/{base}...{head}\"],\n compareCommitsWithBasehead: [\n \"GET /repos/{owner}/{repo}/compare/{basehead}\"\n ],\n createAutolink: [\"POST /repos/{owner}/{repo}/autolinks\"],\n createCommitComment: [\n \"POST /repos/{owner}/{repo}/commits/{commit_sha}/comments\"\n ],\n createCommitSignatureProtection: [\n \"POST /repos/{owner}/{repo}/branches/{branch}/protection/required_signatures\"\n ],\n createCommitStatus: [\"POST /repos/{owner}/{repo}/statuses/{sha}\"],\n createDeployKey: [\"POST /repos/{owner}/{repo}/keys\"],\n createDeployment: [\"POST /repos/{owner}/{repo}/deployments\"],\n createDeploymentBranchPolicy: [\n \"POST /repos/{owner}/{repo}/environments/{environment_name}/deployment-branch-policies\"\n ],\n createDeploymentProtectionRule: [\n \"POST /repos/{owner}/{repo}/environments/{environment_name}/deployment_protection_rules\"\n ],\n createDeploymentStatus: [\n \"POST /repos/{owner}/{repo}/deployments/{deployment_id}/statuses\"\n ],\n createDispatchEvent: [\"POST /repos/{owner}/{repo}/dispatches\"],\n createForAuthenticatedUser: [\"POST /user/repos\"],\n createFork: [\"POST /repos/{owner}/{repo}/forks\"],\n createInOrg: [\"POST /orgs/{org}/repos\"],\n createOrUpdateCustomPropertiesValues: [\n \"PATCH /repos/{owner}/{repo}/properties/values\"\n ],\n createOrUpdateEnvironment: [\n \"PUT /repos/{owner}/{repo}/environments/{environment_name}\"\n ],\n createOrUpdateFileContents: [\"PUT /repos/{owner}/{repo}/contents/{path}\"],\n createOrgRuleset: [\"POST /orgs/{org}/rulesets\"],\n createPagesDeployment: [\"POST /repos/{owner}/{repo}/pages/deployments\"],\n createPagesSite: [\"POST /repos/{owner}/{repo}/pages\"],\n createRelease: [\"POST /repos/{owner}/{repo}/releases\"],\n createRepoRuleset: [\"POST /repos/{owner}/{repo}/rulesets\"],\n createTagProtection: [\"POST /repos/{owner}/{repo}/tags/protection\"],\n createUsingTemplate: [\n \"POST /repos/{template_owner}/{template_repo}/generate\"\n ],\n createWebhook: [\"POST /repos/{owner}/{repo}/hooks\"],\n declineInvitation: [\n \"DELETE /user/repository_invitations/{invitation_id}\",\n {},\n { renamed: [\"repos\", \"declineInvitationForAuthenticatedUser\"] }\n ],\n declineInvitationForAuthenticatedUser: [\n \"DELETE /user/repository_invitations/{invitation_id}\"\n ],\n delete: [\"DELETE /repos/{owner}/{repo}\"],\n deleteAccessRestrictions: [\n \"DELETE /repos/{owner}/{repo}/branches/{branch}/protection/restrictions\"\n ],\n deleteAdminBranchProtection: [\n \"DELETE /repos/{owner}/{repo}/branches/{branch}/protection/enforce_admins\"\n ],\n deleteAnEnvironment: [\n \"DELETE /repos/{owner}/{repo}/environments/{environment_name}\"\n ],\n deleteAutolink: [\"DELETE /repos/{owner}/{repo}/autolinks/{autolink_id}\"],\n deleteBranchProtection: [\n \"DELETE /repos/{owner}/{repo}/branches/{branch}/protection\"\n ],\n deleteCommitComment: [\"DELETE /repos/{owner}/{repo}/comments/{comment_id}\"],\n deleteCommitSignatureProtection: [\n \"DELETE /repos/{owner}/{repo}/branches/{branch}/protection/required_signatures\"\n ],\n deleteDeployKey: [\"DELETE /repos/{owner}/{repo}/keys/{key_id}\"],\n deleteDeployment: [\n \"DELETE /repos/{owner}/{repo}/deployments/{deployment_id}\"\n ],\n deleteDeploymentBranchPolicy: [\n \"DELETE /repos/{owner}/{repo}/environments/{environment_name}/deployment-branch-policies/{branch_policy_id}\"\n ],\n deleteFile: [\"DELETE /repos/{owner}/{repo}/contents/{path}\"],\n deleteInvitation: [\n \"DELETE /repos/{owner}/{repo}/invitations/{invitation_id}\"\n ],\n deleteOrgRuleset: [\"DELETE /orgs/{org}/rulesets/{ruleset_id}\"],\n deletePagesSite: [\"DELETE /repos/{owner}/{repo}/pages\"],\n deletePullRequestReviewProtection: [\n \"DELETE /repos/{owner}/{repo}/branches/{branch}/protection/required_pull_request_reviews\"\n ],\n deleteRelease: [\"DELETE /repos/{owner}/{repo}/releases/{release_id}\"],\n deleteReleaseAsset: [\n \"DELETE /repos/{owner}/{repo}/releases/assets/{asset_id}\"\n ],\n deleteRepoRuleset: [\"DELETE /repos/{owner}/{repo}/rulesets/{ruleset_id}\"],\n deleteTagProtection: [\n \"DELETE /repos/{owner}/{repo}/tags/protection/{tag_protection_id}\"\n ],\n deleteWebhook: [\"DELETE /repos/{owner}/{repo}/hooks/{hook_id}\"],\n disableAutomatedSecurityFixes: [\n \"DELETE /repos/{owner}/{repo}/automated-security-fixes\"\n ],\n disableDeploymentProtectionRule: [\n \"DELETE /repos/{owner}/{repo}/environments/{environment_name}/deployment_protection_rules/{protection_rule_id}\"\n ],\n disablePrivateVulnerabilityReporting: [\n \"DELETE /repos/{owner}/{repo}/private-vulnerability-reporting\"\n ],\n disableVulnerabilityAlerts: [\n \"DELETE /repos/{owner}/{repo}/vulnerability-alerts\"\n ],\n downloadArchive: [\n \"GET /repos/{owner}/{repo}/zipball/{ref}\",\n {},\n { renamed: [\"repos\", \"downloadZipballArchive\"] }\n ],\n downloadTarballArchive: [\"GET /repos/{owner}/{repo}/tarball/{ref}\"],\n downloadZipballArchive: [\"GET /repos/{owner}/{repo}/zipball/{ref}\"],\n enableAutomatedSecurityFixes: [\n \"PUT /repos/{owner}/{repo}/automated-security-fixes\"\n ],\n enablePrivateVulnerabilityReporting: [\n \"PUT /repos/{owner}/{repo}/private-vulnerability-reporting\"\n ],\n enableVulnerabilityAlerts: [\n \"PUT /repos/{owner}/{repo}/vulnerability-alerts\"\n ],\n generateReleaseNotes: [\n \"POST /repos/{owner}/{repo}/releases/generate-notes\"\n ],\n get: [\"GET /repos/{owner}/{repo}\"],\n getAccessRestrictions: [\n \"GET /repos/{owner}/{repo}/branches/{branch}/protection/restrictions\"\n ],\n getAdminBranchProtection: [\n \"GET /repos/{owner}/{repo}/branches/{branch}/protection/enforce_admins\"\n ],\n getAllDeploymentProtectionRules: [\n \"GET /repos/{owner}/{repo}/environments/{environment_name}/deployment_protection_rules\"\n ],\n getAllEnvironments: [\"GET /repos/{owner}/{repo}/environments\"],\n getAllStatusCheckContexts: [\n \"GET /repos/{owner}/{repo}/branches/{branch}/protection/required_status_checks/contexts\"\n ],\n getAllTopics: [\"GET /repos/{owner}/{repo}/topics\"],\n getAppsWithAccessToProtectedBranch: [\n \"GET /repos/{owner}/{repo}/branches/{branch}/protection/restrictions/apps\"\n ],\n getAutolink: [\"GET /repos/{owner}/{repo}/autolinks/{autolink_id}\"],\n getBranch: [\"GET /repos/{owner}/{repo}/branches/{branch}\"],\n getBranchProtection: [\n \"GET /repos/{owner}/{repo}/branches/{branch}/protection\"\n ],\n getBranchRules: [\"GET /repos/{owner}/{repo}/rules/branches/{branch}\"],\n getClones: [\"GET /repos/{owner}/{repo}/traffic/clones\"],\n getCodeFrequencyStats: [\"GET /repos/{owner}/{repo}/stats/code_frequency\"],\n getCollaboratorPermissionLevel: [\n \"GET /repos/{owner}/{repo}/collaborators/{username}/permission\"\n ],\n getCombinedStatusForRef: [\"GET /repos/{owner}/{repo}/commits/{ref}/status\"],\n getCommit: [\"GET /repos/{owner}/{repo}/commits/{ref}\"],\n getCommitActivityStats: [\"GET /repos/{owner}/{repo}/stats/commit_activity\"],\n getCommitComment: [\"GET /repos/{owner}/{repo}/comments/{comment_id}\"],\n getCommitSignatureProtection: [\n \"GET /repos/{owner}/{repo}/branches/{branch}/protection/required_signatures\"\n ],\n getCommunityProfileMetrics: [\"GET /repos/{owner}/{repo}/community/profile\"],\n getContent: [\"GET /repos/{owner}/{repo}/contents/{path}\"],\n getContributorsStats: [\"GET /repos/{owner}/{repo}/stats/contributors\"],\n getCustomDeploymentProtectionRule: [\n \"GET /repos/{owner}/{repo}/environments/{environment_name}/deployment_protection_rules/{protection_rule_id}\"\n ],\n getCustomPropertiesValues: [\"GET /repos/{owner}/{repo}/properties/values\"],\n getDeployKey: [\"GET /repos/{owner}/{repo}/keys/{key_id}\"],\n getDeployment: [\"GET /repos/{owner}/{repo}/deployments/{deployment_id}\"],\n getDeploymentBranchPolicy: [\n \"GET /repos/{owner}/{repo}/environments/{environment_name}/deployment-branch-policies/{branch_policy_id}\"\n ],\n getDeploymentStatus: [\n \"GET /repos/{owner}/{repo}/deployments/{deployment_id}/statuses/{status_id}\"\n ],\n getEnvironment: [\n \"GET /repos/{owner}/{repo}/environments/{environment_name}\"\n ],\n getLatestPagesBuild: [\"GET /repos/{owner}/{repo}/pages/builds/latest\"],\n getLatestRelease: [\"GET /repos/{owner}/{repo}/releases/latest\"],\n getOrgRuleSuite: [\"GET /orgs/{org}/rulesets/rule-suites/{rule_suite_id}\"],\n getOrgRuleSuites: [\"GET /orgs/{org}/rulesets/rule-suites\"],\n getOrgRuleset: [\"GET /orgs/{org}/rulesets/{ruleset_id}\"],\n getOrgRulesets: [\"GET /orgs/{org}/rulesets\"],\n getPages: [\"GET /repos/{owner}/{repo}/pages\"],\n getPagesBuild: [\"GET /repos/{owner}/{repo}/pages/builds/{build_id}\"],\n getPagesDeployment: [\n \"GET /repos/{owner}/{repo}/pages/deployments/{pages_deployment_id}\"\n ],\n getPagesHealthCheck: [\"GET /repos/{owner}/{repo}/pages/health\"],\n getParticipationStats: [\"GET /repos/{owner}/{repo}/stats/participation\"],\n getPullRequestReviewProtection: [\n \"GET /repos/{owner}/{repo}/branches/{branch}/protection/required_pull_request_reviews\"\n ],\n getPunchCardStats: [\"GET /repos/{owner}/{repo}/stats/punch_card\"],\n getReadme: [\"GET /repos/{owner}/{repo}/readme\"],\n getReadmeInDirectory: [\"GET /repos/{owner}/{repo}/readme/{dir}\"],\n getRelease: [\"GET /repos/{owner}/{repo}/releases/{release_id}\"],\n getReleaseAsset: [\"GET /repos/{owner}/{repo}/releases/assets/{asset_id}\"],\n getReleaseByTag: [\"GET /repos/{owner}/{repo}/releases/tags/{tag}\"],\n getRepoRuleSuite: [\n \"GET /repos/{owner}/{repo}/rulesets/rule-suites/{rule_suite_id}\"\n ],\n getRepoRuleSuites: [\"GET /repos/{owner}/{repo}/rulesets/rule-suites\"],\n getRepoRuleset: [\"GET /repos/{owner}/{repo}/rulesets/{ruleset_id}\"],\n getRepoRulesets: [\"GET /repos/{owner}/{repo}/rulesets\"],\n getStatusChecksProtection: [\n \"GET /repos/{owner}/{repo}/branches/{branch}/protection/required_status_checks\"\n ],\n getTeamsWithAccessToProtectedBranch: [\n \"GET /repos/{owner}/{repo}/branches/{branch}/protection/restrictions/teams\"\n ],\n getTopPaths: [\"GET /repos/{owner}/{repo}/traffic/popular/paths\"],\n getTopReferrers: [\"GET /repos/{owner}/{repo}/traffic/popular/referrers\"],\n getUsersWithAccessToProtectedBranch: [\n \"GET /repos/{owner}/{repo}/branches/{branch}/protection/restrictions/users\"\n ],\n getViews: [\"GET /repos/{owner}/{repo}/traffic/views\"],\n getWebhook: [\"GET /repos/{owner}/{repo}/hooks/{hook_id}\"],\n getWebhookConfigForRepo: [\n \"GET /repos/{owner}/{repo}/hooks/{hook_id}/config\"\n ],\n getWebhookDelivery: [\n \"GET /repos/{owner}/{repo}/hooks/{hook_id}/deliveries/{delivery_id}\"\n ],\n listActivities: [\"GET /repos/{owner}/{repo}/activity\"],\n listAutolinks: [\"GET /repos/{owner}/{repo}/autolinks\"],\n listBranches: [\"GET /repos/{owner}/{repo}/branches\"],\n listBranchesForHeadCommit: [\n \"GET /repos/{owner}/{repo}/commits/{commit_sha}/branches-where-head\"\n ],\n listCollaborators: [\"GET /repos/{owner}/{repo}/collaborators\"],\n listCommentsForCommit: [\n \"GET /repos/{owner}/{repo}/commits/{commit_sha}/comments\"\n ],\n listCommitCommentsForRepo: [\"GET /repos/{owner}/{repo}/comments\"],\n listCommitStatusesForRef: [\n \"GET /repos/{owner}/{repo}/commits/{ref}/statuses\"\n ],\n listCommits: [\"GET /repos/{owner}/{repo}/commits\"],\n listContributors: [\"GET /repos/{owner}/{repo}/contributors\"],\n listCustomDeploymentRuleIntegrations: [\n \"GET /repos/{owner}/{repo}/environments/{environment_name}/deployment_protection_rules/apps\"\n ],\n listDeployKeys: [\"GET /repos/{owner}/{repo}/keys\"],\n listDeploymentBranchPolicies: [\n \"GET /repos/{owner}/{repo}/environments/{environment_name}/deployment-branch-policies\"\n ],\n listDeploymentStatuses: [\n \"GET /repos/{owner}/{repo}/deployments/{deployment_id}/statuses\"\n ],\n listDeployments: [\"GET /repos/{owner}/{repo}/deployments\"],\n listForAuthenticatedUser: [\"GET /user/repos\"],\n listForOrg: [\"GET /orgs/{org}/repos\"],\n listForUser: [\"GET /users/{username}/repos\"],\n listForks: [\"GET /repos/{owner}/{repo}/forks\"],\n listInvitations: [\"GET /repos/{owner}/{repo}/invitations\"],\n listInvitationsForAuthenticatedUser: [\"GET /user/repository_invitations\"],\n listLanguages: [\"GET /repos/{owner}/{repo}/languages\"],\n listPagesBuilds: [\"GET /repos/{owner}/{repo}/pages/builds\"],\n listPublic: [\"GET /repositories\"],\n listPullRequestsAssociatedWithCommit: [\n \"GET /repos/{owner}/{repo}/commits/{commit_sha}/pulls\"\n ],\n listReleaseAssets: [\n \"GET /repos/{owner}/{repo}/releases/{release_id}/assets\"\n ],\n listReleases: [\"GET /repos/{owner}/{repo}/releases\"],\n listTagProtection: [\"GET /repos/{owner}/{repo}/tags/protection\"],\n listTags: [\"GET /repos/{owner}/{repo}/tags\"],\n listTeams: [\"GET /repos/{owner}/{repo}/teams\"],\n listWebhookDeliveries: [\n \"GET /repos/{owner}/{repo}/hooks/{hook_id}/deliveries\"\n ],\n listWebhooks: [\"GET /repos/{owner}/{repo}/hooks\"],\n merge: [\"POST /repos/{owner}/{repo}/merges\"],\n mergeUpstream: [\"POST /repos/{owner}/{repo}/merge-upstream\"],\n pingWebhook: [\"POST /repos/{owner}/{repo}/hooks/{hook_id}/pings\"],\n redeliverWebhookDelivery: [\n \"POST /repos/{owner}/{repo}/hooks/{hook_id}/deliveries/{delivery_id}/attempts\"\n ],\n removeAppAccessRestrictions: [\n \"DELETE /repos/{owner}/{repo}/branches/{branch}/protection/restrictions/apps\",\n {},\n { mapToData: \"apps\" }\n ],\n removeCollaborator: [\n \"DELETE /repos/{owner}/{repo}/collaborators/{username}\"\n ],\n removeStatusCheckContexts: [\n \"DELETE /repos/{owner}/{repo}/branches/{branch}/protection/required_status_checks/contexts\",\n {},\n { mapToData: \"contexts\" }\n ],\n removeStatusCheckProtection: [\n \"DELETE /repos/{owner}/{repo}/branches/{branch}/protection/required_status_checks\"\n ],\n removeTeamAccessRestrictions: [\n \"DELETE /repos/{owner}/{repo}/branches/{branch}/protection/restrictions/teams\",\n {},\n { mapToData: \"teams\" }\n ],\n removeUserAccessRestrictions: [\n \"DELETE /repos/{owner}/{repo}/branches/{branch}/protection/restrictions/users\",\n {},\n { mapToData: \"users\" }\n ],\n renameBranch: [\"POST /repos/{owner}/{repo}/branches/{branch}/rename\"],\n replaceAllTopics: [\"PUT /repos/{owner}/{repo}/topics\"],\n requestPagesBuild: [\"POST /repos/{owner}/{repo}/pages/builds\"],\n setAdminBranchProtection: [\n \"POST /repos/{owner}/{repo}/branches/{branch}/protection/enforce_admins\"\n ],\n setAppAccessRestrictions: [\n \"PUT /repos/{owner}/{repo}/branches/{branch}/protection/restrictions/apps\",\n {},\n { mapToData: \"apps\" }\n ],\n setStatusCheckContexts: [\n \"PUT /repos/{owner}/{repo}/branches/{branch}/protection/required_status_checks/contexts\",\n {},\n { mapToData: \"contexts\" }\n ],\n setTeamAccessRestrictions: [\n \"PUT /repos/{owner}/{repo}/branches/{branch}/protection/restrictions/teams\",\n {},\n { mapToData: \"teams\" }\n ],\n setUserAccessRestrictions: [\n \"PUT /repos/{owner}/{repo}/branches/{branch}/protection/restrictions/users\",\n {},\n { mapToData: \"users\" }\n ],\n testPushWebhook: [\"POST /repos/{owner}/{repo}/hooks/{hook_id}/tests\"],\n transfer: [\"POST /repos/{owner}/{repo}/transfer\"],\n update: [\"PATCH /repos/{owner}/{repo}\"],\n updateBranchProtection: [\n \"PUT /repos/{owner}/{repo}/branches/{branch}/protection\"\n ],\n updateCommitComment: [\"PATCH /repos/{owner}/{repo}/comments/{comment_id}\"],\n updateDeploymentBranchPolicy: [\n \"PUT /repos/{owner}/{repo}/environments/{environment_name}/deployment-branch-policies/{branch_policy_id}\"\n ],\n updateInformationAboutPagesSite: [\"PUT /repos/{owner}/{repo}/pages\"],\n updateInvitation: [\n \"PATCH /repos/{owner}/{repo}/invitations/{invitation_id}\"\n ],\n updateOrgRuleset: [\"PUT /orgs/{org}/rulesets/{ruleset_id}\"],\n updatePullRequestReviewProtection: [\n \"PATCH /repos/{owner}/{repo}/branches/{branch}/protection/required_pull_request_reviews\"\n ],\n updateRelease: [\"PATCH /repos/{owner}/{repo}/releases/{release_id}\"],\n updateReleaseAsset: [\n \"PATCH /repos/{owner}/{repo}/releases/assets/{asset_id}\"\n ],\n updateRepoRuleset: [\"PUT /repos/{owner}/{repo}/rulesets/{ruleset_id}\"],\n updateStatusCheckPotection: [\n \"PATCH /repos/{owner}/{repo}/branches/{branch}/protection/required_status_checks\",\n {},\n { renamed: [\"repos\", \"updateStatusCheckProtection\"] }\n ],\n updateStatusCheckProtection: [\n \"PATCH /repos/{owner}/{repo}/branches/{branch}/protection/required_status_checks\"\n ],\n updateWebhook: [\"PATCH /repos/{owner}/{repo}/hooks/{hook_id}\"],\n updateWebhookConfigForRepo: [\n \"PATCH /repos/{owner}/{repo}/hooks/{hook_id}/config\"\n ],\n uploadReleaseAsset: [\n \"POST /repos/{owner}/{repo}/releases/{release_id}/assets{?name,label}\",\n { baseUrl: \"https://uploads.github.com\" }\n ]\n },\n search: {\n code: [\"GET /search/code\"],\n commits: [\"GET /search/commits\"],\n issuesAndPullRequests: [\"GET /search/issues\"],\n labels: [\"GET /search/labels\"],\n repos: [\"GET /search/repositories\"],\n topics: [\"GET /search/topics\"],\n users: [\"GET /search/users\"]\n },\n secretScanning: {\n getAlert: [\n \"GET /repos/{owner}/{repo}/secret-scanning/alerts/{alert_number}\"\n ],\n listAlertsForEnterprise: [\n \"GET /enterprises/{enterprise}/secret-scanning/alerts\"\n ],\n listAlertsForOrg: [\"GET /orgs/{org}/secret-scanning/alerts\"],\n listAlertsForRepo: [\"GET /repos/{owner}/{repo}/secret-scanning/alerts\"],\n listLocationsForAlert: [\n \"GET /repos/{owner}/{repo}/secret-scanning/alerts/{alert_number}/locations\"\n ],\n updateAlert: [\n \"PATCH /repos/{owner}/{repo}/secret-scanning/alerts/{alert_number}\"\n ]\n },\n securityAdvisories: {\n createFork: [\n \"POST /repos/{owner}/{repo}/security-advisories/{ghsa_id}/forks\"\n ],\n createPrivateVulnerabilityReport: [\n \"POST /repos/{owner}/{repo}/security-advisories/reports\"\n ],\n createRepositoryAdvisory: [\n \"POST /repos/{owner}/{repo}/security-advisories\"\n ],\n createRepositoryAdvisoryCveRequest: [\n \"POST /repos/{owner}/{repo}/security-advisories/{ghsa_id}/cve\"\n ],\n getGlobalAdvisory: [\"GET /advisories/{ghsa_id}\"],\n getRepositoryAdvisory: [\n \"GET /repos/{owner}/{repo}/security-advisories/{ghsa_id}\"\n ],\n listGlobalAdvisories: [\"GET /advisories\"],\n listOrgRepositoryAdvisories: [\"GET /orgs/{org}/security-advisories\"],\n listRepositoryAdvisories: [\"GET /repos/{owner}/{repo}/security-advisories\"],\n updateRepositoryAdvisory: [\n \"PATCH /repos/{owner}/{repo}/security-advisories/{ghsa_id}\"\n ]\n },\n teams: {\n addOrUpdateMembershipForUserInOrg: [\n \"PUT /orgs/{org}/teams/{team_slug}/memberships/{username}\"\n ],\n addOrUpdateProjectPermissionsInOrg: [\n \"PUT /orgs/{org}/teams/{team_slug}/projects/{project_id}\"\n ],\n addOrUpdateRepoPermissionsInOrg: [\n \"PUT /orgs/{org}/teams/{team_slug}/repos/{owner}/{repo}\"\n ],\n checkPermissionsForProjectInOrg: [\n \"GET /orgs/{org}/teams/{team_slug}/projects/{project_id}\"\n ],\n checkPermissionsForRepoInOrg: [\n \"GET /orgs/{org}/teams/{team_slug}/repos/{owner}/{repo}\"\n ],\n create: [\"POST /orgs/{org}/teams\"],\n createDiscussionCommentInOrg: [\n \"POST /orgs/{org}/teams/{team_slug}/discussions/{discussion_number}/comments\"\n ],\n createDiscussionInOrg: [\"POST /orgs/{org}/teams/{team_slug}/discussions\"],\n deleteDiscussionCommentInOrg: [\n \"DELETE /orgs/{org}/teams/{team_slug}/discussions/{discussion_number}/comments/{comment_number}\"\n ],\n deleteDiscussionInOrg: [\n \"DELETE /orgs/{org}/teams/{team_slug}/discussions/{discussion_number}\"\n ],\n deleteInOrg: [\"DELETE /orgs/{org}/teams/{team_slug}\"],\n getByName: [\"GET /orgs/{org}/teams/{team_slug}\"],\n getDiscussionCommentInOrg: [\n \"GET /orgs/{org}/teams/{team_slug}/discussions/{discussion_number}/comments/{comment_number}\"\n ],\n getDiscussionInOrg: [\n \"GET /orgs/{org}/teams/{team_slug}/discussions/{discussion_number}\"\n ],\n getMembershipForUserInOrg: [\n \"GET /orgs/{org}/teams/{team_slug}/memberships/{username}\"\n ],\n list: [\"GET /orgs/{org}/teams\"],\n listChildInOrg: [\"GET /orgs/{org}/teams/{team_slug}/teams\"],\n listDiscussionCommentsInOrg: [\n \"GET /orgs/{org}/teams/{team_slug}/discussions/{discussion_number}/comments\"\n ],\n listDiscussionsInOrg: [\"GET /orgs/{org}/teams/{team_slug}/discussions\"],\n listForAuthenticatedUser: [\"GET /user/teams\"],\n listMembersInOrg: [\"GET /orgs/{org}/teams/{team_slug}/members\"],\n listPendingInvitationsInOrg: [\n \"GET /orgs/{org}/teams/{team_slug}/invitations\"\n ],\n listProjectsInOrg: [\"GET /orgs/{org}/teams/{team_slug}/projects\"],\n listReposInOrg: [\"GET /orgs/{org}/teams/{team_slug}/repos\"],\n removeMembershipForUserInOrg: [\n \"DELETE /orgs/{org}/teams/{team_slug}/memberships/{username}\"\n ],\n removeProjectInOrg: [\n \"DELETE /orgs/{org}/teams/{team_slug}/projects/{project_id}\"\n ],\n removeRepoInOrg: [\n \"DELETE /orgs/{org}/teams/{team_slug}/repos/{owner}/{repo}\"\n ],\n updateDiscussionCommentInOrg: [\n \"PATCH /orgs/{org}/teams/{team_slug}/discussions/{discussion_number}/comments/{comment_number}\"\n ],\n updateDiscussionInOrg: [\n \"PATCH /orgs/{org}/teams/{team_slug}/discussions/{discussion_number}\"\n ],\n updateInOrg: [\"PATCH /orgs/{org}/teams/{team_slug}\"]\n },\n users: {\n addEmailForAuthenticated: [\n \"POST /user/emails\",\n {},\n { renamed: [\"users\", \"addEmailForAuthenticatedUser\"] }\n ],\n addEmailForAuthenticatedUser: [\"POST /user/emails\"],\n addSocialAccountForAuthenticatedUser: [\"POST /user/social_accounts\"],\n block: [\"PUT /user/blocks/{username}\"],\n checkBlocked: [\"GET /user/blocks/{username}\"],\n checkFollowingForUser: [\"GET /users/{username}/following/{target_user}\"],\n checkPersonIsFollowedByAuthenticated: [\"GET /user/following/{username}\"],\n createGpgKeyForAuthenticated: [\n \"POST /user/gpg_keys\",\n {},\n { renamed: [\"users\", \"createGpgKeyForAuthenticatedUser\"] }\n ],\n createGpgKeyForAuthenticatedUser: [\"POST /user/gpg_keys\"],\n createPublicSshKeyForAuthenticated: [\n \"POST /user/keys\",\n {},\n { renamed: [\"users\", \"createPublicSshKeyForAuthenticatedUser\"] }\n ],\n createPublicSshKeyForAuthenticatedUser: [\"POST /user/keys\"],\n createSshSigningKeyForAuthenticatedUser: [\"POST /user/ssh_signing_keys\"],\n deleteEmailForAuthenticated: [\n \"DELETE /user/emails\",\n {},\n { renamed: [\"users\", \"deleteEmailForAuthenticatedUser\"] }\n ],\n deleteEmailForAuthenticatedUser: [\"DELETE /user/emails\"],\n deleteGpgKeyForAuthenticated: [\n \"DELETE /user/gpg_keys/{gpg_key_id}\",\n {},\n { renamed: [\"users\", \"deleteGpgKeyForAuthenticatedUser\"] }\n ],\n deleteGpgKeyForAuthenticatedUser: [\"DELETE /user/gpg_keys/{gpg_key_id}\"],\n deletePublicSshKeyForAuthenticated: [\n \"DELETE /user/keys/{key_id}\",\n {},\n { renamed: [\"users\", \"deletePublicSshKeyForAuthenticatedUser\"] }\n ],\n deletePublicSshKeyForAuthenticatedUser: [\"DELETE /user/keys/{key_id}\"],\n deleteSocialAccountForAuthenticatedUser: [\"DELETE /user/social_accounts\"],\n deleteSshSigningKeyForAuthenticatedUser: [\n \"DELETE /user/ssh_signing_keys/{ssh_signing_key_id}\"\n ],\n follow: [\"PUT /user/following/{username}\"],\n getAuthenticated: [\"GET /user\"],\n getByUsername: [\"GET /users/{username}\"],\n getContextForUser: [\"GET /users/{username}/hovercard\"],\n getGpgKeyForAuthenticated: [\n \"GET /user/gpg_keys/{gpg_key_id}\",\n {},\n { renamed: [\"users\", \"getGpgKeyForAuthenticatedUser\"] }\n ],\n getGpgKeyForAuthenticatedUser: [\"GET /user/gpg_keys/{gpg_key_id}\"],\n getPublicSshKeyForAuthenticated: [\n \"GET /user/keys/{key_id}\",\n {},\n { renamed: [\"users\", \"getPublicSshKeyForAuthenticatedUser\"] }\n ],\n getPublicSshKeyForAuthenticatedUser: [\"GET /user/keys/{key_id}\"],\n getSshSigningKeyForAuthenticatedUser: [\n \"GET /user/ssh_signing_keys/{ssh_signing_key_id}\"\n ],\n list: [\"GET /users\"],\n listBlockedByAuthenticated: [\n \"GET /user/blocks\",\n {},\n { renamed: [\"users\", \"listBlockedByAuthenticatedUser\"] }\n ],\n listBlockedByAuthenticatedUser: [\"GET /user/blocks\"],\n listEmailsForAuthenticated: [\n \"GET /user/emails\",\n {},\n { renamed: [\"users\", \"listEmailsForAuthenticatedUser\"] }\n ],\n listEmailsForAuthenticatedUser: [\"GET /user/emails\"],\n listFollowedByAuthenticated: [\n \"GET /user/following\",\n {},\n { renamed: [\"users\", \"listFollowedByAuthenticatedUser\"] }\n ],\n listFollowedByAuthenticatedUser: [\"GET /user/following\"],\n listFollowersForAuthenticatedUser: [\"GET /user/followers\"],\n listFollowersForUser: [\"GET /users/{username}/followers\"],\n listFollowingForUser: [\"GET /users/{username}/following\"],\n listGpgKeysForAuthenticated: [\n \"GET /user/gpg_keys\",\n {},\n { renamed: [\"users\", \"listGpgKeysForAuthenticatedUser\"] }\n ],\n listGpgKeysForAuthenticatedUser: [\"GET /user/gpg_keys\"],\n listGpgKeysForUser: [\"GET /users/{username}/gpg_keys\"],\n listPublicEmailsForAuthenticated: [\n \"GET /user/public_emails\",\n {},\n { renamed: [\"users\", \"listPublicEmailsForAuthenticatedUser\"] }\n ],\n listPublicEmailsForAuthenticatedUser: [\"GET /user/public_emails\"],\n listPublicKeysForUser: [\"GET /users/{username}/keys\"],\n listPublicSshKeysForAuthenticated: [\n \"GET /user/keys\",\n {},\n { renamed: [\"users\", \"listPublicSshKeysForAuthenticatedUser\"] }\n ],\n listPublicSshKeysForAuthenticatedUser: [\"GET /user/keys\"],\n listSocialAccountsForAuthenticatedUser: [\"GET /user/social_accounts\"],\n listSocialAccountsForUser: [\"GET /users/{username}/social_accounts\"],\n listSshSigningKeysForAuthenticatedUser: [\"GET /user/ssh_signing_keys\"],\n listSshSigningKeysForUser: [\"GET /users/{username}/ssh_signing_keys\"],\n setPrimaryEmailVisibilityForAuthenticated: [\n \"PATCH /user/email/visibility\",\n {},\n { renamed: [\"users\", \"setPrimaryEmailVisibilityForAuthenticatedUser\"] }\n ],\n setPrimaryEmailVisibilityForAuthenticatedUser: [\n \"PATCH /user/email/visibility\"\n ],\n unblock: [\"DELETE /user/blocks/{username}\"],\n unfollow: [\"DELETE /user/following/{username}\"],\n updateAuthenticated: [\"PATCH /user\"]\n }\n};\nvar endpoints_default = Endpoints;\n\n// pkg/dist-src/endpoints-to-methods.js\nvar endpointMethodsMap = /* @__PURE__ */ new Map();\nfor (const [scope, endpoints] of Object.entries(endpoints_default)) {\n for (const [methodName, endpoint] of Object.entries(endpoints)) {\n const [route, defaults, decorations] = endpoint;\n const [method, url] = route.split(/ /);\n const endpointDefaults = Object.assign(\n {\n method,\n url\n },\n defaults\n );\n if (!endpointMethodsMap.has(scope)) {\n endpointMethodsMap.set(scope, /* @__PURE__ */ new Map());\n }\n endpointMethodsMap.get(scope).set(methodName, {\n scope,\n methodName,\n endpointDefaults,\n decorations\n });\n }\n}\nvar handler = {\n has({ scope }, methodName) {\n return endpointMethodsMap.get(scope).has(methodName);\n },\n getOwnPropertyDescriptor(target, methodName) {\n return {\n value: this.get(target, methodName),\n // ensures method is in the cache\n configurable: true,\n writable: true,\n enumerable: true\n };\n },\n defineProperty(target, methodName, descriptor) {\n Object.defineProperty(target.cache, methodName, descriptor);\n return true;\n },\n deleteProperty(target, methodName) {\n delete target.cache[methodName];\n return true;\n },\n ownKeys({ scope }) {\n return [...endpointMethodsMap.get(scope).keys()];\n },\n set(target, methodName, value) {\n return target.cache[methodName] = value;\n },\n get({ octokit, scope, cache }, methodName) {\n if (cache[methodName]) {\n return cache[methodName];\n }\n const method = endpointMethodsMap.get(scope).get(methodName);\n if (!method) {\n return void 0;\n }\n const { endpointDefaults, decorations } = method;\n if (decorations) {\n cache[methodName] = decorate(\n octokit,\n scope,\n methodName,\n endpointDefaults,\n decorations\n );\n } else {\n cache[methodName] = octokit.request.defaults(endpointDefaults);\n }\n return cache[methodName];\n }\n};\nfunction endpointsToMethods(octokit) {\n const newMethods = {};\n for (const scope of endpointMethodsMap.keys()) {\n newMethods[scope] = new Proxy({ octokit, scope, cache: {} }, handler);\n }\n return newMethods;\n}\nfunction decorate(octokit, scope, methodName, defaults, decorations) {\n const requestWithDefaults = octokit.request.defaults(defaults);\n function withDecorations(...args) {\n let options = requestWithDefaults.endpoint.merge(...args);\n if (decorations.mapToData) {\n options = Object.assign({}, options, {\n data: options[decorations.mapToData],\n [decorations.mapToData]: void 0\n });\n return requestWithDefaults(options);\n }\n if (decorations.renamed) {\n const [newScope, newMethodName] = decorations.renamed;\n octokit.log.warn(\n `octokit.${scope}.${methodName}() has been renamed to octokit.${newScope}.${newMethodName}()`\n );\n }\n if (decorations.deprecated) {\n octokit.log.warn(decorations.deprecated);\n }\n if (decorations.renamedParameters) {\n const options2 = requestWithDefaults.endpoint.merge(...args);\n for (const [name, alias] of Object.entries(\n decorations.renamedParameters\n )) {\n if (name in options2) {\n octokit.log.warn(\n `\"${name}\" parameter is deprecated for \"octokit.${scope}.${methodName}()\". Use \"${alias}\" instead`\n );\n if (!(alias in options2)) {\n options2[alias] = options2[name];\n }\n delete options2[name];\n }\n }\n return requestWithDefaults(options2);\n }\n return requestWithDefaults(...args);\n }\n return Object.assign(withDecorations, requestWithDefaults);\n}\n\n// pkg/dist-src/index.js\nfunction restEndpointMethods(octokit) {\n const api = endpointsToMethods(octokit);\n return {\n rest: api\n };\n}\nrestEndpointMethods.VERSION = VERSION;\nfunction legacyRestEndpointMethods(octokit) {\n const api = endpointsToMethods(octokit);\n return {\n ...api,\n rest: api\n };\n}\nlegacyRestEndpointMethods.VERSION = VERSION;\n// Annotate the CommonJS export names for ESM import in node:\n0 && (module.exports = {\n legacyRestEndpointMethods,\n restEndpointMethods\n});\n","\"use strict\";\nvar __create = Object.create;\nvar __defProp = Object.defineProperty;\nvar __getOwnPropDesc = Object.getOwnPropertyDescriptor;\nvar __getOwnPropNames = Object.getOwnPropertyNames;\nvar __getProtoOf = Object.getPrototypeOf;\nvar __hasOwnProp = Object.prototype.hasOwnProperty;\nvar __export = (target, all) => {\n for (var name in all)\n __defProp(target, name, { get: all[name], enumerable: true });\n};\nvar __copyProps = (to, from, except, desc) => {\n if (from && typeof from === \"object\" || typeof from === \"function\") {\n for (let key of __getOwnPropNames(from))\n if (!__hasOwnProp.call(to, key) && key !== except)\n __defProp(to, key, { get: () => from[key], enumerable: !(desc = __getOwnPropDesc(from, key)) || desc.enumerable });\n }\n return to;\n};\nvar __toESM = (mod, isNodeMode, target) => (target = mod != null ? __create(__getProtoOf(mod)) : {}, __copyProps(\n // If the importer is in node compatibility mode or this is not an ESM\n // file that has been converted to a CommonJS file using a Babel-\n // compatible transform (i.e. \"__esModule\" has not been set), then set\n // \"default\" to the CommonJS \"module.exports\" for node compatibility.\n isNodeMode || !mod || !mod.__esModule ? __defProp(target, \"default\", { value: mod, enumerable: true }) : target,\n mod\n));\nvar __toCommonJS = (mod) => __copyProps(__defProp({}, \"__esModule\", { value: true }), mod);\n\n// pkg/dist-src/index.js\nvar dist_src_exports = {};\n__export(dist_src_exports, {\n RequestError: () => RequestError\n});\nmodule.exports = __toCommonJS(dist_src_exports);\nvar import_deprecation = require(\"deprecation\");\nvar import_once = __toESM(require(\"once\"));\nvar logOnceCode = (0, import_once.default)((deprecation) => console.warn(deprecation));\nvar logOnceHeaders = (0, import_once.default)((deprecation) => console.warn(deprecation));\nvar RequestError = class extends Error {\n constructor(message, statusCode, options) {\n super(message);\n if (Error.captureStackTrace) {\n Error.captureStackTrace(this, this.constructor);\n }\n this.name = \"HttpError\";\n this.status = statusCode;\n let headers;\n if (\"headers\" in options && typeof options.headers !== \"undefined\") {\n headers = options.headers;\n }\n if (\"response\" in options) {\n this.response = options.response;\n headers = options.response.headers;\n }\n const requestCopy = Object.assign({}, options.request);\n if (options.request.headers.authorization) {\n requestCopy.headers = Object.assign({}, options.request.headers, {\n authorization: options.request.headers.authorization.replace(\n / .*$/,\n \" [REDACTED]\"\n )\n });\n }\n requestCopy.url = requestCopy.url.replace(/\\bclient_secret=\\w+/g, \"client_secret=[REDACTED]\").replace(/\\baccess_token=\\w+/g, \"access_token=[REDACTED]\");\n this.request = requestCopy;\n Object.defineProperty(this, \"code\", {\n get() {\n logOnceCode(\n new import_deprecation.Deprecation(\n \"[@octokit/request-error] `error.code` is deprecated, use `error.status`.\"\n )\n );\n return statusCode;\n }\n });\n Object.defineProperty(this, \"headers\", {\n get() {\n logOnceHeaders(\n new import_deprecation.Deprecation(\n \"[@octokit/request-error] `error.headers` is deprecated, use `error.response.headers`.\"\n )\n );\n return headers || {};\n }\n });\n }\n};\n// Annotate the CommonJS export names for ESM import in node:\n0 && (module.exports = {\n RequestError\n});\n","\"use strict\";\nvar __defProp = Object.defineProperty;\nvar __getOwnPropDesc = Object.getOwnPropertyDescriptor;\nvar __getOwnPropNames = Object.getOwnPropertyNames;\nvar __hasOwnProp = Object.prototype.hasOwnProperty;\nvar __export = (target, all) => {\n for (var name in all)\n __defProp(target, name, { get: all[name], enumerable: true });\n};\nvar __copyProps = (to, from, except, desc) => {\n if (from && typeof from === \"object\" || typeof from === \"function\") {\n for (let key of __getOwnPropNames(from))\n if (!__hasOwnProp.call(to, key) && key !== except)\n __defProp(to, key, { get: () => from[key], enumerable: !(desc = __getOwnPropDesc(from, key)) || desc.enumerable });\n }\n return to;\n};\nvar __toCommonJS = (mod) => __copyProps(__defProp({}, \"__esModule\", { value: true }), mod);\n\n// pkg/dist-src/index.js\nvar dist_src_exports = {};\n__export(dist_src_exports, {\n request: () => request\n});\nmodule.exports = __toCommonJS(dist_src_exports);\nvar import_endpoint = require(\"@octokit/endpoint\");\nvar import_universal_user_agent = require(\"universal-user-agent\");\n\n// pkg/dist-src/version.js\nvar VERSION = \"8.2.0\";\n\n// pkg/dist-src/is-plain-object.js\nfunction isPlainObject(value) {\n if (typeof value !== \"object\" || value === null)\n return false;\n if (Object.prototype.toString.call(value) !== \"[object Object]\")\n return false;\n const proto = Object.getPrototypeOf(value);\n if (proto === null)\n return true;\n const Ctor = Object.prototype.hasOwnProperty.call(proto, \"constructor\") && proto.constructor;\n return typeof Ctor === \"function\" && Ctor instanceof Ctor && Function.prototype.call(Ctor) === Function.prototype.call(value);\n}\n\n// pkg/dist-src/fetch-wrapper.js\nvar import_request_error = require(\"@octokit/request-error\");\n\n// pkg/dist-src/get-buffer-response.js\nfunction getBufferResponse(response) {\n return response.arrayBuffer();\n}\n\n// pkg/dist-src/fetch-wrapper.js\nfunction fetchWrapper(requestOptions) {\n var _a, _b, _c;\n const log = requestOptions.request && requestOptions.request.log ? requestOptions.request.log : console;\n const parseSuccessResponseBody = ((_a = requestOptions.request) == null ? void 0 : _a.parseSuccessResponseBody) !== false;\n if (isPlainObject(requestOptions.body) || Array.isArray(requestOptions.body)) {\n requestOptions.body = JSON.stringify(requestOptions.body);\n }\n let headers = {};\n let status;\n let url;\n let { fetch } = globalThis;\n if ((_b = requestOptions.request) == null ? void 0 : _b.fetch) {\n fetch = requestOptions.request.fetch;\n }\n if (!fetch) {\n throw new Error(\n \"fetch is not set. Please pass a fetch implementation as new Octokit({ request: { fetch }}). Learn more at https://github.com/octokit/octokit.js/#fetch-missing\"\n );\n }\n return fetch(requestOptions.url, {\n method: requestOptions.method,\n body: requestOptions.body,\n headers: requestOptions.headers,\n signal: (_c = requestOptions.request) == null ? void 0 : _c.signal,\n // duplex must be set if request.body is ReadableStream or Async Iterables.\n // See https://fetch.spec.whatwg.org/#dom-requestinit-duplex.\n ...requestOptions.body && { duplex: \"half\" }\n }).then(async (response) => {\n url = response.url;\n status = response.status;\n for (const keyAndValue of response.headers) {\n headers[keyAndValue[0]] = keyAndValue[1];\n }\n if (\"deprecation\" in headers) {\n const matches = headers.link && headers.link.match(/<([^>]+)>; rel=\"deprecation\"/);\n const deprecationLink = matches && matches.pop();\n log.warn(\n `[@octokit/request] \"${requestOptions.method} ${requestOptions.url}\" is deprecated. It is scheduled to be removed on ${headers.sunset}${deprecationLink ? `. See ${deprecationLink}` : \"\"}`\n );\n }\n if (status === 204 || status === 205) {\n return;\n }\n if (requestOptions.method === \"HEAD\") {\n if (status < 400) {\n return;\n }\n throw new import_request_error.RequestError(response.statusText, status, {\n response: {\n url,\n status,\n headers,\n data: void 0\n },\n request: requestOptions\n });\n }\n if (status === 304) {\n throw new import_request_error.RequestError(\"Not modified\", status, {\n response: {\n url,\n status,\n headers,\n data: await getResponseData(response)\n },\n request: requestOptions\n });\n }\n if (status >= 400) {\n const data = await getResponseData(response);\n const error = new import_request_error.RequestError(toErrorMessage(data), status, {\n response: {\n url,\n status,\n headers,\n data\n },\n request: requestOptions\n });\n throw error;\n }\n return parseSuccessResponseBody ? await getResponseData(response) : response.body;\n }).then((data) => {\n return {\n status,\n url,\n headers,\n data\n };\n }).catch((error) => {\n if (error instanceof import_request_error.RequestError)\n throw error;\n else if (error.name === \"AbortError\")\n throw error;\n let message = error.message;\n if (error.name === \"TypeError\" && \"cause\" in error) {\n if (error.cause instanceof Error) {\n message = error.cause.message;\n } else if (typeof error.cause === \"string\") {\n message = error.cause;\n }\n }\n throw new import_request_error.RequestError(message, 500, {\n request: requestOptions\n });\n });\n}\nasync function getResponseData(response) {\n const contentType = response.headers.get(\"content-type\");\n if (/application\\/json/.test(contentType)) {\n return response.json().catch(() => response.text()).catch(() => \"\");\n }\n if (!contentType || /^text\\/|charset=utf-8$/.test(contentType)) {\n return response.text();\n }\n return getBufferResponse(response);\n}\nfunction toErrorMessage(data) {\n if (typeof data === \"string\")\n return data;\n let suffix;\n if (\"documentation_url\" in data) {\n suffix = ` - ${data.documentation_url}`;\n } else {\n suffix = \"\";\n }\n if (\"message\" in data) {\n if (Array.isArray(data.errors)) {\n return `${data.message}: ${data.errors.map(JSON.stringify).join(\", \")}${suffix}`;\n }\n return `${data.message}${suffix}`;\n }\n return `Unknown error: ${JSON.stringify(data)}`;\n}\n\n// pkg/dist-src/with-defaults.js\nfunction withDefaults(oldEndpoint, newDefaults) {\n const endpoint2 = oldEndpoint.defaults(newDefaults);\n const newApi = function(route, parameters) {\n const endpointOptions = endpoint2.merge(route, parameters);\n if (!endpointOptions.request || !endpointOptions.request.hook) {\n return fetchWrapper(endpoint2.parse(endpointOptions));\n }\n const request2 = (route2, parameters2) => {\n return fetchWrapper(\n endpoint2.parse(endpoint2.merge(route2, parameters2))\n );\n };\n Object.assign(request2, {\n endpoint: endpoint2,\n defaults: withDefaults.bind(null, endpoint2)\n });\n return endpointOptions.request.hook(request2, endpointOptions);\n };\n return Object.assign(newApi, {\n endpoint: endpoint2,\n defaults: withDefaults.bind(null, endpoint2)\n });\n}\n\n// pkg/dist-src/index.js\nvar request = withDefaults(import_endpoint.endpoint, {\n headers: {\n \"user-agent\": `octokit-request.js/${VERSION} ${(0, import_universal_user_agent.getUserAgent)()}`\n }\n});\n// Annotate the CommonJS export names for ESM import in node:\n0 && (module.exports = {\n request\n});\n","var register = require(\"./lib/register\");\nvar addHook = require(\"./lib/add\");\nvar removeHook = require(\"./lib/remove\");\n\n// bind with array of arguments: https://stackoverflow.com/a/21792913\nvar bind = Function.bind;\nvar bindable = bind.bind(bind);\n\nfunction bindApi(hook, state, name) {\n var removeHookRef = bindable(removeHook, null).apply(\n null,\n name ? [state, name] : [state]\n );\n hook.api = { remove: removeHookRef };\n hook.remove = removeHookRef;\n [\"before\", \"error\", \"after\", \"wrap\"].forEach(function (kind) {\n var args = name ? [state, kind, name] : [state, kind];\n hook[kind] = hook.api[kind] = bindable(addHook, null).apply(null, args);\n });\n}\n\nfunction HookSingular() {\n var singularHookName = \"h\";\n var singularHookState = {\n registry: {},\n };\n var singularHook = register.bind(null, singularHookState, singularHookName);\n bindApi(singularHook, singularHookState, singularHookName);\n return singularHook;\n}\n\nfunction HookCollection() {\n var state = {\n registry: {},\n };\n\n var hook = register.bind(null, state);\n bindApi(hook, state);\n\n return hook;\n}\n\nvar collectionHookDeprecationMessageDisplayed = false;\nfunction Hook() {\n if (!collectionHookDeprecationMessageDisplayed) {\n console.warn(\n '[before-after-hook]: \"Hook()\" repurposing warning, use \"Hook.Collection()\". Read more: https://git.io/upgrade-before-after-hook-to-1.4'\n );\n collectionHookDeprecationMessageDisplayed = true;\n }\n return HookCollection();\n}\n\nHook.Singular = HookSingular.bind();\nHook.Collection = HookCollection.bind();\n\nmodule.exports = Hook;\n// expose constructors as a named property for TypeScript\nmodule.exports.Hook = Hook;\nmodule.exports.Singular = Hook.Singular;\nmodule.exports.Collection = Hook.Collection;\n","module.exports = addHook;\n\nfunction addHook(state, kind, name, hook) {\n var orig = hook;\n if (!state.registry[name]) {\n state.registry[name] = [];\n }\n\n if (kind === \"before\") {\n hook = function (method, options) {\n return Promise.resolve()\n .then(orig.bind(null, options))\n .then(method.bind(null, options));\n };\n }\n\n if (kind === \"after\") {\n hook = function (method, options) {\n var result;\n return Promise.resolve()\n .then(method.bind(null, options))\n .then(function (result_) {\n result = result_;\n return orig(result, options);\n })\n .then(function () {\n return result;\n });\n };\n }\n\n if (kind === \"error\") {\n hook = function (method, options) {\n return Promise.resolve()\n .then(method.bind(null, options))\n .catch(function (error) {\n return orig(error, options);\n });\n };\n }\n\n state.registry[name].push({\n hook: hook,\n orig: orig,\n });\n}\n","module.exports = register;\n\nfunction register(state, name, method, options) {\n if (typeof method !== \"function\") {\n throw new Error(\"method for before hook must be a function\");\n }\n\n if (!options) {\n options = {};\n }\n\n if (Array.isArray(name)) {\n return name.reverse().reduce(function (callback, name) {\n return register.bind(null, state, name, callback, options);\n }, method)();\n }\n\n return Promise.resolve().then(function () {\n if (!state.registry[name]) {\n return method(options);\n }\n\n return state.registry[name].reduce(function (method, registered) {\n return registered.hook.bind(null, method, options);\n }, method)();\n });\n}\n","module.exports = removeHook;\n\nfunction removeHook(state, name, method) {\n if (!state.registry[name]) {\n return;\n }\n\n var index = state.registry[name]\n .map(function (registered) {\n return registered.orig;\n })\n .indexOf(method);\n\n if (index === -1) {\n return;\n }\n\n state.registry[name].splice(index, 1);\n}\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nclass Deprecation extends Error {\n constructor(message) {\n super(message); // Maintains proper stack trace (only available on V8)\n\n /* istanbul ignore next */\n\n if (Error.captureStackTrace) {\n Error.captureStackTrace(this, this.constructor);\n }\n\n this.name = 'Deprecation';\n }\n\n}\n\nexports.Deprecation = Deprecation;\n","/* eslint indent: [\"warn\", 4] */\n\n\n// Private helper class\nclass SubRange {\n constructor(low, high) {\n this.low = low;\n this.high = high;\n this.length = 1 + high - low;\n }\n\n overlaps(range) {\n return range.low <= this.high && this.low <= range.high;\n }\n\n touches(range) {\n return range.low <= this.high + 1 && this.low - 1 <= range.high;\n }\n\n covers(range) {\n return this.low <= range.low && range.high <= this.high;\n }\n\n isInside(range) {\n return range.low < this.low && this.high < range.high;\n }\n\n isBefore(range) {\n return this.high < range.low;\n }\n\n // Returns inclusive combination of SubRanges as a SubRange.\n add(range) {\n return new SubRange(\n Math.min(this.low, range.low),\n Math.max(this.high, range.high)\n );\n }\n\n // Returns subtraction of SubRanges as an array of SubRanges.\n // (There's a case where subtraction divides it in 2)\n subtract(range) {\n if (range.covers(this)) {\n return [];\n } else if (range.isInside(this)) {\n return [\n new SubRange(this.low, range.low - 1),\n new SubRange(range.high + 1, this.high)\n ];\n } else if (range.low <= this.low) {\n return [new SubRange(range.high + 1, this.high)];\n } else {\n return [new SubRange(this.low, range.low - 1)];\n }\n }\n\n toString() {\n return this.low == this.high ?\n this.low.toString() : this.low + '-' + this.high;\n }\n}\n\nclass DRange {\n constructor(a, b) {\n this.ranges = [];\n this.length = 0;\n if (a != null) this.add(a, b);\n }\n\n _update_length() {\n this.length = this.ranges.reduce((previous, range) => {\n return previous + range.length;\n }, 0);\n }\n\n add(a, b) {\n const _add = (subrange) => {\n let i = 0;\n while (i < this.ranges.length && !subrange.touches(this.ranges[i]) &&\n this.ranges[i].isBefore(subrange)) {\n i++;\n }\n const newRanges = this.ranges.slice(0, i);\n while (i < this.ranges.length && subrange.touches(this.ranges[i])) {\n subrange = subrange.add(this.ranges[i]);\n i++;\n }\n newRanges.push(subrange);\n this.ranges = newRanges.concat(this.ranges.slice(i));\n this._update_length();\n };\n\n if (a instanceof DRange) {\n a.ranges.forEach(_add);\n } else {\n if (b == null) b = a;\n _add(new SubRange(a, b));\n }\n return this;\n }\n\n subtract(a, b) {\n const _subtract = (subrange) => {\n let i = 0;\n while (i < this.ranges.length && !subrange.overlaps(this.ranges[i])) {\n i++;\n }\n let newRanges = this.ranges.slice(0, i);\n while (i < this.ranges.length && subrange.overlaps(this.ranges[i])) {\n newRanges = newRanges.concat(this.ranges[i].subtract(subrange));\n i++;\n }\n this.ranges = newRanges.concat(this.ranges.slice(i));\n this._update_length();\n };\n\n if (a instanceof DRange) {\n a.ranges.forEach(_subtract);\n } else {\n if (b == null) b = a;\n _subtract(new SubRange(a, b));\n }\n return this;\n }\n\n intersect(a, b) {\n const newRanges = [];\n const _intersect = (subrange) => {\n let i = 0;\n while (i < this.ranges.length && !subrange.overlaps(this.ranges[i])) {\n i++;\n }\n while (i < this.ranges.length && subrange.overlaps(this.ranges[i])) {\n let low = Math.max(this.ranges[i].low, subrange.low);\n let high = Math.min(this.ranges[i].high, subrange.high);\n newRanges.push(new SubRange(low, high));\n i++;\n }\n };\n\n if (a instanceof DRange) {\n a.ranges.forEach(_intersect);\n } else {\n if (b == null) b = a;\n _intersect(new SubRange(a, b));\n }\n this.ranges = newRanges;\n this._update_length();\n return this;\n }\n\n index(index) {\n let i = 0;\n while (i < this.ranges.length && this.ranges[i].length <= index) {\n index -= this.ranges[i].length;\n i++;\n }\n return this.ranges[i].low + index;\n }\n\n toString() {\n return '[ ' + this.ranges.join(', ') + ' ]';\n }\n\n clone() {\n return new DRange(this);\n }\n\n numbers() {\n return this.ranges.reduce((result, subrange) => {\n let i = subrange.low;\n while (i <= subrange.high) {\n result.push(i);\n i++;\n }\n return result;\n }, []);\n }\n\n subranges() {\n return this.ranges.map((subrange) => ({\n low: subrange.low,\n high: subrange.high,\n length: 1 + subrange.high - subrange.low\n }));\n }\n}\n\nmodule.exports = DRange;\n","var wrappy = require('wrappy')\nmodule.exports = wrappy(once)\nmodule.exports.strict = wrappy(onceStrict)\n\nonce.proto = once(function () {\n Object.defineProperty(Function.prototype, 'once', {\n value: function () {\n return once(this)\n },\n configurable: true\n })\n\n Object.defineProperty(Function.prototype, 'onceStrict', {\n value: function () {\n return onceStrict(this)\n },\n configurable: true\n })\n})\n\nfunction once (fn) {\n var f = function () {\n if (f.called) return f.value\n f.called = true\n return f.value = fn.apply(this, arguments)\n }\n f.called = false\n return f\n}\n\nfunction onceStrict (fn) {\n var f = function () {\n if (f.called)\n throw new Error(f.onceError)\n f.called = true\n return f.value = fn.apply(this, arguments)\n }\n var name = fn.name || 'Function wrapped with `once`'\n f.onceError = name + \" shouldn't be called more than once\"\n f.called = false\n return f\n}\n","\"use strict\";\n\nexports.__esModule = true;\nexports[\"default\"] = parseLCOV;\n\nvar _line = require(\"./line\");\n\nvar _record = require(\"./record\");\n\nexports.LCOVRecord = _record.LCOVRecord;\nexports.FunctionsDetails = _record.FunctionsDetails;\nexports.BranchesDetails = _record.BranchesDetails;\nexports.LinesDetails = _record.LinesDetails;\n\nvar _transform = require(\"./transform\");\n\nfunction _extends() { _extends = Object.assign || function (target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i]; for (var key in source) { if (Object.prototype.hasOwnProperty.call(source, key)) { target[key] = source[key]; } } } return target; }; return _extends.apply(this, arguments); }\n\nfunction parseLCOV(string) {\n if (string === void 0) {\n string = \"\";\n }\n\n var lines = string.split(\"\\n\");\n var record = (0, _record.newRecord)();\n return lines.reduce(function (retval, line) {\n if ((0, _line.isEnd)(line)) {\n retval.push(_extends({}, record));\n record = (0, _record.newRecord)();\n } else {\n var _parseLine = (0, _line.parseLine)(line),\n type = _parseLine.type,\n data = _parseLine.data;\n\n (0, _transform.transform)(record, type, data);\n }\n\n return retval;\n }, []);\n}","\"use strict\";\n\nexports.__esModule = true;\nexports.isLineType = isLineType;\nexports.isEnd = isEnd;\nexports.parseLine = parseLine;\nvar linesTypes = [\"TN\", \"SF\", \"FN\", \"FNDA\", \"FNF\", \"FNH\", \"BRDA\", \"BRF\", \"BRH\", \"DA\", \"LF\", \"LH\"];\n\nfunction isLineType(string) {\n return linesTypes.includes(string);\n}\n\nfunction isEnd(string) {\n return string === \"end_of_record\";\n}\n\nfunction parseLine(line) {\n var _line$split = line.split(\":\"),\n type = _line$split[0],\n data = _line$split[1];\n\n return {\n type: isLineType(type) ? type : undefined,\n data: (data != null ? data : \"\").split(\",\")\n };\n}","\"use strict\";\n\nexports.__esModule = true;\nexports.newRecord = newRecord;\n\nfunction newRecord() {\n return {\n title: \"\",\n file: \"\",\n functions: {\n found: 0,\n hit: 0,\n details: []\n },\n branches: {\n found: 0,\n hit: 0,\n details: []\n },\n lines: {\n found: 0,\n hit: 0,\n details: []\n }\n };\n}","\"use strict\";\n\nexports.__esModule = true;\nexports.transform = transform;\nvar transformers = {\n TN: function TN(record, data) {\n record.title = data[0];\n },\n SF: function SF(record, data) {\n record.file = data[0];\n },\n // Functions\n FNF: function FNF(record, data) {\n record.functions.found = parseInt(data[0]);\n },\n FNH: function FNH(record, data) {\n record.functions.hit = parseInt(data[0]);\n },\n FN: function FN(record, data) {\n var line = data[0],\n name = data[1];\n record.functions.details.push({\n name: name,\n line: parseInt(line)\n });\n },\n FNDA: function FNDA(record, data) {\n var hit = data[0],\n name = data[1];\n record.functions.details.some(function (item) {\n if (item.name === name && item.hit === undefined) {\n item.hit = parseInt(hit);\n return true;\n } else {\n return undefined;\n }\n });\n },\n // Branches\n BRF: function BRF(record, data) {\n record.branches.found = parseInt(data[0]);\n },\n BRH: function BRH(record, data) {\n record.branches.hit = parseInt(data[0]);\n },\n BRDA: function BRDA(record, data) {\n var line = data[0],\n block = data[1],\n branch = data[2],\n taken = data[3];\n record.branches.details.push({\n line: parseInt(line),\n block: parseInt(block),\n branch: parseInt(branch),\n taken: taken === \"-\" ? 0 : parseInt(taken)\n });\n },\n // Lines\n LF: function LF(record, data) {\n record.lines.found = parseInt(data[0]);\n },\n LH: function LH(record, data) {\n record.lines.hit = parseInt(data[0]);\n },\n DA: function DA(record, data) {\n var line = data[0],\n hit = data[1];\n record.lines.details.push({\n line: parseInt(line),\n hit: parseInt(hit)\n });\n }\n};\n\nfunction transform(record, lineType, data) {\n if (lineType) {\n transformers[lineType](record, data);\n }\n}","module.exports = require('./lib/tunnel');\n","'use strict';\n\nvar net = require('net');\nvar tls = require('tls');\nvar http = require('http');\nvar https = require('https');\nvar events = require('events');\nvar assert = require('assert');\nvar util = require('util');\n\n\nexports.httpOverHttp = httpOverHttp;\nexports.httpsOverHttp = httpsOverHttp;\nexports.httpOverHttps = httpOverHttps;\nexports.httpsOverHttps = httpsOverHttps;\n\n\nfunction httpOverHttp(options) {\n var agent = new TunnelingAgent(options);\n agent.request = http.request;\n return agent;\n}\n\nfunction httpsOverHttp(options) {\n var agent = new TunnelingAgent(options);\n agent.request = http.request;\n agent.createSocket = createSecureSocket;\n agent.defaultPort = 443;\n return agent;\n}\n\nfunction httpOverHttps(options) {\n var agent = new TunnelingAgent(options);\n agent.request = https.request;\n return agent;\n}\n\nfunction httpsOverHttps(options) {\n var agent = new TunnelingAgent(options);\n agent.request = https.request;\n agent.createSocket = createSecureSocket;\n agent.defaultPort = 443;\n return agent;\n}\n\n\nfunction TunnelingAgent(options) {\n var self = this;\n self.options = options || {};\n self.proxyOptions = self.options.proxy || {};\n self.maxSockets = self.options.maxSockets || http.Agent.defaultMaxSockets;\n self.requests = [];\n self.sockets = [];\n\n self.on('free', function onFree(socket, host, port, localAddress) {\n var options = toOptions(host, port, localAddress);\n for (var i = 0, len = self.requests.length; i < len; ++i) {\n var pending = self.requests[i];\n if (pending.host === options.host && pending.port === options.port) {\n // Detect the request to connect same origin server,\n // reuse the connection.\n self.requests.splice(i, 1);\n pending.request.onSocket(socket);\n return;\n }\n }\n socket.destroy();\n self.removeSocket(socket);\n });\n}\nutil.inherits(TunnelingAgent, events.EventEmitter);\n\nTunnelingAgent.prototype.addRequest = function addRequest(req, host, port, localAddress) {\n var self = this;\n var options = mergeOptions({request: req}, self.options, toOptions(host, port, localAddress));\n\n if (self.sockets.length >= this.maxSockets) {\n // We are over limit so we'll add it to the queue.\n self.requests.push(options);\n return;\n }\n\n // If we are under maxSockets create a new one.\n self.createSocket(options, function(socket) {\n socket.on('free', onFree);\n socket.on('close', onCloseOrRemove);\n socket.on('agentRemove', onCloseOrRemove);\n req.onSocket(socket);\n\n function onFree() {\n self.emit('free', socket, options);\n }\n\n function onCloseOrRemove(err) {\n self.removeSocket(socket);\n socket.removeListener('free', onFree);\n socket.removeListener('close', onCloseOrRemove);\n socket.removeListener('agentRemove', onCloseOrRemove);\n }\n });\n};\n\nTunnelingAgent.prototype.createSocket = function createSocket(options, cb) {\n var self = this;\n var placeholder = {};\n self.sockets.push(placeholder);\n\n var connectOptions = mergeOptions({}, self.proxyOptions, {\n method: 'CONNECT',\n path: options.host + ':' + options.port,\n agent: false,\n headers: {\n host: options.host + ':' + options.port\n }\n });\n if (options.localAddress) {\n connectOptions.localAddress = options.localAddress;\n }\n if (connectOptions.proxyAuth) {\n connectOptions.headers = connectOptions.headers || {};\n connectOptions.headers['Proxy-Authorization'] = 'Basic ' +\n new Buffer(connectOptions.proxyAuth).toString('base64');\n }\n\n debug('making CONNECT request');\n var connectReq = self.request(connectOptions);\n connectReq.useChunkedEncodingByDefault = false; // for v0.6\n connectReq.once('response', onResponse); // for v0.6\n connectReq.once('upgrade', onUpgrade); // for v0.6\n connectReq.once('connect', onConnect); // for v0.7 or later\n connectReq.once('error', onError);\n connectReq.end();\n\n function onResponse(res) {\n // Very hacky. This is necessary to avoid http-parser leaks.\n res.upgrade = true;\n }\n\n function onUpgrade(res, socket, head) {\n // Hacky.\n process.nextTick(function() {\n onConnect(res, socket, head);\n });\n }\n\n function onConnect(res, socket, head) {\n connectReq.removeAllListeners();\n socket.removeAllListeners();\n\n if (res.statusCode !== 200) {\n debug('tunneling socket could not be established, statusCode=%d',\n res.statusCode);\n socket.destroy();\n var error = new Error('tunneling socket could not be established, ' +\n 'statusCode=' + res.statusCode);\n error.code = 'ECONNRESET';\n options.request.emit('error', error);\n self.removeSocket(placeholder);\n return;\n }\n if (head.length > 0) {\n debug('got illegal response body from proxy');\n socket.destroy();\n var error = new Error('got illegal response body from proxy');\n error.code = 'ECONNRESET';\n options.request.emit('error', error);\n self.removeSocket(placeholder);\n return;\n }\n debug('tunneling connection has established');\n self.sockets[self.sockets.indexOf(placeholder)] = socket;\n return cb(socket);\n }\n\n function onError(cause) {\n connectReq.removeAllListeners();\n\n debug('tunneling socket could not be established, cause=%s\\n',\n cause.message, cause.stack);\n var error = new Error('tunneling socket could not be established, ' +\n 'cause=' + cause.message);\n error.code = 'ECONNRESET';\n options.request.emit('error', error);\n self.removeSocket(placeholder);\n }\n};\n\nTunnelingAgent.prototype.removeSocket = function removeSocket(socket) {\n var pos = this.sockets.indexOf(socket)\n if (pos === -1) {\n return;\n }\n this.sockets.splice(pos, 1);\n\n var pending = this.requests.shift();\n if (pending) {\n // If we have pending requests and a socket gets closed a new one\n // needs to be created to take over in the pool for the one that closed.\n this.createSocket(pending, function(socket) {\n pending.request.onSocket(socket);\n });\n }\n};\n\nfunction createSecureSocket(options, cb) {\n var self = this;\n TunnelingAgent.prototype.createSocket.call(self, options, function(socket) {\n var hostHeader = options.request.getHeader('host');\n var tlsOptions = mergeOptions({}, self.options, {\n socket: socket,\n servername: hostHeader ? hostHeader.replace(/:.*$/, '') : options.host\n });\n\n // 0 is dummy port for v0.6\n var secureSocket = tls.connect(0, tlsOptions);\n self.sockets[self.sockets.indexOf(socket)] = secureSocket;\n cb(secureSocket);\n });\n}\n\n\nfunction toOptions(host, port, localAddress) {\n if (typeof host === 'string') { // since v0.10\n return {\n host: host,\n port: port,\n localAddress: localAddress\n };\n }\n return host; // for v0.11 or later\n}\n\nfunction mergeOptions(target) {\n for (var i = 1, len = arguments.length; i < len; ++i) {\n var overrides = arguments[i];\n if (typeof overrides === 'object') {\n var keys = Object.keys(overrides);\n for (var j = 0, keyLen = keys.length; j < keyLen; ++j) {\n var k = keys[j];\n if (overrides[k] !== undefined) {\n target[k] = overrides[k];\n }\n }\n }\n }\n return target;\n}\n\n\nvar debug;\nif (process.env.NODE_DEBUG && /\\btunnel\\b/.test(process.env.NODE_DEBUG)) {\n debug = function() {\n var args = Array.prototype.slice.call(arguments);\n if (typeof args[0] === 'string') {\n args[0] = 'TUNNEL: ' + args[0];\n } else {\n args.unshift('TUNNEL:');\n }\n console.error.apply(console, args);\n }\n} else {\n debug = function() {};\n}\nexports.debug = debug; // for test\n","'use strict'\n\nconst Client = require('./lib/client')\nconst Dispatcher = require('./lib/dispatcher')\nconst errors = require('./lib/core/errors')\nconst Pool = require('./lib/pool')\nconst BalancedPool = require('./lib/balanced-pool')\nconst Agent = require('./lib/agent')\nconst util = require('./lib/core/util')\nconst { InvalidArgumentError } = errors\nconst api = require('./lib/api')\nconst buildConnector = require('./lib/core/connect')\nconst MockClient = require('./lib/mock/mock-client')\nconst MockAgent = require('./lib/mock/mock-agent')\nconst MockPool = require('./lib/mock/mock-pool')\nconst mockErrors = require('./lib/mock/mock-errors')\nconst ProxyAgent = require('./lib/proxy-agent')\nconst RetryHandler = require('./lib/handler/RetryHandler')\nconst { getGlobalDispatcher, setGlobalDispatcher } = require('./lib/global')\nconst DecoratorHandler = require('./lib/handler/DecoratorHandler')\nconst RedirectHandler = require('./lib/handler/RedirectHandler')\nconst createRedirectInterceptor = require('./lib/interceptor/redirectInterceptor')\n\nlet hasCrypto\ntry {\n require('crypto')\n hasCrypto = true\n} catch {\n hasCrypto = false\n}\n\nObject.assign(Dispatcher.prototype, api)\n\nmodule.exports.Dispatcher = Dispatcher\nmodule.exports.Client = Client\nmodule.exports.Pool = Pool\nmodule.exports.BalancedPool = BalancedPool\nmodule.exports.Agent = Agent\nmodule.exports.ProxyAgent = ProxyAgent\nmodule.exports.RetryHandler = RetryHandler\n\nmodule.exports.DecoratorHandler = DecoratorHandler\nmodule.exports.RedirectHandler = RedirectHandler\nmodule.exports.createRedirectInterceptor = createRedirectInterceptor\n\nmodule.exports.buildConnector = buildConnector\nmodule.exports.errors = errors\n\nfunction makeDispatcher (fn) {\n return (url, opts, handler) => {\n if (typeof opts === 'function') {\n handler = opts\n opts = null\n }\n\n if (!url || (typeof url !== 'string' && typeof url !== 'object' && !(url instanceof URL))) {\n throw new InvalidArgumentError('invalid url')\n }\n\n if (opts != null && typeof opts !== 'object') {\n throw new InvalidArgumentError('invalid opts')\n }\n\n if (opts && opts.path != null) {\n if (typeof opts.path !== 'string') {\n throw new InvalidArgumentError('invalid opts.path')\n }\n\n let path = opts.path\n if (!opts.path.startsWith('/')) {\n path = `/${path}`\n }\n\n url = new URL(util.parseOrigin(url).origin + path)\n } else {\n if (!opts) {\n opts = typeof url === 'object' ? url : {}\n }\n\n url = util.parseURL(url)\n }\n\n const { agent, dispatcher = getGlobalDispatcher() } = opts\n\n if (agent) {\n throw new InvalidArgumentError('unsupported opts.agent. Did you mean opts.client?')\n }\n\n return fn.call(dispatcher, {\n ...opts,\n origin: url.origin,\n path: url.search ? `${url.pathname}${url.search}` : url.pathname,\n method: opts.method || (opts.body ? 'PUT' : 'GET')\n }, handler)\n }\n}\n\nmodule.exports.setGlobalDispatcher = setGlobalDispatcher\nmodule.exports.getGlobalDispatcher = getGlobalDispatcher\n\nif (util.nodeMajor > 16 || (util.nodeMajor === 16 && util.nodeMinor >= 8)) {\n let fetchImpl = null\n module.exports.fetch = async function fetch (resource) {\n if (!fetchImpl) {\n fetchImpl = require('./lib/fetch').fetch\n }\n\n try {\n return await fetchImpl(...arguments)\n } catch (err) {\n if (typeof err === 'object') {\n Error.captureStackTrace(err, this)\n }\n\n throw err\n }\n }\n module.exports.Headers = require('./lib/fetch/headers').Headers\n module.exports.Response = require('./lib/fetch/response').Response\n module.exports.Request = require('./lib/fetch/request').Request\n module.exports.FormData = require('./lib/fetch/formdata').FormData\n module.exports.File = require('./lib/fetch/file').File\n module.exports.FileReader = require('./lib/fileapi/filereader').FileReader\n\n const { setGlobalOrigin, getGlobalOrigin } = require('./lib/fetch/global')\n\n module.exports.setGlobalOrigin = setGlobalOrigin\n module.exports.getGlobalOrigin = getGlobalOrigin\n\n const { CacheStorage } = require('./lib/cache/cachestorage')\n const { kConstruct } = require('./lib/cache/symbols')\n\n // Cache & CacheStorage are tightly coupled with fetch. Even if it may run\n // in an older version of Node, it doesn't have any use without fetch.\n module.exports.caches = new CacheStorage(kConstruct)\n}\n\nif (util.nodeMajor >= 16) {\n const { deleteCookie, getCookies, getSetCookies, setCookie } = require('./lib/cookies')\n\n module.exports.deleteCookie = deleteCookie\n module.exports.getCookies = getCookies\n module.exports.getSetCookies = getSetCookies\n module.exports.setCookie = setCookie\n\n const { parseMIMEType, serializeAMimeType } = require('./lib/fetch/dataURL')\n\n module.exports.parseMIMEType = parseMIMEType\n module.exports.serializeAMimeType = serializeAMimeType\n}\n\nif (util.nodeMajor >= 18 && hasCrypto) {\n const { WebSocket } = require('./lib/websocket/websocket')\n\n module.exports.WebSocket = WebSocket\n}\n\nmodule.exports.request = makeDispatcher(api.request)\nmodule.exports.stream = makeDispatcher(api.stream)\nmodule.exports.pipeline = makeDispatcher(api.pipeline)\nmodule.exports.connect = makeDispatcher(api.connect)\nmodule.exports.upgrade = makeDispatcher(api.upgrade)\n\nmodule.exports.MockClient = MockClient\nmodule.exports.MockPool = MockPool\nmodule.exports.MockAgent = MockAgent\nmodule.exports.mockErrors = mockErrors\n","'use strict'\n\nconst { InvalidArgumentError } = require('./core/errors')\nconst { kClients, kRunning, kClose, kDestroy, kDispatch, kInterceptors } = require('./core/symbols')\nconst DispatcherBase = require('./dispatcher-base')\nconst Pool = require('./pool')\nconst Client = require('./client')\nconst util = require('./core/util')\nconst createRedirectInterceptor = require('./interceptor/redirectInterceptor')\nconst { WeakRef, FinalizationRegistry } = require('./compat/dispatcher-weakref')()\n\nconst kOnConnect = Symbol('onConnect')\nconst kOnDisconnect = Symbol('onDisconnect')\nconst kOnConnectionError = Symbol('onConnectionError')\nconst kMaxRedirections = Symbol('maxRedirections')\nconst kOnDrain = Symbol('onDrain')\nconst kFactory = Symbol('factory')\nconst kFinalizer = Symbol('finalizer')\nconst kOptions = Symbol('options')\n\nfunction defaultFactory (origin, opts) {\n return opts && opts.connections === 1\n ? new Client(origin, opts)\n : new Pool(origin, opts)\n}\n\nclass Agent extends DispatcherBase {\n constructor ({ factory = defaultFactory, maxRedirections = 0, connect, ...options } = {}) {\n super()\n\n if (typeof factory !== 'function') {\n throw new InvalidArgumentError('factory must be a function.')\n }\n\n if (connect != null && typeof connect !== 'function' && typeof connect !== 'object') {\n throw new InvalidArgumentError('connect must be a function or an object')\n }\n\n if (!Number.isInteger(maxRedirections) || maxRedirections < 0) {\n throw new InvalidArgumentError('maxRedirections must be a positive number')\n }\n\n if (connect && typeof connect !== 'function') {\n connect = { ...connect }\n }\n\n this[kInterceptors] = options.interceptors && options.interceptors.Agent && Array.isArray(options.interceptors.Agent)\n ? options.interceptors.Agent\n : [createRedirectInterceptor({ maxRedirections })]\n\n this[kOptions] = { ...util.deepClone(options), connect }\n this[kOptions].interceptors = options.interceptors\n ? { ...options.interceptors }\n : undefined\n this[kMaxRedirections] = maxRedirections\n this[kFactory] = factory\n this[kClients] = new Map()\n this[kFinalizer] = new FinalizationRegistry(/* istanbul ignore next: gc is undeterministic */ key => {\n const ref = this[kClients].get(key)\n if (ref !== undefined && ref.deref() === undefined) {\n this[kClients].delete(key)\n }\n })\n\n const agent = this\n\n this[kOnDrain] = (origin, targets) => {\n agent.emit('drain', origin, [agent, ...targets])\n }\n\n this[kOnConnect] = (origin, targets) => {\n agent.emit('connect', origin, [agent, ...targets])\n }\n\n this[kOnDisconnect] = (origin, targets, err) => {\n agent.emit('disconnect', origin, [agent, ...targets], err)\n }\n\n this[kOnConnectionError] = (origin, targets, err) => {\n agent.emit('connectionError', origin, [agent, ...targets], err)\n }\n }\n\n get [kRunning] () {\n let ret = 0\n for (const ref of this[kClients].values()) {\n const client = ref.deref()\n /* istanbul ignore next: gc is undeterministic */\n if (client) {\n ret += client[kRunning]\n }\n }\n return ret\n }\n\n [kDispatch] (opts, handler) {\n let key\n if (opts.origin && (typeof opts.origin === 'string' || opts.origin instanceof URL)) {\n key = String(opts.origin)\n } else {\n throw new InvalidArgumentError('opts.origin must be a non-empty string or URL.')\n }\n\n const ref = this[kClients].get(key)\n\n let dispatcher = ref ? ref.deref() : null\n if (!dispatcher) {\n dispatcher = this[kFactory](opts.origin, this[kOptions])\n .on('drain', this[kOnDrain])\n .on('connect', this[kOnConnect])\n .on('disconnect', this[kOnDisconnect])\n .on('connectionError', this[kOnConnectionError])\n\n this[kClients].set(key, new WeakRef(dispatcher))\n this[kFinalizer].register(dispatcher, key)\n }\n\n return dispatcher.dispatch(opts, handler)\n }\n\n async [kClose] () {\n const closePromises = []\n for (const ref of this[kClients].values()) {\n const client = ref.deref()\n /* istanbul ignore else: gc is undeterministic */\n if (client) {\n closePromises.push(client.close())\n }\n }\n\n await Promise.all(closePromises)\n }\n\n async [kDestroy] (err) {\n const destroyPromises = []\n for (const ref of this[kClients].values()) {\n const client = ref.deref()\n /* istanbul ignore else: gc is undeterministic */\n if (client) {\n destroyPromises.push(client.destroy(err))\n }\n }\n\n await Promise.all(destroyPromises)\n }\n}\n\nmodule.exports = Agent\n","const { addAbortListener } = require('../core/util')\nconst { RequestAbortedError } = require('../core/errors')\n\nconst kListener = Symbol('kListener')\nconst kSignal = Symbol('kSignal')\n\nfunction abort (self) {\n if (self.abort) {\n self.abort()\n } else {\n self.onError(new RequestAbortedError())\n }\n}\n\nfunction addSignal (self, signal) {\n self[kSignal] = null\n self[kListener] = null\n\n if (!signal) {\n return\n }\n\n if (signal.aborted) {\n abort(self)\n return\n }\n\n self[kSignal] = signal\n self[kListener] = () => {\n abort(self)\n }\n\n addAbortListener(self[kSignal], self[kListener])\n}\n\nfunction removeSignal (self) {\n if (!self[kSignal]) {\n return\n }\n\n if ('removeEventListener' in self[kSignal]) {\n self[kSignal].removeEventListener('abort', self[kListener])\n } else {\n self[kSignal].removeListener('abort', self[kListener])\n }\n\n self[kSignal] = null\n self[kListener] = null\n}\n\nmodule.exports = {\n addSignal,\n removeSignal\n}\n","'use strict'\n\nconst { AsyncResource } = require('async_hooks')\nconst { InvalidArgumentError, RequestAbortedError, SocketError } = require('../core/errors')\nconst util = require('../core/util')\nconst { addSignal, removeSignal } = require('./abort-signal')\n\nclass ConnectHandler extends AsyncResource {\n constructor (opts, callback) {\n if (!opts || typeof opts !== 'object') {\n throw new InvalidArgumentError('invalid opts')\n }\n\n if (typeof callback !== 'function') {\n throw new InvalidArgumentError('invalid callback')\n }\n\n const { signal, opaque, responseHeaders } = opts\n\n if (signal && typeof signal.on !== 'function' && typeof signal.addEventListener !== 'function') {\n throw new InvalidArgumentError('signal must be an EventEmitter or EventTarget')\n }\n\n super('UNDICI_CONNECT')\n\n this.opaque = opaque || null\n this.responseHeaders = responseHeaders || null\n this.callback = callback\n this.abort = null\n\n addSignal(this, signal)\n }\n\n onConnect (abort, context) {\n if (!this.callback) {\n throw new RequestAbortedError()\n }\n\n this.abort = abort\n this.context = context\n }\n\n onHeaders () {\n throw new SocketError('bad connect', null)\n }\n\n onUpgrade (statusCode, rawHeaders, socket) {\n const { callback, opaque, context } = this\n\n removeSignal(this)\n\n this.callback = null\n\n let headers = rawHeaders\n // Indicates is an HTTP2Session\n if (headers != null) {\n headers = this.responseHeaders === 'raw' ? util.parseRawHeaders(rawHeaders) : util.parseHeaders(rawHeaders)\n }\n\n this.runInAsyncScope(callback, null, null, {\n statusCode,\n headers,\n socket,\n opaque,\n context\n })\n }\n\n onError (err) {\n const { callback, opaque } = this\n\n removeSignal(this)\n\n if (callback) {\n this.callback = null\n queueMicrotask(() => {\n this.runInAsyncScope(callback, null, err, { opaque })\n })\n }\n }\n}\n\nfunction connect (opts, callback) {\n if (callback === undefined) {\n return new Promise((resolve, reject) => {\n connect.call(this, opts, (err, data) => {\n return err ? reject(err) : resolve(data)\n })\n })\n }\n\n try {\n const connectHandler = new ConnectHandler(opts, callback)\n this.dispatch({ ...opts, method: 'CONNECT' }, connectHandler)\n } catch (err) {\n if (typeof callback !== 'function') {\n throw err\n }\n const opaque = opts && opts.opaque\n queueMicrotask(() => callback(err, { opaque }))\n }\n}\n\nmodule.exports = connect\n","'use strict'\n\nconst {\n Readable,\n Duplex,\n PassThrough\n} = require('stream')\nconst {\n InvalidArgumentError,\n InvalidReturnValueError,\n RequestAbortedError\n} = require('../core/errors')\nconst util = require('../core/util')\nconst { AsyncResource } = require('async_hooks')\nconst { addSignal, removeSignal } = require('./abort-signal')\nconst assert = require('assert')\n\nconst kResume = Symbol('resume')\n\nclass PipelineRequest extends Readable {\n constructor () {\n super({ autoDestroy: true })\n\n this[kResume] = null\n }\n\n _read () {\n const { [kResume]: resume } = this\n\n if (resume) {\n this[kResume] = null\n resume()\n }\n }\n\n _destroy (err, callback) {\n this._read()\n\n callback(err)\n }\n}\n\nclass PipelineResponse extends Readable {\n constructor (resume) {\n super({ autoDestroy: true })\n this[kResume] = resume\n }\n\n _read () {\n this[kResume]()\n }\n\n _destroy (err, callback) {\n if (!err && !this._readableState.endEmitted) {\n err = new RequestAbortedError()\n }\n\n callback(err)\n }\n}\n\nclass PipelineHandler extends AsyncResource {\n constructor (opts, handler) {\n if (!opts || typeof opts !== 'object') {\n throw new InvalidArgumentError('invalid opts')\n }\n\n if (typeof handler !== 'function') {\n throw new InvalidArgumentError('invalid handler')\n }\n\n const { signal, method, opaque, onInfo, responseHeaders } = opts\n\n if (signal && typeof signal.on !== 'function' && typeof signal.addEventListener !== 'function') {\n throw new InvalidArgumentError('signal must be an EventEmitter or EventTarget')\n }\n\n if (method === 'CONNECT') {\n throw new InvalidArgumentError('invalid method')\n }\n\n if (onInfo && typeof onInfo !== 'function') {\n throw new InvalidArgumentError('invalid onInfo callback')\n }\n\n super('UNDICI_PIPELINE')\n\n this.opaque = opaque || null\n this.responseHeaders = responseHeaders || null\n this.handler = handler\n this.abort = null\n this.context = null\n this.onInfo = onInfo || null\n\n this.req = new PipelineRequest().on('error', util.nop)\n\n this.ret = new Duplex({\n readableObjectMode: opts.objectMode,\n autoDestroy: true,\n read: () => {\n const { body } = this\n\n if (body && body.resume) {\n body.resume()\n }\n },\n write: (chunk, encoding, callback) => {\n const { req } = this\n\n if (req.push(chunk, encoding) || req._readableState.destroyed) {\n callback()\n } else {\n req[kResume] = callback\n }\n },\n destroy: (err, callback) => {\n const { body, req, res, ret, abort } = this\n\n if (!err && !ret._readableState.endEmitted) {\n err = new RequestAbortedError()\n }\n\n if (abort && err) {\n abort()\n }\n\n util.destroy(body, err)\n util.destroy(req, err)\n util.destroy(res, err)\n\n removeSignal(this)\n\n callback(err)\n }\n }).on('prefinish', () => {\n const { req } = this\n\n // Node < 15 does not call _final in same tick.\n req.push(null)\n })\n\n this.res = null\n\n addSignal(this, signal)\n }\n\n onConnect (abort, context) {\n const { ret, res } = this\n\n assert(!res, 'pipeline cannot be retried')\n\n if (ret.destroyed) {\n throw new RequestAbortedError()\n }\n\n this.abort = abort\n this.context = context\n }\n\n onHeaders (statusCode, rawHeaders, resume) {\n const { opaque, handler, context } = this\n\n if (statusCode < 200) {\n if (this.onInfo) {\n const headers = this.responseHeaders === 'raw' ? util.parseRawHeaders(rawHeaders) : util.parseHeaders(rawHeaders)\n this.onInfo({ statusCode, headers })\n }\n return\n }\n\n this.res = new PipelineResponse(resume)\n\n let body\n try {\n this.handler = null\n const headers = this.responseHeaders === 'raw' ? util.parseRawHeaders(rawHeaders) : util.parseHeaders(rawHeaders)\n body = this.runInAsyncScope(handler, null, {\n statusCode,\n headers,\n opaque,\n body: this.res,\n context\n })\n } catch (err) {\n this.res.on('error', util.nop)\n throw err\n }\n\n if (!body || typeof body.on !== 'function') {\n throw new InvalidReturnValueError('expected Readable')\n }\n\n body\n .on('data', (chunk) => {\n const { ret, body } = this\n\n if (!ret.push(chunk) && body.pause) {\n body.pause()\n }\n })\n .on('error', (err) => {\n const { ret } = this\n\n util.destroy(ret, err)\n })\n .on('end', () => {\n const { ret } = this\n\n ret.push(null)\n })\n .on('close', () => {\n const { ret } = this\n\n if (!ret._readableState.ended) {\n util.destroy(ret, new RequestAbortedError())\n }\n })\n\n this.body = body\n }\n\n onData (chunk) {\n const { res } = this\n return res.push(chunk)\n }\n\n onComplete (trailers) {\n const { res } = this\n res.push(null)\n }\n\n onError (err) {\n const { ret } = this\n this.handler = null\n util.destroy(ret, err)\n }\n}\n\nfunction pipeline (opts, handler) {\n try {\n const pipelineHandler = new PipelineHandler(opts, handler)\n this.dispatch({ ...opts, body: pipelineHandler.req }, pipelineHandler)\n return pipelineHandler.ret\n } catch (err) {\n return new PassThrough().destroy(err)\n }\n}\n\nmodule.exports = pipeline\n","'use strict'\n\nconst Readable = require('./readable')\nconst {\n InvalidArgumentError,\n RequestAbortedError\n} = require('../core/errors')\nconst util = require('../core/util')\nconst { getResolveErrorBodyCallback } = require('./util')\nconst { AsyncResource } = require('async_hooks')\nconst { addSignal, removeSignal } = require('./abort-signal')\n\nclass RequestHandler extends AsyncResource {\n constructor (opts, callback) {\n if (!opts || typeof opts !== 'object') {\n throw new InvalidArgumentError('invalid opts')\n }\n\n const { signal, method, opaque, body, onInfo, responseHeaders, throwOnError, highWaterMark } = opts\n\n try {\n if (typeof callback !== 'function') {\n throw new InvalidArgumentError('invalid callback')\n }\n\n if (highWaterMark && (typeof highWaterMark !== 'number' || highWaterMark < 0)) {\n throw new InvalidArgumentError('invalid highWaterMark')\n }\n\n if (signal && typeof signal.on !== 'function' && typeof signal.addEventListener !== 'function') {\n throw new InvalidArgumentError('signal must be an EventEmitter or EventTarget')\n }\n\n if (method === 'CONNECT') {\n throw new InvalidArgumentError('invalid method')\n }\n\n if (onInfo && typeof onInfo !== 'function') {\n throw new InvalidArgumentError('invalid onInfo callback')\n }\n\n super('UNDICI_REQUEST')\n } catch (err) {\n if (util.isStream(body)) {\n util.destroy(body.on('error', util.nop), err)\n }\n throw err\n }\n\n this.responseHeaders = responseHeaders || null\n this.opaque = opaque || null\n this.callback = callback\n this.res = null\n this.abort = null\n this.body = body\n this.trailers = {}\n this.context = null\n this.onInfo = onInfo || null\n this.throwOnError = throwOnError\n this.highWaterMark = highWaterMark\n\n if (util.isStream(body)) {\n body.on('error', (err) => {\n this.onError(err)\n })\n }\n\n addSignal(this, signal)\n }\n\n onConnect (abort, context) {\n if (!this.callback) {\n throw new RequestAbortedError()\n }\n\n this.abort = abort\n this.context = context\n }\n\n onHeaders (statusCode, rawHeaders, resume, statusMessage) {\n const { callback, opaque, abort, context, responseHeaders, highWaterMark } = this\n\n const headers = responseHeaders === 'raw' ? util.parseRawHeaders(rawHeaders) : util.parseHeaders(rawHeaders)\n\n if (statusCode < 200) {\n if (this.onInfo) {\n this.onInfo({ statusCode, headers })\n }\n return\n }\n\n const parsedHeaders = responseHeaders === 'raw' ? util.parseHeaders(rawHeaders) : headers\n const contentType = parsedHeaders['content-type']\n const body = new Readable({ resume, abort, contentType, highWaterMark })\n\n this.callback = null\n this.res = body\n if (callback !== null) {\n if (this.throwOnError && statusCode >= 400) {\n this.runInAsyncScope(getResolveErrorBodyCallback, null,\n { callback, body, contentType, statusCode, statusMessage, headers }\n )\n } else {\n this.runInAsyncScope(callback, null, null, {\n statusCode,\n headers,\n trailers: this.trailers,\n opaque,\n body,\n context\n })\n }\n }\n }\n\n onData (chunk) {\n const { res } = this\n return res.push(chunk)\n }\n\n onComplete (trailers) {\n const { res } = this\n\n removeSignal(this)\n\n util.parseHeaders(trailers, this.trailers)\n\n res.push(null)\n }\n\n onError (err) {\n const { res, callback, body, opaque } = this\n\n removeSignal(this)\n\n if (callback) {\n // TODO: Does this need queueMicrotask?\n this.callback = null\n queueMicrotask(() => {\n this.runInAsyncScope(callback, null, err, { opaque })\n })\n }\n\n if (res) {\n this.res = null\n // Ensure all queued handlers are invoked before destroying res.\n queueMicrotask(() => {\n util.destroy(res, err)\n })\n }\n\n if (body) {\n this.body = null\n util.destroy(body, err)\n }\n }\n}\n\nfunction request (opts, callback) {\n if (callback === undefined) {\n return new Promise((resolve, reject) => {\n request.call(this, opts, (err, data) => {\n return err ? reject(err) : resolve(data)\n })\n })\n }\n\n try {\n this.dispatch(opts, new RequestHandler(opts, callback))\n } catch (err) {\n if (typeof callback !== 'function') {\n throw err\n }\n const opaque = opts && opts.opaque\n queueMicrotask(() => callback(err, { opaque }))\n }\n}\n\nmodule.exports = request\nmodule.exports.RequestHandler = RequestHandler\n","'use strict'\n\nconst { finished, PassThrough } = require('stream')\nconst {\n InvalidArgumentError,\n InvalidReturnValueError,\n RequestAbortedError\n} = require('../core/errors')\nconst util = require('../core/util')\nconst { getResolveErrorBodyCallback } = require('./util')\nconst { AsyncResource } = require('async_hooks')\nconst { addSignal, removeSignal } = require('./abort-signal')\n\nclass StreamHandler extends AsyncResource {\n constructor (opts, factory, callback) {\n if (!opts || typeof opts !== 'object') {\n throw new InvalidArgumentError('invalid opts')\n }\n\n const { signal, method, opaque, body, onInfo, responseHeaders, throwOnError } = opts\n\n try {\n if (typeof callback !== 'function') {\n throw new InvalidArgumentError('invalid callback')\n }\n\n if (typeof factory !== 'function') {\n throw new InvalidArgumentError('invalid factory')\n }\n\n if (signal && typeof signal.on !== 'function' && typeof signal.addEventListener !== 'function') {\n throw new InvalidArgumentError('signal must be an EventEmitter or EventTarget')\n }\n\n if (method === 'CONNECT') {\n throw new InvalidArgumentError('invalid method')\n }\n\n if (onInfo && typeof onInfo !== 'function') {\n throw new InvalidArgumentError('invalid onInfo callback')\n }\n\n super('UNDICI_STREAM')\n } catch (err) {\n if (util.isStream(body)) {\n util.destroy(body.on('error', util.nop), err)\n }\n throw err\n }\n\n this.responseHeaders = responseHeaders || null\n this.opaque = opaque || null\n this.factory = factory\n this.callback = callback\n this.res = null\n this.abort = null\n this.context = null\n this.trailers = null\n this.body = body\n this.onInfo = onInfo || null\n this.throwOnError = throwOnError || false\n\n if (util.isStream(body)) {\n body.on('error', (err) => {\n this.onError(err)\n })\n }\n\n addSignal(this, signal)\n }\n\n onConnect (abort, context) {\n if (!this.callback) {\n throw new RequestAbortedError()\n }\n\n this.abort = abort\n this.context = context\n }\n\n onHeaders (statusCode, rawHeaders, resume, statusMessage) {\n const { factory, opaque, context, callback, responseHeaders } = this\n\n const headers = responseHeaders === 'raw' ? util.parseRawHeaders(rawHeaders) : util.parseHeaders(rawHeaders)\n\n if (statusCode < 200) {\n if (this.onInfo) {\n this.onInfo({ statusCode, headers })\n }\n return\n }\n\n this.factory = null\n\n let res\n\n if (this.throwOnError && statusCode >= 400) {\n const parsedHeaders = responseHeaders === 'raw' ? util.parseHeaders(rawHeaders) : headers\n const contentType = parsedHeaders['content-type']\n res = new PassThrough()\n\n this.callback = null\n this.runInAsyncScope(getResolveErrorBodyCallback, null,\n { callback, body: res, contentType, statusCode, statusMessage, headers }\n )\n } else {\n if (factory === null) {\n return\n }\n\n res = this.runInAsyncScope(factory, null, {\n statusCode,\n headers,\n opaque,\n context\n })\n\n if (\n !res ||\n typeof res.write !== 'function' ||\n typeof res.end !== 'function' ||\n typeof res.on !== 'function'\n ) {\n throw new InvalidReturnValueError('expected Writable')\n }\n\n // TODO: Avoid finished. It registers an unnecessary amount of listeners.\n finished(res, { readable: false }, (err) => {\n const { callback, res, opaque, trailers, abort } = this\n\n this.res = null\n if (err || !res.readable) {\n util.destroy(res, err)\n }\n\n this.callback = null\n this.runInAsyncScope(callback, null, err || null, { opaque, trailers })\n\n if (err) {\n abort()\n }\n })\n }\n\n res.on('drain', resume)\n\n this.res = res\n\n const needDrain = res.writableNeedDrain !== undefined\n ? res.writableNeedDrain\n : res._writableState && res._writableState.needDrain\n\n return needDrain !== true\n }\n\n onData (chunk) {\n const { res } = this\n\n return res ? res.write(chunk) : true\n }\n\n onComplete (trailers) {\n const { res } = this\n\n removeSignal(this)\n\n if (!res) {\n return\n }\n\n this.trailers = util.parseHeaders(trailers)\n\n res.end()\n }\n\n onError (err) {\n const { res, callback, opaque, body } = this\n\n removeSignal(this)\n\n this.factory = null\n\n if (res) {\n this.res = null\n util.destroy(res, err)\n } else if (callback) {\n this.callback = null\n queueMicrotask(() => {\n this.runInAsyncScope(callback, null, err, { opaque })\n })\n }\n\n if (body) {\n this.body = null\n util.destroy(body, err)\n }\n }\n}\n\nfunction stream (opts, factory, callback) {\n if (callback === undefined) {\n return new Promise((resolve, reject) => {\n stream.call(this, opts, factory, (err, data) => {\n return err ? reject(err) : resolve(data)\n })\n })\n }\n\n try {\n this.dispatch(opts, new StreamHandler(opts, factory, callback))\n } catch (err) {\n if (typeof callback !== 'function') {\n throw err\n }\n const opaque = opts && opts.opaque\n queueMicrotask(() => callback(err, { opaque }))\n }\n}\n\nmodule.exports = stream\n","'use strict'\n\nconst { InvalidArgumentError, RequestAbortedError, SocketError } = require('../core/errors')\nconst { AsyncResource } = require('async_hooks')\nconst util = require('../core/util')\nconst { addSignal, removeSignal } = require('./abort-signal')\nconst assert = require('assert')\n\nclass UpgradeHandler extends AsyncResource {\n constructor (opts, callback) {\n if (!opts || typeof opts !== 'object') {\n throw new InvalidArgumentError('invalid opts')\n }\n\n if (typeof callback !== 'function') {\n throw new InvalidArgumentError('invalid callback')\n }\n\n const { signal, opaque, responseHeaders } = opts\n\n if (signal && typeof signal.on !== 'function' && typeof signal.addEventListener !== 'function') {\n throw new InvalidArgumentError('signal must be an EventEmitter or EventTarget')\n }\n\n super('UNDICI_UPGRADE')\n\n this.responseHeaders = responseHeaders || null\n this.opaque = opaque || null\n this.callback = callback\n this.abort = null\n this.context = null\n\n addSignal(this, signal)\n }\n\n onConnect (abort, context) {\n if (!this.callback) {\n throw new RequestAbortedError()\n }\n\n this.abort = abort\n this.context = null\n }\n\n onHeaders () {\n throw new SocketError('bad upgrade', null)\n }\n\n onUpgrade (statusCode, rawHeaders, socket) {\n const { callback, opaque, context } = this\n\n assert.strictEqual(statusCode, 101)\n\n removeSignal(this)\n\n this.callback = null\n const headers = this.responseHeaders === 'raw' ? util.parseRawHeaders(rawHeaders) : util.parseHeaders(rawHeaders)\n this.runInAsyncScope(callback, null, null, {\n headers,\n socket,\n opaque,\n context\n })\n }\n\n onError (err) {\n const { callback, opaque } = this\n\n removeSignal(this)\n\n if (callback) {\n this.callback = null\n queueMicrotask(() => {\n this.runInAsyncScope(callback, null, err, { opaque })\n })\n }\n }\n}\n\nfunction upgrade (opts, callback) {\n if (callback === undefined) {\n return new Promise((resolve, reject) => {\n upgrade.call(this, opts, (err, data) => {\n return err ? reject(err) : resolve(data)\n })\n })\n }\n\n try {\n const upgradeHandler = new UpgradeHandler(opts, callback)\n this.dispatch({\n ...opts,\n method: opts.method || 'GET',\n upgrade: opts.protocol || 'Websocket'\n }, upgradeHandler)\n } catch (err) {\n if (typeof callback !== 'function') {\n throw err\n }\n const opaque = opts && opts.opaque\n queueMicrotask(() => callback(err, { opaque }))\n }\n}\n\nmodule.exports = upgrade\n","'use strict'\n\nmodule.exports.request = require('./api-request')\nmodule.exports.stream = require('./api-stream')\nmodule.exports.pipeline = require('./api-pipeline')\nmodule.exports.upgrade = require('./api-upgrade')\nmodule.exports.connect = require('./api-connect')\n","// Ported from https://github.com/nodejs/undici/pull/907\n\n'use strict'\n\nconst assert = require('assert')\nconst { Readable } = require('stream')\nconst { RequestAbortedError, NotSupportedError, InvalidArgumentError } = require('../core/errors')\nconst util = require('../core/util')\nconst { ReadableStreamFrom, toUSVString } = require('../core/util')\n\nlet Blob\n\nconst kConsume = Symbol('kConsume')\nconst kReading = Symbol('kReading')\nconst kBody = Symbol('kBody')\nconst kAbort = Symbol('abort')\nconst kContentType = Symbol('kContentType')\n\nconst noop = () => {}\n\nmodule.exports = class BodyReadable extends Readable {\n constructor ({\n resume,\n abort,\n contentType = '',\n highWaterMark = 64 * 1024 // Same as nodejs fs streams.\n }) {\n super({\n autoDestroy: true,\n read: resume,\n highWaterMark\n })\n\n this._readableState.dataEmitted = false\n\n this[kAbort] = abort\n this[kConsume] = null\n this[kBody] = null\n this[kContentType] = contentType\n\n // Is stream being consumed through Readable API?\n // This is an optimization so that we avoid checking\n // for 'data' and 'readable' listeners in the hot path\n // inside push().\n this[kReading] = false\n }\n\n destroy (err) {\n if (this.destroyed) {\n // Node < 16\n return this\n }\n\n if (!err && !this._readableState.endEmitted) {\n err = new RequestAbortedError()\n }\n\n if (err) {\n this[kAbort]()\n }\n\n return super.destroy(err)\n }\n\n emit (ev, ...args) {\n if (ev === 'data') {\n // Node < 16.7\n this._readableState.dataEmitted = true\n } else if (ev === 'error') {\n // Node < 16\n this._readableState.errorEmitted = true\n }\n return super.emit(ev, ...args)\n }\n\n on (ev, ...args) {\n if (ev === 'data' || ev === 'readable') {\n this[kReading] = true\n }\n return super.on(ev, ...args)\n }\n\n addListener (ev, ...args) {\n return this.on(ev, ...args)\n }\n\n off (ev, ...args) {\n const ret = super.off(ev, ...args)\n if (ev === 'data' || ev === 'readable') {\n this[kReading] = (\n this.listenerCount('data') > 0 ||\n this.listenerCount('readable') > 0\n )\n }\n return ret\n }\n\n removeListener (ev, ...args) {\n return this.off(ev, ...args)\n }\n\n push (chunk) {\n if (this[kConsume] && chunk !== null && this.readableLength === 0) {\n consumePush(this[kConsume], chunk)\n return this[kReading] ? super.push(chunk) : true\n }\n return super.push(chunk)\n }\n\n // https://fetch.spec.whatwg.org/#dom-body-text\n async text () {\n return consume(this, 'text')\n }\n\n // https://fetch.spec.whatwg.org/#dom-body-json\n async json () {\n return consume(this, 'json')\n }\n\n // https://fetch.spec.whatwg.org/#dom-body-blob\n async blob () {\n return consume(this, 'blob')\n }\n\n // https://fetch.spec.whatwg.org/#dom-body-arraybuffer\n async arrayBuffer () {\n return consume(this, 'arrayBuffer')\n }\n\n // https://fetch.spec.whatwg.org/#dom-body-formdata\n async formData () {\n // TODO: Implement.\n throw new NotSupportedError()\n }\n\n // https://fetch.spec.whatwg.org/#dom-body-bodyused\n get bodyUsed () {\n return util.isDisturbed(this)\n }\n\n // https://fetch.spec.whatwg.org/#dom-body-body\n get body () {\n if (!this[kBody]) {\n this[kBody] = ReadableStreamFrom(this)\n if (this[kConsume]) {\n // TODO: Is this the best way to force a lock?\n this[kBody].getReader() // Ensure stream is locked.\n assert(this[kBody].locked)\n }\n }\n return this[kBody]\n }\n\n dump (opts) {\n let limit = opts && Number.isFinite(opts.limit) ? opts.limit : 262144\n const signal = opts && opts.signal\n\n if (signal) {\n try {\n if (typeof signal !== 'object' || !('aborted' in signal)) {\n throw new InvalidArgumentError('signal must be an AbortSignal')\n }\n util.throwIfAborted(signal)\n } catch (err) {\n return Promise.reject(err)\n }\n }\n\n if (this.closed) {\n return Promise.resolve(null)\n }\n\n return new Promise((resolve, reject) => {\n const signalListenerCleanup = signal\n ? util.addAbortListener(signal, () => {\n this.destroy()\n })\n : noop\n\n this\n .on('close', function () {\n signalListenerCleanup()\n if (signal && signal.aborted) {\n reject(signal.reason || Object.assign(new Error('The operation was aborted'), { name: 'AbortError' }))\n } else {\n resolve(null)\n }\n })\n .on('error', noop)\n .on('data', function (chunk) {\n limit -= chunk.length\n if (limit <= 0) {\n this.destroy()\n }\n })\n .resume()\n })\n }\n}\n\n// https://streams.spec.whatwg.org/#readablestream-locked\nfunction isLocked (self) {\n // Consume is an implicit lock.\n return (self[kBody] && self[kBody].locked === true) || self[kConsume]\n}\n\n// https://fetch.spec.whatwg.org/#body-unusable\nfunction isUnusable (self) {\n return util.isDisturbed(self) || isLocked(self)\n}\n\nasync function consume (stream, type) {\n if (isUnusable(stream)) {\n throw new TypeError('unusable')\n }\n\n assert(!stream[kConsume])\n\n return new Promise((resolve, reject) => {\n stream[kConsume] = {\n type,\n stream,\n resolve,\n reject,\n length: 0,\n body: []\n }\n\n stream\n .on('error', function (err) {\n consumeFinish(this[kConsume], err)\n })\n .on('close', function () {\n if (this[kConsume].body !== null) {\n consumeFinish(this[kConsume], new RequestAbortedError())\n }\n })\n\n process.nextTick(consumeStart, stream[kConsume])\n })\n}\n\nfunction consumeStart (consume) {\n if (consume.body === null) {\n return\n }\n\n const { _readableState: state } = consume.stream\n\n for (const chunk of state.buffer) {\n consumePush(consume, chunk)\n }\n\n if (state.endEmitted) {\n consumeEnd(this[kConsume])\n } else {\n consume.stream.on('end', function () {\n consumeEnd(this[kConsume])\n })\n }\n\n consume.stream.resume()\n\n while (consume.stream.read() != null) {\n // Loop\n }\n}\n\nfunction consumeEnd (consume) {\n const { type, body, resolve, stream, length } = consume\n\n try {\n if (type === 'text') {\n resolve(toUSVString(Buffer.concat(body)))\n } else if (type === 'json') {\n resolve(JSON.parse(Buffer.concat(body)))\n } else if (type === 'arrayBuffer') {\n const dst = new Uint8Array(length)\n\n let pos = 0\n for (const buf of body) {\n dst.set(buf, pos)\n pos += buf.byteLength\n }\n\n resolve(dst.buffer)\n } else if (type === 'blob') {\n if (!Blob) {\n Blob = require('buffer').Blob\n }\n resolve(new Blob(body, { type: stream[kContentType] }))\n }\n\n consumeFinish(consume)\n } catch (err) {\n stream.destroy(err)\n }\n}\n\nfunction consumePush (consume, chunk) {\n consume.length += chunk.length\n consume.body.push(chunk)\n}\n\nfunction consumeFinish (consume, err) {\n if (consume.body === null) {\n return\n }\n\n if (err) {\n consume.reject(err)\n } else {\n consume.resolve()\n }\n\n consume.type = null\n consume.stream = null\n consume.resolve = null\n consume.reject = null\n consume.length = 0\n consume.body = null\n}\n","const assert = require('assert')\nconst {\n ResponseStatusCodeError\n} = require('../core/errors')\nconst { toUSVString } = require('../core/util')\n\nasync function getResolveErrorBodyCallback ({ callback, body, contentType, statusCode, statusMessage, headers }) {\n assert(body)\n\n let chunks = []\n let limit = 0\n\n for await (const chunk of body) {\n chunks.push(chunk)\n limit += chunk.length\n if (limit > 128 * 1024) {\n chunks = null\n break\n }\n }\n\n if (statusCode === 204 || !contentType || !chunks) {\n process.nextTick(callback, new ResponseStatusCodeError(`Response status code ${statusCode}${statusMessage ? `: ${statusMessage}` : ''}`, statusCode, headers))\n return\n }\n\n try {\n if (contentType.startsWith('application/json')) {\n const payload = JSON.parse(toUSVString(Buffer.concat(chunks)))\n process.nextTick(callback, new ResponseStatusCodeError(`Response status code ${statusCode}${statusMessage ? `: ${statusMessage}` : ''}`, statusCode, headers, payload))\n return\n }\n\n if (contentType.startsWith('text/')) {\n const payload = toUSVString(Buffer.concat(chunks))\n process.nextTick(callback, new ResponseStatusCodeError(`Response status code ${statusCode}${statusMessage ? `: ${statusMessage}` : ''}`, statusCode, headers, payload))\n return\n }\n } catch (err) {\n // Process in a fallback if error\n }\n\n process.nextTick(callback, new ResponseStatusCodeError(`Response status code ${statusCode}${statusMessage ? `: ${statusMessage}` : ''}`, statusCode, headers))\n}\n\nmodule.exports = { getResolveErrorBodyCallback }\n","'use strict'\n\nconst {\n BalancedPoolMissingUpstreamError,\n InvalidArgumentError\n} = require('./core/errors')\nconst {\n PoolBase,\n kClients,\n kNeedDrain,\n kAddClient,\n kRemoveClient,\n kGetDispatcher\n} = require('./pool-base')\nconst Pool = require('./pool')\nconst { kUrl, kInterceptors } = require('./core/symbols')\nconst { parseOrigin } = require('./core/util')\nconst kFactory = Symbol('factory')\n\nconst kOptions = Symbol('options')\nconst kGreatestCommonDivisor = Symbol('kGreatestCommonDivisor')\nconst kCurrentWeight = Symbol('kCurrentWeight')\nconst kIndex = Symbol('kIndex')\nconst kWeight = Symbol('kWeight')\nconst kMaxWeightPerServer = Symbol('kMaxWeightPerServer')\nconst kErrorPenalty = Symbol('kErrorPenalty')\n\nfunction getGreatestCommonDivisor (a, b) {\n if (b === 0) return a\n return getGreatestCommonDivisor(b, a % b)\n}\n\nfunction defaultFactory (origin, opts) {\n return new Pool(origin, opts)\n}\n\nclass BalancedPool extends PoolBase {\n constructor (upstreams = [], { factory = defaultFactory, ...opts } = {}) {\n super()\n\n this[kOptions] = opts\n this[kIndex] = -1\n this[kCurrentWeight] = 0\n\n this[kMaxWeightPerServer] = this[kOptions].maxWeightPerServer || 100\n this[kErrorPenalty] = this[kOptions].errorPenalty || 15\n\n if (!Array.isArray(upstreams)) {\n upstreams = [upstreams]\n }\n\n if (typeof factory !== 'function') {\n throw new InvalidArgumentError('factory must be a function.')\n }\n\n this[kInterceptors] = opts.interceptors && opts.interceptors.BalancedPool && Array.isArray(opts.interceptors.BalancedPool)\n ? opts.interceptors.BalancedPool\n : []\n this[kFactory] = factory\n\n for (const upstream of upstreams) {\n this.addUpstream(upstream)\n }\n this._updateBalancedPoolStats()\n }\n\n addUpstream (upstream) {\n const upstreamOrigin = parseOrigin(upstream).origin\n\n if (this[kClients].find((pool) => (\n pool[kUrl].origin === upstreamOrigin &&\n pool.closed !== true &&\n pool.destroyed !== true\n ))) {\n return this\n }\n const pool = this[kFactory](upstreamOrigin, Object.assign({}, this[kOptions]))\n\n this[kAddClient](pool)\n pool.on('connect', () => {\n pool[kWeight] = Math.min(this[kMaxWeightPerServer], pool[kWeight] + this[kErrorPenalty])\n })\n\n pool.on('connectionError', () => {\n pool[kWeight] = Math.max(1, pool[kWeight] - this[kErrorPenalty])\n this._updateBalancedPoolStats()\n })\n\n pool.on('disconnect', (...args) => {\n const err = args[2]\n if (err && err.code === 'UND_ERR_SOCKET') {\n // decrease the weight of the pool.\n pool[kWeight] = Math.max(1, pool[kWeight] - this[kErrorPenalty])\n this._updateBalancedPoolStats()\n }\n })\n\n for (const client of this[kClients]) {\n client[kWeight] = this[kMaxWeightPerServer]\n }\n\n this._updateBalancedPoolStats()\n\n return this\n }\n\n _updateBalancedPoolStats () {\n this[kGreatestCommonDivisor] = this[kClients].map(p => p[kWeight]).reduce(getGreatestCommonDivisor, 0)\n }\n\n removeUpstream (upstream) {\n const upstreamOrigin = parseOrigin(upstream).origin\n\n const pool = this[kClients].find((pool) => (\n pool[kUrl].origin === upstreamOrigin &&\n pool.closed !== true &&\n pool.destroyed !== true\n ))\n\n if (pool) {\n this[kRemoveClient](pool)\n }\n\n return this\n }\n\n get upstreams () {\n return this[kClients]\n .filter(dispatcher => dispatcher.closed !== true && dispatcher.destroyed !== true)\n .map((p) => p[kUrl].origin)\n }\n\n [kGetDispatcher] () {\n // We validate that pools is greater than 0,\n // otherwise we would have to wait until an upstream\n // is added, which might never happen.\n if (this[kClients].length === 0) {\n throw new BalancedPoolMissingUpstreamError()\n }\n\n const dispatcher = this[kClients].find(dispatcher => (\n !dispatcher[kNeedDrain] &&\n dispatcher.closed !== true &&\n dispatcher.destroyed !== true\n ))\n\n if (!dispatcher) {\n return\n }\n\n const allClientsBusy = this[kClients].map(pool => pool[kNeedDrain]).reduce((a, b) => a && b, true)\n\n if (allClientsBusy) {\n return\n }\n\n let counter = 0\n\n let maxWeightIndex = this[kClients].findIndex(pool => !pool[kNeedDrain])\n\n while (counter++ < this[kClients].length) {\n this[kIndex] = (this[kIndex] + 1) % this[kClients].length\n const pool = this[kClients][this[kIndex]]\n\n // find pool index with the largest weight\n if (pool[kWeight] > this[kClients][maxWeightIndex][kWeight] && !pool[kNeedDrain]) {\n maxWeightIndex = this[kIndex]\n }\n\n // decrease the current weight every `this[kClients].length`.\n if (this[kIndex] === 0) {\n // Set the current weight to the next lower weight.\n this[kCurrentWeight] = this[kCurrentWeight] - this[kGreatestCommonDivisor]\n\n if (this[kCurrentWeight] <= 0) {\n this[kCurrentWeight] = this[kMaxWeightPerServer]\n }\n }\n if (pool[kWeight] >= this[kCurrentWeight] && (!pool[kNeedDrain])) {\n return pool\n }\n }\n\n this[kCurrentWeight] = this[kClients][maxWeightIndex][kWeight]\n this[kIndex] = maxWeightIndex\n return this[kClients][maxWeightIndex]\n }\n}\n\nmodule.exports = BalancedPool\n","'use strict'\n\nconst { kConstruct } = require('./symbols')\nconst { urlEquals, fieldValues: getFieldValues } = require('./util')\nconst { kEnumerableProperty, isDisturbed } = require('../core/util')\nconst { kHeadersList } = require('../core/symbols')\nconst { webidl } = require('../fetch/webidl')\nconst { Response, cloneResponse } = require('../fetch/response')\nconst { Request } = require('../fetch/request')\nconst { kState, kHeaders, kGuard, kRealm } = require('../fetch/symbols')\nconst { fetching } = require('../fetch/index')\nconst { urlIsHttpHttpsScheme, createDeferredPromise, readAllBytes } = require('../fetch/util')\nconst assert = require('assert')\nconst { getGlobalDispatcher } = require('../global')\n\n/**\n * @see https://w3c.github.io/ServiceWorker/#dfn-cache-batch-operation\n * @typedef {Object} CacheBatchOperation\n * @property {'delete' | 'put'} type\n * @property {any} request\n * @property {any} response\n * @property {import('../../types/cache').CacheQueryOptions} options\n */\n\n/**\n * @see https://w3c.github.io/ServiceWorker/#dfn-request-response-list\n * @typedef {[any, any][]} requestResponseList\n */\n\nclass Cache {\n /**\n * @see https://w3c.github.io/ServiceWorker/#dfn-relevant-request-response-list\n * @type {requestResponseList}\n */\n #relevantRequestResponseList\n\n constructor () {\n if (arguments[0] !== kConstruct) {\n webidl.illegalConstructor()\n }\n\n this.#relevantRequestResponseList = arguments[1]\n }\n\n async match (request, options = {}) {\n webidl.brandCheck(this, Cache)\n webidl.argumentLengthCheck(arguments, 1, { header: 'Cache.match' })\n\n request = webidl.converters.RequestInfo(request)\n options = webidl.converters.CacheQueryOptions(options)\n\n const p = await this.matchAll(request, options)\n\n if (p.length === 0) {\n return\n }\n\n return p[0]\n }\n\n async matchAll (request = undefined, options = {}) {\n webidl.brandCheck(this, Cache)\n\n if (request !== undefined) request = webidl.converters.RequestInfo(request)\n options = webidl.converters.CacheQueryOptions(options)\n\n // 1.\n let r = null\n\n // 2.\n if (request !== undefined) {\n if (request instanceof Request) {\n // 2.1.1\n r = request[kState]\n\n // 2.1.2\n if (r.method !== 'GET' && !options.ignoreMethod) {\n return []\n }\n } else if (typeof request === 'string') {\n // 2.2.1\n r = new Request(request)[kState]\n }\n }\n\n // 5.\n // 5.1\n const responses = []\n\n // 5.2\n if (request === undefined) {\n // 5.2.1\n for (const requestResponse of this.#relevantRequestResponseList) {\n responses.push(requestResponse[1])\n }\n } else { // 5.3\n // 5.3.1\n const requestResponses = this.#queryCache(r, options)\n\n // 5.3.2\n for (const requestResponse of requestResponses) {\n responses.push(requestResponse[1])\n }\n }\n\n // 5.4\n // We don't implement CORs so we don't need to loop over the responses, yay!\n\n // 5.5.1\n const responseList = []\n\n // 5.5.2\n for (const response of responses) {\n // 5.5.2.1\n const responseObject = new Response(response.body?.source ?? null)\n const body = responseObject[kState].body\n responseObject[kState] = response\n responseObject[kState].body = body\n responseObject[kHeaders][kHeadersList] = response.headersList\n responseObject[kHeaders][kGuard] = 'immutable'\n\n responseList.push(responseObject)\n }\n\n // 6.\n return Object.freeze(responseList)\n }\n\n async add (request) {\n webidl.brandCheck(this, Cache)\n webidl.argumentLengthCheck(arguments, 1, { header: 'Cache.add' })\n\n request = webidl.converters.RequestInfo(request)\n\n // 1.\n const requests = [request]\n\n // 2.\n const responseArrayPromise = this.addAll(requests)\n\n // 3.\n return await responseArrayPromise\n }\n\n async addAll (requests) {\n webidl.brandCheck(this, Cache)\n webidl.argumentLengthCheck(arguments, 1, { header: 'Cache.addAll' })\n\n requests = webidl.converters['sequence'](requests)\n\n // 1.\n const responsePromises = []\n\n // 2.\n const requestList = []\n\n // 3.\n for (const request of requests) {\n if (typeof request === 'string') {\n continue\n }\n\n // 3.1\n const r = request[kState]\n\n // 3.2\n if (!urlIsHttpHttpsScheme(r.url) || r.method !== 'GET') {\n throw webidl.errors.exception({\n header: 'Cache.addAll',\n message: 'Expected http/s scheme when method is not GET.'\n })\n }\n }\n\n // 4.\n /** @type {ReturnType[]} */\n const fetchControllers = []\n\n // 5.\n for (const request of requests) {\n // 5.1\n const r = new Request(request)[kState]\n\n // 5.2\n if (!urlIsHttpHttpsScheme(r.url)) {\n throw webidl.errors.exception({\n header: 'Cache.addAll',\n message: 'Expected http/s scheme.'\n })\n }\n\n // 5.4\n r.initiator = 'fetch'\n r.destination = 'subresource'\n\n // 5.5\n requestList.push(r)\n\n // 5.6\n const responsePromise = createDeferredPromise()\n\n // 5.7\n fetchControllers.push(fetching({\n request: r,\n dispatcher: getGlobalDispatcher(),\n processResponse (response) {\n // 1.\n if (response.type === 'error' || response.status === 206 || response.status < 200 || response.status > 299) {\n responsePromise.reject(webidl.errors.exception({\n header: 'Cache.addAll',\n message: 'Received an invalid status code or the request failed.'\n }))\n } else if (response.headersList.contains('vary')) { // 2.\n // 2.1\n const fieldValues = getFieldValues(response.headersList.get('vary'))\n\n // 2.2\n for (const fieldValue of fieldValues) {\n // 2.2.1\n if (fieldValue === '*') {\n responsePromise.reject(webidl.errors.exception({\n header: 'Cache.addAll',\n message: 'invalid vary field value'\n }))\n\n for (const controller of fetchControllers) {\n controller.abort()\n }\n\n return\n }\n }\n }\n },\n processResponseEndOfBody (response) {\n // 1.\n if (response.aborted) {\n responsePromise.reject(new DOMException('aborted', 'AbortError'))\n return\n }\n\n // 2.\n responsePromise.resolve(response)\n }\n }))\n\n // 5.8\n responsePromises.push(responsePromise.promise)\n }\n\n // 6.\n const p = Promise.all(responsePromises)\n\n // 7.\n const responses = await p\n\n // 7.1\n const operations = []\n\n // 7.2\n let index = 0\n\n // 7.3\n for (const response of responses) {\n // 7.3.1\n /** @type {CacheBatchOperation} */\n const operation = {\n type: 'put', // 7.3.2\n request: requestList[index], // 7.3.3\n response // 7.3.4\n }\n\n operations.push(operation) // 7.3.5\n\n index++ // 7.3.6\n }\n\n // 7.5\n const cacheJobPromise = createDeferredPromise()\n\n // 7.6.1\n let errorData = null\n\n // 7.6.2\n try {\n this.#batchCacheOperations(operations)\n } catch (e) {\n errorData = e\n }\n\n // 7.6.3\n queueMicrotask(() => {\n // 7.6.3.1\n if (errorData === null) {\n cacheJobPromise.resolve(undefined)\n } else {\n // 7.6.3.2\n cacheJobPromise.reject(errorData)\n }\n })\n\n // 7.7\n return cacheJobPromise.promise\n }\n\n async put (request, response) {\n webidl.brandCheck(this, Cache)\n webidl.argumentLengthCheck(arguments, 2, { header: 'Cache.put' })\n\n request = webidl.converters.RequestInfo(request)\n response = webidl.converters.Response(response)\n\n // 1.\n let innerRequest = null\n\n // 2.\n if (request instanceof Request) {\n innerRequest = request[kState]\n } else { // 3.\n innerRequest = new Request(request)[kState]\n }\n\n // 4.\n if (!urlIsHttpHttpsScheme(innerRequest.url) || innerRequest.method !== 'GET') {\n throw webidl.errors.exception({\n header: 'Cache.put',\n message: 'Expected an http/s scheme when method is not GET'\n })\n }\n\n // 5.\n const innerResponse = response[kState]\n\n // 6.\n if (innerResponse.status === 206) {\n throw webidl.errors.exception({\n header: 'Cache.put',\n message: 'Got 206 status'\n })\n }\n\n // 7.\n if (innerResponse.headersList.contains('vary')) {\n // 7.1.\n const fieldValues = getFieldValues(innerResponse.headersList.get('vary'))\n\n // 7.2.\n for (const fieldValue of fieldValues) {\n // 7.2.1\n if (fieldValue === '*') {\n throw webidl.errors.exception({\n header: 'Cache.put',\n message: 'Got * vary field value'\n })\n }\n }\n }\n\n // 8.\n if (innerResponse.body && (isDisturbed(innerResponse.body.stream) || innerResponse.body.stream.locked)) {\n throw webidl.errors.exception({\n header: 'Cache.put',\n message: 'Response body is locked or disturbed'\n })\n }\n\n // 9.\n const clonedResponse = cloneResponse(innerResponse)\n\n // 10.\n const bodyReadPromise = createDeferredPromise()\n\n // 11.\n if (innerResponse.body != null) {\n // 11.1\n const stream = innerResponse.body.stream\n\n // 11.2\n const reader = stream.getReader()\n\n // 11.3\n readAllBytes(reader).then(bodyReadPromise.resolve, bodyReadPromise.reject)\n } else {\n bodyReadPromise.resolve(undefined)\n }\n\n // 12.\n /** @type {CacheBatchOperation[]} */\n const operations = []\n\n // 13.\n /** @type {CacheBatchOperation} */\n const operation = {\n type: 'put', // 14.\n request: innerRequest, // 15.\n response: clonedResponse // 16.\n }\n\n // 17.\n operations.push(operation)\n\n // 19.\n const bytes = await bodyReadPromise.promise\n\n if (clonedResponse.body != null) {\n clonedResponse.body.source = bytes\n }\n\n // 19.1\n const cacheJobPromise = createDeferredPromise()\n\n // 19.2.1\n let errorData = null\n\n // 19.2.2\n try {\n this.#batchCacheOperations(operations)\n } catch (e) {\n errorData = e\n }\n\n // 19.2.3\n queueMicrotask(() => {\n // 19.2.3.1\n if (errorData === null) {\n cacheJobPromise.resolve()\n } else { // 19.2.3.2\n cacheJobPromise.reject(errorData)\n }\n })\n\n return cacheJobPromise.promise\n }\n\n async delete (request, options = {}) {\n webidl.brandCheck(this, Cache)\n webidl.argumentLengthCheck(arguments, 1, { header: 'Cache.delete' })\n\n request = webidl.converters.RequestInfo(request)\n options = webidl.converters.CacheQueryOptions(options)\n\n /**\n * @type {Request}\n */\n let r = null\n\n if (request instanceof Request) {\n r = request[kState]\n\n if (r.method !== 'GET' && !options.ignoreMethod) {\n return false\n }\n } else {\n assert(typeof request === 'string')\n\n r = new Request(request)[kState]\n }\n\n /** @type {CacheBatchOperation[]} */\n const operations = []\n\n /** @type {CacheBatchOperation} */\n const operation = {\n type: 'delete',\n request: r,\n options\n }\n\n operations.push(operation)\n\n const cacheJobPromise = createDeferredPromise()\n\n let errorData = null\n let requestResponses\n\n try {\n requestResponses = this.#batchCacheOperations(operations)\n } catch (e) {\n errorData = e\n }\n\n queueMicrotask(() => {\n if (errorData === null) {\n cacheJobPromise.resolve(!!requestResponses?.length)\n } else {\n cacheJobPromise.reject(errorData)\n }\n })\n\n return cacheJobPromise.promise\n }\n\n /**\n * @see https://w3c.github.io/ServiceWorker/#dom-cache-keys\n * @param {any} request\n * @param {import('../../types/cache').CacheQueryOptions} options\n * @returns {readonly Request[]}\n */\n async keys (request = undefined, options = {}) {\n webidl.brandCheck(this, Cache)\n\n if (request !== undefined) request = webidl.converters.RequestInfo(request)\n options = webidl.converters.CacheQueryOptions(options)\n\n // 1.\n let r = null\n\n // 2.\n if (request !== undefined) {\n // 2.1\n if (request instanceof Request) {\n // 2.1.1\n r = request[kState]\n\n // 2.1.2\n if (r.method !== 'GET' && !options.ignoreMethod) {\n return []\n }\n } else if (typeof request === 'string') { // 2.2\n r = new Request(request)[kState]\n }\n }\n\n // 4.\n const promise = createDeferredPromise()\n\n // 5.\n // 5.1\n const requests = []\n\n // 5.2\n if (request === undefined) {\n // 5.2.1\n for (const requestResponse of this.#relevantRequestResponseList) {\n // 5.2.1.1\n requests.push(requestResponse[0])\n }\n } else { // 5.3\n // 5.3.1\n const requestResponses = this.#queryCache(r, options)\n\n // 5.3.2\n for (const requestResponse of requestResponses) {\n // 5.3.2.1\n requests.push(requestResponse[0])\n }\n }\n\n // 5.4\n queueMicrotask(() => {\n // 5.4.1\n const requestList = []\n\n // 5.4.2\n for (const request of requests) {\n const requestObject = new Request('https://a')\n requestObject[kState] = request\n requestObject[kHeaders][kHeadersList] = request.headersList\n requestObject[kHeaders][kGuard] = 'immutable'\n requestObject[kRealm] = request.client\n\n // 5.4.2.1\n requestList.push(requestObject)\n }\n\n // 5.4.3\n promise.resolve(Object.freeze(requestList))\n })\n\n return promise.promise\n }\n\n /**\n * @see https://w3c.github.io/ServiceWorker/#batch-cache-operations-algorithm\n * @param {CacheBatchOperation[]} operations\n * @returns {requestResponseList}\n */\n #batchCacheOperations (operations) {\n // 1.\n const cache = this.#relevantRequestResponseList\n\n // 2.\n const backupCache = [...cache]\n\n // 3.\n const addedItems = []\n\n // 4.1\n const resultList = []\n\n try {\n // 4.2\n for (const operation of operations) {\n // 4.2.1\n if (operation.type !== 'delete' && operation.type !== 'put') {\n throw webidl.errors.exception({\n header: 'Cache.#batchCacheOperations',\n message: 'operation type does not match \"delete\" or \"put\"'\n })\n }\n\n // 4.2.2\n if (operation.type === 'delete' && operation.response != null) {\n throw webidl.errors.exception({\n header: 'Cache.#batchCacheOperations',\n message: 'delete operation should not have an associated response'\n })\n }\n\n // 4.2.3\n if (this.#queryCache(operation.request, operation.options, addedItems).length) {\n throw new DOMException('???', 'InvalidStateError')\n }\n\n // 4.2.4\n let requestResponses\n\n // 4.2.5\n if (operation.type === 'delete') {\n // 4.2.5.1\n requestResponses = this.#queryCache(operation.request, operation.options)\n\n // TODO: the spec is wrong, this is needed to pass WPTs\n if (requestResponses.length === 0) {\n return []\n }\n\n // 4.2.5.2\n for (const requestResponse of requestResponses) {\n const idx = cache.indexOf(requestResponse)\n assert(idx !== -1)\n\n // 4.2.5.2.1\n cache.splice(idx, 1)\n }\n } else if (operation.type === 'put') { // 4.2.6\n // 4.2.6.1\n if (operation.response == null) {\n throw webidl.errors.exception({\n header: 'Cache.#batchCacheOperations',\n message: 'put operation should have an associated response'\n })\n }\n\n // 4.2.6.2\n const r = operation.request\n\n // 4.2.6.3\n if (!urlIsHttpHttpsScheme(r.url)) {\n throw webidl.errors.exception({\n header: 'Cache.#batchCacheOperations',\n message: 'expected http or https scheme'\n })\n }\n\n // 4.2.6.4\n if (r.method !== 'GET') {\n throw webidl.errors.exception({\n header: 'Cache.#batchCacheOperations',\n message: 'not get method'\n })\n }\n\n // 4.2.6.5\n if (operation.options != null) {\n throw webidl.errors.exception({\n header: 'Cache.#batchCacheOperations',\n message: 'options must not be defined'\n })\n }\n\n // 4.2.6.6\n requestResponses = this.#queryCache(operation.request)\n\n // 4.2.6.7\n for (const requestResponse of requestResponses) {\n const idx = cache.indexOf(requestResponse)\n assert(idx !== -1)\n\n // 4.2.6.7.1\n cache.splice(idx, 1)\n }\n\n // 4.2.6.8\n cache.push([operation.request, operation.response])\n\n // 4.2.6.10\n addedItems.push([operation.request, operation.response])\n }\n\n // 4.2.7\n resultList.push([operation.request, operation.response])\n }\n\n // 4.3\n return resultList\n } catch (e) { // 5.\n // 5.1\n this.#relevantRequestResponseList.length = 0\n\n // 5.2\n this.#relevantRequestResponseList = backupCache\n\n // 5.3\n throw e\n }\n }\n\n /**\n * @see https://w3c.github.io/ServiceWorker/#query-cache\n * @param {any} requestQuery\n * @param {import('../../types/cache').CacheQueryOptions} options\n * @param {requestResponseList} targetStorage\n * @returns {requestResponseList}\n */\n #queryCache (requestQuery, options, targetStorage) {\n /** @type {requestResponseList} */\n const resultList = []\n\n const storage = targetStorage ?? this.#relevantRequestResponseList\n\n for (const requestResponse of storage) {\n const [cachedRequest, cachedResponse] = requestResponse\n if (this.#requestMatchesCachedItem(requestQuery, cachedRequest, cachedResponse, options)) {\n resultList.push(requestResponse)\n }\n }\n\n return resultList\n }\n\n /**\n * @see https://w3c.github.io/ServiceWorker/#request-matches-cached-item-algorithm\n * @param {any} requestQuery\n * @param {any} request\n * @param {any | null} response\n * @param {import('../../types/cache').CacheQueryOptions | undefined} options\n * @returns {boolean}\n */\n #requestMatchesCachedItem (requestQuery, request, response = null, options) {\n // if (options?.ignoreMethod === false && request.method === 'GET') {\n // return false\n // }\n\n const queryURL = new URL(requestQuery.url)\n\n const cachedURL = new URL(request.url)\n\n if (options?.ignoreSearch) {\n cachedURL.search = ''\n\n queryURL.search = ''\n }\n\n if (!urlEquals(queryURL, cachedURL, true)) {\n return false\n }\n\n if (\n response == null ||\n options?.ignoreVary ||\n !response.headersList.contains('vary')\n ) {\n return true\n }\n\n const fieldValues = getFieldValues(response.headersList.get('vary'))\n\n for (const fieldValue of fieldValues) {\n if (fieldValue === '*') {\n return false\n }\n\n const requestValue = request.headersList.get(fieldValue)\n const queryValue = requestQuery.headersList.get(fieldValue)\n\n // If one has the header and the other doesn't, or one has\n // a different value than the other, return false\n if (requestValue !== queryValue) {\n return false\n }\n }\n\n return true\n }\n}\n\nObject.defineProperties(Cache.prototype, {\n [Symbol.toStringTag]: {\n value: 'Cache',\n configurable: true\n },\n match: kEnumerableProperty,\n matchAll: kEnumerableProperty,\n add: kEnumerableProperty,\n addAll: kEnumerableProperty,\n put: kEnumerableProperty,\n delete: kEnumerableProperty,\n keys: kEnumerableProperty\n})\n\nconst cacheQueryOptionConverters = [\n {\n key: 'ignoreSearch',\n converter: webidl.converters.boolean,\n defaultValue: false\n },\n {\n key: 'ignoreMethod',\n converter: webidl.converters.boolean,\n defaultValue: false\n },\n {\n key: 'ignoreVary',\n converter: webidl.converters.boolean,\n defaultValue: false\n }\n]\n\nwebidl.converters.CacheQueryOptions = webidl.dictionaryConverter(cacheQueryOptionConverters)\n\nwebidl.converters.MultiCacheQueryOptions = webidl.dictionaryConverter([\n ...cacheQueryOptionConverters,\n {\n key: 'cacheName',\n converter: webidl.converters.DOMString\n }\n])\n\nwebidl.converters.Response = webidl.interfaceConverter(Response)\n\nwebidl.converters['sequence'] = webidl.sequenceConverter(\n webidl.converters.RequestInfo\n)\n\nmodule.exports = {\n Cache\n}\n","'use strict'\n\nconst { kConstruct } = require('./symbols')\nconst { Cache } = require('./cache')\nconst { webidl } = require('../fetch/webidl')\nconst { kEnumerableProperty } = require('../core/util')\n\nclass CacheStorage {\n /**\n * @see https://w3c.github.io/ServiceWorker/#dfn-relevant-name-to-cache-map\n * @type {Map}\n */\n async has (cacheName) {\n webidl.brandCheck(this, CacheStorage)\n webidl.argumentLengthCheck(arguments, 1, { header: 'CacheStorage.has' })\n\n cacheName = webidl.converters.DOMString(cacheName)\n\n // 2.1.1\n // 2.2\n return this.#caches.has(cacheName)\n }\n\n /**\n * @see https://w3c.github.io/ServiceWorker/#dom-cachestorage-open\n * @param {string} cacheName\n * @returns {Promise}\n */\n async open (cacheName) {\n webidl.brandCheck(this, CacheStorage)\n webidl.argumentLengthCheck(arguments, 1, { header: 'CacheStorage.open' })\n\n cacheName = webidl.converters.DOMString(cacheName)\n\n // 2.1\n if (this.#caches.has(cacheName)) {\n // await caches.open('v1') !== await caches.open('v1')\n\n // 2.1.1\n const cache = this.#caches.get(cacheName)\n\n // 2.1.1.1\n return new Cache(kConstruct, cache)\n }\n\n // 2.2\n const cache = []\n\n // 2.3\n this.#caches.set(cacheName, cache)\n\n // 2.4\n return new Cache(kConstruct, cache)\n }\n\n /**\n * @see https://w3c.github.io/ServiceWorker/#cache-storage-delete\n * @param {string} cacheName\n * @returns {Promise}\n */\n async delete (cacheName) {\n webidl.brandCheck(this, CacheStorage)\n webidl.argumentLengthCheck(arguments, 1, { header: 'CacheStorage.delete' })\n\n cacheName = webidl.converters.DOMString(cacheName)\n\n return this.#caches.delete(cacheName)\n }\n\n /**\n * @see https://w3c.github.io/ServiceWorker/#cache-storage-keys\n * @returns {string[]}\n */\n async keys () {\n webidl.brandCheck(this, CacheStorage)\n\n // 2.1\n const keys = this.#caches.keys()\n\n // 2.2\n return [...keys]\n }\n}\n\nObject.defineProperties(CacheStorage.prototype, {\n [Symbol.toStringTag]: {\n value: 'CacheStorage',\n configurable: true\n },\n match: kEnumerableProperty,\n has: kEnumerableProperty,\n open: kEnumerableProperty,\n delete: kEnumerableProperty,\n keys: kEnumerableProperty\n})\n\nmodule.exports = {\n CacheStorage\n}\n","'use strict'\n\nmodule.exports = {\n kConstruct: require('../core/symbols').kConstruct\n}\n","'use strict'\n\nconst assert = require('assert')\nconst { URLSerializer } = require('../fetch/dataURL')\nconst { isValidHeaderName } = require('../fetch/util')\n\n/**\n * @see https://url.spec.whatwg.org/#concept-url-equals\n * @param {URL} A\n * @param {URL} B\n * @param {boolean | undefined} excludeFragment\n * @returns {boolean}\n */\nfunction urlEquals (A, B, excludeFragment = false) {\n const serializedA = URLSerializer(A, excludeFragment)\n\n const serializedB = URLSerializer(B, excludeFragment)\n\n return serializedA === serializedB\n}\n\n/**\n * @see https://github.com/chromium/chromium/blob/694d20d134cb553d8d89e5500b9148012b1ba299/content/browser/cache_storage/cache_storage_cache.cc#L260-L262\n * @param {string} header\n */\nfunction fieldValues (header) {\n assert(header !== null)\n\n const values = []\n\n for (let value of header.split(',')) {\n value = value.trim()\n\n if (!value.length) {\n continue\n } else if (!isValidHeaderName(value)) {\n continue\n }\n\n values.push(value)\n }\n\n return values\n}\n\nmodule.exports = {\n urlEquals,\n fieldValues\n}\n","// @ts-check\n\n'use strict'\n\n/* global WebAssembly */\n\nconst assert = require('assert')\nconst net = require('net')\nconst http = require('http')\nconst { pipeline } = require('stream')\nconst util = require('./core/util')\nconst timers = require('./timers')\nconst Request = require('./core/request')\nconst DispatcherBase = require('./dispatcher-base')\nconst {\n RequestContentLengthMismatchError,\n ResponseContentLengthMismatchError,\n InvalidArgumentError,\n RequestAbortedError,\n HeadersTimeoutError,\n HeadersOverflowError,\n SocketError,\n InformationalError,\n BodyTimeoutError,\n HTTPParserError,\n ResponseExceededMaxSizeError,\n ClientDestroyedError\n} = require('./core/errors')\nconst buildConnector = require('./core/connect')\nconst {\n kUrl,\n kReset,\n kServerName,\n kClient,\n kBusy,\n kParser,\n kConnect,\n kBlocking,\n kResuming,\n kRunning,\n kPending,\n kSize,\n kWriting,\n kQueue,\n kConnected,\n kConnecting,\n kNeedDrain,\n kNoRef,\n kKeepAliveDefaultTimeout,\n kHostHeader,\n kPendingIdx,\n kRunningIdx,\n kError,\n kPipelining,\n kSocket,\n kKeepAliveTimeoutValue,\n kMaxHeadersSize,\n kKeepAliveMaxTimeout,\n kKeepAliveTimeoutThreshold,\n kHeadersTimeout,\n kBodyTimeout,\n kStrictContentLength,\n kConnector,\n kMaxRedirections,\n kMaxRequests,\n kCounter,\n kClose,\n kDestroy,\n kDispatch,\n kInterceptors,\n kLocalAddress,\n kMaxResponseSize,\n kHTTPConnVersion,\n // HTTP2\n kHost,\n kHTTP2Session,\n kHTTP2SessionState,\n kHTTP2BuildRequest,\n kHTTP2CopyHeaders,\n kHTTP1BuildRequest\n} = require('./core/symbols')\n\n/** @type {import('http2')} */\nlet http2\ntry {\n http2 = require('http2')\n} catch {\n // @ts-ignore\n http2 = { constants: {} }\n}\n\nconst {\n constants: {\n HTTP2_HEADER_AUTHORITY,\n HTTP2_HEADER_METHOD,\n HTTP2_HEADER_PATH,\n HTTP2_HEADER_SCHEME,\n HTTP2_HEADER_CONTENT_LENGTH,\n HTTP2_HEADER_EXPECT,\n HTTP2_HEADER_STATUS\n }\n} = http2\n\n// Experimental\nlet h2ExperimentalWarned = false\n\nconst FastBuffer = Buffer[Symbol.species]\n\nconst kClosedResolve = Symbol('kClosedResolve')\n\nconst channels = {}\n\ntry {\n const diagnosticsChannel = require('diagnostics_channel')\n channels.sendHeaders = diagnosticsChannel.channel('undici:client:sendHeaders')\n channels.beforeConnect = diagnosticsChannel.channel('undici:client:beforeConnect')\n channels.connectError = diagnosticsChannel.channel('undici:client:connectError')\n channels.connected = diagnosticsChannel.channel('undici:client:connected')\n} catch {\n channels.sendHeaders = { hasSubscribers: false }\n channels.beforeConnect = { hasSubscribers: false }\n channels.connectError = { hasSubscribers: false }\n channels.connected = { hasSubscribers: false }\n}\n\n/**\n * @type {import('../types/client').default}\n */\nclass Client extends DispatcherBase {\n /**\n *\n * @param {string|URL} url\n * @param {import('../types/client').Client.Options} options\n */\n constructor (url, {\n interceptors,\n maxHeaderSize,\n headersTimeout,\n socketTimeout,\n requestTimeout,\n connectTimeout,\n bodyTimeout,\n idleTimeout,\n keepAlive,\n keepAliveTimeout,\n maxKeepAliveTimeout,\n keepAliveMaxTimeout,\n keepAliveTimeoutThreshold,\n socketPath,\n pipelining,\n tls,\n strictContentLength,\n maxCachedSessions,\n maxRedirections,\n connect,\n maxRequestsPerClient,\n localAddress,\n maxResponseSize,\n autoSelectFamily,\n autoSelectFamilyAttemptTimeout,\n // h2\n allowH2,\n maxConcurrentStreams\n } = {}) {\n super()\n\n if (keepAlive !== undefined) {\n throw new InvalidArgumentError('unsupported keepAlive, use pipelining=0 instead')\n }\n\n if (socketTimeout !== undefined) {\n throw new InvalidArgumentError('unsupported socketTimeout, use headersTimeout & bodyTimeout instead')\n }\n\n if (requestTimeout !== undefined) {\n throw new InvalidArgumentError('unsupported requestTimeout, use headersTimeout & bodyTimeout instead')\n }\n\n if (idleTimeout !== undefined) {\n throw new InvalidArgumentError('unsupported idleTimeout, use keepAliveTimeout instead')\n }\n\n if (maxKeepAliveTimeout !== undefined) {\n throw new InvalidArgumentError('unsupported maxKeepAliveTimeout, use keepAliveMaxTimeout instead')\n }\n\n if (maxHeaderSize != null && !Number.isFinite(maxHeaderSize)) {\n throw new InvalidArgumentError('invalid maxHeaderSize')\n }\n\n if (socketPath != null && typeof socketPath !== 'string') {\n throw new InvalidArgumentError('invalid socketPath')\n }\n\n if (connectTimeout != null && (!Number.isFinite(connectTimeout) || connectTimeout < 0)) {\n throw new InvalidArgumentError('invalid connectTimeout')\n }\n\n if (keepAliveTimeout != null && (!Number.isFinite(keepAliveTimeout) || keepAliveTimeout <= 0)) {\n throw new InvalidArgumentError('invalid keepAliveTimeout')\n }\n\n if (keepAliveMaxTimeout != null && (!Number.isFinite(keepAliveMaxTimeout) || keepAliveMaxTimeout <= 0)) {\n throw new InvalidArgumentError('invalid keepAliveMaxTimeout')\n }\n\n if (keepAliveTimeoutThreshold != null && !Number.isFinite(keepAliveTimeoutThreshold)) {\n throw new InvalidArgumentError('invalid keepAliveTimeoutThreshold')\n }\n\n if (headersTimeout != null && (!Number.isInteger(headersTimeout) || headersTimeout < 0)) {\n throw new InvalidArgumentError('headersTimeout must be a positive integer or zero')\n }\n\n if (bodyTimeout != null && (!Number.isInteger(bodyTimeout) || bodyTimeout < 0)) {\n throw new InvalidArgumentError('bodyTimeout must be a positive integer or zero')\n }\n\n if (connect != null && typeof connect !== 'function' && typeof connect !== 'object') {\n throw new InvalidArgumentError('connect must be a function or an object')\n }\n\n if (maxRedirections != null && (!Number.isInteger(maxRedirections) || maxRedirections < 0)) {\n throw new InvalidArgumentError('maxRedirections must be a positive number')\n }\n\n if (maxRequestsPerClient != null && (!Number.isInteger(maxRequestsPerClient) || maxRequestsPerClient < 0)) {\n throw new InvalidArgumentError('maxRequestsPerClient must be a positive number')\n }\n\n if (localAddress != null && (typeof localAddress !== 'string' || net.isIP(localAddress) === 0)) {\n throw new InvalidArgumentError('localAddress must be valid string IP address')\n }\n\n if (maxResponseSize != null && (!Number.isInteger(maxResponseSize) || maxResponseSize < -1)) {\n throw new InvalidArgumentError('maxResponseSize must be a positive number')\n }\n\n if (\n autoSelectFamilyAttemptTimeout != null &&\n (!Number.isInteger(autoSelectFamilyAttemptTimeout) || autoSelectFamilyAttemptTimeout < -1)\n ) {\n throw new InvalidArgumentError('autoSelectFamilyAttemptTimeout must be a positive number')\n }\n\n // h2\n if (allowH2 != null && typeof allowH2 !== 'boolean') {\n throw new InvalidArgumentError('allowH2 must be a valid boolean value')\n }\n\n if (maxConcurrentStreams != null && (typeof maxConcurrentStreams !== 'number' || maxConcurrentStreams < 1)) {\n throw new InvalidArgumentError('maxConcurrentStreams must be a possitive integer, greater than 0')\n }\n\n if (typeof connect !== 'function') {\n connect = buildConnector({\n ...tls,\n maxCachedSessions,\n allowH2,\n socketPath,\n timeout: connectTimeout,\n ...(util.nodeHasAutoSelectFamily && autoSelectFamily ? { autoSelectFamily, autoSelectFamilyAttemptTimeout } : undefined),\n ...connect\n })\n }\n\n this[kInterceptors] = interceptors && interceptors.Client && Array.isArray(interceptors.Client)\n ? interceptors.Client\n : [createRedirectInterceptor({ maxRedirections })]\n this[kUrl] = util.parseOrigin(url)\n this[kConnector] = connect\n this[kSocket] = null\n this[kPipelining] = pipelining != null ? pipelining : 1\n this[kMaxHeadersSize] = maxHeaderSize || http.maxHeaderSize\n this[kKeepAliveDefaultTimeout] = keepAliveTimeout == null ? 4e3 : keepAliveTimeout\n this[kKeepAliveMaxTimeout] = keepAliveMaxTimeout == null ? 600e3 : keepAliveMaxTimeout\n this[kKeepAliveTimeoutThreshold] = keepAliveTimeoutThreshold == null ? 1e3 : keepAliveTimeoutThreshold\n this[kKeepAliveTimeoutValue] = this[kKeepAliveDefaultTimeout]\n this[kServerName] = null\n this[kLocalAddress] = localAddress != null ? localAddress : null\n this[kResuming] = 0 // 0, idle, 1, scheduled, 2 resuming\n this[kNeedDrain] = 0 // 0, idle, 1, scheduled, 2 resuming\n this[kHostHeader] = `host: ${this[kUrl].hostname}${this[kUrl].port ? `:${this[kUrl].port}` : ''}\\r\\n`\n this[kBodyTimeout] = bodyTimeout != null ? bodyTimeout : 300e3\n this[kHeadersTimeout] = headersTimeout != null ? headersTimeout : 300e3\n this[kStrictContentLength] = strictContentLength == null ? true : strictContentLength\n this[kMaxRedirections] = maxRedirections\n this[kMaxRequests] = maxRequestsPerClient\n this[kClosedResolve] = null\n this[kMaxResponseSize] = maxResponseSize > -1 ? maxResponseSize : -1\n this[kHTTPConnVersion] = 'h1'\n\n // HTTP/2\n this[kHTTP2Session] = null\n this[kHTTP2SessionState] = !allowH2\n ? null\n : {\n // streams: null, // Fixed queue of streams - For future support of `push`\n openStreams: 0, // Keep track of them to decide wether or not unref the session\n maxConcurrentStreams: maxConcurrentStreams != null ? maxConcurrentStreams : 100 // Max peerConcurrentStreams for a Node h2 server\n }\n this[kHost] = `${this[kUrl].hostname}${this[kUrl].port ? `:${this[kUrl].port}` : ''}`\n\n // kQueue is built up of 3 sections separated by\n // the kRunningIdx and kPendingIdx indices.\n // | complete | running | pending |\n // ^ kRunningIdx ^ kPendingIdx ^ kQueue.length\n // kRunningIdx points to the first running element.\n // kPendingIdx points to the first pending element.\n // This implements a fast queue with an amortized\n // time of O(1).\n\n this[kQueue] = []\n this[kRunningIdx] = 0\n this[kPendingIdx] = 0\n }\n\n get pipelining () {\n return this[kPipelining]\n }\n\n set pipelining (value) {\n this[kPipelining] = value\n resume(this, true)\n }\n\n get [kPending] () {\n return this[kQueue].length - this[kPendingIdx]\n }\n\n get [kRunning] () {\n return this[kPendingIdx] - this[kRunningIdx]\n }\n\n get [kSize] () {\n return this[kQueue].length - this[kRunningIdx]\n }\n\n get [kConnected] () {\n return !!this[kSocket] && !this[kConnecting] && !this[kSocket].destroyed\n }\n\n get [kBusy] () {\n const socket = this[kSocket]\n return (\n (socket && (socket[kReset] || socket[kWriting] || socket[kBlocking])) ||\n (this[kSize] >= (this[kPipelining] || 1)) ||\n this[kPending] > 0\n )\n }\n\n /* istanbul ignore: only used for test */\n [kConnect] (cb) {\n connect(this)\n this.once('connect', cb)\n }\n\n [kDispatch] (opts, handler) {\n const origin = opts.origin || this[kUrl].origin\n\n const request = this[kHTTPConnVersion] === 'h2'\n ? Request[kHTTP2BuildRequest](origin, opts, handler)\n : Request[kHTTP1BuildRequest](origin, opts, handler)\n\n this[kQueue].push(request)\n if (this[kResuming]) {\n // Do nothing.\n } else if (util.bodyLength(request.body) == null && util.isIterable(request.body)) {\n // Wait a tick in case stream/iterator is ended in the same tick.\n this[kResuming] = 1\n process.nextTick(resume, this)\n } else {\n resume(this, true)\n }\n\n if (this[kResuming] && this[kNeedDrain] !== 2 && this[kBusy]) {\n this[kNeedDrain] = 2\n }\n\n return this[kNeedDrain] < 2\n }\n\n async [kClose] () {\n // TODO: for H2 we need to gracefully flush the remaining enqueued\n // request and close each stream.\n return new Promise((resolve) => {\n if (!this[kSize]) {\n resolve(null)\n } else {\n this[kClosedResolve] = resolve\n }\n })\n }\n\n async [kDestroy] (err) {\n return new Promise((resolve) => {\n const requests = this[kQueue].splice(this[kPendingIdx])\n for (let i = 0; i < requests.length; i++) {\n const request = requests[i]\n errorRequest(this, request, err)\n }\n\n const callback = () => {\n if (this[kClosedResolve]) {\n // TODO (fix): Should we error here with ClientDestroyedError?\n this[kClosedResolve]()\n this[kClosedResolve] = null\n }\n resolve()\n }\n\n if (this[kHTTP2Session] != null) {\n util.destroy(this[kHTTP2Session], err)\n this[kHTTP2Session] = null\n this[kHTTP2SessionState] = null\n }\n\n if (!this[kSocket]) {\n queueMicrotask(callback)\n } else {\n util.destroy(this[kSocket].on('close', callback), err)\n }\n\n resume(this)\n })\n }\n}\n\nfunction onHttp2SessionError (err) {\n assert(err.code !== 'ERR_TLS_CERT_ALTNAME_INVALID')\n\n this[kSocket][kError] = err\n\n onError(this[kClient], err)\n}\n\nfunction onHttp2FrameError (type, code, id) {\n const err = new InformationalError(`HTTP/2: \"frameError\" received - type ${type}, code ${code}`)\n\n if (id === 0) {\n this[kSocket][kError] = err\n onError(this[kClient], err)\n }\n}\n\nfunction onHttp2SessionEnd () {\n util.destroy(this, new SocketError('other side closed'))\n util.destroy(this[kSocket], new SocketError('other side closed'))\n}\n\nfunction onHTTP2GoAway (code) {\n const client = this[kClient]\n const err = new InformationalError(`HTTP/2: \"GOAWAY\" frame received with code ${code}`)\n client[kSocket] = null\n client[kHTTP2Session] = null\n\n if (client.destroyed) {\n assert(this[kPending] === 0)\n\n // Fail entire queue.\n const requests = client[kQueue].splice(client[kRunningIdx])\n for (let i = 0; i < requests.length; i++) {\n const request = requests[i]\n errorRequest(this, request, err)\n }\n } else if (client[kRunning] > 0) {\n // Fail head of pipeline.\n const request = client[kQueue][client[kRunningIdx]]\n client[kQueue][client[kRunningIdx]++] = null\n\n errorRequest(client, request, err)\n }\n\n client[kPendingIdx] = client[kRunningIdx]\n\n assert(client[kRunning] === 0)\n\n client.emit('disconnect',\n client[kUrl],\n [client],\n err\n )\n\n resume(client)\n}\n\nconst constants = require('./llhttp/constants')\nconst createRedirectInterceptor = require('./interceptor/redirectInterceptor')\nconst EMPTY_BUF = Buffer.alloc(0)\n\nasync function lazyllhttp () {\n const llhttpWasmData = process.env.JEST_WORKER_ID ? require('./llhttp/llhttp-wasm.js') : undefined\n\n let mod\n try {\n mod = await WebAssembly.compile(Buffer.from(require('./llhttp/llhttp_simd-wasm.js'), 'base64'))\n } catch (e) {\n /* istanbul ignore next */\n\n // We could check if the error was caused by the simd option not\n // being enabled, but the occurring of this other error\n // * https://github.com/emscripten-core/emscripten/issues/11495\n // got me to remove that check to avoid breaking Node 12.\n mod = await WebAssembly.compile(Buffer.from(llhttpWasmData || require('./llhttp/llhttp-wasm.js'), 'base64'))\n }\n\n return await WebAssembly.instantiate(mod, {\n env: {\n /* eslint-disable camelcase */\n\n wasm_on_url: (p, at, len) => {\n /* istanbul ignore next */\n return 0\n },\n wasm_on_status: (p, at, len) => {\n assert.strictEqual(currentParser.ptr, p)\n const start = at - currentBufferPtr + currentBufferRef.byteOffset\n return currentParser.onStatus(new FastBuffer(currentBufferRef.buffer, start, len)) || 0\n },\n wasm_on_message_begin: (p) => {\n assert.strictEqual(currentParser.ptr, p)\n return currentParser.onMessageBegin() || 0\n },\n wasm_on_header_field: (p, at, len) => {\n assert.strictEqual(currentParser.ptr, p)\n const start = at - currentBufferPtr + currentBufferRef.byteOffset\n return currentParser.onHeaderField(new FastBuffer(currentBufferRef.buffer, start, len)) || 0\n },\n wasm_on_header_value: (p, at, len) => {\n assert.strictEqual(currentParser.ptr, p)\n const start = at - currentBufferPtr + currentBufferRef.byteOffset\n return currentParser.onHeaderValue(new FastBuffer(currentBufferRef.buffer, start, len)) || 0\n },\n wasm_on_headers_complete: (p, statusCode, upgrade, shouldKeepAlive) => {\n assert.strictEqual(currentParser.ptr, p)\n return currentParser.onHeadersComplete(statusCode, Boolean(upgrade), Boolean(shouldKeepAlive)) || 0\n },\n wasm_on_body: (p, at, len) => {\n assert.strictEqual(currentParser.ptr, p)\n const start = at - currentBufferPtr + currentBufferRef.byteOffset\n return currentParser.onBody(new FastBuffer(currentBufferRef.buffer, start, len)) || 0\n },\n wasm_on_message_complete: (p) => {\n assert.strictEqual(currentParser.ptr, p)\n return currentParser.onMessageComplete() || 0\n }\n\n /* eslint-enable camelcase */\n }\n })\n}\n\nlet llhttpInstance = null\nlet llhttpPromise = lazyllhttp()\nllhttpPromise.catch()\n\nlet currentParser = null\nlet currentBufferRef = null\nlet currentBufferSize = 0\nlet currentBufferPtr = null\n\nconst TIMEOUT_HEADERS = 1\nconst TIMEOUT_BODY = 2\nconst TIMEOUT_IDLE = 3\n\nclass Parser {\n constructor (client, socket, { exports }) {\n assert(Number.isFinite(client[kMaxHeadersSize]) && client[kMaxHeadersSize] > 0)\n\n this.llhttp = exports\n this.ptr = this.llhttp.llhttp_alloc(constants.TYPE.RESPONSE)\n this.client = client\n this.socket = socket\n this.timeout = null\n this.timeoutValue = null\n this.timeoutType = null\n this.statusCode = null\n this.statusText = ''\n this.upgrade = false\n this.headers = []\n this.headersSize = 0\n this.headersMaxSize = client[kMaxHeadersSize]\n this.shouldKeepAlive = false\n this.paused = false\n this.resume = this.resume.bind(this)\n\n this.bytesRead = 0\n\n this.keepAlive = ''\n this.contentLength = ''\n this.connection = ''\n this.maxResponseSize = client[kMaxResponseSize]\n }\n\n setTimeout (value, type) {\n this.timeoutType = type\n if (value !== this.timeoutValue) {\n timers.clearTimeout(this.timeout)\n if (value) {\n this.timeout = timers.setTimeout(onParserTimeout, value, this)\n // istanbul ignore else: only for jest\n if (this.timeout.unref) {\n this.timeout.unref()\n }\n } else {\n this.timeout = null\n }\n this.timeoutValue = value\n } else if (this.timeout) {\n // istanbul ignore else: only for jest\n if (this.timeout.refresh) {\n this.timeout.refresh()\n }\n }\n }\n\n resume () {\n if (this.socket.destroyed || !this.paused) {\n return\n }\n\n assert(this.ptr != null)\n assert(currentParser == null)\n\n this.llhttp.llhttp_resume(this.ptr)\n\n assert(this.timeoutType === TIMEOUT_BODY)\n if (this.timeout) {\n // istanbul ignore else: only for jest\n if (this.timeout.refresh) {\n this.timeout.refresh()\n }\n }\n\n this.paused = false\n this.execute(this.socket.read() || EMPTY_BUF) // Flush parser.\n this.readMore()\n }\n\n readMore () {\n while (!this.paused && this.ptr) {\n const chunk = this.socket.read()\n if (chunk === null) {\n break\n }\n this.execute(chunk)\n }\n }\n\n execute (data) {\n assert(this.ptr != null)\n assert(currentParser == null)\n assert(!this.paused)\n\n const { socket, llhttp } = this\n\n if (data.length > currentBufferSize) {\n if (currentBufferPtr) {\n llhttp.free(currentBufferPtr)\n }\n currentBufferSize = Math.ceil(data.length / 4096) * 4096\n currentBufferPtr = llhttp.malloc(currentBufferSize)\n }\n\n new Uint8Array(llhttp.memory.buffer, currentBufferPtr, currentBufferSize).set(data)\n\n // Call `execute` on the wasm parser.\n // We pass the `llhttp_parser` pointer address, the pointer address of buffer view data,\n // and finally the length of bytes to parse.\n // The return value is an error code or `constants.ERROR.OK`.\n try {\n let ret\n\n try {\n currentBufferRef = data\n currentParser = this\n ret = llhttp.llhttp_execute(this.ptr, currentBufferPtr, data.length)\n /* eslint-disable-next-line no-useless-catch */\n } catch (err) {\n /* istanbul ignore next: difficult to make a test case for */\n throw err\n } finally {\n currentParser = null\n currentBufferRef = null\n }\n\n const offset = llhttp.llhttp_get_error_pos(this.ptr) - currentBufferPtr\n\n if (ret === constants.ERROR.PAUSED_UPGRADE) {\n this.onUpgrade(data.slice(offset))\n } else if (ret === constants.ERROR.PAUSED) {\n this.paused = true\n socket.unshift(data.slice(offset))\n } else if (ret !== constants.ERROR.OK) {\n const ptr = llhttp.llhttp_get_error_reason(this.ptr)\n let message = ''\n /* istanbul ignore else: difficult to make a test case for */\n if (ptr) {\n const len = new Uint8Array(llhttp.memory.buffer, ptr).indexOf(0)\n message =\n 'Response does not match the HTTP/1.1 protocol (' +\n Buffer.from(llhttp.memory.buffer, ptr, len).toString() +\n ')'\n }\n throw new HTTPParserError(message, constants.ERROR[ret], data.slice(offset))\n }\n } catch (err) {\n util.destroy(socket, err)\n }\n }\n\n destroy () {\n assert(this.ptr != null)\n assert(currentParser == null)\n\n this.llhttp.llhttp_free(this.ptr)\n this.ptr = null\n\n timers.clearTimeout(this.timeout)\n this.timeout = null\n this.timeoutValue = null\n this.timeoutType = null\n\n this.paused = false\n }\n\n onStatus (buf) {\n this.statusText = buf.toString()\n }\n\n onMessageBegin () {\n const { socket, client } = this\n\n /* istanbul ignore next: difficult to make a test case for */\n if (socket.destroyed) {\n return -1\n }\n\n const request = client[kQueue][client[kRunningIdx]]\n if (!request) {\n return -1\n }\n }\n\n onHeaderField (buf) {\n const len = this.headers.length\n\n if ((len & 1) === 0) {\n this.headers.push(buf)\n } else {\n this.headers[len - 1] = Buffer.concat([this.headers[len - 1], buf])\n }\n\n this.trackHeader(buf.length)\n }\n\n onHeaderValue (buf) {\n let len = this.headers.length\n\n if ((len & 1) === 1) {\n this.headers.push(buf)\n len += 1\n } else {\n this.headers[len - 1] = Buffer.concat([this.headers[len - 1], buf])\n }\n\n const key = this.headers[len - 2]\n if (key.length === 10 && key.toString().toLowerCase() === 'keep-alive') {\n this.keepAlive += buf.toString()\n } else if (key.length === 10 && key.toString().toLowerCase() === 'connection') {\n this.connection += buf.toString()\n } else if (key.length === 14 && key.toString().toLowerCase() === 'content-length') {\n this.contentLength += buf.toString()\n }\n\n this.trackHeader(buf.length)\n }\n\n trackHeader (len) {\n this.headersSize += len\n if (this.headersSize >= this.headersMaxSize) {\n util.destroy(this.socket, new HeadersOverflowError())\n }\n }\n\n onUpgrade (head) {\n const { upgrade, client, socket, headers, statusCode } = this\n\n assert(upgrade)\n\n const request = client[kQueue][client[kRunningIdx]]\n assert(request)\n\n assert(!socket.destroyed)\n assert(socket === client[kSocket])\n assert(!this.paused)\n assert(request.upgrade || request.method === 'CONNECT')\n\n this.statusCode = null\n this.statusText = ''\n this.shouldKeepAlive = null\n\n assert(this.headers.length % 2 === 0)\n this.headers = []\n this.headersSize = 0\n\n socket.unshift(head)\n\n socket[kParser].destroy()\n socket[kParser] = null\n\n socket[kClient] = null\n socket[kError] = null\n socket\n .removeListener('error', onSocketError)\n .removeListener('readable', onSocketReadable)\n .removeListener('end', onSocketEnd)\n .removeListener('close', onSocketClose)\n\n client[kSocket] = null\n client[kQueue][client[kRunningIdx]++] = null\n client.emit('disconnect', client[kUrl], [client], new InformationalError('upgrade'))\n\n try {\n request.onUpgrade(statusCode, headers, socket)\n } catch (err) {\n util.destroy(socket, err)\n }\n\n resume(client)\n }\n\n onHeadersComplete (statusCode, upgrade, shouldKeepAlive) {\n const { client, socket, headers, statusText } = this\n\n /* istanbul ignore next: difficult to make a test case for */\n if (socket.destroyed) {\n return -1\n }\n\n const request = client[kQueue][client[kRunningIdx]]\n\n /* istanbul ignore next: difficult to make a test case for */\n if (!request) {\n return -1\n }\n\n assert(!this.upgrade)\n assert(this.statusCode < 200)\n\n if (statusCode === 100) {\n util.destroy(socket, new SocketError('bad response', util.getSocketInfo(socket)))\n return -1\n }\n\n /* this can only happen if server is misbehaving */\n if (upgrade && !request.upgrade) {\n util.destroy(socket, new SocketError('bad upgrade', util.getSocketInfo(socket)))\n return -1\n }\n\n assert.strictEqual(this.timeoutType, TIMEOUT_HEADERS)\n\n this.statusCode = statusCode\n this.shouldKeepAlive = (\n shouldKeepAlive ||\n // Override llhttp value which does not allow keepAlive for HEAD.\n (request.method === 'HEAD' && !socket[kReset] && this.connection.toLowerCase() === 'keep-alive')\n )\n\n if (this.statusCode >= 200) {\n const bodyTimeout = request.bodyTimeout != null\n ? request.bodyTimeout\n : client[kBodyTimeout]\n this.setTimeout(bodyTimeout, TIMEOUT_BODY)\n } else if (this.timeout) {\n // istanbul ignore else: only for jest\n if (this.timeout.refresh) {\n this.timeout.refresh()\n }\n }\n\n if (request.method === 'CONNECT') {\n assert(client[kRunning] === 1)\n this.upgrade = true\n return 2\n }\n\n if (upgrade) {\n assert(client[kRunning] === 1)\n this.upgrade = true\n return 2\n }\n\n assert(this.headers.length % 2 === 0)\n this.headers = []\n this.headersSize = 0\n\n if (this.shouldKeepAlive && client[kPipelining]) {\n const keepAliveTimeout = this.keepAlive ? util.parseKeepAliveTimeout(this.keepAlive) : null\n\n if (keepAliveTimeout != null) {\n const timeout = Math.min(\n keepAliveTimeout - client[kKeepAliveTimeoutThreshold],\n client[kKeepAliveMaxTimeout]\n )\n if (timeout <= 0) {\n socket[kReset] = true\n } else {\n client[kKeepAliveTimeoutValue] = timeout\n }\n } else {\n client[kKeepAliveTimeoutValue] = client[kKeepAliveDefaultTimeout]\n }\n } else {\n // Stop more requests from being dispatched.\n socket[kReset] = true\n }\n\n const pause = request.onHeaders(statusCode, headers, this.resume, statusText) === false\n\n if (request.aborted) {\n return -1\n }\n\n if (request.method === 'HEAD') {\n return 1\n }\n\n if (statusCode < 200) {\n return 1\n }\n\n if (socket[kBlocking]) {\n socket[kBlocking] = false\n resume(client)\n }\n\n return pause ? constants.ERROR.PAUSED : 0\n }\n\n onBody (buf) {\n const { client, socket, statusCode, maxResponseSize } = this\n\n if (socket.destroyed) {\n return -1\n }\n\n const request = client[kQueue][client[kRunningIdx]]\n assert(request)\n\n assert.strictEqual(this.timeoutType, TIMEOUT_BODY)\n if (this.timeout) {\n // istanbul ignore else: only for jest\n if (this.timeout.refresh) {\n this.timeout.refresh()\n }\n }\n\n assert(statusCode >= 200)\n\n if (maxResponseSize > -1 && this.bytesRead + buf.length > maxResponseSize) {\n util.destroy(socket, new ResponseExceededMaxSizeError())\n return -1\n }\n\n this.bytesRead += buf.length\n\n if (request.onData(buf) === false) {\n return constants.ERROR.PAUSED\n }\n }\n\n onMessageComplete () {\n const { client, socket, statusCode, upgrade, headers, contentLength, bytesRead, shouldKeepAlive } = this\n\n if (socket.destroyed && (!statusCode || shouldKeepAlive)) {\n return -1\n }\n\n if (upgrade) {\n return\n }\n\n const request = client[kQueue][client[kRunningIdx]]\n assert(request)\n\n assert(statusCode >= 100)\n\n this.statusCode = null\n this.statusText = ''\n this.bytesRead = 0\n this.contentLength = ''\n this.keepAlive = ''\n this.connection = ''\n\n assert(this.headers.length % 2 === 0)\n this.headers = []\n this.headersSize = 0\n\n if (statusCode < 200) {\n return\n }\n\n /* istanbul ignore next: should be handled by llhttp? */\n if (request.method !== 'HEAD' && contentLength && bytesRead !== parseInt(contentLength, 10)) {\n util.destroy(socket, new ResponseContentLengthMismatchError())\n return -1\n }\n\n request.onComplete(headers)\n\n client[kQueue][client[kRunningIdx]++] = null\n\n if (socket[kWriting]) {\n assert.strictEqual(client[kRunning], 0)\n // Response completed before request.\n util.destroy(socket, new InformationalError('reset'))\n return constants.ERROR.PAUSED\n } else if (!shouldKeepAlive) {\n util.destroy(socket, new InformationalError('reset'))\n return constants.ERROR.PAUSED\n } else if (socket[kReset] && client[kRunning] === 0) {\n // Destroy socket once all requests have completed.\n // The request at the tail of the pipeline is the one\n // that requested reset and no further requests should\n // have been queued since then.\n util.destroy(socket, new InformationalError('reset'))\n return constants.ERROR.PAUSED\n } else if (client[kPipelining] === 1) {\n // We must wait a full event loop cycle to reuse this socket to make sure\n // that non-spec compliant servers are not closing the connection even if they\n // said they won't.\n setImmediate(resume, client)\n } else {\n resume(client)\n }\n }\n}\n\nfunction onParserTimeout (parser) {\n const { socket, timeoutType, client } = parser\n\n /* istanbul ignore else */\n if (timeoutType === TIMEOUT_HEADERS) {\n if (!socket[kWriting] || socket.writableNeedDrain || client[kRunning] > 1) {\n assert(!parser.paused, 'cannot be paused while waiting for headers')\n util.destroy(socket, new HeadersTimeoutError())\n }\n } else if (timeoutType === TIMEOUT_BODY) {\n if (!parser.paused) {\n util.destroy(socket, new BodyTimeoutError())\n }\n } else if (timeoutType === TIMEOUT_IDLE) {\n assert(client[kRunning] === 0 && client[kKeepAliveTimeoutValue])\n util.destroy(socket, new InformationalError('socket idle timeout'))\n }\n}\n\nfunction onSocketReadable () {\n const { [kParser]: parser } = this\n if (parser) {\n parser.readMore()\n }\n}\n\nfunction onSocketError (err) {\n const { [kClient]: client, [kParser]: parser } = this\n\n assert(err.code !== 'ERR_TLS_CERT_ALTNAME_INVALID')\n\n if (client[kHTTPConnVersion] !== 'h2') {\n // On Mac OS, we get an ECONNRESET even if there is a full body to be forwarded\n // to the user.\n if (err.code === 'ECONNRESET' && parser.statusCode && !parser.shouldKeepAlive) {\n // We treat all incoming data so for as a valid response.\n parser.onMessageComplete()\n return\n }\n }\n\n this[kError] = err\n\n onError(this[kClient], err)\n}\n\nfunction onError (client, err) {\n if (\n client[kRunning] === 0 &&\n err.code !== 'UND_ERR_INFO' &&\n err.code !== 'UND_ERR_SOCKET'\n ) {\n // Error is not caused by running request and not a recoverable\n // socket error.\n\n assert(client[kPendingIdx] === client[kRunningIdx])\n\n const requests = client[kQueue].splice(client[kRunningIdx])\n for (let i = 0; i < requests.length; i++) {\n const request = requests[i]\n errorRequest(client, request, err)\n }\n assert(client[kSize] === 0)\n }\n}\n\nfunction onSocketEnd () {\n const { [kParser]: parser, [kClient]: client } = this\n\n if (client[kHTTPConnVersion] !== 'h2') {\n if (parser.statusCode && !parser.shouldKeepAlive) {\n // We treat all incoming data so far as a valid response.\n parser.onMessageComplete()\n return\n }\n }\n\n util.destroy(this, new SocketError('other side closed', util.getSocketInfo(this)))\n}\n\nfunction onSocketClose () {\n const { [kClient]: client, [kParser]: parser } = this\n\n if (client[kHTTPConnVersion] === 'h1' && parser) {\n if (!this[kError] && parser.statusCode && !parser.shouldKeepAlive) {\n // We treat all incoming data so far as a valid response.\n parser.onMessageComplete()\n }\n\n this[kParser].destroy()\n this[kParser] = null\n }\n\n const err = this[kError] || new SocketError('closed', util.getSocketInfo(this))\n\n client[kSocket] = null\n\n if (client.destroyed) {\n assert(client[kPending] === 0)\n\n // Fail entire queue.\n const requests = client[kQueue].splice(client[kRunningIdx])\n for (let i = 0; i < requests.length; i++) {\n const request = requests[i]\n errorRequest(client, request, err)\n }\n } else if (client[kRunning] > 0 && err.code !== 'UND_ERR_INFO') {\n // Fail head of pipeline.\n const request = client[kQueue][client[kRunningIdx]]\n client[kQueue][client[kRunningIdx]++] = null\n\n errorRequest(client, request, err)\n }\n\n client[kPendingIdx] = client[kRunningIdx]\n\n assert(client[kRunning] === 0)\n\n client.emit('disconnect', client[kUrl], [client], err)\n\n resume(client)\n}\n\nasync function connect (client) {\n assert(!client[kConnecting])\n assert(!client[kSocket])\n\n let { host, hostname, protocol, port } = client[kUrl]\n\n // Resolve ipv6\n if (hostname[0] === '[') {\n const idx = hostname.indexOf(']')\n\n assert(idx !== -1)\n const ip = hostname.substring(1, idx)\n\n assert(net.isIP(ip))\n hostname = ip\n }\n\n client[kConnecting] = true\n\n if (channels.beforeConnect.hasSubscribers) {\n channels.beforeConnect.publish({\n connectParams: {\n host,\n hostname,\n protocol,\n port,\n servername: client[kServerName],\n localAddress: client[kLocalAddress]\n },\n connector: client[kConnector]\n })\n }\n\n try {\n const socket = await new Promise((resolve, reject) => {\n client[kConnector]({\n host,\n hostname,\n protocol,\n port,\n servername: client[kServerName],\n localAddress: client[kLocalAddress]\n }, (err, socket) => {\n if (err) {\n reject(err)\n } else {\n resolve(socket)\n }\n })\n })\n\n if (client.destroyed) {\n util.destroy(socket.on('error', () => {}), new ClientDestroyedError())\n return\n }\n\n client[kConnecting] = false\n\n assert(socket)\n\n const isH2 = socket.alpnProtocol === 'h2'\n if (isH2) {\n if (!h2ExperimentalWarned) {\n h2ExperimentalWarned = true\n process.emitWarning('H2 support is experimental, expect them to change at any time.', {\n code: 'UNDICI-H2'\n })\n }\n\n const session = http2.connect(client[kUrl], {\n createConnection: () => socket,\n peerMaxConcurrentStreams: client[kHTTP2SessionState].maxConcurrentStreams\n })\n\n client[kHTTPConnVersion] = 'h2'\n session[kClient] = client\n session[kSocket] = socket\n session.on('error', onHttp2SessionError)\n session.on('frameError', onHttp2FrameError)\n session.on('end', onHttp2SessionEnd)\n session.on('goaway', onHTTP2GoAway)\n session.on('close', onSocketClose)\n session.unref()\n\n client[kHTTP2Session] = session\n socket[kHTTP2Session] = session\n } else {\n if (!llhttpInstance) {\n llhttpInstance = await llhttpPromise\n llhttpPromise = null\n }\n\n socket[kNoRef] = false\n socket[kWriting] = false\n socket[kReset] = false\n socket[kBlocking] = false\n socket[kParser] = new Parser(client, socket, llhttpInstance)\n }\n\n socket[kCounter] = 0\n socket[kMaxRequests] = client[kMaxRequests]\n socket[kClient] = client\n socket[kError] = null\n\n socket\n .on('error', onSocketError)\n .on('readable', onSocketReadable)\n .on('end', onSocketEnd)\n .on('close', onSocketClose)\n\n client[kSocket] = socket\n\n if (channels.connected.hasSubscribers) {\n channels.connected.publish({\n connectParams: {\n host,\n hostname,\n protocol,\n port,\n servername: client[kServerName],\n localAddress: client[kLocalAddress]\n },\n connector: client[kConnector],\n socket\n })\n }\n client.emit('connect', client[kUrl], [client])\n } catch (err) {\n if (client.destroyed) {\n return\n }\n\n client[kConnecting] = false\n\n if (channels.connectError.hasSubscribers) {\n channels.connectError.publish({\n connectParams: {\n host,\n hostname,\n protocol,\n port,\n servername: client[kServerName],\n localAddress: client[kLocalAddress]\n },\n connector: client[kConnector],\n error: err\n })\n }\n\n if (err.code === 'ERR_TLS_CERT_ALTNAME_INVALID') {\n assert(client[kRunning] === 0)\n while (client[kPending] > 0 && client[kQueue][client[kPendingIdx]].servername === client[kServerName]) {\n const request = client[kQueue][client[kPendingIdx]++]\n errorRequest(client, request, err)\n }\n } else {\n onError(client, err)\n }\n\n client.emit('connectionError', client[kUrl], [client], err)\n }\n\n resume(client)\n}\n\nfunction emitDrain (client) {\n client[kNeedDrain] = 0\n client.emit('drain', client[kUrl], [client])\n}\n\nfunction resume (client, sync) {\n if (client[kResuming] === 2) {\n return\n }\n\n client[kResuming] = 2\n\n _resume(client, sync)\n client[kResuming] = 0\n\n if (client[kRunningIdx] > 256) {\n client[kQueue].splice(0, client[kRunningIdx])\n client[kPendingIdx] -= client[kRunningIdx]\n client[kRunningIdx] = 0\n }\n}\n\nfunction _resume (client, sync) {\n while (true) {\n if (client.destroyed) {\n assert(client[kPending] === 0)\n return\n }\n\n if (client[kClosedResolve] && !client[kSize]) {\n client[kClosedResolve]()\n client[kClosedResolve] = null\n return\n }\n\n const socket = client[kSocket]\n\n if (socket && !socket.destroyed && socket.alpnProtocol !== 'h2') {\n if (client[kSize] === 0) {\n if (!socket[kNoRef] && socket.unref) {\n socket.unref()\n socket[kNoRef] = true\n }\n } else if (socket[kNoRef] && socket.ref) {\n socket.ref()\n socket[kNoRef] = false\n }\n\n if (client[kSize] === 0) {\n if (socket[kParser].timeoutType !== TIMEOUT_IDLE) {\n socket[kParser].setTimeout(client[kKeepAliveTimeoutValue], TIMEOUT_IDLE)\n }\n } else if (client[kRunning] > 0 && socket[kParser].statusCode < 200) {\n if (socket[kParser].timeoutType !== TIMEOUT_HEADERS) {\n const request = client[kQueue][client[kRunningIdx]]\n const headersTimeout = request.headersTimeout != null\n ? request.headersTimeout\n : client[kHeadersTimeout]\n socket[kParser].setTimeout(headersTimeout, TIMEOUT_HEADERS)\n }\n }\n }\n\n if (client[kBusy]) {\n client[kNeedDrain] = 2\n } else if (client[kNeedDrain] === 2) {\n if (sync) {\n client[kNeedDrain] = 1\n process.nextTick(emitDrain, client)\n } else {\n emitDrain(client)\n }\n continue\n }\n\n if (client[kPending] === 0) {\n return\n }\n\n if (client[kRunning] >= (client[kPipelining] || 1)) {\n return\n }\n\n const request = client[kQueue][client[kPendingIdx]]\n\n if (client[kUrl].protocol === 'https:' && client[kServerName] !== request.servername) {\n if (client[kRunning] > 0) {\n return\n }\n\n client[kServerName] = request.servername\n\n if (socket && socket.servername !== request.servername) {\n util.destroy(socket, new InformationalError('servername changed'))\n return\n }\n }\n\n if (client[kConnecting]) {\n return\n }\n\n if (!socket && !client[kHTTP2Session]) {\n connect(client)\n return\n }\n\n if (socket.destroyed || socket[kWriting] || socket[kReset] || socket[kBlocking]) {\n return\n }\n\n if (client[kRunning] > 0 && !request.idempotent) {\n // Non-idempotent request cannot be retried.\n // Ensure that no other requests are inflight and\n // could cause failure.\n return\n }\n\n if (client[kRunning] > 0 && (request.upgrade || request.method === 'CONNECT')) {\n // Don't dispatch an upgrade until all preceding requests have completed.\n // A misbehaving server might upgrade the connection before all pipelined\n // request has completed.\n return\n }\n\n if (client[kRunning] > 0 && util.bodyLength(request.body) !== 0 &&\n (util.isStream(request.body) || util.isAsyncIterable(request.body))) {\n // Request with stream or iterator body can error while other requests\n // are inflight and indirectly error those as well.\n // Ensure this doesn't happen by waiting for inflight\n // to complete before dispatching.\n\n // Request with stream or iterator body cannot be retried.\n // Ensure that no other requests are inflight and\n // could cause failure.\n return\n }\n\n if (!request.aborted && write(client, request)) {\n client[kPendingIdx]++\n } else {\n client[kQueue].splice(client[kPendingIdx], 1)\n }\n }\n}\n\n// https://www.rfc-editor.org/rfc/rfc7230#section-3.3.2\nfunction shouldSendContentLength (method) {\n return method !== 'GET' && method !== 'HEAD' && method !== 'OPTIONS' && method !== 'TRACE' && method !== 'CONNECT'\n}\n\nfunction write (client, request) {\n if (client[kHTTPConnVersion] === 'h2') {\n writeH2(client, client[kHTTP2Session], request)\n return\n }\n\n const { body, method, path, host, upgrade, headers, blocking, reset } = request\n\n // https://tools.ietf.org/html/rfc7231#section-4.3.1\n // https://tools.ietf.org/html/rfc7231#section-4.3.2\n // https://tools.ietf.org/html/rfc7231#section-4.3.5\n\n // Sending a payload body on a request that does not\n // expect it can cause undefined behavior on some\n // servers and corrupt connection state. Do not\n // re-use the connection for further requests.\n\n const expectsPayload = (\n method === 'PUT' ||\n method === 'POST' ||\n method === 'PATCH'\n )\n\n if (body && typeof body.read === 'function') {\n // Try to read EOF in order to get length.\n body.read(0)\n }\n\n const bodyLength = util.bodyLength(body)\n\n let contentLength = bodyLength\n\n if (contentLength === null) {\n contentLength = request.contentLength\n }\n\n if (contentLength === 0 && !expectsPayload) {\n // https://tools.ietf.org/html/rfc7230#section-3.3.2\n // A user agent SHOULD NOT send a Content-Length header field when\n // the request message does not contain a payload body and the method\n // semantics do not anticipate such a body.\n\n contentLength = null\n }\n\n // https://github.com/nodejs/undici/issues/2046\n // A user agent may send a Content-Length header with 0 value, this should be allowed.\n if (shouldSendContentLength(method) && contentLength > 0 && request.contentLength !== null && request.contentLength !== contentLength) {\n if (client[kStrictContentLength]) {\n errorRequest(client, request, new RequestContentLengthMismatchError())\n return false\n }\n\n process.emitWarning(new RequestContentLengthMismatchError())\n }\n\n const socket = client[kSocket]\n\n try {\n request.onConnect((err) => {\n if (request.aborted || request.completed) {\n return\n }\n\n errorRequest(client, request, err || new RequestAbortedError())\n\n util.destroy(socket, new InformationalError('aborted'))\n })\n } catch (err) {\n errorRequest(client, request, err)\n }\n\n if (request.aborted) {\n return false\n }\n\n if (method === 'HEAD') {\n // https://github.com/mcollina/undici/issues/258\n // Close after a HEAD request to interop with misbehaving servers\n // that may send a body in the response.\n\n socket[kReset] = true\n }\n\n if (upgrade || method === 'CONNECT') {\n // On CONNECT or upgrade, block pipeline from dispatching further\n // requests on this connection.\n\n socket[kReset] = true\n }\n\n if (reset != null) {\n socket[kReset] = reset\n }\n\n if (client[kMaxRequests] && socket[kCounter]++ >= client[kMaxRequests]) {\n socket[kReset] = true\n }\n\n if (blocking) {\n socket[kBlocking] = true\n }\n\n let header = `${method} ${path} HTTP/1.1\\r\\n`\n\n if (typeof host === 'string') {\n header += `host: ${host}\\r\\n`\n } else {\n header += client[kHostHeader]\n }\n\n if (upgrade) {\n header += `connection: upgrade\\r\\nupgrade: ${upgrade}\\r\\n`\n } else if (client[kPipelining] && !socket[kReset]) {\n header += 'connection: keep-alive\\r\\n'\n } else {\n header += 'connection: close\\r\\n'\n }\n\n if (headers) {\n header += headers\n }\n\n if (channels.sendHeaders.hasSubscribers) {\n channels.sendHeaders.publish({ request, headers: header, socket })\n }\n\n /* istanbul ignore else: assertion */\n if (!body || bodyLength === 0) {\n if (contentLength === 0) {\n socket.write(`${header}content-length: 0\\r\\n\\r\\n`, 'latin1')\n } else {\n assert(contentLength === null, 'no body must not have content length')\n socket.write(`${header}\\r\\n`, 'latin1')\n }\n request.onRequestSent()\n } else if (util.isBuffer(body)) {\n assert(contentLength === body.byteLength, 'buffer body must have content length')\n\n socket.cork()\n socket.write(`${header}content-length: ${contentLength}\\r\\n\\r\\n`, 'latin1')\n socket.write(body)\n socket.uncork()\n request.onBodySent(body)\n request.onRequestSent()\n if (!expectsPayload) {\n socket[kReset] = true\n }\n } else if (util.isBlobLike(body)) {\n if (typeof body.stream === 'function') {\n writeIterable({ body: body.stream(), client, request, socket, contentLength, header, expectsPayload })\n } else {\n writeBlob({ body, client, request, socket, contentLength, header, expectsPayload })\n }\n } else if (util.isStream(body)) {\n writeStream({ body, client, request, socket, contentLength, header, expectsPayload })\n } else if (util.isIterable(body)) {\n writeIterable({ body, client, request, socket, contentLength, header, expectsPayload })\n } else {\n assert(false)\n }\n\n return true\n}\n\nfunction writeH2 (client, session, request) {\n const { body, method, path, host, upgrade, expectContinue, signal, headers: reqHeaders } = request\n\n let headers\n if (typeof reqHeaders === 'string') headers = Request[kHTTP2CopyHeaders](reqHeaders.trim())\n else headers = reqHeaders\n\n if (upgrade) {\n errorRequest(client, request, new Error('Upgrade not supported for H2'))\n return false\n }\n\n try {\n // TODO(HTTP/2): Should we call onConnect immediately or on stream ready event?\n request.onConnect((err) => {\n if (request.aborted || request.completed) {\n return\n }\n\n errorRequest(client, request, err || new RequestAbortedError())\n })\n } catch (err) {\n errorRequest(client, request, err)\n }\n\n if (request.aborted) {\n return false\n }\n\n /** @type {import('node:http2').ClientHttp2Stream} */\n let stream\n const h2State = client[kHTTP2SessionState]\n\n headers[HTTP2_HEADER_AUTHORITY] = host || client[kHost]\n headers[HTTP2_HEADER_METHOD] = method\n\n if (method === 'CONNECT') {\n session.ref()\n // we are already connected, streams are pending, first request\n // will create a new stream. We trigger a request to create the stream and wait until\n // `ready` event is triggered\n // We disabled endStream to allow the user to write to the stream\n stream = session.request(headers, { endStream: false, signal })\n\n if (stream.id && !stream.pending) {\n request.onUpgrade(null, null, stream)\n ++h2State.openStreams\n } else {\n stream.once('ready', () => {\n request.onUpgrade(null, null, stream)\n ++h2State.openStreams\n })\n }\n\n stream.once('close', () => {\n h2State.openStreams -= 1\n // TODO(HTTP/2): unref only if current streams count is 0\n if (h2State.openStreams === 0) session.unref()\n })\n\n return true\n }\n\n // https://tools.ietf.org/html/rfc7540#section-8.3\n // :path and :scheme headers must be omited when sending CONNECT\n\n headers[HTTP2_HEADER_PATH] = path\n headers[HTTP2_HEADER_SCHEME] = 'https'\n\n // https://tools.ietf.org/html/rfc7231#section-4.3.1\n // https://tools.ietf.org/html/rfc7231#section-4.3.2\n // https://tools.ietf.org/html/rfc7231#section-4.3.5\n\n // Sending a payload body on a request that does not\n // expect it can cause undefined behavior on some\n // servers and corrupt connection state. Do not\n // re-use the connection for further requests.\n\n const expectsPayload = (\n method === 'PUT' ||\n method === 'POST' ||\n method === 'PATCH'\n )\n\n if (body && typeof body.read === 'function') {\n // Try to read EOF in order to get length.\n body.read(0)\n }\n\n let contentLength = util.bodyLength(body)\n\n if (contentLength == null) {\n contentLength = request.contentLength\n }\n\n if (contentLength === 0 || !expectsPayload) {\n // https://tools.ietf.org/html/rfc7230#section-3.3.2\n // A user agent SHOULD NOT send a Content-Length header field when\n // the request message does not contain a payload body and the method\n // semantics do not anticipate such a body.\n\n contentLength = null\n }\n\n // https://github.com/nodejs/undici/issues/2046\n // A user agent may send a Content-Length header with 0 value, this should be allowed.\n if (shouldSendContentLength(method) && contentLength > 0 && request.contentLength != null && request.contentLength !== contentLength) {\n if (client[kStrictContentLength]) {\n errorRequest(client, request, new RequestContentLengthMismatchError())\n return false\n }\n\n process.emitWarning(new RequestContentLengthMismatchError())\n }\n\n if (contentLength != null) {\n assert(body, 'no body must not have content length')\n headers[HTTP2_HEADER_CONTENT_LENGTH] = `${contentLength}`\n }\n\n session.ref()\n\n const shouldEndStream = method === 'GET' || method === 'HEAD'\n if (expectContinue) {\n headers[HTTP2_HEADER_EXPECT] = '100-continue'\n stream = session.request(headers, { endStream: shouldEndStream, signal })\n\n stream.once('continue', writeBodyH2)\n } else {\n stream = session.request(headers, {\n endStream: shouldEndStream,\n signal\n })\n writeBodyH2()\n }\n\n // Increment counter as we have new several streams open\n ++h2State.openStreams\n\n stream.once('response', headers => {\n const { [HTTP2_HEADER_STATUS]: statusCode, ...realHeaders } = headers\n\n if (request.onHeaders(Number(statusCode), realHeaders, stream.resume.bind(stream), '') === false) {\n stream.pause()\n }\n })\n\n stream.once('end', () => {\n request.onComplete([])\n })\n\n stream.on('data', (chunk) => {\n if (request.onData(chunk) === false) {\n stream.pause()\n }\n })\n\n stream.once('close', () => {\n h2State.openStreams -= 1\n // TODO(HTTP/2): unref only if current streams count is 0\n if (h2State.openStreams === 0) {\n session.unref()\n }\n })\n\n stream.once('error', function (err) {\n if (client[kHTTP2Session] && !client[kHTTP2Session].destroyed && !this.closed && !this.destroyed) {\n h2State.streams -= 1\n util.destroy(stream, err)\n }\n })\n\n stream.once('frameError', (type, code) => {\n const err = new InformationalError(`HTTP/2: \"frameError\" received - type ${type}, code ${code}`)\n errorRequest(client, request, err)\n\n if (client[kHTTP2Session] && !client[kHTTP2Session].destroyed && !this.closed && !this.destroyed) {\n h2State.streams -= 1\n util.destroy(stream, err)\n }\n })\n\n // stream.on('aborted', () => {\n // // TODO(HTTP/2): Support aborted\n // })\n\n // stream.on('timeout', () => {\n // // TODO(HTTP/2): Support timeout\n // })\n\n // stream.on('push', headers => {\n // // TODO(HTTP/2): Suppor push\n // })\n\n // stream.on('trailers', headers => {\n // // TODO(HTTP/2): Support trailers\n // })\n\n return true\n\n function writeBodyH2 () {\n /* istanbul ignore else: assertion */\n if (!body) {\n request.onRequestSent()\n } else if (util.isBuffer(body)) {\n assert(contentLength === body.byteLength, 'buffer body must have content length')\n stream.cork()\n stream.write(body)\n stream.uncork()\n stream.end()\n request.onBodySent(body)\n request.onRequestSent()\n } else if (util.isBlobLike(body)) {\n if (typeof body.stream === 'function') {\n writeIterable({\n client,\n request,\n contentLength,\n h2stream: stream,\n expectsPayload,\n body: body.stream(),\n socket: client[kSocket],\n header: ''\n })\n } else {\n writeBlob({\n body,\n client,\n request,\n contentLength,\n expectsPayload,\n h2stream: stream,\n header: '',\n socket: client[kSocket]\n })\n }\n } else if (util.isStream(body)) {\n writeStream({\n body,\n client,\n request,\n contentLength,\n expectsPayload,\n socket: client[kSocket],\n h2stream: stream,\n header: ''\n })\n } else if (util.isIterable(body)) {\n writeIterable({\n body,\n client,\n request,\n contentLength,\n expectsPayload,\n header: '',\n h2stream: stream,\n socket: client[kSocket]\n })\n } else {\n assert(false)\n }\n }\n}\n\nfunction writeStream ({ h2stream, body, client, request, socket, contentLength, header, expectsPayload }) {\n assert(contentLength !== 0 || client[kRunning] === 0, 'stream body cannot be pipelined')\n\n if (client[kHTTPConnVersion] === 'h2') {\n // For HTTP/2, is enough to pipe the stream\n const pipe = pipeline(\n body,\n h2stream,\n (err) => {\n if (err) {\n util.destroy(body, err)\n util.destroy(h2stream, err)\n } else {\n request.onRequestSent()\n }\n }\n )\n\n pipe.on('data', onPipeData)\n pipe.once('end', () => {\n pipe.removeListener('data', onPipeData)\n util.destroy(pipe)\n })\n\n function onPipeData (chunk) {\n request.onBodySent(chunk)\n }\n\n return\n }\n\n let finished = false\n\n const writer = new AsyncWriter({ socket, request, contentLength, client, expectsPayload, header })\n\n const onData = function (chunk) {\n if (finished) {\n return\n }\n\n try {\n if (!writer.write(chunk) && this.pause) {\n this.pause()\n }\n } catch (err) {\n util.destroy(this, err)\n }\n }\n const onDrain = function () {\n if (finished) {\n return\n }\n\n if (body.resume) {\n body.resume()\n }\n }\n const onAbort = function () {\n if (finished) {\n return\n }\n const err = new RequestAbortedError()\n queueMicrotask(() => onFinished(err))\n }\n const onFinished = function (err) {\n if (finished) {\n return\n }\n\n finished = true\n\n assert(socket.destroyed || (socket[kWriting] && client[kRunning] <= 1))\n\n socket\n .off('drain', onDrain)\n .off('error', onFinished)\n\n body\n .removeListener('data', onData)\n .removeListener('end', onFinished)\n .removeListener('error', onFinished)\n .removeListener('close', onAbort)\n\n if (!err) {\n try {\n writer.end()\n } catch (er) {\n err = er\n }\n }\n\n writer.destroy(err)\n\n if (err && (err.code !== 'UND_ERR_INFO' || err.message !== 'reset')) {\n util.destroy(body, err)\n } else {\n util.destroy(body)\n }\n }\n\n body\n .on('data', onData)\n .on('end', onFinished)\n .on('error', onFinished)\n .on('close', onAbort)\n\n if (body.resume) {\n body.resume()\n }\n\n socket\n .on('drain', onDrain)\n .on('error', onFinished)\n}\n\nasync function writeBlob ({ h2stream, body, client, request, socket, contentLength, header, expectsPayload }) {\n assert(contentLength === body.size, 'blob body must have content length')\n\n const isH2 = client[kHTTPConnVersion] === 'h2'\n try {\n if (contentLength != null && contentLength !== body.size) {\n throw new RequestContentLengthMismatchError()\n }\n\n const buffer = Buffer.from(await body.arrayBuffer())\n\n if (isH2) {\n h2stream.cork()\n h2stream.write(buffer)\n h2stream.uncork()\n } else {\n socket.cork()\n socket.write(`${header}content-length: ${contentLength}\\r\\n\\r\\n`, 'latin1')\n socket.write(buffer)\n socket.uncork()\n }\n\n request.onBodySent(buffer)\n request.onRequestSent()\n\n if (!expectsPayload) {\n socket[kReset] = true\n }\n\n resume(client)\n } catch (err) {\n util.destroy(isH2 ? h2stream : socket, err)\n }\n}\n\nasync function writeIterable ({ h2stream, body, client, request, socket, contentLength, header, expectsPayload }) {\n assert(contentLength !== 0 || client[kRunning] === 0, 'iterator body cannot be pipelined')\n\n let callback = null\n function onDrain () {\n if (callback) {\n const cb = callback\n callback = null\n cb()\n }\n }\n\n const waitForDrain = () => new Promise((resolve, reject) => {\n assert(callback === null)\n\n if (socket[kError]) {\n reject(socket[kError])\n } else {\n callback = resolve\n }\n })\n\n if (client[kHTTPConnVersion] === 'h2') {\n h2stream\n .on('close', onDrain)\n .on('drain', onDrain)\n\n try {\n // It's up to the user to somehow abort the async iterable.\n for await (const chunk of body) {\n if (socket[kError]) {\n throw socket[kError]\n }\n\n const res = h2stream.write(chunk)\n request.onBodySent(chunk)\n if (!res) {\n await waitForDrain()\n }\n }\n } catch (err) {\n h2stream.destroy(err)\n } finally {\n request.onRequestSent()\n h2stream.end()\n h2stream\n .off('close', onDrain)\n .off('drain', onDrain)\n }\n\n return\n }\n\n socket\n .on('close', onDrain)\n .on('drain', onDrain)\n\n const writer = new AsyncWriter({ socket, request, contentLength, client, expectsPayload, header })\n try {\n // It's up to the user to somehow abort the async iterable.\n for await (const chunk of body) {\n if (socket[kError]) {\n throw socket[kError]\n }\n\n if (!writer.write(chunk)) {\n await waitForDrain()\n }\n }\n\n writer.end()\n } catch (err) {\n writer.destroy(err)\n } finally {\n socket\n .off('close', onDrain)\n .off('drain', onDrain)\n }\n}\n\nclass AsyncWriter {\n constructor ({ socket, request, contentLength, client, expectsPayload, header }) {\n this.socket = socket\n this.request = request\n this.contentLength = contentLength\n this.client = client\n this.bytesWritten = 0\n this.expectsPayload = expectsPayload\n this.header = header\n\n socket[kWriting] = true\n }\n\n write (chunk) {\n const { socket, request, contentLength, client, bytesWritten, expectsPayload, header } = this\n\n if (socket[kError]) {\n throw socket[kError]\n }\n\n if (socket.destroyed) {\n return false\n }\n\n const len = Buffer.byteLength(chunk)\n if (!len) {\n return true\n }\n\n // We should defer writing chunks.\n if (contentLength !== null && bytesWritten + len > contentLength) {\n if (client[kStrictContentLength]) {\n throw new RequestContentLengthMismatchError()\n }\n\n process.emitWarning(new RequestContentLengthMismatchError())\n }\n\n socket.cork()\n\n if (bytesWritten === 0) {\n if (!expectsPayload) {\n socket[kReset] = true\n }\n\n if (contentLength === null) {\n socket.write(`${header}transfer-encoding: chunked\\r\\n`, 'latin1')\n } else {\n socket.write(`${header}content-length: ${contentLength}\\r\\n\\r\\n`, 'latin1')\n }\n }\n\n if (contentLength === null) {\n socket.write(`\\r\\n${len.toString(16)}\\r\\n`, 'latin1')\n }\n\n this.bytesWritten += len\n\n const ret = socket.write(chunk)\n\n socket.uncork()\n\n request.onBodySent(chunk)\n\n if (!ret) {\n if (socket[kParser].timeout && socket[kParser].timeoutType === TIMEOUT_HEADERS) {\n // istanbul ignore else: only for jest\n if (socket[kParser].timeout.refresh) {\n socket[kParser].timeout.refresh()\n }\n }\n }\n\n return ret\n }\n\n end () {\n const { socket, contentLength, client, bytesWritten, expectsPayload, header, request } = this\n request.onRequestSent()\n\n socket[kWriting] = false\n\n if (socket[kError]) {\n throw socket[kError]\n }\n\n if (socket.destroyed) {\n return\n }\n\n if (bytesWritten === 0) {\n if (expectsPayload) {\n // https://tools.ietf.org/html/rfc7230#section-3.3.2\n // A user agent SHOULD send a Content-Length in a request message when\n // no Transfer-Encoding is sent and the request method defines a meaning\n // for an enclosed payload body.\n\n socket.write(`${header}content-length: 0\\r\\n\\r\\n`, 'latin1')\n } else {\n socket.write(`${header}\\r\\n`, 'latin1')\n }\n } else if (contentLength === null) {\n socket.write('\\r\\n0\\r\\n\\r\\n', 'latin1')\n }\n\n if (contentLength !== null && bytesWritten !== contentLength) {\n if (client[kStrictContentLength]) {\n throw new RequestContentLengthMismatchError()\n } else {\n process.emitWarning(new RequestContentLengthMismatchError())\n }\n }\n\n if (socket[kParser].timeout && socket[kParser].timeoutType === TIMEOUT_HEADERS) {\n // istanbul ignore else: only for jest\n if (socket[kParser].timeout.refresh) {\n socket[kParser].timeout.refresh()\n }\n }\n\n resume(client)\n }\n\n destroy (err) {\n const { socket, client } = this\n\n socket[kWriting] = false\n\n if (err) {\n assert(client[kRunning] <= 1, 'pipeline should only contain this request')\n util.destroy(socket, err)\n }\n }\n}\n\nfunction errorRequest (client, request, err) {\n try {\n request.onError(err)\n assert(request.aborted)\n } catch (err) {\n client.emit('error', err)\n }\n}\n\nmodule.exports = Client\n","'use strict'\n\n/* istanbul ignore file: only for Node 12 */\n\nconst { kConnected, kSize } = require('../core/symbols')\n\nclass CompatWeakRef {\n constructor (value) {\n this.value = value\n }\n\n deref () {\n return this.value[kConnected] === 0 && this.value[kSize] === 0\n ? undefined\n : this.value\n }\n}\n\nclass CompatFinalizer {\n constructor (finalizer) {\n this.finalizer = finalizer\n }\n\n register (dispatcher, key) {\n if (dispatcher.on) {\n dispatcher.on('disconnect', () => {\n if (dispatcher[kConnected] === 0 && dispatcher[kSize] === 0) {\n this.finalizer(key)\n }\n })\n }\n }\n}\n\nmodule.exports = function () {\n // FIXME: remove workaround when the Node bug is fixed\n // https://github.com/nodejs/node/issues/49344#issuecomment-1741776308\n if (process.env.NODE_V8_COVERAGE) {\n return {\n WeakRef: CompatWeakRef,\n FinalizationRegistry: CompatFinalizer\n }\n }\n return {\n WeakRef: global.WeakRef || CompatWeakRef,\n FinalizationRegistry: global.FinalizationRegistry || CompatFinalizer\n }\n}\n","'use strict'\n\n// https://wicg.github.io/cookie-store/#cookie-maximum-attribute-value-size\nconst maxAttributeValueSize = 1024\n\n// https://wicg.github.io/cookie-store/#cookie-maximum-name-value-pair-size\nconst maxNameValuePairSize = 4096\n\nmodule.exports = {\n maxAttributeValueSize,\n maxNameValuePairSize\n}\n","'use strict'\n\nconst { parseSetCookie } = require('./parse')\nconst { stringify, getHeadersList } = require('./util')\nconst { webidl } = require('../fetch/webidl')\nconst { Headers } = require('../fetch/headers')\n\n/**\n * @typedef {Object} Cookie\n * @property {string} name\n * @property {string} value\n * @property {Date|number|undefined} expires\n * @property {number|undefined} maxAge\n * @property {string|undefined} domain\n * @property {string|undefined} path\n * @property {boolean|undefined} secure\n * @property {boolean|undefined} httpOnly\n * @property {'Strict'|'Lax'|'None'} sameSite\n * @property {string[]} unparsed\n */\n\n/**\n * @param {Headers} headers\n * @returns {Record}\n */\nfunction getCookies (headers) {\n webidl.argumentLengthCheck(arguments, 1, { header: 'getCookies' })\n\n webidl.brandCheck(headers, Headers, { strict: false })\n\n const cookie = headers.get('cookie')\n const out = {}\n\n if (!cookie) {\n return out\n }\n\n for (const piece of cookie.split(';')) {\n const [name, ...value] = piece.split('=')\n\n out[name.trim()] = value.join('=')\n }\n\n return out\n}\n\n/**\n * @param {Headers} headers\n * @param {string} name\n * @param {{ path?: string, domain?: string }|undefined} attributes\n * @returns {void}\n */\nfunction deleteCookie (headers, name, attributes) {\n webidl.argumentLengthCheck(arguments, 2, { header: 'deleteCookie' })\n\n webidl.brandCheck(headers, Headers, { strict: false })\n\n name = webidl.converters.DOMString(name)\n attributes = webidl.converters.DeleteCookieAttributes(attributes)\n\n // Matches behavior of\n // https://github.com/denoland/deno_std/blob/63827b16330b82489a04614027c33b7904e08be5/http/cookie.ts#L278\n setCookie(headers, {\n name,\n value: '',\n expires: new Date(0),\n ...attributes\n })\n}\n\n/**\n * @param {Headers} headers\n * @returns {Cookie[]}\n */\nfunction getSetCookies (headers) {\n webidl.argumentLengthCheck(arguments, 1, { header: 'getSetCookies' })\n\n webidl.brandCheck(headers, Headers, { strict: false })\n\n const cookies = getHeadersList(headers).cookies\n\n if (!cookies) {\n return []\n }\n\n // In older versions of undici, cookies is a list of name:value.\n return cookies.map((pair) => parseSetCookie(Array.isArray(pair) ? pair[1] : pair))\n}\n\n/**\n * @param {Headers} headers\n * @param {Cookie} cookie\n * @returns {void}\n */\nfunction setCookie (headers, cookie) {\n webidl.argumentLengthCheck(arguments, 2, { header: 'setCookie' })\n\n webidl.brandCheck(headers, Headers, { strict: false })\n\n cookie = webidl.converters.Cookie(cookie)\n\n const str = stringify(cookie)\n\n if (str) {\n headers.append('Set-Cookie', stringify(cookie))\n }\n}\n\nwebidl.converters.DeleteCookieAttributes = webidl.dictionaryConverter([\n {\n converter: webidl.nullableConverter(webidl.converters.DOMString),\n key: 'path',\n defaultValue: null\n },\n {\n converter: webidl.nullableConverter(webidl.converters.DOMString),\n key: 'domain',\n defaultValue: null\n }\n])\n\nwebidl.converters.Cookie = webidl.dictionaryConverter([\n {\n converter: webidl.converters.DOMString,\n key: 'name'\n },\n {\n converter: webidl.converters.DOMString,\n key: 'value'\n },\n {\n converter: webidl.nullableConverter((value) => {\n if (typeof value === 'number') {\n return webidl.converters['unsigned long long'](value)\n }\n\n return new Date(value)\n }),\n key: 'expires',\n defaultValue: null\n },\n {\n converter: webidl.nullableConverter(webidl.converters['long long']),\n key: 'maxAge',\n defaultValue: null\n },\n {\n converter: webidl.nullableConverter(webidl.converters.DOMString),\n key: 'domain',\n defaultValue: null\n },\n {\n converter: webidl.nullableConverter(webidl.converters.DOMString),\n key: 'path',\n defaultValue: null\n },\n {\n converter: webidl.nullableConverter(webidl.converters.boolean),\n key: 'secure',\n defaultValue: null\n },\n {\n converter: webidl.nullableConverter(webidl.converters.boolean),\n key: 'httpOnly',\n defaultValue: null\n },\n {\n converter: webidl.converters.USVString,\n key: 'sameSite',\n allowedValues: ['Strict', 'Lax', 'None']\n },\n {\n converter: webidl.sequenceConverter(webidl.converters.DOMString),\n key: 'unparsed',\n defaultValue: []\n }\n])\n\nmodule.exports = {\n getCookies,\n deleteCookie,\n getSetCookies,\n setCookie\n}\n","'use strict'\n\nconst { maxNameValuePairSize, maxAttributeValueSize } = require('./constants')\nconst { isCTLExcludingHtab } = require('./util')\nconst { collectASequenceOfCodePointsFast } = require('../fetch/dataURL')\nconst assert = require('assert')\n\n/**\n * @description Parses the field-value attributes of a set-cookie header string.\n * @see https://datatracker.ietf.org/doc/html/draft-ietf-httpbis-rfc6265bis#section-5.4\n * @param {string} header\n * @returns if the header is invalid, null will be returned\n */\nfunction parseSetCookie (header) {\n // 1. If the set-cookie-string contains a %x00-08 / %x0A-1F / %x7F\n // character (CTL characters excluding HTAB): Abort these steps and\n // ignore the set-cookie-string entirely.\n if (isCTLExcludingHtab(header)) {\n return null\n }\n\n let nameValuePair = ''\n let unparsedAttributes = ''\n let name = ''\n let value = ''\n\n // 2. If the set-cookie-string contains a %x3B (\";\") character:\n if (header.includes(';')) {\n // 1. The name-value-pair string consists of the characters up to,\n // but not including, the first %x3B (\";\"), and the unparsed-\n // attributes consist of the remainder of the set-cookie-string\n // (including the %x3B (\";\") in question).\n const position = { position: 0 }\n\n nameValuePair = collectASequenceOfCodePointsFast(';', header, position)\n unparsedAttributes = header.slice(position.position)\n } else {\n // Otherwise:\n\n // 1. The name-value-pair string consists of all the characters\n // contained in the set-cookie-string, and the unparsed-\n // attributes is the empty string.\n nameValuePair = header\n }\n\n // 3. If the name-value-pair string lacks a %x3D (\"=\") character, then\n // the name string is empty, and the value string is the value of\n // name-value-pair.\n if (!nameValuePair.includes('=')) {\n value = nameValuePair\n } else {\n // Otherwise, the name string consists of the characters up to, but\n // not including, the first %x3D (\"=\") character, and the (possibly\n // empty) value string consists of the characters after the first\n // %x3D (\"=\") character.\n const position = { position: 0 }\n name = collectASequenceOfCodePointsFast(\n '=',\n nameValuePair,\n position\n )\n value = nameValuePair.slice(position.position + 1)\n }\n\n // 4. Remove any leading or trailing WSP characters from the name\n // string and the value string.\n name = name.trim()\n value = value.trim()\n\n // 5. If the sum of the lengths of the name string and the value string\n // is more than 4096 octets, abort these steps and ignore the set-\n // cookie-string entirely.\n if (name.length + value.length > maxNameValuePairSize) {\n return null\n }\n\n // 6. The cookie-name is the name string, and the cookie-value is the\n // value string.\n return {\n name, value, ...parseUnparsedAttributes(unparsedAttributes)\n }\n}\n\n/**\n * Parses the remaining attributes of a set-cookie header\n * @see https://datatracker.ietf.org/doc/html/draft-ietf-httpbis-rfc6265bis#section-5.4\n * @param {string} unparsedAttributes\n * @param {[Object.]={}} cookieAttributeList\n */\nfunction parseUnparsedAttributes (unparsedAttributes, cookieAttributeList = {}) {\n // 1. If the unparsed-attributes string is empty, skip the rest of\n // these steps.\n if (unparsedAttributes.length === 0) {\n return cookieAttributeList\n }\n\n // 2. Discard the first character of the unparsed-attributes (which\n // will be a %x3B (\";\") character).\n assert(unparsedAttributes[0] === ';')\n unparsedAttributes = unparsedAttributes.slice(1)\n\n let cookieAv = ''\n\n // 3. If the remaining unparsed-attributes contains a %x3B (\";\")\n // character:\n if (unparsedAttributes.includes(';')) {\n // 1. Consume the characters of the unparsed-attributes up to, but\n // not including, the first %x3B (\";\") character.\n cookieAv = collectASequenceOfCodePointsFast(\n ';',\n unparsedAttributes,\n { position: 0 }\n )\n unparsedAttributes = unparsedAttributes.slice(cookieAv.length)\n } else {\n // Otherwise:\n\n // 1. Consume the remainder of the unparsed-attributes.\n cookieAv = unparsedAttributes\n unparsedAttributes = ''\n }\n\n // Let the cookie-av string be the characters consumed in this step.\n\n let attributeName = ''\n let attributeValue = ''\n\n // 4. If the cookie-av string contains a %x3D (\"=\") character:\n if (cookieAv.includes('=')) {\n // 1. The (possibly empty) attribute-name string consists of the\n // characters up to, but not including, the first %x3D (\"=\")\n // character, and the (possibly empty) attribute-value string\n // consists of the characters after the first %x3D (\"=\")\n // character.\n const position = { position: 0 }\n\n attributeName = collectASequenceOfCodePointsFast(\n '=',\n cookieAv,\n position\n )\n attributeValue = cookieAv.slice(position.position + 1)\n } else {\n // Otherwise:\n\n // 1. The attribute-name string consists of the entire cookie-av\n // string, and the attribute-value string is empty.\n attributeName = cookieAv\n }\n\n // 5. Remove any leading or trailing WSP characters from the attribute-\n // name string and the attribute-value string.\n attributeName = attributeName.trim()\n attributeValue = attributeValue.trim()\n\n // 6. If the attribute-value is longer than 1024 octets, ignore the\n // cookie-av string and return to Step 1 of this algorithm.\n if (attributeValue.length > maxAttributeValueSize) {\n return parseUnparsedAttributes(unparsedAttributes, cookieAttributeList)\n }\n\n // 7. Process the attribute-name and attribute-value according to the\n // requirements in the following subsections. (Notice that\n // attributes with unrecognized attribute-names are ignored.)\n const attributeNameLowercase = attributeName.toLowerCase()\n\n // https://datatracker.ietf.org/doc/html/draft-ietf-httpbis-rfc6265bis#section-5.4.1\n // If the attribute-name case-insensitively matches the string\n // \"Expires\", the user agent MUST process the cookie-av as follows.\n if (attributeNameLowercase === 'expires') {\n // 1. Let the expiry-time be the result of parsing the attribute-value\n // as cookie-date (see Section 5.1.1).\n const expiryTime = new Date(attributeValue)\n\n // 2. If the attribute-value failed to parse as a cookie date, ignore\n // the cookie-av.\n\n cookieAttributeList.expires = expiryTime\n } else if (attributeNameLowercase === 'max-age') {\n // https://datatracker.ietf.org/doc/html/draft-ietf-httpbis-rfc6265bis#section-5.4.2\n // If the attribute-name case-insensitively matches the string \"Max-\n // Age\", the user agent MUST process the cookie-av as follows.\n\n // 1. If the first character of the attribute-value is not a DIGIT or a\n // \"-\" character, ignore the cookie-av.\n const charCode = attributeValue.charCodeAt(0)\n\n if ((charCode < 48 || charCode > 57) && attributeValue[0] !== '-') {\n return parseUnparsedAttributes(unparsedAttributes, cookieAttributeList)\n }\n\n // 2. If the remainder of attribute-value contains a non-DIGIT\n // character, ignore the cookie-av.\n if (!/^\\d+$/.test(attributeValue)) {\n return parseUnparsedAttributes(unparsedAttributes, cookieAttributeList)\n }\n\n // 3. Let delta-seconds be the attribute-value converted to an integer.\n const deltaSeconds = Number(attributeValue)\n\n // 4. Let cookie-age-limit be the maximum age of the cookie (which\n // SHOULD be 400 days or less, see Section 4.1.2.2).\n\n // 5. Set delta-seconds to the smaller of its present value and cookie-\n // age-limit.\n // deltaSeconds = Math.min(deltaSeconds * 1000, maxExpiresMs)\n\n // 6. If delta-seconds is less than or equal to zero (0), let expiry-\n // time be the earliest representable date and time. Otherwise, let\n // the expiry-time be the current date and time plus delta-seconds\n // seconds.\n // const expiryTime = deltaSeconds <= 0 ? Date.now() : Date.now() + deltaSeconds\n\n // 7. Append an attribute to the cookie-attribute-list with an\n // attribute-name of Max-Age and an attribute-value of expiry-time.\n cookieAttributeList.maxAge = deltaSeconds\n } else if (attributeNameLowercase === 'domain') {\n // https://datatracker.ietf.org/doc/html/draft-ietf-httpbis-rfc6265bis#section-5.4.3\n // If the attribute-name case-insensitively matches the string \"Domain\",\n // the user agent MUST process the cookie-av as follows.\n\n // 1. Let cookie-domain be the attribute-value.\n let cookieDomain = attributeValue\n\n // 2. If cookie-domain starts with %x2E (\".\"), let cookie-domain be\n // cookie-domain without its leading %x2E (\".\").\n if (cookieDomain[0] === '.') {\n cookieDomain = cookieDomain.slice(1)\n }\n\n // 3. Convert the cookie-domain to lower case.\n cookieDomain = cookieDomain.toLowerCase()\n\n // 4. Append an attribute to the cookie-attribute-list with an\n // attribute-name of Domain and an attribute-value of cookie-domain.\n cookieAttributeList.domain = cookieDomain\n } else if (attributeNameLowercase === 'path') {\n // https://datatracker.ietf.org/doc/html/draft-ietf-httpbis-rfc6265bis#section-5.4.4\n // If the attribute-name case-insensitively matches the string \"Path\",\n // the user agent MUST process the cookie-av as follows.\n\n // 1. If the attribute-value is empty or if the first character of the\n // attribute-value is not %x2F (\"/\"):\n let cookiePath = ''\n if (attributeValue.length === 0 || attributeValue[0] !== '/') {\n // 1. Let cookie-path be the default-path.\n cookiePath = '/'\n } else {\n // Otherwise:\n\n // 1. Let cookie-path be the attribute-value.\n cookiePath = attributeValue\n }\n\n // 2. Append an attribute to the cookie-attribute-list with an\n // attribute-name of Path and an attribute-value of cookie-path.\n cookieAttributeList.path = cookiePath\n } else if (attributeNameLowercase === 'secure') {\n // https://datatracker.ietf.org/doc/html/draft-ietf-httpbis-rfc6265bis#section-5.4.5\n // If the attribute-name case-insensitively matches the string \"Secure\",\n // the user agent MUST append an attribute to the cookie-attribute-list\n // with an attribute-name of Secure and an empty attribute-value.\n\n cookieAttributeList.secure = true\n } else if (attributeNameLowercase === 'httponly') {\n // https://datatracker.ietf.org/doc/html/draft-ietf-httpbis-rfc6265bis#section-5.4.6\n // If the attribute-name case-insensitively matches the string\n // \"HttpOnly\", the user agent MUST append an attribute to the cookie-\n // attribute-list with an attribute-name of HttpOnly and an empty\n // attribute-value.\n\n cookieAttributeList.httpOnly = true\n } else if (attributeNameLowercase === 'samesite') {\n // https://datatracker.ietf.org/doc/html/draft-ietf-httpbis-rfc6265bis#section-5.4.7\n // If the attribute-name case-insensitively matches the string\n // \"SameSite\", the user agent MUST process the cookie-av as follows:\n\n // 1. Let enforcement be \"Default\".\n let enforcement = 'Default'\n\n const attributeValueLowercase = attributeValue.toLowerCase()\n // 2. If cookie-av's attribute-value is a case-insensitive match for\n // \"None\", set enforcement to \"None\".\n if (attributeValueLowercase.includes('none')) {\n enforcement = 'None'\n }\n\n // 3. If cookie-av's attribute-value is a case-insensitive match for\n // \"Strict\", set enforcement to \"Strict\".\n if (attributeValueLowercase.includes('strict')) {\n enforcement = 'Strict'\n }\n\n // 4. If cookie-av's attribute-value is a case-insensitive match for\n // \"Lax\", set enforcement to \"Lax\".\n if (attributeValueLowercase.includes('lax')) {\n enforcement = 'Lax'\n }\n\n // 5. Append an attribute to the cookie-attribute-list with an\n // attribute-name of \"SameSite\" and an attribute-value of\n // enforcement.\n cookieAttributeList.sameSite = enforcement\n } else {\n cookieAttributeList.unparsed ??= []\n\n cookieAttributeList.unparsed.push(`${attributeName}=${attributeValue}`)\n }\n\n // 8. Return to Step 1 of this algorithm.\n return parseUnparsedAttributes(unparsedAttributes, cookieAttributeList)\n}\n\nmodule.exports = {\n parseSetCookie,\n parseUnparsedAttributes\n}\n","'use strict'\n\nconst assert = require('assert')\nconst { kHeadersList } = require('../core/symbols')\n\nfunction isCTLExcludingHtab (value) {\n if (value.length === 0) {\n return false\n }\n\n for (const char of value) {\n const code = char.charCodeAt(0)\n\n if (\n (code >= 0x00 || code <= 0x08) ||\n (code >= 0x0A || code <= 0x1F) ||\n code === 0x7F\n ) {\n return false\n }\n }\n}\n\n/**\n CHAR = \n token = 1*\n separators = \"(\" | \")\" | \"<\" | \">\" | \"@\"\n | \",\" | \";\" | \":\" | \"\\\" | <\">\n | \"/\" | \"[\" | \"]\" | \"?\" | \"=\"\n | \"{\" | \"}\" | SP | HT\n * @param {string} name\n */\nfunction validateCookieName (name) {\n for (const char of name) {\n const code = char.charCodeAt(0)\n\n if (\n (code <= 0x20 || code > 0x7F) ||\n char === '(' ||\n char === ')' ||\n char === '>' ||\n char === '<' ||\n char === '@' ||\n char === ',' ||\n char === ';' ||\n char === ':' ||\n char === '\\\\' ||\n char === '\"' ||\n char === '/' ||\n char === '[' ||\n char === ']' ||\n char === '?' ||\n char === '=' ||\n char === '{' ||\n char === '}'\n ) {\n throw new Error('Invalid cookie name')\n }\n }\n}\n\n/**\n cookie-value = *cookie-octet / ( DQUOTE *cookie-octet DQUOTE )\n cookie-octet = %x21 / %x23-2B / %x2D-3A / %x3C-5B / %x5D-7E\n ; US-ASCII characters excluding CTLs,\n ; whitespace DQUOTE, comma, semicolon,\n ; and backslash\n * @param {string} value\n */\nfunction validateCookieValue (value) {\n for (const char of value) {\n const code = char.charCodeAt(0)\n\n if (\n code < 0x21 || // exclude CTLs (0-31)\n code === 0x22 ||\n code === 0x2C ||\n code === 0x3B ||\n code === 0x5C ||\n code > 0x7E // non-ascii\n ) {\n throw new Error('Invalid header value')\n }\n }\n}\n\n/**\n * path-value = \n * @param {string} path\n */\nfunction validateCookiePath (path) {\n for (const char of path) {\n const code = char.charCodeAt(0)\n\n if (code < 0x21 || char === ';') {\n throw new Error('Invalid cookie path')\n }\n }\n}\n\n/**\n * I have no idea why these values aren't allowed to be honest,\n * but Deno tests these. - Khafra\n * @param {string} domain\n */\nfunction validateCookieDomain (domain) {\n if (\n domain.startsWith('-') ||\n domain.endsWith('.') ||\n domain.endsWith('-')\n ) {\n throw new Error('Invalid cookie domain')\n }\n}\n\n/**\n * @see https://www.rfc-editor.org/rfc/rfc7231#section-7.1.1.1\n * @param {number|Date} date\n IMF-fixdate = day-name \",\" SP date1 SP time-of-day SP GMT\n ; fixed length/zone/capitalization subset of the format\n ; see Section 3.3 of [RFC5322]\n\n day-name = %x4D.6F.6E ; \"Mon\", case-sensitive\n / %x54.75.65 ; \"Tue\", case-sensitive\n / %x57.65.64 ; \"Wed\", case-sensitive\n / %x54.68.75 ; \"Thu\", case-sensitive\n / %x46.72.69 ; \"Fri\", case-sensitive\n / %x53.61.74 ; \"Sat\", case-sensitive\n / %x53.75.6E ; \"Sun\", case-sensitive\n date1 = day SP month SP year\n ; e.g., 02 Jun 1982\n\n day = 2DIGIT\n month = %x4A.61.6E ; \"Jan\", case-sensitive\n / %x46.65.62 ; \"Feb\", case-sensitive\n / %x4D.61.72 ; \"Mar\", case-sensitive\n / %x41.70.72 ; \"Apr\", case-sensitive\n / %x4D.61.79 ; \"May\", case-sensitive\n / %x4A.75.6E ; \"Jun\", case-sensitive\n / %x4A.75.6C ; \"Jul\", case-sensitive\n / %x41.75.67 ; \"Aug\", case-sensitive\n / %x53.65.70 ; \"Sep\", case-sensitive\n / %x4F.63.74 ; \"Oct\", case-sensitive\n / %x4E.6F.76 ; \"Nov\", case-sensitive\n / %x44.65.63 ; \"Dec\", case-sensitive\n year = 4DIGIT\n\n GMT = %x47.4D.54 ; \"GMT\", case-sensitive\n\n time-of-day = hour \":\" minute \":\" second\n ; 00:00:00 - 23:59:60 (leap second)\n\n hour = 2DIGIT\n minute = 2DIGIT\n second = 2DIGIT\n */\nfunction toIMFDate (date) {\n if (typeof date === 'number') {\n date = new Date(date)\n }\n\n const days = [\n 'Sun', 'Mon', 'Tue', 'Wed',\n 'Thu', 'Fri', 'Sat'\n ]\n\n const months = [\n 'Jan', 'Feb', 'Mar', 'Apr', 'May', 'Jun',\n 'Jul', 'Aug', 'Sep', 'Oct', 'Nov', 'Dec'\n ]\n\n const dayName = days[date.getUTCDay()]\n const day = date.getUTCDate().toString().padStart(2, '0')\n const month = months[date.getUTCMonth()]\n const year = date.getUTCFullYear()\n const hour = date.getUTCHours().toString().padStart(2, '0')\n const minute = date.getUTCMinutes().toString().padStart(2, '0')\n const second = date.getUTCSeconds().toString().padStart(2, '0')\n\n return `${dayName}, ${day} ${month} ${year} ${hour}:${minute}:${second} GMT`\n}\n\n/**\n max-age-av = \"Max-Age=\" non-zero-digit *DIGIT\n ; In practice, both expires-av and max-age-av\n ; are limited to dates representable by the\n ; user agent.\n * @param {number} maxAge\n */\nfunction validateCookieMaxAge (maxAge) {\n if (maxAge < 0) {\n throw new Error('Invalid cookie max-age')\n }\n}\n\n/**\n * @see https://www.rfc-editor.org/rfc/rfc6265#section-4.1.1\n * @param {import('./index').Cookie} cookie\n */\nfunction stringify (cookie) {\n if (cookie.name.length === 0) {\n return null\n }\n\n validateCookieName(cookie.name)\n validateCookieValue(cookie.value)\n\n const out = [`${cookie.name}=${cookie.value}`]\n\n // https://datatracker.ietf.org/doc/html/draft-ietf-httpbis-cookie-prefixes-00#section-3.1\n // https://datatracker.ietf.org/doc/html/draft-ietf-httpbis-cookie-prefixes-00#section-3.2\n if (cookie.name.startsWith('__Secure-')) {\n cookie.secure = true\n }\n\n if (cookie.name.startsWith('__Host-')) {\n cookie.secure = true\n cookie.domain = null\n cookie.path = '/'\n }\n\n if (cookie.secure) {\n out.push('Secure')\n }\n\n if (cookie.httpOnly) {\n out.push('HttpOnly')\n }\n\n if (typeof cookie.maxAge === 'number') {\n validateCookieMaxAge(cookie.maxAge)\n out.push(`Max-Age=${cookie.maxAge}`)\n }\n\n if (cookie.domain) {\n validateCookieDomain(cookie.domain)\n out.push(`Domain=${cookie.domain}`)\n }\n\n if (cookie.path) {\n validateCookiePath(cookie.path)\n out.push(`Path=${cookie.path}`)\n }\n\n if (cookie.expires && cookie.expires.toString() !== 'Invalid Date') {\n out.push(`Expires=${toIMFDate(cookie.expires)}`)\n }\n\n if (cookie.sameSite) {\n out.push(`SameSite=${cookie.sameSite}`)\n }\n\n for (const part of cookie.unparsed) {\n if (!part.includes('=')) {\n throw new Error('Invalid unparsed')\n }\n\n const [key, ...value] = part.split('=')\n\n out.push(`${key.trim()}=${value.join('=')}`)\n }\n\n return out.join('; ')\n}\n\nlet kHeadersListNode\n\nfunction getHeadersList (headers) {\n if (headers[kHeadersList]) {\n return headers[kHeadersList]\n }\n\n if (!kHeadersListNode) {\n kHeadersListNode = Object.getOwnPropertySymbols(headers).find(\n (symbol) => symbol.description === 'headers list'\n )\n\n assert(kHeadersListNode, 'Headers cannot be parsed')\n }\n\n const headersList = headers[kHeadersListNode]\n assert(headersList)\n\n return headersList\n}\n\nmodule.exports = {\n isCTLExcludingHtab,\n stringify,\n getHeadersList\n}\n","'use strict'\n\nconst net = require('net')\nconst assert = require('assert')\nconst util = require('./util')\nconst { InvalidArgumentError, ConnectTimeoutError } = require('./errors')\n\nlet tls // include tls conditionally since it is not always available\n\n// TODO: session re-use does not wait for the first\n// connection to resolve the session and might therefore\n// resolve the same servername multiple times even when\n// re-use is enabled.\n\nlet SessionCache\n// FIXME: remove workaround when the Node bug is fixed\n// https://github.com/nodejs/node/issues/49344#issuecomment-1741776308\nif (global.FinalizationRegistry && !process.env.NODE_V8_COVERAGE) {\n SessionCache = class WeakSessionCache {\n constructor (maxCachedSessions) {\n this._maxCachedSessions = maxCachedSessions\n this._sessionCache = new Map()\n this._sessionRegistry = new global.FinalizationRegistry((key) => {\n if (this._sessionCache.size < this._maxCachedSessions) {\n return\n }\n\n const ref = this._sessionCache.get(key)\n if (ref !== undefined && ref.deref() === undefined) {\n this._sessionCache.delete(key)\n }\n })\n }\n\n get (sessionKey) {\n const ref = this._sessionCache.get(sessionKey)\n return ref ? ref.deref() : null\n }\n\n set (sessionKey, session) {\n if (this._maxCachedSessions === 0) {\n return\n }\n\n this._sessionCache.set(sessionKey, new WeakRef(session))\n this._sessionRegistry.register(session, sessionKey)\n }\n }\n} else {\n SessionCache = class SimpleSessionCache {\n constructor (maxCachedSessions) {\n this._maxCachedSessions = maxCachedSessions\n this._sessionCache = new Map()\n }\n\n get (sessionKey) {\n return this._sessionCache.get(sessionKey)\n }\n\n set (sessionKey, session) {\n if (this._maxCachedSessions === 0) {\n return\n }\n\n if (this._sessionCache.size >= this._maxCachedSessions) {\n // remove the oldest session\n const { value: oldestKey } = this._sessionCache.keys().next()\n this._sessionCache.delete(oldestKey)\n }\n\n this._sessionCache.set(sessionKey, session)\n }\n }\n}\n\nfunction buildConnector ({ allowH2, maxCachedSessions, socketPath, timeout, ...opts }) {\n if (maxCachedSessions != null && (!Number.isInteger(maxCachedSessions) || maxCachedSessions < 0)) {\n throw new InvalidArgumentError('maxCachedSessions must be a positive integer or zero')\n }\n\n const options = { path: socketPath, ...opts }\n const sessionCache = new SessionCache(maxCachedSessions == null ? 100 : maxCachedSessions)\n timeout = timeout == null ? 10e3 : timeout\n allowH2 = allowH2 != null ? allowH2 : false\n return function connect ({ hostname, host, protocol, port, servername, localAddress, httpSocket }, callback) {\n let socket\n if (protocol === 'https:') {\n if (!tls) {\n tls = require('tls')\n }\n servername = servername || options.servername || util.getServerName(host) || null\n\n const sessionKey = servername || hostname\n const session = sessionCache.get(sessionKey) || null\n\n assert(sessionKey)\n\n socket = tls.connect({\n highWaterMark: 16384, // TLS in node can't have bigger HWM anyway...\n ...options,\n servername,\n session,\n localAddress,\n // TODO(HTTP/2): Add support for h2c\n ALPNProtocols: allowH2 ? ['http/1.1', 'h2'] : ['http/1.1'],\n socket: httpSocket, // upgrade socket connection\n port: port || 443,\n host: hostname\n })\n\n socket\n .on('session', function (session) {\n // TODO (fix): Can a session become invalid once established? Don't think so?\n sessionCache.set(sessionKey, session)\n })\n } else {\n assert(!httpSocket, 'httpSocket can only be sent on TLS update')\n socket = net.connect({\n highWaterMark: 64 * 1024, // Same as nodejs fs streams.\n ...options,\n localAddress,\n port: port || 80,\n host: hostname\n })\n }\n\n // Set TCP keep alive options on the socket here instead of in connect() for the case of assigning the socket\n if (options.keepAlive == null || options.keepAlive) {\n const keepAliveInitialDelay = options.keepAliveInitialDelay === undefined ? 60e3 : options.keepAliveInitialDelay\n socket.setKeepAlive(true, keepAliveInitialDelay)\n }\n\n const cancelTimeout = setupTimeout(() => onConnectTimeout(socket), timeout)\n\n socket\n .setNoDelay(true)\n .once(protocol === 'https:' ? 'secureConnect' : 'connect', function () {\n cancelTimeout()\n\n if (callback) {\n const cb = callback\n callback = null\n cb(null, this)\n }\n })\n .on('error', function (err) {\n cancelTimeout()\n\n if (callback) {\n const cb = callback\n callback = null\n cb(err)\n }\n })\n\n return socket\n }\n}\n\nfunction setupTimeout (onConnectTimeout, timeout) {\n if (!timeout) {\n return () => {}\n }\n\n let s1 = null\n let s2 = null\n const timeoutId = setTimeout(() => {\n // setImmediate is added to make sure that we priotorise socket error events over timeouts\n s1 = setImmediate(() => {\n if (process.platform === 'win32') {\n // Windows needs an extra setImmediate probably due to implementation differences in the socket logic\n s2 = setImmediate(() => onConnectTimeout())\n } else {\n onConnectTimeout()\n }\n })\n }, timeout)\n return () => {\n clearTimeout(timeoutId)\n clearImmediate(s1)\n clearImmediate(s2)\n }\n}\n\nfunction onConnectTimeout (socket) {\n util.destroy(socket, new ConnectTimeoutError())\n}\n\nmodule.exports = buildConnector\n","'use strict'\n\nclass UndiciError extends Error {\n constructor (message) {\n super(message)\n this.name = 'UndiciError'\n this.code = 'UND_ERR'\n }\n}\n\nclass ConnectTimeoutError extends UndiciError {\n constructor (message) {\n super(message)\n Error.captureStackTrace(this, ConnectTimeoutError)\n this.name = 'ConnectTimeoutError'\n this.message = message || 'Connect Timeout Error'\n this.code = 'UND_ERR_CONNECT_TIMEOUT'\n }\n}\n\nclass HeadersTimeoutError extends UndiciError {\n constructor (message) {\n super(message)\n Error.captureStackTrace(this, HeadersTimeoutError)\n this.name = 'HeadersTimeoutError'\n this.message = message || 'Headers Timeout Error'\n this.code = 'UND_ERR_HEADERS_TIMEOUT'\n }\n}\n\nclass HeadersOverflowError extends UndiciError {\n constructor (message) {\n super(message)\n Error.captureStackTrace(this, HeadersOverflowError)\n this.name = 'HeadersOverflowError'\n this.message = message || 'Headers Overflow Error'\n this.code = 'UND_ERR_HEADERS_OVERFLOW'\n }\n}\n\nclass BodyTimeoutError extends UndiciError {\n constructor (message) {\n super(message)\n Error.captureStackTrace(this, BodyTimeoutError)\n this.name = 'BodyTimeoutError'\n this.message = message || 'Body Timeout Error'\n this.code = 'UND_ERR_BODY_TIMEOUT'\n }\n}\n\nclass ResponseStatusCodeError extends UndiciError {\n constructor (message, statusCode, headers, body) {\n super(message)\n Error.captureStackTrace(this, ResponseStatusCodeError)\n this.name = 'ResponseStatusCodeError'\n this.message = message || 'Response Status Code Error'\n this.code = 'UND_ERR_RESPONSE_STATUS_CODE'\n this.body = body\n this.status = statusCode\n this.statusCode = statusCode\n this.headers = headers\n }\n}\n\nclass InvalidArgumentError extends UndiciError {\n constructor (message) {\n super(message)\n Error.captureStackTrace(this, InvalidArgumentError)\n this.name = 'InvalidArgumentError'\n this.message = message || 'Invalid Argument Error'\n this.code = 'UND_ERR_INVALID_ARG'\n }\n}\n\nclass InvalidReturnValueError extends UndiciError {\n constructor (message) {\n super(message)\n Error.captureStackTrace(this, InvalidReturnValueError)\n this.name = 'InvalidReturnValueError'\n this.message = message || 'Invalid Return Value Error'\n this.code = 'UND_ERR_INVALID_RETURN_VALUE'\n }\n}\n\nclass RequestAbortedError extends UndiciError {\n constructor (message) {\n super(message)\n Error.captureStackTrace(this, RequestAbortedError)\n this.name = 'AbortError'\n this.message = message || 'Request aborted'\n this.code = 'UND_ERR_ABORTED'\n }\n}\n\nclass InformationalError extends UndiciError {\n constructor (message) {\n super(message)\n Error.captureStackTrace(this, InformationalError)\n this.name = 'InformationalError'\n this.message = message || 'Request information'\n this.code = 'UND_ERR_INFO'\n }\n}\n\nclass RequestContentLengthMismatchError extends UndiciError {\n constructor (message) {\n super(message)\n Error.captureStackTrace(this, RequestContentLengthMismatchError)\n this.name = 'RequestContentLengthMismatchError'\n this.message = message || 'Request body length does not match content-length header'\n this.code = 'UND_ERR_REQ_CONTENT_LENGTH_MISMATCH'\n }\n}\n\nclass ResponseContentLengthMismatchError extends UndiciError {\n constructor (message) {\n super(message)\n Error.captureStackTrace(this, ResponseContentLengthMismatchError)\n this.name = 'ResponseContentLengthMismatchError'\n this.message = message || 'Response body length does not match content-length header'\n this.code = 'UND_ERR_RES_CONTENT_LENGTH_MISMATCH'\n }\n}\n\nclass ClientDestroyedError extends UndiciError {\n constructor (message) {\n super(message)\n Error.captureStackTrace(this, ClientDestroyedError)\n this.name = 'ClientDestroyedError'\n this.message = message || 'The client is destroyed'\n this.code = 'UND_ERR_DESTROYED'\n }\n}\n\nclass ClientClosedError extends UndiciError {\n constructor (message) {\n super(message)\n Error.captureStackTrace(this, ClientClosedError)\n this.name = 'ClientClosedError'\n this.message = message || 'The client is closed'\n this.code = 'UND_ERR_CLOSED'\n }\n}\n\nclass SocketError extends UndiciError {\n constructor (message, socket) {\n super(message)\n Error.captureStackTrace(this, SocketError)\n this.name = 'SocketError'\n this.message = message || 'Socket error'\n this.code = 'UND_ERR_SOCKET'\n this.socket = socket\n }\n}\n\nclass NotSupportedError extends UndiciError {\n constructor (message) {\n super(message)\n Error.captureStackTrace(this, NotSupportedError)\n this.name = 'NotSupportedError'\n this.message = message || 'Not supported error'\n this.code = 'UND_ERR_NOT_SUPPORTED'\n }\n}\n\nclass BalancedPoolMissingUpstreamError extends UndiciError {\n constructor (message) {\n super(message)\n Error.captureStackTrace(this, NotSupportedError)\n this.name = 'MissingUpstreamError'\n this.message = message || 'No upstream has been added to the BalancedPool'\n this.code = 'UND_ERR_BPL_MISSING_UPSTREAM'\n }\n}\n\nclass HTTPParserError extends Error {\n constructor (message, code, data) {\n super(message)\n Error.captureStackTrace(this, HTTPParserError)\n this.name = 'HTTPParserError'\n this.code = code ? `HPE_${code}` : undefined\n this.data = data ? data.toString() : undefined\n }\n}\n\nclass ResponseExceededMaxSizeError extends UndiciError {\n constructor (message) {\n super(message)\n Error.captureStackTrace(this, ResponseExceededMaxSizeError)\n this.name = 'ResponseExceededMaxSizeError'\n this.message = message || 'Response content exceeded max size'\n this.code = 'UND_ERR_RES_EXCEEDED_MAX_SIZE'\n }\n}\n\nclass RequestRetryError extends UndiciError {\n constructor (message, code, { headers, data }) {\n super(message)\n Error.captureStackTrace(this, RequestRetryError)\n this.name = 'RequestRetryError'\n this.message = message || 'Request retry error'\n this.code = 'UND_ERR_REQ_RETRY'\n this.statusCode = code\n this.data = data\n this.headers = headers\n }\n}\n\nmodule.exports = {\n HTTPParserError,\n UndiciError,\n HeadersTimeoutError,\n HeadersOverflowError,\n BodyTimeoutError,\n RequestContentLengthMismatchError,\n ConnectTimeoutError,\n ResponseStatusCodeError,\n InvalidArgumentError,\n InvalidReturnValueError,\n RequestAbortedError,\n ClientDestroyedError,\n ClientClosedError,\n InformationalError,\n SocketError,\n NotSupportedError,\n ResponseContentLengthMismatchError,\n BalancedPoolMissingUpstreamError,\n ResponseExceededMaxSizeError,\n RequestRetryError\n}\n","'use strict'\n\nconst {\n InvalidArgumentError,\n NotSupportedError\n} = require('./errors')\nconst assert = require('assert')\nconst { kHTTP2BuildRequest, kHTTP2CopyHeaders, kHTTP1BuildRequest } = require('./symbols')\nconst util = require('./util')\n\n// tokenRegExp and headerCharRegex have been lifted from\n// https://github.com/nodejs/node/blob/main/lib/_http_common.js\n\n/**\n * Verifies that the given val is a valid HTTP token\n * per the rules defined in RFC 7230\n * See https://tools.ietf.org/html/rfc7230#section-3.2.6\n */\nconst tokenRegExp = /^[\\^_`a-zA-Z\\-0-9!#$%&'*+.|~]+$/\n\n/**\n * Matches if val contains an invalid field-vchar\n * field-value = *( field-content / obs-fold )\n * field-content = field-vchar [ 1*( SP / HTAB ) field-vchar ]\n * field-vchar = VCHAR / obs-text\n */\nconst headerCharRegex = /[^\\t\\x20-\\x7e\\x80-\\xff]/\n\n// Verifies that a given path is valid does not contain control chars \\x00 to \\x20\nconst invalidPathRegex = /[^\\u0021-\\u00ff]/\n\nconst kHandler = Symbol('handler')\n\nconst channels = {}\n\nlet extractBody\n\ntry {\n const diagnosticsChannel = require('diagnostics_channel')\n channels.create = diagnosticsChannel.channel('undici:request:create')\n channels.bodySent = diagnosticsChannel.channel('undici:request:bodySent')\n channels.headers = diagnosticsChannel.channel('undici:request:headers')\n channels.trailers = diagnosticsChannel.channel('undici:request:trailers')\n channels.error = diagnosticsChannel.channel('undici:request:error')\n} catch {\n channels.create = { hasSubscribers: false }\n channels.bodySent = { hasSubscribers: false }\n channels.headers = { hasSubscribers: false }\n channels.trailers = { hasSubscribers: false }\n channels.error = { hasSubscribers: false }\n}\n\nclass Request {\n constructor (origin, {\n path,\n method,\n body,\n headers,\n query,\n idempotent,\n blocking,\n upgrade,\n headersTimeout,\n bodyTimeout,\n reset,\n throwOnError,\n expectContinue\n }, handler) {\n if (typeof path !== 'string') {\n throw new InvalidArgumentError('path must be a string')\n } else if (\n path[0] !== '/' &&\n !(path.startsWith('http://') || path.startsWith('https://')) &&\n method !== 'CONNECT'\n ) {\n throw new InvalidArgumentError('path must be an absolute URL or start with a slash')\n } else if (invalidPathRegex.exec(path) !== null) {\n throw new InvalidArgumentError('invalid request path')\n }\n\n if (typeof method !== 'string') {\n throw new InvalidArgumentError('method must be a string')\n } else if (tokenRegExp.exec(method) === null) {\n throw new InvalidArgumentError('invalid request method')\n }\n\n if (upgrade && typeof upgrade !== 'string') {\n throw new InvalidArgumentError('upgrade must be a string')\n }\n\n if (headersTimeout != null && (!Number.isFinite(headersTimeout) || headersTimeout < 0)) {\n throw new InvalidArgumentError('invalid headersTimeout')\n }\n\n if (bodyTimeout != null && (!Number.isFinite(bodyTimeout) || bodyTimeout < 0)) {\n throw new InvalidArgumentError('invalid bodyTimeout')\n }\n\n if (reset != null && typeof reset !== 'boolean') {\n throw new InvalidArgumentError('invalid reset')\n }\n\n if (expectContinue != null && typeof expectContinue !== 'boolean') {\n throw new InvalidArgumentError('invalid expectContinue')\n }\n\n this.headersTimeout = headersTimeout\n\n this.bodyTimeout = bodyTimeout\n\n this.throwOnError = throwOnError === true\n\n this.method = method\n\n this.abort = null\n\n if (body == null) {\n this.body = null\n } else if (util.isStream(body)) {\n this.body = body\n\n const rState = this.body._readableState\n if (!rState || !rState.autoDestroy) {\n this.endHandler = function autoDestroy () {\n util.destroy(this)\n }\n this.body.on('end', this.endHandler)\n }\n\n this.errorHandler = err => {\n if (this.abort) {\n this.abort(err)\n } else {\n this.error = err\n }\n }\n this.body.on('error', this.errorHandler)\n } else if (util.isBuffer(body)) {\n this.body = body.byteLength ? body : null\n } else if (ArrayBuffer.isView(body)) {\n this.body = body.buffer.byteLength ? Buffer.from(body.buffer, body.byteOffset, body.byteLength) : null\n } else if (body instanceof ArrayBuffer) {\n this.body = body.byteLength ? Buffer.from(body) : null\n } else if (typeof body === 'string') {\n this.body = body.length ? Buffer.from(body) : null\n } else if (util.isFormDataLike(body) || util.isIterable(body) || util.isBlobLike(body)) {\n this.body = body\n } else {\n throw new InvalidArgumentError('body must be a string, a Buffer, a Readable stream, an iterable, or an async iterable')\n }\n\n this.completed = false\n\n this.aborted = false\n\n this.upgrade = upgrade || null\n\n this.path = query ? util.buildURL(path, query) : path\n\n this.origin = origin\n\n this.idempotent = idempotent == null\n ? method === 'HEAD' || method === 'GET'\n : idempotent\n\n this.blocking = blocking == null ? false : blocking\n\n this.reset = reset == null ? null : reset\n\n this.host = null\n\n this.contentLength = null\n\n this.contentType = null\n\n this.headers = ''\n\n // Only for H2\n this.expectContinue = expectContinue != null ? expectContinue : false\n\n if (Array.isArray(headers)) {\n if (headers.length % 2 !== 0) {\n throw new InvalidArgumentError('headers array must be even')\n }\n for (let i = 0; i < headers.length; i += 2) {\n processHeader(this, headers[i], headers[i + 1])\n }\n } else if (headers && typeof headers === 'object') {\n const keys = Object.keys(headers)\n for (let i = 0; i < keys.length; i++) {\n const key = keys[i]\n processHeader(this, key, headers[key])\n }\n } else if (headers != null) {\n throw new InvalidArgumentError('headers must be an object or an array')\n }\n\n if (util.isFormDataLike(this.body)) {\n if (util.nodeMajor < 16 || (util.nodeMajor === 16 && util.nodeMinor < 8)) {\n throw new InvalidArgumentError('Form-Data bodies are only supported in node v16.8 and newer.')\n }\n\n if (!extractBody) {\n extractBody = require('../fetch/body.js').extractBody\n }\n\n const [bodyStream, contentType] = extractBody(body)\n if (this.contentType == null) {\n this.contentType = contentType\n this.headers += `content-type: ${contentType}\\r\\n`\n }\n this.body = bodyStream.stream\n this.contentLength = bodyStream.length\n } else if (util.isBlobLike(body) && this.contentType == null && body.type) {\n this.contentType = body.type\n this.headers += `content-type: ${body.type}\\r\\n`\n }\n\n util.validateHandler(handler, method, upgrade)\n\n this.servername = util.getServerName(this.host)\n\n this[kHandler] = handler\n\n if (channels.create.hasSubscribers) {\n channels.create.publish({ request: this })\n }\n }\n\n onBodySent (chunk) {\n if (this[kHandler].onBodySent) {\n try {\n return this[kHandler].onBodySent(chunk)\n } catch (err) {\n this.abort(err)\n }\n }\n }\n\n onRequestSent () {\n if (channels.bodySent.hasSubscribers) {\n channels.bodySent.publish({ request: this })\n }\n\n if (this[kHandler].onRequestSent) {\n try {\n return this[kHandler].onRequestSent()\n } catch (err) {\n this.abort(err)\n }\n }\n }\n\n onConnect (abort) {\n assert(!this.aborted)\n assert(!this.completed)\n\n if (this.error) {\n abort(this.error)\n } else {\n this.abort = abort\n return this[kHandler].onConnect(abort)\n }\n }\n\n onHeaders (statusCode, headers, resume, statusText) {\n assert(!this.aborted)\n assert(!this.completed)\n\n if (channels.headers.hasSubscribers) {\n channels.headers.publish({ request: this, response: { statusCode, headers, statusText } })\n }\n\n try {\n return this[kHandler].onHeaders(statusCode, headers, resume, statusText)\n } catch (err) {\n this.abort(err)\n }\n }\n\n onData (chunk) {\n assert(!this.aborted)\n assert(!this.completed)\n\n try {\n return this[kHandler].onData(chunk)\n } catch (err) {\n this.abort(err)\n return false\n }\n }\n\n onUpgrade (statusCode, headers, socket) {\n assert(!this.aborted)\n assert(!this.completed)\n\n return this[kHandler].onUpgrade(statusCode, headers, socket)\n }\n\n onComplete (trailers) {\n this.onFinally()\n\n assert(!this.aborted)\n\n this.completed = true\n if (channels.trailers.hasSubscribers) {\n channels.trailers.publish({ request: this, trailers })\n }\n\n try {\n return this[kHandler].onComplete(trailers)\n } catch (err) {\n // TODO (fix): This might be a bad idea?\n this.onError(err)\n }\n }\n\n onError (error) {\n this.onFinally()\n\n if (channels.error.hasSubscribers) {\n channels.error.publish({ request: this, error })\n }\n\n if (this.aborted) {\n return\n }\n this.aborted = true\n\n return this[kHandler].onError(error)\n }\n\n onFinally () {\n if (this.errorHandler) {\n this.body.off('error', this.errorHandler)\n this.errorHandler = null\n }\n\n if (this.endHandler) {\n this.body.off('end', this.endHandler)\n this.endHandler = null\n }\n }\n\n // TODO: adjust to support H2\n addHeader (key, value) {\n processHeader(this, key, value)\n return this\n }\n\n static [kHTTP1BuildRequest] (origin, opts, handler) {\n // TODO: Migrate header parsing here, to make Requests\n // HTTP agnostic\n return new Request(origin, opts, handler)\n }\n\n static [kHTTP2BuildRequest] (origin, opts, handler) {\n const headers = opts.headers\n opts = { ...opts, headers: null }\n\n const request = new Request(origin, opts, handler)\n\n request.headers = {}\n\n if (Array.isArray(headers)) {\n if (headers.length % 2 !== 0) {\n throw new InvalidArgumentError('headers array must be even')\n }\n for (let i = 0; i < headers.length; i += 2) {\n processHeader(request, headers[i], headers[i + 1], true)\n }\n } else if (headers && typeof headers === 'object') {\n const keys = Object.keys(headers)\n for (let i = 0; i < keys.length; i++) {\n const key = keys[i]\n processHeader(request, key, headers[key], true)\n }\n } else if (headers != null) {\n throw new InvalidArgumentError('headers must be an object or an array')\n }\n\n return request\n }\n\n static [kHTTP2CopyHeaders] (raw) {\n const rawHeaders = raw.split('\\r\\n')\n const headers = {}\n\n for (const header of rawHeaders) {\n const [key, value] = header.split(': ')\n\n if (value == null || value.length === 0) continue\n\n if (headers[key]) headers[key] += `,${value}`\n else headers[key] = value\n }\n\n return headers\n }\n}\n\nfunction processHeaderValue (key, val, skipAppend) {\n if (val && typeof val === 'object') {\n throw new InvalidArgumentError(`invalid ${key} header`)\n }\n\n val = val != null ? `${val}` : ''\n\n if (headerCharRegex.exec(val) !== null) {\n throw new InvalidArgumentError(`invalid ${key} header`)\n }\n\n return skipAppend ? val : `${key}: ${val}\\r\\n`\n}\n\nfunction processHeader (request, key, val, skipAppend = false) {\n if (val && (typeof val === 'object' && !Array.isArray(val))) {\n throw new InvalidArgumentError(`invalid ${key} header`)\n } else if (val === undefined) {\n return\n }\n\n if (\n request.host === null &&\n key.length === 4 &&\n key.toLowerCase() === 'host'\n ) {\n if (headerCharRegex.exec(val) !== null) {\n throw new InvalidArgumentError(`invalid ${key} header`)\n }\n // Consumed by Client\n request.host = val\n } else if (\n request.contentLength === null &&\n key.length === 14 &&\n key.toLowerCase() === 'content-length'\n ) {\n request.contentLength = parseInt(val, 10)\n if (!Number.isFinite(request.contentLength)) {\n throw new InvalidArgumentError('invalid content-length header')\n }\n } else if (\n request.contentType === null &&\n key.length === 12 &&\n key.toLowerCase() === 'content-type'\n ) {\n request.contentType = val\n if (skipAppend) request.headers[key] = processHeaderValue(key, val, skipAppend)\n else request.headers += processHeaderValue(key, val)\n } else if (\n key.length === 17 &&\n key.toLowerCase() === 'transfer-encoding'\n ) {\n throw new InvalidArgumentError('invalid transfer-encoding header')\n } else if (\n key.length === 10 &&\n key.toLowerCase() === 'connection'\n ) {\n const value = typeof val === 'string' ? val.toLowerCase() : null\n if (value !== 'close' && value !== 'keep-alive') {\n throw new InvalidArgumentError('invalid connection header')\n } else if (value === 'close') {\n request.reset = true\n }\n } else if (\n key.length === 10 &&\n key.toLowerCase() === 'keep-alive'\n ) {\n throw new InvalidArgumentError('invalid keep-alive header')\n } else if (\n key.length === 7 &&\n key.toLowerCase() === 'upgrade'\n ) {\n throw new InvalidArgumentError('invalid upgrade header')\n } else if (\n key.length === 6 &&\n key.toLowerCase() === 'expect'\n ) {\n throw new NotSupportedError('expect header not supported')\n } else if (tokenRegExp.exec(key) === null) {\n throw new InvalidArgumentError('invalid header key')\n } else {\n if (Array.isArray(val)) {\n for (let i = 0; i < val.length; i++) {\n if (skipAppend) {\n if (request.headers[key]) request.headers[key] += `,${processHeaderValue(key, val[i], skipAppend)}`\n else request.headers[key] = processHeaderValue(key, val[i], skipAppend)\n } else {\n request.headers += processHeaderValue(key, val[i])\n }\n }\n } else {\n if (skipAppend) request.headers[key] = processHeaderValue(key, val, skipAppend)\n else request.headers += processHeaderValue(key, val)\n }\n }\n}\n\nmodule.exports = Request\n","module.exports = {\n kClose: Symbol('close'),\n kDestroy: Symbol('destroy'),\n kDispatch: Symbol('dispatch'),\n kUrl: Symbol('url'),\n kWriting: Symbol('writing'),\n kResuming: Symbol('resuming'),\n kQueue: Symbol('queue'),\n kConnect: Symbol('connect'),\n kConnecting: Symbol('connecting'),\n kHeadersList: Symbol('headers list'),\n kKeepAliveDefaultTimeout: Symbol('default keep alive timeout'),\n kKeepAliveMaxTimeout: Symbol('max keep alive timeout'),\n kKeepAliveTimeoutThreshold: Symbol('keep alive timeout threshold'),\n kKeepAliveTimeoutValue: Symbol('keep alive timeout'),\n kKeepAlive: Symbol('keep alive'),\n kHeadersTimeout: Symbol('headers timeout'),\n kBodyTimeout: Symbol('body timeout'),\n kServerName: Symbol('server name'),\n kLocalAddress: Symbol('local address'),\n kHost: Symbol('host'),\n kNoRef: Symbol('no ref'),\n kBodyUsed: Symbol('used'),\n kRunning: Symbol('running'),\n kBlocking: Symbol('blocking'),\n kPending: Symbol('pending'),\n kSize: Symbol('size'),\n kBusy: Symbol('busy'),\n kQueued: Symbol('queued'),\n kFree: Symbol('free'),\n kConnected: Symbol('connected'),\n kClosed: Symbol('closed'),\n kNeedDrain: Symbol('need drain'),\n kReset: Symbol('reset'),\n kDestroyed: Symbol.for('nodejs.stream.destroyed'),\n kMaxHeadersSize: Symbol('max headers size'),\n kRunningIdx: Symbol('running index'),\n kPendingIdx: Symbol('pending index'),\n kError: Symbol('error'),\n kClients: Symbol('clients'),\n kClient: Symbol('client'),\n kParser: Symbol('parser'),\n kOnDestroyed: Symbol('destroy callbacks'),\n kPipelining: Symbol('pipelining'),\n kSocket: Symbol('socket'),\n kHostHeader: Symbol('host header'),\n kConnector: Symbol('connector'),\n kStrictContentLength: Symbol('strict content length'),\n kMaxRedirections: Symbol('maxRedirections'),\n kMaxRequests: Symbol('maxRequestsPerClient'),\n kProxy: Symbol('proxy agent options'),\n kCounter: Symbol('socket request counter'),\n kInterceptors: Symbol('dispatch interceptors'),\n kMaxResponseSize: Symbol('max response size'),\n kHTTP2Session: Symbol('http2Session'),\n kHTTP2SessionState: Symbol('http2Session state'),\n kHTTP2BuildRequest: Symbol('http2 build request'),\n kHTTP1BuildRequest: Symbol('http1 build request'),\n kHTTP2CopyHeaders: Symbol('http2 copy headers'),\n kHTTPConnVersion: Symbol('http connection version'),\n kRetryHandlerDefaultRetry: Symbol('retry agent default retry'),\n kConstruct: Symbol('constructable')\n}\n","'use strict'\n\nconst assert = require('assert')\nconst { kDestroyed, kBodyUsed } = require('./symbols')\nconst { IncomingMessage } = require('http')\nconst stream = require('stream')\nconst net = require('net')\nconst { InvalidArgumentError } = require('./errors')\nconst { Blob } = require('buffer')\nconst nodeUtil = require('util')\nconst { stringify } = require('querystring')\n\nconst [nodeMajor, nodeMinor] = process.versions.node.split('.').map(v => Number(v))\n\nfunction nop () {}\n\nfunction isStream (obj) {\n return obj && typeof obj === 'object' && typeof obj.pipe === 'function' && typeof obj.on === 'function'\n}\n\n// based on https://github.com/node-fetch/fetch-blob/blob/8ab587d34080de94140b54f07168451e7d0b655e/index.js#L229-L241 (MIT License)\nfunction isBlobLike (object) {\n return (Blob && object instanceof Blob) || (\n object &&\n typeof object === 'object' &&\n (typeof object.stream === 'function' ||\n typeof object.arrayBuffer === 'function') &&\n /^(Blob|File)$/.test(object[Symbol.toStringTag])\n )\n}\n\nfunction buildURL (url, queryParams) {\n if (url.includes('?') || url.includes('#')) {\n throw new Error('Query params cannot be passed when url already contains \"?\" or \"#\".')\n }\n\n const stringified = stringify(queryParams)\n\n if (stringified) {\n url += '?' + stringified\n }\n\n return url\n}\n\nfunction parseURL (url) {\n if (typeof url === 'string') {\n url = new URL(url)\n\n if (!/^https?:/.test(url.origin || url.protocol)) {\n throw new InvalidArgumentError('Invalid URL protocol: the URL must start with `http:` or `https:`.')\n }\n\n return url\n }\n\n if (!url || typeof url !== 'object') {\n throw new InvalidArgumentError('Invalid URL: The URL argument must be a non-null object.')\n }\n\n if (!/^https?:/.test(url.origin || url.protocol)) {\n throw new InvalidArgumentError('Invalid URL protocol: the URL must start with `http:` or `https:`.')\n }\n\n if (!(url instanceof URL)) {\n if (url.port != null && url.port !== '' && !Number.isFinite(parseInt(url.port))) {\n throw new InvalidArgumentError('Invalid URL: port must be a valid integer or a string representation of an integer.')\n }\n\n if (url.path != null && typeof url.path !== 'string') {\n throw new InvalidArgumentError('Invalid URL path: the path must be a string or null/undefined.')\n }\n\n if (url.pathname != null && typeof url.pathname !== 'string') {\n throw new InvalidArgumentError('Invalid URL pathname: the pathname must be a string or null/undefined.')\n }\n\n if (url.hostname != null && typeof url.hostname !== 'string') {\n throw new InvalidArgumentError('Invalid URL hostname: the hostname must be a string or null/undefined.')\n }\n\n if (url.origin != null && typeof url.origin !== 'string') {\n throw new InvalidArgumentError('Invalid URL origin: the origin must be a string or null/undefined.')\n }\n\n const port = url.port != null\n ? url.port\n : (url.protocol === 'https:' ? 443 : 80)\n let origin = url.origin != null\n ? url.origin\n : `${url.protocol}//${url.hostname}:${port}`\n let path = url.path != null\n ? url.path\n : `${url.pathname || ''}${url.search || ''}`\n\n if (origin.endsWith('/')) {\n origin = origin.substring(0, origin.length - 1)\n }\n\n if (path && !path.startsWith('/')) {\n path = `/${path}`\n }\n // new URL(path, origin) is unsafe when `path` contains an absolute URL\n // From https://developer.mozilla.org/en-US/docs/Web/API/URL/URL:\n // If first parameter is a relative URL, second param is required, and will be used as the base URL.\n // If first parameter is an absolute URL, a given second param will be ignored.\n url = new URL(origin + path)\n }\n\n return url\n}\n\nfunction parseOrigin (url) {\n url = parseURL(url)\n\n if (url.pathname !== '/' || url.search || url.hash) {\n throw new InvalidArgumentError('invalid url')\n }\n\n return url\n}\n\nfunction getHostname (host) {\n if (host[0] === '[') {\n const idx = host.indexOf(']')\n\n assert(idx !== -1)\n return host.substring(1, idx)\n }\n\n const idx = host.indexOf(':')\n if (idx === -1) return host\n\n return host.substring(0, idx)\n}\n\n// IP addresses are not valid server names per RFC6066\n// > Currently, the only server names supported are DNS hostnames\nfunction getServerName (host) {\n if (!host) {\n return null\n }\n\n assert.strictEqual(typeof host, 'string')\n\n const servername = getHostname(host)\n if (net.isIP(servername)) {\n return ''\n }\n\n return servername\n}\n\nfunction deepClone (obj) {\n return JSON.parse(JSON.stringify(obj))\n}\n\nfunction isAsyncIterable (obj) {\n return !!(obj != null && typeof obj[Symbol.asyncIterator] === 'function')\n}\n\nfunction isIterable (obj) {\n return !!(obj != null && (typeof obj[Symbol.iterator] === 'function' || typeof obj[Symbol.asyncIterator] === 'function'))\n}\n\nfunction bodyLength (body) {\n if (body == null) {\n return 0\n } else if (isStream(body)) {\n const state = body._readableState\n return state && state.objectMode === false && state.ended === true && Number.isFinite(state.length)\n ? state.length\n : null\n } else if (isBlobLike(body)) {\n return body.size != null ? body.size : null\n } else if (isBuffer(body)) {\n return body.byteLength\n }\n\n return null\n}\n\nfunction isDestroyed (stream) {\n return !stream || !!(stream.destroyed || stream[kDestroyed])\n}\n\nfunction isReadableAborted (stream) {\n const state = stream && stream._readableState\n return isDestroyed(stream) && state && !state.endEmitted\n}\n\nfunction destroy (stream, err) {\n if (stream == null || !isStream(stream) || isDestroyed(stream)) {\n return\n }\n\n if (typeof stream.destroy === 'function') {\n if (Object.getPrototypeOf(stream).constructor === IncomingMessage) {\n // See: https://github.com/nodejs/node/pull/38505/files\n stream.socket = null\n }\n\n stream.destroy(err)\n } else if (err) {\n process.nextTick((stream, err) => {\n stream.emit('error', err)\n }, stream, err)\n }\n\n if (stream.destroyed !== true) {\n stream[kDestroyed] = true\n }\n}\n\nconst KEEPALIVE_TIMEOUT_EXPR = /timeout=(\\d+)/\nfunction parseKeepAliveTimeout (val) {\n const m = val.toString().match(KEEPALIVE_TIMEOUT_EXPR)\n return m ? parseInt(m[1], 10) * 1000 : null\n}\n\nfunction parseHeaders (headers, obj = {}) {\n // For H2 support\n if (!Array.isArray(headers)) return headers\n\n for (let i = 0; i < headers.length; i += 2) {\n const key = headers[i].toString().toLowerCase()\n let val = obj[key]\n\n if (!val) {\n if (Array.isArray(headers[i + 1])) {\n obj[key] = headers[i + 1].map(x => x.toString('utf8'))\n } else {\n obj[key] = headers[i + 1].toString('utf8')\n }\n } else {\n if (!Array.isArray(val)) {\n val = [val]\n obj[key] = val\n }\n val.push(headers[i + 1].toString('utf8'))\n }\n }\n\n // See https://github.com/nodejs/node/pull/46528\n if ('content-length' in obj && 'content-disposition' in obj) {\n obj['content-disposition'] = Buffer.from(obj['content-disposition']).toString('latin1')\n }\n\n return obj\n}\n\nfunction parseRawHeaders (headers) {\n const ret = []\n let hasContentLength = false\n let contentDispositionIdx = -1\n\n for (let n = 0; n < headers.length; n += 2) {\n const key = headers[n + 0].toString()\n const val = headers[n + 1].toString('utf8')\n\n if (key.length === 14 && (key === 'content-length' || key.toLowerCase() === 'content-length')) {\n ret.push(key, val)\n hasContentLength = true\n } else if (key.length === 19 && (key === 'content-disposition' || key.toLowerCase() === 'content-disposition')) {\n contentDispositionIdx = ret.push(key, val) - 1\n } else {\n ret.push(key, val)\n }\n }\n\n // See https://github.com/nodejs/node/pull/46528\n if (hasContentLength && contentDispositionIdx !== -1) {\n ret[contentDispositionIdx] = Buffer.from(ret[contentDispositionIdx]).toString('latin1')\n }\n\n return ret\n}\n\nfunction isBuffer (buffer) {\n // See, https://github.com/mcollina/undici/pull/319\n return buffer instanceof Uint8Array || Buffer.isBuffer(buffer)\n}\n\nfunction validateHandler (handler, method, upgrade) {\n if (!handler || typeof handler !== 'object') {\n throw new InvalidArgumentError('handler must be an object')\n }\n\n if (typeof handler.onConnect !== 'function') {\n throw new InvalidArgumentError('invalid onConnect method')\n }\n\n if (typeof handler.onError !== 'function') {\n throw new InvalidArgumentError('invalid onError method')\n }\n\n if (typeof handler.onBodySent !== 'function' && handler.onBodySent !== undefined) {\n throw new InvalidArgumentError('invalid onBodySent method')\n }\n\n if (upgrade || method === 'CONNECT') {\n if (typeof handler.onUpgrade !== 'function') {\n throw new InvalidArgumentError('invalid onUpgrade method')\n }\n } else {\n if (typeof handler.onHeaders !== 'function') {\n throw new InvalidArgumentError('invalid onHeaders method')\n }\n\n if (typeof handler.onData !== 'function') {\n throw new InvalidArgumentError('invalid onData method')\n }\n\n if (typeof handler.onComplete !== 'function') {\n throw new InvalidArgumentError('invalid onComplete method')\n }\n }\n}\n\n// A body is disturbed if it has been read from and it cannot\n// be re-used without losing state or data.\nfunction isDisturbed (body) {\n return !!(body && (\n stream.isDisturbed\n ? stream.isDisturbed(body) || body[kBodyUsed] // TODO (fix): Why is body[kBodyUsed] needed?\n : body[kBodyUsed] ||\n body.readableDidRead ||\n (body._readableState && body._readableState.dataEmitted) ||\n isReadableAborted(body)\n ))\n}\n\nfunction isErrored (body) {\n return !!(body && (\n stream.isErrored\n ? stream.isErrored(body)\n : /state: 'errored'/.test(nodeUtil.inspect(body)\n )))\n}\n\nfunction isReadable (body) {\n return !!(body && (\n stream.isReadable\n ? stream.isReadable(body)\n : /state: 'readable'/.test(nodeUtil.inspect(body)\n )))\n}\n\nfunction getSocketInfo (socket) {\n return {\n localAddress: socket.localAddress,\n localPort: socket.localPort,\n remoteAddress: socket.remoteAddress,\n remotePort: socket.remotePort,\n remoteFamily: socket.remoteFamily,\n timeout: socket.timeout,\n bytesWritten: socket.bytesWritten,\n bytesRead: socket.bytesRead\n }\n}\n\nasync function * convertIterableToBuffer (iterable) {\n for await (const chunk of iterable) {\n yield Buffer.isBuffer(chunk) ? chunk : Buffer.from(chunk)\n }\n}\n\nlet ReadableStream\nfunction ReadableStreamFrom (iterable) {\n if (!ReadableStream) {\n ReadableStream = require('stream/web').ReadableStream\n }\n\n if (ReadableStream.from) {\n return ReadableStream.from(convertIterableToBuffer(iterable))\n }\n\n let iterator\n return new ReadableStream(\n {\n async start () {\n iterator = iterable[Symbol.asyncIterator]()\n },\n async pull (controller) {\n const { done, value } = await iterator.next()\n if (done) {\n queueMicrotask(() => {\n controller.close()\n })\n } else {\n const buf = Buffer.isBuffer(value) ? value : Buffer.from(value)\n controller.enqueue(new Uint8Array(buf))\n }\n return controller.desiredSize > 0\n },\n async cancel (reason) {\n await iterator.return()\n }\n },\n 0\n )\n}\n\n// The chunk should be a FormData instance and contains\n// all the required methods.\nfunction isFormDataLike (object) {\n return (\n object &&\n typeof object === 'object' &&\n typeof object.append === 'function' &&\n typeof object.delete === 'function' &&\n typeof object.get === 'function' &&\n typeof object.getAll === 'function' &&\n typeof object.has === 'function' &&\n typeof object.set === 'function' &&\n object[Symbol.toStringTag] === 'FormData'\n )\n}\n\nfunction throwIfAborted (signal) {\n if (!signal) { return }\n if (typeof signal.throwIfAborted === 'function') {\n signal.throwIfAborted()\n } else {\n if (signal.aborted) {\n // DOMException not available < v17.0.0\n const err = new Error('The operation was aborted')\n err.name = 'AbortError'\n throw err\n }\n }\n}\n\nfunction addAbortListener (signal, listener) {\n if ('addEventListener' in signal) {\n signal.addEventListener('abort', listener, { once: true })\n return () => signal.removeEventListener('abort', listener)\n }\n signal.addListener('abort', listener)\n return () => signal.removeListener('abort', listener)\n}\n\nconst hasToWellFormed = !!String.prototype.toWellFormed\n\n/**\n * @param {string} val\n */\nfunction toUSVString (val) {\n if (hasToWellFormed) {\n return `${val}`.toWellFormed()\n } else if (nodeUtil.toUSVString) {\n return nodeUtil.toUSVString(val)\n }\n\n return `${val}`\n}\n\n// Parsed accordingly to RFC 9110\n// https://www.rfc-editor.org/rfc/rfc9110#field.content-range\nfunction parseRangeHeader (range) {\n if (range == null || range === '') return { start: 0, end: null, size: null }\n\n const m = range ? range.match(/^bytes (\\d+)-(\\d+)\\/(\\d+)?$/) : null\n return m\n ? {\n start: parseInt(m[1]),\n end: m[2] ? parseInt(m[2]) : null,\n size: m[3] ? parseInt(m[3]) : null\n }\n : null\n}\n\nconst kEnumerableProperty = Object.create(null)\nkEnumerableProperty.enumerable = true\n\nmodule.exports = {\n kEnumerableProperty,\n nop,\n isDisturbed,\n isErrored,\n isReadable,\n toUSVString,\n isReadableAborted,\n isBlobLike,\n parseOrigin,\n parseURL,\n getServerName,\n isStream,\n isIterable,\n isAsyncIterable,\n isDestroyed,\n parseRawHeaders,\n parseHeaders,\n parseKeepAliveTimeout,\n destroy,\n bodyLength,\n deepClone,\n ReadableStreamFrom,\n isBuffer,\n validateHandler,\n getSocketInfo,\n isFormDataLike,\n buildURL,\n throwIfAborted,\n addAbortListener,\n parseRangeHeader,\n nodeMajor,\n nodeMinor,\n nodeHasAutoSelectFamily: nodeMajor > 18 || (nodeMajor === 18 && nodeMinor >= 13),\n safeHTTPMethods: ['GET', 'HEAD', 'OPTIONS', 'TRACE']\n}\n","'use strict'\n\nconst Dispatcher = require('./dispatcher')\nconst {\n ClientDestroyedError,\n ClientClosedError,\n InvalidArgumentError\n} = require('./core/errors')\nconst { kDestroy, kClose, kDispatch, kInterceptors } = require('./core/symbols')\n\nconst kDestroyed = Symbol('destroyed')\nconst kClosed = Symbol('closed')\nconst kOnDestroyed = Symbol('onDestroyed')\nconst kOnClosed = Symbol('onClosed')\nconst kInterceptedDispatch = Symbol('Intercepted Dispatch')\n\nclass DispatcherBase extends Dispatcher {\n constructor () {\n super()\n\n this[kDestroyed] = false\n this[kOnDestroyed] = null\n this[kClosed] = false\n this[kOnClosed] = []\n }\n\n get destroyed () {\n return this[kDestroyed]\n }\n\n get closed () {\n return this[kClosed]\n }\n\n get interceptors () {\n return this[kInterceptors]\n }\n\n set interceptors (newInterceptors) {\n if (newInterceptors) {\n for (let i = newInterceptors.length - 1; i >= 0; i--) {\n const interceptor = this[kInterceptors][i]\n if (typeof interceptor !== 'function') {\n throw new InvalidArgumentError('interceptor must be an function')\n }\n }\n }\n\n this[kInterceptors] = newInterceptors\n }\n\n close (callback) {\n if (callback === undefined) {\n return new Promise((resolve, reject) => {\n this.close((err, data) => {\n return err ? reject(err) : resolve(data)\n })\n })\n }\n\n if (typeof callback !== 'function') {\n throw new InvalidArgumentError('invalid callback')\n }\n\n if (this[kDestroyed]) {\n queueMicrotask(() => callback(new ClientDestroyedError(), null))\n return\n }\n\n if (this[kClosed]) {\n if (this[kOnClosed]) {\n this[kOnClosed].push(callback)\n } else {\n queueMicrotask(() => callback(null, null))\n }\n return\n }\n\n this[kClosed] = true\n this[kOnClosed].push(callback)\n\n const onClosed = () => {\n const callbacks = this[kOnClosed]\n this[kOnClosed] = null\n for (let i = 0; i < callbacks.length; i++) {\n callbacks[i](null, null)\n }\n }\n\n // Should not error.\n this[kClose]()\n .then(() => this.destroy())\n .then(() => {\n queueMicrotask(onClosed)\n })\n }\n\n destroy (err, callback) {\n if (typeof err === 'function') {\n callback = err\n err = null\n }\n\n if (callback === undefined) {\n return new Promise((resolve, reject) => {\n this.destroy(err, (err, data) => {\n return err ? /* istanbul ignore next: should never error */ reject(err) : resolve(data)\n })\n })\n }\n\n if (typeof callback !== 'function') {\n throw new InvalidArgumentError('invalid callback')\n }\n\n if (this[kDestroyed]) {\n if (this[kOnDestroyed]) {\n this[kOnDestroyed].push(callback)\n } else {\n queueMicrotask(() => callback(null, null))\n }\n return\n }\n\n if (!err) {\n err = new ClientDestroyedError()\n }\n\n this[kDestroyed] = true\n this[kOnDestroyed] = this[kOnDestroyed] || []\n this[kOnDestroyed].push(callback)\n\n const onDestroyed = () => {\n const callbacks = this[kOnDestroyed]\n this[kOnDestroyed] = null\n for (let i = 0; i < callbacks.length; i++) {\n callbacks[i](null, null)\n }\n }\n\n // Should not error.\n this[kDestroy](err).then(() => {\n queueMicrotask(onDestroyed)\n })\n }\n\n [kInterceptedDispatch] (opts, handler) {\n if (!this[kInterceptors] || this[kInterceptors].length === 0) {\n this[kInterceptedDispatch] = this[kDispatch]\n return this[kDispatch](opts, handler)\n }\n\n let dispatch = this[kDispatch].bind(this)\n for (let i = this[kInterceptors].length - 1; i >= 0; i--) {\n dispatch = this[kInterceptors][i](dispatch)\n }\n this[kInterceptedDispatch] = dispatch\n return dispatch(opts, handler)\n }\n\n dispatch (opts, handler) {\n if (!handler || typeof handler !== 'object') {\n throw new InvalidArgumentError('handler must be an object')\n }\n\n try {\n if (!opts || typeof opts !== 'object') {\n throw new InvalidArgumentError('opts must be an object.')\n }\n\n if (this[kDestroyed] || this[kOnDestroyed]) {\n throw new ClientDestroyedError()\n }\n\n if (this[kClosed]) {\n throw new ClientClosedError()\n }\n\n return this[kInterceptedDispatch](opts, handler)\n } catch (err) {\n if (typeof handler.onError !== 'function') {\n throw new InvalidArgumentError('invalid onError method')\n }\n\n handler.onError(err)\n\n return false\n }\n }\n}\n\nmodule.exports = DispatcherBase\n","'use strict'\n\nconst EventEmitter = require('events')\n\nclass Dispatcher extends EventEmitter {\n dispatch () {\n throw new Error('not implemented')\n }\n\n close () {\n throw new Error('not implemented')\n }\n\n destroy () {\n throw new Error('not implemented')\n }\n}\n\nmodule.exports = Dispatcher\n","'use strict'\n\nconst Busboy = require('@fastify/busboy')\nconst util = require('../core/util')\nconst {\n ReadableStreamFrom,\n isBlobLike,\n isReadableStreamLike,\n readableStreamClose,\n createDeferredPromise,\n fullyReadBody\n} = require('./util')\nconst { FormData } = require('./formdata')\nconst { kState } = require('./symbols')\nconst { webidl } = require('./webidl')\nconst { DOMException, structuredClone } = require('./constants')\nconst { Blob, File: NativeFile } = require('buffer')\nconst { kBodyUsed } = require('../core/symbols')\nconst assert = require('assert')\nconst { isErrored } = require('../core/util')\nconst { isUint8Array, isArrayBuffer } = require('util/types')\nconst { File: UndiciFile } = require('./file')\nconst { parseMIMEType, serializeAMimeType } = require('./dataURL')\n\nlet ReadableStream = globalThis.ReadableStream\n\n/** @type {globalThis['File']} */\nconst File = NativeFile ?? UndiciFile\nconst textEncoder = new TextEncoder()\nconst textDecoder = new TextDecoder()\n\n// https://fetch.spec.whatwg.org/#concept-bodyinit-extract\nfunction extractBody (object, keepalive = false) {\n if (!ReadableStream) {\n ReadableStream = require('stream/web').ReadableStream\n }\n\n // 1. Let stream be null.\n let stream = null\n\n // 2. If object is a ReadableStream object, then set stream to object.\n if (object instanceof ReadableStream) {\n stream = object\n } else if (isBlobLike(object)) {\n // 3. Otherwise, if object is a Blob object, set stream to the\n // result of running object’s get stream.\n stream = object.stream()\n } else {\n // 4. Otherwise, set stream to a new ReadableStream object, and set\n // up stream.\n stream = new ReadableStream({\n async pull (controller) {\n controller.enqueue(\n typeof source === 'string' ? textEncoder.encode(source) : source\n )\n queueMicrotask(() => readableStreamClose(controller))\n },\n start () {},\n type: undefined\n })\n }\n\n // 5. Assert: stream is a ReadableStream object.\n assert(isReadableStreamLike(stream))\n\n // 6. Let action be null.\n let action = null\n\n // 7. Let source be null.\n let source = null\n\n // 8. Let length be null.\n let length = null\n\n // 9. Let type be null.\n let type = null\n\n // 10. Switch on object:\n if (typeof object === 'string') {\n // Set source to the UTF-8 encoding of object.\n // Note: setting source to a Uint8Array here breaks some mocking assumptions.\n source = object\n\n // Set type to `text/plain;charset=UTF-8`.\n type = 'text/plain;charset=UTF-8'\n } else if (object instanceof URLSearchParams) {\n // URLSearchParams\n\n // spec says to run application/x-www-form-urlencoded on body.list\n // this is implemented in Node.js as apart of an URLSearchParams instance toString method\n // See: https://github.com/nodejs/node/blob/e46c680bf2b211bbd52cf959ca17ee98c7f657f5/lib/internal/url.js#L490\n // and https://github.com/nodejs/node/blob/e46c680bf2b211bbd52cf959ca17ee98c7f657f5/lib/internal/url.js#L1100\n\n // Set source to the result of running the application/x-www-form-urlencoded serializer with object’s list.\n source = object.toString()\n\n // Set type to `application/x-www-form-urlencoded;charset=UTF-8`.\n type = 'application/x-www-form-urlencoded;charset=UTF-8'\n } else if (isArrayBuffer(object)) {\n // BufferSource/ArrayBuffer\n\n // Set source to a copy of the bytes held by object.\n source = new Uint8Array(object.slice())\n } else if (ArrayBuffer.isView(object)) {\n // BufferSource/ArrayBufferView\n\n // Set source to a copy of the bytes held by object.\n source = new Uint8Array(object.buffer.slice(object.byteOffset, object.byteOffset + object.byteLength))\n } else if (util.isFormDataLike(object)) {\n const boundary = `----formdata-undici-0${`${Math.floor(Math.random() * 1e11)}`.padStart(11, '0')}`\n const prefix = `--${boundary}\\r\\nContent-Disposition: form-data`\n\n /*! formdata-polyfill. MIT License. Jimmy Wärting */\n const escape = (str) =>\n str.replace(/\\n/g, '%0A').replace(/\\r/g, '%0D').replace(/\"/g, '%22')\n const normalizeLinefeeds = (value) => value.replace(/\\r?\\n|\\r/g, '\\r\\n')\n\n // Set action to this step: run the multipart/form-data\n // encoding algorithm, with object’s entry list and UTF-8.\n // - This ensures that the body is immutable and can't be changed afterwords\n // - That the content-length is calculated in advance.\n // - And that all parts are pre-encoded and ready to be sent.\n\n const blobParts = []\n const rn = new Uint8Array([13, 10]) // '\\r\\n'\n length = 0\n let hasUnknownSizeValue = false\n\n for (const [name, value] of object) {\n if (typeof value === 'string') {\n const chunk = textEncoder.encode(prefix +\n `; name=\"${escape(normalizeLinefeeds(name))}\"` +\n `\\r\\n\\r\\n${normalizeLinefeeds(value)}\\r\\n`)\n blobParts.push(chunk)\n length += chunk.byteLength\n } else {\n const chunk = textEncoder.encode(`${prefix}; name=\"${escape(normalizeLinefeeds(name))}\"` +\n (value.name ? `; filename=\"${escape(value.name)}\"` : '') + '\\r\\n' +\n `Content-Type: ${\n value.type || 'application/octet-stream'\n }\\r\\n\\r\\n`)\n blobParts.push(chunk, value, rn)\n if (typeof value.size === 'number') {\n length += chunk.byteLength + value.size + rn.byteLength\n } else {\n hasUnknownSizeValue = true\n }\n }\n }\n\n const chunk = textEncoder.encode(`--${boundary}--`)\n blobParts.push(chunk)\n length += chunk.byteLength\n if (hasUnknownSizeValue) {\n length = null\n }\n\n // Set source to object.\n source = object\n\n action = async function * () {\n for (const part of blobParts) {\n if (part.stream) {\n yield * part.stream()\n } else {\n yield part\n }\n }\n }\n\n // Set type to `multipart/form-data; boundary=`,\n // followed by the multipart/form-data boundary string generated\n // by the multipart/form-data encoding algorithm.\n type = 'multipart/form-data; boundary=' + boundary\n } else if (isBlobLike(object)) {\n // Blob\n\n // Set source to object.\n source = object\n\n // Set length to object’s size.\n length = object.size\n\n // If object’s type attribute is not the empty byte sequence, set\n // type to its value.\n if (object.type) {\n type = object.type\n }\n } else if (typeof object[Symbol.asyncIterator] === 'function') {\n // If keepalive is true, then throw a TypeError.\n if (keepalive) {\n throw new TypeError('keepalive')\n }\n\n // If object is disturbed or locked, then throw a TypeError.\n if (util.isDisturbed(object) || object.locked) {\n throw new TypeError(\n 'Response body object should not be disturbed or locked'\n )\n }\n\n stream =\n object instanceof ReadableStream ? object : ReadableStreamFrom(object)\n }\n\n // 11. If source is a byte sequence, then set action to a\n // step that returns source and length to source’s length.\n if (typeof source === 'string' || util.isBuffer(source)) {\n length = Buffer.byteLength(source)\n }\n\n // 12. If action is non-null, then run these steps in in parallel:\n if (action != null) {\n // Run action.\n let iterator\n stream = new ReadableStream({\n async start () {\n iterator = action(object)[Symbol.asyncIterator]()\n },\n async pull (controller) {\n const { value, done } = await iterator.next()\n if (done) {\n // When running action is done, close stream.\n queueMicrotask(() => {\n controller.close()\n })\n } else {\n // Whenever one or more bytes are available and stream is not errored,\n // enqueue a Uint8Array wrapping an ArrayBuffer containing the available\n // bytes into stream.\n if (!isErrored(stream)) {\n controller.enqueue(new Uint8Array(value))\n }\n }\n return controller.desiredSize > 0\n },\n async cancel (reason) {\n await iterator.return()\n },\n type: undefined\n })\n }\n\n // 13. Let body be a body whose stream is stream, source is source,\n // and length is length.\n const body = { stream, source, length }\n\n // 14. Return (body, type).\n return [body, type]\n}\n\n// https://fetch.spec.whatwg.org/#bodyinit-safely-extract\nfunction safelyExtractBody (object, keepalive = false) {\n if (!ReadableStream) {\n // istanbul ignore next\n ReadableStream = require('stream/web').ReadableStream\n }\n\n // To safely extract a body and a `Content-Type` value from\n // a byte sequence or BodyInit object object, run these steps:\n\n // 1. If object is a ReadableStream object, then:\n if (object instanceof ReadableStream) {\n // Assert: object is neither disturbed nor locked.\n // istanbul ignore next\n assert(!util.isDisturbed(object), 'The body has already been consumed.')\n // istanbul ignore next\n assert(!object.locked, 'The stream is locked.')\n }\n\n // 2. Return the results of extracting object.\n return extractBody(object, keepalive)\n}\n\nfunction cloneBody (body) {\n // To clone a body body, run these steps:\n\n // https://fetch.spec.whatwg.org/#concept-body-clone\n\n // 1. Let « out1, out2 » be the result of teeing body’s stream.\n const [out1, out2] = body.stream.tee()\n const out2Clone = structuredClone(out2, { transfer: [out2] })\n // This, for whatever reasons, unrefs out2Clone which allows\n // the process to exit by itself.\n const [, finalClone] = out2Clone.tee()\n\n // 2. Set body’s stream to out1.\n body.stream = out1\n\n // 3. Return a body whose stream is out2 and other members are copied from body.\n return {\n stream: finalClone,\n length: body.length,\n source: body.source\n }\n}\n\nasync function * consumeBody (body) {\n if (body) {\n if (isUint8Array(body)) {\n yield body\n } else {\n const stream = body.stream\n\n if (util.isDisturbed(stream)) {\n throw new TypeError('The body has already been consumed.')\n }\n\n if (stream.locked) {\n throw new TypeError('The stream is locked.')\n }\n\n // Compat.\n stream[kBodyUsed] = true\n\n yield * stream\n }\n }\n}\n\nfunction throwIfAborted (state) {\n if (state.aborted) {\n throw new DOMException('The operation was aborted.', 'AbortError')\n }\n}\n\nfunction bodyMixinMethods (instance) {\n const methods = {\n blob () {\n // The blob() method steps are to return the result of\n // running consume body with this and the following step\n // given a byte sequence bytes: return a Blob whose\n // contents are bytes and whose type attribute is this’s\n // MIME type.\n return specConsumeBody(this, (bytes) => {\n let mimeType = bodyMimeType(this)\n\n if (mimeType === 'failure') {\n mimeType = ''\n } else if (mimeType) {\n mimeType = serializeAMimeType(mimeType)\n }\n\n // Return a Blob whose contents are bytes and type attribute\n // is mimeType.\n return new Blob([bytes], { type: mimeType })\n }, instance)\n },\n\n arrayBuffer () {\n // The arrayBuffer() method steps are to return the result\n // of running consume body with this and the following step\n // given a byte sequence bytes: return a new ArrayBuffer\n // whose contents are bytes.\n return specConsumeBody(this, (bytes) => {\n return new Uint8Array(bytes).buffer\n }, instance)\n },\n\n text () {\n // The text() method steps are to return the result of running\n // consume body with this and UTF-8 decode.\n return specConsumeBody(this, utf8DecodeBytes, instance)\n },\n\n json () {\n // The json() method steps are to return the result of running\n // consume body with this and parse JSON from bytes.\n return specConsumeBody(this, parseJSONFromBytes, instance)\n },\n\n async formData () {\n webidl.brandCheck(this, instance)\n\n throwIfAborted(this[kState])\n\n const contentType = this.headers.get('Content-Type')\n\n // If mimeType’s essence is \"multipart/form-data\", then:\n if (/multipart\\/form-data/.test(contentType)) {\n const headers = {}\n for (const [key, value] of this.headers) headers[key.toLowerCase()] = value\n\n const responseFormData = new FormData()\n\n let busboy\n\n try {\n busboy = new Busboy({\n headers,\n preservePath: true\n })\n } catch (err) {\n throw new DOMException(`${err}`, 'AbortError')\n }\n\n busboy.on('field', (name, value) => {\n responseFormData.append(name, value)\n })\n busboy.on('file', (name, value, filename, encoding, mimeType) => {\n const chunks = []\n\n if (encoding === 'base64' || encoding.toLowerCase() === 'base64') {\n let base64chunk = ''\n\n value.on('data', (chunk) => {\n base64chunk += chunk.toString().replace(/[\\r\\n]/gm, '')\n\n const end = base64chunk.length - base64chunk.length % 4\n chunks.push(Buffer.from(base64chunk.slice(0, end), 'base64'))\n\n base64chunk = base64chunk.slice(end)\n })\n value.on('end', () => {\n chunks.push(Buffer.from(base64chunk, 'base64'))\n responseFormData.append(name, new File(chunks, filename, { type: mimeType }))\n })\n } else {\n value.on('data', (chunk) => {\n chunks.push(chunk)\n })\n value.on('end', () => {\n responseFormData.append(name, new File(chunks, filename, { type: mimeType }))\n })\n }\n })\n\n const busboyResolve = new Promise((resolve, reject) => {\n busboy.on('finish', resolve)\n busboy.on('error', (err) => reject(new TypeError(err)))\n })\n\n if (this.body !== null) for await (const chunk of consumeBody(this[kState].body)) busboy.write(chunk)\n busboy.end()\n await busboyResolve\n\n return responseFormData\n } else if (/application\\/x-www-form-urlencoded/.test(contentType)) {\n // Otherwise, if mimeType’s essence is \"application/x-www-form-urlencoded\", then:\n\n // 1. Let entries be the result of parsing bytes.\n let entries\n try {\n let text = ''\n // application/x-www-form-urlencoded parser will keep the BOM.\n // https://url.spec.whatwg.org/#concept-urlencoded-parser\n // Note that streaming decoder is stateful and cannot be reused\n const streamingDecoder = new TextDecoder('utf-8', { ignoreBOM: true })\n\n for await (const chunk of consumeBody(this[kState].body)) {\n if (!isUint8Array(chunk)) {\n throw new TypeError('Expected Uint8Array chunk')\n }\n text += streamingDecoder.decode(chunk, { stream: true })\n }\n text += streamingDecoder.decode()\n entries = new URLSearchParams(text)\n } catch (err) {\n // istanbul ignore next: Unclear when new URLSearchParams can fail on a string.\n // 2. If entries is failure, then throw a TypeError.\n throw Object.assign(new TypeError(), { cause: err })\n }\n\n // 3. Return a new FormData object whose entries are entries.\n const formData = new FormData()\n for (const [name, value] of entries) {\n formData.append(name, value)\n }\n return formData\n } else {\n // Wait a tick before checking if the request has been aborted.\n // Otherwise, a TypeError can be thrown when an AbortError should.\n await Promise.resolve()\n\n throwIfAborted(this[kState])\n\n // Otherwise, throw a TypeError.\n throw webidl.errors.exception({\n header: `${instance.name}.formData`,\n message: 'Could not parse content as FormData.'\n })\n }\n }\n }\n\n return methods\n}\n\nfunction mixinBody (prototype) {\n Object.assign(prototype.prototype, bodyMixinMethods(prototype))\n}\n\n/**\n * @see https://fetch.spec.whatwg.org/#concept-body-consume-body\n * @param {Response|Request} object\n * @param {(value: unknown) => unknown} convertBytesToJSValue\n * @param {Response|Request} instance\n */\nasync function specConsumeBody (object, convertBytesToJSValue, instance) {\n webidl.brandCheck(object, instance)\n\n throwIfAborted(object[kState])\n\n // 1. If object is unusable, then return a promise rejected\n // with a TypeError.\n if (bodyUnusable(object[kState].body)) {\n throw new TypeError('Body is unusable')\n }\n\n // 2. Let promise be a new promise.\n const promise = createDeferredPromise()\n\n // 3. Let errorSteps given error be to reject promise with error.\n const errorSteps = (error) => promise.reject(error)\n\n // 4. Let successSteps given a byte sequence data be to resolve\n // promise with the result of running convertBytesToJSValue\n // with data. If that threw an exception, then run errorSteps\n // with that exception.\n const successSteps = (data) => {\n try {\n promise.resolve(convertBytesToJSValue(data))\n } catch (e) {\n errorSteps(e)\n }\n }\n\n // 5. If object’s body is null, then run successSteps with an\n // empty byte sequence.\n if (object[kState].body == null) {\n successSteps(new Uint8Array())\n return promise.promise\n }\n\n // 6. Otherwise, fully read object’s body given successSteps,\n // errorSteps, and object’s relevant global object.\n await fullyReadBody(object[kState].body, successSteps, errorSteps)\n\n // 7. Return promise.\n return promise.promise\n}\n\n// https://fetch.spec.whatwg.org/#body-unusable\nfunction bodyUnusable (body) {\n // An object including the Body interface mixin is\n // said to be unusable if its body is non-null and\n // its body’s stream is disturbed or locked.\n return body != null && (body.stream.locked || util.isDisturbed(body.stream))\n}\n\n/**\n * @see https://encoding.spec.whatwg.org/#utf-8-decode\n * @param {Buffer} buffer\n */\nfunction utf8DecodeBytes (buffer) {\n if (buffer.length === 0) {\n return ''\n }\n\n // 1. Let buffer be the result of peeking three bytes from\n // ioQueue, converted to a byte sequence.\n\n // 2. If buffer is 0xEF 0xBB 0xBF, then read three\n // bytes from ioQueue. (Do nothing with those bytes.)\n if (buffer[0] === 0xEF && buffer[1] === 0xBB && buffer[2] === 0xBF) {\n buffer = buffer.subarray(3)\n }\n\n // 3. Process a queue with an instance of UTF-8’s\n // decoder, ioQueue, output, and \"replacement\".\n const output = textDecoder.decode(buffer)\n\n // 4. Return output.\n return output\n}\n\n/**\n * @see https://infra.spec.whatwg.org/#parse-json-bytes-to-a-javascript-value\n * @param {Uint8Array} bytes\n */\nfunction parseJSONFromBytes (bytes) {\n return JSON.parse(utf8DecodeBytes(bytes))\n}\n\n/**\n * @see https://fetch.spec.whatwg.org/#concept-body-mime-type\n * @param {import('./response').Response|import('./request').Request} object\n */\nfunction bodyMimeType (object) {\n const { headersList } = object[kState]\n const contentType = headersList.get('content-type')\n\n if (contentType === null) {\n return 'failure'\n }\n\n return parseMIMEType(contentType)\n}\n\nmodule.exports = {\n extractBody,\n safelyExtractBody,\n cloneBody,\n mixinBody\n}\n","'use strict'\n\nconst { MessageChannel, receiveMessageOnPort } = require('worker_threads')\n\nconst corsSafeListedMethods = ['GET', 'HEAD', 'POST']\nconst corsSafeListedMethodsSet = new Set(corsSafeListedMethods)\n\nconst nullBodyStatus = [101, 204, 205, 304]\n\nconst redirectStatus = [301, 302, 303, 307, 308]\nconst redirectStatusSet = new Set(redirectStatus)\n\n// https://fetch.spec.whatwg.org/#block-bad-port\nconst badPorts = [\n '1', '7', '9', '11', '13', '15', '17', '19', '20', '21', '22', '23', '25', '37', '42', '43', '53', '69', '77', '79',\n '87', '95', '101', '102', '103', '104', '109', '110', '111', '113', '115', '117', '119', '123', '135', '137',\n '139', '143', '161', '179', '389', '427', '465', '512', '513', '514', '515', '526', '530', '531', '532',\n '540', '548', '554', '556', '563', '587', '601', '636', '989', '990', '993', '995', '1719', '1720', '1723',\n '2049', '3659', '4045', '5060', '5061', '6000', '6566', '6665', '6666', '6667', '6668', '6669', '6697',\n '10080'\n]\n\nconst badPortsSet = new Set(badPorts)\n\n// https://w3c.github.io/webappsec-referrer-policy/#referrer-policies\nconst referrerPolicy = [\n '',\n 'no-referrer',\n 'no-referrer-when-downgrade',\n 'same-origin',\n 'origin',\n 'strict-origin',\n 'origin-when-cross-origin',\n 'strict-origin-when-cross-origin',\n 'unsafe-url'\n]\nconst referrerPolicySet = new Set(referrerPolicy)\n\nconst requestRedirect = ['follow', 'manual', 'error']\n\nconst safeMethods = ['GET', 'HEAD', 'OPTIONS', 'TRACE']\nconst safeMethodsSet = new Set(safeMethods)\n\nconst requestMode = ['navigate', 'same-origin', 'no-cors', 'cors']\n\nconst requestCredentials = ['omit', 'same-origin', 'include']\n\nconst requestCache = [\n 'default',\n 'no-store',\n 'reload',\n 'no-cache',\n 'force-cache',\n 'only-if-cached'\n]\n\n// https://fetch.spec.whatwg.org/#request-body-header-name\nconst requestBodyHeader = [\n 'content-encoding',\n 'content-language',\n 'content-location',\n 'content-type',\n // See https://github.com/nodejs/undici/issues/2021\n // 'Content-Length' is a forbidden header name, which is typically\n // removed in the Headers implementation. However, undici doesn't\n // filter out headers, so we add it here.\n 'content-length'\n]\n\n// https://fetch.spec.whatwg.org/#enumdef-requestduplex\nconst requestDuplex = [\n 'half'\n]\n\n// http://fetch.spec.whatwg.org/#forbidden-method\nconst forbiddenMethods = ['CONNECT', 'TRACE', 'TRACK']\nconst forbiddenMethodsSet = new Set(forbiddenMethods)\n\nconst subresource = [\n 'audio',\n 'audioworklet',\n 'font',\n 'image',\n 'manifest',\n 'paintworklet',\n 'script',\n 'style',\n 'track',\n 'video',\n 'xslt',\n ''\n]\nconst subresourceSet = new Set(subresource)\n\n/** @type {globalThis['DOMException']} */\nconst DOMException = globalThis.DOMException ?? (() => {\n // DOMException was only made a global in Node v17.0.0,\n // but fetch supports >= v16.8.\n try {\n atob('~')\n } catch (err) {\n return Object.getPrototypeOf(err).constructor\n }\n})()\n\nlet channel\n\n/** @type {globalThis['structuredClone']} */\nconst structuredClone =\n globalThis.structuredClone ??\n // https://github.com/nodejs/node/blob/b27ae24dcc4251bad726d9d84baf678d1f707fed/lib/internal/structured_clone.js\n // structuredClone was added in v17.0.0, but fetch supports v16.8\n function structuredClone (value, options = undefined) {\n if (arguments.length === 0) {\n throw new TypeError('missing argument')\n }\n\n if (!channel) {\n channel = new MessageChannel()\n }\n channel.port1.unref()\n channel.port2.unref()\n channel.port1.postMessage(value, options?.transfer)\n return receiveMessageOnPort(channel.port2).message\n }\n\nmodule.exports = {\n DOMException,\n structuredClone,\n subresource,\n forbiddenMethods,\n requestBodyHeader,\n referrerPolicy,\n requestRedirect,\n requestMode,\n requestCredentials,\n requestCache,\n redirectStatus,\n corsSafeListedMethods,\n nullBodyStatus,\n safeMethods,\n badPorts,\n requestDuplex,\n subresourceSet,\n badPortsSet,\n redirectStatusSet,\n corsSafeListedMethodsSet,\n safeMethodsSet,\n forbiddenMethodsSet,\n referrerPolicySet\n}\n","const assert = require('assert')\nconst { atob } = require('buffer')\nconst { isomorphicDecode } = require('./util')\n\nconst encoder = new TextEncoder()\n\n/**\n * @see https://mimesniff.spec.whatwg.org/#http-token-code-point\n */\nconst HTTP_TOKEN_CODEPOINTS = /^[!#$%&'*+-.^_|~A-Za-z0-9]+$/\nconst HTTP_WHITESPACE_REGEX = /(\\u000A|\\u000D|\\u0009|\\u0020)/ // eslint-disable-line\n/**\n * @see https://mimesniff.spec.whatwg.org/#http-quoted-string-token-code-point\n */\nconst HTTP_QUOTED_STRING_TOKENS = /[\\u0009|\\u0020-\\u007E|\\u0080-\\u00FF]/ // eslint-disable-line\n\n// https://fetch.spec.whatwg.org/#data-url-processor\n/** @param {URL} dataURL */\nfunction dataURLProcessor (dataURL) {\n // 1. Assert: dataURL’s scheme is \"data\".\n assert(dataURL.protocol === 'data:')\n\n // 2. Let input be the result of running the URL\n // serializer on dataURL with exclude fragment\n // set to true.\n let input = URLSerializer(dataURL, true)\n\n // 3. Remove the leading \"data:\" string from input.\n input = input.slice(5)\n\n // 4. Let position point at the start of input.\n const position = { position: 0 }\n\n // 5. Let mimeType be the result of collecting a\n // sequence of code points that are not equal\n // to U+002C (,), given position.\n let mimeType = collectASequenceOfCodePointsFast(\n ',',\n input,\n position\n )\n\n // 6. Strip leading and trailing ASCII whitespace\n // from mimeType.\n // Undici implementation note: we need to store the\n // length because if the mimetype has spaces removed,\n // the wrong amount will be sliced from the input in\n // step #9\n const mimeTypeLength = mimeType.length\n mimeType = removeASCIIWhitespace(mimeType, true, true)\n\n // 7. If position is past the end of input, then\n // return failure\n if (position.position >= input.length) {\n return 'failure'\n }\n\n // 8. Advance position by 1.\n position.position++\n\n // 9. Let encodedBody be the remainder of input.\n const encodedBody = input.slice(mimeTypeLength + 1)\n\n // 10. Let body be the percent-decoding of encodedBody.\n let body = stringPercentDecode(encodedBody)\n\n // 11. If mimeType ends with U+003B (;), followed by\n // zero or more U+0020 SPACE, followed by an ASCII\n // case-insensitive match for \"base64\", then:\n if (/;(\\u0020){0,}base64$/i.test(mimeType)) {\n // 1. Let stringBody be the isomorphic decode of body.\n const stringBody = isomorphicDecode(body)\n\n // 2. Set body to the forgiving-base64 decode of\n // stringBody.\n body = forgivingBase64(stringBody)\n\n // 3. If body is failure, then return failure.\n if (body === 'failure') {\n return 'failure'\n }\n\n // 4. Remove the last 6 code points from mimeType.\n mimeType = mimeType.slice(0, -6)\n\n // 5. Remove trailing U+0020 SPACE code points from mimeType,\n // if any.\n mimeType = mimeType.replace(/(\\u0020)+$/, '')\n\n // 6. Remove the last U+003B (;) code point from mimeType.\n mimeType = mimeType.slice(0, -1)\n }\n\n // 12. If mimeType starts with U+003B (;), then prepend\n // \"text/plain\" to mimeType.\n if (mimeType.startsWith(';')) {\n mimeType = 'text/plain' + mimeType\n }\n\n // 13. Let mimeTypeRecord be the result of parsing\n // mimeType.\n let mimeTypeRecord = parseMIMEType(mimeType)\n\n // 14. If mimeTypeRecord is failure, then set\n // mimeTypeRecord to text/plain;charset=US-ASCII.\n if (mimeTypeRecord === 'failure') {\n mimeTypeRecord = parseMIMEType('text/plain;charset=US-ASCII')\n }\n\n // 15. Return a new data: URL struct whose MIME\n // type is mimeTypeRecord and body is body.\n // https://fetch.spec.whatwg.org/#data-url-struct\n return { mimeType: mimeTypeRecord, body }\n}\n\n// https://url.spec.whatwg.org/#concept-url-serializer\n/**\n * @param {URL} url\n * @param {boolean} excludeFragment\n */\nfunction URLSerializer (url, excludeFragment = false) {\n if (!excludeFragment) {\n return url.href\n }\n\n const href = url.href\n const hashLength = url.hash.length\n\n return hashLength === 0 ? href : href.substring(0, href.length - hashLength)\n}\n\n// https://infra.spec.whatwg.org/#collect-a-sequence-of-code-points\n/**\n * @param {(char: string) => boolean} condition\n * @param {string} input\n * @param {{ position: number }} position\n */\nfunction collectASequenceOfCodePoints (condition, input, position) {\n // 1. Let result be the empty string.\n let result = ''\n\n // 2. While position doesn’t point past the end of input and the\n // code point at position within input meets the condition condition:\n while (position.position < input.length && condition(input[position.position])) {\n // 1. Append that code point to the end of result.\n result += input[position.position]\n\n // 2. Advance position by 1.\n position.position++\n }\n\n // 3. Return result.\n return result\n}\n\n/**\n * A faster collectASequenceOfCodePoints that only works when comparing a single character.\n * @param {string} char\n * @param {string} input\n * @param {{ position: number }} position\n */\nfunction collectASequenceOfCodePointsFast (char, input, position) {\n const idx = input.indexOf(char, position.position)\n const start = position.position\n\n if (idx === -1) {\n position.position = input.length\n return input.slice(start)\n }\n\n position.position = idx\n return input.slice(start, position.position)\n}\n\n// https://url.spec.whatwg.org/#string-percent-decode\n/** @param {string} input */\nfunction stringPercentDecode (input) {\n // 1. Let bytes be the UTF-8 encoding of input.\n const bytes = encoder.encode(input)\n\n // 2. Return the percent-decoding of bytes.\n return percentDecode(bytes)\n}\n\n// https://url.spec.whatwg.org/#percent-decode\n/** @param {Uint8Array} input */\nfunction percentDecode (input) {\n // 1. Let output be an empty byte sequence.\n /** @type {number[]} */\n const output = []\n\n // 2. For each byte byte in input:\n for (let i = 0; i < input.length; i++) {\n const byte = input[i]\n\n // 1. If byte is not 0x25 (%), then append byte to output.\n if (byte !== 0x25) {\n output.push(byte)\n\n // 2. Otherwise, if byte is 0x25 (%) and the next two bytes\n // after byte in input are not in the ranges\n // 0x30 (0) to 0x39 (9), 0x41 (A) to 0x46 (F),\n // and 0x61 (a) to 0x66 (f), all inclusive, append byte\n // to output.\n } else if (\n byte === 0x25 &&\n !/^[0-9A-Fa-f]{2}$/i.test(String.fromCharCode(input[i + 1], input[i + 2]))\n ) {\n output.push(0x25)\n\n // 3. Otherwise:\n } else {\n // 1. Let bytePoint be the two bytes after byte in input,\n // decoded, and then interpreted as hexadecimal number.\n const nextTwoBytes = String.fromCharCode(input[i + 1], input[i + 2])\n const bytePoint = Number.parseInt(nextTwoBytes, 16)\n\n // 2. Append a byte whose value is bytePoint to output.\n output.push(bytePoint)\n\n // 3. Skip the next two bytes in input.\n i += 2\n }\n }\n\n // 3. Return output.\n return Uint8Array.from(output)\n}\n\n// https://mimesniff.spec.whatwg.org/#parse-a-mime-type\n/** @param {string} input */\nfunction parseMIMEType (input) {\n // 1. Remove any leading and trailing HTTP whitespace\n // from input.\n input = removeHTTPWhitespace(input, true, true)\n\n // 2. Let position be a position variable for input,\n // initially pointing at the start of input.\n const position = { position: 0 }\n\n // 3. Let type be the result of collecting a sequence\n // of code points that are not U+002F (/) from\n // input, given position.\n const type = collectASequenceOfCodePointsFast(\n '/',\n input,\n position\n )\n\n // 4. If type is the empty string or does not solely\n // contain HTTP token code points, then return failure.\n // https://mimesniff.spec.whatwg.org/#http-token-code-point\n if (type.length === 0 || !HTTP_TOKEN_CODEPOINTS.test(type)) {\n return 'failure'\n }\n\n // 5. If position is past the end of input, then return\n // failure\n if (position.position > input.length) {\n return 'failure'\n }\n\n // 6. Advance position by 1. (This skips past U+002F (/).)\n position.position++\n\n // 7. Let subtype be the result of collecting a sequence of\n // code points that are not U+003B (;) from input, given\n // position.\n let subtype = collectASequenceOfCodePointsFast(\n ';',\n input,\n position\n )\n\n // 8. Remove any trailing HTTP whitespace from subtype.\n subtype = removeHTTPWhitespace(subtype, false, true)\n\n // 9. If subtype is the empty string or does not solely\n // contain HTTP token code points, then return failure.\n if (subtype.length === 0 || !HTTP_TOKEN_CODEPOINTS.test(subtype)) {\n return 'failure'\n }\n\n const typeLowercase = type.toLowerCase()\n const subtypeLowercase = subtype.toLowerCase()\n\n // 10. Let mimeType be a new MIME type record whose type\n // is type, in ASCII lowercase, and subtype is subtype,\n // in ASCII lowercase.\n // https://mimesniff.spec.whatwg.org/#mime-type\n const mimeType = {\n type: typeLowercase,\n subtype: subtypeLowercase,\n /** @type {Map} */\n parameters: new Map(),\n // https://mimesniff.spec.whatwg.org/#mime-type-essence\n essence: `${typeLowercase}/${subtypeLowercase}`\n }\n\n // 11. While position is not past the end of input:\n while (position.position < input.length) {\n // 1. Advance position by 1. (This skips past U+003B (;).)\n position.position++\n\n // 2. Collect a sequence of code points that are HTTP\n // whitespace from input given position.\n collectASequenceOfCodePoints(\n // https://fetch.spec.whatwg.org/#http-whitespace\n char => HTTP_WHITESPACE_REGEX.test(char),\n input,\n position\n )\n\n // 3. Let parameterName be the result of collecting a\n // sequence of code points that are not U+003B (;)\n // or U+003D (=) from input, given position.\n let parameterName = collectASequenceOfCodePoints(\n (char) => char !== ';' && char !== '=',\n input,\n position\n )\n\n // 4. Set parameterName to parameterName, in ASCII\n // lowercase.\n parameterName = parameterName.toLowerCase()\n\n // 5. If position is not past the end of input, then:\n if (position.position < input.length) {\n // 1. If the code point at position within input is\n // U+003B (;), then continue.\n if (input[position.position] === ';') {\n continue\n }\n\n // 2. Advance position by 1. (This skips past U+003D (=).)\n position.position++\n }\n\n // 6. If position is past the end of input, then break.\n if (position.position > input.length) {\n break\n }\n\n // 7. Let parameterValue be null.\n let parameterValue = null\n\n // 8. If the code point at position within input is\n // U+0022 (\"), then:\n if (input[position.position] === '\"') {\n // 1. Set parameterValue to the result of collecting\n // an HTTP quoted string from input, given position\n // and the extract-value flag.\n parameterValue = collectAnHTTPQuotedString(input, position, true)\n\n // 2. Collect a sequence of code points that are not\n // U+003B (;) from input, given position.\n collectASequenceOfCodePointsFast(\n ';',\n input,\n position\n )\n\n // 9. Otherwise:\n } else {\n // 1. Set parameterValue to the result of collecting\n // a sequence of code points that are not U+003B (;)\n // from input, given position.\n parameterValue = collectASequenceOfCodePointsFast(\n ';',\n input,\n position\n )\n\n // 2. Remove any trailing HTTP whitespace from parameterValue.\n parameterValue = removeHTTPWhitespace(parameterValue, false, true)\n\n // 3. If parameterValue is the empty string, then continue.\n if (parameterValue.length === 0) {\n continue\n }\n }\n\n // 10. If all of the following are true\n // - parameterName is not the empty string\n // - parameterName solely contains HTTP token code points\n // - parameterValue solely contains HTTP quoted-string token code points\n // - mimeType’s parameters[parameterName] does not exist\n // then set mimeType’s parameters[parameterName] to parameterValue.\n if (\n parameterName.length !== 0 &&\n HTTP_TOKEN_CODEPOINTS.test(parameterName) &&\n (parameterValue.length === 0 || HTTP_QUOTED_STRING_TOKENS.test(parameterValue)) &&\n !mimeType.parameters.has(parameterName)\n ) {\n mimeType.parameters.set(parameterName, parameterValue)\n }\n }\n\n // 12. Return mimeType.\n return mimeType\n}\n\n// https://infra.spec.whatwg.org/#forgiving-base64-decode\n/** @param {string} data */\nfunction forgivingBase64 (data) {\n // 1. Remove all ASCII whitespace from data.\n data = data.replace(/[\\u0009\\u000A\\u000C\\u000D\\u0020]/g, '') // eslint-disable-line\n\n // 2. If data’s code point length divides by 4 leaving\n // no remainder, then:\n if (data.length % 4 === 0) {\n // 1. If data ends with one or two U+003D (=) code points,\n // then remove them from data.\n data = data.replace(/=?=$/, '')\n }\n\n // 3. If data’s code point length divides by 4 leaving\n // a remainder of 1, then return failure.\n if (data.length % 4 === 1) {\n return 'failure'\n }\n\n // 4. If data contains a code point that is not one of\n // U+002B (+)\n // U+002F (/)\n // ASCII alphanumeric\n // then return failure.\n if (/[^+/0-9A-Za-z]/.test(data)) {\n return 'failure'\n }\n\n const binary = atob(data)\n const bytes = new Uint8Array(binary.length)\n\n for (let byte = 0; byte < binary.length; byte++) {\n bytes[byte] = binary.charCodeAt(byte)\n }\n\n return bytes\n}\n\n// https://fetch.spec.whatwg.org/#collect-an-http-quoted-string\n// tests: https://fetch.spec.whatwg.org/#example-http-quoted-string\n/**\n * @param {string} input\n * @param {{ position: number }} position\n * @param {boolean?} extractValue\n */\nfunction collectAnHTTPQuotedString (input, position, extractValue) {\n // 1. Let positionStart be position.\n const positionStart = position.position\n\n // 2. Let value be the empty string.\n let value = ''\n\n // 3. Assert: the code point at position within input\n // is U+0022 (\").\n assert(input[position.position] === '\"')\n\n // 4. Advance position by 1.\n position.position++\n\n // 5. While true:\n while (true) {\n // 1. Append the result of collecting a sequence of code points\n // that are not U+0022 (\") or U+005C (\\) from input, given\n // position, to value.\n value += collectASequenceOfCodePoints(\n (char) => char !== '\"' && char !== '\\\\',\n input,\n position\n )\n\n // 2. If position is past the end of input, then break.\n if (position.position >= input.length) {\n break\n }\n\n // 3. Let quoteOrBackslash be the code point at position within\n // input.\n const quoteOrBackslash = input[position.position]\n\n // 4. Advance position by 1.\n position.position++\n\n // 5. If quoteOrBackslash is U+005C (\\), then:\n if (quoteOrBackslash === '\\\\') {\n // 1. If position is past the end of input, then append\n // U+005C (\\) to value and break.\n if (position.position >= input.length) {\n value += '\\\\'\n break\n }\n\n // 2. Append the code point at position within input to value.\n value += input[position.position]\n\n // 3. Advance position by 1.\n position.position++\n\n // 6. Otherwise:\n } else {\n // 1. Assert: quoteOrBackslash is U+0022 (\").\n assert(quoteOrBackslash === '\"')\n\n // 2. Break.\n break\n }\n }\n\n // 6. If the extract-value flag is set, then return value.\n if (extractValue) {\n return value\n }\n\n // 7. Return the code points from positionStart to position,\n // inclusive, within input.\n return input.slice(positionStart, position.position)\n}\n\n/**\n * @see https://mimesniff.spec.whatwg.org/#serialize-a-mime-type\n */\nfunction serializeAMimeType (mimeType) {\n assert(mimeType !== 'failure')\n const { parameters, essence } = mimeType\n\n // 1. Let serialization be the concatenation of mimeType’s\n // type, U+002F (/), and mimeType’s subtype.\n let serialization = essence\n\n // 2. For each name → value of mimeType’s parameters:\n for (let [name, value] of parameters.entries()) {\n // 1. Append U+003B (;) to serialization.\n serialization += ';'\n\n // 2. Append name to serialization.\n serialization += name\n\n // 3. Append U+003D (=) to serialization.\n serialization += '='\n\n // 4. If value does not solely contain HTTP token code\n // points or value is the empty string, then:\n if (!HTTP_TOKEN_CODEPOINTS.test(value)) {\n // 1. Precede each occurence of U+0022 (\") or\n // U+005C (\\) in value with U+005C (\\).\n value = value.replace(/(\\\\|\")/g, '\\\\$1')\n\n // 2. Prepend U+0022 (\") to value.\n value = '\"' + value\n\n // 3. Append U+0022 (\") to value.\n value += '\"'\n }\n\n // 5. Append value to serialization.\n serialization += value\n }\n\n // 3. Return serialization.\n return serialization\n}\n\n/**\n * @see https://fetch.spec.whatwg.org/#http-whitespace\n * @param {string} char\n */\nfunction isHTTPWhiteSpace (char) {\n return char === '\\r' || char === '\\n' || char === '\\t' || char === ' '\n}\n\n/**\n * @see https://fetch.spec.whatwg.org/#http-whitespace\n * @param {string} str\n */\nfunction removeHTTPWhitespace (str, leading = true, trailing = true) {\n let lead = 0\n let trail = str.length - 1\n\n if (leading) {\n for (; lead < str.length && isHTTPWhiteSpace(str[lead]); lead++);\n }\n\n if (trailing) {\n for (; trail > 0 && isHTTPWhiteSpace(str[trail]); trail--);\n }\n\n return str.slice(lead, trail + 1)\n}\n\n/**\n * @see https://infra.spec.whatwg.org/#ascii-whitespace\n * @param {string} char\n */\nfunction isASCIIWhitespace (char) {\n return char === '\\r' || char === '\\n' || char === '\\t' || char === '\\f' || char === ' '\n}\n\n/**\n * @see https://infra.spec.whatwg.org/#strip-leading-and-trailing-ascii-whitespace\n */\nfunction removeASCIIWhitespace (str, leading = true, trailing = true) {\n let lead = 0\n let trail = str.length - 1\n\n if (leading) {\n for (; lead < str.length && isASCIIWhitespace(str[lead]); lead++);\n }\n\n if (trailing) {\n for (; trail > 0 && isASCIIWhitespace(str[trail]); trail--);\n }\n\n return str.slice(lead, trail + 1)\n}\n\nmodule.exports = {\n dataURLProcessor,\n URLSerializer,\n collectASequenceOfCodePoints,\n collectASequenceOfCodePointsFast,\n stringPercentDecode,\n parseMIMEType,\n collectAnHTTPQuotedString,\n serializeAMimeType\n}\n","'use strict'\n\nconst { Blob, File: NativeFile } = require('buffer')\nconst { types } = require('util')\nconst { kState } = require('./symbols')\nconst { isBlobLike } = require('./util')\nconst { webidl } = require('./webidl')\nconst { parseMIMEType, serializeAMimeType } = require('./dataURL')\nconst { kEnumerableProperty } = require('../core/util')\nconst encoder = new TextEncoder()\n\nclass File extends Blob {\n constructor (fileBits, fileName, options = {}) {\n // The File constructor is invoked with two or three parameters, depending\n // on whether the optional dictionary parameter is used. When the File()\n // constructor is invoked, user agents must run the following steps:\n webidl.argumentLengthCheck(arguments, 2, { header: 'File constructor' })\n\n fileBits = webidl.converters['sequence'](fileBits)\n fileName = webidl.converters.USVString(fileName)\n options = webidl.converters.FilePropertyBag(options)\n\n // 1. Let bytes be the result of processing blob parts given fileBits and\n // options.\n // Note: Blob handles this for us\n\n // 2. Let n be the fileName argument to the constructor.\n const n = fileName\n\n // 3. Process FilePropertyBag dictionary argument by running the following\n // substeps:\n\n // 1. If the type member is provided and is not the empty string, let t\n // be set to the type dictionary member. If t contains any characters\n // outside the range U+0020 to U+007E, then set t to the empty string\n // and return from these substeps.\n // 2. Convert every character in t to ASCII lowercase.\n let t = options.type\n let d\n\n // eslint-disable-next-line no-labels\n substep: {\n if (t) {\n t = parseMIMEType(t)\n\n if (t === 'failure') {\n t = ''\n // eslint-disable-next-line no-labels\n break substep\n }\n\n t = serializeAMimeType(t).toLowerCase()\n }\n\n // 3. If the lastModified member is provided, let d be set to the\n // lastModified dictionary member. If it is not provided, set d to the\n // current date and time represented as the number of milliseconds since\n // the Unix Epoch (which is the equivalent of Date.now() [ECMA-262]).\n d = options.lastModified\n }\n\n // 4. Return a new File object F such that:\n // F refers to the bytes byte sequence.\n // F.size is set to the number of total bytes in bytes.\n // F.name is set to n.\n // F.type is set to t.\n // F.lastModified is set to d.\n\n super(processBlobParts(fileBits, options), { type: t })\n this[kState] = {\n name: n,\n lastModified: d,\n type: t\n }\n }\n\n get name () {\n webidl.brandCheck(this, File)\n\n return this[kState].name\n }\n\n get lastModified () {\n webidl.brandCheck(this, File)\n\n return this[kState].lastModified\n }\n\n get type () {\n webidl.brandCheck(this, File)\n\n return this[kState].type\n }\n}\n\nclass FileLike {\n constructor (blobLike, fileName, options = {}) {\n // TODO: argument idl type check\n\n // The File constructor is invoked with two or three parameters, depending\n // on whether the optional dictionary parameter is used. When the File()\n // constructor is invoked, user agents must run the following steps:\n\n // 1. Let bytes be the result of processing blob parts given fileBits and\n // options.\n\n // 2. Let n be the fileName argument to the constructor.\n const n = fileName\n\n // 3. Process FilePropertyBag dictionary argument by running the following\n // substeps:\n\n // 1. If the type member is provided and is not the empty string, let t\n // be set to the type dictionary member. If t contains any characters\n // outside the range U+0020 to U+007E, then set t to the empty string\n // and return from these substeps.\n // TODO\n const t = options.type\n\n // 2. Convert every character in t to ASCII lowercase.\n // TODO\n\n // 3. If the lastModified member is provided, let d be set to the\n // lastModified dictionary member. If it is not provided, set d to the\n // current date and time represented as the number of milliseconds since\n // the Unix Epoch (which is the equivalent of Date.now() [ECMA-262]).\n const d = options.lastModified ?? Date.now()\n\n // 4. Return a new File object F such that:\n // F refers to the bytes byte sequence.\n // F.size is set to the number of total bytes in bytes.\n // F.name is set to n.\n // F.type is set to t.\n // F.lastModified is set to d.\n\n this[kState] = {\n blobLike,\n name: n,\n type: t,\n lastModified: d\n }\n }\n\n stream (...args) {\n webidl.brandCheck(this, FileLike)\n\n return this[kState].blobLike.stream(...args)\n }\n\n arrayBuffer (...args) {\n webidl.brandCheck(this, FileLike)\n\n return this[kState].blobLike.arrayBuffer(...args)\n }\n\n slice (...args) {\n webidl.brandCheck(this, FileLike)\n\n return this[kState].blobLike.slice(...args)\n }\n\n text (...args) {\n webidl.brandCheck(this, FileLike)\n\n return this[kState].blobLike.text(...args)\n }\n\n get size () {\n webidl.brandCheck(this, FileLike)\n\n return this[kState].blobLike.size\n }\n\n get type () {\n webidl.brandCheck(this, FileLike)\n\n return this[kState].blobLike.type\n }\n\n get name () {\n webidl.brandCheck(this, FileLike)\n\n return this[kState].name\n }\n\n get lastModified () {\n webidl.brandCheck(this, FileLike)\n\n return this[kState].lastModified\n }\n\n get [Symbol.toStringTag] () {\n return 'File'\n }\n}\n\nObject.defineProperties(File.prototype, {\n [Symbol.toStringTag]: {\n value: 'File',\n configurable: true\n },\n name: kEnumerableProperty,\n lastModified: kEnumerableProperty\n})\n\nwebidl.converters.Blob = webidl.interfaceConverter(Blob)\n\nwebidl.converters.BlobPart = function (V, opts) {\n if (webidl.util.Type(V) === 'Object') {\n if (isBlobLike(V)) {\n return webidl.converters.Blob(V, { strict: false })\n }\n\n if (\n ArrayBuffer.isView(V) ||\n types.isAnyArrayBuffer(V)\n ) {\n return webidl.converters.BufferSource(V, opts)\n }\n }\n\n return webidl.converters.USVString(V, opts)\n}\n\nwebidl.converters['sequence'] = webidl.sequenceConverter(\n webidl.converters.BlobPart\n)\n\n// https://www.w3.org/TR/FileAPI/#dfn-FilePropertyBag\nwebidl.converters.FilePropertyBag = webidl.dictionaryConverter([\n {\n key: 'lastModified',\n converter: webidl.converters['long long'],\n get defaultValue () {\n return Date.now()\n }\n },\n {\n key: 'type',\n converter: webidl.converters.DOMString,\n defaultValue: ''\n },\n {\n key: 'endings',\n converter: (value) => {\n value = webidl.converters.DOMString(value)\n value = value.toLowerCase()\n\n if (value !== 'native') {\n value = 'transparent'\n }\n\n return value\n },\n defaultValue: 'transparent'\n }\n])\n\n/**\n * @see https://www.w3.org/TR/FileAPI/#process-blob-parts\n * @param {(NodeJS.TypedArray|Blob|string)[]} parts\n * @param {{ type: string, endings: string }} options\n */\nfunction processBlobParts (parts, options) {\n // 1. Let bytes be an empty sequence of bytes.\n /** @type {NodeJS.TypedArray[]} */\n const bytes = []\n\n // 2. For each element in parts:\n for (const element of parts) {\n // 1. If element is a USVString, run the following substeps:\n if (typeof element === 'string') {\n // 1. Let s be element.\n let s = element\n\n // 2. If the endings member of options is \"native\", set s\n // to the result of converting line endings to native\n // of element.\n if (options.endings === 'native') {\n s = convertLineEndingsNative(s)\n }\n\n // 3. Append the result of UTF-8 encoding s to bytes.\n bytes.push(encoder.encode(s))\n } else if (\n types.isAnyArrayBuffer(element) ||\n types.isTypedArray(element)\n ) {\n // 2. If element is a BufferSource, get a copy of the\n // bytes held by the buffer source, and append those\n // bytes to bytes.\n if (!element.buffer) { // ArrayBuffer\n bytes.push(new Uint8Array(element))\n } else {\n bytes.push(\n new Uint8Array(element.buffer, element.byteOffset, element.byteLength)\n )\n }\n } else if (isBlobLike(element)) {\n // 3. If element is a Blob, append the bytes it represents\n // to bytes.\n bytes.push(element)\n }\n }\n\n // 3. Return bytes.\n return bytes\n}\n\n/**\n * @see https://www.w3.org/TR/FileAPI/#convert-line-endings-to-native\n * @param {string} s\n */\nfunction convertLineEndingsNative (s) {\n // 1. Let native line ending be be the code point U+000A LF.\n let nativeLineEnding = '\\n'\n\n // 2. If the underlying platform’s conventions are to\n // represent newlines as a carriage return and line feed\n // sequence, set native line ending to the code point\n // U+000D CR followed by the code point U+000A LF.\n if (process.platform === 'win32') {\n nativeLineEnding = '\\r\\n'\n }\n\n return s.replace(/\\r?\\n/g, nativeLineEnding)\n}\n\n// If this function is moved to ./util.js, some tools (such as\n// rollup) will warn about circular dependencies. See:\n// https://github.com/nodejs/undici/issues/1629\nfunction isFileLike (object) {\n return (\n (NativeFile && object instanceof NativeFile) ||\n object instanceof File || (\n object &&\n (typeof object.stream === 'function' ||\n typeof object.arrayBuffer === 'function') &&\n object[Symbol.toStringTag] === 'File'\n )\n )\n}\n\nmodule.exports = { File, FileLike, isFileLike }\n","'use strict'\n\nconst { isBlobLike, toUSVString, makeIterator } = require('./util')\nconst { kState } = require('./symbols')\nconst { File: UndiciFile, FileLike, isFileLike } = require('./file')\nconst { webidl } = require('./webidl')\nconst { Blob, File: NativeFile } = require('buffer')\n\n/** @type {globalThis['File']} */\nconst File = NativeFile ?? UndiciFile\n\n// https://xhr.spec.whatwg.org/#formdata\nclass FormData {\n constructor (form) {\n if (form !== undefined) {\n throw webidl.errors.conversionFailed({\n prefix: 'FormData constructor',\n argument: 'Argument 1',\n types: ['undefined']\n })\n }\n\n this[kState] = []\n }\n\n append (name, value, filename = undefined) {\n webidl.brandCheck(this, FormData)\n\n webidl.argumentLengthCheck(arguments, 2, { header: 'FormData.append' })\n\n if (arguments.length === 3 && !isBlobLike(value)) {\n throw new TypeError(\n \"Failed to execute 'append' on 'FormData': parameter 2 is not of type 'Blob'\"\n )\n }\n\n // 1. Let value be value if given; otherwise blobValue.\n\n name = webidl.converters.USVString(name)\n value = isBlobLike(value)\n ? webidl.converters.Blob(value, { strict: false })\n : webidl.converters.USVString(value)\n filename = arguments.length === 3\n ? webidl.converters.USVString(filename)\n : undefined\n\n // 2. Let entry be the result of creating an entry with\n // name, value, and filename if given.\n const entry = makeEntry(name, value, filename)\n\n // 3. Append entry to this’s entry list.\n this[kState].push(entry)\n }\n\n delete (name) {\n webidl.brandCheck(this, FormData)\n\n webidl.argumentLengthCheck(arguments, 1, { header: 'FormData.delete' })\n\n name = webidl.converters.USVString(name)\n\n // The delete(name) method steps are to remove all entries whose name\n // is name from this’s entry list.\n this[kState] = this[kState].filter(entry => entry.name !== name)\n }\n\n get (name) {\n webidl.brandCheck(this, FormData)\n\n webidl.argumentLengthCheck(arguments, 1, { header: 'FormData.get' })\n\n name = webidl.converters.USVString(name)\n\n // 1. If there is no entry whose name is name in this’s entry list,\n // then return null.\n const idx = this[kState].findIndex((entry) => entry.name === name)\n if (idx === -1) {\n return null\n }\n\n // 2. Return the value of the first entry whose name is name from\n // this’s entry list.\n return this[kState][idx].value\n }\n\n getAll (name) {\n webidl.brandCheck(this, FormData)\n\n webidl.argumentLengthCheck(arguments, 1, { header: 'FormData.getAll' })\n\n name = webidl.converters.USVString(name)\n\n // 1. If there is no entry whose name is name in this’s entry list,\n // then return the empty list.\n // 2. Return the values of all entries whose name is name, in order,\n // from this’s entry list.\n return this[kState]\n .filter((entry) => entry.name === name)\n .map((entry) => entry.value)\n }\n\n has (name) {\n webidl.brandCheck(this, FormData)\n\n webidl.argumentLengthCheck(arguments, 1, { header: 'FormData.has' })\n\n name = webidl.converters.USVString(name)\n\n // The has(name) method steps are to return true if there is an entry\n // whose name is name in this’s entry list; otherwise false.\n return this[kState].findIndex((entry) => entry.name === name) !== -1\n }\n\n set (name, value, filename = undefined) {\n webidl.brandCheck(this, FormData)\n\n webidl.argumentLengthCheck(arguments, 2, { header: 'FormData.set' })\n\n if (arguments.length === 3 && !isBlobLike(value)) {\n throw new TypeError(\n \"Failed to execute 'set' on 'FormData': parameter 2 is not of type 'Blob'\"\n )\n }\n\n // The set(name, value) and set(name, blobValue, filename) method steps\n // are:\n\n // 1. Let value be value if given; otherwise blobValue.\n\n name = webidl.converters.USVString(name)\n value = isBlobLike(value)\n ? webidl.converters.Blob(value, { strict: false })\n : webidl.converters.USVString(value)\n filename = arguments.length === 3\n ? toUSVString(filename)\n : undefined\n\n // 2. Let entry be the result of creating an entry with name, value, and\n // filename if given.\n const entry = makeEntry(name, value, filename)\n\n // 3. If there are entries in this’s entry list whose name is name, then\n // replace the first such entry with entry and remove the others.\n const idx = this[kState].findIndex((entry) => entry.name === name)\n if (idx !== -1) {\n this[kState] = [\n ...this[kState].slice(0, idx),\n entry,\n ...this[kState].slice(idx + 1).filter((entry) => entry.name !== name)\n ]\n } else {\n // 4. Otherwise, append entry to this’s entry list.\n this[kState].push(entry)\n }\n }\n\n entries () {\n webidl.brandCheck(this, FormData)\n\n return makeIterator(\n () => this[kState].map(pair => [pair.name, pair.value]),\n 'FormData',\n 'key+value'\n )\n }\n\n keys () {\n webidl.brandCheck(this, FormData)\n\n return makeIterator(\n () => this[kState].map(pair => [pair.name, pair.value]),\n 'FormData',\n 'key'\n )\n }\n\n values () {\n webidl.brandCheck(this, FormData)\n\n return makeIterator(\n () => this[kState].map(pair => [pair.name, pair.value]),\n 'FormData',\n 'value'\n )\n }\n\n /**\n * @param {(value: string, key: string, self: FormData) => void} callbackFn\n * @param {unknown} thisArg\n */\n forEach (callbackFn, thisArg = globalThis) {\n webidl.brandCheck(this, FormData)\n\n webidl.argumentLengthCheck(arguments, 1, { header: 'FormData.forEach' })\n\n if (typeof callbackFn !== 'function') {\n throw new TypeError(\n \"Failed to execute 'forEach' on 'FormData': parameter 1 is not of type 'Function'.\"\n )\n }\n\n for (const [key, value] of this) {\n callbackFn.apply(thisArg, [value, key, this])\n }\n }\n}\n\nFormData.prototype[Symbol.iterator] = FormData.prototype.entries\n\nObject.defineProperties(FormData.prototype, {\n [Symbol.toStringTag]: {\n value: 'FormData',\n configurable: true\n }\n})\n\n/**\n * @see https://html.spec.whatwg.org/multipage/form-control-infrastructure.html#create-an-entry\n * @param {string} name\n * @param {string|Blob} value\n * @param {?string} filename\n * @returns\n */\nfunction makeEntry (name, value, filename) {\n // 1. Set name to the result of converting name into a scalar value string.\n // \"To convert a string into a scalar value string, replace any surrogates\n // with U+FFFD.\"\n // see: https://nodejs.org/dist/latest-v18.x/docs/api/buffer.html#buftostringencoding-start-end\n name = Buffer.from(name).toString('utf8')\n\n // 2. If value is a string, then set value to the result of converting\n // value into a scalar value string.\n if (typeof value === 'string') {\n value = Buffer.from(value).toString('utf8')\n } else {\n // 3. Otherwise:\n\n // 1. If value is not a File object, then set value to a new File object,\n // representing the same bytes, whose name attribute value is \"blob\"\n if (!isFileLike(value)) {\n value = value instanceof Blob\n ? new File([value], 'blob', { type: value.type })\n : new FileLike(value, 'blob', { type: value.type })\n }\n\n // 2. If filename is given, then set value to a new File object,\n // representing the same bytes, whose name attribute is filename.\n if (filename !== undefined) {\n /** @type {FilePropertyBag} */\n const options = {\n type: value.type,\n lastModified: value.lastModified\n }\n\n value = (NativeFile && value instanceof NativeFile) || value instanceof UndiciFile\n ? new File([value], filename, options)\n : new FileLike(value, filename, options)\n }\n }\n\n // 4. Return an entry whose name is name and whose value is value.\n return { name, value }\n}\n\nmodule.exports = { FormData }\n","'use strict'\n\n// In case of breaking changes, increase the version\n// number to avoid conflicts.\nconst globalOrigin = Symbol.for('undici.globalOrigin.1')\n\nfunction getGlobalOrigin () {\n return globalThis[globalOrigin]\n}\n\nfunction setGlobalOrigin (newOrigin) {\n if (newOrigin === undefined) {\n Object.defineProperty(globalThis, globalOrigin, {\n value: undefined,\n writable: true,\n enumerable: false,\n configurable: false\n })\n\n return\n }\n\n const parsedURL = new URL(newOrigin)\n\n if (parsedURL.protocol !== 'http:' && parsedURL.protocol !== 'https:') {\n throw new TypeError(`Only http & https urls are allowed, received ${parsedURL.protocol}`)\n }\n\n Object.defineProperty(globalThis, globalOrigin, {\n value: parsedURL,\n writable: true,\n enumerable: false,\n configurable: false\n })\n}\n\nmodule.exports = {\n getGlobalOrigin,\n setGlobalOrigin\n}\n","// https://github.com/Ethan-Arrowood/undici-fetch\n\n'use strict'\n\nconst { kHeadersList, kConstruct } = require('../core/symbols')\nconst { kGuard } = require('./symbols')\nconst { kEnumerableProperty } = require('../core/util')\nconst {\n makeIterator,\n isValidHeaderName,\n isValidHeaderValue\n} = require('./util')\nconst { webidl } = require('./webidl')\nconst assert = require('assert')\n\nconst kHeadersMap = Symbol('headers map')\nconst kHeadersSortedMap = Symbol('headers map sorted')\n\n/**\n * @param {number} code\n */\nfunction isHTTPWhiteSpaceCharCode (code) {\n return code === 0x00a || code === 0x00d || code === 0x009 || code === 0x020\n}\n\n/**\n * @see https://fetch.spec.whatwg.org/#concept-header-value-normalize\n * @param {string} potentialValue\n */\nfunction headerValueNormalize (potentialValue) {\n // To normalize a byte sequence potentialValue, remove\n // any leading and trailing HTTP whitespace bytes from\n // potentialValue.\n let i = 0; let j = potentialValue.length\n\n while (j > i && isHTTPWhiteSpaceCharCode(potentialValue.charCodeAt(j - 1))) --j\n while (j > i && isHTTPWhiteSpaceCharCode(potentialValue.charCodeAt(i))) ++i\n\n return i === 0 && j === potentialValue.length ? potentialValue : potentialValue.substring(i, j)\n}\n\nfunction fill (headers, object) {\n // To fill a Headers object headers with a given object object, run these steps:\n\n // 1. If object is a sequence, then for each header in object:\n // Note: webidl conversion to array has already been done.\n if (Array.isArray(object)) {\n for (let i = 0; i < object.length; ++i) {\n const header = object[i]\n // 1. If header does not contain exactly two items, then throw a TypeError.\n if (header.length !== 2) {\n throw webidl.errors.exception({\n header: 'Headers constructor',\n message: `expected name/value pair to be length 2, found ${header.length}.`\n })\n }\n\n // 2. Append (header’s first item, header’s second item) to headers.\n appendHeader(headers, header[0], header[1])\n }\n } else if (typeof object === 'object' && object !== null) {\n // Note: null should throw\n\n // 2. Otherwise, object is a record, then for each key → value in object,\n // append (key, value) to headers\n const keys = Object.keys(object)\n for (let i = 0; i < keys.length; ++i) {\n appendHeader(headers, keys[i], object[keys[i]])\n }\n } else {\n throw webidl.errors.conversionFailed({\n prefix: 'Headers constructor',\n argument: 'Argument 1',\n types: ['sequence>', 'record']\n })\n }\n}\n\n/**\n * @see https://fetch.spec.whatwg.org/#concept-headers-append\n */\nfunction appendHeader (headers, name, value) {\n // 1. Normalize value.\n value = headerValueNormalize(value)\n\n // 2. If name is not a header name or value is not a\n // header value, then throw a TypeError.\n if (!isValidHeaderName(name)) {\n throw webidl.errors.invalidArgument({\n prefix: 'Headers.append',\n value: name,\n type: 'header name'\n })\n } else if (!isValidHeaderValue(value)) {\n throw webidl.errors.invalidArgument({\n prefix: 'Headers.append',\n value,\n type: 'header value'\n })\n }\n\n // 3. If headers’s guard is \"immutable\", then throw a TypeError.\n // 4. Otherwise, if headers’s guard is \"request\" and name is a\n // forbidden header name, return.\n // Note: undici does not implement forbidden header names\n if (headers[kGuard] === 'immutable') {\n throw new TypeError('immutable')\n } else if (headers[kGuard] === 'request-no-cors') {\n // 5. Otherwise, if headers’s guard is \"request-no-cors\":\n // TODO\n }\n\n // 6. Otherwise, if headers’s guard is \"response\" and name is a\n // forbidden response-header name, return.\n\n // 7. Append (name, value) to headers’s header list.\n return headers[kHeadersList].append(name, value)\n\n // 8. If headers’s guard is \"request-no-cors\", then remove\n // privileged no-CORS request headers from headers\n}\n\nclass HeadersList {\n /** @type {[string, string][]|null} */\n cookies = null\n\n constructor (init) {\n if (init instanceof HeadersList) {\n this[kHeadersMap] = new Map(init[kHeadersMap])\n this[kHeadersSortedMap] = init[kHeadersSortedMap]\n this.cookies = init.cookies === null ? null : [...init.cookies]\n } else {\n this[kHeadersMap] = new Map(init)\n this[kHeadersSortedMap] = null\n }\n }\n\n // https://fetch.spec.whatwg.org/#header-list-contains\n contains (name) {\n // A header list list contains a header name name if list\n // contains a header whose name is a byte-case-insensitive\n // match for name.\n name = name.toLowerCase()\n\n return this[kHeadersMap].has(name)\n }\n\n clear () {\n this[kHeadersMap].clear()\n this[kHeadersSortedMap] = null\n this.cookies = null\n }\n\n // https://fetch.spec.whatwg.org/#concept-header-list-append\n append (name, value) {\n this[kHeadersSortedMap] = null\n\n // 1. If list contains name, then set name to the first such\n // header’s name.\n const lowercaseName = name.toLowerCase()\n const exists = this[kHeadersMap].get(lowercaseName)\n\n // 2. Append (name, value) to list.\n if (exists) {\n const delimiter = lowercaseName === 'cookie' ? '; ' : ', '\n this[kHeadersMap].set(lowercaseName, {\n name: exists.name,\n value: `${exists.value}${delimiter}${value}`\n })\n } else {\n this[kHeadersMap].set(lowercaseName, { name, value })\n }\n\n if (lowercaseName === 'set-cookie') {\n this.cookies ??= []\n this.cookies.push(value)\n }\n }\n\n // https://fetch.spec.whatwg.org/#concept-header-list-set\n set (name, value) {\n this[kHeadersSortedMap] = null\n const lowercaseName = name.toLowerCase()\n\n if (lowercaseName === 'set-cookie') {\n this.cookies = [value]\n }\n\n // 1. If list contains name, then set the value of\n // the first such header to value and remove the\n // others.\n // 2. Otherwise, append header (name, value) to list.\n this[kHeadersMap].set(lowercaseName, { name, value })\n }\n\n // https://fetch.spec.whatwg.org/#concept-header-list-delete\n delete (name) {\n this[kHeadersSortedMap] = null\n\n name = name.toLowerCase()\n\n if (name === 'set-cookie') {\n this.cookies = null\n }\n\n this[kHeadersMap].delete(name)\n }\n\n // https://fetch.spec.whatwg.org/#concept-header-list-get\n get (name) {\n const value = this[kHeadersMap].get(name.toLowerCase())\n\n // 1. If list does not contain name, then return null.\n // 2. Return the values of all headers in list whose name\n // is a byte-case-insensitive match for name,\n // separated from each other by 0x2C 0x20, in order.\n return value === undefined ? null : value.value\n }\n\n * [Symbol.iterator] () {\n // use the lowercased name\n for (const [name, { value }] of this[kHeadersMap]) {\n yield [name, value]\n }\n }\n\n get entries () {\n const headers = {}\n\n if (this[kHeadersMap].size) {\n for (const { name, value } of this[kHeadersMap].values()) {\n headers[name] = value\n }\n }\n\n return headers\n }\n}\n\n// https://fetch.spec.whatwg.org/#headers-class\nclass Headers {\n constructor (init = undefined) {\n if (init === kConstruct) {\n return\n }\n this[kHeadersList] = new HeadersList()\n\n // The new Headers(init) constructor steps are:\n\n // 1. Set this’s guard to \"none\".\n this[kGuard] = 'none'\n\n // 2. If init is given, then fill this with init.\n if (init !== undefined) {\n init = webidl.converters.HeadersInit(init)\n fill(this, init)\n }\n }\n\n // https://fetch.spec.whatwg.org/#dom-headers-append\n append (name, value) {\n webidl.brandCheck(this, Headers)\n\n webidl.argumentLengthCheck(arguments, 2, { header: 'Headers.append' })\n\n name = webidl.converters.ByteString(name)\n value = webidl.converters.ByteString(value)\n\n return appendHeader(this, name, value)\n }\n\n // https://fetch.spec.whatwg.org/#dom-headers-delete\n delete (name) {\n webidl.brandCheck(this, Headers)\n\n webidl.argumentLengthCheck(arguments, 1, { header: 'Headers.delete' })\n\n name = webidl.converters.ByteString(name)\n\n // 1. If name is not a header name, then throw a TypeError.\n if (!isValidHeaderName(name)) {\n throw webidl.errors.invalidArgument({\n prefix: 'Headers.delete',\n value: name,\n type: 'header name'\n })\n }\n\n // 2. If this’s guard is \"immutable\", then throw a TypeError.\n // 3. Otherwise, if this’s guard is \"request\" and name is a\n // forbidden header name, return.\n // 4. Otherwise, if this’s guard is \"request-no-cors\", name\n // is not a no-CORS-safelisted request-header name, and\n // name is not a privileged no-CORS request-header name,\n // return.\n // 5. Otherwise, if this’s guard is \"response\" and name is\n // a forbidden response-header name, return.\n // Note: undici does not implement forbidden header names\n if (this[kGuard] === 'immutable') {\n throw new TypeError('immutable')\n } else if (this[kGuard] === 'request-no-cors') {\n // TODO\n }\n\n // 6. If this’s header list does not contain name, then\n // return.\n if (!this[kHeadersList].contains(name)) {\n return\n }\n\n // 7. Delete name from this’s header list.\n // 8. If this’s guard is \"request-no-cors\", then remove\n // privileged no-CORS request headers from this.\n this[kHeadersList].delete(name)\n }\n\n // https://fetch.spec.whatwg.org/#dom-headers-get\n get (name) {\n webidl.brandCheck(this, Headers)\n\n webidl.argumentLengthCheck(arguments, 1, { header: 'Headers.get' })\n\n name = webidl.converters.ByteString(name)\n\n // 1. If name is not a header name, then throw a TypeError.\n if (!isValidHeaderName(name)) {\n throw webidl.errors.invalidArgument({\n prefix: 'Headers.get',\n value: name,\n type: 'header name'\n })\n }\n\n // 2. Return the result of getting name from this’s header\n // list.\n return this[kHeadersList].get(name)\n }\n\n // https://fetch.spec.whatwg.org/#dom-headers-has\n has (name) {\n webidl.brandCheck(this, Headers)\n\n webidl.argumentLengthCheck(arguments, 1, { header: 'Headers.has' })\n\n name = webidl.converters.ByteString(name)\n\n // 1. If name is not a header name, then throw a TypeError.\n if (!isValidHeaderName(name)) {\n throw webidl.errors.invalidArgument({\n prefix: 'Headers.has',\n value: name,\n type: 'header name'\n })\n }\n\n // 2. Return true if this’s header list contains name;\n // otherwise false.\n return this[kHeadersList].contains(name)\n }\n\n // https://fetch.spec.whatwg.org/#dom-headers-set\n set (name, value) {\n webidl.brandCheck(this, Headers)\n\n webidl.argumentLengthCheck(arguments, 2, { header: 'Headers.set' })\n\n name = webidl.converters.ByteString(name)\n value = webidl.converters.ByteString(value)\n\n // 1. Normalize value.\n value = headerValueNormalize(value)\n\n // 2. If name is not a header name or value is not a\n // header value, then throw a TypeError.\n if (!isValidHeaderName(name)) {\n throw webidl.errors.invalidArgument({\n prefix: 'Headers.set',\n value: name,\n type: 'header name'\n })\n } else if (!isValidHeaderValue(value)) {\n throw webidl.errors.invalidArgument({\n prefix: 'Headers.set',\n value,\n type: 'header value'\n })\n }\n\n // 3. If this’s guard is \"immutable\", then throw a TypeError.\n // 4. Otherwise, if this’s guard is \"request\" and name is a\n // forbidden header name, return.\n // 5. Otherwise, if this’s guard is \"request-no-cors\" and\n // name/value is not a no-CORS-safelisted request-header,\n // return.\n // 6. Otherwise, if this’s guard is \"response\" and name is a\n // forbidden response-header name, return.\n // Note: undici does not implement forbidden header names\n if (this[kGuard] === 'immutable') {\n throw new TypeError('immutable')\n } else if (this[kGuard] === 'request-no-cors') {\n // TODO\n }\n\n // 7. Set (name, value) in this’s header list.\n // 8. If this’s guard is \"request-no-cors\", then remove\n // privileged no-CORS request headers from this\n this[kHeadersList].set(name, value)\n }\n\n // https://fetch.spec.whatwg.org/#dom-headers-getsetcookie\n getSetCookie () {\n webidl.brandCheck(this, Headers)\n\n // 1. If this’s header list does not contain `Set-Cookie`, then return « ».\n // 2. Return the values of all headers in this’s header list whose name is\n // a byte-case-insensitive match for `Set-Cookie`, in order.\n\n const list = this[kHeadersList].cookies\n\n if (list) {\n return [...list]\n }\n\n return []\n }\n\n // https://fetch.spec.whatwg.org/#concept-header-list-sort-and-combine\n get [kHeadersSortedMap] () {\n if (this[kHeadersList][kHeadersSortedMap]) {\n return this[kHeadersList][kHeadersSortedMap]\n }\n\n // 1. Let headers be an empty list of headers with the key being the name\n // and value the value.\n const headers = []\n\n // 2. Let names be the result of convert header names to a sorted-lowercase\n // set with all the names of the headers in list.\n const names = [...this[kHeadersList]].sort((a, b) => a[0] < b[0] ? -1 : 1)\n const cookies = this[kHeadersList].cookies\n\n // 3. For each name of names:\n for (let i = 0; i < names.length; ++i) {\n const [name, value] = names[i]\n // 1. If name is `set-cookie`, then:\n if (name === 'set-cookie') {\n // 1. Let values be a list of all values of headers in list whose name\n // is a byte-case-insensitive match for name, in order.\n\n // 2. For each value of values:\n // 1. Append (name, value) to headers.\n for (let j = 0; j < cookies.length; ++j) {\n headers.push([name, cookies[j]])\n }\n } else {\n // 2. Otherwise:\n\n // 1. Let value be the result of getting name from list.\n\n // 2. Assert: value is non-null.\n assert(value !== null)\n\n // 3. Append (name, value) to headers.\n headers.push([name, value])\n }\n }\n\n this[kHeadersList][kHeadersSortedMap] = headers\n\n // 4. Return headers.\n return headers\n }\n\n keys () {\n webidl.brandCheck(this, Headers)\n\n if (this[kGuard] === 'immutable') {\n const value = this[kHeadersSortedMap]\n return makeIterator(() => value, 'Headers',\n 'key')\n }\n\n return makeIterator(\n () => [...this[kHeadersSortedMap].values()],\n 'Headers',\n 'key'\n )\n }\n\n values () {\n webidl.brandCheck(this, Headers)\n\n if (this[kGuard] === 'immutable') {\n const value = this[kHeadersSortedMap]\n return makeIterator(() => value, 'Headers',\n 'value')\n }\n\n return makeIterator(\n () => [...this[kHeadersSortedMap].values()],\n 'Headers',\n 'value'\n )\n }\n\n entries () {\n webidl.brandCheck(this, Headers)\n\n if (this[kGuard] === 'immutable') {\n const value = this[kHeadersSortedMap]\n return makeIterator(() => value, 'Headers',\n 'key+value')\n }\n\n return makeIterator(\n () => [...this[kHeadersSortedMap].values()],\n 'Headers',\n 'key+value'\n )\n }\n\n /**\n * @param {(value: string, key: string, self: Headers) => void} callbackFn\n * @param {unknown} thisArg\n */\n forEach (callbackFn, thisArg = globalThis) {\n webidl.brandCheck(this, Headers)\n\n webidl.argumentLengthCheck(arguments, 1, { header: 'Headers.forEach' })\n\n if (typeof callbackFn !== 'function') {\n throw new TypeError(\n \"Failed to execute 'forEach' on 'Headers': parameter 1 is not of type 'Function'.\"\n )\n }\n\n for (const [key, value] of this) {\n callbackFn.apply(thisArg, [value, key, this])\n }\n }\n\n [Symbol.for('nodejs.util.inspect.custom')] () {\n webidl.brandCheck(this, Headers)\n\n return this[kHeadersList]\n }\n}\n\nHeaders.prototype[Symbol.iterator] = Headers.prototype.entries\n\nObject.defineProperties(Headers.prototype, {\n append: kEnumerableProperty,\n delete: kEnumerableProperty,\n get: kEnumerableProperty,\n has: kEnumerableProperty,\n set: kEnumerableProperty,\n getSetCookie: kEnumerableProperty,\n keys: kEnumerableProperty,\n values: kEnumerableProperty,\n entries: kEnumerableProperty,\n forEach: kEnumerableProperty,\n [Symbol.iterator]: { enumerable: false },\n [Symbol.toStringTag]: {\n value: 'Headers',\n configurable: true\n }\n})\n\nwebidl.converters.HeadersInit = function (V) {\n if (webidl.util.Type(V) === 'Object') {\n if (V[Symbol.iterator]) {\n return webidl.converters['sequence>'](V)\n }\n\n return webidl.converters['record'](V)\n }\n\n throw webidl.errors.conversionFailed({\n prefix: 'Headers constructor',\n argument: 'Argument 1',\n types: ['sequence>', 'record']\n })\n}\n\nmodule.exports = {\n fill,\n Headers,\n HeadersList\n}\n","// https://github.com/Ethan-Arrowood/undici-fetch\n\n'use strict'\n\nconst {\n Response,\n makeNetworkError,\n makeAppropriateNetworkError,\n filterResponse,\n makeResponse\n} = require('./response')\nconst { Headers } = require('./headers')\nconst { Request, makeRequest } = require('./request')\nconst zlib = require('zlib')\nconst {\n bytesMatch,\n makePolicyContainer,\n clonePolicyContainer,\n requestBadPort,\n TAOCheck,\n appendRequestOriginHeader,\n responseLocationURL,\n requestCurrentURL,\n setRequestReferrerPolicyOnRedirect,\n tryUpgradeRequestToAPotentiallyTrustworthyURL,\n createOpaqueTimingInfo,\n appendFetchMetadata,\n corsCheck,\n crossOriginResourcePolicyCheck,\n determineRequestsReferrer,\n coarsenedSharedCurrentTime,\n createDeferredPromise,\n isBlobLike,\n sameOrigin,\n isCancelled,\n isAborted,\n isErrorLike,\n fullyReadBody,\n readableStreamClose,\n isomorphicEncode,\n urlIsLocal,\n urlIsHttpHttpsScheme,\n urlHasHttpsScheme\n} = require('./util')\nconst { kState, kHeaders, kGuard, kRealm } = require('./symbols')\nconst assert = require('assert')\nconst { safelyExtractBody } = require('./body')\nconst {\n redirectStatusSet,\n nullBodyStatus,\n safeMethodsSet,\n requestBodyHeader,\n subresourceSet,\n DOMException\n} = require('./constants')\nconst { kHeadersList } = require('../core/symbols')\nconst EE = require('events')\nconst { Readable, pipeline } = require('stream')\nconst { addAbortListener, isErrored, isReadable, nodeMajor, nodeMinor } = require('../core/util')\nconst { dataURLProcessor, serializeAMimeType } = require('./dataURL')\nconst { TransformStream } = require('stream/web')\nconst { getGlobalDispatcher } = require('../global')\nconst { webidl } = require('./webidl')\nconst { STATUS_CODES } = require('http')\nconst GET_OR_HEAD = ['GET', 'HEAD']\n\n/** @type {import('buffer').resolveObjectURL} */\nlet resolveObjectURL\nlet ReadableStream = globalThis.ReadableStream\n\nclass Fetch extends EE {\n constructor (dispatcher) {\n super()\n\n this.dispatcher = dispatcher\n this.connection = null\n this.dump = false\n this.state = 'ongoing'\n // 2 terminated listeners get added per request,\n // but only 1 gets removed. If there are 20 redirects,\n // 21 listeners will be added.\n // See https://github.com/nodejs/undici/issues/1711\n // TODO (fix): Find and fix root cause for leaked listener.\n this.setMaxListeners(21)\n }\n\n terminate (reason) {\n if (this.state !== 'ongoing') {\n return\n }\n\n this.state = 'terminated'\n this.connection?.destroy(reason)\n this.emit('terminated', reason)\n }\n\n // https://fetch.spec.whatwg.org/#fetch-controller-abort\n abort (error) {\n if (this.state !== 'ongoing') {\n return\n }\n\n // 1. Set controller’s state to \"aborted\".\n this.state = 'aborted'\n\n // 2. Let fallbackError be an \"AbortError\" DOMException.\n // 3. Set error to fallbackError if it is not given.\n if (!error) {\n error = new DOMException('The operation was aborted.', 'AbortError')\n }\n\n // 4. Let serializedError be StructuredSerialize(error).\n // If that threw an exception, catch it, and let\n // serializedError be StructuredSerialize(fallbackError).\n\n // 5. Set controller’s serialized abort reason to serializedError.\n this.serializedAbortReason = error\n\n this.connection?.destroy(error)\n this.emit('terminated', error)\n }\n}\n\n// https://fetch.spec.whatwg.org/#fetch-method\nfunction fetch (input, init = {}) {\n webidl.argumentLengthCheck(arguments, 1, { header: 'globalThis.fetch' })\n\n // 1. Let p be a new promise.\n const p = createDeferredPromise()\n\n // 2. Let requestObject be the result of invoking the initial value of\n // Request as constructor with input and init as arguments. If this throws\n // an exception, reject p with it and return p.\n let requestObject\n\n try {\n requestObject = new Request(input, init)\n } catch (e) {\n p.reject(e)\n return p.promise\n }\n\n // 3. Let request be requestObject’s request.\n const request = requestObject[kState]\n\n // 4. If requestObject’s signal’s aborted flag is set, then:\n if (requestObject.signal.aborted) {\n // 1. Abort the fetch() call with p, request, null, and\n // requestObject’s signal’s abort reason.\n abortFetch(p, request, null, requestObject.signal.reason)\n\n // 2. Return p.\n return p.promise\n }\n\n // 5. Let globalObject be request’s client’s global object.\n const globalObject = request.client.globalObject\n\n // 6. If globalObject is a ServiceWorkerGlobalScope object, then set\n // request’s service-workers mode to \"none\".\n if (globalObject?.constructor?.name === 'ServiceWorkerGlobalScope') {\n request.serviceWorkers = 'none'\n }\n\n // 7. Let responseObject be null.\n let responseObject = null\n\n // 8. Let relevantRealm be this’s relevant Realm.\n const relevantRealm = null\n\n // 9. Let locallyAborted be false.\n let locallyAborted = false\n\n // 10. Let controller be null.\n let controller = null\n\n // 11. Add the following abort steps to requestObject’s signal:\n addAbortListener(\n requestObject.signal,\n () => {\n // 1. Set locallyAborted to true.\n locallyAborted = true\n\n // 2. Assert: controller is non-null.\n assert(controller != null)\n\n // 3. Abort controller with requestObject’s signal’s abort reason.\n controller.abort(requestObject.signal.reason)\n\n // 4. Abort the fetch() call with p, request, responseObject,\n // and requestObject’s signal’s abort reason.\n abortFetch(p, request, responseObject, requestObject.signal.reason)\n }\n )\n\n // 12. Let handleFetchDone given response response be to finalize and\n // report timing with response, globalObject, and \"fetch\".\n const handleFetchDone = (response) =>\n finalizeAndReportTiming(response, 'fetch')\n\n // 13. Set controller to the result of calling fetch given request,\n // with processResponseEndOfBody set to handleFetchDone, and processResponse\n // given response being these substeps:\n\n const processResponse = (response) => {\n // 1. If locallyAborted is true, terminate these substeps.\n if (locallyAborted) {\n return Promise.resolve()\n }\n\n // 2. If response’s aborted flag is set, then:\n if (response.aborted) {\n // 1. Let deserializedError be the result of deserialize a serialized\n // abort reason given controller’s serialized abort reason and\n // relevantRealm.\n\n // 2. Abort the fetch() call with p, request, responseObject, and\n // deserializedError.\n\n abortFetch(p, request, responseObject, controller.serializedAbortReason)\n return Promise.resolve()\n }\n\n // 3. If response is a network error, then reject p with a TypeError\n // and terminate these substeps.\n if (response.type === 'error') {\n p.reject(\n Object.assign(new TypeError('fetch failed'), { cause: response.error })\n )\n return Promise.resolve()\n }\n\n // 4. Set responseObject to the result of creating a Response object,\n // given response, \"immutable\", and relevantRealm.\n responseObject = new Response()\n responseObject[kState] = response\n responseObject[kRealm] = relevantRealm\n responseObject[kHeaders][kHeadersList] = response.headersList\n responseObject[kHeaders][kGuard] = 'immutable'\n responseObject[kHeaders][kRealm] = relevantRealm\n\n // 5. Resolve p with responseObject.\n p.resolve(responseObject)\n }\n\n controller = fetching({\n request,\n processResponseEndOfBody: handleFetchDone,\n processResponse,\n dispatcher: init.dispatcher ?? getGlobalDispatcher() // undici\n })\n\n // 14. Return p.\n return p.promise\n}\n\n// https://fetch.spec.whatwg.org/#finalize-and-report-timing\nfunction finalizeAndReportTiming (response, initiatorType = 'other') {\n // 1. If response is an aborted network error, then return.\n if (response.type === 'error' && response.aborted) {\n return\n }\n\n // 2. If response’s URL list is null or empty, then return.\n if (!response.urlList?.length) {\n return\n }\n\n // 3. Let originalURL be response’s URL list[0].\n const originalURL = response.urlList[0]\n\n // 4. Let timingInfo be response’s timing info.\n let timingInfo = response.timingInfo\n\n // 5. Let cacheState be response’s cache state.\n let cacheState = response.cacheState\n\n // 6. If originalURL’s scheme is not an HTTP(S) scheme, then return.\n if (!urlIsHttpHttpsScheme(originalURL)) {\n return\n }\n\n // 7. If timingInfo is null, then return.\n if (timingInfo === null) {\n return\n }\n\n // 8. If response’s timing allow passed flag is not set, then:\n if (!response.timingAllowPassed) {\n // 1. Set timingInfo to a the result of creating an opaque timing info for timingInfo.\n timingInfo = createOpaqueTimingInfo({\n startTime: timingInfo.startTime\n })\n\n // 2. Set cacheState to the empty string.\n cacheState = ''\n }\n\n // 9. Set timingInfo’s end time to the coarsened shared current time\n // given global’s relevant settings object’s cross-origin isolated\n // capability.\n // TODO: given global’s relevant settings object’s cross-origin isolated\n // capability?\n timingInfo.endTime = coarsenedSharedCurrentTime()\n\n // 10. Set response’s timing info to timingInfo.\n response.timingInfo = timingInfo\n\n // 11. Mark resource timing for timingInfo, originalURL, initiatorType,\n // global, and cacheState.\n markResourceTiming(\n timingInfo,\n originalURL,\n initiatorType,\n globalThis,\n cacheState\n )\n}\n\n// https://w3c.github.io/resource-timing/#dfn-mark-resource-timing\nfunction markResourceTiming (timingInfo, originalURL, initiatorType, globalThis, cacheState) {\n if (nodeMajor > 18 || (nodeMajor === 18 && nodeMinor >= 2)) {\n performance.markResourceTiming(timingInfo, originalURL.href, initiatorType, globalThis, cacheState)\n }\n}\n\n// https://fetch.spec.whatwg.org/#abort-fetch\nfunction abortFetch (p, request, responseObject, error) {\n // Note: AbortSignal.reason was added in node v17.2.0\n // which would give us an undefined error to reject with.\n // Remove this once node v16 is no longer supported.\n if (!error) {\n error = new DOMException('The operation was aborted.', 'AbortError')\n }\n\n // 1. Reject promise with error.\n p.reject(error)\n\n // 2. If request’s body is not null and is readable, then cancel request’s\n // body with error.\n if (request.body != null && isReadable(request.body?.stream)) {\n request.body.stream.cancel(error).catch((err) => {\n if (err.code === 'ERR_INVALID_STATE') {\n // Node bug?\n return\n }\n throw err\n })\n }\n\n // 3. If responseObject is null, then return.\n if (responseObject == null) {\n return\n }\n\n // 4. Let response be responseObject’s response.\n const response = responseObject[kState]\n\n // 5. If response’s body is not null and is readable, then error response’s\n // body with error.\n if (response.body != null && isReadable(response.body?.stream)) {\n response.body.stream.cancel(error).catch((err) => {\n if (err.code === 'ERR_INVALID_STATE') {\n // Node bug?\n return\n }\n throw err\n })\n }\n}\n\n// https://fetch.spec.whatwg.org/#fetching\nfunction fetching ({\n request,\n processRequestBodyChunkLength,\n processRequestEndOfBody,\n processResponse,\n processResponseEndOfBody,\n processResponseConsumeBody,\n useParallelQueue = false,\n dispatcher // undici\n}) {\n // 1. Let taskDestination be null.\n let taskDestination = null\n\n // 2. Let crossOriginIsolatedCapability be false.\n let crossOriginIsolatedCapability = false\n\n // 3. If request’s client is non-null, then:\n if (request.client != null) {\n // 1. Set taskDestination to request’s client’s global object.\n taskDestination = request.client.globalObject\n\n // 2. Set crossOriginIsolatedCapability to request’s client’s cross-origin\n // isolated capability.\n crossOriginIsolatedCapability =\n request.client.crossOriginIsolatedCapability\n }\n\n // 4. If useParallelQueue is true, then set taskDestination to the result of\n // starting a new parallel queue.\n // TODO\n\n // 5. Let timingInfo be a new fetch timing info whose start time and\n // post-redirect start time are the coarsened shared current time given\n // crossOriginIsolatedCapability.\n const currenTime = coarsenedSharedCurrentTime(crossOriginIsolatedCapability)\n const timingInfo = createOpaqueTimingInfo({\n startTime: currenTime\n })\n\n // 6. Let fetchParams be a new fetch params whose\n // request is request,\n // timing info is timingInfo,\n // process request body chunk length is processRequestBodyChunkLength,\n // process request end-of-body is processRequestEndOfBody,\n // process response is processResponse,\n // process response consume body is processResponseConsumeBody,\n // process response end-of-body is processResponseEndOfBody,\n // task destination is taskDestination,\n // and cross-origin isolated capability is crossOriginIsolatedCapability.\n const fetchParams = {\n controller: new Fetch(dispatcher),\n request,\n timingInfo,\n processRequestBodyChunkLength,\n processRequestEndOfBody,\n processResponse,\n processResponseConsumeBody,\n processResponseEndOfBody,\n taskDestination,\n crossOriginIsolatedCapability\n }\n\n // 7. If request’s body is a byte sequence, then set request’s body to\n // request’s body as a body.\n // NOTE: Since fetching is only called from fetch, body should already be\n // extracted.\n assert(!request.body || request.body.stream)\n\n // 8. If request’s window is \"client\", then set request’s window to request’s\n // client, if request’s client’s global object is a Window object; otherwise\n // \"no-window\".\n if (request.window === 'client') {\n // TODO: What if request.client is null?\n request.window =\n request.client?.globalObject?.constructor?.name === 'Window'\n ? request.client\n : 'no-window'\n }\n\n // 9. If request’s origin is \"client\", then set request’s origin to request’s\n // client’s origin.\n if (request.origin === 'client') {\n // TODO: What if request.client is null?\n request.origin = request.client?.origin\n }\n\n // 10. If all of the following conditions are true:\n // TODO\n\n // 11. If request’s policy container is \"client\", then:\n if (request.policyContainer === 'client') {\n // 1. If request’s client is non-null, then set request’s policy\n // container to a clone of request’s client’s policy container. [HTML]\n if (request.client != null) {\n request.policyContainer = clonePolicyContainer(\n request.client.policyContainer\n )\n } else {\n // 2. Otherwise, set request’s policy container to a new policy\n // container.\n request.policyContainer = makePolicyContainer()\n }\n }\n\n // 12. If request’s header list does not contain `Accept`, then:\n if (!request.headersList.contains('accept')) {\n // 1. Let value be `*/*`.\n const value = '*/*'\n\n // 2. A user agent should set value to the first matching statement, if\n // any, switching on request’s destination:\n // \"document\"\n // \"frame\"\n // \"iframe\"\n // `text/html,application/xhtml+xml,application/xml;q=0.9,*/*;q=0.8`\n // \"image\"\n // `image/png,image/svg+xml,image/*;q=0.8,*/*;q=0.5`\n // \"style\"\n // `text/css,*/*;q=0.1`\n // TODO\n\n // 3. Append `Accept`/value to request’s header list.\n request.headersList.append('accept', value)\n }\n\n // 13. If request’s header list does not contain `Accept-Language`, then\n // user agents should append `Accept-Language`/an appropriate value to\n // request’s header list.\n if (!request.headersList.contains('accept-language')) {\n request.headersList.append('accept-language', '*')\n }\n\n // 14. If request’s priority is null, then use request’s initiator and\n // destination appropriately in setting request’s priority to a\n // user-agent-defined object.\n if (request.priority === null) {\n // TODO\n }\n\n // 15. If request is a subresource request, then:\n if (subresourceSet.has(request.destination)) {\n // TODO\n }\n\n // 16. Run main fetch given fetchParams.\n mainFetch(fetchParams)\n .catch(err => {\n fetchParams.controller.terminate(err)\n })\n\n // 17. Return fetchParam's controller\n return fetchParams.controller\n}\n\n// https://fetch.spec.whatwg.org/#concept-main-fetch\nasync function mainFetch (fetchParams, recursive = false) {\n // 1. Let request be fetchParams’s request.\n const request = fetchParams.request\n\n // 2. Let response be null.\n let response = null\n\n // 3. If request’s local-URLs-only flag is set and request’s current URL is\n // not local, then set response to a network error.\n if (request.localURLsOnly && !urlIsLocal(requestCurrentURL(request))) {\n response = makeNetworkError('local URLs only')\n }\n\n // 4. Run report Content Security Policy violations for request.\n // TODO\n\n // 5. Upgrade request to a potentially trustworthy URL, if appropriate.\n tryUpgradeRequestToAPotentiallyTrustworthyURL(request)\n\n // 6. If should request be blocked due to a bad port, should fetching request\n // be blocked as mixed content, or should request be blocked by Content\n // Security Policy returns blocked, then set response to a network error.\n if (requestBadPort(request) === 'blocked') {\n response = makeNetworkError('bad port')\n }\n // TODO: should fetching request be blocked as mixed content?\n // TODO: should request be blocked by Content Security Policy?\n\n // 7. If request’s referrer policy is the empty string, then set request’s\n // referrer policy to request’s policy container’s referrer policy.\n if (request.referrerPolicy === '') {\n request.referrerPolicy = request.policyContainer.referrerPolicy\n }\n\n // 8. If request’s referrer is not \"no-referrer\", then set request’s\n // referrer to the result of invoking determine request’s referrer.\n if (request.referrer !== 'no-referrer') {\n request.referrer = determineRequestsReferrer(request)\n }\n\n // 9. Set request’s current URL’s scheme to \"https\" if all of the following\n // conditions are true:\n // - request’s current URL’s scheme is \"http\"\n // - request’s current URL’s host is a domain\n // - Matching request’s current URL’s host per Known HSTS Host Domain Name\n // Matching results in either a superdomain match with an asserted\n // includeSubDomains directive or a congruent match (with or without an\n // asserted includeSubDomains directive). [HSTS]\n // TODO\n\n // 10. If recursive is false, then run the remaining steps in parallel.\n // TODO\n\n // 11. If response is null, then set response to the result of running\n // the steps corresponding to the first matching statement:\n if (response === null) {\n response = await (async () => {\n const currentURL = requestCurrentURL(request)\n\n if (\n // - request’s current URL’s origin is same origin with request’s origin,\n // and request’s response tainting is \"basic\"\n (sameOrigin(currentURL, request.url) && request.responseTainting === 'basic') ||\n // request’s current URL’s scheme is \"data\"\n (currentURL.protocol === 'data:') ||\n // - request’s mode is \"navigate\" or \"websocket\"\n (request.mode === 'navigate' || request.mode === 'websocket')\n ) {\n // 1. Set request’s response tainting to \"basic\".\n request.responseTainting = 'basic'\n\n // 2. Return the result of running scheme fetch given fetchParams.\n return await schemeFetch(fetchParams)\n }\n\n // request’s mode is \"same-origin\"\n if (request.mode === 'same-origin') {\n // 1. Return a network error.\n return makeNetworkError('request mode cannot be \"same-origin\"')\n }\n\n // request’s mode is \"no-cors\"\n if (request.mode === 'no-cors') {\n // 1. If request’s redirect mode is not \"follow\", then return a network\n // error.\n if (request.redirect !== 'follow') {\n return makeNetworkError(\n 'redirect mode cannot be \"follow\" for \"no-cors\" request'\n )\n }\n\n // 2. Set request’s response tainting to \"opaque\".\n request.responseTainting = 'opaque'\n\n // 3. Return the result of running scheme fetch given fetchParams.\n return await schemeFetch(fetchParams)\n }\n\n // request’s current URL’s scheme is not an HTTP(S) scheme\n if (!urlIsHttpHttpsScheme(requestCurrentURL(request))) {\n // Return a network error.\n return makeNetworkError('URL scheme must be a HTTP(S) scheme')\n }\n\n // - request’s use-CORS-preflight flag is set\n // - request’s unsafe-request flag is set and either request’s method is\n // not a CORS-safelisted method or CORS-unsafe request-header names with\n // request’s header list is not empty\n // 1. Set request’s response tainting to \"cors\".\n // 2. Let corsWithPreflightResponse be the result of running HTTP fetch\n // given fetchParams and true.\n // 3. If corsWithPreflightResponse is a network error, then clear cache\n // entries using request.\n // 4. Return corsWithPreflightResponse.\n // TODO\n\n // Otherwise\n // 1. Set request’s response tainting to \"cors\".\n request.responseTainting = 'cors'\n\n // 2. Return the result of running HTTP fetch given fetchParams.\n return await httpFetch(fetchParams)\n })()\n }\n\n // 12. If recursive is true, then return response.\n if (recursive) {\n return response\n }\n\n // 13. If response is not a network error and response is not a filtered\n // response, then:\n if (response.status !== 0 && !response.internalResponse) {\n // If request’s response tainting is \"cors\", then:\n if (request.responseTainting === 'cors') {\n // 1. Let headerNames be the result of extracting header list values\n // given `Access-Control-Expose-Headers` and response’s header list.\n // TODO\n // 2. If request’s credentials mode is not \"include\" and headerNames\n // contains `*`, then set response’s CORS-exposed header-name list to\n // all unique header names in response’s header list.\n // TODO\n // 3. Otherwise, if headerNames is not null or failure, then set\n // response’s CORS-exposed header-name list to headerNames.\n // TODO\n }\n\n // Set response to the following filtered response with response as its\n // internal response, depending on request’s response tainting:\n if (request.responseTainting === 'basic') {\n response = filterResponse(response, 'basic')\n } else if (request.responseTainting === 'cors') {\n response = filterResponse(response, 'cors')\n } else if (request.responseTainting === 'opaque') {\n response = filterResponse(response, 'opaque')\n } else {\n assert(false)\n }\n }\n\n // 14. Let internalResponse be response, if response is a network error,\n // and response’s internal response otherwise.\n let internalResponse =\n response.status === 0 ? response : response.internalResponse\n\n // 15. If internalResponse’s URL list is empty, then set it to a clone of\n // request’s URL list.\n if (internalResponse.urlList.length === 0) {\n internalResponse.urlList.push(...request.urlList)\n }\n\n // 16. If request’s timing allow failed flag is unset, then set\n // internalResponse’s timing allow passed flag.\n if (!request.timingAllowFailed) {\n response.timingAllowPassed = true\n }\n\n // 17. If response is not a network error and any of the following returns\n // blocked\n // - should internalResponse to request be blocked as mixed content\n // - should internalResponse to request be blocked by Content Security Policy\n // - should internalResponse to request be blocked due to its MIME type\n // - should internalResponse to request be blocked due to nosniff\n // TODO\n\n // 18. If response’s type is \"opaque\", internalResponse’s status is 206,\n // internalResponse’s range-requested flag is set, and request’s header\n // list does not contain `Range`, then set response and internalResponse\n // to a network error.\n if (\n response.type === 'opaque' &&\n internalResponse.status === 206 &&\n internalResponse.rangeRequested &&\n !request.headers.contains('range')\n ) {\n response = internalResponse = makeNetworkError()\n }\n\n // 19. If response is not a network error and either request’s method is\n // `HEAD` or `CONNECT`, or internalResponse’s status is a null body status,\n // set internalResponse’s body to null and disregard any enqueuing toward\n // it (if any).\n if (\n response.status !== 0 &&\n (request.method === 'HEAD' ||\n request.method === 'CONNECT' ||\n nullBodyStatus.includes(internalResponse.status))\n ) {\n internalResponse.body = null\n fetchParams.controller.dump = true\n }\n\n // 20. If request’s integrity metadata is not the empty string, then:\n if (request.integrity) {\n // 1. Let processBodyError be this step: run fetch finale given fetchParams\n // and a network error.\n const processBodyError = (reason) =>\n fetchFinale(fetchParams, makeNetworkError(reason))\n\n // 2. If request’s response tainting is \"opaque\", or response’s body is null,\n // then run processBodyError and abort these steps.\n if (request.responseTainting === 'opaque' || response.body == null) {\n processBodyError(response.error)\n return\n }\n\n // 3. Let processBody given bytes be these steps:\n const processBody = (bytes) => {\n // 1. If bytes do not match request’s integrity metadata,\n // then run processBodyError and abort these steps. [SRI]\n if (!bytesMatch(bytes, request.integrity)) {\n processBodyError('integrity mismatch')\n return\n }\n\n // 2. Set response’s body to bytes as a body.\n response.body = safelyExtractBody(bytes)[0]\n\n // 3. Run fetch finale given fetchParams and response.\n fetchFinale(fetchParams, response)\n }\n\n // 4. Fully read response’s body given processBody and processBodyError.\n await fullyReadBody(response.body, processBody, processBodyError)\n } else {\n // 21. Otherwise, run fetch finale given fetchParams and response.\n fetchFinale(fetchParams, response)\n }\n}\n\n// https://fetch.spec.whatwg.org/#concept-scheme-fetch\n// given a fetch params fetchParams\nfunction schemeFetch (fetchParams) {\n // Note: since the connection is destroyed on redirect, which sets fetchParams to a\n // cancelled state, we do not want this condition to trigger *unless* there have been\n // no redirects. See https://github.com/nodejs/undici/issues/1776\n // 1. If fetchParams is canceled, then return the appropriate network error for fetchParams.\n if (isCancelled(fetchParams) && fetchParams.request.redirectCount === 0) {\n return Promise.resolve(makeAppropriateNetworkError(fetchParams))\n }\n\n // 2. Let request be fetchParams’s request.\n const { request } = fetchParams\n\n const { protocol: scheme } = requestCurrentURL(request)\n\n // 3. Switch on request’s current URL’s scheme and run the associated steps:\n switch (scheme) {\n case 'about:': {\n // If request’s current URL’s path is the string \"blank\", then return a new response\n // whose status message is `OK`, header list is « (`Content-Type`, `text/html;charset=utf-8`) »,\n // and body is the empty byte sequence as a body.\n\n // Otherwise, return a network error.\n return Promise.resolve(makeNetworkError('about scheme is not supported'))\n }\n case 'blob:': {\n if (!resolveObjectURL) {\n resolveObjectURL = require('buffer').resolveObjectURL\n }\n\n // 1. Let blobURLEntry be request’s current URL’s blob URL entry.\n const blobURLEntry = requestCurrentURL(request)\n\n // https://github.com/web-platform-tests/wpt/blob/7b0ebaccc62b566a1965396e5be7bb2bc06f841f/FileAPI/url/resources/fetch-tests.js#L52-L56\n // Buffer.resolveObjectURL does not ignore URL queries.\n if (blobURLEntry.search.length !== 0) {\n return Promise.resolve(makeNetworkError('NetworkError when attempting to fetch resource.'))\n }\n\n const blobURLEntryObject = resolveObjectURL(blobURLEntry.toString())\n\n // 2. If request’s method is not `GET`, blobURLEntry is null, or blobURLEntry’s\n // object is not a Blob object, then return a network error.\n if (request.method !== 'GET' || !isBlobLike(blobURLEntryObject)) {\n return Promise.resolve(makeNetworkError('invalid method'))\n }\n\n // 3. Let bodyWithType be the result of safely extracting blobURLEntry’s object.\n const bodyWithType = safelyExtractBody(blobURLEntryObject)\n\n // 4. Let body be bodyWithType’s body.\n const body = bodyWithType[0]\n\n // 5. Let length be body’s length, serialized and isomorphic encoded.\n const length = isomorphicEncode(`${body.length}`)\n\n // 6. Let type be bodyWithType’s type if it is non-null; otherwise the empty byte sequence.\n const type = bodyWithType[1] ?? ''\n\n // 7. Return a new response whose status message is `OK`, header list is\n // « (`Content-Length`, length), (`Content-Type`, type) », and body is body.\n const response = makeResponse({\n statusText: 'OK',\n headersList: [\n ['content-length', { name: 'Content-Length', value: length }],\n ['content-type', { name: 'Content-Type', value: type }]\n ]\n })\n\n response.body = body\n\n return Promise.resolve(response)\n }\n case 'data:': {\n // 1. Let dataURLStruct be the result of running the\n // data: URL processor on request’s current URL.\n const currentURL = requestCurrentURL(request)\n const dataURLStruct = dataURLProcessor(currentURL)\n\n // 2. If dataURLStruct is failure, then return a\n // network error.\n if (dataURLStruct === 'failure') {\n return Promise.resolve(makeNetworkError('failed to fetch the data URL'))\n }\n\n // 3. Let mimeType be dataURLStruct’s MIME type, serialized.\n const mimeType = serializeAMimeType(dataURLStruct.mimeType)\n\n // 4. Return a response whose status message is `OK`,\n // header list is « (`Content-Type`, mimeType) »,\n // and body is dataURLStruct’s body as a body.\n return Promise.resolve(makeResponse({\n statusText: 'OK',\n headersList: [\n ['content-type', { name: 'Content-Type', value: mimeType }]\n ],\n body: safelyExtractBody(dataURLStruct.body)[0]\n }))\n }\n case 'file:': {\n // For now, unfortunate as it is, file URLs are left as an exercise for the reader.\n // When in doubt, return a network error.\n return Promise.resolve(makeNetworkError('not implemented... yet...'))\n }\n case 'http:':\n case 'https:': {\n // Return the result of running HTTP fetch given fetchParams.\n\n return httpFetch(fetchParams)\n .catch((err) => makeNetworkError(err))\n }\n default: {\n return Promise.resolve(makeNetworkError('unknown scheme'))\n }\n }\n}\n\n// https://fetch.spec.whatwg.org/#finalize-response\nfunction finalizeResponse (fetchParams, response) {\n // 1. Set fetchParams’s request’s done flag.\n fetchParams.request.done = true\n\n // 2, If fetchParams’s process response done is not null, then queue a fetch\n // task to run fetchParams’s process response done given response, with\n // fetchParams’s task destination.\n if (fetchParams.processResponseDone != null) {\n queueMicrotask(() => fetchParams.processResponseDone(response))\n }\n}\n\n// https://fetch.spec.whatwg.org/#fetch-finale\nfunction fetchFinale (fetchParams, response) {\n // 1. If response is a network error, then:\n if (response.type === 'error') {\n // 1. Set response’s URL list to « fetchParams’s request’s URL list[0] ».\n response.urlList = [fetchParams.request.urlList[0]]\n\n // 2. Set response’s timing info to the result of creating an opaque timing\n // info for fetchParams’s timing info.\n response.timingInfo = createOpaqueTimingInfo({\n startTime: fetchParams.timingInfo.startTime\n })\n }\n\n // 2. Let processResponseEndOfBody be the following steps:\n const processResponseEndOfBody = () => {\n // 1. Set fetchParams’s request’s done flag.\n fetchParams.request.done = true\n\n // If fetchParams’s process response end-of-body is not null,\n // then queue a fetch task to run fetchParams’s process response\n // end-of-body given response with fetchParams’s task destination.\n if (fetchParams.processResponseEndOfBody != null) {\n queueMicrotask(() => fetchParams.processResponseEndOfBody(response))\n }\n }\n\n // 3. If fetchParams’s process response is non-null, then queue a fetch task\n // to run fetchParams’s process response given response, with fetchParams’s\n // task destination.\n if (fetchParams.processResponse != null) {\n queueMicrotask(() => fetchParams.processResponse(response))\n }\n\n // 4. If response’s body is null, then run processResponseEndOfBody.\n if (response.body == null) {\n processResponseEndOfBody()\n } else {\n // 5. Otherwise:\n\n // 1. Let transformStream be a new a TransformStream.\n\n // 2. Let identityTransformAlgorithm be an algorithm which, given chunk,\n // enqueues chunk in transformStream.\n const identityTransformAlgorithm = (chunk, controller) => {\n controller.enqueue(chunk)\n }\n\n // 3. Set up transformStream with transformAlgorithm set to identityTransformAlgorithm\n // and flushAlgorithm set to processResponseEndOfBody.\n const transformStream = new TransformStream({\n start () {},\n transform: identityTransformAlgorithm,\n flush: processResponseEndOfBody\n }, {\n size () {\n return 1\n }\n }, {\n size () {\n return 1\n }\n })\n\n // 4. Set response’s body to the result of piping response’s body through transformStream.\n response.body = { stream: response.body.stream.pipeThrough(transformStream) }\n }\n\n // 6. If fetchParams’s process response consume body is non-null, then:\n if (fetchParams.processResponseConsumeBody != null) {\n // 1. Let processBody given nullOrBytes be this step: run fetchParams’s\n // process response consume body given response and nullOrBytes.\n const processBody = (nullOrBytes) => fetchParams.processResponseConsumeBody(response, nullOrBytes)\n\n // 2. Let processBodyError be this step: run fetchParams’s process\n // response consume body given response and failure.\n const processBodyError = (failure) => fetchParams.processResponseConsumeBody(response, failure)\n\n // 3. If response’s body is null, then queue a fetch task to run processBody\n // given null, with fetchParams’s task destination.\n if (response.body == null) {\n queueMicrotask(() => processBody(null))\n } else {\n // 4. Otherwise, fully read response’s body given processBody, processBodyError,\n // and fetchParams’s task destination.\n return fullyReadBody(response.body, processBody, processBodyError)\n }\n return Promise.resolve()\n }\n}\n\n// https://fetch.spec.whatwg.org/#http-fetch\nasync function httpFetch (fetchParams) {\n // 1. Let request be fetchParams’s request.\n const request = fetchParams.request\n\n // 2. Let response be null.\n let response = null\n\n // 3. Let actualResponse be null.\n let actualResponse = null\n\n // 4. Let timingInfo be fetchParams’s timing info.\n const timingInfo = fetchParams.timingInfo\n\n // 5. If request’s service-workers mode is \"all\", then:\n if (request.serviceWorkers === 'all') {\n // TODO\n }\n\n // 6. If response is null, then:\n if (response === null) {\n // 1. If makeCORSPreflight is true and one of these conditions is true:\n // TODO\n\n // 2. If request’s redirect mode is \"follow\", then set request’s\n // service-workers mode to \"none\".\n if (request.redirect === 'follow') {\n request.serviceWorkers = 'none'\n }\n\n // 3. Set response and actualResponse to the result of running\n // HTTP-network-or-cache fetch given fetchParams.\n actualResponse = response = await httpNetworkOrCacheFetch(fetchParams)\n\n // 4. If request’s response tainting is \"cors\" and a CORS check\n // for request and response returns failure, then return a network error.\n if (\n request.responseTainting === 'cors' &&\n corsCheck(request, response) === 'failure'\n ) {\n return makeNetworkError('cors failure')\n }\n\n // 5. If the TAO check for request and response returns failure, then set\n // request’s timing allow failed flag.\n if (TAOCheck(request, response) === 'failure') {\n request.timingAllowFailed = true\n }\n }\n\n // 7. If either request’s response tainting or response’s type\n // is \"opaque\", and the cross-origin resource policy check with\n // request’s origin, request’s client, request’s destination,\n // and actualResponse returns blocked, then return a network error.\n if (\n (request.responseTainting === 'opaque' || response.type === 'opaque') &&\n crossOriginResourcePolicyCheck(\n request.origin,\n request.client,\n request.destination,\n actualResponse\n ) === 'blocked'\n ) {\n return makeNetworkError('blocked')\n }\n\n // 8. If actualResponse’s status is a redirect status, then:\n if (redirectStatusSet.has(actualResponse.status)) {\n // 1. If actualResponse’s status is not 303, request’s body is not null,\n // and the connection uses HTTP/2, then user agents may, and are even\n // encouraged to, transmit an RST_STREAM frame.\n // See, https://github.com/whatwg/fetch/issues/1288\n if (request.redirect !== 'manual') {\n fetchParams.controller.connection.destroy()\n }\n\n // 2. Switch on request’s redirect mode:\n if (request.redirect === 'error') {\n // Set response to a network error.\n response = makeNetworkError('unexpected redirect')\n } else if (request.redirect === 'manual') {\n // Set response to an opaque-redirect filtered response whose internal\n // response is actualResponse.\n // NOTE(spec): On the web this would return an `opaqueredirect` response,\n // but that doesn't make sense server side.\n // See https://github.com/nodejs/undici/issues/1193.\n response = actualResponse\n } else if (request.redirect === 'follow') {\n // Set response to the result of running HTTP-redirect fetch given\n // fetchParams and response.\n response = await httpRedirectFetch(fetchParams, response)\n } else {\n assert(false)\n }\n }\n\n // 9. Set response’s timing info to timingInfo.\n response.timingInfo = timingInfo\n\n // 10. Return response.\n return response\n}\n\n// https://fetch.spec.whatwg.org/#http-redirect-fetch\nfunction httpRedirectFetch (fetchParams, response) {\n // 1. Let request be fetchParams’s request.\n const request = fetchParams.request\n\n // 2. Let actualResponse be response, if response is not a filtered response,\n // and response’s internal response otherwise.\n const actualResponse = response.internalResponse\n ? response.internalResponse\n : response\n\n // 3. Let locationURL be actualResponse’s location URL given request’s current\n // URL’s fragment.\n let locationURL\n\n try {\n locationURL = responseLocationURL(\n actualResponse,\n requestCurrentURL(request).hash\n )\n\n // 4. If locationURL is null, then return response.\n if (locationURL == null) {\n return response\n }\n } catch (err) {\n // 5. If locationURL is failure, then return a network error.\n return Promise.resolve(makeNetworkError(err))\n }\n\n // 6. If locationURL’s scheme is not an HTTP(S) scheme, then return a network\n // error.\n if (!urlIsHttpHttpsScheme(locationURL)) {\n return Promise.resolve(makeNetworkError('URL scheme must be a HTTP(S) scheme'))\n }\n\n // 7. If request’s redirect count is 20, then return a network error.\n if (request.redirectCount === 20) {\n return Promise.resolve(makeNetworkError('redirect count exceeded'))\n }\n\n // 8. Increase request’s redirect count by 1.\n request.redirectCount += 1\n\n // 9. If request’s mode is \"cors\", locationURL includes credentials, and\n // request’s origin is not same origin with locationURL’s origin, then return\n // a network error.\n if (\n request.mode === 'cors' &&\n (locationURL.username || locationURL.password) &&\n !sameOrigin(request, locationURL)\n ) {\n return Promise.resolve(makeNetworkError('cross origin not allowed for request mode \"cors\"'))\n }\n\n // 10. If request’s response tainting is \"cors\" and locationURL includes\n // credentials, then return a network error.\n if (\n request.responseTainting === 'cors' &&\n (locationURL.username || locationURL.password)\n ) {\n return Promise.resolve(makeNetworkError(\n 'URL cannot contain credentials for request mode \"cors\"'\n ))\n }\n\n // 11. If actualResponse’s status is not 303, request’s body is non-null,\n // and request’s body’s source is null, then return a network error.\n if (\n actualResponse.status !== 303 &&\n request.body != null &&\n request.body.source == null\n ) {\n return Promise.resolve(makeNetworkError())\n }\n\n // 12. If one of the following is true\n // - actualResponse’s status is 301 or 302 and request’s method is `POST`\n // - actualResponse’s status is 303 and request’s method is not `GET` or `HEAD`\n if (\n ([301, 302].includes(actualResponse.status) && request.method === 'POST') ||\n (actualResponse.status === 303 &&\n !GET_OR_HEAD.includes(request.method))\n ) {\n // then:\n // 1. Set request’s method to `GET` and request’s body to null.\n request.method = 'GET'\n request.body = null\n\n // 2. For each headerName of request-body-header name, delete headerName from\n // request’s header list.\n for (const headerName of requestBodyHeader) {\n request.headersList.delete(headerName)\n }\n }\n\n // 13. If request’s current URL’s origin is not same origin with locationURL’s\n // origin, then for each headerName of CORS non-wildcard request-header name,\n // delete headerName from request’s header list.\n if (!sameOrigin(requestCurrentURL(request), locationURL)) {\n // https://fetch.spec.whatwg.org/#cors-non-wildcard-request-header-name\n request.headersList.delete('authorization')\n\n // https://fetch.spec.whatwg.org/#authentication-entries\n request.headersList.delete('proxy-authorization', true)\n\n // \"Cookie\" and \"Host\" are forbidden request-headers, which undici doesn't implement.\n request.headersList.delete('cookie')\n request.headersList.delete('host')\n }\n\n // 14. If request’s body is non-null, then set request’s body to the first return\n // value of safely extracting request’s body’s source.\n if (request.body != null) {\n assert(request.body.source != null)\n request.body = safelyExtractBody(request.body.source)[0]\n }\n\n // 15. Let timingInfo be fetchParams’s timing info.\n const timingInfo = fetchParams.timingInfo\n\n // 16. Set timingInfo’s redirect end time and post-redirect start time to the\n // coarsened shared current time given fetchParams’s cross-origin isolated\n // capability.\n timingInfo.redirectEndTime = timingInfo.postRedirectStartTime =\n coarsenedSharedCurrentTime(fetchParams.crossOriginIsolatedCapability)\n\n // 17. If timingInfo’s redirect start time is 0, then set timingInfo’s\n // redirect start time to timingInfo’s start time.\n if (timingInfo.redirectStartTime === 0) {\n timingInfo.redirectStartTime = timingInfo.startTime\n }\n\n // 18. Append locationURL to request’s URL list.\n request.urlList.push(locationURL)\n\n // 19. Invoke set request’s referrer policy on redirect on request and\n // actualResponse.\n setRequestReferrerPolicyOnRedirect(request, actualResponse)\n\n // 20. Return the result of running main fetch given fetchParams and true.\n return mainFetch(fetchParams, true)\n}\n\n// https://fetch.spec.whatwg.org/#http-network-or-cache-fetch\nasync function httpNetworkOrCacheFetch (\n fetchParams,\n isAuthenticationFetch = false,\n isNewConnectionFetch = false\n) {\n // 1. Let request be fetchParams’s request.\n const request = fetchParams.request\n\n // 2. Let httpFetchParams be null.\n let httpFetchParams = null\n\n // 3. Let httpRequest be null.\n let httpRequest = null\n\n // 4. Let response be null.\n let response = null\n\n // 5. Let storedResponse be null.\n // TODO: cache\n\n // 6. Let httpCache be null.\n const httpCache = null\n\n // 7. Let the revalidatingFlag be unset.\n const revalidatingFlag = false\n\n // 8. Run these steps, but abort when the ongoing fetch is terminated:\n\n // 1. If request’s window is \"no-window\" and request’s redirect mode is\n // \"error\", then set httpFetchParams to fetchParams and httpRequest to\n // request.\n if (request.window === 'no-window' && request.redirect === 'error') {\n httpFetchParams = fetchParams\n httpRequest = request\n } else {\n // Otherwise:\n\n // 1. Set httpRequest to a clone of request.\n httpRequest = makeRequest(request)\n\n // 2. Set httpFetchParams to a copy of fetchParams.\n httpFetchParams = { ...fetchParams }\n\n // 3. Set httpFetchParams’s request to httpRequest.\n httpFetchParams.request = httpRequest\n }\n\n // 3. Let includeCredentials be true if one of\n const includeCredentials =\n request.credentials === 'include' ||\n (request.credentials === 'same-origin' &&\n request.responseTainting === 'basic')\n\n // 4. Let contentLength be httpRequest’s body’s length, if httpRequest’s\n // body is non-null; otherwise null.\n const contentLength = httpRequest.body ? httpRequest.body.length : null\n\n // 5. Let contentLengthHeaderValue be null.\n let contentLengthHeaderValue = null\n\n // 6. If httpRequest’s body is null and httpRequest’s method is `POST` or\n // `PUT`, then set contentLengthHeaderValue to `0`.\n if (\n httpRequest.body == null &&\n ['POST', 'PUT'].includes(httpRequest.method)\n ) {\n contentLengthHeaderValue = '0'\n }\n\n // 7. If contentLength is non-null, then set contentLengthHeaderValue to\n // contentLength, serialized and isomorphic encoded.\n if (contentLength != null) {\n contentLengthHeaderValue = isomorphicEncode(`${contentLength}`)\n }\n\n // 8. If contentLengthHeaderValue is non-null, then append\n // `Content-Length`/contentLengthHeaderValue to httpRequest’s header\n // list.\n if (contentLengthHeaderValue != null) {\n httpRequest.headersList.append('content-length', contentLengthHeaderValue)\n }\n\n // 9. If contentLengthHeaderValue is non-null, then append (`Content-Length`,\n // contentLengthHeaderValue) to httpRequest’s header list.\n\n // 10. If contentLength is non-null and httpRequest’s keepalive is true,\n // then:\n if (contentLength != null && httpRequest.keepalive) {\n // NOTE: keepalive is a noop outside of browser context.\n }\n\n // 11. If httpRequest’s referrer is a URL, then append\n // `Referer`/httpRequest’s referrer, serialized and isomorphic encoded,\n // to httpRequest’s header list.\n if (httpRequest.referrer instanceof URL) {\n httpRequest.headersList.append('referer', isomorphicEncode(httpRequest.referrer.href))\n }\n\n // 12. Append a request `Origin` header for httpRequest.\n appendRequestOriginHeader(httpRequest)\n\n // 13. Append the Fetch metadata headers for httpRequest. [FETCH-METADATA]\n appendFetchMetadata(httpRequest)\n\n // 14. If httpRequest’s header list does not contain `User-Agent`, then\n // user agents should append `User-Agent`/default `User-Agent` value to\n // httpRequest’s header list.\n if (!httpRequest.headersList.contains('user-agent')) {\n httpRequest.headersList.append('user-agent', typeof esbuildDetection === 'undefined' ? 'undici' : 'node')\n }\n\n // 15. If httpRequest’s cache mode is \"default\" and httpRequest’s header\n // list contains `If-Modified-Since`, `If-None-Match`,\n // `If-Unmodified-Since`, `If-Match`, or `If-Range`, then set\n // httpRequest’s cache mode to \"no-store\".\n if (\n httpRequest.cache === 'default' &&\n (httpRequest.headersList.contains('if-modified-since') ||\n httpRequest.headersList.contains('if-none-match') ||\n httpRequest.headersList.contains('if-unmodified-since') ||\n httpRequest.headersList.contains('if-match') ||\n httpRequest.headersList.contains('if-range'))\n ) {\n httpRequest.cache = 'no-store'\n }\n\n // 16. If httpRequest’s cache mode is \"no-cache\", httpRequest’s prevent\n // no-cache cache-control header modification flag is unset, and\n // httpRequest’s header list does not contain `Cache-Control`, then append\n // `Cache-Control`/`max-age=0` to httpRequest’s header list.\n if (\n httpRequest.cache === 'no-cache' &&\n !httpRequest.preventNoCacheCacheControlHeaderModification &&\n !httpRequest.headersList.contains('cache-control')\n ) {\n httpRequest.headersList.append('cache-control', 'max-age=0')\n }\n\n // 17. If httpRequest’s cache mode is \"no-store\" or \"reload\", then:\n if (httpRequest.cache === 'no-store' || httpRequest.cache === 'reload') {\n // 1. If httpRequest’s header list does not contain `Pragma`, then append\n // `Pragma`/`no-cache` to httpRequest’s header list.\n if (!httpRequest.headersList.contains('pragma')) {\n httpRequest.headersList.append('pragma', 'no-cache')\n }\n\n // 2. If httpRequest’s header list does not contain `Cache-Control`,\n // then append `Cache-Control`/`no-cache` to httpRequest’s header list.\n if (!httpRequest.headersList.contains('cache-control')) {\n httpRequest.headersList.append('cache-control', 'no-cache')\n }\n }\n\n // 18. If httpRequest’s header list contains `Range`, then append\n // `Accept-Encoding`/`identity` to httpRequest’s header list.\n if (httpRequest.headersList.contains('range')) {\n httpRequest.headersList.append('accept-encoding', 'identity')\n }\n\n // 19. Modify httpRequest’s header list per HTTP. Do not append a given\n // header if httpRequest’s header list contains that header’s name.\n // TODO: https://github.com/whatwg/fetch/issues/1285#issuecomment-896560129\n if (!httpRequest.headersList.contains('accept-encoding')) {\n if (urlHasHttpsScheme(requestCurrentURL(httpRequest))) {\n httpRequest.headersList.append('accept-encoding', 'br, gzip, deflate')\n } else {\n httpRequest.headersList.append('accept-encoding', 'gzip, deflate')\n }\n }\n\n httpRequest.headersList.delete('host')\n\n // 20. If includeCredentials is true, then:\n if (includeCredentials) {\n // 1. If the user agent is not configured to block cookies for httpRequest\n // (see section 7 of [COOKIES]), then:\n // TODO: credentials\n // 2. If httpRequest’s header list does not contain `Authorization`, then:\n // TODO: credentials\n }\n\n // 21. If there’s a proxy-authentication entry, use it as appropriate.\n // TODO: proxy-authentication\n\n // 22. Set httpCache to the result of determining the HTTP cache\n // partition, given httpRequest.\n // TODO: cache\n\n // 23. If httpCache is null, then set httpRequest’s cache mode to\n // \"no-store\".\n if (httpCache == null) {\n httpRequest.cache = 'no-store'\n }\n\n // 24. If httpRequest’s cache mode is neither \"no-store\" nor \"reload\",\n // then:\n if (httpRequest.mode !== 'no-store' && httpRequest.mode !== 'reload') {\n // TODO: cache\n }\n\n // 9. If aborted, then return the appropriate network error for fetchParams.\n // TODO\n\n // 10. If response is null, then:\n if (response == null) {\n // 1. If httpRequest’s cache mode is \"only-if-cached\", then return a\n // network error.\n if (httpRequest.mode === 'only-if-cached') {\n return makeNetworkError('only if cached')\n }\n\n // 2. Let forwardResponse be the result of running HTTP-network fetch\n // given httpFetchParams, includeCredentials, and isNewConnectionFetch.\n const forwardResponse = await httpNetworkFetch(\n httpFetchParams,\n includeCredentials,\n isNewConnectionFetch\n )\n\n // 3. If httpRequest’s method is unsafe and forwardResponse’s status is\n // in the range 200 to 399, inclusive, invalidate appropriate stored\n // responses in httpCache, as per the \"Invalidation\" chapter of HTTP\n // Caching, and set storedResponse to null. [HTTP-CACHING]\n if (\n !safeMethodsSet.has(httpRequest.method) &&\n forwardResponse.status >= 200 &&\n forwardResponse.status <= 399\n ) {\n // TODO: cache\n }\n\n // 4. If the revalidatingFlag is set and forwardResponse’s status is 304,\n // then:\n if (revalidatingFlag && forwardResponse.status === 304) {\n // TODO: cache\n }\n\n // 5. If response is null, then:\n if (response == null) {\n // 1. Set response to forwardResponse.\n response = forwardResponse\n\n // 2. Store httpRequest and forwardResponse in httpCache, as per the\n // \"Storing Responses in Caches\" chapter of HTTP Caching. [HTTP-CACHING]\n // TODO: cache\n }\n }\n\n // 11. Set response’s URL list to a clone of httpRequest’s URL list.\n response.urlList = [...httpRequest.urlList]\n\n // 12. If httpRequest’s header list contains `Range`, then set response’s\n // range-requested flag.\n if (httpRequest.headersList.contains('range')) {\n response.rangeRequested = true\n }\n\n // 13. Set response’s request-includes-credentials to includeCredentials.\n response.requestIncludesCredentials = includeCredentials\n\n // 14. If response’s status is 401, httpRequest’s response tainting is not\n // \"cors\", includeCredentials is true, and request’s window is an environment\n // settings object, then:\n // TODO\n\n // 15. If response’s status is 407, then:\n if (response.status === 407) {\n // 1. If request’s window is \"no-window\", then return a network error.\n if (request.window === 'no-window') {\n return makeNetworkError()\n }\n\n // 2. ???\n\n // 3. If fetchParams is canceled, then return the appropriate network error for fetchParams.\n if (isCancelled(fetchParams)) {\n return makeAppropriateNetworkError(fetchParams)\n }\n\n // 4. Prompt the end user as appropriate in request’s window and store\n // the result as a proxy-authentication entry. [HTTP-AUTH]\n // TODO: Invoke some kind of callback?\n\n // 5. Set response to the result of running HTTP-network-or-cache fetch given\n // fetchParams.\n // TODO\n return makeNetworkError('proxy authentication required')\n }\n\n // 16. If all of the following are true\n if (\n // response’s status is 421\n response.status === 421 &&\n // isNewConnectionFetch is false\n !isNewConnectionFetch &&\n // request’s body is null, or request’s body is non-null and request’s body’s source is non-null\n (request.body == null || request.body.source != null)\n ) {\n // then:\n\n // 1. If fetchParams is canceled, then return the appropriate network error for fetchParams.\n if (isCancelled(fetchParams)) {\n return makeAppropriateNetworkError(fetchParams)\n }\n\n // 2. Set response to the result of running HTTP-network-or-cache\n // fetch given fetchParams, isAuthenticationFetch, and true.\n\n // TODO (spec): The spec doesn't specify this but we need to cancel\n // the active response before we can start a new one.\n // https://github.com/whatwg/fetch/issues/1293\n fetchParams.controller.connection.destroy()\n\n response = await httpNetworkOrCacheFetch(\n fetchParams,\n isAuthenticationFetch,\n true\n )\n }\n\n // 17. If isAuthenticationFetch is true, then create an authentication entry\n if (isAuthenticationFetch) {\n // TODO\n }\n\n // 18. Return response.\n return response\n}\n\n// https://fetch.spec.whatwg.org/#http-network-fetch\nasync function httpNetworkFetch (\n fetchParams,\n includeCredentials = false,\n forceNewConnection = false\n) {\n assert(!fetchParams.controller.connection || fetchParams.controller.connection.destroyed)\n\n fetchParams.controller.connection = {\n abort: null,\n destroyed: false,\n destroy (err) {\n if (!this.destroyed) {\n this.destroyed = true\n this.abort?.(err ?? new DOMException('The operation was aborted.', 'AbortError'))\n }\n }\n }\n\n // 1. Let request be fetchParams’s request.\n const request = fetchParams.request\n\n // 2. Let response be null.\n let response = null\n\n // 3. Let timingInfo be fetchParams’s timing info.\n const timingInfo = fetchParams.timingInfo\n\n // 4. Let httpCache be the result of determining the HTTP cache partition,\n // given request.\n // TODO: cache\n const httpCache = null\n\n // 5. If httpCache is null, then set request’s cache mode to \"no-store\".\n if (httpCache == null) {\n request.cache = 'no-store'\n }\n\n // 6. Let networkPartitionKey be the result of determining the network\n // partition key given request.\n // TODO\n\n // 7. Let newConnection be \"yes\" if forceNewConnection is true; otherwise\n // \"no\".\n const newConnection = forceNewConnection ? 'yes' : 'no' // eslint-disable-line no-unused-vars\n\n // 8. Switch on request’s mode:\n if (request.mode === 'websocket') {\n // Let connection be the result of obtaining a WebSocket connection,\n // given request’s current URL.\n // TODO\n } else {\n // Let connection be the result of obtaining a connection, given\n // networkPartitionKey, request’s current URL’s origin,\n // includeCredentials, and forceNewConnection.\n // TODO\n }\n\n // 9. Run these steps, but abort when the ongoing fetch is terminated:\n\n // 1. If connection is failure, then return a network error.\n\n // 2. Set timingInfo’s final connection timing info to the result of\n // calling clamp and coarsen connection timing info with connection’s\n // timing info, timingInfo’s post-redirect start time, and fetchParams’s\n // cross-origin isolated capability.\n\n // 3. If connection is not an HTTP/2 connection, request’s body is non-null,\n // and request’s body’s source is null, then append (`Transfer-Encoding`,\n // `chunked`) to request’s header list.\n\n // 4. Set timingInfo’s final network-request start time to the coarsened\n // shared current time given fetchParams’s cross-origin isolated\n // capability.\n\n // 5. Set response to the result of making an HTTP request over connection\n // using request with the following caveats:\n\n // - Follow the relevant requirements from HTTP. [HTTP] [HTTP-SEMANTICS]\n // [HTTP-COND] [HTTP-CACHING] [HTTP-AUTH]\n\n // - If request’s body is non-null, and request’s body’s source is null,\n // then the user agent may have a buffer of up to 64 kibibytes and store\n // a part of request’s body in that buffer. If the user agent reads from\n // request’s body beyond that buffer’s size and the user agent needs to\n // resend request, then instead return a network error.\n\n // - Set timingInfo’s final network-response start time to the coarsened\n // shared current time given fetchParams’s cross-origin isolated capability,\n // immediately after the user agent’s HTTP parser receives the first byte\n // of the response (e.g., frame header bytes for HTTP/2 or response status\n // line for HTTP/1.x).\n\n // - Wait until all the headers are transmitted.\n\n // - Any responses whose status is in the range 100 to 199, inclusive,\n // and is not 101, are to be ignored, except for the purposes of setting\n // timingInfo’s final network-response start time above.\n\n // - If request’s header list contains `Transfer-Encoding`/`chunked` and\n // response is transferred via HTTP/1.0 or older, then return a network\n // error.\n\n // - If the HTTP request results in a TLS client certificate dialog, then:\n\n // 1. If request’s window is an environment settings object, make the\n // dialog available in request’s window.\n\n // 2. Otherwise, return a network error.\n\n // To transmit request’s body body, run these steps:\n let requestBody = null\n // 1. If body is null and fetchParams’s process request end-of-body is\n // non-null, then queue a fetch task given fetchParams’s process request\n // end-of-body and fetchParams’s task destination.\n if (request.body == null && fetchParams.processRequestEndOfBody) {\n queueMicrotask(() => fetchParams.processRequestEndOfBody())\n } else if (request.body != null) {\n // 2. Otherwise, if body is non-null:\n\n // 1. Let processBodyChunk given bytes be these steps:\n const processBodyChunk = async function * (bytes) {\n // 1. If the ongoing fetch is terminated, then abort these steps.\n if (isCancelled(fetchParams)) {\n return\n }\n\n // 2. Run this step in parallel: transmit bytes.\n yield bytes\n\n // 3. If fetchParams’s process request body is non-null, then run\n // fetchParams’s process request body given bytes’s length.\n fetchParams.processRequestBodyChunkLength?.(bytes.byteLength)\n }\n\n // 2. Let processEndOfBody be these steps:\n const processEndOfBody = () => {\n // 1. If fetchParams is canceled, then abort these steps.\n if (isCancelled(fetchParams)) {\n return\n }\n\n // 2. If fetchParams’s process request end-of-body is non-null,\n // then run fetchParams’s process request end-of-body.\n if (fetchParams.processRequestEndOfBody) {\n fetchParams.processRequestEndOfBody()\n }\n }\n\n // 3. Let processBodyError given e be these steps:\n const processBodyError = (e) => {\n // 1. If fetchParams is canceled, then abort these steps.\n if (isCancelled(fetchParams)) {\n return\n }\n\n // 2. If e is an \"AbortError\" DOMException, then abort fetchParams’s controller.\n if (e.name === 'AbortError') {\n fetchParams.controller.abort()\n } else {\n fetchParams.controller.terminate(e)\n }\n }\n\n // 4. Incrementally read request’s body given processBodyChunk, processEndOfBody,\n // processBodyError, and fetchParams’s task destination.\n requestBody = (async function * () {\n try {\n for await (const bytes of request.body.stream) {\n yield * processBodyChunk(bytes)\n }\n processEndOfBody()\n } catch (err) {\n processBodyError(err)\n }\n })()\n }\n\n try {\n // socket is only provided for websockets\n const { body, status, statusText, headersList, socket } = await dispatch({ body: requestBody })\n\n if (socket) {\n response = makeResponse({ status, statusText, headersList, socket })\n } else {\n const iterator = body[Symbol.asyncIterator]()\n fetchParams.controller.next = () => iterator.next()\n\n response = makeResponse({ status, statusText, headersList })\n }\n } catch (err) {\n // 10. If aborted, then:\n if (err.name === 'AbortError') {\n // 1. If connection uses HTTP/2, then transmit an RST_STREAM frame.\n fetchParams.controller.connection.destroy()\n\n // 2. Return the appropriate network error for fetchParams.\n return makeAppropriateNetworkError(fetchParams, err)\n }\n\n return makeNetworkError(err)\n }\n\n // 11. Let pullAlgorithm be an action that resumes the ongoing fetch\n // if it is suspended.\n const pullAlgorithm = () => {\n fetchParams.controller.resume()\n }\n\n // 12. Let cancelAlgorithm be an algorithm that aborts fetchParams’s\n // controller with reason, given reason.\n const cancelAlgorithm = (reason) => {\n fetchParams.controller.abort(reason)\n }\n\n // 13. Let highWaterMark be a non-negative, non-NaN number, chosen by\n // the user agent.\n // TODO\n\n // 14. Let sizeAlgorithm be an algorithm that accepts a chunk object\n // and returns a non-negative, non-NaN, non-infinite number, chosen by the user agent.\n // TODO\n\n // 15. Let stream be a new ReadableStream.\n // 16. Set up stream with pullAlgorithm set to pullAlgorithm,\n // cancelAlgorithm set to cancelAlgorithm, highWaterMark set to\n // highWaterMark, and sizeAlgorithm set to sizeAlgorithm.\n if (!ReadableStream) {\n ReadableStream = require('stream/web').ReadableStream\n }\n\n const stream = new ReadableStream(\n {\n async start (controller) {\n fetchParams.controller.controller = controller\n },\n async pull (controller) {\n await pullAlgorithm(controller)\n },\n async cancel (reason) {\n await cancelAlgorithm(reason)\n }\n },\n {\n highWaterMark: 0,\n size () {\n return 1\n }\n }\n )\n\n // 17. Run these steps, but abort when the ongoing fetch is terminated:\n\n // 1. Set response’s body to a new body whose stream is stream.\n response.body = { stream }\n\n // 2. If response is not a network error and request’s cache mode is\n // not \"no-store\", then update response in httpCache for request.\n // TODO\n\n // 3. If includeCredentials is true and the user agent is not configured\n // to block cookies for request (see section 7 of [COOKIES]), then run the\n // \"set-cookie-string\" parsing algorithm (see section 5.2 of [COOKIES]) on\n // the value of each header whose name is a byte-case-insensitive match for\n // `Set-Cookie` in response’s header list, if any, and request’s current URL.\n // TODO\n\n // 18. If aborted, then:\n // TODO\n\n // 19. Run these steps in parallel:\n\n // 1. Run these steps, but abort when fetchParams is canceled:\n fetchParams.controller.on('terminated', onAborted)\n fetchParams.controller.resume = async () => {\n // 1. While true\n while (true) {\n // 1-3. See onData...\n\n // 4. Set bytes to the result of handling content codings given\n // codings and bytes.\n let bytes\n let isFailure\n try {\n const { done, value } = await fetchParams.controller.next()\n\n if (isAborted(fetchParams)) {\n break\n }\n\n bytes = done ? undefined : value\n } catch (err) {\n if (fetchParams.controller.ended && !timingInfo.encodedBodySize) {\n // zlib doesn't like empty streams.\n bytes = undefined\n } else {\n bytes = err\n\n // err may be propagated from the result of calling readablestream.cancel,\n // which might not be an error. https://github.com/nodejs/undici/issues/2009\n isFailure = true\n }\n }\n\n if (bytes === undefined) {\n // 2. Otherwise, if the bytes transmission for response’s message\n // body is done normally and stream is readable, then close\n // stream, finalize response for fetchParams and response, and\n // abort these in-parallel steps.\n readableStreamClose(fetchParams.controller.controller)\n\n finalizeResponse(fetchParams, response)\n\n return\n }\n\n // 5. Increase timingInfo’s decoded body size by bytes’s length.\n timingInfo.decodedBodySize += bytes?.byteLength ?? 0\n\n // 6. If bytes is failure, then terminate fetchParams’s controller.\n if (isFailure) {\n fetchParams.controller.terminate(bytes)\n return\n }\n\n // 7. Enqueue a Uint8Array wrapping an ArrayBuffer containing bytes\n // into stream.\n fetchParams.controller.controller.enqueue(new Uint8Array(bytes))\n\n // 8. If stream is errored, then terminate the ongoing fetch.\n if (isErrored(stream)) {\n fetchParams.controller.terminate()\n return\n }\n\n // 9. If stream doesn’t need more data ask the user agent to suspend\n // the ongoing fetch.\n if (!fetchParams.controller.controller.desiredSize) {\n return\n }\n }\n }\n\n // 2. If aborted, then:\n function onAborted (reason) {\n // 2. If fetchParams is aborted, then:\n if (isAborted(fetchParams)) {\n // 1. Set response’s aborted flag.\n response.aborted = true\n\n // 2. If stream is readable, then error stream with the result of\n // deserialize a serialized abort reason given fetchParams’s\n // controller’s serialized abort reason and an\n // implementation-defined realm.\n if (isReadable(stream)) {\n fetchParams.controller.controller.error(\n fetchParams.controller.serializedAbortReason\n )\n }\n } else {\n // 3. Otherwise, if stream is readable, error stream with a TypeError.\n if (isReadable(stream)) {\n fetchParams.controller.controller.error(new TypeError('terminated', {\n cause: isErrorLike(reason) ? reason : undefined\n }))\n }\n }\n\n // 4. If connection uses HTTP/2, then transmit an RST_STREAM frame.\n // 5. Otherwise, the user agent should close connection unless it would be bad for performance to do so.\n fetchParams.controller.connection.destroy()\n }\n\n // 20. Return response.\n return response\n\n async function dispatch ({ body }) {\n const url = requestCurrentURL(request)\n /** @type {import('../..').Agent} */\n const agent = fetchParams.controller.dispatcher\n\n return new Promise((resolve, reject) => agent.dispatch(\n {\n path: url.pathname + url.search,\n origin: url.origin,\n method: request.method,\n body: fetchParams.controller.dispatcher.isMockActive ? request.body && (request.body.source || request.body.stream) : body,\n headers: request.headersList.entries,\n maxRedirections: 0,\n upgrade: request.mode === 'websocket' ? 'websocket' : undefined\n },\n {\n body: null,\n abort: null,\n\n onConnect (abort) {\n // TODO (fix): Do we need connection here?\n const { connection } = fetchParams.controller\n\n if (connection.destroyed) {\n abort(new DOMException('The operation was aborted.', 'AbortError'))\n } else {\n fetchParams.controller.on('terminated', abort)\n this.abort = connection.abort = abort\n }\n },\n\n onHeaders (status, headersList, resume, statusText) {\n if (status < 200) {\n return\n }\n\n let codings = []\n let location = ''\n\n const headers = new Headers()\n\n // For H2, the headers are a plain JS object\n // We distinguish between them and iterate accordingly\n if (Array.isArray(headersList)) {\n for (let n = 0; n < headersList.length; n += 2) {\n const key = headersList[n + 0].toString('latin1')\n const val = headersList[n + 1].toString('latin1')\n if (key.toLowerCase() === 'content-encoding') {\n // https://www.rfc-editor.org/rfc/rfc7231#section-3.1.2.1\n // \"All content-coding values are case-insensitive...\"\n codings = val.toLowerCase().split(',').map((x) => x.trim())\n } else if (key.toLowerCase() === 'location') {\n location = val\n }\n\n headers[kHeadersList].append(key, val)\n }\n } else {\n const keys = Object.keys(headersList)\n for (const key of keys) {\n const val = headersList[key]\n if (key.toLowerCase() === 'content-encoding') {\n // https://www.rfc-editor.org/rfc/rfc7231#section-3.1.2.1\n // \"All content-coding values are case-insensitive...\"\n codings = val.toLowerCase().split(',').map((x) => x.trim()).reverse()\n } else if (key.toLowerCase() === 'location') {\n location = val\n }\n\n headers[kHeadersList].append(key, val)\n }\n }\n\n this.body = new Readable({ read: resume })\n\n const decoders = []\n\n const willFollow = request.redirect === 'follow' &&\n location &&\n redirectStatusSet.has(status)\n\n // https://developer.mozilla.org/en-US/docs/Web/HTTP/Headers/Content-Encoding\n if (request.method !== 'HEAD' && request.method !== 'CONNECT' && !nullBodyStatus.includes(status) && !willFollow) {\n for (const coding of codings) {\n // https://www.rfc-editor.org/rfc/rfc9112.html#section-7.2\n if (coding === 'x-gzip' || coding === 'gzip') {\n decoders.push(zlib.createGunzip({\n // Be less strict when decoding compressed responses, since sometimes\n // servers send slightly invalid responses that are still accepted\n // by common browsers.\n // Always using Z_SYNC_FLUSH is what cURL does.\n flush: zlib.constants.Z_SYNC_FLUSH,\n finishFlush: zlib.constants.Z_SYNC_FLUSH\n }))\n } else if (coding === 'deflate') {\n decoders.push(zlib.createInflate())\n } else if (coding === 'br') {\n decoders.push(zlib.createBrotliDecompress())\n } else {\n decoders.length = 0\n break\n }\n }\n }\n\n resolve({\n status,\n statusText,\n headersList: headers[kHeadersList],\n body: decoders.length\n ? pipeline(this.body, ...decoders, () => { })\n : this.body.on('error', () => {})\n })\n\n return true\n },\n\n onData (chunk) {\n if (fetchParams.controller.dump) {\n return\n }\n\n // 1. If one or more bytes have been transmitted from response’s\n // message body, then:\n\n // 1. Let bytes be the transmitted bytes.\n const bytes = chunk\n\n // 2. Let codings be the result of extracting header list values\n // given `Content-Encoding` and response’s header list.\n // See pullAlgorithm.\n\n // 3. Increase timingInfo’s encoded body size by bytes’s length.\n timingInfo.encodedBodySize += bytes.byteLength\n\n // 4. See pullAlgorithm...\n\n return this.body.push(bytes)\n },\n\n onComplete () {\n if (this.abort) {\n fetchParams.controller.off('terminated', this.abort)\n }\n\n fetchParams.controller.ended = true\n\n this.body.push(null)\n },\n\n onError (error) {\n if (this.abort) {\n fetchParams.controller.off('terminated', this.abort)\n }\n\n this.body?.destroy(error)\n\n fetchParams.controller.terminate(error)\n\n reject(error)\n },\n\n onUpgrade (status, headersList, socket) {\n if (status !== 101) {\n return\n }\n\n const headers = new Headers()\n\n for (let n = 0; n < headersList.length; n += 2) {\n const key = headersList[n + 0].toString('latin1')\n const val = headersList[n + 1].toString('latin1')\n\n headers[kHeadersList].append(key, val)\n }\n\n resolve({\n status,\n statusText: STATUS_CODES[status],\n headersList: headers[kHeadersList],\n socket\n })\n\n return true\n }\n }\n ))\n }\n}\n\nmodule.exports = {\n fetch,\n Fetch,\n fetching,\n finalizeAndReportTiming\n}\n","/* globals AbortController */\n\n'use strict'\n\nconst { extractBody, mixinBody, cloneBody } = require('./body')\nconst { Headers, fill: fillHeaders, HeadersList } = require('./headers')\nconst { FinalizationRegistry } = require('../compat/dispatcher-weakref')()\nconst util = require('../core/util')\nconst {\n isValidHTTPToken,\n sameOrigin,\n normalizeMethod,\n makePolicyContainer,\n normalizeMethodRecord\n} = require('./util')\nconst {\n forbiddenMethodsSet,\n corsSafeListedMethodsSet,\n referrerPolicy,\n requestRedirect,\n requestMode,\n requestCredentials,\n requestCache,\n requestDuplex\n} = require('./constants')\nconst { kEnumerableProperty } = util\nconst { kHeaders, kSignal, kState, kGuard, kRealm } = require('./symbols')\nconst { webidl } = require('./webidl')\nconst { getGlobalOrigin } = require('./global')\nconst { URLSerializer } = require('./dataURL')\nconst { kHeadersList, kConstruct } = require('../core/symbols')\nconst assert = require('assert')\nconst { getMaxListeners, setMaxListeners, getEventListeners, defaultMaxListeners } = require('events')\n\nlet TransformStream = globalThis.TransformStream\n\nconst kAbortController = Symbol('abortController')\n\nconst requestFinalizer = new FinalizationRegistry(({ signal, abort }) => {\n signal.removeEventListener('abort', abort)\n})\n\n// https://fetch.spec.whatwg.org/#request-class\nclass Request {\n // https://fetch.spec.whatwg.org/#dom-request\n constructor (input, init = {}) {\n if (input === kConstruct) {\n return\n }\n\n webidl.argumentLengthCheck(arguments, 1, { header: 'Request constructor' })\n\n input = webidl.converters.RequestInfo(input)\n init = webidl.converters.RequestInit(init)\n\n // https://html.spec.whatwg.org/multipage/webappapis.html#environment-settings-object\n this[kRealm] = {\n settingsObject: {\n baseUrl: getGlobalOrigin(),\n get origin () {\n return this.baseUrl?.origin\n },\n policyContainer: makePolicyContainer()\n }\n }\n\n // 1. Let request be null.\n let request = null\n\n // 2. Let fallbackMode be null.\n let fallbackMode = null\n\n // 3. Let baseURL be this’s relevant settings object’s API base URL.\n const baseUrl = this[kRealm].settingsObject.baseUrl\n\n // 4. Let signal be null.\n let signal = null\n\n // 5. If input is a string, then:\n if (typeof input === 'string') {\n // 1. Let parsedURL be the result of parsing input with baseURL.\n // 2. If parsedURL is failure, then throw a TypeError.\n let parsedURL\n try {\n parsedURL = new URL(input, baseUrl)\n } catch (err) {\n throw new TypeError('Failed to parse URL from ' + input, { cause: err })\n }\n\n // 3. If parsedURL includes credentials, then throw a TypeError.\n if (parsedURL.username || parsedURL.password) {\n throw new TypeError(\n 'Request cannot be constructed from a URL that includes credentials: ' +\n input\n )\n }\n\n // 4. Set request to a new request whose URL is parsedURL.\n request = makeRequest({ urlList: [parsedURL] })\n\n // 5. Set fallbackMode to \"cors\".\n fallbackMode = 'cors'\n } else {\n // 6. Otherwise:\n\n // 7. Assert: input is a Request object.\n assert(input instanceof Request)\n\n // 8. Set request to input’s request.\n request = input[kState]\n\n // 9. Set signal to input’s signal.\n signal = input[kSignal]\n }\n\n // 7. Let origin be this’s relevant settings object’s origin.\n const origin = this[kRealm].settingsObject.origin\n\n // 8. Let window be \"client\".\n let window = 'client'\n\n // 9. If request’s window is an environment settings object and its origin\n // is same origin with origin, then set window to request’s window.\n if (\n request.window?.constructor?.name === 'EnvironmentSettingsObject' &&\n sameOrigin(request.window, origin)\n ) {\n window = request.window\n }\n\n // 10. If init[\"window\"] exists and is non-null, then throw a TypeError.\n if (init.window != null) {\n throw new TypeError(`'window' option '${window}' must be null`)\n }\n\n // 11. If init[\"window\"] exists, then set window to \"no-window\".\n if ('window' in init) {\n window = 'no-window'\n }\n\n // 12. Set request to a new request with the following properties:\n request = makeRequest({\n // URL request’s URL.\n // undici implementation note: this is set as the first item in request's urlList in makeRequest\n // method request’s method.\n method: request.method,\n // header list A copy of request’s header list.\n // undici implementation note: headersList is cloned in makeRequest\n headersList: request.headersList,\n // unsafe-request flag Set.\n unsafeRequest: request.unsafeRequest,\n // client This’s relevant settings object.\n client: this[kRealm].settingsObject,\n // window window.\n window,\n // priority request’s priority.\n priority: request.priority,\n // origin request’s origin. The propagation of the origin is only significant for navigation requests\n // being handled by a service worker. In this scenario a request can have an origin that is different\n // from the current client.\n origin: request.origin,\n // referrer request’s referrer.\n referrer: request.referrer,\n // referrer policy request’s referrer policy.\n referrerPolicy: request.referrerPolicy,\n // mode request’s mode.\n mode: request.mode,\n // credentials mode request’s credentials mode.\n credentials: request.credentials,\n // cache mode request’s cache mode.\n cache: request.cache,\n // redirect mode request’s redirect mode.\n redirect: request.redirect,\n // integrity metadata request’s integrity metadata.\n integrity: request.integrity,\n // keepalive request’s keepalive.\n keepalive: request.keepalive,\n // reload-navigation flag request’s reload-navigation flag.\n reloadNavigation: request.reloadNavigation,\n // history-navigation flag request’s history-navigation flag.\n historyNavigation: request.historyNavigation,\n // URL list A clone of request’s URL list.\n urlList: [...request.urlList]\n })\n\n const initHasKey = Object.keys(init).length !== 0\n\n // 13. If init is not empty, then:\n if (initHasKey) {\n // 1. If request’s mode is \"navigate\", then set it to \"same-origin\".\n if (request.mode === 'navigate') {\n request.mode = 'same-origin'\n }\n\n // 2. Unset request’s reload-navigation flag.\n request.reloadNavigation = false\n\n // 3. Unset request’s history-navigation flag.\n request.historyNavigation = false\n\n // 4. Set request’s origin to \"client\".\n request.origin = 'client'\n\n // 5. Set request’s referrer to \"client\"\n request.referrer = 'client'\n\n // 6. Set request’s referrer policy to the empty string.\n request.referrerPolicy = ''\n\n // 7. Set request’s URL to request’s current URL.\n request.url = request.urlList[request.urlList.length - 1]\n\n // 8. Set request’s URL list to « request’s URL ».\n request.urlList = [request.url]\n }\n\n // 14. If init[\"referrer\"] exists, then:\n if (init.referrer !== undefined) {\n // 1. Let referrer be init[\"referrer\"].\n const referrer = init.referrer\n\n // 2. If referrer is the empty string, then set request’s referrer to \"no-referrer\".\n if (referrer === '') {\n request.referrer = 'no-referrer'\n } else {\n // 1. Let parsedReferrer be the result of parsing referrer with\n // baseURL.\n // 2. If parsedReferrer is failure, then throw a TypeError.\n let parsedReferrer\n try {\n parsedReferrer = new URL(referrer, baseUrl)\n } catch (err) {\n throw new TypeError(`Referrer \"${referrer}\" is not a valid URL.`, { cause: err })\n }\n\n // 3. If one of the following is true\n // - parsedReferrer’s scheme is \"about\" and path is the string \"client\"\n // - parsedReferrer’s origin is not same origin with origin\n // then set request’s referrer to \"client\".\n if (\n (parsedReferrer.protocol === 'about:' && parsedReferrer.hostname === 'client') ||\n (origin && !sameOrigin(parsedReferrer, this[kRealm].settingsObject.baseUrl))\n ) {\n request.referrer = 'client'\n } else {\n // 4. Otherwise, set request’s referrer to parsedReferrer.\n request.referrer = parsedReferrer\n }\n }\n }\n\n // 15. If init[\"referrerPolicy\"] exists, then set request’s referrer policy\n // to it.\n if (init.referrerPolicy !== undefined) {\n request.referrerPolicy = init.referrerPolicy\n }\n\n // 16. Let mode be init[\"mode\"] if it exists, and fallbackMode otherwise.\n let mode\n if (init.mode !== undefined) {\n mode = init.mode\n } else {\n mode = fallbackMode\n }\n\n // 17. If mode is \"navigate\", then throw a TypeError.\n if (mode === 'navigate') {\n throw webidl.errors.exception({\n header: 'Request constructor',\n message: 'invalid request mode navigate.'\n })\n }\n\n // 18. If mode is non-null, set request’s mode to mode.\n if (mode != null) {\n request.mode = mode\n }\n\n // 19. If init[\"credentials\"] exists, then set request’s credentials mode\n // to it.\n if (init.credentials !== undefined) {\n request.credentials = init.credentials\n }\n\n // 18. If init[\"cache\"] exists, then set request’s cache mode to it.\n if (init.cache !== undefined) {\n request.cache = init.cache\n }\n\n // 21. If request’s cache mode is \"only-if-cached\" and request’s mode is\n // not \"same-origin\", then throw a TypeError.\n if (request.cache === 'only-if-cached' && request.mode !== 'same-origin') {\n throw new TypeError(\n \"'only-if-cached' can be set only with 'same-origin' mode\"\n )\n }\n\n // 22. If init[\"redirect\"] exists, then set request’s redirect mode to it.\n if (init.redirect !== undefined) {\n request.redirect = init.redirect\n }\n\n // 23. If init[\"integrity\"] exists, then set request’s integrity metadata to it.\n if (init.integrity != null) {\n request.integrity = String(init.integrity)\n }\n\n // 24. If init[\"keepalive\"] exists, then set request’s keepalive to it.\n if (init.keepalive !== undefined) {\n request.keepalive = Boolean(init.keepalive)\n }\n\n // 25. If init[\"method\"] exists, then:\n if (init.method !== undefined) {\n // 1. Let method be init[\"method\"].\n let method = init.method\n\n // 2. If method is not a method or method is a forbidden method, then\n // throw a TypeError.\n if (!isValidHTTPToken(method)) {\n throw new TypeError(`'${method}' is not a valid HTTP method.`)\n }\n\n if (forbiddenMethodsSet.has(method.toUpperCase())) {\n throw new TypeError(`'${method}' HTTP method is unsupported.`)\n }\n\n // 3. Normalize method.\n method = normalizeMethodRecord[method] ?? normalizeMethod(method)\n\n // 4. Set request’s method to method.\n request.method = method\n }\n\n // 26. If init[\"signal\"] exists, then set signal to it.\n if (init.signal !== undefined) {\n signal = init.signal\n }\n\n // 27. Set this’s request to request.\n this[kState] = request\n\n // 28. Set this’s signal to a new AbortSignal object with this’s relevant\n // Realm.\n // TODO: could this be simplified with AbortSignal.any\n // (https://dom.spec.whatwg.org/#dom-abortsignal-any)\n const ac = new AbortController()\n this[kSignal] = ac.signal\n this[kSignal][kRealm] = this[kRealm]\n\n // 29. If signal is not null, then make this’s signal follow signal.\n if (signal != null) {\n if (\n !signal ||\n typeof signal.aborted !== 'boolean' ||\n typeof signal.addEventListener !== 'function'\n ) {\n throw new TypeError(\n \"Failed to construct 'Request': member signal is not of type AbortSignal.\"\n )\n }\n\n if (signal.aborted) {\n ac.abort(signal.reason)\n } else {\n // Keep a strong ref to ac while request object\n // is alive. This is needed to prevent AbortController\n // from being prematurely garbage collected.\n // See, https://github.com/nodejs/undici/issues/1926.\n this[kAbortController] = ac\n\n const acRef = new WeakRef(ac)\n const abort = function () {\n const ac = acRef.deref()\n if (ac !== undefined) {\n ac.abort(this.reason)\n }\n }\n\n // Third-party AbortControllers may not work with these.\n // See, https://github.com/nodejs/undici/pull/1910#issuecomment-1464495619.\n try {\n // If the max amount of listeners is equal to the default, increase it\n // This is only available in node >= v19.9.0\n if (typeof getMaxListeners === 'function' && getMaxListeners(signal) === defaultMaxListeners) {\n setMaxListeners(100, signal)\n } else if (getEventListeners(signal, 'abort').length >= defaultMaxListeners) {\n setMaxListeners(100, signal)\n }\n } catch {}\n\n util.addAbortListener(signal, abort)\n requestFinalizer.register(ac, { signal, abort })\n }\n }\n\n // 30. Set this’s headers to a new Headers object with this’s relevant\n // Realm, whose header list is request’s header list and guard is\n // \"request\".\n this[kHeaders] = new Headers(kConstruct)\n this[kHeaders][kHeadersList] = request.headersList\n this[kHeaders][kGuard] = 'request'\n this[kHeaders][kRealm] = this[kRealm]\n\n // 31. If this’s request’s mode is \"no-cors\", then:\n if (mode === 'no-cors') {\n // 1. If this’s request’s method is not a CORS-safelisted method,\n // then throw a TypeError.\n if (!corsSafeListedMethodsSet.has(request.method)) {\n throw new TypeError(\n `'${request.method} is unsupported in no-cors mode.`\n )\n }\n\n // 2. Set this’s headers’s guard to \"request-no-cors\".\n this[kHeaders][kGuard] = 'request-no-cors'\n }\n\n // 32. If init is not empty, then:\n if (initHasKey) {\n /** @type {HeadersList} */\n const headersList = this[kHeaders][kHeadersList]\n // 1. Let headers be a copy of this’s headers and its associated header\n // list.\n // 2. If init[\"headers\"] exists, then set headers to init[\"headers\"].\n const headers = init.headers !== undefined ? init.headers : new HeadersList(headersList)\n\n // 3. Empty this’s headers’s header list.\n headersList.clear()\n\n // 4. If headers is a Headers object, then for each header in its header\n // list, append header’s name/header’s value to this’s headers.\n if (headers instanceof HeadersList) {\n for (const [key, val] of headers) {\n headersList.append(key, val)\n }\n // Note: Copy the `set-cookie` meta-data.\n headersList.cookies = headers.cookies\n } else {\n // 5. Otherwise, fill this’s headers with headers.\n fillHeaders(this[kHeaders], headers)\n }\n }\n\n // 33. Let inputBody be input’s request’s body if input is a Request\n // object; otherwise null.\n const inputBody = input instanceof Request ? input[kState].body : null\n\n // 34. If either init[\"body\"] exists and is non-null or inputBody is\n // non-null, and request’s method is `GET` or `HEAD`, then throw a\n // TypeError.\n if (\n (init.body != null || inputBody != null) &&\n (request.method === 'GET' || request.method === 'HEAD')\n ) {\n throw new TypeError('Request with GET/HEAD method cannot have body.')\n }\n\n // 35. Let initBody be null.\n let initBody = null\n\n // 36. If init[\"body\"] exists and is non-null, then:\n if (init.body != null) {\n // 1. Let Content-Type be null.\n // 2. Set initBody and Content-Type to the result of extracting\n // init[\"body\"], with keepalive set to request’s keepalive.\n const [extractedBody, contentType] = extractBody(\n init.body,\n request.keepalive\n )\n initBody = extractedBody\n\n // 3, If Content-Type is non-null and this’s headers’s header list does\n // not contain `Content-Type`, then append `Content-Type`/Content-Type to\n // this’s headers.\n if (contentType && !this[kHeaders][kHeadersList].contains('content-type')) {\n this[kHeaders].append('content-type', contentType)\n }\n }\n\n // 37. Let inputOrInitBody be initBody if it is non-null; otherwise\n // inputBody.\n const inputOrInitBody = initBody ?? inputBody\n\n // 38. If inputOrInitBody is non-null and inputOrInitBody’s source is\n // null, then:\n if (inputOrInitBody != null && inputOrInitBody.source == null) {\n // 1. If initBody is non-null and init[\"duplex\"] does not exist,\n // then throw a TypeError.\n if (initBody != null && init.duplex == null) {\n throw new TypeError('RequestInit: duplex option is required when sending a body.')\n }\n\n // 2. If this’s request’s mode is neither \"same-origin\" nor \"cors\",\n // then throw a TypeError.\n if (request.mode !== 'same-origin' && request.mode !== 'cors') {\n throw new TypeError(\n 'If request is made from ReadableStream, mode should be \"same-origin\" or \"cors\"'\n )\n }\n\n // 3. Set this’s request’s use-CORS-preflight flag.\n request.useCORSPreflightFlag = true\n }\n\n // 39. Let finalBody be inputOrInitBody.\n let finalBody = inputOrInitBody\n\n // 40. If initBody is null and inputBody is non-null, then:\n if (initBody == null && inputBody != null) {\n // 1. If input is unusable, then throw a TypeError.\n if (util.isDisturbed(inputBody.stream) || inputBody.stream.locked) {\n throw new TypeError(\n 'Cannot construct a Request with a Request object that has already been used.'\n )\n }\n\n // 2. Set finalBody to the result of creating a proxy for inputBody.\n if (!TransformStream) {\n TransformStream = require('stream/web').TransformStream\n }\n\n // https://streams.spec.whatwg.org/#readablestream-create-a-proxy\n const identityTransform = new TransformStream()\n inputBody.stream.pipeThrough(identityTransform)\n finalBody = {\n source: inputBody.source,\n length: inputBody.length,\n stream: identityTransform.readable\n }\n }\n\n // 41. Set this’s request’s body to finalBody.\n this[kState].body = finalBody\n }\n\n // Returns request’s HTTP method, which is \"GET\" by default.\n get method () {\n webidl.brandCheck(this, Request)\n\n // The method getter steps are to return this’s request’s method.\n return this[kState].method\n }\n\n // Returns the URL of request as a string.\n get url () {\n webidl.brandCheck(this, Request)\n\n // The url getter steps are to return this’s request’s URL, serialized.\n return URLSerializer(this[kState].url)\n }\n\n // Returns a Headers object consisting of the headers associated with request.\n // Note that headers added in the network layer by the user agent will not\n // be accounted for in this object, e.g., the \"Host\" header.\n get headers () {\n webidl.brandCheck(this, Request)\n\n // The headers getter steps are to return this’s headers.\n return this[kHeaders]\n }\n\n // Returns the kind of resource requested by request, e.g., \"document\"\n // or \"script\".\n get destination () {\n webidl.brandCheck(this, Request)\n\n // The destination getter are to return this’s request’s destination.\n return this[kState].destination\n }\n\n // Returns the referrer of request. Its value can be a same-origin URL if\n // explicitly set in init, the empty string to indicate no referrer, and\n // \"about:client\" when defaulting to the global’s default. This is used\n // during fetching to determine the value of the `Referer` header of the\n // request being made.\n get referrer () {\n webidl.brandCheck(this, Request)\n\n // 1. If this’s request’s referrer is \"no-referrer\", then return the\n // empty string.\n if (this[kState].referrer === 'no-referrer') {\n return ''\n }\n\n // 2. If this’s request’s referrer is \"client\", then return\n // \"about:client\".\n if (this[kState].referrer === 'client') {\n return 'about:client'\n }\n\n // Return this’s request’s referrer, serialized.\n return this[kState].referrer.toString()\n }\n\n // Returns the referrer policy associated with request.\n // This is used during fetching to compute the value of the request’s\n // referrer.\n get referrerPolicy () {\n webidl.brandCheck(this, Request)\n\n // The referrerPolicy getter steps are to return this’s request’s referrer policy.\n return this[kState].referrerPolicy\n }\n\n // Returns the mode associated with request, which is a string indicating\n // whether the request will use CORS, or will be restricted to same-origin\n // URLs.\n get mode () {\n webidl.brandCheck(this, Request)\n\n // The mode getter steps are to return this’s request’s mode.\n return this[kState].mode\n }\n\n // Returns the credentials mode associated with request,\n // which is a string indicating whether credentials will be sent with the\n // request always, never, or only when sent to a same-origin URL.\n get credentials () {\n // The credentials getter steps are to return this’s request’s credentials mode.\n return this[kState].credentials\n }\n\n // Returns the cache mode associated with request,\n // which is a string indicating how the request will\n // interact with the browser’s cache when fetching.\n get cache () {\n webidl.brandCheck(this, Request)\n\n // The cache getter steps are to return this’s request’s cache mode.\n return this[kState].cache\n }\n\n // Returns the redirect mode associated with request,\n // which is a string indicating how redirects for the\n // request will be handled during fetching. A request\n // will follow redirects by default.\n get redirect () {\n webidl.brandCheck(this, Request)\n\n // The redirect getter steps are to return this’s request’s redirect mode.\n return this[kState].redirect\n }\n\n // Returns request’s subresource integrity metadata, which is a\n // cryptographic hash of the resource being fetched. Its value\n // consists of multiple hashes separated by whitespace. [SRI]\n get integrity () {\n webidl.brandCheck(this, Request)\n\n // The integrity getter steps are to return this’s request’s integrity\n // metadata.\n return this[kState].integrity\n }\n\n // Returns a boolean indicating whether or not request can outlive the\n // global in which it was created.\n get keepalive () {\n webidl.brandCheck(this, Request)\n\n // The keepalive getter steps are to return this’s request’s keepalive.\n return this[kState].keepalive\n }\n\n // Returns a boolean indicating whether or not request is for a reload\n // navigation.\n get isReloadNavigation () {\n webidl.brandCheck(this, Request)\n\n // The isReloadNavigation getter steps are to return true if this’s\n // request’s reload-navigation flag is set; otherwise false.\n return this[kState].reloadNavigation\n }\n\n // Returns a boolean indicating whether or not request is for a history\n // navigation (a.k.a. back-foward navigation).\n get isHistoryNavigation () {\n webidl.brandCheck(this, Request)\n\n // The isHistoryNavigation getter steps are to return true if this’s request’s\n // history-navigation flag is set; otherwise false.\n return this[kState].historyNavigation\n }\n\n // Returns the signal associated with request, which is an AbortSignal\n // object indicating whether or not request has been aborted, and its\n // abort event handler.\n get signal () {\n webidl.brandCheck(this, Request)\n\n // The signal getter steps are to return this’s signal.\n return this[kSignal]\n }\n\n get body () {\n webidl.brandCheck(this, Request)\n\n return this[kState].body ? this[kState].body.stream : null\n }\n\n get bodyUsed () {\n webidl.brandCheck(this, Request)\n\n return !!this[kState].body && util.isDisturbed(this[kState].body.stream)\n }\n\n get duplex () {\n webidl.brandCheck(this, Request)\n\n return 'half'\n }\n\n // Returns a clone of request.\n clone () {\n webidl.brandCheck(this, Request)\n\n // 1. If this is unusable, then throw a TypeError.\n if (this.bodyUsed || this.body?.locked) {\n throw new TypeError('unusable')\n }\n\n // 2. Let clonedRequest be the result of cloning this’s request.\n const clonedRequest = cloneRequest(this[kState])\n\n // 3. Let clonedRequestObject be the result of creating a Request object,\n // given clonedRequest, this’s headers’s guard, and this’s relevant Realm.\n const clonedRequestObject = new Request(kConstruct)\n clonedRequestObject[kState] = clonedRequest\n clonedRequestObject[kRealm] = this[kRealm]\n clonedRequestObject[kHeaders] = new Headers(kConstruct)\n clonedRequestObject[kHeaders][kHeadersList] = clonedRequest.headersList\n clonedRequestObject[kHeaders][kGuard] = this[kHeaders][kGuard]\n clonedRequestObject[kHeaders][kRealm] = this[kHeaders][kRealm]\n\n // 4. Make clonedRequestObject’s signal follow this’s signal.\n const ac = new AbortController()\n if (this.signal.aborted) {\n ac.abort(this.signal.reason)\n } else {\n util.addAbortListener(\n this.signal,\n () => {\n ac.abort(this.signal.reason)\n }\n )\n }\n clonedRequestObject[kSignal] = ac.signal\n\n // 4. Return clonedRequestObject.\n return clonedRequestObject\n }\n}\n\nmixinBody(Request)\n\nfunction makeRequest (init) {\n // https://fetch.spec.whatwg.org/#requests\n const request = {\n method: 'GET',\n localURLsOnly: false,\n unsafeRequest: false,\n body: null,\n client: null,\n reservedClient: null,\n replacesClientId: '',\n window: 'client',\n keepalive: false,\n serviceWorkers: 'all',\n initiator: '',\n destination: '',\n priority: null,\n origin: 'client',\n policyContainer: 'client',\n referrer: 'client',\n referrerPolicy: '',\n mode: 'no-cors',\n useCORSPreflightFlag: false,\n credentials: 'same-origin',\n useCredentials: false,\n cache: 'default',\n redirect: 'follow',\n integrity: '',\n cryptoGraphicsNonceMetadata: '',\n parserMetadata: '',\n reloadNavigation: false,\n historyNavigation: false,\n userActivation: false,\n taintedOrigin: false,\n redirectCount: 0,\n responseTainting: 'basic',\n preventNoCacheCacheControlHeaderModification: false,\n done: false,\n timingAllowFailed: false,\n ...init,\n headersList: init.headersList\n ? new HeadersList(init.headersList)\n : new HeadersList()\n }\n request.url = request.urlList[0]\n return request\n}\n\n// https://fetch.spec.whatwg.org/#concept-request-clone\nfunction cloneRequest (request) {\n // To clone a request request, run these steps:\n\n // 1. Let newRequest be a copy of request, except for its body.\n const newRequest = makeRequest({ ...request, body: null })\n\n // 2. If request’s body is non-null, set newRequest’s body to the\n // result of cloning request’s body.\n if (request.body != null) {\n newRequest.body = cloneBody(request.body)\n }\n\n // 3. Return newRequest.\n return newRequest\n}\n\nObject.defineProperties(Request.prototype, {\n method: kEnumerableProperty,\n url: kEnumerableProperty,\n headers: kEnumerableProperty,\n redirect: kEnumerableProperty,\n clone: kEnumerableProperty,\n signal: kEnumerableProperty,\n duplex: kEnumerableProperty,\n destination: kEnumerableProperty,\n body: kEnumerableProperty,\n bodyUsed: kEnumerableProperty,\n isHistoryNavigation: kEnumerableProperty,\n isReloadNavigation: kEnumerableProperty,\n keepalive: kEnumerableProperty,\n integrity: kEnumerableProperty,\n cache: kEnumerableProperty,\n credentials: kEnumerableProperty,\n attribute: kEnumerableProperty,\n referrerPolicy: kEnumerableProperty,\n referrer: kEnumerableProperty,\n mode: kEnumerableProperty,\n [Symbol.toStringTag]: {\n value: 'Request',\n configurable: true\n }\n})\n\nwebidl.converters.Request = webidl.interfaceConverter(\n Request\n)\n\n// https://fetch.spec.whatwg.org/#requestinfo\nwebidl.converters.RequestInfo = function (V) {\n if (typeof V === 'string') {\n return webidl.converters.USVString(V)\n }\n\n if (V instanceof Request) {\n return webidl.converters.Request(V)\n }\n\n return webidl.converters.USVString(V)\n}\n\nwebidl.converters.AbortSignal = webidl.interfaceConverter(\n AbortSignal\n)\n\n// https://fetch.spec.whatwg.org/#requestinit\nwebidl.converters.RequestInit = webidl.dictionaryConverter([\n {\n key: 'method',\n converter: webidl.converters.ByteString\n },\n {\n key: 'headers',\n converter: webidl.converters.HeadersInit\n },\n {\n key: 'body',\n converter: webidl.nullableConverter(\n webidl.converters.BodyInit\n )\n },\n {\n key: 'referrer',\n converter: webidl.converters.USVString\n },\n {\n key: 'referrerPolicy',\n converter: webidl.converters.DOMString,\n // https://w3c.github.io/webappsec-referrer-policy/#referrer-policy\n allowedValues: referrerPolicy\n },\n {\n key: 'mode',\n converter: webidl.converters.DOMString,\n // https://fetch.spec.whatwg.org/#concept-request-mode\n allowedValues: requestMode\n },\n {\n key: 'credentials',\n converter: webidl.converters.DOMString,\n // https://fetch.spec.whatwg.org/#requestcredentials\n allowedValues: requestCredentials\n },\n {\n key: 'cache',\n converter: webidl.converters.DOMString,\n // https://fetch.spec.whatwg.org/#requestcache\n allowedValues: requestCache\n },\n {\n key: 'redirect',\n converter: webidl.converters.DOMString,\n // https://fetch.spec.whatwg.org/#requestredirect\n allowedValues: requestRedirect\n },\n {\n key: 'integrity',\n converter: webidl.converters.DOMString\n },\n {\n key: 'keepalive',\n converter: webidl.converters.boolean\n },\n {\n key: 'signal',\n converter: webidl.nullableConverter(\n (signal) => webidl.converters.AbortSignal(\n signal,\n { strict: false }\n )\n )\n },\n {\n key: 'window',\n converter: webidl.converters.any\n },\n {\n key: 'duplex',\n converter: webidl.converters.DOMString,\n allowedValues: requestDuplex\n }\n])\n\nmodule.exports = { Request, makeRequest }\n","'use strict'\n\nconst { Headers, HeadersList, fill } = require('./headers')\nconst { extractBody, cloneBody, mixinBody } = require('./body')\nconst util = require('../core/util')\nconst { kEnumerableProperty } = util\nconst {\n isValidReasonPhrase,\n isCancelled,\n isAborted,\n isBlobLike,\n serializeJavascriptValueToJSONString,\n isErrorLike,\n isomorphicEncode\n} = require('./util')\nconst {\n redirectStatusSet,\n nullBodyStatus,\n DOMException\n} = require('./constants')\nconst { kState, kHeaders, kGuard, kRealm } = require('./symbols')\nconst { webidl } = require('./webidl')\nconst { FormData } = require('./formdata')\nconst { getGlobalOrigin } = require('./global')\nconst { URLSerializer } = require('./dataURL')\nconst { kHeadersList, kConstruct } = require('../core/symbols')\nconst assert = require('assert')\nconst { types } = require('util')\n\nconst ReadableStream = globalThis.ReadableStream || require('stream/web').ReadableStream\nconst textEncoder = new TextEncoder('utf-8')\n\n// https://fetch.spec.whatwg.org/#response-class\nclass Response {\n // Creates network error Response.\n static error () {\n // TODO\n const relevantRealm = { settingsObject: {} }\n\n // The static error() method steps are to return the result of creating a\n // Response object, given a new network error, \"immutable\", and this’s\n // relevant Realm.\n const responseObject = new Response()\n responseObject[kState] = makeNetworkError()\n responseObject[kRealm] = relevantRealm\n responseObject[kHeaders][kHeadersList] = responseObject[kState].headersList\n responseObject[kHeaders][kGuard] = 'immutable'\n responseObject[kHeaders][kRealm] = relevantRealm\n return responseObject\n }\n\n // https://fetch.spec.whatwg.org/#dom-response-json\n static json (data, init = {}) {\n webidl.argumentLengthCheck(arguments, 1, { header: 'Response.json' })\n\n if (init !== null) {\n init = webidl.converters.ResponseInit(init)\n }\n\n // 1. Let bytes the result of running serialize a JavaScript value to JSON bytes on data.\n const bytes = textEncoder.encode(\n serializeJavascriptValueToJSONString(data)\n )\n\n // 2. Let body be the result of extracting bytes.\n const body = extractBody(bytes)\n\n // 3. Let responseObject be the result of creating a Response object, given a new response,\n // \"response\", and this’s relevant Realm.\n const relevantRealm = { settingsObject: {} }\n const responseObject = new Response()\n responseObject[kRealm] = relevantRealm\n responseObject[kHeaders][kGuard] = 'response'\n responseObject[kHeaders][kRealm] = relevantRealm\n\n // 4. Perform initialize a response given responseObject, init, and (body, \"application/json\").\n initializeResponse(responseObject, init, { body: body[0], type: 'application/json' })\n\n // 5. Return responseObject.\n return responseObject\n }\n\n // Creates a redirect Response that redirects to url with status status.\n static redirect (url, status = 302) {\n const relevantRealm = { settingsObject: {} }\n\n webidl.argumentLengthCheck(arguments, 1, { header: 'Response.redirect' })\n\n url = webidl.converters.USVString(url)\n status = webidl.converters['unsigned short'](status)\n\n // 1. Let parsedURL be the result of parsing url with current settings\n // object’s API base URL.\n // 2. If parsedURL is failure, then throw a TypeError.\n // TODO: base-URL?\n let parsedURL\n try {\n parsedURL = new URL(url, getGlobalOrigin())\n } catch (err) {\n throw Object.assign(new TypeError('Failed to parse URL from ' + url), {\n cause: err\n })\n }\n\n // 3. If status is not a redirect status, then throw a RangeError.\n if (!redirectStatusSet.has(status)) {\n throw new RangeError('Invalid status code ' + status)\n }\n\n // 4. Let responseObject be the result of creating a Response object,\n // given a new response, \"immutable\", and this’s relevant Realm.\n const responseObject = new Response()\n responseObject[kRealm] = relevantRealm\n responseObject[kHeaders][kGuard] = 'immutable'\n responseObject[kHeaders][kRealm] = relevantRealm\n\n // 5. Set responseObject’s response’s status to status.\n responseObject[kState].status = status\n\n // 6. Let value be parsedURL, serialized and isomorphic encoded.\n const value = isomorphicEncode(URLSerializer(parsedURL))\n\n // 7. Append `Location`/value to responseObject’s response’s header list.\n responseObject[kState].headersList.append('location', value)\n\n // 8. Return responseObject.\n return responseObject\n }\n\n // https://fetch.spec.whatwg.org/#dom-response\n constructor (body = null, init = {}) {\n if (body !== null) {\n body = webidl.converters.BodyInit(body)\n }\n\n init = webidl.converters.ResponseInit(init)\n\n // TODO\n this[kRealm] = { settingsObject: {} }\n\n // 1. Set this’s response to a new response.\n this[kState] = makeResponse({})\n\n // 2. Set this’s headers to a new Headers object with this’s relevant\n // Realm, whose header list is this’s response’s header list and guard\n // is \"response\".\n this[kHeaders] = new Headers(kConstruct)\n this[kHeaders][kGuard] = 'response'\n this[kHeaders][kHeadersList] = this[kState].headersList\n this[kHeaders][kRealm] = this[kRealm]\n\n // 3. Let bodyWithType be null.\n let bodyWithType = null\n\n // 4. If body is non-null, then set bodyWithType to the result of extracting body.\n if (body != null) {\n const [extractedBody, type] = extractBody(body)\n bodyWithType = { body: extractedBody, type }\n }\n\n // 5. Perform initialize a response given this, init, and bodyWithType.\n initializeResponse(this, init, bodyWithType)\n }\n\n // Returns response’s type, e.g., \"cors\".\n get type () {\n webidl.brandCheck(this, Response)\n\n // The type getter steps are to return this’s response’s type.\n return this[kState].type\n }\n\n // Returns response’s URL, if it has one; otherwise the empty string.\n get url () {\n webidl.brandCheck(this, Response)\n\n const urlList = this[kState].urlList\n\n // The url getter steps are to return the empty string if this’s\n // response’s URL is null; otherwise this’s response’s URL,\n // serialized with exclude fragment set to true.\n const url = urlList[urlList.length - 1] ?? null\n\n if (url === null) {\n return ''\n }\n\n return URLSerializer(url, true)\n }\n\n // Returns whether response was obtained through a redirect.\n get redirected () {\n webidl.brandCheck(this, Response)\n\n // The redirected getter steps are to return true if this’s response’s URL\n // list has more than one item; otherwise false.\n return this[kState].urlList.length > 1\n }\n\n // Returns response’s status.\n get status () {\n webidl.brandCheck(this, Response)\n\n // The status getter steps are to return this’s response’s status.\n return this[kState].status\n }\n\n // Returns whether response’s status is an ok status.\n get ok () {\n webidl.brandCheck(this, Response)\n\n // The ok getter steps are to return true if this’s response’s status is an\n // ok status; otherwise false.\n return this[kState].status >= 200 && this[kState].status <= 299\n }\n\n // Returns response’s status message.\n get statusText () {\n webidl.brandCheck(this, Response)\n\n // The statusText getter steps are to return this’s response’s status\n // message.\n return this[kState].statusText\n }\n\n // Returns response’s headers as Headers.\n get headers () {\n webidl.brandCheck(this, Response)\n\n // The headers getter steps are to return this’s headers.\n return this[kHeaders]\n }\n\n get body () {\n webidl.brandCheck(this, Response)\n\n return this[kState].body ? this[kState].body.stream : null\n }\n\n get bodyUsed () {\n webidl.brandCheck(this, Response)\n\n return !!this[kState].body && util.isDisturbed(this[kState].body.stream)\n }\n\n // Returns a clone of response.\n clone () {\n webidl.brandCheck(this, Response)\n\n // 1. If this is unusable, then throw a TypeError.\n if (this.bodyUsed || (this.body && this.body.locked)) {\n throw webidl.errors.exception({\n header: 'Response.clone',\n message: 'Body has already been consumed.'\n })\n }\n\n // 2. Let clonedResponse be the result of cloning this’s response.\n const clonedResponse = cloneResponse(this[kState])\n\n // 3. Return the result of creating a Response object, given\n // clonedResponse, this’s headers’s guard, and this’s relevant Realm.\n const clonedResponseObject = new Response()\n clonedResponseObject[kState] = clonedResponse\n clonedResponseObject[kRealm] = this[kRealm]\n clonedResponseObject[kHeaders][kHeadersList] = clonedResponse.headersList\n clonedResponseObject[kHeaders][kGuard] = this[kHeaders][kGuard]\n clonedResponseObject[kHeaders][kRealm] = this[kHeaders][kRealm]\n\n return clonedResponseObject\n }\n}\n\nmixinBody(Response)\n\nObject.defineProperties(Response.prototype, {\n type: kEnumerableProperty,\n url: kEnumerableProperty,\n status: kEnumerableProperty,\n ok: kEnumerableProperty,\n redirected: kEnumerableProperty,\n statusText: kEnumerableProperty,\n headers: kEnumerableProperty,\n clone: kEnumerableProperty,\n body: kEnumerableProperty,\n bodyUsed: kEnumerableProperty,\n [Symbol.toStringTag]: {\n value: 'Response',\n configurable: true\n }\n})\n\nObject.defineProperties(Response, {\n json: kEnumerableProperty,\n redirect: kEnumerableProperty,\n error: kEnumerableProperty\n})\n\n// https://fetch.spec.whatwg.org/#concept-response-clone\nfunction cloneResponse (response) {\n // To clone a response response, run these steps:\n\n // 1. If response is a filtered response, then return a new identical\n // filtered response whose internal response is a clone of response’s\n // internal response.\n if (response.internalResponse) {\n return filterResponse(\n cloneResponse(response.internalResponse),\n response.type\n )\n }\n\n // 2. Let newResponse be a copy of response, except for its body.\n const newResponse = makeResponse({ ...response, body: null })\n\n // 3. If response’s body is non-null, then set newResponse’s body to the\n // result of cloning response’s body.\n if (response.body != null) {\n newResponse.body = cloneBody(response.body)\n }\n\n // 4. Return newResponse.\n return newResponse\n}\n\nfunction makeResponse (init) {\n return {\n aborted: false,\n rangeRequested: false,\n timingAllowPassed: false,\n requestIncludesCredentials: false,\n type: 'default',\n status: 200,\n timingInfo: null,\n cacheState: '',\n statusText: '',\n ...init,\n headersList: init.headersList\n ? new HeadersList(init.headersList)\n : new HeadersList(),\n urlList: init.urlList ? [...init.urlList] : []\n }\n}\n\nfunction makeNetworkError (reason) {\n const isError = isErrorLike(reason)\n return makeResponse({\n type: 'error',\n status: 0,\n error: isError\n ? reason\n : new Error(reason ? String(reason) : reason),\n aborted: reason && reason.name === 'AbortError'\n })\n}\n\nfunction makeFilteredResponse (response, state) {\n state = {\n internalResponse: response,\n ...state\n }\n\n return new Proxy(response, {\n get (target, p) {\n return p in state ? state[p] : target[p]\n },\n set (target, p, value) {\n assert(!(p in state))\n target[p] = value\n return true\n }\n })\n}\n\n// https://fetch.spec.whatwg.org/#concept-filtered-response\nfunction filterResponse (response, type) {\n // Set response to the following filtered response with response as its\n // internal response, depending on request’s response tainting:\n if (type === 'basic') {\n // A basic filtered response is a filtered response whose type is \"basic\"\n // and header list excludes any headers in internal response’s header list\n // whose name is a forbidden response-header name.\n\n // Note: undici does not implement forbidden response-header names\n return makeFilteredResponse(response, {\n type: 'basic',\n headersList: response.headersList\n })\n } else if (type === 'cors') {\n // A CORS filtered response is a filtered response whose type is \"cors\"\n // and header list excludes any headers in internal response’s header\n // list whose name is not a CORS-safelisted response-header name, given\n // internal response’s CORS-exposed header-name list.\n\n // Note: undici does not implement CORS-safelisted response-header names\n return makeFilteredResponse(response, {\n type: 'cors',\n headersList: response.headersList\n })\n } else if (type === 'opaque') {\n // An opaque filtered response is a filtered response whose type is\n // \"opaque\", URL list is the empty list, status is 0, status message\n // is the empty byte sequence, header list is empty, and body is null.\n\n return makeFilteredResponse(response, {\n type: 'opaque',\n urlList: Object.freeze([]),\n status: 0,\n statusText: '',\n body: null\n })\n } else if (type === 'opaqueredirect') {\n // An opaque-redirect filtered response is a filtered response whose type\n // is \"opaqueredirect\", status is 0, status message is the empty byte\n // sequence, header list is empty, and body is null.\n\n return makeFilteredResponse(response, {\n type: 'opaqueredirect',\n status: 0,\n statusText: '',\n headersList: [],\n body: null\n })\n } else {\n assert(false)\n }\n}\n\n// https://fetch.spec.whatwg.org/#appropriate-network-error\nfunction makeAppropriateNetworkError (fetchParams, err = null) {\n // 1. Assert: fetchParams is canceled.\n assert(isCancelled(fetchParams))\n\n // 2. Return an aborted network error if fetchParams is aborted;\n // otherwise return a network error.\n return isAborted(fetchParams)\n ? makeNetworkError(Object.assign(new DOMException('The operation was aborted.', 'AbortError'), { cause: err }))\n : makeNetworkError(Object.assign(new DOMException('Request was cancelled.'), { cause: err }))\n}\n\n// https://whatpr.org/fetch/1392.html#initialize-a-response\nfunction initializeResponse (response, init, body) {\n // 1. If init[\"status\"] is not in the range 200 to 599, inclusive, then\n // throw a RangeError.\n if (init.status !== null && (init.status < 200 || init.status > 599)) {\n throw new RangeError('init[\"status\"] must be in the range of 200 to 599, inclusive.')\n }\n\n // 2. If init[\"statusText\"] does not match the reason-phrase token production,\n // then throw a TypeError.\n if ('statusText' in init && init.statusText != null) {\n // See, https://datatracker.ietf.org/doc/html/rfc7230#section-3.1.2:\n // reason-phrase = *( HTAB / SP / VCHAR / obs-text )\n if (!isValidReasonPhrase(String(init.statusText))) {\n throw new TypeError('Invalid statusText')\n }\n }\n\n // 3. Set response’s response’s status to init[\"status\"].\n if ('status' in init && init.status != null) {\n response[kState].status = init.status\n }\n\n // 4. Set response’s response’s status message to init[\"statusText\"].\n if ('statusText' in init && init.statusText != null) {\n response[kState].statusText = init.statusText\n }\n\n // 5. If init[\"headers\"] exists, then fill response’s headers with init[\"headers\"].\n if ('headers' in init && init.headers != null) {\n fill(response[kHeaders], init.headers)\n }\n\n // 6. If body was given, then:\n if (body) {\n // 1. If response's status is a null body status, then throw a TypeError.\n if (nullBodyStatus.includes(response.status)) {\n throw webidl.errors.exception({\n header: 'Response constructor',\n message: 'Invalid response status code ' + response.status\n })\n }\n\n // 2. Set response's body to body's body.\n response[kState].body = body.body\n\n // 3. If body's type is non-null and response's header list does not contain\n // `Content-Type`, then append (`Content-Type`, body's type) to response's header list.\n if (body.type != null && !response[kState].headersList.contains('Content-Type')) {\n response[kState].headersList.append('content-type', body.type)\n }\n }\n}\n\nwebidl.converters.ReadableStream = webidl.interfaceConverter(\n ReadableStream\n)\n\nwebidl.converters.FormData = webidl.interfaceConverter(\n FormData\n)\n\nwebidl.converters.URLSearchParams = webidl.interfaceConverter(\n URLSearchParams\n)\n\n// https://fetch.spec.whatwg.org/#typedefdef-xmlhttprequestbodyinit\nwebidl.converters.XMLHttpRequestBodyInit = function (V) {\n if (typeof V === 'string') {\n return webidl.converters.USVString(V)\n }\n\n if (isBlobLike(V)) {\n return webidl.converters.Blob(V, { strict: false })\n }\n\n if (types.isArrayBuffer(V) || types.isTypedArray(V) || types.isDataView(V)) {\n return webidl.converters.BufferSource(V)\n }\n\n if (util.isFormDataLike(V)) {\n return webidl.converters.FormData(V, { strict: false })\n }\n\n if (V instanceof URLSearchParams) {\n return webidl.converters.URLSearchParams(V)\n }\n\n return webidl.converters.DOMString(V)\n}\n\n// https://fetch.spec.whatwg.org/#bodyinit\nwebidl.converters.BodyInit = function (V) {\n if (V instanceof ReadableStream) {\n return webidl.converters.ReadableStream(V)\n }\n\n // Note: the spec doesn't include async iterables,\n // this is an undici extension.\n if (V?.[Symbol.asyncIterator]) {\n return V\n }\n\n return webidl.converters.XMLHttpRequestBodyInit(V)\n}\n\nwebidl.converters.ResponseInit = webidl.dictionaryConverter([\n {\n key: 'status',\n converter: webidl.converters['unsigned short'],\n defaultValue: 200\n },\n {\n key: 'statusText',\n converter: webidl.converters.ByteString,\n defaultValue: ''\n },\n {\n key: 'headers',\n converter: webidl.converters.HeadersInit\n }\n])\n\nmodule.exports = {\n makeNetworkError,\n makeResponse,\n makeAppropriateNetworkError,\n filterResponse,\n Response,\n cloneResponse\n}\n","'use strict'\n\nmodule.exports = {\n kUrl: Symbol('url'),\n kHeaders: Symbol('headers'),\n kSignal: Symbol('signal'),\n kState: Symbol('state'),\n kGuard: Symbol('guard'),\n kRealm: Symbol('realm')\n}\n","'use strict'\n\nconst { redirectStatusSet, referrerPolicySet: referrerPolicyTokens, badPortsSet } = require('./constants')\nconst { getGlobalOrigin } = require('./global')\nconst { performance } = require('perf_hooks')\nconst { isBlobLike, toUSVString, ReadableStreamFrom } = require('../core/util')\nconst assert = require('assert')\nconst { isUint8Array } = require('util/types')\n\n// https://nodejs.org/api/crypto.html#determining-if-crypto-support-is-unavailable\n/** @type {import('crypto')|undefined} */\nlet crypto\n\ntry {\n crypto = require('crypto')\n} catch {\n\n}\n\nfunction responseURL (response) {\n // https://fetch.spec.whatwg.org/#responses\n // A response has an associated URL. It is a pointer to the last URL\n // in response’s URL list and null if response’s URL list is empty.\n const urlList = response.urlList\n const length = urlList.length\n return length === 0 ? null : urlList[length - 1].toString()\n}\n\n// https://fetch.spec.whatwg.org/#concept-response-location-url\nfunction responseLocationURL (response, requestFragment) {\n // 1. If response’s status is not a redirect status, then return null.\n if (!redirectStatusSet.has(response.status)) {\n return null\n }\n\n // 2. Let location be the result of extracting header list values given\n // `Location` and response’s header list.\n let location = response.headersList.get('location')\n\n // 3. If location is a header value, then set location to the result of\n // parsing location with response’s URL.\n if (location !== null && isValidHeaderValue(location)) {\n location = new URL(location, responseURL(response))\n }\n\n // 4. If location is a URL whose fragment is null, then set location’s\n // fragment to requestFragment.\n if (location && !location.hash) {\n location.hash = requestFragment\n }\n\n // 5. Return location.\n return location\n}\n\n/** @returns {URL} */\nfunction requestCurrentURL (request) {\n return request.urlList[request.urlList.length - 1]\n}\n\nfunction requestBadPort (request) {\n // 1. Let url be request’s current URL.\n const url = requestCurrentURL(request)\n\n // 2. If url’s scheme is an HTTP(S) scheme and url’s port is a bad port,\n // then return blocked.\n if (urlIsHttpHttpsScheme(url) && badPortsSet.has(url.port)) {\n return 'blocked'\n }\n\n // 3. Return allowed.\n return 'allowed'\n}\n\nfunction isErrorLike (object) {\n return object instanceof Error || (\n object?.constructor?.name === 'Error' ||\n object?.constructor?.name === 'DOMException'\n )\n}\n\n// Check whether |statusText| is a ByteString and\n// matches the Reason-Phrase token production.\n// RFC 2616: https://tools.ietf.org/html/rfc2616\n// RFC 7230: https://tools.ietf.org/html/rfc7230\n// \"reason-phrase = *( HTAB / SP / VCHAR / obs-text )\"\n// https://github.com/chromium/chromium/blob/94.0.4604.1/third_party/blink/renderer/core/fetch/response.cc#L116\nfunction isValidReasonPhrase (statusText) {\n for (let i = 0; i < statusText.length; ++i) {\n const c = statusText.charCodeAt(i)\n if (\n !(\n (\n c === 0x09 || // HTAB\n (c >= 0x20 && c <= 0x7e) || // SP / VCHAR\n (c >= 0x80 && c <= 0xff)\n ) // obs-text\n )\n ) {\n return false\n }\n }\n return true\n}\n\n/**\n * @see https://tools.ietf.org/html/rfc7230#section-3.2.6\n * @param {number} c\n */\nfunction isTokenCharCode (c) {\n switch (c) {\n case 0x22:\n case 0x28:\n case 0x29:\n case 0x2c:\n case 0x2f:\n case 0x3a:\n case 0x3b:\n case 0x3c:\n case 0x3d:\n case 0x3e:\n case 0x3f:\n case 0x40:\n case 0x5b:\n case 0x5c:\n case 0x5d:\n case 0x7b:\n case 0x7d:\n // DQUOTE and \"(),/:;<=>?@[\\]{}\"\n return false\n default:\n // VCHAR %x21-7E\n return c >= 0x21 && c <= 0x7e\n }\n}\n\n/**\n * @param {string} characters\n */\nfunction isValidHTTPToken (characters) {\n if (characters.length === 0) {\n return false\n }\n for (let i = 0; i < characters.length; ++i) {\n if (!isTokenCharCode(characters.charCodeAt(i))) {\n return false\n }\n }\n return true\n}\n\n/**\n * @see https://fetch.spec.whatwg.org/#header-name\n * @param {string} potentialValue\n */\nfunction isValidHeaderName (potentialValue) {\n return isValidHTTPToken(potentialValue)\n}\n\n/**\n * @see https://fetch.spec.whatwg.org/#header-value\n * @param {string} potentialValue\n */\nfunction isValidHeaderValue (potentialValue) {\n // - Has no leading or trailing HTTP tab or space bytes.\n // - Contains no 0x00 (NUL) or HTTP newline bytes.\n if (\n potentialValue.startsWith('\\t') ||\n potentialValue.startsWith(' ') ||\n potentialValue.endsWith('\\t') ||\n potentialValue.endsWith(' ')\n ) {\n return false\n }\n\n if (\n potentialValue.includes('\\0') ||\n potentialValue.includes('\\r') ||\n potentialValue.includes('\\n')\n ) {\n return false\n }\n\n return true\n}\n\n// https://w3c.github.io/webappsec-referrer-policy/#set-requests-referrer-policy-on-redirect\nfunction setRequestReferrerPolicyOnRedirect (request, actualResponse) {\n // Given a request request and a response actualResponse, this algorithm\n // updates request’s referrer policy according to the Referrer-Policy\n // header (if any) in actualResponse.\n\n // 1. Let policy be the result of executing § 8.1 Parse a referrer policy\n // from a Referrer-Policy header on actualResponse.\n\n // 8.1 Parse a referrer policy from a Referrer-Policy header\n // 1. Let policy-tokens be the result of extracting header list values given `Referrer-Policy` and response’s header list.\n const { headersList } = actualResponse\n // 2. Let policy be the empty string.\n // 3. For each token in policy-tokens, if token is a referrer policy and token is not the empty string, then set policy to token.\n // 4. Return policy.\n const policyHeader = (headersList.get('referrer-policy') ?? '').split(',')\n\n // Note: As the referrer-policy can contain multiple policies\n // separated by comma, we need to loop through all of them\n // and pick the first valid one.\n // Ref: https://developer.mozilla.org/en-US/docs/Web/HTTP/Headers/Referrer-Policy#specify_a_fallback_policy\n let policy = ''\n if (policyHeader.length > 0) {\n // The right-most policy takes precedence.\n // The left-most policy is the fallback.\n for (let i = policyHeader.length; i !== 0; i--) {\n const token = policyHeader[i - 1].trim()\n if (referrerPolicyTokens.has(token)) {\n policy = token\n break\n }\n }\n }\n\n // 2. If policy is not the empty string, then set request’s referrer policy to policy.\n if (policy !== '') {\n request.referrerPolicy = policy\n }\n}\n\n// https://fetch.spec.whatwg.org/#cross-origin-resource-policy-check\nfunction crossOriginResourcePolicyCheck () {\n // TODO\n return 'allowed'\n}\n\n// https://fetch.spec.whatwg.org/#concept-cors-check\nfunction corsCheck () {\n // TODO\n return 'success'\n}\n\n// https://fetch.spec.whatwg.org/#concept-tao-check\nfunction TAOCheck () {\n // TODO\n return 'success'\n}\n\nfunction appendFetchMetadata (httpRequest) {\n // https://w3c.github.io/webappsec-fetch-metadata/#sec-fetch-dest-header\n // TODO\n\n // https://w3c.github.io/webappsec-fetch-metadata/#sec-fetch-mode-header\n\n // 1. Assert: r’s url is a potentially trustworthy URL.\n // TODO\n\n // 2. Let header be a Structured Header whose value is a token.\n let header = null\n\n // 3. Set header’s value to r’s mode.\n header = httpRequest.mode\n\n // 4. Set a structured field value `Sec-Fetch-Mode`/header in r’s header list.\n httpRequest.headersList.set('sec-fetch-mode', header)\n\n // https://w3c.github.io/webappsec-fetch-metadata/#sec-fetch-site-header\n // TODO\n\n // https://w3c.github.io/webappsec-fetch-metadata/#sec-fetch-user-header\n // TODO\n}\n\n// https://fetch.spec.whatwg.org/#append-a-request-origin-header\nfunction appendRequestOriginHeader (request) {\n // 1. Let serializedOrigin be the result of byte-serializing a request origin with request.\n let serializedOrigin = request.origin\n\n // 2. If request’s response tainting is \"cors\" or request’s mode is \"websocket\", then append (`Origin`, serializedOrigin) to request’s header list.\n if (request.responseTainting === 'cors' || request.mode === 'websocket') {\n if (serializedOrigin) {\n request.headersList.append('origin', serializedOrigin)\n }\n\n // 3. Otherwise, if request’s method is neither `GET` nor `HEAD`, then:\n } else if (request.method !== 'GET' && request.method !== 'HEAD') {\n // 1. Switch on request’s referrer policy:\n switch (request.referrerPolicy) {\n case 'no-referrer':\n // Set serializedOrigin to `null`.\n serializedOrigin = null\n break\n case 'no-referrer-when-downgrade':\n case 'strict-origin':\n case 'strict-origin-when-cross-origin':\n // If request’s origin is a tuple origin, its scheme is \"https\", and request’s current URL’s scheme is not \"https\", then set serializedOrigin to `null`.\n if (request.origin && urlHasHttpsScheme(request.origin) && !urlHasHttpsScheme(requestCurrentURL(request))) {\n serializedOrigin = null\n }\n break\n case 'same-origin':\n // If request’s origin is not same origin with request’s current URL’s origin, then set serializedOrigin to `null`.\n if (!sameOrigin(request, requestCurrentURL(request))) {\n serializedOrigin = null\n }\n break\n default:\n // Do nothing.\n }\n\n if (serializedOrigin) {\n // 2. Append (`Origin`, serializedOrigin) to request’s header list.\n request.headersList.append('origin', serializedOrigin)\n }\n }\n}\n\nfunction coarsenedSharedCurrentTime (crossOriginIsolatedCapability) {\n // TODO\n return performance.now()\n}\n\n// https://fetch.spec.whatwg.org/#create-an-opaque-timing-info\nfunction createOpaqueTimingInfo (timingInfo) {\n return {\n startTime: timingInfo.startTime ?? 0,\n redirectStartTime: 0,\n redirectEndTime: 0,\n postRedirectStartTime: timingInfo.startTime ?? 0,\n finalServiceWorkerStartTime: 0,\n finalNetworkResponseStartTime: 0,\n finalNetworkRequestStartTime: 0,\n endTime: 0,\n encodedBodySize: 0,\n decodedBodySize: 0,\n finalConnectionTimingInfo: null\n }\n}\n\n// https://html.spec.whatwg.org/multipage/origin.html#policy-container\nfunction makePolicyContainer () {\n // Note: the fetch spec doesn't make use of embedder policy or CSP list\n return {\n referrerPolicy: 'strict-origin-when-cross-origin'\n }\n}\n\n// https://html.spec.whatwg.org/multipage/origin.html#clone-a-policy-container\nfunction clonePolicyContainer (policyContainer) {\n return {\n referrerPolicy: policyContainer.referrerPolicy\n }\n}\n\n// https://w3c.github.io/webappsec-referrer-policy/#determine-requests-referrer\nfunction determineRequestsReferrer (request) {\n // 1. Let policy be request's referrer policy.\n const policy = request.referrerPolicy\n\n // Note: policy cannot (shouldn't) be null or an empty string.\n assert(policy)\n\n // 2. Let environment be request’s client.\n\n let referrerSource = null\n\n // 3. Switch on request’s referrer:\n if (request.referrer === 'client') {\n // Note: node isn't a browser and doesn't implement document/iframes,\n // so we bypass this step and replace it with our own.\n\n const globalOrigin = getGlobalOrigin()\n\n if (!globalOrigin || globalOrigin.origin === 'null') {\n return 'no-referrer'\n }\n\n // note: we need to clone it as it's mutated\n referrerSource = new URL(globalOrigin)\n } else if (request.referrer instanceof URL) {\n // Let referrerSource be request’s referrer.\n referrerSource = request.referrer\n }\n\n // 4. Let request’s referrerURL be the result of stripping referrerSource for\n // use as a referrer.\n let referrerURL = stripURLForReferrer(referrerSource)\n\n // 5. Let referrerOrigin be the result of stripping referrerSource for use as\n // a referrer, with the origin-only flag set to true.\n const referrerOrigin = stripURLForReferrer(referrerSource, true)\n\n // 6. If the result of serializing referrerURL is a string whose length is\n // greater than 4096, set referrerURL to referrerOrigin.\n if (referrerURL.toString().length > 4096) {\n referrerURL = referrerOrigin\n }\n\n const areSameOrigin = sameOrigin(request, referrerURL)\n const isNonPotentiallyTrustWorthy = isURLPotentiallyTrustworthy(referrerURL) &&\n !isURLPotentiallyTrustworthy(request.url)\n\n // 8. Execute the switch statements corresponding to the value of policy:\n switch (policy) {\n case 'origin': return referrerOrigin != null ? referrerOrigin : stripURLForReferrer(referrerSource, true)\n case 'unsafe-url': return referrerURL\n case 'same-origin':\n return areSameOrigin ? referrerOrigin : 'no-referrer'\n case 'origin-when-cross-origin':\n return areSameOrigin ? referrerURL : referrerOrigin\n case 'strict-origin-when-cross-origin': {\n const currentURL = requestCurrentURL(request)\n\n // 1. If the origin of referrerURL and the origin of request’s current\n // URL are the same, then return referrerURL.\n if (sameOrigin(referrerURL, currentURL)) {\n return referrerURL\n }\n\n // 2. If referrerURL is a potentially trustworthy URL and request’s\n // current URL is not a potentially trustworthy URL, then return no\n // referrer.\n if (isURLPotentiallyTrustworthy(referrerURL) && !isURLPotentiallyTrustworthy(currentURL)) {\n return 'no-referrer'\n }\n\n // 3. Return referrerOrigin.\n return referrerOrigin\n }\n case 'strict-origin': // eslint-disable-line\n /**\n * 1. If referrerURL is a potentially trustworthy URL and\n * request’s current URL is not a potentially trustworthy URL,\n * then return no referrer.\n * 2. Return referrerOrigin\n */\n case 'no-referrer-when-downgrade': // eslint-disable-line\n /**\n * 1. If referrerURL is a potentially trustworthy URL and\n * request’s current URL is not a potentially trustworthy URL,\n * then return no referrer.\n * 2. Return referrerOrigin\n */\n\n default: // eslint-disable-line\n return isNonPotentiallyTrustWorthy ? 'no-referrer' : referrerOrigin\n }\n}\n\n/**\n * @see https://w3c.github.io/webappsec-referrer-policy/#strip-url\n * @param {URL} url\n * @param {boolean|undefined} originOnly\n */\nfunction stripURLForReferrer (url, originOnly) {\n // 1. Assert: url is a URL.\n assert(url instanceof URL)\n\n // 2. If url’s scheme is a local scheme, then return no referrer.\n if (url.protocol === 'file:' || url.protocol === 'about:' || url.protocol === 'blank:') {\n return 'no-referrer'\n }\n\n // 3. Set url’s username to the empty string.\n url.username = ''\n\n // 4. Set url’s password to the empty string.\n url.password = ''\n\n // 5. Set url’s fragment to null.\n url.hash = ''\n\n // 6. If the origin-only flag is true, then:\n if (originOnly) {\n // 1. Set url’s path to « the empty string ».\n url.pathname = ''\n\n // 2. Set url’s query to null.\n url.search = ''\n }\n\n // 7. Return url.\n return url\n}\n\nfunction isURLPotentiallyTrustworthy (url) {\n if (!(url instanceof URL)) {\n return false\n }\n\n // If child of about, return true\n if (url.href === 'about:blank' || url.href === 'about:srcdoc') {\n return true\n }\n\n // If scheme is data, return true\n if (url.protocol === 'data:') return true\n\n // If file, return true\n if (url.protocol === 'file:') return true\n\n return isOriginPotentiallyTrustworthy(url.origin)\n\n function isOriginPotentiallyTrustworthy (origin) {\n // If origin is explicitly null, return false\n if (origin == null || origin === 'null') return false\n\n const originAsURL = new URL(origin)\n\n // If secure, return true\n if (originAsURL.protocol === 'https:' || originAsURL.protocol === 'wss:') {\n return true\n }\n\n // If localhost or variants, return true\n if (/^127(?:\\.[0-9]+){0,2}\\.[0-9]+$|^\\[(?:0*:)*?:?0*1\\]$/.test(originAsURL.hostname) ||\n (originAsURL.hostname === 'localhost' || originAsURL.hostname.includes('localhost.')) ||\n (originAsURL.hostname.endsWith('.localhost'))) {\n return true\n }\n\n // If any other, return false\n return false\n }\n}\n\n/**\n * @see https://w3c.github.io/webappsec-subresource-integrity/#does-response-match-metadatalist\n * @param {Uint8Array} bytes\n * @param {string} metadataList\n */\nfunction bytesMatch (bytes, metadataList) {\n // If node is not built with OpenSSL support, we cannot check\n // a request's integrity, so allow it by default (the spec will\n // allow requests if an invalid hash is given, as precedence).\n /* istanbul ignore if: only if node is built with --without-ssl */\n if (crypto === undefined) {\n return true\n }\n\n // 1. Let parsedMetadata be the result of parsing metadataList.\n const parsedMetadata = parseMetadata(metadataList)\n\n // 2. If parsedMetadata is no metadata, return true.\n if (parsedMetadata === 'no metadata') {\n return true\n }\n\n // 3. If parsedMetadata is the empty set, return true.\n if (parsedMetadata.length === 0) {\n return true\n }\n\n // 4. Let metadata be the result of getting the strongest\n // metadata from parsedMetadata.\n const list = parsedMetadata.sort((c, d) => d.algo.localeCompare(c.algo))\n // get the strongest algorithm\n const strongest = list[0].algo\n // get all entries that use the strongest algorithm; ignore weaker\n const metadata = list.filter((item) => item.algo === strongest)\n\n // 5. For each item in metadata:\n for (const item of metadata) {\n // 1. Let algorithm be the alg component of item.\n const algorithm = item.algo\n\n // 2. Let expectedValue be the val component of item.\n let expectedValue = item.hash\n\n // See https://github.com/web-platform-tests/wpt/commit/e4c5cc7a5e48093220528dfdd1c4012dc3837a0e\n // \"be liberal with padding\". This is annoying, and it's not even in the spec.\n\n if (expectedValue.endsWith('==')) {\n expectedValue = expectedValue.slice(0, -2)\n }\n\n // 3. Let actualValue be the result of applying algorithm to bytes.\n let actualValue = crypto.createHash(algorithm).update(bytes).digest('base64')\n\n if (actualValue.endsWith('==')) {\n actualValue = actualValue.slice(0, -2)\n }\n\n // 4. If actualValue is a case-sensitive match for expectedValue,\n // return true.\n if (actualValue === expectedValue) {\n return true\n }\n\n let actualBase64URL = crypto.createHash(algorithm).update(bytes).digest('base64url')\n\n if (actualBase64URL.endsWith('==')) {\n actualBase64URL = actualBase64URL.slice(0, -2)\n }\n\n if (actualBase64URL === expectedValue) {\n return true\n }\n }\n\n // 6. Return false.\n return false\n}\n\n// https://w3c.github.io/webappsec-subresource-integrity/#grammardef-hash-with-options\n// https://www.w3.org/TR/CSP2/#source-list-syntax\n// https://www.rfc-editor.org/rfc/rfc5234#appendix-B.1\nconst parseHashWithOptions = /((?sha256|sha384|sha512)-(?[A-z0-9+/]{1}.*={0,2}))( +[\\x21-\\x7e]?)?/i\n\n/**\n * @see https://w3c.github.io/webappsec-subresource-integrity/#parse-metadata\n * @param {string} metadata\n */\nfunction parseMetadata (metadata) {\n // 1. Let result be the empty set.\n /** @type {{ algo: string, hash: string }[]} */\n const result = []\n\n // 2. Let empty be equal to true.\n let empty = true\n\n const supportedHashes = crypto.getHashes()\n\n // 3. For each token returned by splitting metadata on spaces:\n for (const token of metadata.split(' ')) {\n // 1. Set empty to false.\n empty = false\n\n // 2. Parse token as a hash-with-options.\n const parsedToken = parseHashWithOptions.exec(token)\n\n // 3. If token does not parse, continue to the next token.\n if (parsedToken === null || parsedToken.groups === undefined) {\n // Note: Chromium blocks the request at this point, but Firefox\n // gives a warning that an invalid integrity was given. The\n // correct behavior is to ignore these, and subsequently not\n // check the integrity of the resource.\n continue\n }\n\n // 4. Let algorithm be the hash-algo component of token.\n const algorithm = parsedToken.groups.algo\n\n // 5. If algorithm is a hash function recognized by the user\n // agent, add the parsed token to result.\n if (supportedHashes.includes(algorithm.toLowerCase())) {\n result.push(parsedToken.groups)\n }\n }\n\n // 4. Return no metadata if empty is true, otherwise return result.\n if (empty === true) {\n return 'no metadata'\n }\n\n return result\n}\n\n// https://w3c.github.io/webappsec-upgrade-insecure-requests/#upgrade-request\nfunction tryUpgradeRequestToAPotentiallyTrustworthyURL (request) {\n // TODO\n}\n\n/**\n * @link {https://html.spec.whatwg.org/multipage/origin.html#same-origin}\n * @param {URL} A\n * @param {URL} B\n */\nfunction sameOrigin (A, B) {\n // 1. If A and B are the same opaque origin, then return true.\n if (A.origin === B.origin && A.origin === 'null') {\n return true\n }\n\n // 2. If A and B are both tuple origins and their schemes,\n // hosts, and port are identical, then return true.\n if (A.protocol === B.protocol && A.hostname === B.hostname && A.port === B.port) {\n return true\n }\n\n // 3. Return false.\n return false\n}\n\nfunction createDeferredPromise () {\n let res\n let rej\n const promise = new Promise((resolve, reject) => {\n res = resolve\n rej = reject\n })\n\n return { promise, resolve: res, reject: rej }\n}\n\nfunction isAborted (fetchParams) {\n return fetchParams.controller.state === 'aborted'\n}\n\nfunction isCancelled (fetchParams) {\n return fetchParams.controller.state === 'aborted' ||\n fetchParams.controller.state === 'terminated'\n}\n\nconst normalizeMethodRecord = {\n delete: 'DELETE',\n DELETE: 'DELETE',\n get: 'GET',\n GET: 'GET',\n head: 'HEAD',\n HEAD: 'HEAD',\n options: 'OPTIONS',\n OPTIONS: 'OPTIONS',\n post: 'POST',\n POST: 'POST',\n put: 'PUT',\n PUT: 'PUT'\n}\n\n// Note: object prototypes should not be able to be referenced. e.g. `Object#hasOwnProperty`.\nObject.setPrototypeOf(normalizeMethodRecord, null)\n\n/**\n * @see https://fetch.spec.whatwg.org/#concept-method-normalize\n * @param {string} method\n */\nfunction normalizeMethod (method) {\n return normalizeMethodRecord[method.toLowerCase()] ?? method\n}\n\n// https://infra.spec.whatwg.org/#serialize-a-javascript-value-to-a-json-string\nfunction serializeJavascriptValueToJSONString (value) {\n // 1. Let result be ? Call(%JSON.stringify%, undefined, « value »).\n const result = JSON.stringify(value)\n\n // 2. If result is undefined, then throw a TypeError.\n if (result === undefined) {\n throw new TypeError('Value is not JSON serializable')\n }\n\n // 3. Assert: result is a string.\n assert(typeof result === 'string')\n\n // 4. Return result.\n return result\n}\n\n// https://tc39.es/ecma262/#sec-%25iteratorprototype%25-object\nconst esIteratorPrototype = Object.getPrototypeOf(Object.getPrototypeOf([][Symbol.iterator]()))\n\n/**\n * @see https://webidl.spec.whatwg.org/#dfn-iterator-prototype-object\n * @param {() => unknown[]} iterator\n * @param {string} name name of the instance\n * @param {'key'|'value'|'key+value'} kind\n */\nfunction makeIterator (iterator, name, kind) {\n const object = {\n index: 0,\n kind,\n target: iterator\n }\n\n const i = {\n next () {\n // 1. Let interface be the interface for which the iterator prototype object exists.\n\n // 2. Let thisValue be the this value.\n\n // 3. Let object be ? ToObject(thisValue).\n\n // 4. If object is a platform object, then perform a security\n // check, passing:\n\n // 5. If object is not a default iterator object for interface,\n // then throw a TypeError.\n if (Object.getPrototypeOf(this) !== i) {\n throw new TypeError(\n `'next' called on an object that does not implement interface ${name} Iterator.`\n )\n }\n\n // 6. Let index be object’s index.\n // 7. Let kind be object’s kind.\n // 8. Let values be object’s target's value pairs to iterate over.\n const { index, kind, target } = object\n const values = target()\n\n // 9. Let len be the length of values.\n const len = values.length\n\n // 10. If index is greater than or equal to len, then return\n // CreateIterResultObject(undefined, true).\n if (index >= len) {\n return { value: undefined, done: true }\n }\n\n // 11. Let pair be the entry in values at index index.\n const pair = values[index]\n\n // 12. Set object’s index to index + 1.\n object.index = index + 1\n\n // 13. Return the iterator result for pair and kind.\n return iteratorResult(pair, kind)\n },\n // The class string of an iterator prototype object for a given interface is the\n // result of concatenating the identifier of the interface and the string \" Iterator\".\n [Symbol.toStringTag]: `${name} Iterator`\n }\n\n // The [[Prototype]] internal slot of an iterator prototype object must be %IteratorPrototype%.\n Object.setPrototypeOf(i, esIteratorPrototype)\n // esIteratorPrototype needs to be the prototype of i\n // which is the prototype of an empty object. Yes, it's confusing.\n return Object.setPrototypeOf({}, i)\n}\n\n// https://webidl.spec.whatwg.org/#iterator-result\nfunction iteratorResult (pair, kind) {\n let result\n\n // 1. Let result be a value determined by the value of kind:\n switch (kind) {\n case 'key': {\n // 1. Let idlKey be pair’s key.\n // 2. Let key be the result of converting idlKey to an\n // ECMAScript value.\n // 3. result is key.\n result = pair[0]\n break\n }\n case 'value': {\n // 1. Let idlValue be pair’s value.\n // 2. Let value be the result of converting idlValue to\n // an ECMAScript value.\n // 3. result is value.\n result = pair[1]\n break\n }\n case 'key+value': {\n // 1. Let idlKey be pair’s key.\n // 2. Let idlValue be pair’s value.\n // 3. Let key be the result of converting idlKey to an\n // ECMAScript value.\n // 4. Let value be the result of converting idlValue to\n // an ECMAScript value.\n // 5. Let array be ! ArrayCreate(2).\n // 6. Call ! CreateDataProperty(array, \"0\", key).\n // 7. Call ! CreateDataProperty(array, \"1\", value).\n // 8. result is array.\n result = pair\n break\n }\n }\n\n // 2. Return CreateIterResultObject(result, false).\n return { value: result, done: false }\n}\n\n/**\n * @see https://fetch.spec.whatwg.org/#body-fully-read\n */\nasync function fullyReadBody (body, processBody, processBodyError) {\n // 1. If taskDestination is null, then set taskDestination to\n // the result of starting a new parallel queue.\n\n // 2. Let successSteps given a byte sequence bytes be to queue a\n // fetch task to run processBody given bytes, with taskDestination.\n const successSteps = processBody\n\n // 3. Let errorSteps be to queue a fetch task to run processBodyError,\n // with taskDestination.\n const errorSteps = processBodyError\n\n // 4. Let reader be the result of getting a reader for body’s stream.\n // If that threw an exception, then run errorSteps with that\n // exception and return.\n let reader\n\n try {\n reader = body.stream.getReader()\n } catch (e) {\n errorSteps(e)\n return\n }\n\n // 5. Read all bytes from reader, given successSteps and errorSteps.\n try {\n const result = await readAllBytes(reader)\n successSteps(result)\n } catch (e) {\n errorSteps(e)\n }\n}\n\n/** @type {ReadableStream} */\nlet ReadableStream = globalThis.ReadableStream\n\nfunction isReadableStreamLike (stream) {\n if (!ReadableStream) {\n ReadableStream = require('stream/web').ReadableStream\n }\n\n return stream instanceof ReadableStream || (\n stream[Symbol.toStringTag] === 'ReadableStream' &&\n typeof stream.tee === 'function'\n )\n}\n\nconst MAXIMUM_ARGUMENT_LENGTH = 65535\n\n/**\n * @see https://infra.spec.whatwg.org/#isomorphic-decode\n * @param {number[]|Uint8Array} input\n */\nfunction isomorphicDecode (input) {\n // 1. To isomorphic decode a byte sequence input, return a string whose code point\n // length is equal to input’s length and whose code points have the same values\n // as the values of input’s bytes, in the same order.\n\n if (input.length < MAXIMUM_ARGUMENT_LENGTH) {\n return String.fromCharCode(...input)\n }\n\n return input.reduce((previous, current) => previous + String.fromCharCode(current), '')\n}\n\n/**\n * @param {ReadableStreamController} controller\n */\nfunction readableStreamClose (controller) {\n try {\n controller.close()\n } catch (err) {\n // TODO: add comment explaining why this error occurs.\n if (!err.message.includes('Controller is already closed')) {\n throw err\n }\n }\n}\n\n/**\n * @see https://infra.spec.whatwg.org/#isomorphic-encode\n * @param {string} input\n */\nfunction isomorphicEncode (input) {\n // 1. Assert: input contains no code points greater than U+00FF.\n for (let i = 0; i < input.length; i++) {\n assert(input.charCodeAt(i) <= 0xFF)\n }\n\n // 2. Return a byte sequence whose length is equal to input’s code\n // point length and whose bytes have the same values as the\n // values of input’s code points, in the same order\n return input\n}\n\n/**\n * @see https://streams.spec.whatwg.org/#readablestreamdefaultreader-read-all-bytes\n * @see https://streams.spec.whatwg.org/#read-loop\n * @param {ReadableStreamDefaultReader} reader\n */\nasync function readAllBytes (reader) {\n const bytes = []\n let byteLength = 0\n\n while (true) {\n const { done, value: chunk } = await reader.read()\n\n if (done) {\n // 1. Call successSteps with bytes.\n return Buffer.concat(bytes, byteLength)\n }\n\n // 1. If chunk is not a Uint8Array object, call failureSteps\n // with a TypeError and abort these steps.\n if (!isUint8Array(chunk)) {\n throw new TypeError('Received non-Uint8Array chunk')\n }\n\n // 2. Append the bytes represented by chunk to bytes.\n bytes.push(chunk)\n byteLength += chunk.length\n\n // 3. Read-loop given reader, bytes, successSteps, and failureSteps.\n }\n}\n\n/**\n * @see https://fetch.spec.whatwg.org/#is-local\n * @param {URL} url\n */\nfunction urlIsLocal (url) {\n assert('protocol' in url) // ensure it's a url object\n\n const protocol = url.protocol\n\n return protocol === 'about:' || protocol === 'blob:' || protocol === 'data:'\n}\n\n/**\n * @param {string|URL} url\n */\nfunction urlHasHttpsScheme (url) {\n if (typeof url === 'string') {\n return url.startsWith('https:')\n }\n\n return url.protocol === 'https:'\n}\n\n/**\n * @see https://fetch.spec.whatwg.org/#http-scheme\n * @param {URL} url\n */\nfunction urlIsHttpHttpsScheme (url) {\n assert('protocol' in url) // ensure it's a url object\n\n const protocol = url.protocol\n\n return protocol === 'http:' || protocol === 'https:'\n}\n\n/**\n * Fetch supports node >= 16.8.0, but Object.hasOwn was added in v16.9.0.\n */\nconst hasOwn = Object.hasOwn || ((dict, key) => Object.prototype.hasOwnProperty.call(dict, key))\n\nmodule.exports = {\n isAborted,\n isCancelled,\n createDeferredPromise,\n ReadableStreamFrom,\n toUSVString,\n tryUpgradeRequestToAPotentiallyTrustworthyURL,\n coarsenedSharedCurrentTime,\n determineRequestsReferrer,\n makePolicyContainer,\n clonePolicyContainer,\n appendFetchMetadata,\n appendRequestOriginHeader,\n TAOCheck,\n corsCheck,\n crossOriginResourcePolicyCheck,\n createOpaqueTimingInfo,\n setRequestReferrerPolicyOnRedirect,\n isValidHTTPToken,\n requestBadPort,\n requestCurrentURL,\n responseURL,\n responseLocationURL,\n isBlobLike,\n isURLPotentiallyTrustworthy,\n isValidReasonPhrase,\n sameOrigin,\n normalizeMethod,\n serializeJavascriptValueToJSONString,\n makeIterator,\n isValidHeaderName,\n isValidHeaderValue,\n hasOwn,\n isErrorLike,\n fullyReadBody,\n bytesMatch,\n isReadableStreamLike,\n readableStreamClose,\n isomorphicEncode,\n isomorphicDecode,\n urlIsLocal,\n urlHasHttpsScheme,\n urlIsHttpHttpsScheme,\n readAllBytes,\n normalizeMethodRecord\n}\n","'use strict'\n\nconst { types } = require('util')\nconst { hasOwn, toUSVString } = require('./util')\n\n/** @type {import('../../types/webidl').Webidl} */\nconst webidl = {}\nwebidl.converters = {}\nwebidl.util = {}\nwebidl.errors = {}\n\nwebidl.errors.exception = function (message) {\n return new TypeError(`${message.header}: ${message.message}`)\n}\n\nwebidl.errors.conversionFailed = function (context) {\n const plural = context.types.length === 1 ? '' : ' one of'\n const message =\n `${context.argument} could not be converted to` +\n `${plural}: ${context.types.join(', ')}.`\n\n return webidl.errors.exception({\n header: context.prefix,\n message\n })\n}\n\nwebidl.errors.invalidArgument = function (context) {\n return webidl.errors.exception({\n header: context.prefix,\n message: `\"${context.value}\" is an invalid ${context.type}.`\n })\n}\n\n// https://webidl.spec.whatwg.org/#implements\nwebidl.brandCheck = function (V, I, opts = undefined) {\n if (opts?.strict !== false && !(V instanceof I)) {\n throw new TypeError('Illegal invocation')\n } else {\n return V?.[Symbol.toStringTag] === I.prototype[Symbol.toStringTag]\n }\n}\n\nwebidl.argumentLengthCheck = function ({ length }, min, ctx) {\n if (length < min) {\n throw webidl.errors.exception({\n message: `${min} argument${min !== 1 ? 's' : ''} required, ` +\n `but${length ? ' only' : ''} ${length} found.`,\n ...ctx\n })\n }\n}\n\nwebidl.illegalConstructor = function () {\n throw webidl.errors.exception({\n header: 'TypeError',\n message: 'Illegal constructor'\n })\n}\n\n// https://tc39.es/ecma262/#sec-ecmascript-data-types-and-values\nwebidl.util.Type = function (V) {\n switch (typeof V) {\n case 'undefined': return 'Undefined'\n case 'boolean': return 'Boolean'\n case 'string': return 'String'\n case 'symbol': return 'Symbol'\n case 'number': return 'Number'\n case 'bigint': return 'BigInt'\n case 'function':\n case 'object': {\n if (V === null) {\n return 'Null'\n }\n\n return 'Object'\n }\n }\n}\n\n// https://webidl.spec.whatwg.org/#abstract-opdef-converttoint\nwebidl.util.ConvertToInt = function (V, bitLength, signedness, opts = {}) {\n let upperBound\n let lowerBound\n\n // 1. If bitLength is 64, then:\n if (bitLength === 64) {\n // 1. Let upperBound be 2^53 − 1.\n upperBound = Math.pow(2, 53) - 1\n\n // 2. If signedness is \"unsigned\", then let lowerBound be 0.\n if (signedness === 'unsigned') {\n lowerBound = 0\n } else {\n // 3. Otherwise let lowerBound be −2^53 + 1.\n lowerBound = Math.pow(-2, 53) + 1\n }\n } else if (signedness === 'unsigned') {\n // 2. Otherwise, if signedness is \"unsigned\", then:\n\n // 1. Let lowerBound be 0.\n lowerBound = 0\n\n // 2. Let upperBound be 2^bitLength − 1.\n upperBound = Math.pow(2, bitLength) - 1\n } else {\n // 3. Otherwise:\n\n // 1. Let lowerBound be -2^bitLength − 1.\n lowerBound = Math.pow(-2, bitLength) - 1\n\n // 2. Let upperBound be 2^bitLength − 1 − 1.\n upperBound = Math.pow(2, bitLength - 1) - 1\n }\n\n // 4. Let x be ? ToNumber(V).\n let x = Number(V)\n\n // 5. If x is −0, then set x to +0.\n if (x === 0) {\n x = 0\n }\n\n // 6. If the conversion is to an IDL type associated\n // with the [EnforceRange] extended attribute, then:\n if (opts.enforceRange === true) {\n // 1. If x is NaN, +∞, or −∞, then throw a TypeError.\n if (\n Number.isNaN(x) ||\n x === Number.POSITIVE_INFINITY ||\n x === Number.NEGATIVE_INFINITY\n ) {\n throw webidl.errors.exception({\n header: 'Integer conversion',\n message: `Could not convert ${V} to an integer.`\n })\n }\n\n // 2. Set x to IntegerPart(x).\n x = webidl.util.IntegerPart(x)\n\n // 3. If x < lowerBound or x > upperBound, then\n // throw a TypeError.\n if (x < lowerBound || x > upperBound) {\n throw webidl.errors.exception({\n header: 'Integer conversion',\n message: `Value must be between ${lowerBound}-${upperBound}, got ${x}.`\n })\n }\n\n // 4. Return x.\n return x\n }\n\n // 7. If x is not NaN and the conversion is to an IDL\n // type associated with the [Clamp] extended\n // attribute, then:\n if (!Number.isNaN(x) && opts.clamp === true) {\n // 1. Set x to min(max(x, lowerBound), upperBound).\n x = Math.min(Math.max(x, lowerBound), upperBound)\n\n // 2. Round x to the nearest integer, choosing the\n // even integer if it lies halfway between two,\n // and choosing +0 rather than −0.\n if (Math.floor(x) % 2 === 0) {\n x = Math.floor(x)\n } else {\n x = Math.ceil(x)\n }\n\n // 3. Return x.\n return x\n }\n\n // 8. If x is NaN, +0, +∞, or −∞, then return +0.\n if (\n Number.isNaN(x) ||\n (x === 0 && Object.is(0, x)) ||\n x === Number.POSITIVE_INFINITY ||\n x === Number.NEGATIVE_INFINITY\n ) {\n return 0\n }\n\n // 9. Set x to IntegerPart(x).\n x = webidl.util.IntegerPart(x)\n\n // 10. Set x to x modulo 2^bitLength.\n x = x % Math.pow(2, bitLength)\n\n // 11. If signedness is \"signed\" and x ≥ 2^bitLength − 1,\n // then return x − 2^bitLength.\n if (signedness === 'signed' && x >= Math.pow(2, bitLength) - 1) {\n return x - Math.pow(2, bitLength)\n }\n\n // 12. Otherwise, return x.\n return x\n}\n\n// https://webidl.spec.whatwg.org/#abstract-opdef-integerpart\nwebidl.util.IntegerPart = function (n) {\n // 1. Let r be floor(abs(n)).\n const r = Math.floor(Math.abs(n))\n\n // 2. If n < 0, then return -1 × r.\n if (n < 0) {\n return -1 * r\n }\n\n // 3. Otherwise, return r.\n return r\n}\n\n// https://webidl.spec.whatwg.org/#es-sequence\nwebidl.sequenceConverter = function (converter) {\n return (V) => {\n // 1. If Type(V) is not Object, throw a TypeError.\n if (webidl.util.Type(V) !== 'Object') {\n throw webidl.errors.exception({\n header: 'Sequence',\n message: `Value of type ${webidl.util.Type(V)} is not an Object.`\n })\n }\n\n // 2. Let method be ? GetMethod(V, @@iterator).\n /** @type {Generator} */\n const method = V?.[Symbol.iterator]?.()\n const seq = []\n\n // 3. If method is undefined, throw a TypeError.\n if (\n method === undefined ||\n typeof method.next !== 'function'\n ) {\n throw webidl.errors.exception({\n header: 'Sequence',\n message: 'Object is not an iterator.'\n })\n }\n\n // https://webidl.spec.whatwg.org/#create-sequence-from-iterable\n while (true) {\n const { done, value } = method.next()\n\n if (done) {\n break\n }\n\n seq.push(converter(value))\n }\n\n return seq\n }\n}\n\n// https://webidl.spec.whatwg.org/#es-to-record\nwebidl.recordConverter = function (keyConverter, valueConverter) {\n return (O) => {\n // 1. If Type(O) is not Object, throw a TypeError.\n if (webidl.util.Type(O) !== 'Object') {\n throw webidl.errors.exception({\n header: 'Record',\n message: `Value of type ${webidl.util.Type(O)} is not an Object.`\n })\n }\n\n // 2. Let result be a new empty instance of record.\n const result = {}\n\n if (!types.isProxy(O)) {\n // Object.keys only returns enumerable properties\n const keys = Object.keys(O)\n\n for (const key of keys) {\n // 1. Let typedKey be key converted to an IDL value of type K.\n const typedKey = keyConverter(key)\n\n // 2. Let value be ? Get(O, key).\n // 3. Let typedValue be value converted to an IDL value of type V.\n const typedValue = valueConverter(O[key])\n\n // 4. Set result[typedKey] to typedValue.\n result[typedKey] = typedValue\n }\n\n // 5. Return result.\n return result\n }\n\n // 3. Let keys be ? O.[[OwnPropertyKeys]]().\n const keys = Reflect.ownKeys(O)\n\n // 4. For each key of keys.\n for (const key of keys) {\n // 1. Let desc be ? O.[[GetOwnProperty]](key).\n const desc = Reflect.getOwnPropertyDescriptor(O, key)\n\n // 2. If desc is not undefined and desc.[[Enumerable]] is true:\n if (desc?.enumerable) {\n // 1. Let typedKey be key converted to an IDL value of type K.\n const typedKey = keyConverter(key)\n\n // 2. Let value be ? Get(O, key).\n // 3. Let typedValue be value converted to an IDL value of type V.\n const typedValue = valueConverter(O[key])\n\n // 4. Set result[typedKey] to typedValue.\n result[typedKey] = typedValue\n }\n }\n\n // 5. Return result.\n return result\n }\n}\n\nwebidl.interfaceConverter = function (i) {\n return (V, opts = {}) => {\n if (opts.strict !== false && !(V instanceof i)) {\n throw webidl.errors.exception({\n header: i.name,\n message: `Expected ${V} to be an instance of ${i.name}.`\n })\n }\n\n return V\n }\n}\n\nwebidl.dictionaryConverter = function (converters) {\n return (dictionary) => {\n const type = webidl.util.Type(dictionary)\n const dict = {}\n\n if (type === 'Null' || type === 'Undefined') {\n return dict\n } else if (type !== 'Object') {\n throw webidl.errors.exception({\n header: 'Dictionary',\n message: `Expected ${dictionary} to be one of: Null, Undefined, Object.`\n })\n }\n\n for (const options of converters) {\n const { key, defaultValue, required, converter } = options\n\n if (required === true) {\n if (!hasOwn(dictionary, key)) {\n throw webidl.errors.exception({\n header: 'Dictionary',\n message: `Missing required key \"${key}\".`\n })\n }\n }\n\n let value = dictionary[key]\n const hasDefault = hasOwn(options, 'defaultValue')\n\n // Only use defaultValue if value is undefined and\n // a defaultValue options was provided.\n if (hasDefault && value !== null) {\n value = value ?? defaultValue\n }\n\n // A key can be optional and have no default value.\n // When this happens, do not perform a conversion,\n // and do not assign the key a value.\n if (required || hasDefault || value !== undefined) {\n value = converter(value)\n\n if (\n options.allowedValues &&\n !options.allowedValues.includes(value)\n ) {\n throw webidl.errors.exception({\n header: 'Dictionary',\n message: `${value} is not an accepted type. Expected one of ${options.allowedValues.join(', ')}.`\n })\n }\n\n dict[key] = value\n }\n }\n\n return dict\n }\n}\n\nwebidl.nullableConverter = function (converter) {\n return (V) => {\n if (V === null) {\n return V\n }\n\n return converter(V)\n }\n}\n\n// https://webidl.spec.whatwg.org/#es-DOMString\nwebidl.converters.DOMString = function (V, opts = {}) {\n // 1. If V is null and the conversion is to an IDL type\n // associated with the [LegacyNullToEmptyString]\n // extended attribute, then return the DOMString value\n // that represents the empty string.\n if (V === null && opts.legacyNullToEmptyString) {\n return ''\n }\n\n // 2. Let x be ? ToString(V).\n if (typeof V === 'symbol') {\n throw new TypeError('Could not convert argument of type symbol to string.')\n }\n\n // 3. Return the IDL DOMString value that represents the\n // same sequence of code units as the one the\n // ECMAScript String value x represents.\n return String(V)\n}\n\n// https://webidl.spec.whatwg.org/#es-ByteString\nwebidl.converters.ByteString = function (V) {\n // 1. Let x be ? ToString(V).\n // Note: DOMString converter perform ? ToString(V)\n const x = webidl.converters.DOMString(V)\n\n // 2. If the value of any element of x is greater than\n // 255, then throw a TypeError.\n for (let index = 0; index < x.length; index++) {\n if (x.charCodeAt(index) > 255) {\n throw new TypeError(\n 'Cannot convert argument to a ByteString because the character at ' +\n `index ${index} has a value of ${x.charCodeAt(index)} which is greater than 255.`\n )\n }\n }\n\n // 3. Return an IDL ByteString value whose length is the\n // length of x, and where the value of each element is\n // the value of the corresponding element of x.\n return x\n}\n\n// https://webidl.spec.whatwg.org/#es-USVString\nwebidl.converters.USVString = toUSVString\n\n// https://webidl.spec.whatwg.org/#es-boolean\nwebidl.converters.boolean = function (V) {\n // 1. Let x be the result of computing ToBoolean(V).\n const x = Boolean(V)\n\n // 2. Return the IDL boolean value that is the one that represents\n // the same truth value as the ECMAScript Boolean value x.\n return x\n}\n\n// https://webidl.spec.whatwg.org/#es-any\nwebidl.converters.any = function (V) {\n return V\n}\n\n// https://webidl.spec.whatwg.org/#es-long-long\nwebidl.converters['long long'] = function (V) {\n // 1. Let x be ? ConvertToInt(V, 64, \"signed\").\n const x = webidl.util.ConvertToInt(V, 64, 'signed')\n\n // 2. Return the IDL long long value that represents\n // the same numeric value as x.\n return x\n}\n\n// https://webidl.spec.whatwg.org/#es-unsigned-long-long\nwebidl.converters['unsigned long long'] = function (V) {\n // 1. Let x be ? ConvertToInt(V, 64, \"unsigned\").\n const x = webidl.util.ConvertToInt(V, 64, 'unsigned')\n\n // 2. Return the IDL unsigned long long value that\n // represents the same numeric value as x.\n return x\n}\n\n// https://webidl.spec.whatwg.org/#es-unsigned-long\nwebidl.converters['unsigned long'] = function (V) {\n // 1. Let x be ? ConvertToInt(V, 32, \"unsigned\").\n const x = webidl.util.ConvertToInt(V, 32, 'unsigned')\n\n // 2. Return the IDL unsigned long value that\n // represents the same numeric value as x.\n return x\n}\n\n// https://webidl.spec.whatwg.org/#es-unsigned-short\nwebidl.converters['unsigned short'] = function (V, opts) {\n // 1. Let x be ? ConvertToInt(V, 16, \"unsigned\").\n const x = webidl.util.ConvertToInt(V, 16, 'unsigned', opts)\n\n // 2. Return the IDL unsigned short value that represents\n // the same numeric value as x.\n return x\n}\n\n// https://webidl.spec.whatwg.org/#idl-ArrayBuffer\nwebidl.converters.ArrayBuffer = function (V, opts = {}) {\n // 1. If Type(V) is not Object, or V does not have an\n // [[ArrayBufferData]] internal slot, then throw a\n // TypeError.\n // see: https://tc39.es/ecma262/#sec-properties-of-the-arraybuffer-instances\n // see: https://tc39.es/ecma262/#sec-properties-of-the-sharedarraybuffer-instances\n if (\n webidl.util.Type(V) !== 'Object' ||\n !types.isAnyArrayBuffer(V)\n ) {\n throw webidl.errors.conversionFailed({\n prefix: `${V}`,\n argument: `${V}`,\n types: ['ArrayBuffer']\n })\n }\n\n // 2. If the conversion is not to an IDL type associated\n // with the [AllowShared] extended attribute, and\n // IsSharedArrayBuffer(V) is true, then throw a\n // TypeError.\n if (opts.allowShared === false && types.isSharedArrayBuffer(V)) {\n throw webidl.errors.exception({\n header: 'ArrayBuffer',\n message: 'SharedArrayBuffer is not allowed.'\n })\n }\n\n // 3. If the conversion is not to an IDL type associated\n // with the [AllowResizable] extended attribute, and\n // IsResizableArrayBuffer(V) is true, then throw a\n // TypeError.\n // Note: resizable ArrayBuffers are currently a proposal.\n\n // 4. Return the IDL ArrayBuffer value that is a\n // reference to the same object as V.\n return V\n}\n\nwebidl.converters.TypedArray = function (V, T, opts = {}) {\n // 1. Let T be the IDL type V is being converted to.\n\n // 2. If Type(V) is not Object, or V does not have a\n // [[TypedArrayName]] internal slot with a value\n // equal to T’s name, then throw a TypeError.\n if (\n webidl.util.Type(V) !== 'Object' ||\n !types.isTypedArray(V) ||\n V.constructor.name !== T.name\n ) {\n throw webidl.errors.conversionFailed({\n prefix: `${T.name}`,\n argument: `${V}`,\n types: [T.name]\n })\n }\n\n // 3. If the conversion is not to an IDL type associated\n // with the [AllowShared] extended attribute, and\n // IsSharedArrayBuffer(V.[[ViewedArrayBuffer]]) is\n // true, then throw a TypeError.\n if (opts.allowShared === false && types.isSharedArrayBuffer(V.buffer)) {\n throw webidl.errors.exception({\n header: 'ArrayBuffer',\n message: 'SharedArrayBuffer is not allowed.'\n })\n }\n\n // 4. If the conversion is not to an IDL type associated\n // with the [AllowResizable] extended attribute, and\n // IsResizableArrayBuffer(V.[[ViewedArrayBuffer]]) is\n // true, then throw a TypeError.\n // Note: resizable array buffers are currently a proposal\n\n // 5. Return the IDL value of type T that is a reference\n // to the same object as V.\n return V\n}\n\nwebidl.converters.DataView = function (V, opts = {}) {\n // 1. If Type(V) is not Object, or V does not have a\n // [[DataView]] internal slot, then throw a TypeError.\n if (webidl.util.Type(V) !== 'Object' || !types.isDataView(V)) {\n throw webidl.errors.exception({\n header: 'DataView',\n message: 'Object is not a DataView.'\n })\n }\n\n // 2. If the conversion is not to an IDL type associated\n // with the [AllowShared] extended attribute, and\n // IsSharedArrayBuffer(V.[[ViewedArrayBuffer]]) is true,\n // then throw a TypeError.\n if (opts.allowShared === false && types.isSharedArrayBuffer(V.buffer)) {\n throw webidl.errors.exception({\n header: 'ArrayBuffer',\n message: 'SharedArrayBuffer is not allowed.'\n })\n }\n\n // 3. If the conversion is not to an IDL type associated\n // with the [AllowResizable] extended attribute, and\n // IsResizableArrayBuffer(V.[[ViewedArrayBuffer]]) is\n // true, then throw a TypeError.\n // Note: resizable ArrayBuffers are currently a proposal\n\n // 4. Return the IDL DataView value that is a reference\n // to the same object as V.\n return V\n}\n\n// https://webidl.spec.whatwg.org/#BufferSource\nwebidl.converters.BufferSource = function (V, opts = {}) {\n if (types.isAnyArrayBuffer(V)) {\n return webidl.converters.ArrayBuffer(V, opts)\n }\n\n if (types.isTypedArray(V)) {\n return webidl.converters.TypedArray(V, V.constructor)\n }\n\n if (types.isDataView(V)) {\n return webidl.converters.DataView(V, opts)\n }\n\n throw new TypeError(`Could not convert ${V} to a BufferSource.`)\n}\n\nwebidl.converters['sequence'] = webidl.sequenceConverter(\n webidl.converters.ByteString\n)\n\nwebidl.converters['sequence>'] = webidl.sequenceConverter(\n webidl.converters['sequence']\n)\n\nwebidl.converters['record'] = webidl.recordConverter(\n webidl.converters.ByteString,\n webidl.converters.ByteString\n)\n\nmodule.exports = {\n webidl\n}\n","'use strict'\n\n/**\n * @see https://encoding.spec.whatwg.org/#concept-encoding-get\n * @param {string|undefined} label\n */\nfunction getEncoding (label) {\n if (!label) {\n return 'failure'\n }\n\n // 1. Remove any leading and trailing ASCII whitespace from label.\n // 2. If label is an ASCII case-insensitive match for any of the\n // labels listed in the table below, then return the\n // corresponding encoding; otherwise return failure.\n switch (label.trim().toLowerCase()) {\n case 'unicode-1-1-utf-8':\n case 'unicode11utf8':\n case 'unicode20utf8':\n case 'utf-8':\n case 'utf8':\n case 'x-unicode20utf8':\n return 'UTF-8'\n case '866':\n case 'cp866':\n case 'csibm866':\n case 'ibm866':\n return 'IBM866'\n case 'csisolatin2':\n case 'iso-8859-2':\n case 'iso-ir-101':\n case 'iso8859-2':\n case 'iso88592':\n case 'iso_8859-2':\n case 'iso_8859-2:1987':\n case 'l2':\n case 'latin2':\n return 'ISO-8859-2'\n case 'csisolatin3':\n case 'iso-8859-3':\n case 'iso-ir-109':\n case 'iso8859-3':\n case 'iso88593':\n case 'iso_8859-3':\n case 'iso_8859-3:1988':\n case 'l3':\n case 'latin3':\n return 'ISO-8859-3'\n case 'csisolatin4':\n case 'iso-8859-4':\n case 'iso-ir-110':\n case 'iso8859-4':\n case 'iso88594':\n case 'iso_8859-4':\n case 'iso_8859-4:1988':\n case 'l4':\n case 'latin4':\n return 'ISO-8859-4'\n case 'csisolatincyrillic':\n case 'cyrillic':\n case 'iso-8859-5':\n case 'iso-ir-144':\n case 'iso8859-5':\n case 'iso88595':\n case 'iso_8859-5':\n case 'iso_8859-5:1988':\n return 'ISO-8859-5'\n case 'arabic':\n case 'asmo-708':\n case 'csiso88596e':\n case 'csiso88596i':\n case 'csisolatinarabic':\n case 'ecma-114':\n case 'iso-8859-6':\n case 'iso-8859-6-e':\n case 'iso-8859-6-i':\n case 'iso-ir-127':\n case 'iso8859-6':\n case 'iso88596':\n case 'iso_8859-6':\n case 'iso_8859-6:1987':\n return 'ISO-8859-6'\n case 'csisolatingreek':\n case 'ecma-118':\n case 'elot_928':\n case 'greek':\n case 'greek8':\n case 'iso-8859-7':\n case 'iso-ir-126':\n case 'iso8859-7':\n case 'iso88597':\n case 'iso_8859-7':\n case 'iso_8859-7:1987':\n case 'sun_eu_greek':\n return 'ISO-8859-7'\n case 'csiso88598e':\n case 'csisolatinhebrew':\n case 'hebrew':\n case 'iso-8859-8':\n case 'iso-8859-8-e':\n case 'iso-ir-138':\n case 'iso8859-8':\n case 'iso88598':\n case 'iso_8859-8':\n case 'iso_8859-8:1988':\n case 'visual':\n return 'ISO-8859-8'\n case 'csiso88598i':\n case 'iso-8859-8-i':\n case 'logical':\n return 'ISO-8859-8-I'\n case 'csisolatin6':\n case 'iso-8859-10':\n case 'iso-ir-157':\n case 'iso8859-10':\n case 'iso885910':\n case 'l6':\n case 'latin6':\n return 'ISO-8859-10'\n case 'iso-8859-13':\n case 'iso8859-13':\n case 'iso885913':\n return 'ISO-8859-13'\n case 'iso-8859-14':\n case 'iso8859-14':\n case 'iso885914':\n return 'ISO-8859-14'\n case 'csisolatin9':\n case 'iso-8859-15':\n case 'iso8859-15':\n case 'iso885915':\n case 'iso_8859-15':\n case 'l9':\n return 'ISO-8859-15'\n case 'iso-8859-16':\n return 'ISO-8859-16'\n case 'cskoi8r':\n case 'koi':\n case 'koi8':\n case 'koi8-r':\n case 'koi8_r':\n return 'KOI8-R'\n case 'koi8-ru':\n case 'koi8-u':\n return 'KOI8-U'\n case 'csmacintosh':\n case 'mac':\n case 'macintosh':\n case 'x-mac-roman':\n return 'macintosh'\n case 'iso-8859-11':\n case 'iso8859-11':\n case 'iso885911':\n case 'tis-620':\n case 'windows-874':\n return 'windows-874'\n case 'cp1250':\n case 'windows-1250':\n case 'x-cp1250':\n return 'windows-1250'\n case 'cp1251':\n case 'windows-1251':\n case 'x-cp1251':\n return 'windows-1251'\n case 'ansi_x3.4-1968':\n case 'ascii':\n case 'cp1252':\n case 'cp819':\n case 'csisolatin1':\n case 'ibm819':\n case 'iso-8859-1':\n case 'iso-ir-100':\n case 'iso8859-1':\n case 'iso88591':\n case 'iso_8859-1':\n case 'iso_8859-1:1987':\n case 'l1':\n case 'latin1':\n case 'us-ascii':\n case 'windows-1252':\n case 'x-cp1252':\n return 'windows-1252'\n case 'cp1253':\n case 'windows-1253':\n case 'x-cp1253':\n return 'windows-1253'\n case 'cp1254':\n case 'csisolatin5':\n case 'iso-8859-9':\n case 'iso-ir-148':\n case 'iso8859-9':\n case 'iso88599':\n case 'iso_8859-9':\n case 'iso_8859-9:1989':\n case 'l5':\n case 'latin5':\n case 'windows-1254':\n case 'x-cp1254':\n return 'windows-1254'\n case 'cp1255':\n case 'windows-1255':\n case 'x-cp1255':\n return 'windows-1255'\n case 'cp1256':\n case 'windows-1256':\n case 'x-cp1256':\n return 'windows-1256'\n case 'cp1257':\n case 'windows-1257':\n case 'x-cp1257':\n return 'windows-1257'\n case 'cp1258':\n case 'windows-1258':\n case 'x-cp1258':\n return 'windows-1258'\n case 'x-mac-cyrillic':\n case 'x-mac-ukrainian':\n return 'x-mac-cyrillic'\n case 'chinese':\n case 'csgb2312':\n case 'csiso58gb231280':\n case 'gb2312':\n case 'gb_2312':\n case 'gb_2312-80':\n case 'gbk':\n case 'iso-ir-58':\n case 'x-gbk':\n return 'GBK'\n case 'gb18030':\n return 'gb18030'\n case 'big5':\n case 'big5-hkscs':\n case 'cn-big5':\n case 'csbig5':\n case 'x-x-big5':\n return 'Big5'\n case 'cseucpkdfmtjapanese':\n case 'euc-jp':\n case 'x-euc-jp':\n return 'EUC-JP'\n case 'csiso2022jp':\n case 'iso-2022-jp':\n return 'ISO-2022-JP'\n case 'csshiftjis':\n case 'ms932':\n case 'ms_kanji':\n case 'shift-jis':\n case 'shift_jis':\n case 'sjis':\n case 'windows-31j':\n case 'x-sjis':\n return 'Shift_JIS'\n case 'cseuckr':\n case 'csksc56011987':\n case 'euc-kr':\n case 'iso-ir-149':\n case 'korean':\n case 'ks_c_5601-1987':\n case 'ks_c_5601-1989':\n case 'ksc5601':\n case 'ksc_5601':\n case 'windows-949':\n return 'EUC-KR'\n case 'csiso2022kr':\n case 'hz-gb-2312':\n case 'iso-2022-cn':\n case 'iso-2022-cn-ext':\n case 'iso-2022-kr':\n case 'replacement':\n return 'replacement'\n case 'unicodefffe':\n case 'utf-16be':\n return 'UTF-16BE'\n case 'csunicode':\n case 'iso-10646-ucs-2':\n case 'ucs-2':\n case 'unicode':\n case 'unicodefeff':\n case 'utf-16':\n case 'utf-16le':\n return 'UTF-16LE'\n case 'x-user-defined':\n return 'x-user-defined'\n default: return 'failure'\n }\n}\n\nmodule.exports = {\n getEncoding\n}\n","'use strict'\n\nconst {\n staticPropertyDescriptors,\n readOperation,\n fireAProgressEvent\n} = require('./util')\nconst {\n kState,\n kError,\n kResult,\n kEvents,\n kAborted\n} = require('./symbols')\nconst { webidl } = require('../fetch/webidl')\nconst { kEnumerableProperty } = require('../core/util')\n\nclass FileReader extends EventTarget {\n constructor () {\n super()\n\n this[kState] = 'empty'\n this[kResult] = null\n this[kError] = null\n this[kEvents] = {\n loadend: null,\n error: null,\n abort: null,\n load: null,\n progress: null,\n loadstart: null\n }\n }\n\n /**\n * @see https://w3c.github.io/FileAPI/#dfn-readAsArrayBuffer\n * @param {import('buffer').Blob} blob\n */\n readAsArrayBuffer (blob) {\n webidl.brandCheck(this, FileReader)\n\n webidl.argumentLengthCheck(arguments, 1, { header: 'FileReader.readAsArrayBuffer' })\n\n blob = webidl.converters.Blob(blob, { strict: false })\n\n // The readAsArrayBuffer(blob) method, when invoked,\n // must initiate a read operation for blob with ArrayBuffer.\n readOperation(this, blob, 'ArrayBuffer')\n }\n\n /**\n * @see https://w3c.github.io/FileAPI/#readAsBinaryString\n * @param {import('buffer').Blob} blob\n */\n readAsBinaryString (blob) {\n webidl.brandCheck(this, FileReader)\n\n webidl.argumentLengthCheck(arguments, 1, { header: 'FileReader.readAsBinaryString' })\n\n blob = webidl.converters.Blob(blob, { strict: false })\n\n // The readAsBinaryString(blob) method, when invoked,\n // must initiate a read operation for blob with BinaryString.\n readOperation(this, blob, 'BinaryString')\n }\n\n /**\n * @see https://w3c.github.io/FileAPI/#readAsDataText\n * @param {import('buffer').Blob} blob\n * @param {string?} encoding\n */\n readAsText (blob, encoding = undefined) {\n webidl.brandCheck(this, FileReader)\n\n webidl.argumentLengthCheck(arguments, 1, { header: 'FileReader.readAsText' })\n\n blob = webidl.converters.Blob(blob, { strict: false })\n\n if (encoding !== undefined) {\n encoding = webidl.converters.DOMString(encoding)\n }\n\n // The readAsText(blob, encoding) method, when invoked,\n // must initiate a read operation for blob with Text and encoding.\n readOperation(this, blob, 'Text', encoding)\n }\n\n /**\n * @see https://w3c.github.io/FileAPI/#dfn-readAsDataURL\n * @param {import('buffer').Blob} blob\n */\n readAsDataURL (blob) {\n webidl.brandCheck(this, FileReader)\n\n webidl.argumentLengthCheck(arguments, 1, { header: 'FileReader.readAsDataURL' })\n\n blob = webidl.converters.Blob(blob, { strict: false })\n\n // The readAsDataURL(blob) method, when invoked, must\n // initiate a read operation for blob with DataURL.\n readOperation(this, blob, 'DataURL')\n }\n\n /**\n * @see https://w3c.github.io/FileAPI/#dfn-abort\n */\n abort () {\n // 1. If this's state is \"empty\" or if this's state is\n // \"done\" set this's result to null and terminate\n // this algorithm.\n if (this[kState] === 'empty' || this[kState] === 'done') {\n this[kResult] = null\n return\n }\n\n // 2. If this's state is \"loading\" set this's state to\n // \"done\" and set this's result to null.\n if (this[kState] === 'loading') {\n this[kState] = 'done'\n this[kResult] = null\n }\n\n // 3. If there are any tasks from this on the file reading\n // task source in an affiliated task queue, then remove\n // those tasks from that task queue.\n this[kAborted] = true\n\n // 4. Terminate the algorithm for the read method being processed.\n // TODO\n\n // 5. Fire a progress event called abort at this.\n fireAProgressEvent('abort', this)\n\n // 6. If this's state is not \"loading\", fire a progress\n // event called loadend at this.\n if (this[kState] !== 'loading') {\n fireAProgressEvent('loadend', this)\n }\n }\n\n /**\n * @see https://w3c.github.io/FileAPI/#dom-filereader-readystate\n */\n get readyState () {\n webidl.brandCheck(this, FileReader)\n\n switch (this[kState]) {\n case 'empty': return this.EMPTY\n case 'loading': return this.LOADING\n case 'done': return this.DONE\n }\n }\n\n /**\n * @see https://w3c.github.io/FileAPI/#dom-filereader-result\n */\n get result () {\n webidl.brandCheck(this, FileReader)\n\n // The result attribute’s getter, when invoked, must return\n // this's result.\n return this[kResult]\n }\n\n /**\n * @see https://w3c.github.io/FileAPI/#dom-filereader-error\n */\n get error () {\n webidl.brandCheck(this, FileReader)\n\n // The error attribute’s getter, when invoked, must return\n // this's error.\n return this[kError]\n }\n\n get onloadend () {\n webidl.brandCheck(this, FileReader)\n\n return this[kEvents].loadend\n }\n\n set onloadend (fn) {\n webidl.brandCheck(this, FileReader)\n\n if (this[kEvents].loadend) {\n this.removeEventListener('loadend', this[kEvents].loadend)\n }\n\n if (typeof fn === 'function') {\n this[kEvents].loadend = fn\n this.addEventListener('loadend', fn)\n } else {\n this[kEvents].loadend = null\n }\n }\n\n get onerror () {\n webidl.brandCheck(this, FileReader)\n\n return this[kEvents].error\n }\n\n set onerror (fn) {\n webidl.brandCheck(this, FileReader)\n\n if (this[kEvents].error) {\n this.removeEventListener('error', this[kEvents].error)\n }\n\n if (typeof fn === 'function') {\n this[kEvents].error = fn\n this.addEventListener('error', fn)\n } else {\n this[kEvents].error = null\n }\n }\n\n get onloadstart () {\n webidl.brandCheck(this, FileReader)\n\n return this[kEvents].loadstart\n }\n\n set onloadstart (fn) {\n webidl.brandCheck(this, FileReader)\n\n if (this[kEvents].loadstart) {\n this.removeEventListener('loadstart', this[kEvents].loadstart)\n }\n\n if (typeof fn === 'function') {\n this[kEvents].loadstart = fn\n this.addEventListener('loadstart', fn)\n } else {\n this[kEvents].loadstart = null\n }\n }\n\n get onprogress () {\n webidl.brandCheck(this, FileReader)\n\n return this[kEvents].progress\n }\n\n set onprogress (fn) {\n webidl.brandCheck(this, FileReader)\n\n if (this[kEvents].progress) {\n this.removeEventListener('progress', this[kEvents].progress)\n }\n\n if (typeof fn === 'function') {\n this[kEvents].progress = fn\n this.addEventListener('progress', fn)\n } else {\n this[kEvents].progress = null\n }\n }\n\n get onload () {\n webidl.brandCheck(this, FileReader)\n\n return this[kEvents].load\n }\n\n set onload (fn) {\n webidl.brandCheck(this, FileReader)\n\n if (this[kEvents].load) {\n this.removeEventListener('load', this[kEvents].load)\n }\n\n if (typeof fn === 'function') {\n this[kEvents].load = fn\n this.addEventListener('load', fn)\n } else {\n this[kEvents].load = null\n }\n }\n\n get onabort () {\n webidl.brandCheck(this, FileReader)\n\n return this[kEvents].abort\n }\n\n set onabort (fn) {\n webidl.brandCheck(this, FileReader)\n\n if (this[kEvents].abort) {\n this.removeEventListener('abort', this[kEvents].abort)\n }\n\n if (typeof fn === 'function') {\n this[kEvents].abort = fn\n this.addEventListener('abort', fn)\n } else {\n this[kEvents].abort = null\n }\n }\n}\n\n// https://w3c.github.io/FileAPI/#dom-filereader-empty\nFileReader.EMPTY = FileReader.prototype.EMPTY = 0\n// https://w3c.github.io/FileAPI/#dom-filereader-loading\nFileReader.LOADING = FileReader.prototype.LOADING = 1\n// https://w3c.github.io/FileAPI/#dom-filereader-done\nFileReader.DONE = FileReader.prototype.DONE = 2\n\nObject.defineProperties(FileReader.prototype, {\n EMPTY: staticPropertyDescriptors,\n LOADING: staticPropertyDescriptors,\n DONE: staticPropertyDescriptors,\n readAsArrayBuffer: kEnumerableProperty,\n readAsBinaryString: kEnumerableProperty,\n readAsText: kEnumerableProperty,\n readAsDataURL: kEnumerableProperty,\n abort: kEnumerableProperty,\n readyState: kEnumerableProperty,\n result: kEnumerableProperty,\n error: kEnumerableProperty,\n onloadstart: kEnumerableProperty,\n onprogress: kEnumerableProperty,\n onload: kEnumerableProperty,\n onabort: kEnumerableProperty,\n onerror: kEnumerableProperty,\n onloadend: kEnumerableProperty,\n [Symbol.toStringTag]: {\n value: 'FileReader',\n writable: false,\n enumerable: false,\n configurable: true\n }\n})\n\nObject.defineProperties(FileReader, {\n EMPTY: staticPropertyDescriptors,\n LOADING: staticPropertyDescriptors,\n DONE: staticPropertyDescriptors\n})\n\nmodule.exports = {\n FileReader\n}\n","'use strict'\n\nconst { webidl } = require('../fetch/webidl')\n\nconst kState = Symbol('ProgressEvent state')\n\n/**\n * @see https://xhr.spec.whatwg.org/#progressevent\n */\nclass ProgressEvent extends Event {\n constructor (type, eventInitDict = {}) {\n type = webidl.converters.DOMString(type)\n eventInitDict = webidl.converters.ProgressEventInit(eventInitDict ?? {})\n\n super(type, eventInitDict)\n\n this[kState] = {\n lengthComputable: eventInitDict.lengthComputable,\n loaded: eventInitDict.loaded,\n total: eventInitDict.total\n }\n }\n\n get lengthComputable () {\n webidl.brandCheck(this, ProgressEvent)\n\n return this[kState].lengthComputable\n }\n\n get loaded () {\n webidl.brandCheck(this, ProgressEvent)\n\n return this[kState].loaded\n }\n\n get total () {\n webidl.brandCheck(this, ProgressEvent)\n\n return this[kState].total\n }\n}\n\nwebidl.converters.ProgressEventInit = webidl.dictionaryConverter([\n {\n key: 'lengthComputable',\n converter: webidl.converters.boolean,\n defaultValue: false\n },\n {\n key: 'loaded',\n converter: webidl.converters['unsigned long long'],\n defaultValue: 0\n },\n {\n key: 'total',\n converter: webidl.converters['unsigned long long'],\n defaultValue: 0\n },\n {\n key: 'bubbles',\n converter: webidl.converters.boolean,\n defaultValue: false\n },\n {\n key: 'cancelable',\n converter: webidl.converters.boolean,\n defaultValue: false\n },\n {\n key: 'composed',\n converter: webidl.converters.boolean,\n defaultValue: false\n }\n])\n\nmodule.exports = {\n ProgressEvent\n}\n","'use strict'\n\nmodule.exports = {\n kState: Symbol('FileReader state'),\n kResult: Symbol('FileReader result'),\n kError: Symbol('FileReader error'),\n kLastProgressEventFired: Symbol('FileReader last progress event fired timestamp'),\n kEvents: Symbol('FileReader events'),\n kAborted: Symbol('FileReader aborted')\n}\n","'use strict'\n\nconst {\n kState,\n kError,\n kResult,\n kAborted,\n kLastProgressEventFired\n} = require('./symbols')\nconst { ProgressEvent } = require('./progressevent')\nconst { getEncoding } = require('./encoding')\nconst { DOMException } = require('../fetch/constants')\nconst { serializeAMimeType, parseMIMEType } = require('../fetch/dataURL')\nconst { types } = require('util')\nconst { StringDecoder } = require('string_decoder')\nconst { btoa } = require('buffer')\n\n/** @type {PropertyDescriptor} */\nconst staticPropertyDescriptors = {\n enumerable: true,\n writable: false,\n configurable: false\n}\n\n/**\n * @see https://w3c.github.io/FileAPI/#readOperation\n * @param {import('./filereader').FileReader} fr\n * @param {import('buffer').Blob} blob\n * @param {string} type\n * @param {string?} encodingName\n */\nfunction readOperation (fr, blob, type, encodingName) {\n // 1. If fr’s state is \"loading\", throw an InvalidStateError\n // DOMException.\n if (fr[kState] === 'loading') {\n throw new DOMException('Invalid state', 'InvalidStateError')\n }\n\n // 2. Set fr’s state to \"loading\".\n fr[kState] = 'loading'\n\n // 3. Set fr’s result to null.\n fr[kResult] = null\n\n // 4. Set fr’s error to null.\n fr[kError] = null\n\n // 5. Let stream be the result of calling get stream on blob.\n /** @type {import('stream/web').ReadableStream} */\n const stream = blob.stream()\n\n // 6. Let reader be the result of getting a reader from stream.\n const reader = stream.getReader()\n\n // 7. Let bytes be an empty byte sequence.\n /** @type {Uint8Array[]} */\n const bytes = []\n\n // 8. Let chunkPromise be the result of reading a chunk from\n // stream with reader.\n let chunkPromise = reader.read()\n\n // 9. Let isFirstChunk be true.\n let isFirstChunk = true\n\n // 10. In parallel, while true:\n // Note: \"In parallel\" just means non-blocking\n // Note 2: readOperation itself cannot be async as double\n // reading the body would then reject the promise, instead\n // of throwing an error.\n ;(async () => {\n while (!fr[kAborted]) {\n // 1. Wait for chunkPromise to be fulfilled or rejected.\n try {\n const { done, value } = await chunkPromise\n\n // 2. If chunkPromise is fulfilled, and isFirstChunk is\n // true, queue a task to fire a progress event called\n // loadstart at fr.\n if (isFirstChunk && !fr[kAborted]) {\n queueMicrotask(() => {\n fireAProgressEvent('loadstart', fr)\n })\n }\n\n // 3. Set isFirstChunk to false.\n isFirstChunk = false\n\n // 4. If chunkPromise is fulfilled with an object whose\n // done property is false and whose value property is\n // a Uint8Array object, run these steps:\n if (!done && types.isUint8Array(value)) {\n // 1. Let bs be the byte sequence represented by the\n // Uint8Array object.\n\n // 2. Append bs to bytes.\n bytes.push(value)\n\n // 3. If roughly 50ms have passed since these steps\n // were last invoked, queue a task to fire a\n // progress event called progress at fr.\n if (\n (\n fr[kLastProgressEventFired] === undefined ||\n Date.now() - fr[kLastProgressEventFired] >= 50\n ) &&\n !fr[kAborted]\n ) {\n fr[kLastProgressEventFired] = Date.now()\n queueMicrotask(() => {\n fireAProgressEvent('progress', fr)\n })\n }\n\n // 4. Set chunkPromise to the result of reading a\n // chunk from stream with reader.\n chunkPromise = reader.read()\n } else if (done) {\n // 5. Otherwise, if chunkPromise is fulfilled with an\n // object whose done property is true, queue a task\n // to run the following steps and abort this algorithm:\n queueMicrotask(() => {\n // 1. Set fr’s state to \"done\".\n fr[kState] = 'done'\n\n // 2. Let result be the result of package data given\n // bytes, type, blob’s type, and encodingName.\n try {\n const result = packageData(bytes, type, blob.type, encodingName)\n\n // 4. Else:\n\n if (fr[kAborted]) {\n return\n }\n\n // 1. Set fr’s result to result.\n fr[kResult] = result\n\n // 2. Fire a progress event called load at the fr.\n fireAProgressEvent('load', fr)\n } catch (error) {\n // 3. If package data threw an exception error:\n\n // 1. Set fr’s error to error.\n fr[kError] = error\n\n // 2. Fire a progress event called error at fr.\n fireAProgressEvent('error', fr)\n }\n\n // 5. If fr’s state is not \"loading\", fire a progress\n // event called loadend at the fr.\n if (fr[kState] !== 'loading') {\n fireAProgressEvent('loadend', fr)\n }\n })\n\n break\n }\n } catch (error) {\n if (fr[kAborted]) {\n return\n }\n\n // 6. Otherwise, if chunkPromise is rejected with an\n // error error, queue a task to run the following\n // steps and abort this algorithm:\n queueMicrotask(() => {\n // 1. Set fr’s state to \"done\".\n fr[kState] = 'done'\n\n // 2. Set fr’s error to error.\n fr[kError] = error\n\n // 3. Fire a progress event called error at fr.\n fireAProgressEvent('error', fr)\n\n // 4. If fr’s state is not \"loading\", fire a progress\n // event called loadend at fr.\n if (fr[kState] !== 'loading') {\n fireAProgressEvent('loadend', fr)\n }\n })\n\n break\n }\n }\n })()\n}\n\n/**\n * @see https://w3c.github.io/FileAPI/#fire-a-progress-event\n * @see https://dom.spec.whatwg.org/#concept-event-fire\n * @param {string} e The name of the event\n * @param {import('./filereader').FileReader} reader\n */\nfunction fireAProgressEvent (e, reader) {\n // The progress event e does not bubble. e.bubbles must be false\n // The progress event e is NOT cancelable. e.cancelable must be false\n const event = new ProgressEvent(e, {\n bubbles: false,\n cancelable: false\n })\n\n reader.dispatchEvent(event)\n}\n\n/**\n * @see https://w3c.github.io/FileAPI/#blob-package-data\n * @param {Uint8Array[]} bytes\n * @param {string} type\n * @param {string?} mimeType\n * @param {string?} encodingName\n */\nfunction packageData (bytes, type, mimeType, encodingName) {\n // 1. A Blob has an associated package data algorithm, given\n // bytes, a type, a optional mimeType, and a optional\n // encodingName, which switches on type and runs the\n // associated steps:\n\n switch (type) {\n case 'DataURL': {\n // 1. Return bytes as a DataURL [RFC2397] subject to\n // the considerations below:\n // * Use mimeType as part of the Data URL if it is\n // available in keeping with the Data URL\n // specification [RFC2397].\n // * If mimeType is not available return a Data URL\n // without a media-type. [RFC2397].\n\n // https://datatracker.ietf.org/doc/html/rfc2397#section-3\n // dataurl := \"data:\" [ mediatype ] [ \";base64\" ] \",\" data\n // mediatype := [ type \"/\" subtype ] *( \";\" parameter )\n // data := *urlchar\n // parameter := attribute \"=\" value\n let dataURL = 'data:'\n\n const parsed = parseMIMEType(mimeType || 'application/octet-stream')\n\n if (parsed !== 'failure') {\n dataURL += serializeAMimeType(parsed)\n }\n\n dataURL += ';base64,'\n\n const decoder = new StringDecoder('latin1')\n\n for (const chunk of bytes) {\n dataURL += btoa(decoder.write(chunk))\n }\n\n dataURL += btoa(decoder.end())\n\n return dataURL\n }\n case 'Text': {\n // 1. Let encoding be failure\n let encoding = 'failure'\n\n // 2. If the encodingName is present, set encoding to the\n // result of getting an encoding from encodingName.\n if (encodingName) {\n encoding = getEncoding(encodingName)\n }\n\n // 3. If encoding is failure, and mimeType is present:\n if (encoding === 'failure' && mimeType) {\n // 1. Let type be the result of parse a MIME type\n // given mimeType.\n const type = parseMIMEType(mimeType)\n\n // 2. If type is not failure, set encoding to the result\n // of getting an encoding from type’s parameters[\"charset\"].\n if (type !== 'failure') {\n encoding = getEncoding(type.parameters.get('charset'))\n }\n }\n\n // 4. If encoding is failure, then set encoding to UTF-8.\n if (encoding === 'failure') {\n encoding = 'UTF-8'\n }\n\n // 5. Decode bytes using fallback encoding encoding, and\n // return the result.\n return decode(bytes, encoding)\n }\n case 'ArrayBuffer': {\n // Return a new ArrayBuffer whose contents are bytes.\n const sequence = combineByteSequences(bytes)\n\n return sequence.buffer\n }\n case 'BinaryString': {\n // Return bytes as a binary string, in which every byte\n // is represented by a code unit of equal value [0..255].\n let binaryString = ''\n\n const decoder = new StringDecoder('latin1')\n\n for (const chunk of bytes) {\n binaryString += decoder.write(chunk)\n }\n\n binaryString += decoder.end()\n\n return binaryString\n }\n }\n}\n\n/**\n * @see https://encoding.spec.whatwg.org/#decode\n * @param {Uint8Array[]} ioQueue\n * @param {string} encoding\n */\nfunction decode (ioQueue, encoding) {\n const bytes = combineByteSequences(ioQueue)\n\n // 1. Let BOMEncoding be the result of BOM sniffing ioQueue.\n const BOMEncoding = BOMSniffing(bytes)\n\n let slice = 0\n\n // 2. If BOMEncoding is non-null:\n if (BOMEncoding !== null) {\n // 1. Set encoding to BOMEncoding.\n encoding = BOMEncoding\n\n // 2. Read three bytes from ioQueue, if BOMEncoding is\n // UTF-8; otherwise read two bytes.\n // (Do nothing with those bytes.)\n slice = BOMEncoding === 'UTF-8' ? 3 : 2\n }\n\n // 3. Process a queue with an instance of encoding’s\n // decoder, ioQueue, output, and \"replacement\".\n\n // 4. Return output.\n\n const sliced = bytes.slice(slice)\n return new TextDecoder(encoding).decode(sliced)\n}\n\n/**\n * @see https://encoding.spec.whatwg.org/#bom-sniff\n * @param {Uint8Array} ioQueue\n */\nfunction BOMSniffing (ioQueue) {\n // 1. Let BOM be the result of peeking 3 bytes from ioQueue,\n // converted to a byte sequence.\n const [a, b, c] = ioQueue\n\n // 2. For each of the rows in the table below, starting with\n // the first one and going down, if BOM starts with the\n // bytes given in the first column, then return the\n // encoding given in the cell in the second column of that\n // row. Otherwise, return null.\n if (a === 0xEF && b === 0xBB && c === 0xBF) {\n return 'UTF-8'\n } else if (a === 0xFE && b === 0xFF) {\n return 'UTF-16BE'\n } else if (a === 0xFF && b === 0xFE) {\n return 'UTF-16LE'\n }\n\n return null\n}\n\n/**\n * @param {Uint8Array[]} sequences\n */\nfunction combineByteSequences (sequences) {\n const size = sequences.reduce((a, b) => {\n return a + b.byteLength\n }, 0)\n\n let offset = 0\n\n return sequences.reduce((a, b) => {\n a.set(b, offset)\n offset += b.byteLength\n return a\n }, new Uint8Array(size))\n}\n\nmodule.exports = {\n staticPropertyDescriptors,\n readOperation,\n fireAProgressEvent\n}\n","'use strict'\n\n// We include a version number for the Dispatcher API. In case of breaking changes,\n// this version number must be increased to avoid conflicts.\nconst globalDispatcher = Symbol.for('undici.globalDispatcher.1')\nconst { InvalidArgumentError } = require('./core/errors')\nconst Agent = require('./agent')\n\nif (getGlobalDispatcher() === undefined) {\n setGlobalDispatcher(new Agent())\n}\n\nfunction setGlobalDispatcher (agent) {\n if (!agent || typeof agent.dispatch !== 'function') {\n throw new InvalidArgumentError('Argument agent must implement Agent')\n }\n Object.defineProperty(globalThis, globalDispatcher, {\n value: agent,\n writable: true,\n enumerable: false,\n configurable: false\n })\n}\n\nfunction getGlobalDispatcher () {\n return globalThis[globalDispatcher]\n}\n\nmodule.exports = {\n setGlobalDispatcher,\n getGlobalDispatcher\n}\n","'use strict'\n\nmodule.exports = class DecoratorHandler {\n constructor (handler) {\n this.handler = handler\n }\n\n onConnect (...args) {\n return this.handler.onConnect(...args)\n }\n\n onError (...args) {\n return this.handler.onError(...args)\n }\n\n onUpgrade (...args) {\n return this.handler.onUpgrade(...args)\n }\n\n onHeaders (...args) {\n return this.handler.onHeaders(...args)\n }\n\n onData (...args) {\n return this.handler.onData(...args)\n }\n\n onComplete (...args) {\n return this.handler.onComplete(...args)\n }\n\n onBodySent (...args) {\n return this.handler.onBodySent(...args)\n }\n}\n","'use strict'\n\nconst util = require('../core/util')\nconst { kBodyUsed } = require('../core/symbols')\nconst assert = require('assert')\nconst { InvalidArgumentError } = require('../core/errors')\nconst EE = require('events')\n\nconst redirectableStatusCodes = [300, 301, 302, 303, 307, 308]\n\nconst kBody = Symbol('body')\n\nclass BodyAsyncIterable {\n constructor (body) {\n this[kBody] = body\n this[kBodyUsed] = false\n }\n\n async * [Symbol.asyncIterator] () {\n assert(!this[kBodyUsed], 'disturbed')\n this[kBodyUsed] = true\n yield * this[kBody]\n }\n}\n\nclass RedirectHandler {\n constructor (dispatch, maxRedirections, opts, handler) {\n if (maxRedirections != null && (!Number.isInteger(maxRedirections) || maxRedirections < 0)) {\n throw new InvalidArgumentError('maxRedirections must be a positive number')\n }\n\n util.validateHandler(handler, opts.method, opts.upgrade)\n\n this.dispatch = dispatch\n this.location = null\n this.abort = null\n this.opts = { ...opts, maxRedirections: 0 } // opts must be a copy\n this.maxRedirections = maxRedirections\n this.handler = handler\n this.history = []\n\n if (util.isStream(this.opts.body)) {\n // TODO (fix): Provide some way for the user to cache the file to e.g. /tmp\n // so that it can be dispatched again?\n // TODO (fix): Do we need 100-expect support to provide a way to do this properly?\n if (util.bodyLength(this.opts.body) === 0) {\n this.opts.body\n .on('data', function () {\n assert(false)\n })\n }\n\n if (typeof this.opts.body.readableDidRead !== 'boolean') {\n this.opts.body[kBodyUsed] = false\n EE.prototype.on.call(this.opts.body, 'data', function () {\n this[kBodyUsed] = true\n })\n }\n } else if (this.opts.body && typeof this.opts.body.pipeTo === 'function') {\n // TODO (fix): We can't access ReadableStream internal state\n // to determine whether or not it has been disturbed. This is just\n // a workaround.\n this.opts.body = new BodyAsyncIterable(this.opts.body)\n } else if (\n this.opts.body &&\n typeof this.opts.body !== 'string' &&\n !ArrayBuffer.isView(this.opts.body) &&\n util.isIterable(this.opts.body)\n ) {\n // TODO: Should we allow re-using iterable if !this.opts.idempotent\n // or through some other flag?\n this.opts.body = new BodyAsyncIterable(this.opts.body)\n }\n }\n\n onConnect (abort) {\n this.abort = abort\n this.handler.onConnect(abort, { history: this.history })\n }\n\n onUpgrade (statusCode, headers, socket) {\n this.handler.onUpgrade(statusCode, headers, socket)\n }\n\n onError (error) {\n this.handler.onError(error)\n }\n\n onHeaders (statusCode, headers, resume, statusText) {\n this.location = this.history.length >= this.maxRedirections || util.isDisturbed(this.opts.body)\n ? null\n : parseLocation(statusCode, headers)\n\n if (this.opts.origin) {\n this.history.push(new URL(this.opts.path, this.opts.origin))\n }\n\n if (!this.location) {\n return this.handler.onHeaders(statusCode, headers, resume, statusText)\n }\n\n const { origin, pathname, search } = util.parseURL(new URL(this.location, this.opts.origin && new URL(this.opts.path, this.opts.origin)))\n const path = search ? `${pathname}${search}` : pathname\n\n // Remove headers referring to the original URL.\n // By default it is Host only, unless it's a 303 (see below), which removes also all Content-* headers.\n // https://tools.ietf.org/html/rfc7231#section-6.4\n this.opts.headers = cleanRequestHeaders(this.opts.headers, statusCode === 303, this.opts.origin !== origin)\n this.opts.path = path\n this.opts.origin = origin\n this.opts.maxRedirections = 0\n this.opts.query = null\n\n // https://tools.ietf.org/html/rfc7231#section-6.4.4\n // In case of HTTP 303, always replace method to be either HEAD or GET\n if (statusCode === 303 && this.opts.method !== 'HEAD') {\n this.opts.method = 'GET'\n this.opts.body = null\n }\n }\n\n onData (chunk) {\n if (this.location) {\n /*\n https://tools.ietf.org/html/rfc7231#section-6.4\n\n TLDR: undici always ignores 3xx response bodies.\n\n Redirection is used to serve the requested resource from another URL, so it is assumes that\n no body is generated (and thus can be ignored). Even though generating a body is not prohibited.\n\n For status 301, 302, 303, 307 and 308 (the latter from RFC 7238), the specs mention that the body usually\n (which means it's optional and not mandated) contain just an hyperlink to the value of\n the Location response header, so the body can be ignored safely.\n\n For status 300, which is \"Multiple Choices\", the spec mentions both generating a Location\n response header AND a response body with the other possible location to follow.\n Since the spec explicitily chooses not to specify a format for such body and leave it to\n servers and browsers implementors, we ignore the body as there is no specified way to eventually parse it.\n */\n } else {\n return this.handler.onData(chunk)\n }\n }\n\n onComplete (trailers) {\n if (this.location) {\n /*\n https://tools.ietf.org/html/rfc7231#section-6.4\n\n TLDR: undici always ignores 3xx response trailers as they are not expected in case of redirections\n and neither are useful if present.\n\n See comment on onData method above for more detailed informations.\n */\n\n this.location = null\n this.abort = null\n\n this.dispatch(this.opts, this)\n } else {\n this.handler.onComplete(trailers)\n }\n }\n\n onBodySent (chunk) {\n if (this.handler.onBodySent) {\n this.handler.onBodySent(chunk)\n }\n }\n}\n\nfunction parseLocation (statusCode, headers) {\n if (redirectableStatusCodes.indexOf(statusCode) === -1) {\n return null\n }\n\n for (let i = 0; i < headers.length; i += 2) {\n if (headers[i].toString().toLowerCase() === 'location') {\n return headers[i + 1]\n }\n }\n}\n\n// https://tools.ietf.org/html/rfc7231#section-6.4.4\nfunction shouldRemoveHeader (header, removeContent, unknownOrigin) {\n return (\n (header.length === 4 && header.toString().toLowerCase() === 'host') ||\n (removeContent && header.toString().toLowerCase().indexOf('content-') === 0) ||\n (unknownOrigin && header.length === 13 && header.toString().toLowerCase() === 'authorization') ||\n (unknownOrigin && header.length === 6 && header.toString().toLowerCase() === 'cookie')\n )\n}\n\n// https://tools.ietf.org/html/rfc7231#section-6.4\nfunction cleanRequestHeaders (headers, removeContent, unknownOrigin) {\n const ret = []\n if (Array.isArray(headers)) {\n for (let i = 0; i < headers.length; i += 2) {\n if (!shouldRemoveHeader(headers[i], removeContent, unknownOrigin)) {\n ret.push(headers[i], headers[i + 1])\n }\n }\n } else if (headers && typeof headers === 'object') {\n for (const key of Object.keys(headers)) {\n if (!shouldRemoveHeader(key, removeContent, unknownOrigin)) {\n ret.push(key, headers[key])\n }\n }\n } else {\n assert(headers == null, 'headers must be an object or an array')\n }\n return ret\n}\n\nmodule.exports = RedirectHandler\n","const assert = require('assert')\n\nconst { kRetryHandlerDefaultRetry } = require('../core/symbols')\nconst { RequestRetryError } = require('../core/errors')\nconst { isDisturbed, parseHeaders, parseRangeHeader } = require('../core/util')\n\nfunction calculateRetryAfterHeader (retryAfter) {\n const current = Date.now()\n const diff = new Date(retryAfter).getTime() - current\n\n return diff\n}\n\nclass RetryHandler {\n constructor (opts, handlers) {\n const { retryOptions, ...dispatchOpts } = opts\n const {\n // Retry scoped\n retry: retryFn,\n maxRetries,\n maxTimeout,\n minTimeout,\n timeoutFactor,\n // Response scoped\n methods,\n errorCodes,\n retryAfter,\n statusCodes\n } = retryOptions ?? {}\n\n this.dispatch = handlers.dispatch\n this.handler = handlers.handler\n this.opts = dispatchOpts\n this.abort = null\n this.aborted = false\n this.retryOpts = {\n retry: retryFn ?? RetryHandler[kRetryHandlerDefaultRetry],\n retryAfter: retryAfter ?? true,\n maxTimeout: maxTimeout ?? 30 * 1000, // 30s,\n timeout: minTimeout ?? 500, // .5s\n timeoutFactor: timeoutFactor ?? 2,\n maxRetries: maxRetries ?? 5,\n // What errors we should retry\n methods: methods ?? ['GET', 'HEAD', 'OPTIONS', 'PUT', 'DELETE', 'TRACE'],\n // Indicates which errors to retry\n statusCodes: statusCodes ?? [500, 502, 503, 504, 429],\n // List of errors to retry\n errorCodes: errorCodes ?? [\n 'ECONNRESET',\n 'ECONNREFUSED',\n 'ENOTFOUND',\n 'ENETDOWN',\n 'ENETUNREACH',\n 'EHOSTDOWN',\n 'EHOSTUNREACH',\n 'EPIPE'\n ]\n }\n\n this.retryCount = 0\n this.start = 0\n this.end = null\n this.etag = null\n this.resume = null\n\n // Handle possible onConnect duplication\n this.handler.onConnect(reason => {\n this.aborted = true\n if (this.abort) {\n this.abort(reason)\n } else {\n this.reason = reason\n }\n })\n }\n\n onRequestSent () {\n if (this.handler.onRequestSent) {\n this.handler.onRequestSent()\n }\n }\n\n onUpgrade (statusCode, headers, socket) {\n if (this.handler.onUpgrade) {\n this.handler.onUpgrade(statusCode, headers, socket)\n }\n }\n\n onConnect (abort) {\n if (this.aborted) {\n abort(this.reason)\n } else {\n this.abort = abort\n }\n }\n\n onBodySent (chunk) {\n if (this.handler.onBodySent) return this.handler.onBodySent(chunk)\n }\n\n static [kRetryHandlerDefaultRetry] (err, { state, opts }, cb) {\n const { statusCode, code, headers } = err\n const { method, retryOptions } = opts\n const {\n maxRetries,\n timeout,\n maxTimeout,\n timeoutFactor,\n statusCodes,\n errorCodes,\n methods\n } = retryOptions\n let { counter, currentTimeout } = state\n\n currentTimeout =\n currentTimeout != null && currentTimeout > 0 ? currentTimeout : timeout\n\n // Any code that is not a Undici's originated and allowed to retry\n if (\n code &&\n code !== 'UND_ERR_REQ_RETRY' &&\n code !== 'UND_ERR_SOCKET' &&\n !errorCodes.includes(code)\n ) {\n cb(err)\n return\n }\n\n // If a set of method are provided and the current method is not in the list\n if (Array.isArray(methods) && !methods.includes(method)) {\n cb(err)\n return\n }\n\n // If a set of status code are provided and the current status code is not in the list\n if (\n statusCode != null &&\n Array.isArray(statusCodes) &&\n !statusCodes.includes(statusCode)\n ) {\n cb(err)\n return\n }\n\n // If we reached the max number of retries\n if (counter > maxRetries) {\n cb(err)\n return\n }\n\n let retryAfterHeader = headers != null && headers['retry-after']\n if (retryAfterHeader) {\n retryAfterHeader = Number(retryAfterHeader)\n retryAfterHeader = isNaN(retryAfterHeader)\n ? calculateRetryAfterHeader(retryAfterHeader)\n : retryAfterHeader * 1e3 // Retry-After is in seconds\n }\n\n const retryTimeout =\n retryAfterHeader > 0\n ? Math.min(retryAfterHeader, maxTimeout)\n : Math.min(currentTimeout * timeoutFactor ** counter, maxTimeout)\n\n state.currentTimeout = retryTimeout\n\n setTimeout(() => cb(null), retryTimeout)\n }\n\n onHeaders (statusCode, rawHeaders, resume, statusMessage) {\n const headers = parseHeaders(rawHeaders)\n\n this.retryCount += 1\n\n if (statusCode >= 300) {\n this.abort(\n new RequestRetryError('Request failed', statusCode, {\n headers,\n count: this.retryCount\n })\n )\n return false\n }\n\n // Checkpoint for resume from where we left it\n if (this.resume != null) {\n this.resume = null\n\n if (statusCode !== 206) {\n return true\n }\n\n const contentRange = parseRangeHeader(headers['content-range'])\n // If no content range\n if (!contentRange) {\n this.abort(\n new RequestRetryError('Content-Range mismatch', statusCode, {\n headers,\n count: this.retryCount\n })\n )\n return false\n }\n\n // Let's start with a weak etag check\n if (this.etag != null && this.etag !== headers.etag) {\n this.abort(\n new RequestRetryError('ETag mismatch', statusCode, {\n headers,\n count: this.retryCount\n })\n )\n return false\n }\n\n const { start, size, end = size } = contentRange\n\n assert(this.start === start, 'content-range mismatch')\n assert(this.end == null || this.end === end, 'content-range mismatch')\n\n this.resume = resume\n return true\n }\n\n if (this.end == null) {\n if (statusCode === 206) {\n // First time we receive 206\n const range = parseRangeHeader(headers['content-range'])\n\n if (range == null) {\n return this.handler.onHeaders(\n statusCode,\n rawHeaders,\n resume,\n statusMessage\n )\n }\n\n const { start, size, end = size } = range\n\n assert(\n start != null && Number.isFinite(start) && this.start !== start,\n 'content-range mismatch'\n )\n assert(Number.isFinite(start))\n assert(\n end != null && Number.isFinite(end) && this.end !== end,\n 'invalid content-length'\n )\n\n this.start = start\n this.end = end\n }\n\n // We make our best to checkpoint the body for further range headers\n if (this.end == null) {\n const contentLength = headers['content-length']\n this.end = contentLength != null ? Number(contentLength) : null\n }\n\n assert(Number.isFinite(this.start))\n assert(\n this.end == null || Number.isFinite(this.end),\n 'invalid content-length'\n )\n\n this.resume = resume\n this.etag = headers.etag != null ? headers.etag : null\n\n return this.handler.onHeaders(\n statusCode,\n rawHeaders,\n resume,\n statusMessage\n )\n }\n\n const err = new RequestRetryError('Request failed', statusCode, {\n headers,\n count: this.retryCount\n })\n\n this.abort(err)\n\n return false\n }\n\n onData (chunk) {\n this.start += chunk.length\n\n return this.handler.onData(chunk)\n }\n\n onComplete (rawTrailers) {\n this.retryCount = 0\n return this.handler.onComplete(rawTrailers)\n }\n\n onError (err) {\n if (this.aborted || isDisturbed(this.opts.body)) {\n return this.handler.onError(err)\n }\n\n this.retryOpts.retry(\n err,\n {\n state: { counter: this.retryCount++, currentTimeout: this.retryAfter },\n opts: { retryOptions: this.retryOpts, ...this.opts }\n },\n onRetry.bind(this)\n )\n\n function onRetry (err) {\n if (err != null || this.aborted || isDisturbed(this.opts.body)) {\n return this.handler.onError(err)\n }\n\n if (this.start !== 0) {\n this.opts = {\n ...this.opts,\n headers: {\n ...this.opts.headers,\n range: `bytes=${this.start}-${this.end ?? ''}`\n }\n }\n }\n\n try {\n this.dispatch(this.opts, this)\n } catch (err) {\n this.handler.onError(err)\n }\n }\n }\n}\n\nmodule.exports = RetryHandler\n","'use strict'\n\nconst RedirectHandler = require('../handler/RedirectHandler')\n\nfunction createRedirectInterceptor ({ maxRedirections: defaultMaxRedirections }) {\n return (dispatch) => {\n return function Intercept (opts, handler) {\n const { maxRedirections = defaultMaxRedirections } = opts\n\n if (!maxRedirections) {\n return dispatch(opts, handler)\n }\n\n const redirectHandler = new RedirectHandler(dispatch, maxRedirections, opts, handler)\n opts = { ...opts, maxRedirections: 0 } // Stop sub dispatcher from also redirecting.\n return dispatch(opts, redirectHandler)\n }\n }\n}\n\nmodule.exports = createRedirectInterceptor\n","\"use strict\";\nObject.defineProperty(exports, \"__esModule\", { value: true });\nexports.SPECIAL_HEADERS = exports.HEADER_STATE = exports.MINOR = exports.MAJOR = exports.CONNECTION_TOKEN_CHARS = exports.HEADER_CHARS = exports.TOKEN = exports.STRICT_TOKEN = exports.HEX = exports.URL_CHAR = exports.STRICT_URL_CHAR = exports.USERINFO_CHARS = exports.MARK = exports.ALPHANUM = exports.NUM = exports.HEX_MAP = exports.NUM_MAP = exports.ALPHA = exports.FINISH = exports.H_METHOD_MAP = exports.METHOD_MAP = exports.METHODS_RTSP = exports.METHODS_ICE = exports.METHODS_HTTP = exports.METHODS = exports.LENIENT_FLAGS = exports.FLAGS = exports.TYPE = exports.ERROR = void 0;\nconst utils_1 = require(\"./utils\");\n// C headers\nvar ERROR;\n(function (ERROR) {\n ERROR[ERROR[\"OK\"] = 0] = \"OK\";\n ERROR[ERROR[\"INTERNAL\"] = 1] = \"INTERNAL\";\n ERROR[ERROR[\"STRICT\"] = 2] = \"STRICT\";\n ERROR[ERROR[\"LF_EXPECTED\"] = 3] = \"LF_EXPECTED\";\n ERROR[ERROR[\"UNEXPECTED_CONTENT_LENGTH\"] = 4] = \"UNEXPECTED_CONTENT_LENGTH\";\n ERROR[ERROR[\"CLOSED_CONNECTION\"] = 5] = \"CLOSED_CONNECTION\";\n ERROR[ERROR[\"INVALID_METHOD\"] = 6] = \"INVALID_METHOD\";\n ERROR[ERROR[\"INVALID_URL\"] = 7] = \"INVALID_URL\";\n ERROR[ERROR[\"INVALID_CONSTANT\"] = 8] = \"INVALID_CONSTANT\";\n ERROR[ERROR[\"INVALID_VERSION\"] = 9] = \"INVALID_VERSION\";\n ERROR[ERROR[\"INVALID_HEADER_TOKEN\"] = 10] = \"INVALID_HEADER_TOKEN\";\n ERROR[ERROR[\"INVALID_CONTENT_LENGTH\"] = 11] = \"INVALID_CONTENT_LENGTH\";\n ERROR[ERROR[\"INVALID_CHUNK_SIZE\"] = 12] = \"INVALID_CHUNK_SIZE\";\n ERROR[ERROR[\"INVALID_STATUS\"] = 13] = \"INVALID_STATUS\";\n ERROR[ERROR[\"INVALID_EOF_STATE\"] = 14] = \"INVALID_EOF_STATE\";\n ERROR[ERROR[\"INVALID_TRANSFER_ENCODING\"] = 15] = \"INVALID_TRANSFER_ENCODING\";\n ERROR[ERROR[\"CB_MESSAGE_BEGIN\"] = 16] = \"CB_MESSAGE_BEGIN\";\n ERROR[ERROR[\"CB_HEADERS_COMPLETE\"] = 17] = \"CB_HEADERS_COMPLETE\";\n ERROR[ERROR[\"CB_MESSAGE_COMPLETE\"] = 18] = \"CB_MESSAGE_COMPLETE\";\n ERROR[ERROR[\"CB_CHUNK_HEADER\"] = 19] = \"CB_CHUNK_HEADER\";\n ERROR[ERROR[\"CB_CHUNK_COMPLETE\"] = 20] = \"CB_CHUNK_COMPLETE\";\n ERROR[ERROR[\"PAUSED\"] = 21] = \"PAUSED\";\n ERROR[ERROR[\"PAUSED_UPGRADE\"] = 22] = \"PAUSED_UPGRADE\";\n ERROR[ERROR[\"PAUSED_H2_UPGRADE\"] = 23] = \"PAUSED_H2_UPGRADE\";\n ERROR[ERROR[\"USER\"] = 24] = \"USER\";\n})(ERROR = exports.ERROR || (exports.ERROR = {}));\nvar TYPE;\n(function (TYPE) {\n TYPE[TYPE[\"BOTH\"] = 0] = \"BOTH\";\n TYPE[TYPE[\"REQUEST\"] = 1] = \"REQUEST\";\n TYPE[TYPE[\"RESPONSE\"] = 2] = \"RESPONSE\";\n})(TYPE = exports.TYPE || (exports.TYPE = {}));\nvar FLAGS;\n(function (FLAGS) {\n FLAGS[FLAGS[\"CONNECTION_KEEP_ALIVE\"] = 1] = \"CONNECTION_KEEP_ALIVE\";\n FLAGS[FLAGS[\"CONNECTION_CLOSE\"] = 2] = \"CONNECTION_CLOSE\";\n FLAGS[FLAGS[\"CONNECTION_UPGRADE\"] = 4] = \"CONNECTION_UPGRADE\";\n FLAGS[FLAGS[\"CHUNKED\"] = 8] = \"CHUNKED\";\n FLAGS[FLAGS[\"UPGRADE\"] = 16] = \"UPGRADE\";\n FLAGS[FLAGS[\"CONTENT_LENGTH\"] = 32] = \"CONTENT_LENGTH\";\n FLAGS[FLAGS[\"SKIPBODY\"] = 64] = \"SKIPBODY\";\n FLAGS[FLAGS[\"TRAILING\"] = 128] = \"TRAILING\";\n // 1 << 8 is unused\n FLAGS[FLAGS[\"TRANSFER_ENCODING\"] = 512] = \"TRANSFER_ENCODING\";\n})(FLAGS = exports.FLAGS || (exports.FLAGS = {}));\nvar LENIENT_FLAGS;\n(function (LENIENT_FLAGS) {\n LENIENT_FLAGS[LENIENT_FLAGS[\"HEADERS\"] = 1] = \"HEADERS\";\n LENIENT_FLAGS[LENIENT_FLAGS[\"CHUNKED_LENGTH\"] = 2] = \"CHUNKED_LENGTH\";\n LENIENT_FLAGS[LENIENT_FLAGS[\"KEEP_ALIVE\"] = 4] = \"KEEP_ALIVE\";\n})(LENIENT_FLAGS = exports.LENIENT_FLAGS || (exports.LENIENT_FLAGS = {}));\nvar METHODS;\n(function (METHODS) {\n METHODS[METHODS[\"DELETE\"] = 0] = \"DELETE\";\n METHODS[METHODS[\"GET\"] = 1] = \"GET\";\n METHODS[METHODS[\"HEAD\"] = 2] = \"HEAD\";\n METHODS[METHODS[\"POST\"] = 3] = \"POST\";\n METHODS[METHODS[\"PUT\"] = 4] = \"PUT\";\n /* pathological */\n METHODS[METHODS[\"CONNECT\"] = 5] = \"CONNECT\";\n METHODS[METHODS[\"OPTIONS\"] = 6] = \"OPTIONS\";\n METHODS[METHODS[\"TRACE\"] = 7] = \"TRACE\";\n /* WebDAV */\n METHODS[METHODS[\"COPY\"] = 8] = \"COPY\";\n METHODS[METHODS[\"LOCK\"] = 9] = \"LOCK\";\n METHODS[METHODS[\"MKCOL\"] = 10] = \"MKCOL\";\n METHODS[METHODS[\"MOVE\"] = 11] = \"MOVE\";\n METHODS[METHODS[\"PROPFIND\"] = 12] = \"PROPFIND\";\n METHODS[METHODS[\"PROPPATCH\"] = 13] = \"PROPPATCH\";\n METHODS[METHODS[\"SEARCH\"] = 14] = \"SEARCH\";\n METHODS[METHODS[\"UNLOCK\"] = 15] = \"UNLOCK\";\n METHODS[METHODS[\"BIND\"] = 16] = \"BIND\";\n METHODS[METHODS[\"REBIND\"] = 17] = \"REBIND\";\n METHODS[METHODS[\"UNBIND\"] = 18] = \"UNBIND\";\n METHODS[METHODS[\"ACL\"] = 19] = \"ACL\";\n /* subversion */\n METHODS[METHODS[\"REPORT\"] = 20] = \"REPORT\";\n METHODS[METHODS[\"MKACTIVITY\"] = 21] = \"MKACTIVITY\";\n METHODS[METHODS[\"CHECKOUT\"] = 22] = \"CHECKOUT\";\n METHODS[METHODS[\"MERGE\"] = 23] = \"MERGE\";\n /* upnp */\n METHODS[METHODS[\"M-SEARCH\"] = 24] = \"M-SEARCH\";\n METHODS[METHODS[\"NOTIFY\"] = 25] = \"NOTIFY\";\n METHODS[METHODS[\"SUBSCRIBE\"] = 26] = \"SUBSCRIBE\";\n METHODS[METHODS[\"UNSUBSCRIBE\"] = 27] = \"UNSUBSCRIBE\";\n /* RFC-5789 */\n METHODS[METHODS[\"PATCH\"] = 28] = \"PATCH\";\n METHODS[METHODS[\"PURGE\"] = 29] = \"PURGE\";\n /* CalDAV */\n METHODS[METHODS[\"MKCALENDAR\"] = 30] = \"MKCALENDAR\";\n /* RFC-2068, section 19.6.1.2 */\n METHODS[METHODS[\"LINK\"] = 31] = \"LINK\";\n METHODS[METHODS[\"UNLINK\"] = 32] = \"UNLINK\";\n /* icecast */\n METHODS[METHODS[\"SOURCE\"] = 33] = \"SOURCE\";\n /* RFC-7540, section 11.6 */\n METHODS[METHODS[\"PRI\"] = 34] = \"PRI\";\n /* RFC-2326 RTSP */\n METHODS[METHODS[\"DESCRIBE\"] = 35] = \"DESCRIBE\";\n METHODS[METHODS[\"ANNOUNCE\"] = 36] = \"ANNOUNCE\";\n METHODS[METHODS[\"SETUP\"] = 37] = \"SETUP\";\n METHODS[METHODS[\"PLAY\"] = 38] = \"PLAY\";\n METHODS[METHODS[\"PAUSE\"] = 39] = \"PAUSE\";\n METHODS[METHODS[\"TEARDOWN\"] = 40] = \"TEARDOWN\";\n METHODS[METHODS[\"GET_PARAMETER\"] = 41] = \"GET_PARAMETER\";\n METHODS[METHODS[\"SET_PARAMETER\"] = 42] = \"SET_PARAMETER\";\n METHODS[METHODS[\"REDIRECT\"] = 43] = \"REDIRECT\";\n METHODS[METHODS[\"RECORD\"] = 44] = \"RECORD\";\n /* RAOP */\n METHODS[METHODS[\"FLUSH\"] = 45] = \"FLUSH\";\n})(METHODS = exports.METHODS || (exports.METHODS = {}));\nexports.METHODS_HTTP = [\n METHODS.DELETE,\n METHODS.GET,\n METHODS.HEAD,\n METHODS.POST,\n METHODS.PUT,\n METHODS.CONNECT,\n METHODS.OPTIONS,\n METHODS.TRACE,\n METHODS.COPY,\n METHODS.LOCK,\n METHODS.MKCOL,\n METHODS.MOVE,\n METHODS.PROPFIND,\n METHODS.PROPPATCH,\n METHODS.SEARCH,\n METHODS.UNLOCK,\n METHODS.BIND,\n METHODS.REBIND,\n METHODS.UNBIND,\n METHODS.ACL,\n METHODS.REPORT,\n METHODS.MKACTIVITY,\n METHODS.CHECKOUT,\n METHODS.MERGE,\n METHODS['M-SEARCH'],\n METHODS.NOTIFY,\n METHODS.SUBSCRIBE,\n METHODS.UNSUBSCRIBE,\n METHODS.PATCH,\n METHODS.PURGE,\n METHODS.MKCALENDAR,\n METHODS.LINK,\n METHODS.UNLINK,\n METHODS.PRI,\n // TODO(indutny): should we allow it with HTTP?\n METHODS.SOURCE,\n];\nexports.METHODS_ICE = [\n METHODS.SOURCE,\n];\nexports.METHODS_RTSP = [\n METHODS.OPTIONS,\n METHODS.DESCRIBE,\n METHODS.ANNOUNCE,\n METHODS.SETUP,\n METHODS.PLAY,\n METHODS.PAUSE,\n METHODS.TEARDOWN,\n METHODS.GET_PARAMETER,\n METHODS.SET_PARAMETER,\n METHODS.REDIRECT,\n METHODS.RECORD,\n METHODS.FLUSH,\n // For AirPlay\n METHODS.GET,\n METHODS.POST,\n];\nexports.METHOD_MAP = utils_1.enumToMap(METHODS);\nexports.H_METHOD_MAP = {};\nObject.keys(exports.METHOD_MAP).forEach((key) => {\n if (/^H/.test(key)) {\n exports.H_METHOD_MAP[key] = exports.METHOD_MAP[key];\n }\n});\nvar FINISH;\n(function (FINISH) {\n FINISH[FINISH[\"SAFE\"] = 0] = \"SAFE\";\n FINISH[FINISH[\"SAFE_WITH_CB\"] = 1] = \"SAFE_WITH_CB\";\n FINISH[FINISH[\"UNSAFE\"] = 2] = \"UNSAFE\";\n})(FINISH = exports.FINISH || (exports.FINISH = {}));\nexports.ALPHA = [];\nfor (let i = 'A'.charCodeAt(0); i <= 'Z'.charCodeAt(0); i++) {\n // Upper case\n exports.ALPHA.push(String.fromCharCode(i));\n // Lower case\n exports.ALPHA.push(String.fromCharCode(i + 0x20));\n}\nexports.NUM_MAP = {\n 0: 0, 1: 1, 2: 2, 3: 3, 4: 4,\n 5: 5, 6: 6, 7: 7, 8: 8, 9: 9,\n};\nexports.HEX_MAP = {\n 0: 0, 1: 1, 2: 2, 3: 3, 4: 4,\n 5: 5, 6: 6, 7: 7, 8: 8, 9: 9,\n A: 0XA, B: 0XB, C: 0XC, D: 0XD, E: 0XE, F: 0XF,\n a: 0xa, b: 0xb, c: 0xc, d: 0xd, e: 0xe, f: 0xf,\n};\nexports.NUM = [\n '0', '1', '2', '3', '4', '5', '6', '7', '8', '9',\n];\nexports.ALPHANUM = exports.ALPHA.concat(exports.NUM);\nexports.MARK = ['-', '_', '.', '!', '~', '*', '\\'', '(', ')'];\nexports.USERINFO_CHARS = exports.ALPHANUM\n .concat(exports.MARK)\n .concat(['%', ';', ':', '&', '=', '+', '$', ',']);\n// TODO(indutny): use RFC\nexports.STRICT_URL_CHAR = [\n '!', '\"', '$', '%', '&', '\\'',\n '(', ')', '*', '+', ',', '-', '.', '/',\n ':', ';', '<', '=', '>',\n '@', '[', '\\\\', ']', '^', '_',\n '`',\n '{', '|', '}', '~',\n].concat(exports.ALPHANUM);\nexports.URL_CHAR = exports.STRICT_URL_CHAR\n .concat(['\\t', '\\f']);\n// All characters with 0x80 bit set to 1\nfor (let i = 0x80; i <= 0xff; i++) {\n exports.URL_CHAR.push(i);\n}\nexports.HEX = exports.NUM.concat(['a', 'b', 'c', 'd', 'e', 'f', 'A', 'B', 'C', 'D', 'E', 'F']);\n/* Tokens as defined by rfc 2616. Also lowercases them.\n * token = 1*\n * separators = \"(\" | \")\" | \"<\" | \">\" | \"@\"\n * | \",\" | \";\" | \":\" | \"\\\" | <\">\n * | \"/\" | \"[\" | \"]\" | \"?\" | \"=\"\n * | \"{\" | \"}\" | SP | HT\n */\nexports.STRICT_TOKEN = [\n '!', '#', '$', '%', '&', '\\'',\n '*', '+', '-', '.',\n '^', '_', '`',\n '|', '~',\n].concat(exports.ALPHANUM);\nexports.TOKEN = exports.STRICT_TOKEN.concat([' ']);\n/*\n * Verify that a char is a valid visible (printable) US-ASCII\n * character or %x80-FF\n */\nexports.HEADER_CHARS = ['\\t'];\nfor (let i = 32; i <= 255; i++) {\n if (i !== 127) {\n exports.HEADER_CHARS.push(i);\n }\n}\n// ',' = \\x44\nexports.CONNECTION_TOKEN_CHARS = exports.HEADER_CHARS.filter((c) => c !== 44);\nexports.MAJOR = exports.NUM_MAP;\nexports.MINOR = exports.MAJOR;\nvar HEADER_STATE;\n(function (HEADER_STATE) {\n HEADER_STATE[HEADER_STATE[\"GENERAL\"] = 0] = \"GENERAL\";\n HEADER_STATE[HEADER_STATE[\"CONNECTION\"] = 1] = \"CONNECTION\";\n HEADER_STATE[HEADER_STATE[\"CONTENT_LENGTH\"] = 2] = \"CONTENT_LENGTH\";\n HEADER_STATE[HEADER_STATE[\"TRANSFER_ENCODING\"] = 3] = \"TRANSFER_ENCODING\";\n HEADER_STATE[HEADER_STATE[\"UPGRADE\"] = 4] = \"UPGRADE\";\n HEADER_STATE[HEADER_STATE[\"CONNECTION_KEEP_ALIVE\"] = 5] = \"CONNECTION_KEEP_ALIVE\";\n HEADER_STATE[HEADER_STATE[\"CONNECTION_CLOSE\"] = 6] = \"CONNECTION_CLOSE\";\n HEADER_STATE[HEADER_STATE[\"CONNECTION_UPGRADE\"] = 7] = \"CONNECTION_UPGRADE\";\n HEADER_STATE[HEADER_STATE[\"TRANSFER_ENCODING_CHUNKED\"] = 8] = \"TRANSFER_ENCODING_CHUNKED\";\n})(HEADER_STATE = exports.HEADER_STATE || (exports.HEADER_STATE = {}));\nexports.SPECIAL_HEADERS = {\n 'connection': HEADER_STATE.CONNECTION,\n 'content-length': HEADER_STATE.CONTENT_LENGTH,\n 'proxy-connection': HEADER_STATE.CONNECTION,\n 'transfer-encoding': HEADER_STATE.TRANSFER_ENCODING,\n 'upgrade': HEADER_STATE.UPGRADE,\n};\n//# sourceMappingURL=constants.js.map","module.exports = 'AGFzbQEAAAABMAhgAX8Bf2ADf39/AX9gBH9/f38Bf2AAAGADf39/AGABfwBgAn9/AGAGf39/f39/AALLAQgDZW52GHdhc21fb25faGVhZGVyc19jb21wbGV0ZQACA2VudhV3YXNtX29uX21lc3NhZ2VfYmVnaW4AAANlbnYLd2FzbV9vbl91cmwAAQNlbnYOd2FzbV9vbl9zdGF0dXMAAQNlbnYUd2FzbV9vbl9oZWFkZXJfZmllbGQAAQNlbnYUd2FzbV9vbl9oZWFkZXJfdmFsdWUAAQNlbnYMd2FzbV9vbl9ib2R5AAEDZW52GHdhc21fb25fbWVzc2FnZV9jb21wbGV0ZQAAA0ZFAwMEAAAFAAAAAAAABQEFAAUFBQAABgAAAAAGBgYGAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQABAAABAQcAAAUFAwABBAUBcAESEgUDAQACBggBfwFBgNQECwfRBSIGbWVtb3J5AgALX2luaXRpYWxpemUACRlfX2luZGlyZWN0X2Z1bmN0aW9uX3RhYmxlAQALbGxodHRwX2luaXQAChhsbGh0dHBfc2hvdWxkX2tlZXBfYWxpdmUAQQxsbGh0dHBfYWxsb2MADAZtYWxsb2MARgtsbGh0dHBfZnJlZQANBGZyZWUASA9sbGh0dHBfZ2V0X3R5cGUADhVsbGh0dHBfZ2V0X2h0dHBfbWFqb3IADxVsbGh0dHBfZ2V0X2h0dHBfbWlub3IAEBFsbGh0dHBfZ2V0X21ldGhvZAARFmxsaHR0cF9nZXRfc3RhdHVzX2NvZGUAEhJsbGh0dHBfZ2V0X3VwZ3JhZGUAEwxsbGh0dHBfcmVzZXQAFA5sbGh0dHBfZXhlY3V0ZQAVFGxsaHR0cF9zZXR0aW5nc19pbml0ABYNbGxodHRwX2ZpbmlzaAAXDGxsaHR0cF9wYXVzZQAYDWxsaHR0cF9yZXN1bWUAGRtsbGh0dHBfcmVzdW1lX2FmdGVyX3VwZ3JhZGUAGhBsbGh0dHBfZ2V0X2Vycm5vABsXbGxodHRwX2dldF9lcnJvcl9yZWFzb24AHBdsbGh0dHBfc2V0X2Vycm9yX3JlYXNvbgAdFGxsaHR0cF9nZXRfZXJyb3JfcG9zAB4RbGxodHRwX2Vycm5vX25hbWUAHxJsbGh0dHBfbWV0aG9kX25hbWUAIBJs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ADcDACAAQShqQgA3AwAgAEEgakIANwMAIABBEGpCADcDACAAQQhqQgA3AwAgAEHdATYCHEEAC3sBAX8CQCAAKAIMIgMNAAJAIAAoAgRFDQAgACABNgIECwJAIAAgASACEMSAgIAAIgMNACAAKAIMDwsgACADNgIcQQAhAyAAKAIEIgFFDQAgACABIAIgACgCCBGBgICAAAAiAUUNACAAIAI2AhQgACABNgIMIAEhAwsgAwvk8wEDDn8DfgR/I4CAgIAAQRBrIgMkgICAgAAgASEEIAEhBSABIQYgASEHIAEhCCABIQkgASEKIAEhCyABIQwgASENIAEhDiABIQ8CQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkAgACgCHCIQQX9qDt0B2gEB2QECAwQFBgcICQoLDA0O2AEPENcBERLWARMUFRYXGBkaG+AB3wEcHR7VAR8gISIjJCXUASYnKCkqKyzTAdIBLS7RAdABLzAxMjM0NTY3ODk6Ozw9Pj9AQUJDREVG2wFHSElKzwHOAUvNAUzMAU1OT1BRUlNUVVZXWFlaW1xdXl9gYWJjZGVmZ2hpamtsbW5vcHFyc3R1dnd4eXp7fH1+f4ABgQGCAYMBhAGFAYYBhwGIAYkB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QAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkAC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FCAAIBA2AgxBACEQDLIBCyAAKAIEIRAgAEEANgIEAkAgACAQIAEQp4CAgAAiEA0AIAEhAQxNCyAAQdMANgIcIAAgATYCFCAAIBA2AgxBACEQDLEBCyAAKAIEIRAgAEEANgIEAkAgACAQIAEQp4CAgAAiEA0AIAEhAQxRCyAAQeUANgIcIAAgATYCFCAAIBA2AgxBACEQDLABCyAAQQA2AhwgACABNgIUIABBxoqAgAA2AhAgAEEHNgIMQQAhEAyvAQsgACgCBCEQIABBADYCBAJAIAAgECABEKeAgIAAIhANACABIQEMSQsgAEHSADYCHCAAIAE2AhQgACAQNgIMQQAhEAyuAQsgACgCBCEQIABBADYCBAJAIAAgECABEKeAgIAAIhANACABIQEMSQsgAEHTADYCHCAAIAE2AhQgACAQNgIMQQAhEAytAQsgACgCBCEQIABBADYCBAJAIAAgECABEKeAgIAAIhANACABIQEMTQsgAEHlADYCHCAAIAE2AhQgACAQNgIMQQAhEAysAQsgAEEANgIcIAAgATYCFCAAQdyIgIAANgIQIABBBzYCDEEAIRAMqwELIBBBP0cNASABQQFqIQELQQUhEAyQAQtBACEQIABBADYCHCAAIAE2AhQgAEH9koCAADYCECAAQQc2AgwMqAELIAAoAgQhECAAQQA2AgQCQCAAIBAgARCngICAACIQDQAgASEBDEILIABB0gA2AhwgACABNgIUIAAgEDYCDEEAIRAMpwELIAAoAgQhECAAQQA2AgQCQCAAIBAgARCngICAACIQDQAgASEBDEILIABB0wA2AhwgACABNgIUIAAgEDYCDEEAIRAMpgELIAAoAgQhECAAQQA2AgQCQCAAIBAgARCngICAACIQDQAgASEBDEYLIABB5QA2AhwgACABNgIUIAAgEDYCDEEAIRAMpQELIAAoAgQhASAAQQA2AgQCQCAAIAEgFBCngICAACIBDQAgFCEBDD8LIABB0gA2AhwgACAUNgIUIAAgATYCDEEAIRAMpAELIAAoAgQhASAAQQA2AgQCQCAAIAEgFBCngICAACIBDQAgFCEBDD8LIABB0wA2AhwgACAUNgIUIAAgATYCDEEAIRAMowELIAAoAgQhASAAQQA2AgQCQCAAIAEgFBCngICAACIBDQAgFCEBDEMLIABB5QA2AhwgACAU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YWdlX2JlZ2luYCBjYWxsYmFjayBlcnJvcgBgb25fY2h1bmtfZXh0ZW5zaW9uX3ZhbHVlYCBjYWxsYmFjayBlcnJvcgBgb25fc3RhdHVzX2NvbXBsZXRlYCBjYWxsYmFjayBlcnJvcgBgb25fdmVyc2lvbl9jb21wbGV0ZWAgY2FsbGJhY2sgZXJyb3IAYG9uX3VybF9jb21wbGV0ZWAgY2FsbGJhY2sgZXJyb3IAYG9uX2NodW5rX2NvbXBsZXRlYCBjYWxsYmFjayBlcnJvcgBgb25faGVhZGVyX3ZhbHVlX2NvbXBsZXRlYCBjYWxsYmFjayBlcnJvcgBgb25fbWVzc2FnZV9jb21wbGV0ZWAgY2FsbGJhY2sgZXJyb3IAYG9uX21ldGhvZF9jb21wbGV0ZWAgY2FsbGJhY2sgZXJyb3IAYG9uX2hlYWRlcl9maWVsZF9jb21wbGV0ZWAgY2FsbGJhY2sgZXJyb3IAYG9uX2NodW5rX2V4dGVuc2lvbl9uYW1lYCBjYWxsYmFjayBlcnJvcgBVbmV4cGVjdGVkIGNoYXIgaW4gdXJsIHNlcnZlcgBJbnZhbGlkIGhlYWRlciB2YWx1ZSBjaGFyAEludmFsaWQgaGVhZGVyIGZpZWxkIGNoYXIAU3BhbiBjYWxsYmFjayBlcnJvciBpbiBvbl92ZXJzaW9uAEludmFsaWQgbWlub3IgdmVyc2lvbgBJbnZhbGlkIG1ham9yIHZlcnNpb24ARXhwZWN0ZWQgc3BhY2UgYWZ0ZXIgdmVyc2lvbgBFeHBlY3RlZCBDUkxGIGFmdGVyIHZlcnNpb24ASW52YWxpZCBIVFRQIHZlcnNpb24ASW52YWxpZCBoZWFkZXIgdG9rZW4AU3BhbiBjYWxsYmFjayBlcnJvciBpbiBvbl91cmwASW52YWxpZCBjaGFyYWN0ZXJzIGluIHVybABVbmV4cGVjdGVkIHN0YXJ0IGNoYXIgaW4gdXJsAERvdWJsZSBAIGluIHVybABFbXB0eSBDb250ZW50LUxlbmd0aABJbnZhbGlkIGNoYXJhY3RlciBpbiBDb250ZW50LUxlbmd0aABEdXBsaWNhdGUgQ29udGVudC1MZW5ndGgASW52YWxpZCBjaGFyIGluIHVybCBwYXRoAENvbnRlbnQtTGVuZ3RoIGNhbid0IGJlIHByZXNlbnQgd2l0aCBUcmFuc2Zlci1FbmNvZGluZwBJbnZhbGlkIGNoYXJhY3RlciBpbiBjaHVuayBzaXplAFNwYW4gY2FsbGJhY2sgZXJyb3IgaW4gb25faGVhZGVyX3ZhbHVlAFNwYW4gY2FsbGJhY2sgZXJyb3IgaW4gb25fY2h1bmtfZXh0ZW5zaW9uX3ZhbHVlAEludmFsaWQgY2hhcmFjdGVyIGluIGNodW5rIGV4dGVuc2lvbnMgdmFsdWUATWlzc2luZyBleHBlY3RlZCBMRiBhZnRlciBoZWFkZXIgdmFsdWUASW52YWxpZCBgVHJhbnNmZXItRW5jb2RpbmdgIGhlYWRlciB2YWx1ZQBJbnZhbGlkIGNoYXJhY3RlciBpbiBjaHVuayBleHRlbnNpb25zIHF1b3RlIHZhbHVlAEludmFsaWQgY2hhcmFjdGVyIGluIGNodW5rIGV4dGVuc2lvbnMgcXVvdGVkIHZhbHVlAFBhdXNlZCBieSBvbl9oZWFkZXJzX2NvbXBsZXRlAEludmFsaWQgRU9GIHN0YXRlAG9uX3Jlc2V0IHBhdXNlAG9uX2NodW5rX2hlYWRlciBwYXVzZQBvbl9tZXNzYWdlX2JlZ2luIHBhdXNlAG9uX2NodW5rX2V4dGVuc2lvbl92YWx1ZSBwYXVzZQBvbl9zdGF0dXNfY29tcGxldGUgcGF1c2UAb25fdmVyc2lvbl9jb21wbGV0ZSBwYXVzZQBvbl91cmxfY29tcGxldGUgcGF1c2UAb25fY2h1bmtfY29tcGxldGUgcGF1c2UAb25faGVhZGVyX3ZhbHVlX2NvbXBsZXRlIHBhdXNlAG9uX21lc3NhZ2VfY29tcGxldGUgcGF1c2UAb25fbWV0aG9kX2NvbXBsZXRlIHBhdXNlAG9uX2hlYWRlcl9maWVsZF9jb21wbGV0ZSBwYXVzZQBvbl9jaHVua19leHRlbnNpb25fbmFtZSBwYXVzZQBVbmV4cGVjdGVkIHNwYWNlIGFmdGVyIHN0YXJ0IGxpbmUAU3BhbiBjYWxsYmFjayBlcnJvciBpbiBvbl9jaHVua19leHRlbnNpb25fbmFtZQBJbnZhbGlkIGNoYXJhY3RlciBpbiBjaHVuayBleHRlbnNpb25zIG5hbWUAUGF1c2Ugb24gQ09OTkVDVC9VcGdyYWRlAFBhdXNlIG9uIFBSSS9VcGdyYWRlAEV4cGVjdGVkIEhUVFAvMiBDb25uZWN0aW9uIFByZWZhY2UAU3BhbiBjYWxsYmFjayBlcnJvciBpbiBvbl9tZXRob2QARXhwZWN0ZWQgc3BhY2UgYWZ0ZXIgbWV0aG9kAFNwYW4gY2FsbGJhY2sgZXJyb3IgaW4gb25faGVhZGVyX2ZpZWxkAFBhdXNlZABJbnZhbGlkIHdvcmQgZW5jb3VudGVyZWQASW52YWxpZCBtZXRob2QgZW5jb3VudGVyZWQAVW5leHBlY3RlZCBjaGFyIGluIHVybCBzY2hlbWEAUmVxdWVzdCBoYXMgaW52YWxpZCBgVHJhbnNmZXItRW5jb2RpbmdgAFNXSVRDSF9QUk9YWQBVU0VfUFJPWFkATUtBQ1RJVklUWQBVTlBST0NFU1NBQkxFX0VOVElUWQBDT1BZAE1PVkVEX1BFUk1BTkVOVExZAFRPT19FQVJMWQBOT1RJRlkARkFJTEVEX0RFUEVOREVOQ1kAQkFEX0dBVEVXQVkAUExBWQBQVVQAQ0hFQ0tPVVQAR0FURVdBWV9USU1FT1VUAFJFUVVFU1RfVElNRU9VVABORVRXT1JLX0NPTk5FQ1RfVElNRU9VVABDT05ORUNUSU9OX1RJTUVPVVQATE9HSU5fVElNRU9VVABORVRXT1JLX1JFQURfVElNRU9VVABQT1NUAE1JU0RJUkVDVEVEX1JFUVVFU1QAQ0xJRU5UX0NMT1NFRF9SRVFVRVNUAENMSUVOVF9DTE9TRURfTE9BRF9CQUxBTkNFRF9SRVFVRVNUAEJBRF9SRVFVRVNUAEhUVFBfUkVRVUVTVF9TRU5UX1RPX0hUVFBTX1BPUlQAUkVQT1JUAElNX0FfVEVBUE9UAFJFU0VUX0NPTlRFTlQATk9fQ09OVEVOVABQQVJUSUFMX0NPTlRFTlQASFBFX0lOVkFMSURfQ09OU1RBTlQASFBFX0NCX1JFU0VUAEdFVABIUEVfU1RSSUNUAENPTkZMSUNUAFRFTVBPUkFSWV9SRURJUkVDVABQRVJNQU5FTlRfUkVESVJFQ1QAQ09OTkVDVABNVUxUSV9TVEFUVVMASFBFX0lOVkFMSURfU1RBVFVTAFRPT19NQU5ZX1JFUVVFU1RTAEVBUkxZX0hJTlRTAFVOQVZBSUxBQkxFX0ZPUl9MRUdBTF9SRUFTT05TAE9QVElPTlMAU1dJVENISU5HX1BST1RPQ09MUwBWQVJJQU5UX0FMU09fTkVHT1RJQVRFUwBNVUxUSVBMRV9DSE9JQ0VTAElOVEVSTkFMX1NFUlZFUl9FUlJPUgBXRUJfU0VSVkVSX1VOS05PV05fRVJST1IAUkFJTEdVTl9FUlJPUgBJREVOVElUWV9QUk9WSURFUl9BVVRIRU5USUNBVElPTl9FUlJPUgBTU0xfQ0VSVElGSUNBVEVfRVJST1IASU5WQUxJRF9YX0ZPUldBUkRFRF9GT1IAU0VUX1BBUkFNRVRFUgBHRVRfUEFSQU1FVEVSAEhQRV9VU0VSAFNFRV9PVEhFUgBIUEVfQ0JfQ0hVTktfSEVBREVSAE1LQ0FMRU5EQVIAU0VUVVAAV0VCX1NFUlZFUl9JU19ET1dOAFRFQVJET1dOAEhQRV9DTE9TRURfQ09OTkVDVElPTgBIRVVSSVNUSUNfRVhQSVJBVElPTgBESVNDT05ORUNURURfT1BFUkFUSU9OAE5PTl9BVVRIT1JJVEFUSVZFX0lORk9STUFUSU9OAEhQRV9JTlZBTElEX1ZFUlNJT04ASFBFX0NCX01FU1NBR0VfQkVHSU4AU0lURV9JU19GUk9aRU4ASFBFX0lOVkFMSURfSEVBREVSX1RPS0VOAElOVkFMSURfVE9LRU4ARk9SQklEREVOAEVOSEFOQ0VfWU9VUl9DQUxNAEhQRV9JTlZBTElEX1VSTABCTE9DS0VEX0JZX1BBUkVOVEFMX0NPTlRST0wATUtDT0wAQUNMAEhQRV9JTlRFUk5BTABSRVFVRVNUX0hFQURFUl9GSUVMRFNfVE9PX0xBUkdFX1VOT0ZGSUNJQUwASFBFX09LAFVOTElOSwBVTkxPQ0sAUFJJAFJFVFJZX1dJVEgASFBFX0lOVkFMSURfQ09OVEVOVF9MRU5HVEgASFBFX1VORVhQRUNURURfQ09OVEVOVF9MRU5HVEgARkxVU0gAUFJPUFBBVENIAE0tU0VBUkNIAFVSSV9UT09fTE9ORwBQUk9DRVNTSU5HAE1JU0NFTExBTkVPVVNfUEVSU0lTVEVOVF9XQVJOSU5HAE1JU0NFTExBTkVPVVNfV0FSTklORwBIUEVfSU5WQUxJRF9UUkFOU0ZFUl9FTkNPRElORwBFeHBlY3RlZCBDUkxGAEhQRV9JTlZBTElEX0NIVU5LX1NJWkUATU9WRQBDT05USU5VRQBIUEVfQ0JfU1RBVFVTX0NPTVBMRVRFAEhQRV9DQl9IRUFERVJTX0NPTVBMRVRFAEhQRV9DQl9WRVJTSU9OX0NPTVBMRVRFAEhQRV9DQl9VUkxfQ09NUExFVEUASFBFX0NCX0NIVU5LX0NPTVBMRVRFAEhQRV9DQl9IRUFERVJfVkFMVUVfQ09NUExFVEUASFBFX0NCX0NIVU5LX0VYVEVOU0lPTl9WQUxVRV9DT01QTEVURQBIUEVfQ0JfQ0hVTktfRVhURU5TSU9OX05BTUVfQ09NUExFVEUASFBFX0NCX01FU1NBR0VfQ09NUExFVEUASFBFX0NCX01FVEhPRF9DT01QTEVURQBIUEVfQ0JfSEVBREVSX0ZJRUxEX0NPTVBMRVRFAERFTEVURQBIUEVfSU5WQUxJRF9FT0ZfU1RBVEUASU5WQUxJRF9TU0xfQ0VSVElGSUNBVEUAUEFVU0UATk9fUkVTUE9OU0UAVU5TVVBQT1JURURfTUVESUFfVFlQRQBHT05FAE5PVF9BQ0NFUFRBQkxFAFNFUlZJQ0VfVU5BVkFJTEFCTEUAUkFOR0VfTk9UX1NBVElTRklBQkxFAE9SSUdJTl9JU19VTlJFQUNIQUJMRQBSRVNQT05TRV9JU19TVEFMRQBQVVJHRQBNRVJHRQBSRVFVRVNUX0hFQURFUl9GSUVMRFNfVE9PX0xBUkdFAFJFUVVFU1RfSEVBREVSX1RPT19MQVJHRQBQQVlMT0FEX1RPT19MQVJHRQBJTlNVRkZJQ0lFTlRfU1RPUkFHRQBIUEVfUEFVU0VEX1VQR1JBREUASFBFX1BBVVNFRF9IMl9VUEdSQURFAFNPVVJDRQBBTk5PVU5DRQBUUkFDRQBIUEVfVU5FWFBFQ1RFRF9TUEFDRQBERVNDUklCRQBVTlNVQlNDUklCRQBSRUNPUkQASFBFX0lOVkFMSURfTUVUSE9EAE5PVF9GT1VORABQUk9QRklORABVTkJJTkQAUkVCSU5EAFVOQVVUSE9SSVpFRABNRVRIT0RfTk9UX0FMTE9XRUQASFRUUF9WRVJTSU9OX05PVF9TVVBQT1JURUQAQUxSRUFEWV9SRVBPUlRFRABBQ0NFUFRFRABOT1RfSU1QTEVNRU5URUQATE9PUF9ERVRFQ1RFRABIUEVfQ1JfRVhQRUNURUQASFBFX0xGX0VYUEVDVEVEAENSRUFURUQASU1fVVNFRABIUEVfUEFVU0VEAFRJTUVPVVRfT0NDVVJFRABQQVlNRU5UX1JFUVVJUkVEAFBSRUNPTkRJVElPTl9SRVFVSVJFRABQUk9YWV9BVVRIRU5USUNBVElPTl9SRVFVSVJFRABORVRXT1JLX0FVVEhFTlRJQ0FUSU9OX1JFUVVJUkVEAExFTkdUSF9SRVFVSVJFRABTU0xfQ0VSVElGSUNBVEVfUkVRVUlSRUQAVVBHUkFERV9SRVFVSVJFRABQQUdFX0VYUElSRUQAUFJFQ09ORElUSU9OX0ZBSUxFRABFWFBFQ1RBVElPTl9GQUlMRUQAUkVWQUxJREFUSU9OX0ZBSUxFRABTU0xfSEFORFNIQUtFX0ZBSUxFRABMT0NLRUQAVFJBTlNGT1JNQVRJT05fQVBQTElFRABOT1RfTU9ESUZJRUQATk9UX0VYVEVOREVEAEJBTkRXSURUSF9MSU1JVF9FWENFRURFRABTSVRFX0lTX09WRVJMT0FERUQASEVBRABFeHBlY3RlZCBIVFRQLwAAXhMAACYTAAAwEAAA8BcAAJ0TAAAVEgAAORcAAPASAAAKEAAAdRIAAK0SAACCEwAATxQAAH8QAACgFQAAIxQAAIkSAACLFAAATRUAANQRAADPFAAAEBgAAMkWAADcFgAAwREAAOAXAAC7FAAAdBQAAHwVAADlFAAACBcAAB8QAABlFQAAoxQAACgVAAACFQAAmRUAACwQAACLGQAATw8AANQOAABqEAAAzhAAAAIXAACJDgAAbhMAABwTAABmFAAAVhcAAMETAADNEwAAbBMAAGgXAABmFwAAXxcAACITAADODwAAaQ4AANgOAABjFgAAyxMAAKoOAAAoFwAAJhcAAMUTAABdFgAA6BEAAGcTAABlEwAA8hYAAHMTAAAdFwAA+RYAAPMRAADPDgAAzhUAAAwSAACzEQAApREAAGEQAAAyFwAAuxMAAAAAAAAAAAAAAAAAAAAAAAAAAQAAAAAAAAAAAAAAAAAAAAAAAAAAAAABAQIBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEAAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQAAAAAAAAAAAAAAAAABAAAAAAAAAAAAAAAAAAAAAAAAAAIDAgICAgIAAAICAAICAAICAgICAgICAgIABAAAAAAAAgICAgICAgICAgICAgICAgICAgICAgICAgIAAAACAgICAgICAgICAgICAgICAgICAgICAgICAgICAgACAAIAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAQAAAAAAAAAAAAAAAAAAAAAAAAACAAICAgICAAACAgACAgACAgICAgICAgICAAMABAAAAAICAgICAgICAgICAgICAgICAgICAgICAgICAAAAAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIAAgACAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAbG9zZWVlcC1hbGl2ZQAAAAAAAAAAAAAAAAEAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEAAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEAAAAAAAAAAAABAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAEBAQEBAQEBAQEBAQIBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAAEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBY2h1bmtlZAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAQEAAQEBAQEAAAEBAAEBAAEBAQEBAQEBAQEAAAAAAAAAAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEAAAABAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQABAAEAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAABlY3Rpb25lbnQtbGVuZ3Rob25yb3h5LWNvbm5lY3Rpb24AAAAAAAAAAAAAAAAAAAByYW5zZmVyLWVuY29kaW5ncGdyYWRlDQoNCg0KU00NCg0KVFRQL0NFL1RTUC8AAAAAAAAAAAAAAAABAgABAwAAAAAAAAAAAAAAAAAAAAAAAAQBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAAEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAAAAAAAAAAAAAQIAAQMAAAAAAAAAAAAAAAAAAAAAAAAEAQEFAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQABAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQAAAAAAAAAAAAEAAAEAAAAAAAAAAAAAAAAAAAAAAAAAAAEBAAEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQABAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEAAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEAAAAAAAAAAAAAAQAAAgAAAAAAAAAAAAAAAAAAAAAAAAMEAAAEBAQEBAQEBAQEBAUEBAQEBAQEBAQEBAQABAAGBwQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAAEAAQABAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQAAAAEAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAEAAAEAAAAAAAAAAAAAAAAAAAAAAAABAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAIAAAAAAAADAwMDAwMDAwMDAwMDAwMDAwMDAwMDAwMDAwAAAAAAAAMDAwMDAwMDAwMDAwMDAwMDAwMDAwMDAwMDAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAABAAABAAAAAAAAAAAAAAAAAAAAAAAAAQAAAAAAAAAAAAIAAAAAAgAAAAAAAAAAAAAAAAAAAAAAAwMDAwMDAwMDAwMDAwMDAwMDAwMDAwMDAwMAAAAAAAADAwMDAwMDAwMDAwMDAwMDAwMDAwMDAwMDAwAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAABOT1VOQ0VFQ0tPVVRORUNURVRFQ1JJQkVMVVNIRVRFQURTRUFSQ0hSR0VDVElWSVRZTEVOREFSVkVPVElGWVBUSU9OU0NIU0VBWVNUQVRDSEdFT1JESVJFQ1RPUlRSQ0hQQVJBTUVURVJVUkNFQlNDUklCRUFSRE9XTkFDRUlORE5LQ0tVQlNDUklCRUhUVFAvQURUUC8='\n","module.exports = 'AGFzbQEAAAABMAhgAX8Bf2ADf39/AX9gBH9/f38Bf2AAAGADf39/AGABfwBgAn9/AGAGf39/f39/AALLAQgDZW52GHdhc21fb25faGVhZGVyc19jb21wbGV0ZQACA2VudhV3YXNtX29uX21lc3NhZ2VfYmVnaW4AAANlbnYLd2FzbV9vbl91cmwAAQNlbnYOd2FzbV9vbl9zdGF0dXMAAQNlbnYUd2FzbV9vbl9oZWFkZXJfZmllbGQAAQNlbnYUd2FzbV9vbl9oZWFkZXJfdmFsdWUAAQNlbnYMd2FzbV9vbl9ib2R5AAEDZW52GHdhc21fb25fbWVzc2FnZV9jb21wbGV0ZQAAA0ZFAwMEAAAFAAAAAAAABQEFAAUFBQAABgAAAAAGBgYGAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQABAAABAQcAAAUFAwABBAUBcAESEgUDAQACBggBfwFBgNQECwfRBSIGbWVtb3J5AgALX2luaXRpYWxpemUACRlfX2luZGlyZWN0X2Z1bmN0aW9uX3RhYmxlAQALbGxodHRwX2luaXQAChhsbGh0dHBfc2hvdWxkX2tlZXBfYWxpdmUAQQxsbGh0dHBfYWxsb2MADAZtYWxsb2MARgtsbGh0dHBfZnJlZQANBGZyZWUASA9sbGh0dHBfZ2V0X3R5cGUADhVsbGh0dHBfZ2V0X2h0dHBfbWFqb3IADxVsbGh0dHBfZ2V0X2h0dHBfbWlub3IAEBFsbGh0dHBfZ2V0X21ldGhvZAARFmxsaHR0cF9nZXRfc3RhdHVzX2NvZGUAEhJsbGh0dHBfZ2V0X3VwZ3JhZGUAEwxsbGh0dHBfcmVzZXQAFA5sbGh0dHBfZXhlY3V0ZQAVFGxsaHR0cF9zZXR0aW5nc19pbml0ABYNbGxodHRwX2ZpbmlzaAAXDGxsaHR0cF9wYXVzZQAYDWxsaHR0cF9yZXN1bWUAGRtsbGh0dHBfcmVzdW1lX2FmdGVyX3VwZ3JhZGUAGhBsbGh0dHBfZ2V0X2Vycm5vABsXbGxodHRwX2dldF9lcnJvcl9yZWFzb24AHBdsbGh0dHBfc2V0X2Vycm9yX3JlYXNvbgAdFGxsaHR0cF9nZXRfZXJyb3JfcG9zAB4RbGxodHRwX2Vycm5vX25hbWUAHxJsbGh0dHBfbWV0aG9kX25hbWUAIBJs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IAH9CwMAIABBMGogAf0LAwAgAEEgaiAB/QsDACAAQd0BNgIcQQALewEBfwJAIAAoAgwiAw0AAkAgACgCBEUNACAAIAE2AgQLAkAgACABIAIQxICAgAAiAw0AIAAoAgwPCyAAIAM2AhxBACEDIAAoAgQiAUUNACAAIAEgAiAAKAIIEYGAgIAAACIBRQ0AIAAgAjYCFCAAIAE2AgwgASEDCyADC+TzAQMOfwN+BH8jgICAgABBEGsiAySAgICAACABIQQgASEFIAEhBiABIQcgASEIIAEhCSABIQogASELIAEhDCABIQ0gASEOIAEhDwJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQCAAKAIcIhBBf2oO3QHaAQHZAQIDBAUGBwgJCgsMDQ7YAQ8Q1wEREtYBExQVFhcYGRob4AHfARwdHtUBHyAhIiMkJdQBJicoKSorLNMB0gEtLtEB0AEvMDEyMzQ1Njc4OTo7PD0+P0BBQkNERUbbAUdISUrPAc4BS80BTMwBTU5PUFFSU1RVVldYWVpbXF1eX2BhYmNkZWZnaGlqa2xtbm9wcXJzdHV2d3h5ent8fX5/gAGBAYIBgwGEAYUBhgGHAYgBiQGKAYsBjAGNAY4BjwGQAZEB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QAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAAkACQAJAIBAOxwEAAQID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YWNrIGVycm9yAGBvbl9jaHVua19leHRlbnNpb25fdmFsdWVgIGNhbGxiYWNrIGVycm9yAGBvbl9zdGF0dXNfY29tcGxldGVgIGNhbGxiYWNrIGVycm9yAGBvbl92ZXJzaW9uX2NvbXBsZXRlYCBjYWxsYmFjayBlcnJvcgBgb25fdXJsX2NvbXBsZXRlYCBjYWxsYmFjayBlcnJvcgBgb25fY2h1bmtfY29tcGxldGVgIGNhbGxiYWNrIGVycm9yAGBvbl9oZWFkZXJfdmFsdWVfY29tcGxldGVgIGNhbGxiYWNrIGVycm9yAGBvbl9tZXNzYWdlX2NvbXBsZXRlYCBjYWxsYmFjayBlcnJvcgBgb25fbWV0aG9kX2NvbXBsZXRlYCBjYWxsYmFjayBlcnJvcgBgb25faGVhZGVyX2ZpZWxkX2NvbXBsZXRlYCBjYWxsYmFjayBlcnJvcgBgb25fY2h1bmtfZXh0ZW5zaW9uX25hbWVgIGNhbGxiYWNrIGVycm9yAFVuZXhwZWN0ZWQgY2hhciBpbiB1cmwgc2VydmVyAEludmFsaWQgaGVhZGVyIHZhbHVlIGNoYXIASW52YWxpZCBoZWFkZXIgZmllbGQgY2hhcgBTcGFuIGNhbGxiYWNrIGVycm9yIGluIG9uX3ZlcnNpb24ASW52YWxpZCBtaW5vciB2ZXJzaW9uAEludmFsaWQgbWFqb3IgdmVyc2lvbgBFeHBlY3RlZCBzcGFjZSBhZnRlciB2ZXJzaW9uAEV4cGVjdGVkIENSTEYgYWZ0ZXIgdmVyc2lvbgBJbnZhbGlkIEhUVFAgdmVyc2lvbgBJbnZhbGlkIGhlYWRlciB0b2tlbgBTcGFuIGNhbGxiYWNrIGVycm9yIGluIG9uX3VybABJbnZhbGlkIGNoYXJhY3RlcnMgaW4gdXJsAFVuZXhwZWN0ZWQgc3RhcnQgY2hhciBpbiB1cmwARG91YmxlIEAgaW4gdXJsAEVtcHR5IENvbnRlbnQtTGVuZ3RoAEludmFsaWQgY2hhcmFjdGVyIGluIENvbnRlbnQtTGVuZ3RoAER1cGxpY2F0ZSBDb250ZW50LUxlbmd0aABJbnZhbGlkIGNoYXIgaW4gdXJsIHBhdGgAQ29udGVudC1MZW5ndGggY2FuJ3QgYmUgcHJlc2VudCB3aXRoIFRyYW5zZmVyLUVuY29kaW5nAEludmFsaWQgY2hhcmFjdGVyIGluIGNodW5rIHNpemUAU3BhbiBjYWxsYmFjayBlcnJvciBpbiBvbl9oZWFkZXJfdmFsdWUAU3BhbiBjYWxsYmFjayBlcnJvciBpbiBvbl9jaHVua19leHRlbnNpb25fdmFsdWUASW52YWxpZCBjaGFyYWN0ZXIgaW4gY2h1bmsgZXh0ZW5zaW9ucyB2YWx1ZQBNaXNzaW5nIGV4cGVjdGVkIExGIGFmdGVyIGhlYWRlciB2YWx1ZQBJbnZhbGlkIGBUcmFuc2Zlci1FbmNvZGluZ2AgaGVhZGVyIHZhbHVlAEludmFsaWQgY2hhcmFjdGVyIGluIGNodW5rIGV4dGVuc2lvbnMgcXVvdGUgdmFsdWUASW52YWxpZCBjaGFyYWN0ZXIgaW4gY2h1bmsgZXh0ZW5zaW9ucyBxdW90ZWQgdmFsdWUAUGF1c2VkIGJ5IG9uX2hlYWRlcnNfY29tcGxldGUASW52YWxpZCBFT0Ygc3RhdGUAb25fcmVzZXQgcGF1c2UAb25fY2h1bmtfaGVhZGVyIHBhdXNlAG9uX21lc3NhZ2VfYmVnaW4gcGF1c2UAb25fY2h1bmtfZXh0ZW5zaW9uX3ZhbHVlIHBhdXNlAG9uX3N0YXR1c19jb21wbGV0ZSBwYXVzZQBvbl92ZXJzaW9uX2NvbXBsZXRlIHBhdXNlAG9uX3VybF9jb21wbGV0ZSBwYXVzZQBvbl9jaHVua19jb21wbGV0ZSBwYXVzZQBvbl9oZWFkZXJfdmFsdWVfY29tcGxldGUgcGF1c2UAb25fbWVzc2FnZV9jb21wbGV0ZSBwYXVzZQBvbl9tZXRob2RfY29tcGxldGUgcGF1c2UAb25faGVhZGVyX2ZpZWxkX2NvbXBsZXRlIHBhdXNlAG9uX2NodW5rX2V4dGVuc2lvbl9uYW1lIHBhdXNlAFVuZXhwZWN0ZWQgc3BhY2UgYWZ0ZXIgc3RhcnQgbGluZQBTcGFuIGNhbGxiYWNrIGVycm9yIGluIG9uX2NodW5rX2V4dGVuc2lvbl9uYW1lAEludmFsaWQgY2hhcmFjdGVyIGluIGNodW5rIGV4dGVuc2lvbnMgbmFtZQBQYXVzZSBvbiBDT05ORUNUL1VwZ3JhZGUAUGF1c2Ugb24gUFJJL1VwZ3JhZGUARXhwZWN0ZWQgSFRUUC8yIENvbm5lY3Rpb24gUHJlZmFjZQBTcGFuIGNhbGxiYWNrIGVycm9yIGluIG9uX21ldGhvZABFeHBlY3RlZCBzcGFjZSBhZnRlciBtZXRob2QAU3BhbiBjYWxsYmFjayBlcnJvciBpbiBvbl9oZWFkZXJfZmllbGQAUGF1c2VkAEludmFsaWQgd29yZCBlbmNvdW50ZXJlZABJbnZhbGlkIG1ldGhvZCBlbmNvdW50ZXJlZABVbmV4cGVjdGVkIGNoYXIgaW4gdXJsIHNjaGVtYQBSZXF1ZXN0IGhhcyBpbnZhbGlkIGBUcmFuc2Zlci1FbmNvZGluZ2AAU1dJVENIX1BST1hZAFVTRV9QUk9YWQBNS0FDVElWSVRZAFVOUFJPQ0VTU0FCTEVfRU5USVRZAENPUFkATU9WRURfUEVSTUFORU5UTFkAVE9PX0VBUkxZAE5PVElGWQBGQUlMRURfREVQRU5ERU5DWQBCQURfR0FURVdBWQBQTEFZAFBVVABDSEVDS09VVABHQVRFV0FZX1RJTUVPVVQAUkVRVUVTVF9USU1FT1VUAE5FVFdPUktfQ09OTkVDVF9USU1FT1VUAENPTk5FQ1RJT05fVElNRU9VVABMT0dJTl9USU1FT1VUAE5FVFdPUktfUkVBRF9USU1FT1VUAFBPU1QATUlTRElSRUNURURfUkVRVUVTVABDTElFTlRfQ0xPU0VEX1JFUVVFU1QAQ0xJRU5UX0NMT1NFRF9MT0FEX0JBTEFOQ0VEX1JFUVVFU1QAQkFEX1JFUVVFU1QASFRUUF9SRVFVRVNUX1NFTlRfVE9fSFRUUFNfUE9SVABSRVBPUlQASU1fQV9URUFQT1QAUkVTRVRfQ09OVEVOVABOT19DT05URU5UAFBBUlRJQUxfQ09OVEVOVABIUEVfSU5WQUxJRF9DT05TVEFOVABIUEVfQ0JfUkVTRVQAR0VUAEhQRV9TVFJJQ1QAQ09ORkxJQ1QAVEVNUE9SQVJZX1JFRElSRUNUAFBFUk1BTkVOVF9SRURJUkVDVABDT05ORUNUAE1VTFRJX1NUQVRVUwBIUEVfSU5WQUxJRF9TVEFUVVMAVE9PX01BTllfUkVRVUVTVFMARUFSTFlfSElOVFMAVU5BVkFJTEFCTEVfRk9SX0xFR0FMX1JFQVNPTlMAT1BUSU9OUwBTV0lUQ0hJTkdfUFJPVE9DT0xTAFZBUklBTlRfQUxTT19ORUdPVElBVEVTAE1VTFRJUExFX0NIT0lDRVMASU5URVJOQUxfU0VSVkVSX0VSUk9SAFdFQl9TRVJWRVJfVU5LTk9XTl9FUlJPUgBSQUlMR1VOX0VSUk9SAElERU5USVRZX1BST1ZJREVSX0FVVEhFTlRJQ0FUSU9OX0VSUk9SAFNTTF9DRVJUSUZJQ0FURV9FUlJPUgBJTlZBTElEX1hfRk9SV0FSREVEX0ZPUgBTRVRfUEFSQU1FVEVSAEdFVF9QQVJBTUVURVIASFBFX1VTRVIAU0VFX09USEVSAEhQRV9DQl9DSFVOS19IRUFERVIATUtDQUxFTkRBUgBTRVRVUABXRUJfU0VSVkVSX0lTX0RPV04AVEVBUkRPV04ASFBFX0NMT1NFRF9DT05ORUNUSU9OAEhFVVJJU1RJQ19FWFBJUkFUSU9OAERJU0NPTk5FQ1RFRF9PUEVSQVRJT04ATk9OX0FVVEhPUklUQVRJVkVfSU5GT1JNQVRJT04ASFBFX0lOVkFMSURfVkVSU0lPTgBIUEVfQ0JfTUVTU0FHRV9CRUdJTgBTSVRFX0lTX0ZST1pFTgBIUEVfSU5WQUxJRF9IRUFERVJfVE9LRU4ASU5WQUxJRF9UT0tFTgBGT1JCSURERU4ARU5IQU5DRV9ZT1VSX0NBTE0ASFBFX0lOVkFMSURfVVJMAEJMT0NLRURfQllfUEFSRU5UQUxfQ09OVFJPTABNS0NPTABBQ0wASFBFX0lOVEVSTkFMAFJFUVVFU1RfSEVBREVSX0ZJRUxEU19UT09fTEFSR0VfVU5PRkZJQ0lBTABIUEVfT0sAVU5MSU5LAFVOTE9DSwBQUkkAUkVUUllfV0lUSABIUEVfSU5WQUxJRF9DT05URU5UX0xFTkdUSABIUEVfVU5FWFBFQ1RFRF9DT05URU5UX0xFTkdUSABGTFVTSABQUk9QUEFUQ0gATS1TRUFSQ0gAVVJJX1RPT19MT05HAFBST0NFU1NJTkcATUlTQ0VMTEFORU9VU19QRVJTSVNURU5UX1dBUk5JTkcATUlTQ0VMTEFORU9VU19XQVJOSU5HAEhQRV9JTlZBTElEX1RSQU5TRkVSX0VOQ09ESU5HAEV4cGVjdGVkIENSTEYASFBFX0lOVkFMSURfQ0hVTktfU0laRQBNT1ZFAENPTlRJTlVFAEhQRV9DQl9TVEFUVVNfQ09NUExFVEUASFBFX0NCX0hFQURFUlNfQ09NUExFVEUASFBFX0NCX1ZFUlNJT05fQ09NUExFVEUASFBFX0NCX1VSTF9DT01QTEVURQBIUEVfQ0JfQ0hVTktfQ09NUExFVEUASFBFX0NCX0hFQURFUl9WQUxVRV9DT01QTEVURQBIUEVfQ0JfQ0hVTktfRVhURU5TSU9OX1ZBTFVFX0NPTVBMRVRFAEhQRV9DQl9DSFVOS19FWFRFTlNJT05fTkFNRV9DT01QTEVURQBIUEVfQ0JfTUVTU0FHRV9DT01QTEVURQBIUEVfQ0JfTUVUSE9EX0NPTVBMRVRFAEhQRV9DQl9IRUFERVJfRklFTERfQ09NUExFVEUAREVMRVRFAEhQRV9JTlZBTElEX0VPRl9TVEFURQBJTlZBTElEX1NTTF9DRVJUSUZJQ0FURQBQQVVTRQBOT19SRVNQT05TRQBVTlNVUFBPUlRFRF9NRURJQV9UWVBFAEdPTkUATk9UX0FDQ0VQVEFCTEUAU0VSVklDRV9VTkFWQUlMQUJMRQBSQU5HRV9OT1RfU0FUSVNGSUFCTEUAT1JJR0lOX0lTX1VOUkVBQ0hBQkxFAFJFU1BPTlNFX0lTX1NUQUxFAFBVUkdFAE1FUkdFAFJFUVVFU1RfSEVBREVSX0ZJRUxEU19UT09fTEFSR0UAUkVRVUVTVF9IRUFERVJfVE9PX0xBUkdFAFBBWUxPQURfVE9PX0xBUkdFAElOU1VGRklDSUVOVF9TVE9SQUdFAEhQRV9QQVVTRURfVVBHUkFERQBIUEVfUEFVU0VEX0gyX1VQR1JBREUAU09VUkNFAEFOTk9VTkNFAFRSQUNFAEhQRV9VTkVYUEVDVEVEX1NQQUNFAERFU0NSSUJFAFVOU1VCU0NSSUJFAFJFQ09SRABIUEVfSU5WQUxJRF9NRVRIT0QATk9UX0ZPVU5EAFBST1BGSU5EAFVOQklORABSRUJJTkQAVU5BVVRIT1JJWkVEAE1FVEhPRF9OT1RfQUxMT1dFRABIVFRQX1ZFUlNJT05fTk9UX1NVUFBPUlRFRABBTFJFQURZX1JFUE9SVEVEAEFDQ0VQVEVEAE5PVF9JTVBMRU1FTlRFRABMT09QX0RFVEVDVEVEAEhQRV9DUl9FWFBFQ1RFRABIUEVfTEZfRVhQRUNURUQAQ1JFQVRFRABJTV9VU0VEAEhQRV9QQVVTRUQAVElNRU9VVF9PQ0NVUkVEAFBBWU1FTlRfUkVRVUlSRUQAUFJFQ09ORElUSU9OX1JFUVVJUkVEAFBST1hZX0FVVEhFTlRJQ0FUSU9OX1JFUVVJUkVEAE5FVFdPUktfQVVUSEVOVElDQVRJT05fUkVRVUlSRUQATEVOR1RIX1JFUVVJUkVEAFNTTF9DRVJUSUZJQ0FURV9SRVFVSVJFRABVUEdSQURFX1JFUVVJUkVEAFBBR0VfRVhQSVJFRABQUkVDT05ESVRJT05fRkFJTEVEAEVYUEVDVEFUSU9OX0ZBSUxFRABSRVZBTElEQVRJT05fRkFJTEVEAFNTTF9IQU5EU0hBS0VfRkFJTEVEAExPQ0tFRABUUkFOU0ZPUk1BVElPTl9BUFBMSUVEAE5PVF9NT0RJRklFRABOT1RfRVhURU5ERUQAQkFORFdJRFRIX0xJTUlUX0VYQ0VFREVEAFNJVEVfSVNfT1ZFUkxPQURFRABIRUFEAEV4cGVjdGVkIEhUVFAvAABeEwAAJhMAADAQAADwFwAAnRMAABUSAAA5FwAA8BIAAAoQAAB1EgAArRIAAIITAABPFAAAfxAAAKAVAAAjFAAAiRIAAIsUAABNFQAA1BEAAM8UAAAQGAAAyRYAANwWAADBEQAA4BcAALsUAAB0FAAAfBUAAOUUAAAIFwAAHxAAAGUVAACjFAAAKBUAAAIVAACZFQAALBAAAIsZAABPDwAA1A4AAGoQAADOEAAAAhcAAIkOAABuEwAAHBMAAGYUAABWFwAAwRMAAM0TAABsEwAAaBcAAGYXAABfFwAAIhMAAM4PAABpDgAA2A4AAGMWAADLEwAAqg4AACgXAAAmFwAAxRMAAF0WAADoEQAAZxMAAGUTAADyFgAAcxMAAB0XAAD5FgAA8xEAAM8OAADOFQAADBIAALMRAAClEQAAYRAAADIXAAC7EwAAAAAAAAAAAAAAAAAAAAAAAAABAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAEBAgEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQABAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAAAAAAAAAAAAAAAAAAEAAAAAAAAAAAAAAAAAAAAAAAAAAgMCAgICAgAAAgIAAgIAAgICAgICAgICAgAEAAAAAAACAgICAgICAgICAgICAgICAgICAgICAgICAgAAAAICAgICAgICAgICAgICAgICAgICAgICAgICAgICAAIAAgAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAABAAAAAAAAAAAAAAAAAAAAAAAAAAIAAgICAgIAAAICAAICAAICAgICAgICAgIAAwAEAAAAAgICAgICAgICAgICAgICAgICAgICAgICAgIAAAACAgICAgICAgICAgICAgICAgICAgICAgICAgICAgACAAIAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAABsb3NlZWVwLWFsaXZlAAAAAAAAAAAAAAAAAQAAAAAAAAAAAAAAAAAAAAAAAAAAAAABAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQABAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQAAAAAAAAAAAAEAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAQEBAQEBAQEBAQEBAgEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEAAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQFjaHVua2VkAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAABAQABAQEBAQAAAQEAAQEAAQEBAQEBAQEBAQAAAAAAAAABAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQAAAAEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAAEAAQAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAGVjdGlvbmVudC1sZW5ndGhvbnJveHktY29ubmVjdGlvbgAAAAAAAAAAAAAAAAAAAHJhbnNmZXItZW5jb2RpbmdwZ3JhZGUNCg0KDQpTTQ0KDQpUVFAvQ0UvVFNQLwAAAAAAAAAAAAAAAAECAAEDAAAAAAAAAAAAAAAAAAAAAAAABAEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEAAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEAAAAAAAAAAAABAgABAwAAAAAAAAAAAAAAAAAAAAAAAAQBAQUBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAAEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAAAAAAAAAAAAAQAAAQAAAAAAAAAAAAAAAAAAAAAAAAAAAQEAAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAAEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQABAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQAAAAAAAAAAAAABAAACAAAAAAAAAAAAAAAAAAAAAAAAAwQAAAQEBAQEBAQEBAQEBQQEBAQEBAQEBAQEBAAEAAYHBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEAAQABAAEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAAAAAQAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAQAAAQAAAAAAAAAAAAAAAAAAAAAAAAEAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAgAAAAAAAAMDAwMDAwMDAwMDAwMDAwMDAwMDAwMDAwMDAAAAAAAAAwMDAwMDAwMDAwMDAwMDAwMDAwMDAwMDAwMAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAEAAAEAAAAAAAAAAAAAAAAAAAAAAAABAAAAAAAAAAAAAgAAAAACAAAAAAAAAAAAAAAAAAAAAAADAwMDAwMDAwMDAwMDAwMDAwMDAwMDAwMDAwAAAAAAAAMDAwMDAwMDAwMDAwMDAwMDAwMDAwMDAwMDAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAE5PVU5DRUVDS09VVE5FQ1RFVEVDUklCRUxVU0hFVEVBRFNFQVJDSFJHRUNUSVZJVFlMRU5EQVJWRU9USUZZUFRJT05TQ0hTRUFZU1RBVENIR0VPUkRJUkVDVE9SVFJDSFBBUkFNRVRFUlVSQ0VCU0NSSUJFQVJET1dOQUNFSU5ETktDS1VCU0NSSUJFSFRUUC9BRFRQLw=='\n","\"use strict\";\nObject.defineProperty(exports, \"__esModule\", { value: true });\nexports.enumToMap = void 0;\nfunction enumToMap(obj) {\n const res = {};\n Object.keys(obj).forEach((key) => {\n const value = obj[key];\n if (typeof value === 'number') {\n res[key] = value;\n }\n });\n return res;\n}\nexports.enumToMap = enumToMap;\n//# sourceMappingURL=utils.js.map","'use strict'\n\nconst { kClients } = require('../core/symbols')\nconst Agent = require('../agent')\nconst {\n kAgent,\n kMockAgentSet,\n kMockAgentGet,\n kDispatches,\n kIsMockActive,\n kNetConnect,\n kGetNetConnect,\n kOptions,\n kFactory\n} = require('./mock-symbols')\nconst MockClient = require('./mock-client')\nconst MockPool = require('./mock-pool')\nconst { matchValue, buildMockOptions } = require('./mock-utils')\nconst { InvalidArgumentError, UndiciError } = require('../core/errors')\nconst Dispatcher = require('../dispatcher')\nconst Pluralizer = require('./pluralizer')\nconst PendingInterceptorsFormatter = require('./pending-interceptors-formatter')\n\nclass FakeWeakRef {\n constructor (value) {\n this.value = value\n }\n\n deref () {\n return this.value\n }\n}\n\nclass MockAgent extends Dispatcher {\n constructor (opts) {\n super(opts)\n\n this[kNetConnect] = true\n this[kIsMockActive] = true\n\n // Instantiate Agent and encapsulate\n if ((opts && opts.agent && typeof opts.agent.dispatch !== 'function')) {\n throw new InvalidArgumentError('Argument opts.agent must implement Agent')\n }\n const agent = opts && opts.agent ? opts.agent : new Agent(opts)\n this[kAgent] = agent\n\n this[kClients] = agent[kClients]\n this[kOptions] = buildMockOptions(opts)\n }\n\n get (origin) {\n let dispatcher = this[kMockAgentGet](origin)\n\n if (!dispatcher) {\n dispatcher = this[kFactory](origin)\n this[kMockAgentSet](origin, dispatcher)\n }\n return dispatcher\n }\n\n dispatch (opts, handler) {\n // Call MockAgent.get to perform additional setup before dispatching as normal\n this.get(opts.origin)\n return this[kAgent].dispatch(opts, handler)\n }\n\n async close () {\n await this[kAgent].close()\n this[kClients].clear()\n }\n\n deactivate () {\n this[kIsMockActive] = false\n }\n\n activate () {\n this[kIsMockActive] = true\n }\n\n enableNetConnect (matcher) {\n if (typeof matcher === 'string' || typeof matcher === 'function' || matcher instanceof RegExp) {\n if (Array.isArray(this[kNetConnect])) {\n this[kNetConnect].push(matcher)\n } else {\n this[kNetConnect] = [matcher]\n }\n } else if (typeof matcher === 'undefined') {\n this[kNetConnect] = true\n } else {\n throw new InvalidArgumentError('Unsupported matcher. Must be one of String|Function|RegExp.')\n }\n }\n\n disableNetConnect () {\n this[kNetConnect] = false\n }\n\n // This is required to bypass issues caused by using global symbols - see:\n // https://github.com/nodejs/undici/issues/1447\n get isMockActive () {\n return this[kIsMockActive]\n }\n\n [kMockAgentSet] (origin, dispatcher) {\n this[kClients].set(origin, new FakeWeakRef(dispatcher))\n }\n\n [kFactory] (origin) {\n const mockOptions = Object.assign({ agent: this }, this[kOptions])\n return this[kOptions] && this[kOptions].connections === 1\n ? new MockClient(origin, mockOptions)\n : new MockPool(origin, mockOptions)\n }\n\n [kMockAgentGet] (origin) {\n // First check if we can immediately find it\n const ref = this[kClients].get(origin)\n if (ref) {\n return ref.deref()\n }\n\n // If the origin is not a string create a dummy parent pool and return to user\n if (typeof origin !== 'string') {\n const dispatcher = this[kFactory]('http://localhost:9999')\n this[kMockAgentSet](origin, dispatcher)\n return dispatcher\n }\n\n // If we match, create a pool and assign the same dispatches\n for (const [keyMatcher, nonExplicitRef] of Array.from(this[kClients])) {\n const nonExplicitDispatcher = nonExplicitRef.deref()\n if (nonExplicitDispatcher && typeof keyMatcher !== 'string' && matchValue(keyMatcher, origin)) {\n const dispatcher = this[kFactory](origin)\n this[kMockAgentSet](origin, dispatcher)\n dispatcher[kDispatches] = nonExplicitDispatcher[kDispatches]\n return dispatcher\n }\n }\n }\n\n [kGetNetConnect] () {\n return this[kNetConnect]\n }\n\n pendingInterceptors () {\n const mockAgentClients = this[kClients]\n\n return Array.from(mockAgentClients.entries())\n .flatMap(([origin, scope]) => scope.deref()[kDispatches].map(dispatch => ({ ...dispatch, origin })))\n .filter(({ pending }) => pending)\n }\n\n assertNoPendingInterceptors ({ pendingInterceptorsFormatter = new PendingInterceptorsFormatter() } = {}) {\n const pending = this.pendingInterceptors()\n\n if (pending.length === 0) {\n return\n }\n\n const pluralizer = new Pluralizer('interceptor', 'interceptors').pluralize(pending.length)\n\n throw new UndiciError(`\n${pluralizer.count} ${pluralizer.noun} ${pluralizer.is} pending:\n\n${pendingInterceptorsFormatter.format(pending)}\n`.trim())\n }\n}\n\nmodule.exports = MockAgent\n","'use strict'\n\nconst { promisify } = require('util')\nconst Client = require('../client')\nconst { buildMockDispatch } = require('./mock-utils')\nconst {\n kDispatches,\n kMockAgent,\n kClose,\n kOriginalClose,\n kOrigin,\n kOriginalDispatch,\n kConnected\n} = require('./mock-symbols')\nconst { MockInterceptor } = require('./mock-interceptor')\nconst Symbols = require('../core/symbols')\nconst { InvalidArgumentError } = require('../core/errors')\n\n/**\n * MockClient provides an API that extends the Client to influence the mockDispatches.\n */\nclass MockClient extends Client {\n constructor (origin, opts) {\n super(origin, opts)\n\n if (!opts || !opts.agent || typeof opts.agent.dispatch !== 'function') {\n throw new InvalidArgumentError('Argument opts.agent must implement Agent')\n }\n\n this[kMockAgent] = opts.agent\n this[kOrigin] = origin\n this[kDispatches] = []\n this[kConnected] = 1\n this[kOriginalDispatch] = this.dispatch\n this[kOriginalClose] = this.close.bind(this)\n\n this.dispatch = buildMockDispatch.call(this)\n this.close = this[kClose]\n }\n\n get [Symbols.kConnected] () {\n return this[kConnected]\n }\n\n /**\n * Sets up the base interceptor for mocking replies from undici.\n */\n intercept (opts) {\n return new MockInterceptor(opts, this[kDispatches])\n }\n\n async [kClose] () {\n await promisify(this[kOriginalClose])()\n this[kConnected] = 0\n this[kMockAgent][Symbols.kClients].delete(this[kOrigin])\n }\n}\n\nmodule.exports = MockClient\n","'use strict'\n\nconst { UndiciError } = require('../core/errors')\n\nclass MockNotMatchedError extends UndiciError {\n constructor (message) {\n super(message)\n Error.captureStackTrace(this, MockNotMatchedError)\n this.name = 'MockNotMatchedError'\n this.message = message || 'The request does not match any registered mock dispatches'\n this.code = 'UND_MOCK_ERR_MOCK_NOT_MATCHED'\n }\n}\n\nmodule.exports = {\n MockNotMatchedError\n}\n","'use strict'\n\nconst { getResponseData, buildKey, addMockDispatch } = require('./mock-utils')\nconst {\n kDispatches,\n kDispatchKey,\n kDefaultHeaders,\n kDefaultTrailers,\n kContentLength,\n kMockDispatch\n} = require('./mock-symbols')\nconst { InvalidArgumentError } = require('../core/errors')\nconst { buildURL } = require('../core/util')\n\n/**\n * Defines the scope API for an interceptor reply\n */\nclass MockScope {\n constructor (mockDispatch) {\n this[kMockDispatch] = mockDispatch\n }\n\n /**\n * Delay a reply by a set amount in ms.\n */\n delay (waitInMs) {\n if (typeof waitInMs !== 'number' || !Number.isInteger(waitInMs) || waitInMs <= 0) {\n throw new InvalidArgumentError('waitInMs must be a valid integer > 0')\n }\n\n this[kMockDispatch].delay = waitInMs\n return this\n }\n\n /**\n * For a defined reply, never mark as consumed.\n */\n persist () {\n this[kMockDispatch].persist = true\n return this\n }\n\n /**\n * Allow one to define a reply for a set amount of matching requests.\n */\n times (repeatTimes) {\n if (typeof repeatTimes !== 'number' || !Number.isInteger(repeatTimes) || repeatTimes <= 0) {\n throw new InvalidArgumentError('repeatTimes must be a valid integer > 0')\n }\n\n this[kMockDispatch].times = repeatTimes\n return this\n }\n}\n\n/**\n * Defines an interceptor for a Mock\n */\nclass MockInterceptor {\n constructor (opts, mockDispatches) {\n if (typeof opts !== 'object') {\n throw new InvalidArgumentError('opts must be an object')\n }\n if (typeof opts.path === 'undefined') {\n throw new InvalidArgumentError('opts.path must be defined')\n }\n if (typeof opts.method === 'undefined') {\n opts.method = 'GET'\n }\n // See https://github.com/nodejs/undici/issues/1245\n // As per RFC 3986, clients are not supposed to send URI\n // fragments to servers when they retrieve a document,\n if (typeof opts.path === 'string') {\n if (opts.query) {\n opts.path = buildURL(opts.path, opts.query)\n } else {\n // Matches https://github.com/nodejs/undici/blob/main/lib/fetch/index.js#L1811\n const parsedURL = new URL(opts.path, 'data://')\n opts.path = parsedURL.pathname + parsedURL.search\n }\n }\n if (typeof opts.method === 'string') {\n opts.method = opts.method.toUpperCase()\n }\n\n this[kDispatchKey] = buildKey(opts)\n this[kDispatches] = mockDispatches\n this[kDefaultHeaders] = {}\n this[kDefaultTrailers] = {}\n this[kContentLength] = false\n }\n\n createMockScopeDispatchData (statusCode, data, responseOptions = {}) {\n const responseData = getResponseData(data)\n const contentLength = this[kContentLength] ? { 'content-length': responseData.length } : {}\n const headers = { ...this[kDefaultHeaders], ...contentLength, ...responseOptions.headers }\n const trailers = { ...this[kDefaultTrailers], ...responseOptions.trailers }\n\n return { statusCode, data, headers, trailers }\n }\n\n validateReplyParameters (statusCode, data, responseOptions) {\n if (typeof statusCode === 'undefined') {\n throw new InvalidArgumentError('statusCode must be defined')\n }\n if (typeof data === 'undefined') {\n throw new InvalidArgumentError('data must be defined')\n }\n if (typeof responseOptions !== 'object') {\n throw new InvalidArgumentError('responseOptions must be an object')\n }\n }\n\n /**\n * Mock an undici request with a defined reply.\n */\n reply (replyData) {\n // Values of reply aren't available right now as they\n // can only be available when the reply callback is invoked.\n if (typeof replyData === 'function') {\n // We'll first wrap the provided callback in another function,\n // this function will properly resolve the data from the callback\n // when invoked.\n const wrappedDefaultsCallback = (opts) => {\n // Our reply options callback contains the parameter for statusCode, data and options.\n const resolvedData = replyData(opts)\n\n // Check if it is in the right format\n if (typeof resolvedData !== 'object') {\n throw new InvalidArgumentError('reply options callback must return an object')\n }\n\n const { statusCode, data = '', responseOptions = {} } = resolvedData\n this.validateReplyParameters(statusCode, data, responseOptions)\n // Since the values can be obtained immediately we return them\n // from this higher order function that will be resolved later.\n return {\n ...this.createMockScopeDispatchData(statusCode, data, responseOptions)\n }\n }\n\n // Add usual dispatch data, but this time set the data parameter to function that will eventually provide data.\n const newMockDispatch = addMockDispatch(this[kDispatches], this[kDispatchKey], wrappedDefaultsCallback)\n return new MockScope(newMockDispatch)\n }\n\n // We can have either one or three parameters, if we get here,\n // we should have 1-3 parameters. So we spread the arguments of\n // this function to obtain the parameters, since replyData will always\n // just be the statusCode.\n const [statusCode, data = '', responseOptions = {}] = [...arguments]\n this.validateReplyParameters(statusCode, data, responseOptions)\n\n // Send in-already provided data like usual\n const dispatchData = this.createMockScopeDispatchData(statusCode, data, responseOptions)\n const newMockDispatch = addMockDispatch(this[kDispatches], this[kDispatchKey], dispatchData)\n return new MockScope(newMockDispatch)\n }\n\n /**\n * Mock an undici request with a defined error.\n */\n replyWithError (error) {\n if (typeof error === 'undefined') {\n throw new InvalidArgumentError('error must be defined')\n }\n\n const newMockDispatch = addMockDispatch(this[kDispatches], this[kDispatchKey], { error })\n return new MockScope(newMockDispatch)\n }\n\n /**\n * Set default reply headers on the interceptor for subsequent replies\n */\n defaultReplyHeaders (headers) {\n if (typeof headers === 'undefined') {\n throw new InvalidArgumentError('headers must be defined')\n }\n\n this[kDefaultHeaders] = headers\n return this\n }\n\n /**\n * Set default reply trailers on the interceptor for subsequent replies\n */\n defaultReplyTrailers (trailers) {\n if (typeof trailers === 'undefined') {\n throw new InvalidArgumentError('trailers must be defined')\n }\n\n this[kDefaultTrailers] = trailers\n return this\n }\n\n /**\n * Set reply content length header for replies on the interceptor\n */\n replyContentLength () {\n this[kContentLength] = true\n return this\n }\n}\n\nmodule.exports.MockInterceptor = MockInterceptor\nmodule.exports.MockScope = MockScope\n","'use strict'\n\nconst { promisify } = require('util')\nconst Pool = require('../pool')\nconst { buildMockDispatch } = require('./mock-utils')\nconst {\n kDispatches,\n kMockAgent,\n kClose,\n kOriginalClose,\n kOrigin,\n kOriginalDispatch,\n kConnected\n} = require('./mock-symbols')\nconst { MockInterceptor } = require('./mock-interceptor')\nconst Symbols = require('../core/symbols')\nconst { InvalidArgumentError } = require('../core/errors')\n\n/**\n * MockPool provides an API that extends the Pool to influence the mockDispatches.\n */\nclass MockPool extends Pool {\n constructor (origin, opts) {\n super(origin, opts)\n\n if (!opts || !opts.agent || typeof opts.agent.dispatch !== 'function') {\n throw new InvalidArgumentError('Argument opts.agent must implement Agent')\n }\n\n this[kMockAgent] = opts.agent\n this[kOrigin] = origin\n this[kDispatches] = []\n this[kConnected] = 1\n this[kOriginalDispatch] = this.dispatch\n this[kOriginalClose] = this.close.bind(this)\n\n this.dispatch = buildMockDispatch.call(this)\n this.close = this[kClose]\n }\n\n get [Symbols.kConnected] () {\n return this[kConnected]\n }\n\n /**\n * Sets up the base interceptor for mocking replies from undici.\n */\n intercept (opts) {\n return new MockInterceptor(opts, this[kDispatches])\n }\n\n async [kClose] () {\n await promisify(this[kOriginalClose])()\n this[kConnected] = 0\n this[kMockAgent][Symbols.kClients].delete(this[kOrigin])\n }\n}\n\nmodule.exports = MockPool\n","'use strict'\n\nmodule.exports = {\n kAgent: Symbol('agent'),\n kOptions: Symbol('options'),\n kFactory: Symbol('factory'),\n kDispatches: Symbol('dispatches'),\n kDispatchKey: Symbol('dispatch key'),\n kDefaultHeaders: Symbol('default headers'),\n kDefaultTrailers: Symbol('default trailers'),\n kContentLength: Symbol('content length'),\n kMockAgent: Symbol('mock agent'),\n kMockAgentSet: Symbol('mock agent set'),\n kMockAgentGet: Symbol('mock agent get'),\n kMockDispatch: Symbol('mock dispatch'),\n kClose: Symbol('close'),\n kOriginalClose: Symbol('original agent close'),\n kOrigin: Symbol('origin'),\n kIsMockActive: Symbol('is mock active'),\n kNetConnect: Symbol('net connect'),\n kGetNetConnect: Symbol('get net connect'),\n kConnected: Symbol('connected')\n}\n","'use strict'\n\nconst { MockNotMatchedError } = require('./mock-errors')\nconst {\n kDispatches,\n kMockAgent,\n kOriginalDispatch,\n kOrigin,\n kGetNetConnect\n} = require('./mock-symbols')\nconst { buildURL, nop } = require('../core/util')\nconst { STATUS_CODES } = require('http')\nconst {\n types: {\n isPromise\n }\n} = require('util')\n\nfunction matchValue (match, value) {\n if (typeof match === 'string') {\n return match === value\n }\n if (match instanceof RegExp) {\n return match.test(value)\n }\n if (typeof match === 'function') {\n return match(value) === true\n }\n return false\n}\n\nfunction lowerCaseEntries (headers) {\n return Object.fromEntries(\n Object.entries(headers).map(([headerName, headerValue]) => {\n return [headerName.toLocaleLowerCase(), headerValue]\n })\n )\n}\n\n/**\n * @param {import('../../index').Headers|string[]|Record} headers\n * @param {string} key\n */\nfunction getHeaderByName (headers, key) {\n if (Array.isArray(headers)) {\n for (let i = 0; i < headers.length; i += 2) {\n if (headers[i].toLocaleLowerCase() === key.toLocaleLowerCase()) {\n return headers[i + 1]\n }\n }\n\n return undefined\n } else if (typeof headers.get === 'function') {\n return headers.get(key)\n } else {\n return lowerCaseEntries(headers)[key.toLocaleLowerCase()]\n }\n}\n\n/** @param {string[]} headers */\nfunction buildHeadersFromArray (headers) { // fetch HeadersList\n const clone = headers.slice()\n const entries = []\n for (let index = 0; index < clone.length; index += 2) {\n entries.push([clone[index], clone[index + 1]])\n }\n return Object.fromEntries(entries)\n}\n\nfunction matchHeaders (mockDispatch, headers) {\n if (typeof mockDispatch.headers === 'function') {\n if (Array.isArray(headers)) { // fetch HeadersList\n headers = buildHeadersFromArray(headers)\n }\n return mockDispatch.headers(headers ? lowerCaseEntries(headers) : {})\n }\n if (typeof mockDispatch.headers === 'undefined') {\n return true\n }\n if (typeof headers !== 'object' || typeof mockDispatch.headers !== 'object') {\n return false\n }\n\n for (const [matchHeaderName, matchHeaderValue] of Object.entries(mockDispatch.headers)) {\n const headerValue = getHeaderByName(headers, matchHeaderName)\n\n if (!matchValue(matchHeaderValue, headerValue)) {\n return false\n }\n }\n return true\n}\n\nfunction safeUrl (path) {\n if (typeof path !== 'string') {\n return path\n }\n\n const pathSegments = path.split('?')\n\n if (pathSegments.length !== 2) {\n return path\n }\n\n const qp = new URLSearchParams(pathSegments.pop())\n qp.sort()\n return [...pathSegments, qp.toString()].join('?')\n}\n\nfunction matchKey (mockDispatch, { path, method, body, headers }) {\n const pathMatch = matchValue(mockDispatch.path, path)\n const methodMatch = matchValue(mockDispatch.method, method)\n const bodyMatch = typeof mockDispatch.body !== 'undefined' ? matchValue(mockDispatch.body, body) : true\n const headersMatch = matchHeaders(mockDispatch, headers)\n return pathMatch && methodMatch && bodyMatch && headersMatch\n}\n\nfunction getResponseData (data) {\n if (Buffer.isBuffer(data)) {\n return data\n } else if (typeof data === 'object') {\n return JSON.stringify(data)\n } else {\n return data.toString()\n }\n}\n\nfunction getMockDispatch (mockDispatches, key) {\n const basePath = key.query ? buildURL(key.path, key.query) : key.path\n const resolvedPath = typeof basePath === 'string' ? safeUrl(basePath) : basePath\n\n // Match path\n let matchedMockDispatches = mockDispatches.filter(({ consumed }) => !consumed).filter(({ path }) => matchValue(safeUrl(path), resolvedPath))\n if (matchedMockDispatches.length === 0) {\n throw new MockNotMatchedError(`Mock dispatch not matched for path '${resolvedPath}'`)\n }\n\n // Match method\n matchedMockDispatches = matchedMockDispatches.filter(({ method }) => matchValue(method, key.method))\n if (matchedMockDispatches.length === 0) {\n throw new MockNotMatchedError(`Mock dispatch not matched for method '${key.method}'`)\n }\n\n // Match body\n matchedMockDispatches = matchedMockDispatches.filter(({ body }) => typeof body !== 'undefined' ? matchValue(body, key.body) : true)\n if (matchedMockDispatches.length === 0) {\n throw new MockNotMatchedError(`Mock dispatch not matched for body '${key.body}'`)\n }\n\n // Match headers\n matchedMockDispatches = matchedMockDispatches.filter((mockDispatch) => matchHeaders(mockDispatch, key.headers))\n if (matchedMockDispatches.length === 0) {\n throw new MockNotMatchedError(`Mock dispatch not matched for headers '${typeof key.headers === 'object' ? JSON.stringify(key.headers) : key.headers}'`)\n }\n\n return matchedMockDispatches[0]\n}\n\nfunction addMockDispatch (mockDispatches, key, data) {\n const baseData = { timesInvoked: 0, times: 1, persist: false, consumed: false }\n const replyData = typeof data === 'function' ? { callback: data } : { ...data }\n const newMockDispatch = { ...baseData, ...key, pending: true, data: { error: null, ...replyData } }\n mockDispatches.push(newMockDispatch)\n return newMockDispatch\n}\n\nfunction deleteMockDispatch (mockDispatches, key) {\n const index = mockDispatches.findIndex(dispatch => {\n if (!dispatch.consumed) {\n return false\n }\n return matchKey(dispatch, key)\n })\n if (index !== -1) {\n mockDispatches.splice(index, 1)\n }\n}\n\nfunction buildKey (opts) {\n const { path, method, body, headers, query } = opts\n return {\n path,\n method,\n body,\n headers,\n query\n }\n}\n\nfunction generateKeyValues (data) {\n return Object.entries(data).reduce((keyValuePairs, [key, value]) => [\n ...keyValuePairs,\n Buffer.from(`${key}`),\n Array.isArray(value) ? value.map(x => Buffer.from(`${x}`)) : Buffer.from(`${value}`)\n ], [])\n}\n\n/**\n * @see https://developer.mozilla.org/en-US/docs/Web/HTTP/Status\n * @param {number} statusCode\n */\nfunction getStatusText (statusCode) {\n return STATUS_CODES[statusCode] || 'unknown'\n}\n\nasync function getResponse (body) {\n const buffers = []\n for await (const data of body) {\n buffers.push(data)\n }\n return Buffer.concat(buffers).toString('utf8')\n}\n\n/**\n * Mock dispatch function used to simulate undici dispatches\n */\nfunction mockDispatch (opts, handler) {\n // Get mock dispatch from built key\n const key = buildKey(opts)\n const mockDispatch = getMockDispatch(this[kDispatches], key)\n\n mockDispatch.timesInvoked++\n\n // Here's where we resolve a callback if a callback is present for the dispatch data.\n if (mockDispatch.data.callback) {\n mockDispatch.data = { ...mockDispatch.data, ...mockDispatch.data.callback(opts) }\n }\n\n // Parse mockDispatch data\n const { data: { statusCode, data, headers, trailers, error }, delay, persist } = mockDispatch\n const { timesInvoked, times } = mockDispatch\n\n // If it's used up and not persistent, mark as consumed\n mockDispatch.consumed = !persist && timesInvoked >= times\n mockDispatch.pending = timesInvoked < times\n\n // If specified, trigger dispatch error\n if (error !== null) {\n deleteMockDispatch(this[kDispatches], key)\n handler.onError(error)\n return true\n }\n\n // Handle the request with a delay if necessary\n if (typeof delay === 'number' && delay > 0) {\n setTimeout(() => {\n handleReply(this[kDispatches])\n }, delay)\n } else {\n handleReply(this[kDispatches])\n }\n\n function handleReply (mockDispatches, _data = data) {\n // fetch's HeadersList is a 1D string array\n const optsHeaders = Array.isArray(opts.headers)\n ? buildHeadersFromArray(opts.headers)\n : opts.headers\n const body = typeof _data === 'function'\n ? _data({ ...opts, headers: optsHeaders })\n : _data\n\n // util.types.isPromise is likely needed for jest.\n if (isPromise(body)) {\n // If handleReply is asynchronous, throwing an error\n // in the callback will reject the promise, rather than\n // synchronously throw the error, which breaks some tests.\n // Rather, we wait for the callback to resolve if it is a\n // promise, and then re-run handleReply with the new body.\n body.then((newData) => handleReply(mockDispatches, newData))\n return\n }\n\n const responseData = getResponseData(body)\n const responseHeaders = generateKeyValues(headers)\n const responseTrailers = generateKeyValues(trailers)\n\n handler.abort = nop\n handler.onHeaders(statusCode, responseHeaders, resume, getStatusText(statusCode))\n handler.onData(Buffer.from(responseData))\n handler.onComplete(responseTrailers)\n deleteMockDispatch(mockDispatches, key)\n }\n\n function resume () {}\n\n return true\n}\n\nfunction buildMockDispatch () {\n const agent = this[kMockAgent]\n const origin = this[kOrigin]\n const originalDispatch = this[kOriginalDispatch]\n\n return function dispatch (opts, handler) {\n if (agent.isMockActive) {\n try {\n mockDispatch.call(this, opts, handler)\n } catch (error) {\n if (error instanceof MockNotMatchedError) {\n const netConnect = agent[kGetNetConnect]()\n if (netConnect === false) {\n throw new MockNotMatchedError(`${error.message}: subsequent request to origin ${origin} was not allowed (net.connect disabled)`)\n }\n if (checkNetConnect(netConnect, origin)) {\n originalDispatch.call(this, opts, handler)\n } else {\n throw new MockNotMatchedError(`${error.message}: subsequent request to origin ${origin} was not allowed (net.connect is not enabled for this origin)`)\n }\n } else {\n throw error\n }\n }\n } else {\n originalDispatch.call(this, opts, handler)\n }\n }\n}\n\nfunction checkNetConnect (netConnect, origin) {\n const url = new URL(origin)\n if (netConnect === true) {\n return true\n } else if (Array.isArray(netConnect) && netConnect.some((matcher) => matchValue(matcher, url.host))) {\n return true\n }\n return false\n}\n\nfunction buildMockOptions (opts) {\n if (opts) {\n const { agent, ...mockOptions } = opts\n return mockOptions\n }\n}\n\nmodule.exports = {\n getResponseData,\n getMockDispatch,\n addMockDispatch,\n deleteMockDispatch,\n buildKey,\n generateKeyValues,\n matchValue,\n getResponse,\n getStatusText,\n mockDispatch,\n buildMockDispatch,\n checkNetConnect,\n buildMockOptions,\n getHeaderByName\n}\n","'use strict'\n\nconst { Transform } = require('stream')\nconst { Console } = require('console')\n\n/**\n * Gets the output of `console.table(…)` as a string.\n */\nmodule.exports = class PendingInterceptorsFormatter {\n constructor ({ disableColors } = {}) {\n this.transform = new Transform({\n transform (chunk, _enc, cb) {\n cb(null, chunk)\n }\n })\n\n this.logger = new Console({\n stdout: this.transform,\n inspectOptions: {\n colors: !disableColors && !process.env.CI\n }\n })\n }\n\n format (pendingInterceptors) {\n const withPrettyHeaders = pendingInterceptors.map(\n ({ method, path, data: { statusCode }, persist, times, timesInvoked, origin }) => ({\n Method: method,\n Origin: origin,\n Path: path,\n 'Status code': statusCode,\n Persistent: persist ? '✅' : '❌',\n Invocations: timesInvoked,\n Remaining: persist ? Infinity : times - timesInvoked\n }))\n\n this.logger.table(withPrettyHeaders)\n return this.transform.read().toString()\n }\n}\n","'use strict'\n\nconst singulars = {\n pronoun: 'it',\n is: 'is',\n was: 'was',\n this: 'this'\n}\n\nconst plurals = {\n pronoun: 'they',\n is: 'are',\n was: 'were',\n this: 'these'\n}\n\nmodule.exports = class Pluralizer {\n constructor (singular, plural) {\n this.singular = singular\n this.plural = plural\n }\n\n pluralize (count) {\n const one = count === 1\n const keys = one ? singulars : plurals\n const noun = one ? this.singular : this.plural\n return { ...keys, count, noun }\n }\n}\n","/* eslint-disable */\n\n'use strict'\n\n// Extracted from node/lib/internal/fixed_queue.js\n\n// Currently optimal queue size, tested on V8 6.0 - 6.6. Must be power of two.\nconst kSize = 2048;\nconst kMask = kSize - 1;\n\n// The FixedQueue is implemented as a singly-linked list of fixed-size\n// circular buffers. It looks something like this:\n//\n// head tail\n// | |\n// v v\n// +-----------+ <-----\\ +-----------+ <------\\ +-----------+\n// | [null] | \\----- | next | \\------- | next |\n// +-----------+ +-----------+ +-----------+\n// | item | <-- bottom | item | <-- bottom | [empty] |\n// | item | | item | | [empty] |\n// | item | | item | | [empty] |\n// | item | | item | | [empty] |\n// | item | | item | bottom --> | item |\n// | item | | item | | item |\n// | ... | | ... | | ... |\n// | item | | item | | item |\n// | item | | item | | item |\n// | [empty] | <-- top | item | | item |\n// | [empty] | | item | | item |\n// | [empty] | | [empty] | <-- top top --> | [empty] |\n// +-----------+ +-----------+ +-----------+\n//\n// Or, if there is only one circular buffer, it looks something\n// like either of these:\n//\n// head tail head tail\n// | | | |\n// v v v v\n// +-----------+ +-----------+\n// | [null] | | [null] |\n// +-----------+ +-----------+\n// | [empty] | | item |\n// | [empty] | | item |\n// | item | <-- bottom top --> | [empty] |\n// | item | | [empty] |\n// | [empty] | <-- top bottom --> | item |\n// | [empty] | | item |\n// +-----------+ +-----------+\n//\n// Adding a value means moving `top` forward by one, removing means\n// moving `bottom` forward by one. After reaching the end, the queue\n// wraps around.\n//\n// When `top === bottom` the current queue is empty and when\n// `top + 1 === bottom` it's full. This wastes a single space of storage\n// but allows much quicker checks.\n\nclass FixedCircularBuffer {\n constructor() {\n this.bottom = 0;\n this.top = 0;\n this.list = new Array(kSize);\n this.next = null;\n }\n\n isEmpty() {\n return this.top === this.bottom;\n }\n\n isFull() {\n return ((this.top + 1) & kMask) === this.bottom;\n }\n\n push(data) {\n this.list[this.top] = data;\n this.top = (this.top + 1) & kMask;\n }\n\n shift() {\n const nextItem = this.list[this.bottom];\n if (nextItem === undefined)\n return null;\n this.list[this.bottom] = undefined;\n this.bottom = (this.bottom + 1) & kMask;\n return nextItem;\n }\n}\n\nmodule.exports = class FixedQueue {\n constructor() {\n this.head = this.tail = new FixedCircularBuffer();\n }\n\n isEmpty() {\n return this.head.isEmpty();\n }\n\n push(data) {\n if (this.head.isFull()) {\n // Head is full: Creates a new queue, sets the old queue's `.next` to it,\n // and sets it as the new main queue.\n this.head = this.head.next = new FixedCircularBuffer();\n }\n this.head.push(data);\n }\n\n shift() {\n const tail = this.tail;\n const next = tail.shift();\n if (tail.isEmpty() && tail.next !== null) {\n // If there is another queue, it forms the new tail.\n this.tail = tail.next;\n }\n return next;\n }\n};\n","'use strict'\n\nconst DispatcherBase = require('./dispatcher-base')\nconst FixedQueue = require('./node/fixed-queue')\nconst { kConnected, kSize, kRunning, kPending, kQueued, kBusy, kFree, kUrl, kClose, kDestroy, kDispatch } = require('./core/symbols')\nconst PoolStats = require('./pool-stats')\n\nconst kClients = Symbol('clients')\nconst kNeedDrain = Symbol('needDrain')\nconst kQueue = Symbol('queue')\nconst kClosedResolve = Symbol('closed resolve')\nconst kOnDrain = Symbol('onDrain')\nconst kOnConnect = Symbol('onConnect')\nconst kOnDisconnect = Symbol('onDisconnect')\nconst kOnConnectionError = Symbol('onConnectionError')\nconst kGetDispatcher = Symbol('get dispatcher')\nconst kAddClient = Symbol('add client')\nconst kRemoveClient = Symbol('remove client')\nconst kStats = Symbol('stats')\n\nclass PoolBase extends DispatcherBase {\n constructor () {\n super()\n\n this[kQueue] = new FixedQueue()\n this[kClients] = []\n this[kQueued] = 0\n\n const pool = this\n\n this[kOnDrain] = function onDrain (origin, targets) {\n const queue = pool[kQueue]\n\n let needDrain = false\n\n while (!needDrain) {\n const item = queue.shift()\n if (!item) {\n break\n }\n pool[kQueued]--\n needDrain = !this.dispatch(item.opts, item.handler)\n }\n\n this[kNeedDrain] = needDrain\n\n if (!this[kNeedDrain] && pool[kNeedDrain]) {\n pool[kNeedDrain] = false\n pool.emit('drain', origin, [pool, ...targets])\n }\n\n if (pool[kClosedResolve] && queue.isEmpty()) {\n Promise\n .all(pool[kClients].map(c => c.close()))\n .then(pool[kClosedResolve])\n }\n }\n\n this[kOnConnect] = (origin, targets) => {\n pool.emit('connect', origin, [pool, ...targets])\n }\n\n this[kOnDisconnect] = (origin, targets, err) => {\n pool.emit('disconnect', origin, [pool, ...targets], err)\n }\n\n this[kOnConnectionError] = (origin, targets, err) => {\n pool.emit('connectionError', origin, [pool, ...targets], err)\n }\n\n this[kStats] = new PoolStats(this)\n }\n\n get [kBusy] () {\n return this[kNeedDrain]\n }\n\n get [kConnected] () {\n return this[kClients].filter(client => client[kConnected]).length\n }\n\n get [kFree] () {\n return this[kClients].filter(client => client[kConnected] && !client[kNeedDrain]).length\n }\n\n get [kPending] () {\n let ret = this[kQueued]\n for (const { [kPending]: pending } of this[kClients]) {\n ret += pending\n }\n return ret\n }\n\n get [kRunning] () {\n let ret = 0\n for (const { [kRunning]: running } of this[kClients]) {\n ret += running\n }\n return ret\n }\n\n get [kSize] () {\n let ret = this[kQueued]\n for (const { [kSize]: size } of this[kClients]) {\n ret += size\n }\n return ret\n }\n\n get stats () {\n return this[kStats]\n }\n\n async [kClose] () {\n if (this[kQueue].isEmpty()) {\n return Promise.all(this[kClients].map(c => c.close()))\n } else {\n return new Promise((resolve) => {\n this[kClosedResolve] = resolve\n })\n }\n }\n\n async [kDestroy] (err) {\n while (true) {\n const item = this[kQueue].shift()\n if (!item) {\n break\n }\n item.handler.onError(err)\n }\n\n return Promise.all(this[kClients].map(c => c.destroy(err)))\n }\n\n [kDispatch] (opts, handler) {\n const dispatcher = this[kGetDispatcher]()\n\n if (!dispatcher) {\n this[kNeedDrain] = true\n this[kQueue].push({ opts, handler })\n this[kQueued]++\n } else if (!dispatcher.dispatch(opts, handler)) {\n dispatcher[kNeedDrain] = true\n this[kNeedDrain] = !this[kGetDispatcher]()\n }\n\n return !this[kNeedDrain]\n }\n\n [kAddClient] (client) {\n client\n .on('drain', this[kOnDrain])\n .on('connect', this[kOnConnect])\n .on('disconnect', this[kOnDisconnect])\n .on('connectionError', this[kOnConnectionError])\n\n this[kClients].push(client)\n\n if (this[kNeedDrain]) {\n process.nextTick(() => {\n if (this[kNeedDrain]) {\n this[kOnDrain](client[kUrl], [this, client])\n }\n })\n }\n\n return this\n }\n\n [kRemoveClient] (client) {\n client.close(() => {\n const idx = this[kClients].indexOf(client)\n if (idx !== -1) {\n this[kClients].splice(idx, 1)\n }\n })\n\n this[kNeedDrain] = this[kClients].some(dispatcher => (\n !dispatcher[kNeedDrain] &&\n dispatcher.closed !== true &&\n dispatcher.destroyed !== true\n ))\n }\n}\n\nmodule.exports = {\n PoolBase,\n kClients,\n kNeedDrain,\n kAddClient,\n kRemoveClient,\n kGetDispatcher\n}\n","const { kFree, kConnected, kPending, kQueued, kRunning, kSize } = require('./core/symbols')\nconst kPool = Symbol('pool')\n\nclass PoolStats {\n constructor (pool) {\n this[kPool] = pool\n }\n\n get connected () {\n return this[kPool][kConnected]\n }\n\n get free () {\n return this[kPool][kFree]\n }\n\n get pending () {\n return this[kPool][kPending]\n }\n\n get queued () {\n return this[kPool][kQueued]\n }\n\n get running () {\n return this[kPool][kRunning]\n }\n\n get size () {\n return this[kPool][kSize]\n }\n}\n\nmodule.exports = PoolStats\n","'use strict'\n\nconst {\n PoolBase,\n kClients,\n kNeedDrain,\n kAddClient,\n kGetDispatcher\n} = require('./pool-base')\nconst Client = require('./client')\nconst {\n InvalidArgumentError\n} = require('./core/errors')\nconst util = require('./core/util')\nconst { kUrl, kInterceptors } = require('./core/symbols')\nconst buildConnector = require('./core/connect')\n\nconst kOptions = Symbol('options')\nconst kConnections = Symbol('connections')\nconst kFactory = Symbol('factory')\n\nfunction defaultFactory (origin, opts) {\n return new Client(origin, opts)\n}\n\nclass Pool extends PoolBase {\n constructor (origin, {\n connections,\n factory = defaultFactory,\n connect,\n connectTimeout,\n tls,\n maxCachedSessions,\n socketPath,\n autoSelectFamily,\n autoSelectFamilyAttemptTimeout,\n allowH2,\n ...options\n } = {}) {\n super()\n\n if (connections != null && (!Number.isFinite(connections) || connections < 0)) {\n throw new InvalidArgumentError('invalid connections')\n }\n\n if (typeof factory !== 'function') {\n throw new InvalidArgumentError('factory must be a function.')\n }\n\n if (connect != null && typeof connect !== 'function' && typeof connect !== 'object') {\n throw new InvalidArgumentError('connect must be a function or an object')\n }\n\n if (typeof connect !== 'function') {\n connect = buildConnector({\n ...tls,\n maxCachedSessions,\n allowH2,\n socketPath,\n timeout: connectTimeout,\n ...(util.nodeHasAutoSelectFamily && autoSelectFamily ? { autoSelectFamily, autoSelectFamilyAttemptTimeout } : undefined),\n ...connect\n })\n }\n\n this[kInterceptors] = options.interceptors && options.interceptors.Pool && Array.isArray(options.interceptors.Pool)\n ? options.interceptors.Pool\n : []\n this[kConnections] = connections || null\n this[kUrl] = util.parseOrigin(origin)\n this[kOptions] = { ...util.deepClone(options), connect, allowH2 }\n this[kOptions].interceptors = options.interceptors\n ? { ...options.interceptors }\n : undefined\n this[kFactory] = factory\n }\n\n [kGetDispatcher] () {\n let dispatcher = this[kClients].find(dispatcher => !dispatcher[kNeedDrain])\n\n if (dispatcher) {\n return dispatcher\n }\n\n if (!this[kConnections] || this[kClients].length < this[kConnections]) {\n dispatcher = this[kFactory](this[kUrl], this[kOptions])\n this[kAddClient](dispatcher)\n }\n\n return dispatcher\n }\n}\n\nmodule.exports = Pool\n","'use strict'\n\nconst { kProxy, kClose, kDestroy, kInterceptors } = require('./core/symbols')\nconst { URL } = require('url')\nconst Agent = require('./agent')\nconst Pool = require('./pool')\nconst DispatcherBase = require('./dispatcher-base')\nconst { InvalidArgumentError, RequestAbortedError } = require('./core/errors')\nconst buildConnector = require('./core/connect')\n\nconst kAgent = Symbol('proxy agent')\nconst kClient = Symbol('proxy client')\nconst kProxyHeaders = Symbol('proxy headers')\nconst kRequestTls = Symbol('request tls settings')\nconst kProxyTls = Symbol('proxy tls settings')\nconst kConnectEndpoint = Symbol('connect endpoint function')\n\nfunction defaultProtocolPort (protocol) {\n return protocol === 'https:' ? 443 : 80\n}\n\nfunction buildProxyOptions (opts) {\n if (typeof opts === 'string') {\n opts = { uri: opts }\n }\n\n if (!opts || !opts.uri) {\n throw new InvalidArgumentError('Proxy opts.uri is mandatory')\n }\n\n return {\n uri: opts.uri,\n protocol: opts.protocol || 'https'\n }\n}\n\nfunction defaultFactory (origin, opts) {\n return new Pool(origin, opts)\n}\n\nclass ProxyAgent extends DispatcherBase {\n constructor (opts) {\n super(opts)\n this[kProxy] = buildProxyOptions(opts)\n this[kAgent] = new Agent(opts)\n this[kInterceptors] = opts.interceptors && opts.interceptors.ProxyAgent && Array.isArray(opts.interceptors.ProxyAgent)\n ? opts.interceptors.ProxyAgent\n : []\n\n if (typeof opts === 'string') {\n opts = { uri: opts }\n }\n\n if (!opts || !opts.uri) {\n throw new InvalidArgumentError('Proxy opts.uri is mandatory')\n }\n\n const { clientFactory = defaultFactory } = opts\n\n if (typeof clientFactory !== 'function') {\n throw new InvalidArgumentError('Proxy opts.clientFactory must be a function.')\n }\n\n this[kRequestTls] = opts.requestTls\n this[kProxyTls] = opts.proxyTls\n this[kProxyHeaders] = opts.headers || {}\n\n const resolvedUrl = new URL(opts.uri)\n const { origin, port, host, username, password } = resolvedUrl\n\n if (opts.auth && opts.token) {\n throw new InvalidArgumentError('opts.auth cannot be used in combination with opts.token')\n } else if (opts.auth) {\n /* @deprecated in favour of opts.token */\n this[kProxyHeaders]['proxy-authorization'] = `Basic ${opts.auth}`\n } else if (opts.token) {\n this[kProxyHeaders]['proxy-authorization'] = opts.token\n } else if (username && password) {\n this[kProxyHeaders]['proxy-authorization'] = `Basic ${Buffer.from(`${decodeURIComponent(username)}:${decodeURIComponent(password)}`).toString('base64')}`\n }\n\n const connect = buildConnector({ ...opts.proxyTls })\n this[kConnectEndpoint] = buildConnector({ ...opts.requestTls })\n this[kClient] = clientFactory(resolvedUrl, { connect })\n this[kAgent] = new Agent({\n ...opts,\n connect: async (opts, callback) => {\n let requestedHost = opts.host\n if (!opts.port) {\n requestedHost += `:${defaultProtocolPort(opts.protocol)}`\n }\n try {\n const { socket, statusCode } = await this[kClient].connect({\n origin,\n port,\n path: requestedHost,\n signal: opts.signal,\n headers: {\n ...this[kProxyHeaders],\n host\n }\n })\n if (statusCode !== 200) {\n socket.on('error', () => {}).destroy()\n callback(new RequestAbortedError(`Proxy response (${statusCode}) !== 200 when HTTP Tunneling`))\n }\n if (opts.protocol !== 'https:') {\n callback(null, socket)\n return\n }\n let servername\n if (this[kRequestTls]) {\n servername = this[kRequestTls].servername\n } else {\n servername = opts.servername\n }\n this[kConnectEndpoint]({ ...opts, servername, httpSocket: socket }, callback)\n } catch (err) {\n callback(err)\n }\n }\n })\n }\n\n dispatch (opts, handler) {\n const { host } = new URL(opts.origin)\n const headers = buildHeaders(opts.headers)\n throwIfProxyAuthIsSent(headers)\n return this[kAgent].dispatch(\n {\n ...opts,\n headers: {\n ...headers,\n host\n }\n },\n handler\n )\n }\n\n async [kClose] () {\n await this[kAgent].close()\n await this[kClient].close()\n }\n\n async [kDestroy] () {\n await this[kAgent].destroy()\n await this[kClient].destroy()\n }\n}\n\n/**\n * @param {string[] | Record} headers\n * @returns {Record}\n */\nfunction buildHeaders (headers) {\n // When using undici.fetch, the headers list is stored\n // as an array.\n if (Array.isArray(headers)) {\n /** @type {Record} */\n const headersPair = {}\n\n for (let i = 0; i < headers.length; i += 2) {\n headersPair[headers[i]] = headers[i + 1]\n }\n\n return headersPair\n }\n\n return headers\n}\n\n/**\n * @param {Record} headers\n *\n * Previous versions of ProxyAgent suggests the Proxy-Authorization in request headers\n * Nevertheless, it was changed and to avoid a security vulnerability by end users\n * this check was created.\n * It should be removed in the next major version for performance reasons\n */\nfunction throwIfProxyAuthIsSent (headers) {\n const existProxyAuth = headers && Object.keys(headers)\n .find((key) => key.toLowerCase() === 'proxy-authorization')\n if (existProxyAuth) {\n throw new InvalidArgumentError('Proxy-Authorization should be sent in ProxyAgent constructor')\n }\n}\n\nmodule.exports = ProxyAgent\n","'use strict'\n\nlet fastNow = Date.now()\nlet fastNowTimeout\n\nconst fastTimers = []\n\nfunction onTimeout () {\n fastNow = Date.now()\n\n let len = fastTimers.length\n let idx = 0\n while (idx < len) {\n const timer = fastTimers[idx]\n\n if (timer.state === 0) {\n timer.state = fastNow + timer.delay\n } else if (timer.state > 0 && fastNow >= timer.state) {\n timer.state = -1\n timer.callback(timer.opaque)\n }\n\n if (timer.state === -1) {\n timer.state = -2\n if (idx !== len - 1) {\n fastTimers[idx] = fastTimers.pop()\n } else {\n fastTimers.pop()\n }\n len -= 1\n } else {\n idx += 1\n }\n }\n\n if (fastTimers.length > 0) {\n refreshTimeout()\n }\n}\n\nfunction refreshTimeout () {\n if (fastNowTimeout && fastNowTimeout.refresh) {\n fastNowTimeout.refresh()\n } else {\n clearTimeout(fastNowTimeout)\n fastNowTimeout = setTimeout(onTimeout, 1e3)\n if (fastNowTimeout.unref) {\n fastNowTimeout.unref()\n }\n }\n}\n\nclass Timeout {\n constructor (callback, delay, opaque) {\n this.callback = callback\n this.delay = delay\n this.opaque = opaque\n\n // -2 not in timer list\n // -1 in timer list but inactive\n // 0 in timer list waiting for time\n // > 0 in timer list waiting for time to expire\n this.state = -2\n\n this.refresh()\n }\n\n refresh () {\n if (this.state === -2) {\n fastTimers.push(this)\n if (!fastNowTimeout || fastTimers.length === 1) {\n refreshTimeout()\n }\n }\n\n this.state = 0\n }\n\n clear () {\n this.state = -1\n }\n}\n\nmodule.exports = {\n setTimeout (callback, delay, opaque) {\n return delay < 1e3\n ? setTimeout(callback, delay, opaque)\n : new Timeout(callback, delay, opaque)\n },\n clearTimeout (timeout) {\n if (timeout instanceof Timeout) {\n timeout.clear()\n } else {\n clearTimeout(timeout)\n }\n }\n}\n","'use strict'\n\nconst diagnosticsChannel = require('diagnostics_channel')\nconst { uid, states } = require('./constants')\nconst {\n kReadyState,\n kSentClose,\n kByteParser,\n kReceivedClose\n} = require('./symbols')\nconst { fireEvent, failWebsocketConnection } = require('./util')\nconst { CloseEvent } = require('./events')\nconst { makeRequest } = require('../fetch/request')\nconst { fetching } = require('../fetch/index')\nconst { Headers } = require('../fetch/headers')\nconst { getGlobalDispatcher } = require('../global')\nconst { kHeadersList } = require('../core/symbols')\n\nconst channels = {}\nchannels.open = diagnosticsChannel.channel('undici:websocket:open')\nchannels.close = diagnosticsChannel.channel('undici:websocket:close')\nchannels.socketError = diagnosticsChannel.channel('undici:websocket:socket_error')\n\n/** @type {import('crypto')} */\nlet crypto\ntry {\n crypto = require('crypto')\n} catch {\n\n}\n\n/**\n * @see https://websockets.spec.whatwg.org/#concept-websocket-establish\n * @param {URL} url\n * @param {string|string[]} protocols\n * @param {import('./websocket').WebSocket} ws\n * @param {(response: any) => void} onEstablish\n * @param {Partial} options\n */\nfunction establishWebSocketConnection (url, protocols, ws, onEstablish, options) {\n // 1. Let requestURL be a copy of url, with its scheme set to \"http\", if url’s\n // scheme is \"ws\", and to \"https\" otherwise.\n const requestURL = url\n\n requestURL.protocol = url.protocol === 'ws:' ? 'http:' : 'https:'\n\n // 2. Let request be a new request, whose URL is requestURL, client is client,\n // service-workers mode is \"none\", referrer is \"no-referrer\", mode is\n // \"websocket\", credentials mode is \"include\", cache mode is \"no-store\" ,\n // and redirect mode is \"error\".\n const request = makeRequest({\n urlList: [requestURL],\n serviceWorkers: 'none',\n referrer: 'no-referrer',\n mode: 'websocket',\n credentials: 'include',\n cache: 'no-store',\n redirect: 'error'\n })\n\n // Note: undici extension, allow setting custom headers.\n if (options.headers) {\n const headersList = new Headers(options.headers)[kHeadersList]\n\n request.headersList = headersList\n }\n\n // 3. Append (`Upgrade`, `websocket`) to request’s header list.\n // 4. Append (`Connection`, `Upgrade`) to request’s header list.\n // Note: both of these are handled by undici currently.\n // https://github.com/nodejs/undici/blob/68c269c4144c446f3f1220951338daef4a6b5ec4/lib/client.js#L1397\n\n // 5. Let keyValue be a nonce consisting of a randomly selected\n // 16-byte value that has been forgiving-base64-encoded and\n // isomorphic encoded.\n const keyValue = crypto.randomBytes(16).toString('base64')\n\n // 6. Append (`Sec-WebSocket-Key`, keyValue) to request’s\n // header list.\n request.headersList.append('sec-websocket-key', keyValue)\n\n // 7. Append (`Sec-WebSocket-Version`, `13`) to request’s\n // header list.\n request.headersList.append('sec-websocket-version', '13')\n\n // 8. For each protocol in protocols, combine\n // (`Sec-WebSocket-Protocol`, protocol) in request’s header\n // list.\n for (const protocol of protocols) {\n request.headersList.append('sec-websocket-protocol', protocol)\n }\n\n // 9. Let permessageDeflate be a user-agent defined\n // \"permessage-deflate\" extension header value.\n // https://github.com/mozilla/gecko-dev/blob/ce78234f5e653a5d3916813ff990f053510227bc/netwerk/protocol/websocket/WebSocketChannel.cpp#L2673\n // TODO: enable once permessage-deflate is supported\n const permessageDeflate = '' // 'permessage-deflate; 15'\n\n // 10. Append (`Sec-WebSocket-Extensions`, permessageDeflate) to\n // request’s header list.\n // request.headersList.append('sec-websocket-extensions', permessageDeflate)\n\n // 11. Fetch request with useParallelQueue set to true, and\n // processResponse given response being these steps:\n const controller = fetching({\n request,\n useParallelQueue: true,\n dispatcher: options.dispatcher ?? getGlobalDispatcher(),\n processResponse (response) {\n // 1. If response is a network error or its status is not 101,\n // fail the WebSocket connection.\n if (response.type === 'error' || response.status !== 101) {\n failWebsocketConnection(ws, 'Received network error or non-101 status code.')\n return\n }\n\n // 2. If protocols is not the empty list and extracting header\n // list values given `Sec-WebSocket-Protocol` and response’s\n // header list results in null, failure, or the empty byte\n // sequence, then fail the WebSocket connection.\n if (protocols.length !== 0 && !response.headersList.get('Sec-WebSocket-Protocol')) {\n failWebsocketConnection(ws, 'Server did not respond with sent protocols.')\n return\n }\n\n // 3. Follow the requirements stated step 2 to step 6, inclusive,\n // of the last set of steps in section 4.1 of The WebSocket\n // Protocol to validate response. This either results in fail\n // the WebSocket connection or the WebSocket connection is\n // established.\n\n // 2. If the response lacks an |Upgrade| header field or the |Upgrade|\n // header field contains a value that is not an ASCII case-\n // insensitive match for the value \"websocket\", the client MUST\n // _Fail the WebSocket Connection_.\n if (response.headersList.get('Upgrade')?.toLowerCase() !== 'websocket') {\n failWebsocketConnection(ws, 'Server did not set Upgrade header to \"websocket\".')\n return\n }\n\n // 3. If the response lacks a |Connection| header field or the\n // |Connection| header field doesn't contain a token that is an\n // ASCII case-insensitive match for the value \"Upgrade\", the client\n // MUST _Fail the WebSocket Connection_.\n if (response.headersList.get('Connection')?.toLowerCase() !== 'upgrade') {\n failWebsocketConnection(ws, 'Server did not set Connection header to \"upgrade\".')\n return\n }\n\n // 4. If the response lacks a |Sec-WebSocket-Accept| header field or\n // the |Sec-WebSocket-Accept| contains a value other than the\n // base64-encoded SHA-1 of the concatenation of the |Sec-WebSocket-\n // Key| (as a string, not base64-decoded) with the string \"258EAFA5-\n // E914-47DA-95CA-C5AB0DC85B11\" but ignoring any leading and\n // trailing whitespace, the client MUST _Fail the WebSocket\n // Connection_.\n const secWSAccept = response.headersList.get('Sec-WebSocket-Accept')\n const digest = crypto.createHash('sha1').update(keyValue + uid).digest('base64')\n if (secWSAccept !== digest) {\n failWebsocketConnection(ws, 'Incorrect hash received in Sec-WebSocket-Accept header.')\n return\n }\n\n // 5. If the response includes a |Sec-WebSocket-Extensions| header\n // field and this header field indicates the use of an extension\n // that was not present in the client's handshake (the server has\n // indicated an extension not requested by the client), the client\n // MUST _Fail the WebSocket Connection_. (The parsing of this\n // header field to determine which extensions are requested is\n // discussed in Section 9.1.)\n const secExtension = response.headersList.get('Sec-WebSocket-Extensions')\n\n if (secExtension !== null && secExtension !== permessageDeflate) {\n failWebsocketConnection(ws, 'Received different permessage-deflate than the one set.')\n return\n }\n\n // 6. If the response includes a |Sec-WebSocket-Protocol| header field\n // and this header field indicates the use of a subprotocol that was\n // not present in the client's handshake (the server has indicated a\n // subprotocol not requested by the client), the client MUST _Fail\n // the WebSocket Connection_.\n const secProtocol = response.headersList.get('Sec-WebSocket-Protocol')\n\n if (secProtocol !== null && secProtocol !== request.headersList.get('Sec-WebSocket-Protocol')) {\n failWebsocketConnection(ws, 'Protocol was not set in the opening handshake.')\n return\n }\n\n response.socket.on('data', onSocketData)\n response.socket.on('close', onSocketClose)\n response.socket.on('error', onSocketError)\n\n if (channels.open.hasSubscribers) {\n channels.open.publish({\n address: response.socket.address(),\n protocol: secProtocol,\n extensions: secExtension\n })\n }\n\n onEstablish(response)\n }\n })\n\n return controller\n}\n\n/**\n * @param {Buffer} chunk\n */\nfunction onSocketData (chunk) {\n if (!this.ws[kByteParser].write(chunk)) {\n this.pause()\n }\n}\n\n/**\n * @see https://websockets.spec.whatwg.org/#feedback-from-the-protocol\n * @see https://datatracker.ietf.org/doc/html/rfc6455#section-7.1.4\n */\nfunction onSocketClose () {\n const { ws } = this\n\n // If the TCP connection was closed after the\n // WebSocket closing handshake was completed, the WebSocket connection\n // is said to have been closed _cleanly_.\n const wasClean = ws[kSentClose] && ws[kReceivedClose]\n\n let code = 1005\n let reason = ''\n\n const result = ws[kByteParser].closingInfo\n\n if (result) {\n code = result.code ?? 1005\n reason = result.reason\n } else if (!ws[kSentClose]) {\n // If _The WebSocket\n // Connection is Closed_ and no Close control frame was received by the\n // endpoint (such as could occur if the underlying transport connection\n // is lost), _The WebSocket Connection Close Code_ is considered to be\n // 1006.\n code = 1006\n }\n\n // 1. Change the ready state to CLOSED (3).\n ws[kReadyState] = states.CLOSED\n\n // 2. If the user agent was required to fail the WebSocket\n // connection, or if the WebSocket connection was closed\n // after being flagged as full, fire an event named error\n // at the WebSocket object.\n // TODO\n\n // 3. Fire an event named close at the WebSocket object,\n // using CloseEvent, with the wasClean attribute\n // initialized to true if the connection closed cleanly\n // and false otherwise, the code attribute initialized to\n // the WebSocket connection close code, and the reason\n // attribute initialized to the result of applying UTF-8\n // decode without BOM to the WebSocket connection close\n // reason.\n fireEvent('close', ws, CloseEvent, {\n wasClean, code, reason\n })\n\n if (channels.close.hasSubscribers) {\n channels.close.publish({\n websocket: ws,\n code,\n reason\n })\n }\n}\n\nfunction onSocketError (error) {\n const { ws } = this\n\n ws[kReadyState] = states.CLOSING\n\n if (channels.socketError.hasSubscribers) {\n channels.socketError.publish(error)\n }\n\n this.destroy()\n}\n\nmodule.exports = {\n establishWebSocketConnection\n}\n","'use strict'\n\n// This is a Globally Unique Identifier unique used\n// to validate that the endpoint accepts websocket\n// connections.\n// See https://www.rfc-editor.org/rfc/rfc6455.html#section-1.3\nconst uid = '258EAFA5-E914-47DA-95CA-C5AB0DC85B11'\n\n/** @type {PropertyDescriptor} */\nconst staticPropertyDescriptors = {\n enumerable: true,\n writable: false,\n configurable: false\n}\n\nconst states = {\n CONNECTING: 0,\n OPEN: 1,\n CLOSING: 2,\n CLOSED: 3\n}\n\nconst opcodes = {\n CONTINUATION: 0x0,\n TEXT: 0x1,\n BINARY: 0x2,\n CLOSE: 0x8,\n PING: 0x9,\n PONG: 0xA\n}\n\nconst maxUnsigned16Bit = 2 ** 16 - 1 // 65535\n\nconst parserStates = {\n INFO: 0,\n PAYLOADLENGTH_16: 2,\n PAYLOADLENGTH_64: 3,\n READ_DATA: 4\n}\n\nconst emptyBuffer = Buffer.allocUnsafe(0)\n\nmodule.exports = {\n uid,\n staticPropertyDescriptors,\n states,\n opcodes,\n maxUnsigned16Bit,\n parserStates,\n emptyBuffer\n}\n","'use strict'\n\nconst { webidl } = require('../fetch/webidl')\nconst { kEnumerableProperty } = require('../core/util')\nconst { MessagePort } = require('worker_threads')\n\n/**\n * @see https://html.spec.whatwg.org/multipage/comms.html#messageevent\n */\nclass MessageEvent extends Event {\n #eventInit\n\n constructor (type, eventInitDict = {}) {\n webidl.argumentLengthCheck(arguments, 1, { header: 'MessageEvent constructor' })\n\n type = webidl.converters.DOMString(type)\n eventInitDict = webidl.converters.MessageEventInit(eventInitDict)\n\n super(type, eventInitDict)\n\n this.#eventInit = eventInitDict\n }\n\n get data () {\n webidl.brandCheck(this, MessageEvent)\n\n return this.#eventInit.data\n }\n\n get origin () {\n webidl.brandCheck(this, MessageEvent)\n\n return this.#eventInit.origin\n }\n\n get lastEventId () {\n webidl.brandCheck(this, MessageEvent)\n\n return this.#eventInit.lastEventId\n }\n\n get source () {\n webidl.brandCheck(this, MessageEvent)\n\n return this.#eventInit.source\n }\n\n get ports () {\n webidl.brandCheck(this, MessageEvent)\n\n if (!Object.isFrozen(this.#eventInit.ports)) {\n Object.freeze(this.#eventInit.ports)\n }\n\n return this.#eventInit.ports\n }\n\n initMessageEvent (\n type,\n bubbles = false,\n cancelable = false,\n data = null,\n origin = '',\n lastEventId = '',\n source = null,\n ports = []\n ) {\n webidl.brandCheck(this, MessageEvent)\n\n webidl.argumentLengthCheck(arguments, 1, { header: 'MessageEvent.initMessageEvent' })\n\n return new MessageEvent(type, {\n bubbles, cancelable, data, origin, lastEventId, source, ports\n })\n }\n}\n\n/**\n * @see https://websockets.spec.whatwg.org/#the-closeevent-interface\n */\nclass CloseEvent extends Event {\n #eventInit\n\n constructor (type, eventInitDict = {}) {\n webidl.argumentLengthCheck(arguments, 1, { header: 'CloseEvent constructor' })\n\n type = webidl.converters.DOMString(type)\n eventInitDict = webidl.converters.CloseEventInit(eventInitDict)\n\n super(type, eventInitDict)\n\n this.#eventInit = eventInitDict\n }\n\n get wasClean () {\n webidl.brandCheck(this, CloseEvent)\n\n return this.#eventInit.wasClean\n }\n\n get code () {\n webidl.brandCheck(this, CloseEvent)\n\n return this.#eventInit.code\n }\n\n get reason () {\n webidl.brandCheck(this, CloseEvent)\n\n return this.#eventInit.reason\n }\n}\n\n// https://html.spec.whatwg.org/multipage/webappapis.html#the-errorevent-interface\nclass ErrorEvent extends Event {\n #eventInit\n\n constructor (type, eventInitDict) {\n webidl.argumentLengthCheck(arguments, 1, { header: 'ErrorEvent constructor' })\n\n super(type, eventInitDict)\n\n type = webidl.converters.DOMString(type)\n eventInitDict = webidl.converters.ErrorEventInit(eventInitDict ?? {})\n\n this.#eventInit = eventInitDict\n }\n\n get message () {\n webidl.brandCheck(this, ErrorEvent)\n\n return this.#eventInit.message\n }\n\n get filename () {\n webidl.brandCheck(this, ErrorEvent)\n\n return this.#eventInit.filename\n }\n\n get lineno () {\n webidl.brandCheck(this, ErrorEvent)\n\n return this.#eventInit.lineno\n }\n\n get colno () {\n webidl.brandCheck(this, ErrorEvent)\n\n return this.#eventInit.colno\n }\n\n get error () {\n webidl.brandCheck(this, ErrorEvent)\n\n return this.#eventInit.error\n }\n}\n\nObject.defineProperties(MessageEvent.prototype, {\n [Symbol.toStringTag]: {\n value: 'MessageEvent',\n configurable: true\n },\n data: kEnumerableProperty,\n origin: kEnumerableProperty,\n lastEventId: kEnumerableProperty,\n source: kEnumerableProperty,\n ports: kEnumerableProperty,\n initMessageEvent: kEnumerableProperty\n})\n\nObject.defineProperties(CloseEvent.prototype, {\n [Symbol.toStringTag]: {\n value: 'CloseEvent',\n configurable: true\n },\n reason: kEnumerableProperty,\n code: kEnumerableProperty,\n wasClean: kEnumerableProperty\n})\n\nObject.defineProperties(ErrorEvent.prototype, {\n [Symbol.toStringTag]: {\n value: 'ErrorEvent',\n configurable: true\n },\n message: kEnumerableProperty,\n filename: kEnumerableProperty,\n lineno: kEnumerableProperty,\n colno: kEnumerableProperty,\n error: kEnumerableProperty\n})\n\nwebidl.converters.MessagePort = webidl.interfaceConverter(MessagePort)\n\nwebidl.converters['sequence'] = webidl.sequenceConverter(\n webidl.converters.MessagePort\n)\n\nconst eventInit = [\n {\n key: 'bubbles',\n converter: webidl.converters.boolean,\n defaultValue: false\n },\n {\n key: 'cancelable',\n converter: webidl.converters.boolean,\n defaultValue: false\n },\n {\n key: 'composed',\n converter: webidl.converters.boolean,\n defaultValue: false\n }\n]\n\nwebidl.converters.MessageEventInit = webidl.dictionaryConverter([\n ...eventInit,\n {\n key: 'data',\n converter: webidl.converters.any,\n defaultValue: null\n },\n {\n key: 'origin',\n converter: webidl.converters.USVString,\n defaultValue: ''\n },\n {\n key: 'lastEventId',\n converter: webidl.converters.DOMString,\n defaultValue: ''\n },\n {\n key: 'source',\n // Node doesn't implement WindowProxy or ServiceWorker, so the only\n // valid value for source is a MessagePort.\n converter: webidl.nullableConverter(webidl.converters.MessagePort),\n defaultValue: null\n },\n {\n key: 'ports',\n converter: webidl.converters['sequence'],\n get defaultValue () {\n return []\n }\n }\n])\n\nwebidl.converters.CloseEventInit = webidl.dictionaryConverter([\n ...eventInit,\n {\n key: 'wasClean',\n converter: webidl.converters.boolean,\n defaultValue: false\n },\n {\n key: 'code',\n converter: webidl.converters['unsigned short'],\n defaultValue: 0\n },\n {\n key: 'reason',\n converter: webidl.converters.USVString,\n defaultValue: ''\n }\n])\n\nwebidl.converters.ErrorEventInit = webidl.dictionaryConverter([\n ...eventInit,\n {\n key: 'message',\n converter: webidl.converters.DOMString,\n defaultValue: ''\n },\n {\n key: 'filename',\n converter: webidl.converters.USVString,\n defaultValue: ''\n },\n {\n key: 'lineno',\n converter: webidl.converters['unsigned long'],\n defaultValue: 0\n },\n {\n key: 'colno',\n converter: webidl.converters['unsigned long'],\n defaultValue: 0\n },\n {\n key: 'error',\n converter: webidl.converters.any\n }\n])\n\nmodule.exports = {\n MessageEvent,\n CloseEvent,\n ErrorEvent\n}\n","'use strict'\n\nconst { maxUnsigned16Bit } = require('./constants')\n\n/** @type {import('crypto')} */\nlet crypto\ntry {\n crypto = require('crypto')\n} catch {\n\n}\n\nclass WebsocketFrameSend {\n /**\n * @param {Buffer|undefined} data\n */\n constructor (data) {\n this.frameData = data\n this.maskKey = crypto.randomBytes(4)\n }\n\n createFrame (opcode) {\n const bodyLength = this.frameData?.byteLength ?? 0\n\n /** @type {number} */\n let payloadLength = bodyLength // 0-125\n let offset = 6\n\n if (bodyLength > maxUnsigned16Bit) {\n offset += 8 // payload length is next 8 bytes\n payloadLength = 127\n } else if (bodyLength > 125) {\n offset += 2 // payload length is next 2 bytes\n payloadLength = 126\n }\n\n const buffer = Buffer.allocUnsafe(bodyLength + offset)\n\n // Clear first 2 bytes, everything else is overwritten\n buffer[0] = buffer[1] = 0\n buffer[0] |= 0x80 // FIN\n buffer[0] = (buffer[0] & 0xF0) + opcode // opcode\n\n /*! ws. MIT License. Einar Otto Stangvik */\n buffer[offset - 4] = this.maskKey[0]\n buffer[offset - 3] = this.maskKey[1]\n buffer[offset - 2] = this.maskKey[2]\n buffer[offset - 1] = this.maskKey[3]\n\n buffer[1] = payloadLength\n\n if (payloadLength === 126) {\n buffer.writeUInt16BE(bodyLength, 2)\n } else if (payloadLength === 127) {\n // Clear extended payload length\n buffer[2] = buffer[3] = 0\n buffer.writeUIntBE(bodyLength, 4, 6)\n }\n\n buffer[1] |= 0x80 // MASK\n\n // mask body\n for (let i = 0; i < bodyLength; i++) {\n buffer[offset + i] = this.frameData[i] ^ this.maskKey[i % 4]\n }\n\n return buffer\n }\n}\n\nmodule.exports = {\n WebsocketFrameSend\n}\n","'use strict'\n\nconst { Writable } = require('stream')\nconst diagnosticsChannel = require('diagnostics_channel')\nconst { parserStates, opcodes, states, emptyBuffer } = require('./constants')\nconst { kReadyState, kSentClose, kResponse, kReceivedClose } = require('./symbols')\nconst { isValidStatusCode, failWebsocketConnection, websocketMessageReceived } = require('./util')\nconst { WebsocketFrameSend } = require('./frame')\n\n// This code was influenced by ws released under the MIT license.\n// Copyright (c) 2011 Einar Otto Stangvik \n// Copyright (c) 2013 Arnout Kazemier and contributors\n// Copyright (c) 2016 Luigi Pinca and contributors\n\nconst channels = {}\nchannels.ping = diagnosticsChannel.channel('undici:websocket:ping')\nchannels.pong = diagnosticsChannel.channel('undici:websocket:pong')\n\nclass ByteParser extends Writable {\n #buffers = []\n #byteOffset = 0\n\n #state = parserStates.INFO\n\n #info = {}\n #fragments = []\n\n constructor (ws) {\n super()\n\n this.ws = ws\n }\n\n /**\n * @param {Buffer} chunk\n * @param {() => void} callback\n */\n _write (chunk, _, callback) {\n this.#buffers.push(chunk)\n this.#byteOffset += chunk.length\n\n this.run(callback)\n }\n\n /**\n * Runs whenever a new chunk is received.\n * Callback is called whenever there are no more chunks buffering,\n * or not enough bytes are buffered to parse.\n */\n run (callback) {\n while (true) {\n if (this.#state === parserStates.INFO) {\n // If there aren't enough bytes to parse the payload length, etc.\n if (this.#byteOffset < 2) {\n return callback()\n }\n\n const buffer = this.consume(2)\n\n this.#info.fin = (buffer[0] & 0x80) !== 0\n this.#info.opcode = buffer[0] & 0x0F\n\n // If we receive a fragmented message, we use the type of the first\n // frame to parse the full message as binary/text, when it's terminated\n this.#info.originalOpcode ??= this.#info.opcode\n\n this.#info.fragmented = !this.#info.fin && this.#info.opcode !== opcodes.CONTINUATION\n\n if (this.#info.fragmented && this.#info.opcode !== opcodes.BINARY && this.#info.opcode !== opcodes.TEXT) {\n // Only text and binary frames can be fragmented\n failWebsocketConnection(this.ws, 'Invalid frame type was fragmented.')\n return\n }\n\n const payloadLength = buffer[1] & 0x7F\n\n if (payloadLength <= 125) {\n this.#info.payloadLength = payloadLength\n this.#state = parserStates.READ_DATA\n } else if (payloadLength === 126) {\n this.#state = parserStates.PAYLOADLENGTH_16\n } else if (payloadLength === 127) {\n this.#state = parserStates.PAYLOADLENGTH_64\n }\n\n if (this.#info.fragmented && payloadLength > 125) {\n // A fragmented frame can't be fragmented itself\n failWebsocketConnection(this.ws, 'Fragmented frame exceeded 125 bytes.')\n return\n } else if (\n (this.#info.opcode === opcodes.PING ||\n this.#info.opcode === opcodes.PONG ||\n this.#info.opcode === opcodes.CLOSE) &&\n payloadLength > 125\n ) {\n // Control frames can have a payload length of 125 bytes MAX\n failWebsocketConnection(this.ws, 'Payload length for control frame exceeded 125 bytes.')\n return\n } else if (this.#info.opcode === opcodes.CLOSE) {\n if (payloadLength === 1) {\n failWebsocketConnection(this.ws, 'Received close frame with a 1-byte body.')\n return\n }\n\n const body = this.consume(payloadLength)\n\n this.#info.closeInfo = this.parseCloseBody(false, body)\n\n if (!this.ws[kSentClose]) {\n // If an endpoint receives a Close frame and did not previously send a\n // Close frame, the endpoint MUST send a Close frame in response. (When\n // sending a Close frame in response, the endpoint typically echos the\n // status code it received.)\n const body = Buffer.allocUnsafe(2)\n body.writeUInt16BE(this.#info.closeInfo.code, 0)\n const closeFrame = new WebsocketFrameSend(body)\n\n this.ws[kResponse].socket.write(\n closeFrame.createFrame(opcodes.CLOSE),\n (err) => {\n if (!err) {\n this.ws[kSentClose] = true\n }\n }\n )\n }\n\n // Upon either sending or receiving a Close control frame, it is said\n // that _The WebSocket Closing Handshake is Started_ and that the\n // WebSocket connection is in the CLOSING state.\n this.ws[kReadyState] = states.CLOSING\n this.ws[kReceivedClose] = true\n\n this.end()\n\n return\n } else if (this.#info.opcode === opcodes.PING) {\n // Upon receipt of a Ping frame, an endpoint MUST send a Pong frame in\n // response, unless it already received a Close frame.\n // A Pong frame sent in response to a Ping frame must have identical\n // \"Application data\"\n\n const body = this.consume(payloadLength)\n\n if (!this.ws[kReceivedClose]) {\n const frame = new WebsocketFrameSend(body)\n\n this.ws[kResponse].socket.write(frame.createFrame(opcodes.PONG))\n\n if (channels.ping.hasSubscribers) {\n channels.ping.publish({\n payload: body\n })\n }\n }\n\n this.#state = parserStates.INFO\n\n if (this.#byteOffset > 0) {\n continue\n } else {\n callback()\n return\n }\n } else if (this.#info.opcode === opcodes.PONG) {\n // A Pong frame MAY be sent unsolicited. This serves as a\n // unidirectional heartbeat. A response to an unsolicited Pong frame is\n // not expected.\n\n const body = this.consume(payloadLength)\n\n if (channels.pong.hasSubscribers) {\n channels.pong.publish({\n payload: body\n })\n }\n\n if (this.#byteOffset > 0) {\n continue\n } else {\n callback()\n return\n }\n }\n } else if (this.#state === parserStates.PAYLOADLENGTH_16) {\n if (this.#byteOffset < 2) {\n return callback()\n }\n\n const buffer = this.consume(2)\n\n this.#info.payloadLength = buffer.readUInt16BE(0)\n this.#state = parserStates.READ_DATA\n } else if (this.#state === parserStates.PAYLOADLENGTH_64) {\n if (this.#byteOffset < 8) {\n return callback()\n }\n\n const buffer = this.consume(8)\n const upper = buffer.readUInt32BE(0)\n\n // 2^31 is the maxinimum bytes an arraybuffer can contain\n // on 32-bit systems. Although, on 64-bit systems, this is\n // 2^53-1 bytes.\n // https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Errors/Invalid_array_length\n // https://source.chromium.org/chromium/chromium/src/+/main:v8/src/common/globals.h;drc=1946212ac0100668f14eb9e2843bdd846e510a1e;bpv=1;bpt=1;l=1275\n // https://source.chromium.org/chromium/chromium/src/+/main:v8/src/objects/js-array-buffer.h;l=34;drc=1946212ac0100668f14eb9e2843bdd846e510a1e\n if (upper > 2 ** 31 - 1) {\n failWebsocketConnection(this.ws, 'Received payload length > 2^31 bytes.')\n return\n }\n\n const lower = buffer.readUInt32BE(4)\n\n this.#info.payloadLength = (upper << 8) + lower\n this.#state = parserStates.READ_DATA\n } else if (this.#state === parserStates.READ_DATA) {\n if (this.#byteOffset < this.#info.payloadLength) {\n // If there is still more data in this chunk that needs to be read\n return callback()\n } else if (this.#byteOffset >= this.#info.payloadLength) {\n // If the server sent multiple frames in a single chunk\n\n const body = this.consume(this.#info.payloadLength)\n\n this.#fragments.push(body)\n\n // If the frame is unfragmented, or a fragmented frame was terminated,\n // a message was received\n if (!this.#info.fragmented || (this.#info.fin && this.#info.opcode === opcodes.CONTINUATION)) {\n const fullMessage = Buffer.concat(this.#fragments)\n\n websocketMessageReceived(this.ws, this.#info.originalOpcode, fullMessage)\n\n this.#info = {}\n this.#fragments.length = 0\n }\n\n this.#state = parserStates.INFO\n }\n }\n\n if (this.#byteOffset > 0) {\n continue\n } else {\n callback()\n break\n }\n }\n }\n\n /**\n * Take n bytes from the buffered Buffers\n * @param {number} n\n * @returns {Buffer|null}\n */\n consume (n) {\n if (n > this.#byteOffset) {\n return null\n } else if (n === 0) {\n return emptyBuffer\n }\n\n if (this.#buffers[0].length === n) {\n this.#byteOffset -= this.#buffers[0].length\n return this.#buffers.shift()\n }\n\n const buffer = Buffer.allocUnsafe(n)\n let offset = 0\n\n while (offset !== n) {\n const next = this.#buffers[0]\n const { length } = next\n\n if (length + offset === n) {\n buffer.set(this.#buffers.shift(), offset)\n break\n } else if (length + offset > n) {\n buffer.set(next.subarray(0, n - offset), offset)\n this.#buffers[0] = next.subarray(n - offset)\n break\n } else {\n buffer.set(this.#buffers.shift(), offset)\n offset += next.length\n }\n }\n\n this.#byteOffset -= n\n\n return buffer\n }\n\n parseCloseBody (onlyCode, data) {\n // https://datatracker.ietf.org/doc/html/rfc6455#section-7.1.5\n /** @type {number|undefined} */\n let code\n\n if (data.length >= 2) {\n // _The WebSocket Connection Close Code_ is\n // defined as the status code (Section 7.4) contained in the first Close\n // control frame received by the application\n code = data.readUInt16BE(0)\n }\n\n if (onlyCode) {\n if (!isValidStatusCode(code)) {\n return null\n }\n\n return { code }\n }\n\n // https://datatracker.ietf.org/doc/html/rfc6455#section-7.1.6\n /** @type {Buffer} */\n let reason = data.subarray(2)\n\n // Remove BOM\n if (reason[0] === 0xEF && reason[1] === 0xBB && reason[2] === 0xBF) {\n reason = reason.subarray(3)\n }\n\n if (code !== undefined && !isValidStatusCode(code)) {\n return null\n }\n\n try {\n // TODO: optimize this\n reason = new TextDecoder('utf-8', { fatal: true }).decode(reason)\n } catch {\n return null\n }\n\n return { code, reason }\n }\n\n get closingInfo () {\n return this.#info.closeInfo\n }\n}\n\nmodule.exports = {\n ByteParser\n}\n","'use strict'\n\nmodule.exports = {\n kWebSocketURL: Symbol('url'),\n kReadyState: Symbol('ready state'),\n kController: Symbol('controller'),\n kResponse: Symbol('response'),\n kBinaryType: Symbol('binary type'),\n kSentClose: Symbol('sent close'),\n kReceivedClose: Symbol('received close'),\n kByteParser: Symbol('byte parser')\n}\n","'use strict'\n\nconst { kReadyState, kController, kResponse, kBinaryType, kWebSocketURL } = require('./symbols')\nconst { states, opcodes } = require('./constants')\nconst { MessageEvent, ErrorEvent } = require('./events')\n\n/* globals Blob */\n\n/**\n * @param {import('./websocket').WebSocket} ws\n */\nfunction isEstablished (ws) {\n // If the server's response is validated as provided for above, it is\n // said that _The WebSocket Connection is Established_ and that the\n // WebSocket Connection is in the OPEN state.\n return ws[kReadyState] === states.OPEN\n}\n\n/**\n * @param {import('./websocket').WebSocket} ws\n */\nfunction isClosing (ws) {\n // Upon either sending or receiving a Close control frame, it is said\n // that _The WebSocket Closing Handshake is Started_ and that the\n // WebSocket connection is in the CLOSING state.\n return ws[kReadyState] === states.CLOSING\n}\n\n/**\n * @param {import('./websocket').WebSocket} ws\n */\nfunction isClosed (ws) {\n return ws[kReadyState] === states.CLOSED\n}\n\n/**\n * @see https://dom.spec.whatwg.org/#concept-event-fire\n * @param {string} e\n * @param {EventTarget} target\n * @param {EventInit | undefined} eventInitDict\n */\nfunction fireEvent (e, target, eventConstructor = Event, eventInitDict) {\n // 1. If eventConstructor is not given, then let eventConstructor be Event.\n\n // 2. Let event be the result of creating an event given eventConstructor,\n // in the relevant realm of target.\n // 3. Initialize event’s type attribute to e.\n const event = new eventConstructor(e, eventInitDict) // eslint-disable-line new-cap\n\n // 4. Initialize any other IDL attributes of event as described in the\n // invocation of this algorithm.\n\n // 5. Return the result of dispatching event at target, with legacy target\n // override flag set if set.\n target.dispatchEvent(event)\n}\n\n/**\n * @see https://websockets.spec.whatwg.org/#feedback-from-the-protocol\n * @param {import('./websocket').WebSocket} ws\n * @param {number} type Opcode\n * @param {Buffer} data application data\n */\nfunction websocketMessageReceived (ws, type, data) {\n // 1. If ready state is not OPEN (1), then return.\n if (ws[kReadyState] !== states.OPEN) {\n return\n }\n\n // 2. Let dataForEvent be determined by switching on type and binary type:\n let dataForEvent\n\n if (type === opcodes.TEXT) {\n // -> type indicates that the data is Text\n // a new DOMString containing data\n try {\n dataForEvent = new TextDecoder('utf-8', { fatal: true }).decode(data)\n } catch {\n failWebsocketConnection(ws, 'Received invalid UTF-8 in text frame.')\n return\n }\n } else if (type === opcodes.BINARY) {\n if (ws[kBinaryType] === 'blob') {\n // -> type indicates that the data is Binary and binary type is \"blob\"\n // a new Blob object, created in the relevant Realm of the WebSocket\n // object, that represents data as its raw data\n dataForEvent = new Blob([data])\n } else {\n // -> type indicates that the data is Binary and binary type is \"arraybuffer\"\n // a new ArrayBuffer object, created in the relevant Realm of the\n // WebSocket object, whose contents are data\n dataForEvent = new Uint8Array(data).buffer\n }\n }\n\n // 3. Fire an event named message at the WebSocket object, using MessageEvent,\n // with the origin attribute initialized to the serialization of the WebSocket\n // object’s url's origin, and the data attribute initialized to dataForEvent.\n fireEvent('message', ws, MessageEvent, {\n origin: ws[kWebSocketURL].origin,\n data: dataForEvent\n })\n}\n\n/**\n * @see https://datatracker.ietf.org/doc/html/rfc6455\n * @see https://datatracker.ietf.org/doc/html/rfc2616\n * @see https://bugs.chromium.org/p/chromium/issues/detail?id=398407\n * @param {string} protocol\n */\nfunction isValidSubprotocol (protocol) {\n // If present, this value indicates one\n // or more comma-separated subprotocol the client wishes to speak,\n // ordered by preference. The elements that comprise this value\n // MUST be non-empty strings with characters in the range U+0021 to\n // U+007E not including separator characters as defined in\n // [RFC2616] and MUST all be unique strings.\n if (protocol.length === 0) {\n return false\n }\n\n for (const char of protocol) {\n const code = char.charCodeAt(0)\n\n if (\n code < 0x21 ||\n code > 0x7E ||\n char === '(' ||\n char === ')' ||\n char === '<' ||\n char === '>' ||\n char === '@' ||\n char === ',' ||\n char === ';' ||\n char === ':' ||\n char === '\\\\' ||\n char === '\"' ||\n char === '/' ||\n char === '[' ||\n char === ']' ||\n char === '?' ||\n char === '=' ||\n char === '{' ||\n char === '}' ||\n code === 32 || // SP\n code === 9 // HT\n ) {\n return false\n }\n }\n\n return true\n}\n\n/**\n * @see https://datatracker.ietf.org/doc/html/rfc6455#section-7-4\n * @param {number} code\n */\nfunction isValidStatusCode (code) {\n if (code >= 1000 && code < 1015) {\n return (\n code !== 1004 && // reserved\n code !== 1005 && // \"MUST NOT be set as a status code\"\n code !== 1006 // \"MUST NOT be set as a status code\"\n )\n }\n\n return code >= 3000 && code <= 4999\n}\n\n/**\n * @param {import('./websocket').WebSocket} ws\n * @param {string|undefined} reason\n */\nfunction failWebsocketConnection (ws, reason) {\n const { [kController]: controller, [kResponse]: response } = ws\n\n controller.abort()\n\n if (response?.socket && !response.socket.destroyed) {\n response.socket.destroy()\n }\n\n if (reason) {\n fireEvent('error', ws, ErrorEvent, {\n error: new Error(reason)\n })\n }\n}\n\nmodule.exports = {\n isEstablished,\n isClosing,\n isClosed,\n fireEvent,\n isValidSubprotocol,\n isValidStatusCode,\n failWebsocketConnection,\n websocketMessageReceived\n}\n","'use strict'\n\nconst { webidl } = require('../fetch/webidl')\nconst { DOMException } = require('../fetch/constants')\nconst { URLSerializer } = require('../fetch/dataURL')\nconst { getGlobalOrigin } = require('../fetch/global')\nconst { staticPropertyDescriptors, states, opcodes, emptyBuffer } = require('./constants')\nconst {\n kWebSocketURL,\n kReadyState,\n kController,\n kBinaryType,\n kResponse,\n kSentClose,\n kByteParser\n} = require('./symbols')\nconst { isEstablished, isClosing, isValidSubprotocol, failWebsocketConnection, fireEvent } = require('./util')\nconst { establishWebSocketConnection } = require('./connection')\nconst { WebsocketFrameSend } = require('./frame')\nconst { ByteParser } = require('./receiver')\nconst { kEnumerableProperty, isBlobLike } = require('../core/util')\nconst { getGlobalDispatcher } = require('../global')\nconst { types } = require('util')\n\nlet experimentalWarned = false\n\n// https://websockets.spec.whatwg.org/#interface-definition\nclass WebSocket extends EventTarget {\n #events = {\n open: null,\n error: null,\n close: null,\n message: null\n }\n\n #bufferedAmount = 0\n #protocol = ''\n #extensions = ''\n\n /**\n * @param {string} url\n * @param {string|string[]} protocols\n */\n constructor (url, protocols = []) {\n super()\n\n webidl.argumentLengthCheck(arguments, 1, { header: 'WebSocket constructor' })\n\n if (!experimentalWarned) {\n experimentalWarned = true\n process.emitWarning('WebSockets are experimental, expect them to change at any time.', {\n code: 'UNDICI-WS'\n })\n }\n\n const options = webidl.converters['DOMString or sequence or WebSocketInit'](protocols)\n\n url = webidl.converters.USVString(url)\n protocols = options.protocols\n\n // 1. Let baseURL be this's relevant settings object's API base URL.\n const baseURL = getGlobalOrigin()\n\n // 1. Let urlRecord be the result of applying the URL parser to url with baseURL.\n let urlRecord\n\n try {\n urlRecord = new URL(url, baseURL)\n } catch (e) {\n // 3. If urlRecord is failure, then throw a \"SyntaxError\" DOMException.\n throw new DOMException(e, 'SyntaxError')\n }\n\n // 4. If urlRecord’s scheme is \"http\", then set urlRecord’s scheme to \"ws\".\n if (urlRecord.protocol === 'http:') {\n urlRecord.protocol = 'ws:'\n } else if (urlRecord.protocol === 'https:') {\n // 5. Otherwise, if urlRecord’s scheme is \"https\", set urlRecord’s scheme to \"wss\".\n urlRecord.protocol = 'wss:'\n }\n\n // 6. If urlRecord’s scheme is not \"ws\" or \"wss\", then throw a \"SyntaxError\" DOMException.\n if (urlRecord.protocol !== 'ws:' && urlRecord.protocol !== 'wss:') {\n throw new DOMException(\n `Expected a ws: or wss: protocol, got ${urlRecord.protocol}`,\n 'SyntaxError'\n )\n }\n\n // 7. If urlRecord’s fragment is non-null, then throw a \"SyntaxError\"\n // DOMException.\n if (urlRecord.hash || urlRecord.href.endsWith('#')) {\n throw new DOMException('Got fragment', 'SyntaxError')\n }\n\n // 8. If protocols is a string, set protocols to a sequence consisting\n // of just that string.\n if (typeof protocols === 'string') {\n protocols = [protocols]\n }\n\n // 9. If any of the values in protocols occur more than once or otherwise\n // fail to match the requirements for elements that comprise the value\n // of `Sec-WebSocket-Protocol` fields as defined by The WebSocket\n // protocol, then throw a \"SyntaxError\" DOMException.\n if (protocols.length !== new Set(protocols.map(p => p.toLowerCase())).size) {\n throw new DOMException('Invalid Sec-WebSocket-Protocol value', 'SyntaxError')\n }\n\n if (protocols.length > 0 && !protocols.every(p => isValidSubprotocol(p))) {\n throw new DOMException('Invalid Sec-WebSocket-Protocol value', 'SyntaxError')\n }\n\n // 10. Set this's url to urlRecord.\n this[kWebSocketURL] = new URL(urlRecord.href)\n\n // 11. Let client be this's relevant settings object.\n\n // 12. Run this step in parallel:\n\n // 1. Establish a WebSocket connection given urlRecord, protocols,\n // and client.\n this[kController] = establishWebSocketConnection(\n urlRecord,\n protocols,\n this,\n (response) => this.#onConnectionEstablished(response),\n options\n )\n\n // Each WebSocket object has an associated ready state, which is a\n // number representing the state of the connection. Initially it must\n // be CONNECTING (0).\n this[kReadyState] = WebSocket.CONNECTING\n\n // The extensions attribute must initially return the empty string.\n\n // The protocol attribute must initially return the empty string.\n\n // Each WebSocket object has an associated binary type, which is a\n // BinaryType. Initially it must be \"blob\".\n this[kBinaryType] = 'blob'\n }\n\n /**\n * @see https://websockets.spec.whatwg.org/#dom-websocket-close\n * @param {number|undefined} code\n * @param {string|undefined} reason\n */\n close (code = undefined, reason = undefined) {\n webidl.brandCheck(this, WebSocket)\n\n if (code !== undefined) {\n code = webidl.converters['unsigned short'](code, { clamp: true })\n }\n\n if (reason !== undefined) {\n reason = webidl.converters.USVString(reason)\n }\n\n // 1. If code is present, but is neither an integer equal to 1000 nor an\n // integer in the range 3000 to 4999, inclusive, throw an\n // \"InvalidAccessError\" DOMException.\n if (code !== undefined) {\n if (code !== 1000 && (code < 3000 || code > 4999)) {\n throw new DOMException('invalid code', 'InvalidAccessError')\n }\n }\n\n let reasonByteLength = 0\n\n // 2. If reason is present, then run these substeps:\n if (reason !== undefined) {\n // 1. Let reasonBytes be the result of encoding reason.\n // 2. If reasonBytes is longer than 123 bytes, then throw a\n // \"SyntaxError\" DOMException.\n reasonByteLength = Buffer.byteLength(reason)\n\n if (reasonByteLength > 123) {\n throw new DOMException(\n `Reason must be less than 123 bytes; received ${reasonByteLength}`,\n 'SyntaxError'\n )\n }\n }\n\n // 3. Run the first matching steps from the following list:\n if (this[kReadyState] === WebSocket.CLOSING || this[kReadyState] === WebSocket.CLOSED) {\n // If this's ready state is CLOSING (2) or CLOSED (3)\n // Do nothing.\n } else if (!isEstablished(this)) {\n // If the WebSocket connection is not yet established\n // Fail the WebSocket connection and set this's ready state\n // to CLOSING (2).\n failWebsocketConnection(this, 'Connection was closed before it was established.')\n this[kReadyState] = WebSocket.CLOSING\n } else if (!isClosing(this)) {\n // If the WebSocket closing handshake has not yet been started\n // Start the WebSocket closing handshake and set this's ready\n // state to CLOSING (2).\n // - If neither code nor reason is present, the WebSocket Close\n // message must not have a body.\n // - If code is present, then the status code to use in the\n // WebSocket Close message must be the integer given by code.\n // - If reason is also present, then reasonBytes must be\n // provided in the Close message after the status code.\n\n const frame = new WebsocketFrameSend()\n\n // If neither code nor reason is present, the WebSocket Close\n // message must not have a body.\n\n // If code is present, then the status code to use in the\n // WebSocket Close message must be the integer given by code.\n if (code !== undefined && reason === undefined) {\n frame.frameData = Buffer.allocUnsafe(2)\n frame.frameData.writeUInt16BE(code, 0)\n } else if (code !== undefined && reason !== undefined) {\n // If reason is also present, then reasonBytes must be\n // provided in the Close message after the status code.\n frame.frameData = Buffer.allocUnsafe(2 + reasonByteLength)\n frame.frameData.writeUInt16BE(code, 0)\n // the body MAY contain UTF-8-encoded data with value /reason/\n frame.frameData.write(reason, 2, 'utf-8')\n } else {\n frame.frameData = emptyBuffer\n }\n\n /** @type {import('stream').Duplex} */\n const socket = this[kResponse].socket\n\n socket.write(frame.createFrame(opcodes.CLOSE), (err) => {\n if (!err) {\n this[kSentClose] = true\n }\n })\n\n // Upon either sending or receiving a Close control frame, it is said\n // that _The WebSocket Closing Handshake is Started_ and that the\n // WebSocket connection is in the CLOSING state.\n this[kReadyState] = states.CLOSING\n } else {\n // Otherwise\n // Set this's ready state to CLOSING (2).\n this[kReadyState] = WebSocket.CLOSING\n }\n }\n\n /**\n * @see https://websockets.spec.whatwg.org/#dom-websocket-send\n * @param {NodeJS.TypedArray|ArrayBuffer|Blob|string} data\n */\n send (data) {\n webidl.brandCheck(this, WebSocket)\n\n webidl.argumentLengthCheck(arguments, 1, { header: 'WebSocket.send' })\n\n data = webidl.converters.WebSocketSendData(data)\n\n // 1. If this's ready state is CONNECTING, then throw an\n // \"InvalidStateError\" DOMException.\n if (this[kReadyState] === WebSocket.CONNECTING) {\n throw new DOMException('Sent before connected.', 'InvalidStateError')\n }\n\n // 2. Run the appropriate set of steps from the following list:\n // https://datatracker.ietf.org/doc/html/rfc6455#section-6.1\n // https://datatracker.ietf.org/doc/html/rfc6455#section-5.2\n\n if (!isEstablished(this) || isClosing(this)) {\n return\n }\n\n /** @type {import('stream').Duplex} */\n const socket = this[kResponse].socket\n\n // If data is a string\n if (typeof data === 'string') {\n // If the WebSocket connection is established and the WebSocket\n // closing handshake has not yet started, then the user agent\n // must send a WebSocket Message comprised of the data argument\n // using a text frame opcode; if the data cannot be sent, e.g.\n // because it would need to be buffered but the buffer is full,\n // the user agent must flag the WebSocket as full and then close\n // the WebSocket connection. Any invocation of this method with a\n // string argument that does not throw an exception must increase\n // the bufferedAmount attribute by the number of bytes needed to\n // express the argument as UTF-8.\n\n const value = Buffer.from(data)\n const frame = new WebsocketFrameSend(value)\n const buffer = frame.createFrame(opcodes.TEXT)\n\n this.#bufferedAmount += value.byteLength\n socket.write(buffer, () => {\n this.#bufferedAmount -= value.byteLength\n })\n } else if (types.isArrayBuffer(data)) {\n // If the WebSocket connection is established, and the WebSocket\n // closing handshake has not yet started, then the user agent must\n // send a WebSocket Message comprised of data using a binary frame\n // opcode; if the data cannot be sent, e.g. because it would need\n // to be buffered but the buffer is full, the user agent must flag\n // the WebSocket as full and then close the WebSocket connection.\n // The data to be sent is the data stored in the buffer described\n // by the ArrayBuffer object. Any invocation of this method with an\n // ArrayBuffer argument that does not throw an exception must\n // increase the bufferedAmount attribute by the length of the\n // ArrayBuffer in bytes.\n\n const value = Buffer.from(data)\n const frame = new WebsocketFrameSend(value)\n const buffer = frame.createFrame(opcodes.BINARY)\n\n this.#bufferedAmount += value.byteLength\n socket.write(buffer, () => {\n this.#bufferedAmount -= value.byteLength\n })\n } else if (ArrayBuffer.isView(data)) {\n // If the WebSocket connection is established, and the WebSocket\n // closing handshake has not yet started, then the user agent must\n // send a WebSocket Message comprised of data using a binary frame\n // opcode; if the data cannot be sent, e.g. because it would need to\n // be buffered but the buffer is full, the user agent must flag the\n // WebSocket as full and then close the WebSocket connection. The\n // data to be sent is the data stored in the section of the buffer\n // described by the ArrayBuffer object that data references. Any\n // invocation of this method with this kind of argument that does\n // not throw an exception must increase the bufferedAmount attribute\n // by the length of data’s buffer in bytes.\n\n const ab = Buffer.from(data, data.byteOffset, data.byteLength)\n\n const frame = new WebsocketFrameSend(ab)\n const buffer = frame.createFrame(opcodes.BINARY)\n\n this.#bufferedAmount += ab.byteLength\n socket.write(buffer, () => {\n this.#bufferedAmount -= ab.byteLength\n })\n } else if (isBlobLike(data)) {\n // If the WebSocket connection is established, and the WebSocket\n // closing handshake has not yet started, then the user agent must\n // send a WebSocket Message comprised of data using a binary frame\n // opcode; if the data cannot be sent, e.g. because it would need to\n // be buffered but the buffer is full, the user agent must flag the\n // WebSocket as full and then close the WebSocket connection. The data\n // to be sent is the raw data represented by the Blob object. Any\n // invocation of this method with a Blob argument that does not throw\n // an exception must increase the bufferedAmount attribute by the size\n // of the Blob object’s raw data, in bytes.\n\n const frame = new WebsocketFrameSend()\n\n data.arrayBuffer().then((ab) => {\n const value = Buffer.from(ab)\n frame.frameData = value\n const buffer = frame.createFrame(opcodes.BINARY)\n\n this.#bufferedAmount += value.byteLength\n socket.write(buffer, () => {\n this.#bufferedAmount -= value.byteLength\n })\n })\n }\n }\n\n get readyState () {\n webidl.brandCheck(this, WebSocket)\n\n // The readyState getter steps are to return this's ready state.\n return this[kReadyState]\n }\n\n get bufferedAmount () {\n webidl.brandCheck(this, WebSocket)\n\n return this.#bufferedAmount\n }\n\n get url () {\n webidl.brandCheck(this, WebSocket)\n\n // The url getter steps are to return this's url, serialized.\n return URLSerializer(this[kWebSocketURL])\n }\n\n get extensions () {\n webidl.brandCheck(this, WebSocket)\n\n return this.#extensions\n }\n\n get protocol () {\n webidl.brandCheck(this, WebSocket)\n\n return this.#protocol\n }\n\n get onopen () {\n webidl.brandCheck(this, WebSocket)\n\n return this.#events.open\n }\n\n set onopen (fn) {\n webidl.brandCheck(this, WebSocket)\n\n if (this.#events.open) {\n this.removeEventListener('open', this.#events.open)\n }\n\n if (typeof fn === 'function') {\n this.#events.open = fn\n this.addEventListener('open', fn)\n } else {\n this.#events.open = null\n }\n }\n\n get onerror () {\n webidl.brandCheck(this, WebSocket)\n\n return this.#events.error\n }\n\n set onerror (fn) {\n webidl.brandCheck(this, WebSocket)\n\n if (this.#events.error) {\n this.removeEventListener('error', this.#events.error)\n }\n\n if (typeof fn === 'function') {\n this.#events.error = fn\n this.addEventListener('error', fn)\n } else {\n this.#events.error = null\n }\n }\n\n get onclose () {\n webidl.brandCheck(this, WebSocket)\n\n return this.#events.close\n }\n\n set onclose (fn) {\n webidl.brandCheck(this, WebSocket)\n\n if (this.#events.close) {\n this.removeEventListener('close', this.#events.close)\n }\n\n if (typeof fn === 'function') {\n this.#events.close = fn\n this.addEventListener('close', fn)\n } else {\n this.#events.close = null\n }\n }\n\n get onmessage () {\n webidl.brandCheck(this, WebSocket)\n\n return this.#events.message\n }\n\n set onmessage (fn) {\n webidl.brandCheck(this, WebSocket)\n\n if (this.#events.message) {\n this.removeEventListener('message', this.#events.message)\n }\n\n if (typeof fn === 'function') {\n this.#events.message = fn\n this.addEventListener('message', fn)\n } else {\n this.#events.message = null\n }\n }\n\n get binaryType () {\n webidl.brandCheck(this, WebSocket)\n\n return this[kBinaryType]\n }\n\n set binaryType (type) {\n webidl.brandCheck(this, WebSocket)\n\n if (type !== 'blob' && type !== 'arraybuffer') {\n this[kBinaryType] = 'blob'\n } else {\n this[kBinaryType] = type\n }\n }\n\n /**\n * @see https://websockets.spec.whatwg.org/#feedback-from-the-protocol\n */\n #onConnectionEstablished (response) {\n // processResponse is called when the \"response’s header list has been received and initialized.\"\n // once this happens, the connection is open\n this[kResponse] = response\n\n const parser = new ByteParser(this)\n parser.on('drain', function onParserDrain () {\n this.ws[kResponse].socket.resume()\n })\n\n response.socket.ws = this\n this[kByteParser] = parser\n\n // 1. Change the ready state to OPEN (1).\n this[kReadyState] = states.OPEN\n\n // 2. Change the extensions attribute’s value to the extensions in use, if\n // it is not the null value.\n // https://datatracker.ietf.org/doc/html/rfc6455#section-9.1\n const extensions = response.headersList.get('sec-websocket-extensions')\n\n if (extensions !== null) {\n this.#extensions = extensions\n }\n\n // 3. Change the protocol attribute’s value to the subprotocol in use, if\n // it is not the null value.\n // https://datatracker.ietf.org/doc/html/rfc6455#section-1.9\n const protocol = response.headersList.get('sec-websocket-protocol')\n\n if (protocol !== null) {\n this.#protocol = protocol\n }\n\n // 4. Fire an event named open at the WebSocket object.\n fireEvent('open', this)\n }\n}\n\n// https://websockets.spec.whatwg.org/#dom-websocket-connecting\nWebSocket.CONNECTING = WebSocket.prototype.CONNECTING = states.CONNECTING\n// https://websockets.spec.whatwg.org/#dom-websocket-open\nWebSocket.OPEN = WebSocket.prototype.OPEN = states.OPEN\n// https://websockets.spec.whatwg.org/#dom-websocket-closing\nWebSocket.CLOSING = WebSocket.prototype.CLOSING = states.CLOSING\n// https://websockets.spec.whatwg.org/#dom-websocket-closed\nWebSocket.CLOSED = WebSocket.prototype.CLOSED = states.CLOSED\n\nObject.defineProperties(WebSocket.prototype, {\n CONNECTING: staticPropertyDescriptors,\n OPEN: staticPropertyDescriptors,\n CLOSING: staticPropertyDescriptors,\n CLOSED: staticPropertyDescriptors,\n url: kEnumerableProperty,\n readyState: kEnumerableProperty,\n bufferedAmount: kEnumerableProperty,\n onopen: kEnumerableProperty,\n onerror: kEnumerableProperty,\n onclose: kEnumerableProperty,\n close: kEnumerableProperty,\n onmessage: kEnumerableProperty,\n binaryType: kEnumerableProperty,\n send: kEnumerableProperty,\n extensions: kEnumerableProperty,\n protocol: kEnumerableProperty,\n [Symbol.toStringTag]: {\n value: 'WebSocket',\n writable: false,\n enumerable: false,\n configurable: true\n }\n})\n\nObject.defineProperties(WebSocket, {\n CONNECTING: staticPropertyDescriptors,\n OPEN: staticPropertyDescriptors,\n CLOSING: staticPropertyDescriptors,\n CLOSED: staticPropertyDescriptors\n})\n\nwebidl.converters['sequence'] = webidl.sequenceConverter(\n webidl.converters.DOMString\n)\n\nwebidl.converters['DOMString or sequence'] = function (V) {\n if (webidl.util.Type(V) === 'Object' && Symbol.iterator in V) {\n return webidl.converters['sequence'](V)\n }\n\n return webidl.converters.DOMString(V)\n}\n\n// This implements the propsal made in https://github.com/whatwg/websockets/issues/42\nwebidl.converters.WebSocketInit = webidl.dictionaryConverter([\n {\n key: 'protocols',\n converter: webidl.converters['DOMString or sequence'],\n get defaultValue () {\n return []\n }\n },\n {\n key: 'dispatcher',\n converter: (V) => V,\n get defaultValue () {\n return getGlobalDispatcher()\n }\n },\n {\n key: 'headers',\n converter: webidl.nullableConverter(webidl.converters.HeadersInit)\n }\n])\n\nwebidl.converters['DOMString or sequence or WebSocketInit'] = function (V) {\n if (webidl.util.Type(V) === 'Object' && !(Symbol.iterator in V)) {\n return webidl.converters.WebSocketInit(V)\n }\n\n return { protocols: webidl.converters['DOMString or sequence'](V) }\n}\n\nwebidl.converters.WebSocketSendData = function (V) {\n if (webidl.util.Type(V) === 'Object') {\n if (isBlobLike(V)) {\n return webidl.converters.Blob(V, { strict: false })\n }\n\n if (ArrayBuffer.isView(V) || types.isAnyArrayBuffer(V)) {\n return webidl.converters.BufferSource(V)\n }\n }\n\n return webidl.converters.USVString(V)\n}\n\nmodule.exports = {\n WebSocket\n}\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nfunction getUserAgent() {\n if (typeof navigator === \"object\" && \"userAgent\" in navigator) {\n return navigator.userAgent;\n }\n\n if (typeof process === \"object\" && process.version !== undefined) {\n return `Node.js/${process.version.substr(1)} (${process.platform}; ${process.arch})`;\n }\n\n return \"\";\n}\n\nexports.getUserAgent = getUserAgent;\n//# sourceMappingURL=index.js.map\n","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nObject.defineProperty(exports, \"v1\", {\n enumerable: true,\n get: function () {\n return _v.default;\n }\n});\nObject.defineProperty(exports, \"v3\", {\n enumerable: true,\n get: function () {\n return _v2.default;\n }\n});\nObject.defineProperty(exports, \"v4\", {\n enumerable: true,\n get: function () {\n return _v3.default;\n }\n});\nObject.defineProperty(exports, \"v5\", {\n enumerable: true,\n get: function () {\n return _v4.default;\n }\n});\nObject.defineProperty(exports, \"NIL\", {\n enumerable: true,\n get: function () {\n return _nil.default;\n }\n});\nObject.defineProperty(exports, \"version\", {\n enumerable: true,\n get: function () {\n return _version.default;\n }\n});\nObject.defineProperty(exports, \"validate\", {\n enumerable: true,\n get: function () {\n return _validate.default;\n }\n});\nObject.defineProperty(exports, \"stringify\", {\n enumerable: true,\n get: function () {\n return _stringify.default;\n }\n});\nObject.defineProperty(exports, \"parse\", {\n enumerable: true,\n get: function () {\n return _parse.default;\n }\n});\n\nvar _v = _interopRequireDefault(require(\"./v1.js\"));\n\nvar _v2 = _interopRequireDefault(require(\"./v3.js\"));\n\nvar _v3 = _interopRequireDefault(require(\"./v4.js\"));\n\nvar _v4 = _interopRequireDefault(require(\"./v5.js\"));\n\nvar _nil = _interopRequireDefault(require(\"./nil.js\"));\n\nvar _version = _interopRequireDefault(require(\"./version.js\"));\n\nvar _validate = _interopRequireDefault(require(\"./validate.js\"));\n\nvar _stringify = _interopRequireDefault(require(\"./stringify.js\"));\n\nvar _parse = _interopRequireDefault(require(\"./parse.js\"));\n\nfunction _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.default = void 0;\n\nvar _crypto = _interopRequireDefault(require(\"crypto\"));\n\nfunction _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }\n\nfunction md5(bytes) {\n if (Array.isArray(bytes)) {\n bytes = Buffer.from(bytes);\n } else if (typeof bytes === 'string') {\n bytes = Buffer.from(bytes, 'utf8');\n }\n\n return _crypto.default.createHash('md5').update(bytes).digest();\n}\n\nvar _default = md5;\nexports.default = _default;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.default = void 0;\nvar _default = '00000000-0000-0000-0000-000000000000';\nexports.default = _default;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.default = void 0;\n\nvar _validate = _interopRequireDefault(require(\"./validate.js\"));\n\nfunction _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }\n\nfunction parse(uuid) {\n if (!(0, _validate.default)(uuid)) {\n throw TypeError('Invalid UUID');\n }\n\n let v;\n const arr = new Uint8Array(16); // Parse ########-....-....-....-............\n\n arr[0] = (v = parseInt(uuid.slice(0, 8), 16)) >>> 24;\n arr[1] = v >>> 16 & 0xff;\n arr[2] = v >>> 8 & 0xff;\n arr[3] = v & 0xff; // Parse ........-####-....-....-............\n\n arr[4] = (v = parseInt(uuid.slice(9, 13), 16)) >>> 8;\n arr[5] = v & 0xff; // Parse ........-....-####-....-............\n\n arr[6] = (v = parseInt(uuid.slice(14, 18), 16)) >>> 8;\n arr[7] = v & 0xff; // Parse ........-....-....-####-............\n\n arr[8] = (v = parseInt(uuid.slice(19, 23), 16)) >>> 8;\n arr[9] = v & 0xff; // Parse ........-....-....-....-############\n // (Use \"/\" to avoid 32-bit truncation when bit-shifting high-order bytes)\n\n arr[10] = (v = parseInt(uuid.slice(24, 36), 16)) / 0x10000000000 & 0xff;\n arr[11] = v / 0x100000000 & 0xff;\n arr[12] = v >>> 24 & 0xff;\n arr[13] = v >>> 16 & 0xff;\n arr[14] = v >>> 8 & 0xff;\n arr[15] = v & 0xff;\n return arr;\n}\n\nvar _default = parse;\nexports.default = _default;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.default = void 0;\nvar _default = /^(?:[0-9a-f]{8}-[0-9a-f]{4}-[1-5][0-9a-f]{3}-[89ab][0-9a-f]{3}-[0-9a-f]{12}|00000000-0000-0000-0000-000000000000)$/i;\nexports.default = _default;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.default = rng;\n\nvar _crypto = _interopRequireDefault(require(\"crypto\"));\n\nfunction _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }\n\nconst rnds8Pool = new Uint8Array(256); // # of random values to pre-allocate\n\nlet poolPtr = rnds8Pool.length;\n\nfunction rng() {\n if (poolPtr > rnds8Pool.length - 16) {\n _crypto.default.randomFillSync(rnds8Pool);\n\n poolPtr = 0;\n }\n\n return rnds8Pool.slice(poolPtr, poolPtr += 16);\n}","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.default = void 0;\n\nvar _crypto = _interopRequireDefault(require(\"crypto\"));\n\nfunction _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }\n\nfunction sha1(bytes) {\n if (Array.isArray(bytes)) {\n bytes = Buffer.from(bytes);\n } else if (typeof bytes === 'string') {\n bytes = Buffer.from(bytes, 'utf8');\n }\n\n return _crypto.default.createHash('sha1').update(bytes).digest();\n}\n\nvar _default = sha1;\nexports.default = _default;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.default = void 0;\n\nvar _validate = _interopRequireDefault(require(\"./validate.js\"));\n\nfunction _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }\n\n/**\n * Convert array of 16 byte values to UUID string format of the form:\n * XXXXXXXX-XXXX-XXXX-XXXX-XXXXXXXXXXXX\n */\nconst byteToHex = [];\n\nfor (let i = 0; i < 256; ++i) {\n byteToHex.push((i + 0x100).toString(16).substr(1));\n}\n\nfunction stringify(arr, offset = 0) {\n // Note: Be careful editing this code! It's been tuned for performance\n // and works in ways you may not expect. See https://github.com/uuidjs/uuid/pull/434\n const uuid = (byteToHex[arr[offset + 0]] + byteToHex[arr[offset + 1]] + byteToHex[arr[offset + 2]] + byteToHex[arr[offset + 3]] + '-' + byteToHex[arr[offset + 4]] + byteToHex[arr[offset + 5]] + '-' + byteToHex[arr[offset + 6]] + byteToHex[arr[offset + 7]] + '-' + byteToHex[arr[offset + 8]] + byteToHex[arr[offset + 9]] + '-' + byteToHex[arr[offset + 10]] + byteToHex[arr[offset + 11]] + byteToHex[arr[offset + 12]] + byteToHex[arr[offset + 13]] + byteToHex[arr[offset + 14]] + byteToHex[arr[offset + 15]]).toLowerCase(); // Consistency check for valid UUID. If this throws, it's likely due to one\n // of the following:\n // - One or more input array values don't map to a hex octet (leading to\n // \"undefined\" in the uuid)\n // - Invalid input values for the RFC `version` or `variant` fields\n\n if (!(0, _validate.default)(uuid)) {\n throw TypeError('Stringified UUID is invalid');\n }\n\n return uuid;\n}\n\nvar _default = stringify;\nexports.default = _default;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.default = void 0;\n\nvar _rng = _interopRequireDefault(require(\"./rng.js\"));\n\nvar _stringify = _interopRequireDefault(require(\"./stringify.js\"));\n\nfunction _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }\n\n// **`v1()` - Generate time-based UUID**\n//\n// Inspired by https://github.com/LiosK/UUID.js\n// and http://docs.python.org/library/uuid.html\nlet _nodeId;\n\nlet _clockseq; // Previous uuid creation time\n\n\nlet _lastMSecs = 0;\nlet _lastNSecs = 0; // See https://github.com/uuidjs/uuid for API details\n\nfunction v1(options, buf, offset) {\n let i = buf && offset || 0;\n const b = buf || new Array(16);\n options = options || {};\n let node = options.node || _nodeId;\n let clockseq = options.clockseq !== undefined ? options.clockseq : _clockseq; // node and clockseq need to be initialized to random values if they're not\n // specified. We do this lazily to minimize issues related to insufficient\n // system entropy. See #189\n\n if (node == null || clockseq == null) {\n const seedBytes = options.random || (options.rng || _rng.default)();\n\n if (node == null) {\n // Per 4.5, create and 48-bit node id, (47 random bits + multicast bit = 1)\n node = _nodeId = [seedBytes[0] | 0x01, seedBytes[1], seedBytes[2], seedBytes[3], seedBytes[4], seedBytes[5]];\n }\n\n if (clockseq == null) {\n // Per 4.2.2, randomize (14 bit) clockseq\n clockseq = _clockseq = (seedBytes[6] << 8 | seedBytes[7]) & 0x3fff;\n }\n } // UUID timestamps are 100 nano-second units since the Gregorian epoch,\n // (1582-10-15 00:00). JSNumbers aren't precise enough for this, so\n // time is handled internally as 'msecs' (integer milliseconds) and 'nsecs'\n // (100-nanoseconds offset from msecs) since unix epoch, 1970-01-01 00:00.\n\n\n let msecs = options.msecs !== undefined ? options.msecs : Date.now(); // Per 4.2.1.2, use count of uuid's generated during the current clock\n // cycle to simulate higher resolution clock\n\n let nsecs = options.nsecs !== undefined ? options.nsecs : _lastNSecs + 1; // Time since last uuid creation (in msecs)\n\n const dt = msecs - _lastMSecs + (nsecs - _lastNSecs) / 10000; // Per 4.2.1.2, Bump clockseq on clock regression\n\n if (dt < 0 && options.clockseq === undefined) {\n clockseq = clockseq + 1 & 0x3fff;\n } // Reset nsecs if clock regresses (new clockseq) or we've moved onto a new\n // time interval\n\n\n if ((dt < 0 || msecs > _lastMSecs) && options.nsecs === undefined) {\n nsecs = 0;\n } // Per 4.2.1.2 Throw error if too many uuids are requested\n\n\n if (nsecs >= 10000) {\n throw new Error(\"uuid.v1(): Can't create more than 10M uuids/sec\");\n }\n\n _lastMSecs = msecs;\n _lastNSecs = nsecs;\n _clockseq = clockseq; // Per 4.1.4 - Convert from unix epoch to Gregorian epoch\n\n msecs += 12219292800000; // `time_low`\n\n const tl = ((msecs & 0xfffffff) * 10000 + nsecs) % 0x100000000;\n b[i++] = tl >>> 24 & 0xff;\n b[i++] = tl >>> 16 & 0xff;\n b[i++] = tl >>> 8 & 0xff;\n b[i++] = tl & 0xff; // `time_mid`\n\n const tmh = msecs / 0x100000000 * 10000 & 0xfffffff;\n b[i++] = tmh >>> 8 & 0xff;\n b[i++] = tmh & 0xff; // `time_high_and_version`\n\n b[i++] = tmh >>> 24 & 0xf | 0x10; // include version\n\n b[i++] = tmh >>> 16 & 0xff; // `clock_seq_hi_and_reserved` (Per 4.2.2 - include variant)\n\n b[i++] = clockseq >>> 8 | 0x80; // `clock_seq_low`\n\n b[i++] = clockseq & 0xff; // `node`\n\n for (let n = 0; n < 6; ++n) {\n b[i + n] = node[n];\n }\n\n return buf || (0, _stringify.default)(b);\n}\n\nvar _default = v1;\nexports.default = _default;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.default = void 0;\n\nvar _v = _interopRequireDefault(require(\"./v35.js\"));\n\nvar _md = _interopRequireDefault(require(\"./md5.js\"));\n\nfunction _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }\n\nconst v3 = (0, _v.default)('v3', 0x30, _md.default);\nvar _default = v3;\nexports.default = _default;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.default = _default;\nexports.URL = exports.DNS = void 0;\n\nvar _stringify = _interopRequireDefault(require(\"./stringify.js\"));\n\nvar _parse = _interopRequireDefault(require(\"./parse.js\"));\n\nfunction _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }\n\nfunction stringToBytes(str) {\n str = unescape(encodeURIComponent(str)); // UTF8 escape\n\n const bytes = [];\n\n for (let i = 0; i < str.length; ++i) {\n bytes.push(str.charCodeAt(i));\n }\n\n return bytes;\n}\n\nconst DNS = '6ba7b810-9dad-11d1-80b4-00c04fd430c8';\nexports.DNS = DNS;\nconst URL = '6ba7b811-9dad-11d1-80b4-00c04fd430c8';\nexports.URL = URL;\n\nfunction _default(name, version, hashfunc) {\n function generateUUID(value, namespace, buf, offset) {\n if (typeof value === 'string') {\n value = stringToBytes(value);\n }\n\n if (typeof namespace === 'string') {\n namespace = (0, _parse.default)(namespace);\n }\n\n if (namespace.length !== 16) {\n throw TypeError('Namespace must be array-like (16 iterable integer values, 0-255)');\n } // Compute hash of namespace and value, Per 4.3\n // Future: Use spread syntax when supported on all platforms, e.g. `bytes =\n // hashfunc([...namespace, ... value])`\n\n\n let bytes = new Uint8Array(16 + value.length);\n bytes.set(namespace);\n bytes.set(value, namespace.length);\n bytes = hashfunc(bytes);\n bytes[6] = bytes[6] & 0x0f | version;\n bytes[8] = bytes[8] & 0x3f | 0x80;\n\n if (buf) {\n offset = offset || 0;\n\n for (let i = 0; i < 16; ++i) {\n buf[offset + i] = bytes[i];\n }\n\n return buf;\n }\n\n return (0, _stringify.default)(bytes);\n } // Function#name is not settable on some platforms (#270)\n\n\n try {\n generateUUID.name = name; // eslint-disable-next-line no-empty\n } catch (err) {} // For CommonJS default export support\n\n\n generateUUID.DNS = DNS;\n generateUUID.URL = URL;\n return generateUUID;\n}","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.default = void 0;\n\nvar _rng = _interopRequireDefault(require(\"./rng.js\"));\n\nvar _stringify = _interopRequireDefault(require(\"./stringify.js\"));\n\nfunction _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }\n\nfunction v4(options, buf, offset) {\n options = options || {};\n\n const rnds = options.random || (options.rng || _rng.default)(); // Per 4.4, set bits for version and `clock_seq_hi_and_reserved`\n\n\n rnds[6] = rnds[6] & 0x0f | 0x40;\n rnds[8] = rnds[8] & 0x3f | 0x80; // Copy bytes to buffer, if provided\n\n if (buf) {\n offset = offset || 0;\n\n for (let i = 0; i < 16; ++i) {\n buf[offset + i] = rnds[i];\n }\n\n return buf;\n }\n\n return (0, _stringify.default)(rnds);\n}\n\nvar _default = v4;\nexports.default = _default;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.default = void 0;\n\nvar _v = _interopRequireDefault(require(\"./v35.js\"));\n\nvar _sha = _interopRequireDefault(require(\"./sha1.js\"));\n\nfunction _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }\n\nconst v5 = (0, _v.default)('v5', 0x50, _sha.default);\nvar _default = v5;\nexports.default = _default;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.default = void 0;\n\nvar _regex = _interopRequireDefault(require(\"./regex.js\"));\n\nfunction _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }\n\nfunction validate(uuid) {\n return typeof uuid === 'string' && _regex.default.test(uuid);\n}\n\nvar _default = validate;\nexports.default = _default;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.default = void 0;\n\nvar _validate = _interopRequireDefault(require(\"./validate.js\"));\n\nfunction _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }\n\nfunction version(uuid) {\n if (!(0, _validate.default)(uuid)) {\n throw TypeError('Invalid UUID');\n }\n\n return parseInt(uuid.substr(14, 1), 16);\n}\n\nvar _default = version;\nexports.default = _default;","// Returns a wrapper function that returns a wrapped callback\n// The wrapper function should do some stuff, and return a\n// presumably different callback function.\n// This makes sure that own properties are retained, so that\n// decorations and such are not lost along the way.\nmodule.exports = wrappy\nfunction wrappy (fn, cb) {\n if (fn && cb) return wrappy(fn)(cb)\n\n if (typeof fn !== 'function')\n throw new TypeError('need wrapper function')\n\n Object.keys(fn).forEach(function (k) {\n wrapper[k] = fn[k]\n })\n\n return wrapper\n\n function wrapper() {\n var args = new Array(arguments.length)\n for (var i = 0; i < args.length; i++) {\n args[i] = arguments[i]\n }\n var ret = fn.apply(this, args)\n var cb = args[args.length-1]\n if (typeof ret === 'function' && ret !== cb) {\n Object.keys(cb).forEach(function (k) {\n ret[k] = cb[k]\n })\n }\n return ret\n }\n}\n","import { readFile } from 'fs/promises';\nimport * as child from 'child_process';\nimport * as pathFs from 'path';\nimport * as Range from 'drange';\nimport * as assert from 'assert';\nimport parseLCOV from 'parse-lcov';\n\nexport type CoverageFormat = 'lcov' | 'istanbul';\n\ntype Opts = {\n base: string;\n coverage: string;\n head: string;\n coverageFormat: CoverageFormat;\n};\n\nexport type Lines = Range;\nexport type Path = string;\n\nasync function runGit(command: string): Promise {\n const [ex, ...args] = command.split(' ');\n return new Promise((ok, fail) => {\n const collected: string[] = [];\n const errors: string[] = [];\n const run = child.spawn(ex, args);\n run.stderr.setEncoding('utf8');\n run.stderr.on('data', (msg: string) => {\n errors.push(msg);\n });\n run.stdout.setEncoding('utf8');\n run.stdout.on('data', (msg: string) => collected.push(msg));\n run.on('close', () => {\n ok(collected.join(''));\n });\n run.on('error', (err: Error) => {\n fail(`got error from rungit \"${err.message}\" ${err.stack}\n\n stderr:\n ${errors.join('')}`);\n });\n });\n}\nasync function changedLines(opts: Opts): Promise> {\n const stdout = await runGit(`git diff -w -U0 ${opts.base}...${opts.head}`);\n const result: Record = {};\n let currentFile: Path | null = null;\n for (const line of stdout.split('\\n')) {\n const fileHeader = line.match(/^\\+\\+\\+ b\\/(.*)/);\n if (fileHeader && fileHeader[1]) {\n currentFile = fileHeader[1];\n result[currentFile] = new Range();\n continue;\n }\n const changeHeader = line.match(/^@@ .* \\+(\\d+)(,\\d+)?/);\n if (changeHeader) {\n const start = Number(changeHeader[1]);\n const count = changeHeader[2] ? Number(changeHeader[2].slice(1)) : 1;\n if (!currentFile) {\n continue;\n }\n const head = result[currentFile];\n if (!head) {\n continue;\n }\n const high = start + count - 1;\n head.add(Math.min(start, high), Math.max(start, high));\n }\n }\n return result;\n}\n\nexport function uncovered(args: {\n coverage: Record;\n changes: Record;\n}): Result {\n const result: Record = {};\n let coveredChanges = 0;\n let totalChanges = 0;\n for (const path of Object.keys(args.changes)) {\n const uncovered = new Range();\n const changes = args.changes[path] ?? new Range();\n const hits = args.coverage[path]?.sort((a, b) => a.start - b.start);\n if (!hits) {\n continue;\n }\n let lowerBoundIndex = 0;\n for (const subrange of changes.subranges().sort((a, b) => a.low - b.low)) {\n for (let i = lowerBoundIndex; i < hits.length && hits[i].start < subrange.high; i++) {\n const hit = hits[i];\n if (subrange.low > hit.end) {\n // all following subranges will have 'low > current range 'low so\n // no need to consider prior hits for those\n lowerBoundIndex++;\n // lets consider next hit\n continue;\n }\n if (subrange.high < hit.start) {\n // subrange ends before next hit starts\n // all following hits will have 'start > current hit 'start\n // so we are done with the current subrange\n break;\n }\n if (hit.hits === 0) {\n uncovered.add(new Range(subrange.low, subrange.high).intersect(hit.start, hit.end));\n }\n }\n }\n totalChanges += changes.length;\n coveredChanges += changes.length - uncovered.length;\n if (uncovered.length) {\n result[path] = uncovered;\n }\n }\n return {\n covered: coveredChanges,\n total: totalChanges,\n uncoveredLines: result\n };\n}\n\ntype Hits = Array<{\n hits: number;\n start: number;\n end: number;\n}>;\nasync function coveredLines(opts: Opts): Promise> {\n return opts.coverageFormat === 'lcov' ? lcovCoveredLines(opts) : istanbulCoveredLines(opts);\n}\n\nasync function istanbulCoveredLines(opts: Opts): Promise> {\n const coverage = JSON.parse(await readFile(opts.coverage, 'utf8'));\n const result: Record = {};\n for (const absolutePath of Object.keys(coverage)) {\n const path = pathFs.relative(process.cwd(), absolutePath);\n const collect: Hits = [];\n result[path] = collect;\n for (const statementIndex of Object.keys(coverage[absolutePath].s)) {\n const hit = coverage[absolutePath].statementMap[statementIndex];\n if (!hit) {\n continue;\n }\n collect.push({\n hits: coverage[absolutePath].s[statementIndex],\n start: Math.min(hit.start.line, hit.end.line),\n end: Math.max(hit.start.line, hit.end.line)\n });\n }\n }\n return result;\n}\n\nasync function lcovCoveredLines(opts: Opts): Promise> {\n const fileContents = await readFile(opts.coverage, 'utf8');\n const lcovData = parseLCOV(fileContents);\n return lcovData.reduce>((result, fileEntry) => {\n const path = pathFs.isAbsolute(fileEntry.file)\n ? pathFs.normalize(pathFs.relative(process.cwd(), fileEntry.file))\n : pathFs.normalize(fileEntry.file);\n result[path] = fileEntry.lines.details.map(({ line, hit }) => ({\n hits: hit,\n start: line,\n end: line\n }));\n return result;\n }, {});\n}\n\nexport type Result = { covered: number; total: number; uncoveredLines: Record };\nasync function uncoveredLines(opts: Opts): Promise {\n const coverage = await coveredLines(opts);\n const changes = await changedLines(opts);\n return uncovered({ coverage, changes });\n}\n\nexport async function run(opts: Opts): Promise {\n const file = opts.coverage;\n if (opts.coverageFormat === 'istanbul') {\n assert(/\\.json$/.test(file), `input file '${file}' must be json coverage file`);\n }\n\n return await uncoveredLines({\n base: opts.base,\n head: opts.head,\n coverage: file,\n coverageFormat: opts.coverageFormat\n });\n}\n","module.exports = require(\"assert\");","module.exports = require(\"async_hooks\");","module.exports = require(\"buffer\");","module.exports = require(\"child_process\");","module.exports = require(\"console\");","module.exports = require(\"crypto\");","module.exports = require(\"diagnostics_channel\");","module.exports = require(\"events\");","module.exports = require(\"fs\");","module.exports = require(\"fs/promises\");","module.exports = require(\"http\");","module.exports = require(\"http2\");","module.exports = require(\"https\");","module.exports = require(\"net\");","module.exports = require(\"node:events\");","module.exports = require(\"node:stream\");","module.exports = require(\"node:util\");","module.exports = require(\"os\");","module.exports = require(\"path\");","module.exports = require(\"perf_hooks\");","module.exports = require(\"querystring\");","module.exports = require(\"stream\");","module.exports = require(\"stream/web\");","module.exports = require(\"string_decoder\");","module.exports = require(\"tls\");","module.exports = require(\"url\");","module.exports = require(\"util\");","module.exports = require(\"util/types\");","module.exports = require(\"worker_threads\");","module.exports = require(\"zlib\");","'use strict'\n\nconst WritableStream = require('node:stream').Writable\nconst inherits = require('node:util').inherits\n\nconst StreamSearch = require('../../streamsearch/sbmh')\n\nconst PartStream = require('./PartStream')\nconst HeaderParser = require('./HeaderParser')\n\nconst DASH = 45\nconst B_ONEDASH = Buffer.from('-')\nconst B_CRLF = Buffer.from('\\r\\n')\nconst EMPTY_FN = function () {}\n\nfunction Dicer (cfg) {\n if (!(this instanceof Dicer)) { return new Dicer(cfg) }\n WritableStream.call(this, cfg)\n\n if (!cfg || (!cfg.headerFirst && typeof cfg.boundary !== 'string')) { throw new TypeError('Boundary required') }\n\n if (typeof cfg.boundary === 'string') { this.setBoundary(cfg.boundary) } else { this._bparser = undefined }\n\n this._headerFirst = cfg.headerFirst\n\n this._dashes = 0\n this._parts = 0\n this._finished = false\n this._realFinish = false\n this._isPreamble = true\n this._justMatched = false\n this._firstWrite = true\n this._inHeader = true\n this._part = undefined\n this._cb = undefined\n this._ignoreData = false\n this._partOpts = { highWaterMark: cfg.partHwm }\n this._pause = false\n\n const self = this\n this._hparser = new HeaderParser(cfg)\n this._hparser.on('header', function (header) {\n self._inHeader = false\n self._part.emit('header', header)\n })\n}\ninherits(Dicer, WritableStream)\n\nDicer.prototype.emit = function (ev) {\n if (ev === 'finish' && !this._realFinish) {\n if (!this._finished) {\n const self = this\n process.nextTick(function () {\n self.emit('error', new Error('Unexpected end of multipart data'))\n if (self._part && !self._ignoreData) {\n const type = (self._isPreamble ? 'Preamble' : 'Part')\n self._part.emit('error', new Error(type + ' terminated early due to unexpected end of multipart data'))\n self._part.push(null)\n process.nextTick(function () {\n self._realFinish = true\n self.emit('finish')\n self._realFinish = false\n })\n return\n }\n self._realFinish = true\n self.emit('finish')\n self._realFinish = false\n })\n }\n } else { WritableStream.prototype.emit.apply(this, arguments) }\n}\n\nDicer.prototype._write = function (data, encoding, cb) {\n // ignore unexpected data (e.g. extra trailer data after finished)\n if (!this._hparser && !this._bparser) { return cb() }\n\n if (this._headerFirst && this._isPreamble) {\n if (!this._part) {\n this._part = new PartStream(this._partOpts)\n if (this.listenerCount('preamble') !== 0) { this.emit('preamble', this._part) } else { this._ignore() }\n }\n const r = this._hparser.push(data)\n if (!this._inHeader && r !== undefined && r < data.length) { data = data.slice(r) } else { return cb() }\n }\n\n // allows for \"easier\" testing\n if (this._firstWrite) {\n this._bparser.push(B_CRLF)\n this._firstWrite = false\n }\n\n this._bparser.push(data)\n\n if (this._pause) { this._cb = cb } else { cb() }\n}\n\nDicer.prototype.reset = function () {\n this._part = undefined\n this._bparser = undefined\n this._hparser = undefined\n}\n\nDicer.prototype.setBoundary = function (boundary) {\n const self = this\n this._bparser = new StreamSearch('\\r\\n--' + boundary)\n this._bparser.on('info', function (isMatch, data, start, end) {\n self._oninfo(isMatch, data, start, end)\n })\n}\n\nDicer.prototype._ignore = function () {\n if (this._part && !this._ignoreData) {\n this._ignoreData = true\n this._part.on('error', EMPTY_FN)\n // we must perform some kind of read on the stream even though we are\n // ignoring the data, otherwise node's Readable stream will not emit 'end'\n // after pushing null to the stream\n this._part.resume()\n }\n}\n\nDicer.prototype._oninfo = function (isMatch, data, start, end) {\n let buf; const self = this; let i = 0; let r; let shouldWriteMore = true\n\n if (!this._part && this._justMatched && data) {\n while (this._dashes < 2 && (start + i) < end) {\n if (data[start + i] === DASH) {\n ++i\n ++this._dashes\n } else {\n if (this._dashes) { buf = B_ONEDASH }\n this._dashes = 0\n break\n }\n }\n if (this._dashes === 2) {\n if ((start + i) < end && this.listenerCount('trailer') !== 0) { this.emit('trailer', data.slice(start + i, end)) }\n this.reset()\n this._finished = true\n // no more parts will be added\n if (self._parts === 0) {\n self._realFinish = true\n self.emit('finish')\n self._realFinish = false\n }\n }\n if (this._dashes) { return }\n }\n if (this._justMatched) { this._justMatched = false }\n if (!this._part) {\n this._part = new PartStream(this._partOpts)\n this._part._read = function (n) {\n self._unpause()\n }\n if (this._isPreamble && this.listenerCount('preamble') !== 0) {\n this.emit('preamble', this._part)\n } else if (this._isPreamble !== true && this.listenerCount('part') !== 0) {\n this.emit('part', this._part)\n } else {\n this._ignore()\n }\n if (!this._isPreamble) { this._inHeader = true }\n }\n if (data && start < end && !this._ignoreData) {\n if (this._isPreamble || !this._inHeader) {\n if (buf) { shouldWriteMore = this._part.push(buf) }\n shouldWriteMore = this._part.push(data.slice(start, end))\n if (!shouldWriteMore) { this._pause = true }\n } else if (!this._isPreamble && this._inHeader) {\n if (buf) { this._hparser.push(buf) }\n r = this._hparser.push(data.slice(start, end))\n if (!this._inHeader && r !== undefined && r < end) { this._oninfo(false, data, start + r, end) }\n }\n }\n if (isMatch) {\n this._hparser.reset()\n if (this._isPreamble) { this._isPreamble = false } else {\n if (start !== end) {\n ++this._parts\n this._part.on('end', function () {\n if (--self._parts === 0) {\n if (self._finished) {\n self._realFinish = true\n self.emit('finish')\n self._realFinish = false\n } else {\n self._unpause()\n }\n }\n })\n }\n }\n this._part.push(null)\n this._part = undefined\n this._ignoreData = false\n this._justMatched = true\n this._dashes = 0\n }\n}\n\nDicer.prototype._unpause = function () {\n if (!this._pause) { return }\n\n this._pause = false\n if (this._cb) {\n const cb = this._cb\n this._cb = undefined\n cb()\n }\n}\n\nmodule.exports = Dicer\n","'use strict'\n\nconst EventEmitter = require('node:events').EventEmitter\nconst inherits = require('node:util').inherits\nconst getLimit = require('../../../lib/utils/getLimit')\n\nconst StreamSearch = require('../../streamsearch/sbmh')\n\nconst B_DCRLF = Buffer.from('\\r\\n\\r\\n')\nconst RE_CRLF = /\\r\\n/g\nconst RE_HDR = /^([^:]+):[ \\t]?([\\x00-\\xFF]+)?$/ // eslint-disable-line no-control-regex\n\nfunction HeaderParser (cfg) {\n EventEmitter.call(this)\n\n cfg = cfg || {}\n const self = this\n this.nread = 0\n this.maxed = false\n this.npairs = 0\n this.maxHeaderPairs = getLimit(cfg, 'maxHeaderPairs', 2000)\n this.maxHeaderSize = getLimit(cfg, 'maxHeaderSize', 80 * 1024)\n this.buffer = ''\n this.header = {}\n this.finished = false\n this.ss = new StreamSearch(B_DCRLF)\n this.ss.on('info', function (isMatch, data, start, end) {\n if (data && !self.maxed) {\n if (self.nread + end - start >= self.maxHeaderSize) {\n end = self.maxHeaderSize - self.nread + start\n self.nread = self.maxHeaderSize\n self.maxed = true\n } else { self.nread += (end - start) }\n\n self.buffer += data.toString('binary', start, end)\n }\n if (isMatch) { self._finish() }\n })\n}\ninherits(HeaderParser, EventEmitter)\n\nHeaderParser.prototype.push = function (data) {\n const r = this.ss.push(data)\n if (this.finished) { return r }\n}\n\nHeaderParser.prototype.reset = function () {\n this.finished = false\n this.buffer = ''\n this.header = {}\n this.ss.reset()\n}\n\nHeaderParser.prototype._finish = function () {\n if (this.buffer) { this._parseHeader() }\n this.ss.matches = this.ss.maxMatches\n const header = this.header\n this.header = {}\n this.buffer = ''\n this.finished = true\n this.nread = this.npairs = 0\n this.maxed = false\n this.emit('header', header)\n}\n\nHeaderParser.prototype._parseHeader = function () {\n if (this.npairs === this.maxHeaderPairs) { return }\n\n const lines = this.buffer.split(RE_CRLF)\n const len = lines.length\n let m, h\n\n for (var i = 0; i < len; ++i) { // eslint-disable-line no-var\n if (lines[i].length === 0) { continue }\n if (lines[i][0] === '\\t' || lines[i][0] === ' ') {\n // folded header content\n // RFC2822 says to just remove the CRLF and not the whitespace following\n // it, so we follow the RFC and include the leading whitespace ...\n if (h) {\n this.header[h][this.header[h].length - 1] += lines[i]\n continue\n }\n }\n\n const posColon = lines[i].indexOf(':')\n if (\n posColon === -1 ||\n posColon === 0\n ) {\n return\n }\n m = RE_HDR.exec(lines[i])\n h = m[1].toLowerCase()\n this.header[h] = this.header[h] || []\n this.header[h].push((m[2] || ''))\n if (++this.npairs === this.maxHeaderPairs) { break }\n }\n}\n\nmodule.exports = HeaderParser\n","'use strict'\n\nconst inherits = require('node:util').inherits\nconst ReadableStream = require('node:stream').Readable\n\nfunction PartStream (opts) {\n ReadableStream.call(this, opts)\n}\ninherits(PartStream, ReadableStream)\n\nPartStream.prototype._read = function (n) {}\n\nmodule.exports = PartStream\n","'use strict'\n\n/**\n * Copyright Brian White. All rights reserved.\n *\n * @see https://github.com/mscdex/streamsearch\n *\n * Permission is hereby granted, free of charge, to any person obtaining a copy\n * of this software and associated documentation files (the \"Software\"), to\n * deal in the Software without restriction, including without limitation the\n * rights to use, copy, modify, merge, publish, distribute, sublicense, and/or\n * sell copies of the Software, and to permit persons to whom the Software is\n * furnished to do so, subject to the following conditions:\n *\n * The above copyright notice and this permission notice shall be included in\n * all copies or substantial portions of the Software.\n *\n * THE SOFTWARE IS PROVIDED \"AS IS\", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR\n * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,\n * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE\n * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER\n * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING\n * FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS\n * IN THE SOFTWARE.\n *\n * Based heavily on the Streaming Boyer-Moore-Horspool C++ implementation\n * by Hongli Lai at: https://github.com/FooBarWidget/boyer-moore-horspool\n */\nconst EventEmitter = require('node:events').EventEmitter\nconst inherits = require('node:util').inherits\n\nfunction SBMH (needle) {\n if (typeof needle === 'string') {\n needle = Buffer.from(needle)\n }\n\n if (!Buffer.isBuffer(needle)) {\n throw new TypeError('The needle has to be a String or a Buffer.')\n }\n\n const needleLength = needle.length\n\n if (needleLength === 0) {\n throw new Error('The needle cannot be an empty String/Buffer.')\n }\n\n if (needleLength > 256) {\n throw new Error('The needle cannot have a length bigger than 256.')\n }\n\n this.maxMatches = Infinity\n this.matches = 0\n\n this._occ = new Array(256)\n .fill(needleLength) // Initialize occurrence table.\n this._lookbehind_size = 0\n this._needle = needle\n this._bufpos = 0\n\n this._lookbehind = Buffer.alloc(needleLength)\n\n // Populate occurrence table with analysis of the needle,\n // ignoring last letter.\n for (var i = 0; i < needleLength - 1; ++i) { // eslint-disable-line no-var\n this._occ[needle[i]] = needleLength - 1 - i\n }\n}\ninherits(SBMH, EventEmitter)\n\nSBMH.prototype.reset = function () {\n this._lookbehind_size = 0\n this.matches = 0\n this._bufpos = 0\n}\n\nSBMH.prototype.push = function (chunk, pos) {\n if (!Buffer.isBuffer(chunk)) {\n chunk = Buffer.from(chunk, 'binary')\n }\n const chlen = chunk.length\n this._bufpos = pos || 0\n let r\n while (r !== chlen && this.matches < this.maxMatches) { r = this._sbmh_feed(chunk) }\n return r\n}\n\nSBMH.prototype._sbmh_feed = function (data) {\n const len = data.length\n const needle = this._needle\n const needleLength = needle.length\n const lastNeedleChar = needle[needleLength - 1]\n\n // Positive: points to a position in `data`\n // pos == 3 points to data[3]\n // Negative: points to a position in the lookbehind buffer\n // pos == -2 points to lookbehind[lookbehind_size - 2]\n let pos = -this._lookbehind_size\n let ch\n\n if (pos < 0) {\n // Lookbehind buffer is not empty. Perform Boyer-Moore-Horspool\n // search with character lookup code that considers both the\n // lookbehind buffer and the current round's haystack data.\n //\n // Loop until\n // there is a match.\n // or until\n // we've moved past the position that requires the\n // lookbehind buffer. In this case we switch to the\n // optimized loop.\n // or until\n // the character to look at lies outside the haystack.\n while (pos < 0 && pos <= len - needleLength) {\n ch = this._sbmh_lookup_char(data, pos + needleLength - 1)\n\n if (\n ch === lastNeedleChar &&\n this._sbmh_memcmp(data, pos, needleLength - 1)\n ) {\n this._lookbehind_size = 0\n ++this.matches\n this.emit('info', true)\n\n return (this._bufpos = pos + needleLength)\n }\n pos += this._occ[ch]\n }\n\n // No match.\n\n if (pos < 0) {\n // There's too few data for Boyer-Moore-Horspool to run,\n // so let's use a different algorithm to skip as much as\n // we can.\n // Forward pos until\n // the trailing part of lookbehind + data\n // looks like the beginning of the needle\n // or until\n // pos == 0\n while (pos < 0 && !this._sbmh_memcmp(data, pos, len - pos)) { ++pos }\n }\n\n if (pos >= 0) {\n // Discard lookbehind buffer.\n this.emit('info', false, this._lookbehind, 0, this._lookbehind_size)\n this._lookbehind_size = 0\n } else {\n // Cut off part of the lookbehind buffer that has\n // been processed and append the entire haystack\n // into it.\n const bytesToCutOff = this._lookbehind_size + pos\n if (bytesToCutOff > 0) {\n // The cut off data is guaranteed not to contain the needle.\n this.emit('info', false, this._lookbehind, 0, bytesToCutOff)\n }\n\n this._lookbehind.copy(this._lookbehind, 0, bytesToCutOff,\n this._lookbehind_size - bytesToCutOff)\n this._lookbehind_size -= bytesToCutOff\n\n data.copy(this._lookbehind, this._lookbehind_size)\n this._lookbehind_size += len\n\n this._bufpos = len\n return len\n }\n }\n\n pos += (pos >= 0) * this._bufpos\n\n // Lookbehind buffer is now empty. We only need to check if the\n // needle is in the haystack.\n if (data.indexOf(needle, pos) !== -1) {\n pos = data.indexOf(needle, pos)\n ++this.matches\n if (pos > 0) { this.emit('info', true, data, this._bufpos, pos) } else { this.emit('info', true) }\n\n return (this._bufpos = pos + needleLength)\n } else {\n pos = len - needleLength\n }\n\n // There was no match. If there's trailing haystack data that we cannot\n // match yet using the Boyer-Moore-Horspool algorithm (because the trailing\n // data is less than the needle size) then match using a modified\n // algorithm that starts matching from the beginning instead of the end.\n // Whatever trailing data is left after running this algorithm is added to\n // the lookbehind buffer.\n while (\n pos < len &&\n (\n data[pos] !== needle[0] ||\n (\n (Buffer.compare(\n data.subarray(pos, pos + len - pos),\n needle.subarray(0, len - pos)\n ) !== 0)\n )\n )\n ) {\n ++pos\n }\n if (pos < len) {\n data.copy(this._lookbehind, 0, pos, pos + (len - pos))\n this._lookbehind_size = len - pos\n }\n\n // Everything until pos is guaranteed not to contain needle data.\n if (pos > 0) { this.emit('info', false, data, this._bufpos, pos < len ? pos : len) }\n\n this._bufpos = len\n return len\n}\n\nSBMH.prototype._sbmh_lookup_char = function (data, pos) {\n return (pos < 0)\n ? this._lookbehind[this._lookbehind_size + pos]\n : data[pos]\n}\n\nSBMH.prototype._sbmh_memcmp = function (data, pos, len) {\n for (var i = 0; i < len; ++i) { // eslint-disable-line no-var\n if (this._sbmh_lookup_char(data, pos + i) !== this._needle[i]) { return false }\n }\n return true\n}\n\nmodule.exports = SBMH\n","'use strict'\n\nconst WritableStream = require('node:stream').Writable\nconst { inherits } = require('node:util')\nconst Dicer = require('../deps/dicer/lib/Dicer')\n\nconst MultipartParser = require('./types/multipart')\nconst UrlencodedParser = require('./types/urlencoded')\nconst parseParams = require('./utils/parseParams')\n\nfunction Busboy (opts) {\n if (!(this instanceof Busboy)) { return new Busboy(opts) }\n\n if (typeof opts !== 'object') {\n throw new TypeError('Busboy expected an options-Object.')\n }\n if (typeof opts.headers !== 'object') {\n throw new TypeError('Busboy expected an options-Object with headers-attribute.')\n }\n if (typeof opts.headers['content-type'] !== 'string') {\n throw new TypeError('Missing Content-Type-header.')\n }\n\n const {\n headers,\n ...streamOptions\n } = opts\n\n this.opts = {\n autoDestroy: false,\n ...streamOptions\n }\n WritableStream.call(this, this.opts)\n\n this._done = false\n this._parser = this.getParserByHeaders(headers)\n this._finished = false\n}\ninherits(Busboy, WritableStream)\n\nBusboy.prototype.emit = function (ev) {\n if (ev === 'finish') {\n if (!this._done) {\n this._parser?.end()\n return\n } else if (this._finished) {\n return\n }\n this._finished = true\n }\n WritableStream.prototype.emit.apply(this, arguments)\n}\n\nBusboy.prototype.getParserByHeaders = function (headers) {\n const parsed = parseParams(headers['content-type'])\n\n const cfg = {\n defCharset: this.opts.defCharset,\n fileHwm: this.opts.fileHwm,\n headers,\n highWaterMark: this.opts.highWaterMark,\n isPartAFile: this.opts.isPartAFile,\n limits: this.opts.limits,\n parsedConType: parsed,\n preservePath: this.opts.preservePath\n }\n\n if (MultipartParser.detect.test(parsed[0])) {\n return new MultipartParser(this, cfg)\n }\n if (UrlencodedParser.detect.test(parsed[0])) {\n return new UrlencodedParser(this, cfg)\n }\n throw new Error('Unsupported Content-Type.')\n}\n\nBusboy.prototype._write = function (chunk, encoding, cb) {\n this._parser.write(chunk, cb)\n}\n\nmodule.exports = Busboy\nmodule.exports.default = Busboy\nmodule.exports.Busboy = Busboy\n\nmodule.exports.Dicer = Dicer\n","'use strict'\n\n// TODO:\n// * support 1 nested multipart level\n// (see second multipart example here:\n// http://www.w3.org/TR/html401/interact/forms.html#didx-multipartform-data)\n// * support limits.fieldNameSize\n// -- this will require modifications to utils.parseParams\n\nconst { Readable } = require('node:stream')\nconst { inherits } = require('node:util')\n\nconst Dicer = require('../../deps/dicer/lib/Dicer')\n\nconst parseParams = require('../utils/parseParams')\nconst decodeText = require('../utils/decodeText')\nconst basename = require('../utils/basename')\nconst getLimit = require('../utils/getLimit')\n\nconst RE_BOUNDARY = /^boundary$/i\nconst RE_FIELD = /^form-data$/i\nconst RE_CHARSET = /^charset$/i\nconst RE_FILENAME = /^filename$/i\nconst RE_NAME = /^name$/i\n\nMultipart.detect = /^multipart\\/form-data/i\nfunction Multipart (boy, cfg) {\n let i\n let len\n const self = this\n let boundary\n const limits = cfg.limits\n const isPartAFile = cfg.isPartAFile || ((fieldName, contentType, fileName) => (contentType === 'application/octet-stream' || fileName !== undefined))\n const parsedConType = cfg.parsedConType || []\n const defCharset = cfg.defCharset || 'utf8'\n const preservePath = cfg.preservePath\n const fileOpts = { highWaterMark: cfg.fileHwm }\n\n for (i = 0, len = parsedConType.length; i < len; ++i) {\n if (Array.isArray(parsedConType[i]) &&\n RE_BOUNDARY.test(parsedConType[i][0])) {\n boundary = parsedConType[i][1]\n break\n }\n }\n\n function checkFinished () {\n if (nends === 0 && finished && !boy._done) {\n finished = false\n self.end()\n }\n }\n\n if (typeof boundary !== 'string') { throw new Error('Multipart: Boundary not found') }\n\n const fieldSizeLimit = getLimit(limits, 'fieldSize', 1 * 1024 * 1024)\n const fileSizeLimit = getLimit(limits, 'fileSize', Infinity)\n const filesLimit = getLimit(limits, 'files', Infinity)\n const fieldsLimit = getLimit(limits, 'fields', Infinity)\n const partsLimit = getLimit(limits, 'parts', Infinity)\n const headerPairsLimit = getLimit(limits, 'headerPairs', 2000)\n const headerSizeLimit = getLimit(limits, 'headerSize', 80 * 1024)\n\n let nfiles = 0\n let nfields = 0\n let nends = 0\n let curFile\n let curField\n let finished = false\n\n this._needDrain = false\n this._pause = false\n this._cb = undefined\n this._nparts = 0\n this._boy = boy\n\n const parserCfg = {\n boundary,\n maxHeaderPairs: headerPairsLimit,\n maxHeaderSize: headerSizeLimit,\n partHwm: fileOpts.highWaterMark,\n highWaterMark: cfg.highWaterMark\n }\n\n this.parser = new Dicer(parserCfg)\n this.parser.on('drain', function () {\n self._needDrain = false\n if (self._cb && !self._pause) {\n const cb = self._cb\n self._cb = undefined\n cb()\n }\n }).on('part', function onPart (part) {\n if (++self._nparts > partsLimit) {\n self.parser.removeListener('part', onPart)\n self.parser.on('part', skipPart)\n boy.hitPartsLimit = true\n boy.emit('partsLimit')\n return skipPart(part)\n }\n\n // hack because streams2 _always_ doesn't emit 'end' until nextTick, so let\n // us emit 'end' early since we know the part has ended if we are already\n // seeing the next part\n if (curField) {\n const field = curField\n field.emit('end')\n field.removeAllListeners('end')\n }\n\n part.on('header', function (header) {\n let contype\n let fieldname\n let parsed\n let charset\n let encoding\n let filename\n let nsize = 0\n\n if (header['content-type']) {\n parsed = parseParams(header['content-type'][0])\n if (parsed[0]) {\n contype = parsed[0].toLowerCase()\n for (i = 0, len = parsed.length; i < len; ++i) {\n if (RE_CHARSET.test(parsed[i][0])) {\n charset = parsed[i][1].toLowerCase()\n break\n }\n }\n }\n }\n\n if (contype === undefined) { contype = 'text/plain' }\n if (charset === undefined) { charset = defCharset }\n\n if (header['content-disposition']) {\n parsed = parseParams(header['content-disposition'][0])\n if (!RE_FIELD.test(parsed[0])) { return skipPart(part) }\n for (i = 0, len = parsed.length; i < len; ++i) {\n if (RE_NAME.test(parsed[i][0])) {\n fieldname = parsed[i][1]\n } else if (RE_FILENAME.test(parsed[i][0])) {\n filename = parsed[i][1]\n if (!preservePath) { filename = basename(filename) }\n }\n }\n } else { return skipPart(part) }\n\n if (header['content-transfer-encoding']) { encoding = header['content-transfer-encoding'][0].toLowerCase() } else { encoding = '7bit' }\n\n let onData,\n onEnd\n\n if (isPartAFile(fieldname, contype, filename)) {\n // file/binary field\n if (nfiles === filesLimit) {\n if (!boy.hitFilesLimit) {\n boy.hitFilesLimit = true\n boy.emit('filesLimit')\n }\n return skipPart(part)\n }\n\n ++nfiles\n\n if (boy.listenerCount('file') === 0) {\n self.parser._ignore()\n return\n }\n\n ++nends\n const file = new FileStream(fileOpts)\n curFile = file\n file.on('end', function () {\n --nends\n self._pause = false\n checkFinished()\n if (self._cb && !self._needDrain) {\n const cb = self._cb\n self._cb = undefined\n cb()\n }\n })\n file._read = function (n) {\n if (!self._pause) { return }\n self._pause = false\n if (self._cb && !self._needDrain) {\n const cb = self._cb\n self._cb = undefined\n cb()\n }\n }\n boy.emit('file', fieldname, file, filename, encoding, contype)\n\n onData = function (data) {\n if ((nsize += data.length) > fileSizeLimit) {\n const extralen = fileSizeLimit - nsize + data.length\n if (extralen > 0) { file.push(data.slice(0, extralen)) }\n file.truncated = true\n file.bytesRead = fileSizeLimit\n part.removeAllListeners('data')\n file.emit('limit')\n return\n } else if (!file.push(data)) { self._pause = true }\n\n file.bytesRead = nsize\n }\n\n onEnd = function () {\n curFile = undefined\n file.push(null)\n }\n } else {\n // non-file field\n if (nfields === fieldsLimit) {\n if (!boy.hitFieldsLimit) {\n boy.hitFieldsLimit = true\n boy.emit('fieldsLimit')\n }\n return skipPart(part)\n }\n\n ++nfields\n ++nends\n let buffer = ''\n let truncated = false\n curField = part\n\n onData = function (data) {\n if ((nsize += data.length) > fieldSizeLimit) {\n const extralen = (fieldSizeLimit - (nsize - data.length))\n buffer += data.toString('binary', 0, extralen)\n truncated = true\n part.removeAllListeners('data')\n } else { buffer += data.toString('binary') }\n }\n\n onEnd = function () {\n curField = undefined\n if (buffer.length) { buffer = decodeText(buffer, 'binary', charset) }\n boy.emit('field', fieldname, buffer, false, truncated, encoding, contype)\n --nends\n checkFinished()\n }\n }\n\n /* As of node@2efe4ab761666 (v0.10.29+/v0.11.14+), busboy had become\n broken. Streams2/streams3 is a huge black box of confusion, but\n somehow overriding the sync state seems to fix things again (and still\n seems to work for previous node versions).\n */\n part._readableState.sync = false\n\n part.on('data', onData)\n part.on('end', onEnd)\n }).on('error', function (err) {\n if (curFile) { curFile.emit('error', err) }\n })\n }).on('error', function (err) {\n boy.emit('error', err)\n }).on('finish', function () {\n finished = true\n checkFinished()\n })\n}\n\nMultipart.prototype.write = function (chunk, cb) {\n const r = this.parser.write(chunk)\n if (r && !this._pause) {\n cb()\n } else {\n this._needDrain = !r\n this._cb = cb\n }\n}\n\nMultipart.prototype.end = function () {\n const self = this\n\n if (self.parser.writable) {\n self.parser.end()\n } else if (!self._boy._done) {\n process.nextTick(function () {\n self._boy._done = true\n self._boy.emit('finish')\n })\n }\n}\n\nfunction skipPart (part) {\n part.resume()\n}\n\nfunction FileStream (opts) {\n Readable.call(this, opts)\n\n this.bytesRead = 0\n\n this.truncated = false\n}\n\ninherits(FileStream, Readable)\n\nFileStream.prototype._read = function (n) {}\n\nmodule.exports = Multipart\n","'use strict'\n\nconst Decoder = require('../utils/Decoder')\nconst decodeText = require('../utils/decodeText')\nconst getLimit = require('../utils/getLimit')\n\nconst RE_CHARSET = /^charset$/i\n\nUrlEncoded.detect = /^application\\/x-www-form-urlencoded/i\nfunction UrlEncoded (boy, cfg) {\n const limits = cfg.limits\n const parsedConType = cfg.parsedConType\n this.boy = boy\n\n this.fieldSizeLimit = getLimit(limits, 'fieldSize', 1 * 1024 * 1024)\n this.fieldNameSizeLimit = getLimit(limits, 'fieldNameSize', 100)\n this.fieldsLimit = getLimit(limits, 'fields', Infinity)\n\n let charset\n for (var i = 0, len = parsedConType.length; i < len; ++i) { // eslint-disable-line no-var\n if (Array.isArray(parsedConType[i]) &&\n RE_CHARSET.test(parsedConType[i][0])) {\n charset = parsedConType[i][1].toLowerCase()\n break\n }\n }\n\n if (charset === undefined) { charset = cfg.defCharset || 'utf8' }\n\n this.decoder = new Decoder()\n this.charset = charset\n this._fields = 0\n this._state = 'key'\n this._checkingBytes = true\n this._bytesKey = 0\n this._bytesVal = 0\n this._key = ''\n this._val = ''\n this._keyTrunc = false\n this._valTrunc = false\n this._hitLimit = false\n}\n\nUrlEncoded.prototype.write = function (data, cb) {\n if (this._fields === this.fieldsLimit) {\n if (!this.boy.hitFieldsLimit) {\n this.boy.hitFieldsLimit = true\n this.boy.emit('fieldsLimit')\n }\n return cb()\n }\n\n let idxeq; let idxamp; let i; let p = 0; const len = data.length\n\n while (p < len) {\n if (this._state === 'key') {\n idxeq = idxamp = undefined\n for (i = p; i < len; ++i) {\n if (!this._checkingBytes) { ++p }\n if (data[i] === 0x3D/* = */) {\n idxeq = i\n break\n } else if (data[i] === 0x26/* & */) {\n idxamp = i\n break\n }\n if (this._checkingBytes && this._bytesKey === this.fieldNameSizeLimit) {\n this._hitLimit = true\n break\n } else if (this._checkingBytes) { ++this._bytesKey }\n }\n\n if (idxeq !== undefined) {\n // key with assignment\n if (idxeq > p) { this._key += this.decoder.write(data.toString('binary', p, idxeq)) }\n this._state = 'val'\n\n this._hitLimit = false\n this._checkingBytes = true\n this._val = ''\n this._bytesVal = 0\n this._valTrunc = false\n this.decoder.reset()\n\n p = idxeq + 1\n } else if (idxamp !== undefined) {\n // key with no assignment\n ++this._fields\n let key; const keyTrunc = this._keyTrunc\n if (idxamp > p) { key = (this._key += this.decoder.write(data.toString('binary', p, idxamp))) } else { key = this._key }\n\n this._hitLimit = false\n this._checkingBytes = true\n this._key = ''\n this._bytesKey = 0\n this._keyTrunc = false\n this.decoder.reset()\n\n if (key.length) {\n this.boy.emit('field', decodeText(key, 'binary', this.charset),\n '',\n keyTrunc,\n false)\n }\n\n p = idxamp + 1\n if (this._fields === this.fieldsLimit) { return cb() }\n } else if (this._hitLimit) {\n // we may not have hit the actual limit if there are encoded bytes...\n if (i > p) { this._key += this.decoder.write(data.toString('binary', p, i)) }\n p = i\n if ((this._bytesKey = this._key.length) === this.fieldNameSizeLimit) {\n // yep, we actually did hit the limit\n this._checkingBytes = false\n this._keyTrunc = true\n }\n } else {\n if (p < len) { this._key += this.decoder.write(data.toString('binary', p)) }\n p = len\n }\n } else {\n idxamp = undefined\n for (i = p; i < len; ++i) {\n if (!this._checkingBytes) { ++p }\n if (data[i] === 0x26/* & */) {\n idxamp = i\n break\n }\n if (this._checkingBytes && this._bytesVal === this.fieldSizeLimit) {\n this._hitLimit = true\n break\n } else if (this._checkingBytes) { ++this._bytesVal }\n }\n\n if (idxamp !== undefined) {\n ++this._fields\n if (idxamp > p) { this._val += this.decoder.write(data.toString('binary', p, idxamp)) }\n this.boy.emit('field', decodeText(this._key, 'binary', this.charset),\n decodeText(this._val, 'binary', this.charset),\n this._keyTrunc,\n this._valTrunc)\n this._state = 'key'\n\n this._hitLimit = false\n this._checkingBytes = true\n this._key = ''\n this._bytesKey = 0\n this._keyTrunc = false\n this.decoder.reset()\n\n p = idxamp + 1\n if (this._fields === this.fieldsLimit) { return cb() }\n } else if (this._hitLimit) {\n // we may not have hit the actual limit if there are encoded bytes...\n if (i > p) { this._val += this.decoder.write(data.toString('binary', p, i)) }\n p = i\n if ((this._val === '' && this.fieldSizeLimit === 0) ||\n (this._bytesVal = this._val.length) === this.fieldSizeLimit) {\n // yep, we actually did hit the limit\n this._checkingBytes = false\n this._valTrunc = true\n }\n } else {\n if (p < len) { this._val += this.decoder.write(data.toString('binary', p)) }\n p = len\n }\n }\n }\n cb()\n}\n\nUrlEncoded.prototype.end = function () {\n if (this.boy._done) { return }\n\n if (this._state === 'key' && this._key.length > 0) {\n this.boy.emit('field', decodeText(this._key, 'binary', this.charset),\n '',\n this._keyTrunc,\n false)\n } else if (this._state === 'val') {\n this.boy.emit('field', decodeText(this._key, 'binary', this.charset),\n decodeText(this._val, 'binary', this.charset),\n this._keyTrunc,\n this._valTrunc)\n }\n this.boy._done = true\n this.boy.emit('finish')\n}\n\nmodule.exports = UrlEncoded\n","'use strict'\n\nconst RE_PLUS = /\\+/g\n\nconst HEX = [\n 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,\n 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,\n 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,\n 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0,\n 0, 1, 1, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0,\n 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,\n 0, 1, 1, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0,\n 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0\n]\n\nfunction Decoder () {\n this.buffer = undefined\n}\nDecoder.prototype.write = function (str) {\n // Replace '+' with ' ' before decoding\n str = str.replace(RE_PLUS, ' ')\n let res = ''\n let i = 0; let p = 0; const len = str.length\n for (; i < len; ++i) {\n if (this.buffer !== undefined) {\n if (!HEX[str.charCodeAt(i)]) {\n res += '%' + this.buffer\n this.buffer = undefined\n --i // retry character\n } else {\n this.buffer += str[i]\n ++p\n if (this.buffer.length === 2) {\n res += String.fromCharCode(parseInt(this.buffer, 16))\n this.buffer = undefined\n }\n }\n } else if (str[i] === '%') {\n if (i > p) {\n res += str.substring(p, i)\n p = i\n }\n this.buffer = ''\n ++p\n }\n }\n if (p < len && this.buffer === undefined) { res += str.substring(p) }\n return res\n}\nDecoder.prototype.reset = function () {\n this.buffer = undefined\n}\n\nmodule.exports = Decoder\n","'use strict'\n\nmodule.exports = function basename (path) {\n if (typeof path !== 'string') { return '' }\n for (var i = path.length - 1; i >= 0; --i) { // eslint-disable-line no-var\n switch (path.charCodeAt(i)) {\n case 0x2F: // '/'\n case 0x5C: // '\\'\n path = path.slice(i + 1)\n return (path === '..' || path === '.' ? '' : path)\n }\n }\n return (path === '..' || path === '.' ? '' : path)\n}\n","'use strict'\n\n// Node has always utf-8\nconst utf8Decoder = new TextDecoder('utf-8')\nconst textDecoders = new Map([\n ['utf-8', utf8Decoder],\n ['utf8', utf8Decoder]\n])\n\nfunction getDecoder (charset) {\n let lc\n while (true) {\n switch (charset) {\n case 'utf-8':\n case 'utf8':\n return decoders.utf8\n case 'latin1':\n case 'ascii': // TODO: Make these a separate, strict decoder?\n case 'us-ascii':\n case 'iso-8859-1':\n case 'iso8859-1':\n case 'iso88591':\n case 'iso_8859-1':\n case 'windows-1252':\n case 'iso_8859-1:1987':\n case 'cp1252':\n case 'x-cp1252':\n return decoders.latin1\n case 'utf16le':\n case 'utf-16le':\n case 'ucs2':\n case 'ucs-2':\n return decoders.utf16le\n case 'base64':\n return decoders.base64\n default:\n if (lc === undefined) {\n lc = true\n charset = charset.toLowerCase()\n continue\n }\n return decoders.other.bind(charset)\n }\n }\n}\n\nconst decoders = {\n utf8: (data, sourceEncoding) => {\n if (data.length === 0) {\n return ''\n }\n if (typeof data === 'string') {\n data = Buffer.from(data, sourceEncoding)\n }\n return data.utf8Slice(0, data.length)\n },\n\n latin1: (data, sourceEncoding) => {\n if (data.length === 0) {\n return ''\n }\n if (typeof data === 'string') {\n return data\n }\n return data.latin1Slice(0, data.length)\n },\n\n utf16le: (data, sourceEncoding) => {\n if (data.length === 0) {\n return ''\n }\n if (typeof data === 'string') {\n data = Buffer.from(data, sourceEncoding)\n }\n return data.ucs2Slice(0, data.length)\n },\n\n base64: (data, sourceEncoding) => {\n if (data.length === 0) {\n return ''\n }\n if (typeof data === 'string') {\n data = Buffer.from(data, sourceEncoding)\n }\n return data.base64Slice(0, data.length)\n },\n\n other: (data, sourceEncoding) => {\n if (data.length === 0) {\n return ''\n }\n if (typeof data === 'string') {\n data = Buffer.from(data, sourceEncoding)\n }\n\n if (textDecoders.has(this.toString())) {\n try {\n return textDecoders.get(this).decode(data)\n } catch {}\n }\n return typeof data === 'string'\n ? data\n : data.toString()\n }\n}\n\nfunction decodeText (text, sourceEncoding, destEncoding) {\n if (text) {\n return getDecoder(destEncoding)(text, sourceEncoding)\n }\n return text\n}\n\nmodule.exports = decodeText\n","'use strict'\n\nmodule.exports = function getLimit (limits, name, defaultLimit) {\n if (\n !limits ||\n limits[name] === undefined ||\n limits[name] === null\n ) { return defaultLimit }\n\n if (\n typeof limits[name] !== 'number' ||\n isNaN(limits[name])\n ) { throw new TypeError('Limit ' + name + ' is not a valid number') }\n\n return limits[name]\n}\n","/* eslint-disable object-property-newline */\n'use strict'\n\nconst decodeText = require('./decodeText')\n\nconst RE_ENCODED = /%[a-fA-F0-9][a-fA-F0-9]/g\n\nconst EncodedLookup = {\n '%00': '\\x00', '%01': '\\x01', '%02': '\\x02', '%03': '\\x03', '%04': '\\x04',\n '%05': '\\x05', '%06': '\\x06', '%07': '\\x07', '%08': '\\x08', '%09': '\\x09',\n '%0a': '\\x0a', '%0A': '\\x0a', '%0b': '\\x0b', '%0B': '\\x0b', '%0c': '\\x0c',\n '%0C': '\\x0c', '%0d': '\\x0d', '%0D': '\\x0d', '%0e': '\\x0e', '%0E': '\\x0e',\n '%0f': '\\x0f', '%0F': '\\x0f', '%10': '\\x10', '%11': '\\x11', '%12': '\\x12',\n '%13': '\\x13', '%14': '\\x14', '%15': '\\x15', '%16': '\\x16', '%17': '\\x17',\n '%18': '\\x18', '%19': '\\x19', '%1a': '\\x1a', '%1A': '\\x1a', '%1b': '\\x1b',\n '%1B': '\\x1b', '%1c': '\\x1c', '%1C': '\\x1c', '%1d': '\\x1d', '%1D': '\\x1d',\n '%1e': '\\x1e', '%1E': '\\x1e', '%1f': '\\x1f', '%1F': '\\x1f', '%20': '\\x20',\n '%21': '\\x21', '%22': '\\x22', '%23': '\\x23', '%24': '\\x24', '%25': '\\x25',\n '%26': '\\x26', '%27': '\\x27', '%28': '\\x28', '%29': '\\x29', '%2a': '\\x2a',\n '%2A': '\\x2a', '%2b': '\\x2b', '%2B': '\\x2b', '%2c': '\\x2c', '%2C': '\\x2c',\n '%2d': '\\x2d', '%2D': '\\x2d', '%2e': '\\x2e', '%2E': '\\x2e', '%2f': '\\x2f',\n '%2F': '\\x2f', '%30': '\\x30', '%31': '\\x31', '%32': '\\x32', '%33': '\\x33',\n '%34': '\\x34', '%35': '\\x35', '%36': '\\x36', '%37': '\\x37', '%38': '\\x38',\n '%39': '\\x39', '%3a': '\\x3a', '%3A': '\\x3a', '%3b': '\\x3b', '%3B': '\\x3b',\n '%3c': '\\x3c', '%3C': '\\x3c', '%3d': '\\x3d', '%3D': '\\x3d', '%3e': '\\x3e',\n '%3E': '\\x3e', '%3f': '\\x3f', '%3F': '\\x3f', '%40': '\\x40', '%41': '\\x41',\n '%42': '\\x42', '%43': '\\x43', '%44': '\\x44', '%45': '\\x45', '%46': '\\x46',\n '%47': '\\x47', '%48': '\\x48', '%49': '\\x49', '%4a': '\\x4a', '%4A': '\\x4a',\n '%4b': '\\x4b', '%4B': '\\x4b', '%4c': '\\x4c', '%4C': '\\x4c', '%4d': '\\x4d',\n '%4D': '\\x4d', '%4e': '\\x4e', '%4E': '\\x4e', '%4f': '\\x4f', '%4F': '\\x4f',\n '%50': '\\x50', '%51': '\\x51', '%52': '\\x52', '%53': '\\x53', '%54': '\\x54',\n '%55': '\\x55', '%56': '\\x56', '%57': '\\x57', '%58': '\\x58', '%59': '\\x59',\n '%5a': '\\x5a', '%5A': '\\x5a', '%5b': '\\x5b', '%5B': '\\x5b', '%5c': '\\x5c',\n '%5C': '\\x5c', '%5d': '\\x5d', '%5D': '\\x5d', '%5e': '\\x5e', '%5E': '\\x5e',\n '%5f': '\\x5f', '%5F': '\\x5f', '%60': '\\x60', '%61': '\\x61', '%62': '\\x62',\n '%63': '\\x63', '%64': '\\x64', '%65': '\\x65', '%66': '\\x66', '%67': '\\x67',\n '%68': '\\x68', '%69': '\\x69', '%6a': '\\x6a', '%6A': '\\x6a', '%6b': '\\x6b',\n '%6B': '\\x6b', '%6c': '\\x6c', '%6C': '\\x6c', '%6d': '\\x6d', '%6D': '\\x6d',\n '%6e': '\\x6e', '%6E': '\\x6e', '%6f': '\\x6f', '%6F': '\\x6f', '%70': '\\x70',\n '%71': '\\x71', '%72': '\\x72', '%73': '\\x73', '%74': '\\x74', '%75': '\\x75',\n '%76': '\\x76', '%77': '\\x77', '%78': '\\x78', '%79': '\\x79', '%7a': '\\x7a',\n '%7A': '\\x7a', '%7b': '\\x7b', '%7B': '\\x7b', '%7c': '\\x7c', '%7C': '\\x7c',\n '%7d': '\\x7d', '%7D': '\\x7d', '%7e': '\\x7e', '%7E': '\\x7e', '%7f': '\\x7f',\n '%7F': '\\x7f', '%80': '\\x80', '%81': '\\x81', '%82': '\\x82', '%83': '\\x83',\n '%84': '\\x84', '%85': '\\x85', '%86': '\\x86', '%87': '\\x87', '%88': '\\x88',\n '%89': '\\x89', '%8a': '\\x8a', '%8A': '\\x8a', '%8b': '\\x8b', '%8B': '\\x8b',\n '%8c': '\\x8c', '%8C': '\\x8c', '%8d': '\\x8d', '%8D': '\\x8d', '%8e': '\\x8e',\n '%8E': '\\x8e', '%8f': '\\x8f', '%8F': '\\x8f', '%90': '\\x90', '%91': '\\x91',\n '%92': '\\x92', '%93': '\\x93', '%94': '\\x94', '%95': '\\x95', '%96': '\\x96',\n '%97': '\\x97', '%98': '\\x98', '%99': '\\x99', '%9a': '\\x9a', '%9A': '\\x9a',\n '%9b': '\\x9b', '%9B': '\\x9b', '%9c': '\\x9c', '%9C': '\\x9c', '%9d': '\\x9d',\n '%9D': '\\x9d', '%9e': '\\x9e', '%9E': '\\x9e', '%9f': '\\x9f', '%9F': '\\x9f',\n '%a0': '\\xa0', '%A0': '\\xa0', '%a1': '\\xa1', '%A1': '\\xa1', '%a2': '\\xa2',\n '%A2': '\\xa2', '%a3': '\\xa3', '%A3': '\\xa3', '%a4': '\\xa4', '%A4': '\\xa4',\n '%a5': '\\xa5', '%A5': '\\xa5', '%a6': '\\xa6', '%A6': '\\xa6', '%a7': '\\xa7',\n '%A7': '\\xa7', '%a8': '\\xa8', '%A8': '\\xa8', '%a9': '\\xa9', '%A9': '\\xa9',\n '%aa': '\\xaa', '%Aa': '\\xaa', '%aA': '\\xaa', '%AA': '\\xaa', '%ab': '\\xab',\n '%Ab': '\\xab', '%aB': '\\xab', '%AB': '\\xab', '%ac': '\\xac', '%Ac': '\\xac',\n '%aC': '\\xac', '%AC': '\\xac', '%ad': '\\xad', '%Ad': '\\xad', '%aD': '\\xad',\n '%AD': '\\xad', '%ae': '\\xae', '%Ae': '\\xae', '%aE': '\\xae', '%AE': '\\xae',\n '%af': '\\xaf', '%Af': '\\xaf', '%aF': '\\xaf', '%AF': '\\xaf', '%b0': '\\xb0',\n '%B0': '\\xb0', '%b1': '\\xb1', '%B1': '\\xb1', '%b2': '\\xb2', '%B2': '\\xb2',\n '%b3': '\\xb3', '%B3': '\\xb3', '%b4': '\\xb4', '%B4': '\\xb4', '%b5': '\\xb5',\n '%B5': '\\xb5', '%b6': '\\xb6', '%B6': '\\xb6', '%b7': '\\xb7', '%B7': '\\xb7',\n '%b8': '\\xb8', '%B8': '\\xb8', '%b9': '\\xb9', '%B9': '\\xb9', '%ba': '\\xba',\n '%Ba': '\\xba', '%bA': '\\xba', '%BA': '\\xba', '%bb': '\\xbb', '%Bb': '\\xbb',\n '%bB': '\\xbb', '%BB': '\\xbb', '%bc': '\\xbc', '%Bc': '\\xbc', '%bC': '\\xbc',\n '%BC': '\\xbc', '%bd': '\\xbd', '%Bd': '\\xbd', '%bD': '\\xbd', '%BD': '\\xbd',\n '%be': '\\xbe', '%Be': '\\xbe', '%bE': '\\xbe', '%BE': '\\xbe', '%bf': '\\xbf',\n '%Bf': '\\xbf', '%bF': '\\xbf', '%BF': '\\xbf', '%c0': '\\xc0', '%C0': '\\xc0',\n '%c1': '\\xc1', '%C1': '\\xc1', '%c2': '\\xc2', '%C2': '\\xc2', '%c3': '\\xc3',\n '%C3': '\\xc3', '%c4': '\\xc4', '%C4': '\\xc4', '%c5': '\\xc5', '%C5': '\\xc5',\n '%c6': '\\xc6', '%C6': '\\xc6', '%c7': '\\xc7', '%C7': '\\xc7', '%c8': '\\xc8',\n '%C8': '\\xc8', '%c9': '\\xc9', '%C9': '\\xc9', '%ca': '\\xca', '%Ca': '\\xca',\n '%cA': '\\xca', '%CA': '\\xca', '%cb': '\\xcb', '%Cb': '\\xcb', '%cB': '\\xcb',\n '%CB': '\\xcb', '%cc': '\\xcc', '%Cc': '\\xcc', '%cC': '\\xcc', '%CC': '\\xcc',\n '%cd': '\\xcd', '%Cd': '\\xcd', '%cD': '\\xcd', '%CD': '\\xcd', '%ce': '\\xce',\n '%Ce': '\\xce', '%cE': '\\xce', '%CE': '\\xce', '%cf': '\\xcf', '%Cf': '\\xcf',\n '%cF': '\\xcf', '%CF': '\\xcf', '%d0': '\\xd0', '%D0': '\\xd0', '%d1': '\\xd1',\n '%D1': '\\xd1', '%d2': '\\xd2', '%D2': '\\xd2', '%d3': '\\xd3', '%D3': '\\xd3',\n '%d4': '\\xd4', '%D4': '\\xd4', '%d5': '\\xd5', '%D5': '\\xd5', '%d6': '\\xd6',\n '%D6': '\\xd6', '%d7': '\\xd7', '%D7': '\\xd7', '%d8': '\\xd8', '%D8': '\\xd8',\n '%d9': '\\xd9', '%D9': '\\xd9', '%da': '\\xda', '%Da': '\\xda', '%dA': '\\xda',\n '%DA': '\\xda', '%db': '\\xdb', '%Db': '\\xdb', '%dB': '\\xdb', '%DB': '\\xdb',\n '%dc': '\\xdc', '%Dc': '\\xdc', '%dC': '\\xdc', '%DC': '\\xdc', '%dd': '\\xdd',\n '%Dd': '\\xdd', '%dD': '\\xdd', '%DD': '\\xdd', '%de': '\\xde', '%De': '\\xde',\n '%dE': '\\xde', '%DE': '\\xde', '%df': '\\xdf', '%Df': '\\xdf', '%dF': '\\xdf',\n '%DF': '\\xdf', '%e0': '\\xe0', '%E0': '\\xe0', '%e1': '\\xe1', '%E1': '\\xe1',\n '%e2': '\\xe2', '%E2': '\\xe2', '%e3': '\\xe3', '%E3': '\\xe3', '%e4': '\\xe4',\n '%E4': '\\xe4', '%e5': '\\xe5', '%E5': '\\xe5', '%e6': '\\xe6', '%E6': '\\xe6',\n '%e7': '\\xe7', '%E7': '\\xe7', '%e8': '\\xe8', '%E8': '\\xe8', '%e9': '\\xe9',\n '%E9': '\\xe9', '%ea': '\\xea', '%Ea': '\\xea', '%eA': '\\xea', '%EA': '\\xea',\n '%eb': '\\xeb', '%Eb': '\\xeb', '%eB': '\\xeb', '%EB': '\\xeb', '%ec': '\\xec',\n '%Ec': '\\xec', '%eC': '\\xec', '%EC': '\\xec', '%ed': '\\xed', '%Ed': '\\xed',\n '%eD': '\\xed', '%ED': '\\xed', '%ee': '\\xee', '%Ee': '\\xee', '%eE': '\\xee',\n '%EE': '\\xee', '%ef': '\\xef', '%Ef': '\\xef', '%eF': '\\xef', '%EF': '\\xef',\n '%f0': '\\xf0', '%F0': '\\xf0', '%f1': '\\xf1', '%F1': '\\xf1', '%f2': '\\xf2',\n '%F2': '\\xf2', '%f3': '\\xf3', '%F3': '\\xf3', '%f4': '\\xf4', '%F4': '\\xf4',\n '%f5': '\\xf5', '%F5': '\\xf5', '%f6': '\\xf6', '%F6': '\\xf6', '%f7': '\\xf7',\n '%F7': '\\xf7', '%f8': '\\xf8', '%F8': '\\xf8', '%f9': '\\xf9', '%F9': '\\xf9',\n '%fa': '\\xfa', '%Fa': '\\xfa', '%fA': '\\xfa', '%FA': '\\xfa', '%fb': '\\xfb',\n '%Fb': '\\xfb', '%fB': '\\xfb', '%FB': '\\xfb', '%fc': '\\xfc', '%Fc': '\\xfc',\n '%fC': '\\xfc', '%FC': '\\xfc', '%fd': '\\xfd', '%Fd': '\\xfd', '%fD': '\\xfd',\n '%FD': '\\xfd', '%fe': '\\xfe', '%Fe': '\\xfe', '%fE': '\\xfe', '%FE': '\\xfe',\n '%ff': '\\xff', '%Ff': '\\xff', '%fF': '\\xff', '%FF': '\\xff'\n}\n\nfunction encodedReplacer (match) {\n return EncodedLookup[match]\n}\n\nconst STATE_KEY = 0\nconst STATE_VALUE = 1\nconst STATE_CHARSET = 2\nconst STATE_LANG = 3\n\nfunction parseParams (str) {\n const res = []\n let state = STATE_KEY\n let charset = ''\n let inquote = false\n let escaping = false\n let p = 0\n let tmp = ''\n const len = str.length\n\n for (var i = 0; i < len; ++i) { // eslint-disable-line no-var\n const char = str[i]\n if (char === '\\\\' && inquote) {\n if (escaping) { escaping = false } else {\n escaping = true\n continue\n }\n } else if (char === '\"') {\n if (!escaping) {\n if (inquote) {\n inquote = false\n state = STATE_KEY\n } else { inquote = true }\n continue\n } else { escaping = false }\n } else {\n if (escaping && inquote) { tmp += '\\\\' }\n escaping = false\n if ((state === STATE_CHARSET || state === STATE_LANG) && char === \"'\") {\n if (state === STATE_CHARSET) {\n state = STATE_LANG\n charset = tmp.substring(1)\n } else { state = STATE_VALUE }\n tmp = ''\n continue\n } else if (state === STATE_KEY &&\n (char === '*' || char === '=') &&\n res.length) {\n state = char === '*'\n ? STATE_CHARSET\n : STATE_VALUE\n res[p] = [tmp, undefined]\n tmp = ''\n continue\n } else if (!inquote && char === ';') {\n state = STATE_KEY\n if (charset) {\n if (tmp.length) {\n tmp = decodeText(tmp.replace(RE_ENCODED, encodedReplacer),\n 'binary',\n charset)\n }\n charset = ''\n } else if (tmp.length) {\n tmp = decodeText(tmp, 'binary', 'utf8')\n }\n if (res[p] === undefined) { res[p] = tmp } else { res[p][1] = tmp }\n tmp = ''\n ++p\n continue\n } else if (!inquote && (char === ' ' || char === '\\t')) { continue }\n }\n tmp += char\n }\n if (charset && tmp.length) {\n tmp = decodeText(tmp.replace(RE_ENCODED, encodedReplacer),\n 'binary',\n charset)\n } else if (tmp) {\n tmp = decodeText(tmp, 'binary', 'utf8')\n }\n\n if (res[p] === undefined) {\n if (tmp) { res[p] = tmp }\n } else { res[p][1] = tmp }\n\n return res\n}\n\nmodule.exports = parseParams\n","// The module cache\nvar __webpack_module_cache__ = {};\n\n// The require function\nfunction __webpack_require__(moduleId) {\n\t// Check if module is in cache\n\tvar cachedModule = __webpack_module_cache__[moduleId];\n\tif (cachedModule !== undefined) {\n\t\treturn cachedModule.exports;\n\t}\n\t// Create a new module (and put it into the cache)\n\tvar module = __webpack_module_cache__[moduleId] = {\n\t\t// no module.id needed\n\t\t// no module.loaded needed\n\t\texports: {}\n\t};\n\n\t// Execute the module function\n\tvar threw = true;\n\ttry {\n\t\t__webpack_modules__[moduleId].call(module.exports, module, module.exports, __webpack_require__);\n\t\tthrew = false;\n\t} finally {\n\t\tif(threw) delete __webpack_module_cache__[moduleId];\n\t}\n\n\t// Return the exports of the module\n\treturn module.exports;\n}\n\n","\nif (typeof __webpack_require__ !== 'undefined') __webpack_require__.ab = __dirname + \"/\";","import * as core from '@actions/core';\nimport * as github from '@actions/github';\nimport { run as runCoverage, CoverageFormat } from './covered';\n\nfunction assertCoverageFormat(coverageType: string): asserts coverageType is CoverageFormat {\n if (!['lcov', 'istanbul'].includes(coverageType)) {\n throw new Error(`Invalid coverage type: ${coverageType}`);\n }\n}\n\nasync function publishCheck(opts: { totals: { covered: number; total: number }; token: string }) {\n const sha = github.context.payload.pull_request?.head?.sha || github.context.sha;\n const octokit = github.getOctokit(opts.token);\n\n const description = opts.totals.total\n ? `${((opts.totals.covered / opts.totals.total) * 100).toFixed(\n 2\n )}% of changed statements covered by tests`\n : `No changes`;\n const output = {\n owner: github.context.repo.owner,\n repo: github.context.repo.repo,\n context: 'Change coverage',\n sha,\n state: 'success' as const,\n description\n };\n await octokit.rest.repos.createCommitStatus(output);\n}\n\nasync function run() {\n const file = core.getInput('coverage-file', { required: true });\n const coverageFormat = core.getInput('coverage-format', { required: false });\n\n assertCoverageFormat(coverageFormat);\n\n const result = await runCoverage({\n base: core.getInput('base-ref'),\n head: github.context.sha,\n coverage: file,\n coverageFormat\n });\n let covered = 0;\n let total = 0;\n covered += result.covered;\n total += result.total;\n for (const [file, lines] of Object.entries(result.uncoveredLines)) {\n for (const line of lines.subranges()) {\n const data = {\n file,\n startLine: line.low,\n endLine: line.high\n };\n // eslint-disable-next-line no-console\n console.log(data);\n core.warning('This change is not covered by tests', data);\n }\n }\n await publishCheck({\n token: core.getInput('github-token', { required: true }),\n totals: { covered, total }\n });\n}\nvoid run();\n"],"names":[],"sourceRoot":""} \ No newline at end of file diff --git a/dist/src/covered.d.ts b/dist/src/covered.d.ts index b1cac34..ac82c08 100644 --- a/dist/src/covered.d.ts +++ b/dist/src/covered.d.ts @@ -1,9 +1,10 @@ import * as Range from 'drange'; +export type CoverageFormat = 'lcov' | 'istanbul'; type Opts = { base: string; coverage: string; head: string; - coverageType: 'istanbul' | 'lcov'; + coverageFormat: CoverageFormat; }; export type Lines = Range; export type Path = string; diff --git a/src/covered.ts b/src/covered.ts index 22fdfb5..17b932a 100644 --- a/src/covered.ts +++ b/src/covered.ts @@ -5,11 +5,13 @@ import * as Range from 'drange'; import * as assert from 'assert'; import parseLCOV from 'parse-lcov'; +export type CoverageFormat = 'lcov' | 'istanbul'; + type Opts = { base: string; coverage: string; head: string; - coverageType: 'istanbul' | 'lcov'; + coverageFormat: CoverageFormat; }; export type Lines = Range; @@ -122,7 +124,7 @@ type Hits = Array<{ end: number; }>; async function coveredLines(opts: Opts): Promise> { - return opts.coverageType === 'lcov' ? lcovCoveredLines(opts) : istanbulCoveredLines(opts); + return opts.coverageFormat === 'lcov' ? lcovCoveredLines(opts) : istanbulCoveredLines(opts); } async function istanbulCoveredLines(opts: Opts): Promise> { @@ -172,7 +174,7 @@ async function uncoveredLines(opts: Opts): Promise { export async function run(opts: Opts): Promise { const file = opts.coverage; - if (opts.coverageType === 'istanbul') { + if (opts.coverageFormat === 'istanbul') { assert(/\.json$/.test(file), `input file '${file}' must be json coverage file`); } @@ -180,6 +182,6 @@ export async function run(opts: Opts): Promise { base: opts.base, head: opts.head, coverage: file, - coverageType: opts.coverageType + coverageFormat: opts.coverageFormat }); } diff --git a/src/index.ts b/src/index.ts index adf9643..eb6d487 100644 --- a/src/index.ts +++ b/src/index.ts @@ -1,8 +1,6 @@ import * as core from '@actions/core'; import * as github from '@actions/github'; -import * as coverage from './covered'; - -type CoverageFormat = 'lcov' | 'istanbul'; +import { run as runCoverage, CoverageFormat } from './covered'; function assertCoverageFormat(coverageType: string): asserts coverageType is CoverageFormat { if (!['lcov', 'istanbul'].includes(coverageType)) { @@ -36,11 +34,11 @@ async function run() { assertCoverageFormat(coverageFormat); - const result = await coverage.run({ + const result = await runCoverage({ base: core.getInput('base-ref'), head: github.context.sha, coverage: file, - coverageType: coverageFormat + coverageFormat }); let covered = 0; let total = 0; diff --git a/test.ts b/test.ts index 8389c70..53a3f48 100644 --- a/test.ts +++ b/test.ts @@ -1,12 +1,12 @@ import * as coverage from './src/covered'; -async function test(opts: { coverageFile: string; cwd: string; coverageType: string }) { +async function test(opts: { coverageFile: string; cwd: string; coverageFormat: string }) { process.chdir(opts.cwd); const result = await coverage.run({ base: 'origin/master', head: 'head', coverage: opts.coverageFile, - coverageType: opts.coverageType as any + coverageFormat: opts.coverageFormat as any }); // eslint-disable-next-line no-console console.log(`covered changes ${result.covered}/ total changes ${result.total}`); @@ -21,7 +21,7 @@ async function test(opts: { coverageFile: string; cwd: string; coverageType: str const opts = { coverageFile: process.argv[3], cwd: process.argv[2], - coverageType: process.argv[4] ?? 'istanbul' + coverageFormat: process.argv[4] ?? 'istanbul' }; // eslint-disable-next-line no-console console.log(opts); diff --git a/test/test.spec.ts b/test/test.spec.ts index 86cf35f..e9c5214 100644 --- a/test/test.spec.ts +++ b/test/test.spec.ts @@ -81,7 +81,7 @@ describe('coverage', () => { base: 'master', head: 'test-branch', coverage: process.cwd() + '/coverage/coverage-final.json', - coverageType: 'istanbul' + coverageFormat: 'istanbul' }); expect(result).toEqual({ covered: 15, @@ -102,7 +102,7 @@ describe('coverage', () => { base: 'master', head: 'test-branch', coverage: process.cwd() + '/coverage/lcov.info', - coverageType: 'lcov' + coverageFormat: 'lcov' }); expect(result).toEqual({ covered: 15, From 1305f394c1c1d4419956c6bbdb275e3a5094b64a Mon Sep 17 00:00:00 2001 From: Ville Lautanala Date: Tue, 12 Mar 2024 22:33:24 +0200 Subject: [PATCH 3/4] Update fixture to use npm --- fixture.tgz | Bin 4309117 -> 89283 bytes package.json | 4 ++-- 2 files changed, 2 insertions(+), 2 deletions(-) diff --git a/fixture.tgz b/fixture.tgz index 3622b4c200990dfbbc12193915e6cfcf75434130..c434fc314a3b717a53c850ac47998fa9c81cae5d 100644 GIT binary patch literal 89283 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 E00HpAcmMzZ literal 4309117 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℘|DeQ})enHup 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π#Zo0d9yRj$I=c(T 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

H8=N^Z# zWBZ5Wy55VueTD@;5C%Z=uU6g5kJ#25KN+VuSUcvlEt=Rl-+FrFSEI&~HWuD(O7*9D z24Ukg?T&<_GhsgqnTzjP?BACbcP^uOXgEAGNnPU#8f6Zc7_2T6CPT-E9^DI#Qhe0< zqYJ*O;%VJ>@r4ynGpIq;?+JJ%!uyPAf!js7COv_#Ez?4_7KmPw8uB8PX-*6EP$VI- zVxx9B@Ji)+hz1o`@ji%6r<6|y+SJr>#C;m*w%GNv(3=|KodBHXUsg}<=IFKt>r5w| zu)*5kNDTHaX{!A)eE$Nh);O4sHiVO9nAciias~7o?b!}&a+qPnD>w!07U_nQ7!bD_ zR`gj|pIQg3b~0ZK0E*w#F1CdIYjIk+$4~CYmgQ)(vc&+oSs&DnpW6kqq_B4<1{h?n z=??HR)z}7jSe3hcp_;tRIkz0)*o+?4k=M6%Yf^bV{Pu#cZ6odl0QqJTmz^1LkLUAk z#Jx@hbMiionda~Gee1;4g(lba*%yT?dmHt$6v~DlH&MSjBq(iRKTCb}Sz$l+16yFf z#Omx5_iKT5EX5t}M}u*=JYIo6NdoX!9PL!+Q=%34>#9jAX4T{DhT`87?2v*;sP#mR^8)mp~fxXpP~LO>@F4h?%Wm^*l%zOm!ubg`XK*M zAuImwHYjjZR}%=bS5x_v14oUDcnj~dzQsR84xI0h=?UydA(i~vSbKE{TtoTDmTSDY zRGZmSV>+&GZoV92eI-WP@Zz`xMf{RaCScsXQcrL{3-Me3p27eA^?$xt|J~CL|D#|0 z?@RuECjR%iqBYdMFn%`+tn1M{#dnc6cp(?8k(YDOQ$0WbYd`HvsmJWFerY59PFpgI z{&w{7yDi&u`%4b}2}erygK5gam}IB?lMOk6+It`lOf6svpTd6{0QdRK7qzH6fVQ6T zqXe@4kZWpBBgdU)rS|j`#ZvEHfit$Cu}$-htg-@UdlOR|+#8x^Ut#h-Hqq#sPm)Qy zVj6$3AK!yd5hRp$$1~ z2qz9{t@Dp8H2TsG?k?g@V5j=qoeQ7T&*R)DfOzlA@qx?sknjf!qV&Z8)O;sw8~|$a zyb-5iBqBZmhc82H)^(Bov0Cyxyh6Zl>hh{2#nbN! zsg3GM=t2S0UfQPBii*VH2DjC&9zZMTu8|~!H8FqU;M9_>4af6`kuru;@ zi=7#6D&)+il6T0Nr9~==AEd~c-^FWeP}@qGGhOj;kDO&uL|5d@@Cv;6l!{*2K+Zf< zu2kONChfKQ#^gGmPSGe|P%FyS-E>)zvt)fbLC)-Z3Ehcz?@l@-`Yk3mB)HO$UiR%pJ|2BOlNPNsYS(<(raNfUd^A- ziHa>`C)pK1i*-&r1kh4+$5c7nKCbww5>QMh=1FlgZ&W#W^jfh z&L8=Xb0p07I?_?}ZV@x31ZgL}K` zYs$~qpovc9rst-ge}hfG{)YW2n4OLGiQmvJrn3|%G7xqhYf4Pb>o*CwAT)3rxV`3g#;m#yAu{TV;go9fs zdA$`9cK9&ZY>aBh59<}NwLI-LusV;!Tz)p`053)^F0z(5rQ=hN&XloVg_hT+g@P}- zw_r1TE+yvw7SdXG-E|j^l{SitQkV`-CZu%!;HAg`4&yn z!N&rdJg{~D3O=uDZhsfgS2ZsjCRZ0j&VIHSsuA6=yoW!bsX-j#fxI>zeoo^{eGrqe z-3oB2{Y)mELky4;D+b8F9eL2Q?VaO(+8o%j8xMN^?bMt0?XK{VFjYw6kV$uC+3!=N zf`7d~#;WgVTlZlV%B0Y`VOM0V{NV3E5JgcHnAhmE`}8_w1LV7 zFib6vQ0@|Y2LoW(YRB8aktMs}-ZsQLE_jV2X?qaM6+EPvR!zD_TRYIC8_yH?(DxNk z;lo66>v2n|NZdq)53|j*Mv|;W8urXZ_%IN^;Ox#u2Mj^GvsN;ipxv3@a|onb^Hlqj z*{###)-@&Z>2aGWx-Iq2xpV5BGhN7a2Ov79!+8%K#t9wD6F_V}Isg!BlNSIGn=ByI zK8DU=9DcVx#7>qRezz1GigrxKb7bxiq_dRWmW)?UK}4HB;DFn{`i$wv+Of@<)6aW@ zal#c=UbPftcV(>au~)CV{&8P(6iBRSU;D6hxYgI}0jgQB ztqb;K!SaNo;LC%B~0U2+1J6l6!oSPoOM2SQw zAU0JVnzIYPhkjA$jm-Gt=(BG}A*EIyTFP}s_@P+j(IVX>=*#rf?;Z6pkAK+RlXS#k zK*u1YhKB`av7dn#cuZ#;SQ+Qf0}~6Gz`-|nh4xny6kFjNaFT_{{y`T({cTx*af-C~ zBKB-sb4E~{dl*ezqbbfkj3!o^B5zdgbot%vSY&sx(iFMx6sa7u!ho(qoO_jEZBgyc z7lp&*(r`p!N8F+;vKie;S)4neHL3KvQ5WSa()0zMm0ReG@*7V1N@C=dMp=wJ!U3La zLlgXhZDTDz5)RXLPvVu=*gg0Gs!Xv(c39bsJFv2sEMTP_E5;f>gPmPO?a-yN1uIRY zvH>fN<;ao?SjiDYkmyL+l)aNMFLyI4rVW5qN(z{cDTy~M_y{u>a|xeew$gw$h8^xq z4Vs)C>xrX&45FhCJr3yrDjVP2Aki_~>;R{(Oa}m_Kv}#)oIrf0OA}0Pw?<@iHpjS#N_OInxPX* z7#9YpFb(cyEIFz9cP=)H=3= zVHUioydHj9{bPy8w}Ue6fL8jyg(@2qf*P5U8U#D+@glhUtQOvObh#Av4I_^|`=%Bq z433Rtt}f6=vxa7f@POR}qKW-9GG`Fs-X1L4QKk*gLjH3Oc@;>d{UrN<{;;RGbMm-7 zIF$kpofH;mDgZJyMp0NU0)7FIlvG!o^8kJe9DGLE*`h-@r^Ml(@l}>bcf# zZRk}_UlrWWg> zoWe}}D1n(MTRTyv5NL@-k=Gcl(GV~+9kHcKj8@C-o#E=KLS1T*<#n)W<5b)4ID?st zbM|9SwR75<^T<1;D@3^VcIUpewbN5~n<~`kbdw4G$xAax@}9Z?V0$aRq=yjy3{e-mHzfi&uAl7>fgFZ50LTFdrx(K<`h7Qz`pSXT(gnVoB6 z44&S$bRiD*u0Rgorpjns+Nz9Zy?@*Ag>3O#ASamY@&?KABc$enRGy{>`PQ6#l^q|JXB2zw$+c3(u5QBK@@;EUl z%F+#DP&KBIPdyfsX;CI7a$_mE&!7Z7ga7=?zk4bE6H?mi|NqAS{F=Wb{AVB)buxC- zTg7|$Ajk>X&c{~tlBM22-52*!zK_~=ueiTMDzTY&qH~tw-ez< zX1+zgGDG}w${Yro&k-%+uhknx{$lnAxz;y@j~fB`9kI5%*EM@tB-US=Pxc?T)en+arxrP#hZ(_7f%;oOY|2X zEk3mQxKT z`AZ6yR9_)oQn_Sv$@Y@nCHqSbmmDuSUvjw=b18Hw{!;2onfAY0yE;J$!qNE3E%Zsp zIfi$)ZQnyQx?t~ihY3G>XZR8Ec#y%7L^EalTfB&P&{*hCjTzdnc&(4nD1yt)Pd~xf z5K%F{pKEMl(!({m?%QMM9T|okpR6qhBNB-s*FJmj$=b4z>lnXdWMhdLhhxDPD=-+x zPMe=BL!NW-OU4LZh~o-ZfckfqVGVVSoyue5X$1^b0|)vr0|(k--6T52#ylMck>2Y9 zPlAEj(jtHN4S>Oxkdt-Y+;nUCc1sy%LSiXlH5Sv2rJG5!i&`I3E2J=h!&yccH+@_X zT*xq}C3;;Sh#5!tZYWR->~2-9%C*I;wONs7`d|Y+G>;rL&}f~_RFbdGCK+avco|3I zOFIa+|3utp*_LdZt@YSE4!}5#6Z|_t!|Np88(8K2NvT4$Rf`QWi?2?XCJ&bTyRPk+q@f z>Eu#RT9?!s&2Y=L_R_OqZxT#^j*de*0I#ij#*99qrwR|(jgSrzI5gD94aXJszzErZ zr;4wKW)NQKg)e7JG7ovGoSrf3?ytF7+=y6LC(?diG7C+>a+pGKB1kUp&X|1LN)zzb zZ_k*PowJc9;A*e#&Y0tQddB2)xsnCKh;%p4nAYX(5wo^*q_-_sfFaJ+DWxRZ^dY5^ z;fNV(6R3I))lN%M`_R9aet?Y+vc0K3bZ7%)_H4UGqF?0^t7Mqb2Tz$Cv-yPSEw% zHVyPip!L%uM@e6|Wpy0pn@7po)A@u1V0w%^^e!Q9L09{k^WQ)J`xpCv)Wz%f{P#V7 zf9m)DHXGRdP2XCi@Yk~dx&vtW#IGW$(ta=8<$jY@ayM7Q{FZr zO5@fCOmEV>BZgt59Dxxa*9ba$AbE9<;6z%vF#-aiz{z;Zi=9S3&IRc2|DD#PX7tMl z*tklubu7Gqlxgw;$cLA^hAd7Y(Yk!c)UM0a?ZtO>hvBK?CL2PG^q48IHT|6jCg;G4 zp7>#owf4x+Wv%7a)#M^7$@Nf|SoGoJZXNB+>Eqhq@7DS-VVpjzy@)BGZ%k`a`2v(Y zU^&?s^zGpJb%W*P2snU=VZm~oBfxSfnMItU75%kp}loRS8+ZH42S?a(B-N~oePHhHr zH@0)n%p&vH6NG`%lv!L^g^sPw$3n-hR{b37@u?|`DAwbwqwBPRXYil@@z1Z-|Mhf$ z|HNPX=PUkxH2%{*G_-a4$DLNCVpq?soZ}8GsDHV5?#$ZOGyOt;iU_r{(^b}cujb+zDWmcB6;=f+wi^pw^hD?e-qNA11zXt(cLP4SQ0E~q{cR~ z0I$_s=RrE8PQ4g;oE${_`A$Sgjq1nXLTW1p6ZfBLIsc)TNxu~Exev%9aQ;;mfqy$i zjntM_3+#hN{j<6`Vj1UWV##sK8uhmYO&a&&cu)8q8ic&vswDHC5K?Ux(NDF*V<5NR zl<=mV@k+LWFD57xUm-uN`xjB)8@pHX?w!=N|^Sg!oG(c|Xd95mTADHEQBZ?2tcse4=2 zOE{cvt)q)Y%S{J%tt%{+6mZxCp?LLp)PvX485LuZ&C&WJ3vbeW?exZWUJtj8M{tLf z&@jK9g=^v|1WaCMgAua@p02uj*WudBhCRrDz-}^>8mjPWxs+yut6FbTWK8V?hr7i| z)ncbw96l0Utef~fn!Vg;IAX5iW;~beCbl`H@g($^FY9h6GA6I1orqjxPaZo2Mh4@= zP6hB6$)PMA!A19{eK?kwuy~}@cO1kZhT?$zBuOddObA8DGs})lv`}~-{jeCyyXj~h zit@4q?-}9A_8{}CI!buksPRtb(}1wdDv$!0nWLUz#mrK$Tg=SzAXs@%5=v}hX3dXh z$9u{y5@KdCSisBz(&vH_tKc zSS5u_MpqRdOj;o`+976iPJhZ2cJ!z5kW+P(a?F9^-z8WWxiK91YP1D|g<04A(?u91 zG3#*%qfniE{nIQcPn!Xpn-A?-oUq!o^je^d?eJU_g(6*(MTzg33@xOny7J}*8y?B; zde=x?$8cG)J?ffx+0^lqP5H9|gFS=){o{-AKT5m!Uljc>{`VDsKN|o0fym#p%&+z( zr+r==m|tBp<1JCfkl&7wKe?phj6HEDbEWMK+DFtC|EmX=Tlilu<$nCHZb04EeVu>H z*cx~$(ce7OQ=?{t%?U*xmoWpjk17`0>5$`!1E~wnwvbsy?tlqwHw73hC>L^KP+B~= z;@Ix4h6 zG~DEsso`E@mvN2-IiS!aKoi=2LW@G=K!5X?z)_WOu1Q#G!d4dD8q<^*GnPH9nQJ9x z%$6&g>omRVMk2zblM^Pe2{RZ}!7>FhWV0ifICn*z~dYS z#hFW1=}3yafvJ;xqyqgeO z7911D{VG?S3UJx1aSN5rH3f}lsB9fk3|HI|U3dLPl&(wD9yuoxnT_;~Jbi}C;yCdO zNJp`_El6j2JkbqE=VN)>Iw!Iw@+yFnoL@k?;lDU4>GsZvh6Be^juPv-Bjr=VYgMVtfy7NSv#CqDPd@l#b4xX&I9Vc7^GjN$H5# z#*%Y~I9;^CzfDRTKU2}VaaCoE$zZUo_Hs~r>a;qcwAHz_x$2A0qHpSw&!TlKceh5% zvRB}`+I=6E!x6im^UXU8Za+?Li*-?I&_J6sCS_m!S-z9&CHR z$=6Fm$ch%$5DM&YFU-)n1~7oYq8%fwkt=S(dd>v*>m2&Ypu5`5$KZi`;JaQ<#8Gt! z;`Pz|ptqZv-QL3V(#rc`i#W2gmDbXSuBu2!_qGAm3u6TPqqCX^K3w^F1QCEZv9mT! z4DhYbUIM;x0c}>Yg!dc+QiX4x%YWC;XT2o?SM;#1-@XSq`G#?;6@# z{p+B%X+1yQLG)vW8(;P(k`46Z^7gfZ&!E@tRI(_NgBv2rBAX{L;mAp7? zk5fcVv!D2f#;IU8aw_9~Sp8t!M<+_s)Tk<1qd0ufKXg<9HxR>1)Mqo%wb*>lo<-Nj zJhUe5`!c%;2*mp-!Fp`6BgT@&W)Ntr2%rWa+n7j&KxIk+E?jIo);A?kx!6NNDa_XP zLeIi%b)GF(V7Bfkc*AGZ1r9g00oY;!fUW%h?7c~kE<11~w)d|{XkA_4JiseSmIT{U z!$1#iX(#ly0WaKJ|96v&2=b7b`AwBox8A+=J-qjdIgv>+IGj9jf@C-r&ruR%LVzt~ zw*%P9lV%oNRTU0lum06u1w2Ptkc~><6#Mi7z*ZW@F92K2HqM@-riQ&rYfSo31{l3G zVob>aQkruh;$(HjugGdQB8K-PA5F+E}%6Em6u3>v6On{eTOjz5^!RqKO-@}T`v=79HX~JdDU@fT3MckMt$x>jx}m*fMcrTm-MCo2 z5}JL&7w)QYX5fQV9EJvLL};KH*WP%0BH#leCK4vFi-=J>Yd~1arJ*ZTpDp-c*;2Vg zyT?+By1yu!Jz(brN1{{T3m}xX`)kZ_9|j27*sz;?JD9MW)15i(y~-I6Mml%k&r_45 z>Uu;?j;6f?cRk9vdkigX&tEuqbnIzQ*z?(2>)hZfp1o-t5`-|SD6@A3wpt90OPP06 z5(h1-VK}>q4fa{&1R>;h-1F}!&rT2v9J8L1K6^8;L6svygIYAo02=Ja=p}sP7xmzC zDO(6WXH{|lDz&0afdQH>+EY9{SN$u`y=C=|hvz3Ap5!TPyckrP!9suugUxz{33XF? zoMA#w5eg@m&}o(4W*%P3MC+bmLXsmDn6S#g158-zdW8v%NoIx#tMZ}Jv$L#eaTCJ= z6B>b|(OH&bwRLA%*W0rO320k6q2bw}usw@KWsfwx*jVh3g$ZyEgM`Yc;UU{FLVyS< zLR+4KGdJ!fpD+F^26I$)UwLY?BgfEE6xfZi& z_KvMKmXBF?HimQ7oefa~R;Yb&KTzRs_Im~Y`#=8S+V~IN?(jbo{SW^46~Et-|5r!6 zDuD7k?2fKL{=RH~Bo+T!ROyncs1kL~cFUyh5NCp7j2mOf0wX0_FZ$273VENEiP!o+FQD4u95>O`oyUlZo;=}Dl-}6p&~mh`HpvfYoH9Iw z#@U)YUKcO{MkECjT&?9U1|_CLIR=b|lD!hEGS$D{39eRlB-v*OC|P#tMr=#U_FcfW zZ)h%`0jmLDwOPpLnFjTkQ`30;QxTgFbMSNq*){6zU+Tnq*d^snFND%|AR5{4s}rPH zH)Hh#At-#b2vZmi&fsbcdmDUX6kS8GizAvQH7bE|vZtQ*j1RmeEDE#6uOEbF3C+R#A3^x&@3Ay|h-ri-pj!(>-6^b=50w z1tPRf!X=@}9mAyURQJBLBU(bFbv>9*zj|`ND%+ACAwiqA{Lk2V#!k^fOwO{=8PJao z)(Z4fY{$|^=W1f1>?l~_%tNUJ`q50j`hk871nllzugL?qXS#TU>w9+$<^ENw3W=HZ^6Z6T&G=&LpAV8*b^kxBb zRPp|Q(moLPEOGS@hQb*yMLr^GADjOadpa~FqOi6vMD4)b7J#? zeTe&HYhPQ%$BYIC-v!wz9dLxx1W3nfay1rrNyp?ng-`7KC)4mThIFcIuzTyOVgW{4DJvL*Fplx&51>1}g8%%}-(Bnf zSB9e<|HuFEf4<~*8U9lZrj77FD3B8m0DapDP<#8l6JQgy)F0dcbK$PRhO7$WIKa>C zZb-umiT*b5w}roN?1||DD0ISFkS#&0Ns%RK{V+pb8S-LoghS6GIuYP+$b0oe05=3G zLl-LHlz|L*VV!c)63D(1X|3uD>+cUheWKxUeXgE_iz8v3xGS&Zqwa*QUt9=3Rd#yw z-#8>8H3I`fltTf!hiHV6MNiIzRN4rZ6v2{?MZ-M$5P}O~vyO;)MW|}=AZ$S`6TX15|>b>z7?o z7^4RycvCiLu~Ys^8W8WwArFZ$otePY@UEOxmmW%GJER;?ooGb-ZXSfcc6OBc@ar51 zjTm50yf7c0+uP^EUs7(e6&so)wm1>CE_QYJP383iy8UemTpS69A0ZE1>vG_b0VNlB zeA}nVP={0e6O+6AeK5mwf^i{^#fW2)5T&$sK$LQ^Aq@{AXOcg+*U`|xW3L*{hGkUI zBmQYC%&R;pph-!pbEW*mm7x{Kk z?1%9;K-^-qD|1S&L)^`qp!|xv8CqQ0xdfd>WzEjxP!slwz+3RquO5e`>~0k%bIz(& zT`no|dGy_RafIiLjVLynHNR&<>AK2Ss6Y}Z|NC?0{~31EEt?0aR8}|6V^{mvIsxt$ z?4WRFxA^~M&BwmtA5?s`5@-1oCdTi zZF9BwGap2!^vi%;UwgsdGdP!<_UcREoOZrSwcP>doKw+G;9NzJGa__3W`|(_v^C-P zN9aEH_X_^^e_rbUR}}&e^#6bKzrN)6$ML`3Rb%}AQu(j4cFVs){;R(DUCfWKdx#Wv z`oa6zjZVw*nClW(MgQFbzwPrUdJ7$zfja}VmR9oqLEM2qlMYb?{2Q0w57@2_UR__f z-}c91cdrn}Y8yPk7c-B9beB{taY)H%no_9c#sf+LGNGdp8vmCG~F%k=ZL!l$& z6d|X@&W!6DYTdpFC&(_Lod~L)+sYVnN|2L83Unh-pw>Ab7^7GcSWO0_kqtPRD7<5r z{~w_@`69~N=oWY{;+X^m5u0siI@(Sj!$&mTJj~W6J7_G)I$?XZ^|%3Oj%ucRA=04m z1^682WgL{kK${q76T_HgsQfyE^gxF883JjVEo}c(E35&?PoUSz zjTA!oy)(JlwSfYKhUa)+y}$@P492>fp+IqF6>D9`1Nr+U98pa2!8vv@^Y-^V+qxbs zTWb#hd~2VpLB(4AlRg<)9azP|Oebd+zsg6Vg5rpGlU4|W+YVD4L)zn9yLG_g(dA&3 z!3nB@tV!O!mAzJ0j}r76=}sO$L5HKB<#c=CJ$!)I|l~cyH$EUgM*c^X7vsnRFp#}1649a2stSTp(AX1L@t=zdMWp=OqQtjSeeZD?Cq<{WXgv{natb(1-0?& zYL*_&tj9oLwVnWIU`wx%ppPwF>#9*!Z#*RJ>0r-Dd&c?@IwWZPd-PiWV1iHlUcvwV z>pxxV|7mU5>;M1we}2jDkHi0dG4xk`<8Ma({0{zZ>ICphH(XpU@B)>}`KbPv2B)>L z<_?OY0MfTK-vz*xxbFP$@xI&~)(t(i+=b>KUFr&>c(3#?LFw94AEEqMxc(N;m0tZh z<7iF`?$AW~@byh;bYho)|7UQiM%EJ>rM(_HiqC)wT1l z;?&uVfn7V58gVqa&wdLHFS78*Y`Q0&oA9o4>Xa!D*BCt21;wAVh?}F?#q)K1>2OZ# zMPMr52c0<&K_zQZ=iVyjFtw!7x=M4M^(uu#t`{Y~)m0bnM?|KADTe^*K`Fsz9Mi02cKmgt+v2M0V=T{<`A^%WpB(IExMyi2WdX&;?`bm%^a^MUqYaj?Z=k+9BZ?*Ohp+(v_qW(R? zB(v5S^S1ZhtN@W22$4-rTR@1sMma8RU5;)xC3em#t z`KXqrMM$_W!By54;aq~NoQ&wZsZB6HD9|InSMZ;|y%_%q2m0?J{@_1f@%zDlzU@-~ zBGQ*_QoonrKlH5EHUVZ5)+KJ1l$b~yt{p?Wsh`uTq{lIdqnV4iaCV@G%?K@0 z=nP~B3ux5k;rWSz9JOvPL@l}sYe@|4*v_Qjo%i4Yer4Sgji(rcW#MVtGrK~NF%<#658f7 zA5_-p5LLS>rn6~v9~Oe2Z~{BAsT+KCj+?Aw5C`c}e=1%pC5H7}y}&_Btett$7t&e^ z7ugl9CT~d2)6B^pc#-6o+z_a;2uQ6?b38H%AVrfy54*_Rp&oW|@|jZ==XlW((pS&6 zGj@}*`IOz%p{cSvqt(;IYtj^1Q#A2y19xV<_{OPRgvNY&TZm1384{aZG$y{S#HLnO zAU1K*a?7o}rc$M8r#5CAu?lHTDMW6n0aaNO-3lm{jjDq7^Ue=I(boWes<)qRks>od zRVL{eXRR^!kaGOH)w$xgtJYYVDo?e>RBRzOf!GxMfUT6b6ntS$`tBHsu$A$?-OI35 z&N_qZqb>Dxf#g^jp;S5nugWVKUo*Lu(qvxpZS?6q*M_~XA72S!r{I;d5#1V9ROOLh z1zx>^|NP(ocrE^;P2BT;%n$za6~7<+=X6nCH*xiw(f2`tq(p%i9H~0`{~9ikwqBox z3%`O3WQ{Z8_*aD@w1`~Grq!4_;h%pit?_Hyr{$xiYhSeTdoant8Jhi=i|=CWT>Kv> z=)_FElY#tNg4_e!xfK&7dwyUeM;CsS8Alc|n*ewIvJUg?z2d5bdq_6Bedqr!Sj_L( zlmGhMo(@IQ)FfT_JMekPfIclI--kIoi#e8Uf=+30RLg$)n$UZ13vDL`FY@+WN!K%X zs5i*Y-D~T@07`sd9E4aQ$;K5a@pjiB4G`IfQ)$Yi9;U1{|Vwuz7|< zW*}t2K&lkZih-C+aS;!hI+B5vVhrG;lACf23-DoGUSj6yrb-be#_*cpGd#amEUkBg7Fe|q2Ei(JV3m0CWU;4U07vInquEoXRRON&0pvD3jXsCm-2tg z1ZQ{g|4jJ7f4=1Rga3TZcAz<8i;hJVt1!m`Q2n}3WCXPg&NmHm#S^?Bx*pcna_oE? z(LC70ov*p{jKdF`vCiqoVei{r%ZE+V1!u;WO*)pLFd+LHWMMv1+;l1oa(&q&d)YJB z#dOZ-6+>UQ{)(`X6#lM_$%SZX{n$Nw>laR_D^<6{r_VA{z9~Q)YfRJS5ffmO&5i%2 z2z?apxs66qvF-pj4EOY z_7+}0+D6czYWIjzJe|Q;-5Yzqhccz1P`uy_$WYN$*lrnn$bKZKACD`MK4Sqg7C?mJ z>1ko)nIV53ALwN==HDq!Ndd)4Mg;bn6aBdAY~y;^hq5(OEcD_>Rzrx2hKk<;T5~a7o zFefoeO58I_J`*vKFw+cn@U<{sHtv*1pqIJf7Sd*6wd-$)9FSj_$yEVvI zeX#kfDW#{BnNox+nUqIdV;gMfi2X$*E6PoXfYHs>en&luy2?xPQ9cd4P%;(?92%EF zKZ^CBCIKl71lUV13Q{B)H58;8bLWH68g=FSOak-m$Rsdd#Y9h~qjDO`^2%nr#BZ$9 zq@;K#n4%4kDWGGDs2$~-i0#a=O70+{ zqhm+SL9+5b8vQnttaQ$KRRXg{X+VBmkT{#32*lBMf57tioTD9BW3h^a;!(z?YN3y~ z18Td|j%vMmP^@}#CR!PX3Q|@#c9{^Zk`ewH70-Iqn0HjyQg{dcf$BZCre^)9k!n{V<;wY{*?5dt)=;f4I}BE9tQc~Jzi0lHwbU@rVwf@3cnIdc?_g9l zvga{`>8x@X_pw->`vc-W%I_8Y?_d7)TKv!GAN{9a_50)SzvdilA3y=$YXD>YiPQio z$;(`@cK7v!7kTj~@W14q;DX8XZz6xL2fo@Ne=W0Pe9l7#-xl+e0{#lSsuO)(X@3Y~?^ZdXdM4L}*DX|!vYwH4niz5?&j87zSe1*LW%?3;}sG@p_a^uHl`PCSRpb|GsF0x4q#cCYUO z@JZ=jjoM1hFJNDLwL=0m+v>xRA2q|LaqGIZO^_e;3WoezV}CocU7rx|%$3D{8&53b zl=dy?cRb>JTl(FYxy_U!kGB9YTgYR+zXoOFl?QdeVD;eRH7orXAFscPo|7GGOAbOh zvN3cg#%KbN^LPlKu{It$eaB8f-P<`sK`IGq^C^3j_pU{mB-?ArZli8}QU>g;s{PE^ zTbYrT;EvAe$+NM!Yo-~3Ga7?C221qI34%-64hSwN`rJD~a3 z@k_zjeQ-y*w+DA@?>d4z61X>Ea3ScG?&qUXvnE$5bMmWvyYpe^=jdHxR-kJh5;k#< z@D+1QIt&P|3^I;%RePjFqbxvh$v>>$?wiNw9)ok|ZjMf;q07~;wH;qWbuLMc2#*#7 z-|DSypl{I`)A@nwJ?oq=kmsuCD#al<#N1R2?gc-`cZ$7v?(FEB%j*k-!E#G7=>fFO zxm_Sf-9mtL%q@oy17L2!h4`b_^-F%Q;D3MjZx`!-g`NJF)!_&K`-HK&bKuLWP36B&Q6I1_tWPp zCUkP}`#{CSMU#QwmrVW@HL_W6dUlH@#bw1g8@rBjZK2LmmNon9$9oD3`6`b@Y-Kx9{Q^|r*<} z0IgS)g)A99Am?=$r(P5UleNLjRqMyQXq9m&1!f5Z61t7k4jF4SqRuE%mx~70b)KwP+{o?9AP@h4J$^o{A9dLduAUVIlwCRuw2M$)+|Vw zi7Ku@nX(})Kv^(4?e)Ouaq{v4k!fw+f{-c4(J%oaGuCPIHnY@%$$C|-kCq_7(Rlhj zMn{i3#%{3_QKnl#9Vr0?T86#sf zQL)u9O2|WD&!EKPnj0np8sWk z{6D|s_dW5S-*&}aBW0v7M}9uzt92t0+gBIhCvcBx8od+TqncPq*Qs{k#MNrD3&OWE z5fcd$8Oq!pEjXp86t@#CC-?)f51eRc?=ZW!?C0ejwo>B*@B18l4LbZ0Y6H|Jq8Y>`wH;cK^|`j7#WRbjD*MzyJ`T%)-{9 zY%)|)7d3N8+@xX;b-zyBG)>HQ2+mi1!EVJ;^iJ2}vEX~)N%F?8(zV!1ZrzZ4>PYtc62EZLN)l+KmjS24P=P0`rcTcf`CS<{dHb zBV%SW+s&^%fh9;-0%2Cu8IK7pfxyG9x$oLG8|`=Ck5M6Shhsdg2RZ|*kbVr?phwYg zyBfejI~%O1dy5oKJhw<8eYC?x3bkBcr0}3cNC(QrrI@Z}sZq`jGlqV4+ZWXM=9~9Y z)JGQpS>uemFKC+8lBMoX(ywAu_4Ijy0TXA*WUq;xIZ7ISz>gg=zryo(y~ zwrcd=9iwhKR=D-Z7u40-uPEa11y%WX_XT|g|NG~^y%zto-tG0@e)wNs^83O6uEYQ8 zib3haUD1yJ73wtcBnnt=%T50OIV@0$br%s7J(m~aLaI~ejzj;?cKz)*Uh35Uvz?M} z*OaiBkR3o1O!rW4_%*v9!~FXCo8lX(DW&1Def@0|Xu&0#`-Lm!4DeLszCQ>myzL80 z)p}rW;+r;WzENvE!5$+6dm1Wi*(_e5t)w@-K*_$a7Y6L<9gR@p5xV1+wc-Y}@`&9p zV&9LLYs6e5_Wg*tMtr};dUIDsZ;?^cKp@Bph2o$F=s+Lp#s8DeU`H4KPp1axU@ZcQ zbk9ykN**nMqE|!Qjmnm>LkOTqmw9+}2Ncyn6!`(@0V#+g5f2XiKRt05lq~n##)bsm zytdusZFLNBlfWAd4p{Tw2T`Q9{ix0x8S!6&t#)pi4}3G5?C{kuXWgJ4q^|Yr@63?W zDFw44%lItRuFr`3X{VpUWyj(NnjZ?oFs%`$dgux4fk$=1Q@Vg?%ABkqsJ4z)5R||Y zWGq3(51j#RBK^*2?6DaTTlFnC`d|3Ny;I}Yj{!=q7o z=(%N%?f@7b-_bEVs;-XVvCAw6fH2ukPNpUEr%=4+m3JHrqL!{s22;$;cKsQO7YQmN zfVL{v&M01O3=OJoDwB8d1m<~V@`~mOjSCz~H8T>2rkf46;baq*msG^Kna=4EIifn0 zD!*WP)|r$SEH4}DXHmB@au`yOLoBbfn_Ib#F_32_w`OwAbeCcCo|E9Up?#%`5p~g2 z%*F$nXSKJdfioLW7bhUk1n2gCrP>&>zX6NJ6~yC91jO?y0g7i#i>ce0bIEe_Pe$>K z0bx2Wv!Hl7P>2nN@k-V@UE*EZ_<3glUewlp48SWr-_vKHe#rSI5u%P`U%q`)2b?4Gr zQn6Y}?5wsM7Up?q!TDJWme; zI@oLi3&!&=h%+oWhN#CK3yzi!Z>xmF*>YhFEo}IQ3k4n`aCIlNyr3J&iWUma`{BNR zRgea9HidS_%D)KC>-m^DIYI>}5RRicW?*_$Ju@$lDyau`br{sO>;ySv17Ui)!EOW7 zYyI#=k5?1dNDb}Cgz5Pvq6OZsWz<;I;^;2n=VgKM4hed$(dQ;mPgAd$DS9nJ!9vlq zc?|{YlR1!yvldW2e!8G~F1oy+dYS_m%nUuxkzxl!FX_Y-Nnq$X%K$8dYDnG#Mq9ms zwX|m`X--y4d&VlduO^*1n~o1FT!ZAy4%;&mw&${sb|UGS!P0ZeML_uMK6-<8 zIygZ1qDtT!tF88+AE&c1pdVNAf}q2t9?8wNA$;aNMcZ1VA$;~dC6`_%>Xn`!7rZ(V zb?*@8Q{Lp4BR3oq^=PMag7CdJIj>tdU+FHs7U^Et*<5U4f%)js-96Tas9neTO5e6R z|KNO2{$7gza5erH)SmzM6aV2$et#VP_p6b=VBK-dhdN{Vc!)~WkC=7#c^aFrI-0YM zO?%?aC=l(6#}Pp)erGy(h)qWcjS0-7d+_+-q{xXw)R0cWa$k-u-o#oD@(^DDOaFe% zV`AnA(lM;D+|d;en}LY&AgLl`Ghlru3{^*htj1Ozz(nD2-XU@Ym-v{ zPdE~%x>~;(1(po%kR#YKdlEJ51}BTx+C>7kd*|x51opp>Am4!fFQR=#w67jzvR#HH zU}RCZP->!1=YS$eS78AnHir-eQ{5^g?Eh@wH0X%qaeXqIG@tO$1Pm|o!zfR05`>#{ zgV95kmNCnW7AJnk?af3jk`fN@fp->`AdM6eN+$AkbieqYBe+P{iP1Y_z%eiDAmE~@ z(nwms#ZZGb8Zdf!CRYA;VhPsre3&KZPXk1dsL$izB3=JgjKS7N_9puvVXzzJM+k#` z8lADiY3e+hG{tnzW=?q_vMuMEL>t>yXyF0B*6+9Xedx^n*lvMwk2`p>cDTQ480!TZ zEA~*~9gvU>m?z-@4}!w1T*KcH75MG?1Tkb@g9rQbXONIefMY*a`<+OxJP$n%6>%$$!H)* z7!6{CgZP&?*f$dYoM)Xjy2Lwn*;U{;n%qkK(?O-QV1&l2Y~E(-pN}mb@ep z2mkvB{#RuZ>U8{xo=jIoeyCp&Z^wMCS3JT0Yth<2%KvMb-ckglD;7yWIyQg4r(>rp z^Mf@xg_{>PP);M>TUmtX;mKQ;VF}#&j2l8>KPcVvHuHeBNOL~!w_6%aUurpG*~eRZ zvXy&V`+gyVT&@ZGVb7m7`{fHIc?zxwa(0FS^%XlJ~8il+p&!A zvbVN=88Zl61RRadcqm)OcF6dS0;IL--M4|_>DKEREmJRP*AhT-DH zpb#_y?_n=K-eE6VVf4_dIb?vncns`VQ%);hLIZh6y(HDjZ_EC=6ROmEOiF``VSDda z333(XI7hw8KFz$Hy1SPBoA0n!{qmVs*h^&_2kcct46Lx1QiO~x>UCxpLe;*_ytv4a z%N!QMbBF`!7u`Kln+5G6x6~;rL`u#18qqEvnPLfOm)3z*1p)2SIRn8lGDD9EaZYLG zJC^n-i+Fe-i+Cd-HN#wznQR^xS6z>yji{3@;tj)zuB>S-FPpk~#533#84;*r5FHWFArF!b-6O=gRyI-NYIcIPCSqK^ zeivn2z(kJ$BHR5LvdP&0g=N$52}TF#0m8CTL;jlY_i!ShX-0e&TgD)~4`~btl=>S}EqZn&NAAsG2DjJ9J`-X|~2< z^G<9sHnS`?X~Zl;Gf1+=lBp`WcEBQ_y@*6SG%x*q(7N29LZKS54(oEew{BGzZhN3C z!_W&aZsvE7_g~*-8JG-=O@W7}IyT)HmCSBnO6$PH+x4w(&g*{yuKRRN*2Ukvm7kp2 zs46vdZ4IWSq3+qQjXJZ&y60UxMTYC5^!CIwsfFkHY%)NcDW9CrNQk?O$=d+?bDrJI zn58;V)%)(XRyAt0X*1ZE25cSrQ!yRQLw~N7?f(WzD;kF4<^O3gDd}* zK2rW)cA{I^ftI$_TWd1db@MxoP>d19rd$Z!t#KzV{wdQ)Qea@xf{9E!%NooWv$dv^u4Qb?0rP zsF#nOw~1zUO4GG1cOe<*kh8ROAOXn?o54WUPi=HFI_pl3G-Jms23g5 zY@MJdhqSEhxkFkmJNHMo=CZ;g78G?F7h9}}I$E@`qPFFs8(I~pKi!b~{GPS3c~XtH zHl-8Q_-Ji7-j?gyOs4P3Yfp|@+rJ9e=MLQGLz7A4NcRR!zm{cc%XT`Y*G8?sxtFtd$HeEFXt!QlH_xu|Kt{hXgT(2 zAF-u9ANS;YYmo4z2#SMM7lY_6ei^{SQ8TPF;sYMHa@!gcxr2P zb<+upu1HX0=jJGvA5tE97CW2f_Bv1X)VXQ)EAZ(ad#1-X@RK3&cgIx4StdS;u}*jN zm&fZb;-g68JrW3opgDZ=gf^0}cBctaCk-(ZngI1c3cqn&F7{N4FpE8rLE^x7J|*=l z1cYqx`6B{PPCvFnpt0i6cdLzICo)gn?elDf5D_q&haDDX$3d?LUra`Zow}3sz6;1* zq4Lz>GtRU<=R##CT5QO1J0Ev*(nJ4Pu`{kb!ASZYem*O(DFnBB4L4g5Giw*bOoe!h ztbbO4usS2ESrvwhg|6GjGV>4At39)@i5X6m?!nM>d26@iLumUULGO1*1Ca$W#s!l8#ce z0GX-S3bBYdrP)KvHJLAf%v5TjCKvvSDb<&ko(rg@M6pzuv>i2@U@{82*HMJEhtLEx+N6eysPgTu- zjB6Fd{c^LUG`Uj&3>ETEBN2vU&{Zf@TuPGzpEeo z?<;@>uZP{N9QM)u&jq#%yuk!#)=jv7D`|hWz1BFDlM2? z!V|p7Q$SOp7w!?`0_+pGtp`nIQiDwn1)w-S(2r}G#R@+R5=o~Vw(`>w@@!qF;NeZv zujPf@~$df7ZZl(o27mcS@jbg-< z@R$h0V1$0w?B&3q$#k-UTzV+T`Yd6>wEH{z%yz4$zdc?=xx30>=@L(LCgFoKT-MCG zthW=pwH%nWG1?8!G#_#kk8P-9wfSJeuxl9|eq7UrNp_?CGA*Yz$zdmb5)Yj0?gdnk z4d}7iu$xe9u}JsRVNYNuu0~XL#h&m$CW17s&eh;x&F=w8Cz{Y^SdfnGhMQZk;M4wW zeXicE0*>bYXs9lIhZBkrOM21Y!>&-g)#5H@p zF;w53?t%vxk#n1vcOm+;z=)>IRIAn#d8tjlZ%OZPU~57E!7iVC?2T#Plhr-KW2v|7 z!)QxWWAzOXv7(#)5x=(;GVDE;2mTo`EK8Bu#T{Znp0Nidhf<~7hYF$GNA>*7z0fc-E)EnRs0rJ^EPVzgC0KpdjW8lrGDQ0(hFGAYk4yqM&;=7`iI2ffrytwH4sxn9 zms(;ELG)9%fC#$c7BJYl$MajE_TYr&eO^1NWu363;=$H5RF~~QyI|oC(lM-!j5WS! z!MA40m|w=X87?;DYOkjhuRBa0+W{AK772{Hl3@26*^K?^AfVLi^~ij;o?F1*Z9D9V znL$X$PC>wKQ9|0PJ?hjN`vq7VUC*tZ$&iR>O%Z#2#BnC#`w37;XYefrC?xw9Kh-3f zRsEg}mx(>MGXikX8GPY{nRaiumIz?KZ04LuP=dXgcY{Qu%Q!?GnLIy$cgT&5Au?7Z zV-hiuFp(kAsY0A$93X>?Roz5D5C|2lkclhEXf$AjGGJgY`)ZzY+ij^<>Kko5yZ%+uyxij zlQ6rQE}7ov#EY@T9E^EMCF?PQ;TU)B5e!X!J0Td-d+!N`yF~*%V)WWwNsqhWygzUq~$Cv1k9Cgsm*ZMg*jgrq23B@CG z!UG#yY$6plz-K}Qo1XTB3O35w939e!feMz^I*$&iyf!Nys3;7;%qnz#j|Xa2gCBUH zPF|%Q9_Xj&kS50o4s@&Vd&x`N1rF3@*76G+sH4xT7?#S;tOH@0v)6NGwd6g!%`u(5R{xhQ7GTRJeU578(4lL5 z_!%v%P=y<4q0uIQ7p~ULuT0*=X%giZ)ps33SIAQDxwPh~LY8WRGIzD#n~dH>HEbUu z&zx~%s+wF^QVn@ZeOmQBn)eWl_A|Xum7Z{j5C)qo9C+lATROS(ZZHeW*i`!HkNErX z?-l&-pa1n@|KF-Ovf_U~`d?r2`{Ve3b#AQ;@Jm(T>5(@PhjztbL`XjMZ9IQp*>~uN z9G=dQJl(aZ&OYY1D-gXKxLs2{!Dd)i;B;(Rfd~A4&ne8RufTg4x4N#;e)s@abrw*c zmfQYHsGXGhNqg!RWHIp^s@_dzZ(H1?Pk?!6rgf=NNk3VrwJq+I_mS>kgh*l!bvcgQ)K7OiWt!YU~>K=b$r+;+qI1{_Yu9-r{6eqg?9TFM~#W`W5^ z#Cr!DnN(>;3~;B;l_&Rj-@?F@T9(^;d@li89BQD^lT@&ad^ zE`*p)qBGY1SRIJ(isrRQwo_mC`36oGQob0cqlxKxoGz*6qi*hU_-cHMe5Pb?gSEON zbfq_i7~Bs+_X~cn;D3MnkJsXV&Z(XLpZ~%CzU24K@V~mCXnUNGpn!GuuHWNsY5~#} z_x4Hs!b2CtcIp{kV7p$H`E^oW_D?O^%z_TKn{LIv<16-XhMfASJ0d;g77MUlalKNY zJo#quF1q3nH4NvdVXOU?hnDW<70YuTw25bG)0Q<2So~L7H#t5{)W=V%2{h1l|Qwu$}9m6hqYLfk! zK+X+P6tK=hR6V-P;~6m6egSsffVoDj!-#qB4Y?;U?}%?4arlW?f`}#P=%gLNE$JN@ zoz&ip;Ff%bGi~Ex!c2uCNcV_~e%%8m%rs%98DBf2y=JWPjIX^PCwd}4**ZqqKQi<) zLJUL z{TxkHqls!XQ3=aI=7uK9$fY&$*zLH#>AVUFj{=wh0ZbYPCIFL)^eBMY2P2v6k5(Sj zFe1YNldilSUpjQkxred72*9M=aIpSl`rv5$cO1vTvDmNFGoC9tVoByIkfk;uKpai0 zQ}a~qp2ZcW_^2@9f=@Q3h+|2@fl2C2X!C?g`j`Qe^gi!+gU;CtPBTN~IgM6D{lEJ5yIH-MC)d;goF)o;7P&$MKlME(>8E)29_|JB)@bXqJrznl* z-Xo#1t?lA_irGR4kMcGnf~Kx`RG1=YR_dOcAxUj?nB@p#LpcSKw5o}RGB41(I5Y_x z<1ns}WHtd1Nv{GTl9r;Q2qI~$!pNFbl+GOV0hxoQ*jgNjq_?rgyL>f($BISTSSj8o zSY#=d{U8=O)-Ypekq>*%Ba*?tr=VTDi%9B9Og#(YQKOEf5yhi4o%VkMAo&XZ_n-dh zTKun!YkU1a`-A^|#qXQpf4}?2TdQh$#z{mFk2E4q;qyDH=k0Lfv!weXuwGgAbQ;n3fc3r-&}%*7 z7K&ab_xy3c`qml?WY><}k?_-}$a%BHQ+tz}AJNz(1HnBaZ9sSD+<$7u#1kk4c|GZZ<|kjXfC6Jtrx%2I%ktORN^@2MAHG z?rSFaq%>cDw>>&`=t}!EnNJKH=4ducGo_d`WhvY(@r$&h=s%AEV10Pv+>UJALZeB1 z+e9%%$C(Smba)JO%ZrmvA5&BcPDbq!7~{cl2FBXxIe@XCAXtZ{Knxui3rP2BMY$wm zM{EE%#<=xWDG=#6-t!}Bhc-Iy$$R8BE%ZKi=>(X}XvS)gx~I+Fy|xu*mfH(7 zeawMwqXU$TUaGs-x?PxC&CJp%%x&~)^{!1hDzl(uCOHmB403xp8DQ=uMeI11+Y6DE zAX}JQ{hqC!B<#ur7=XHGvr=j1?wRI3{G{;SjD-OVX2cm;alZu=toGA5P%ugMsJyxX zevE>ZdTwM#R@+NuDnId`y@!H9XRXjs2rixgU?#rjGJ?E}fK|l0dh*KmA42lS*ir|O z8msDg9L$vdRyvHmude5vN~^kFtk78J=anKlgX((KE&fk{!~VG6EBN2P|BwIqAO4^J z{x}AB8~-ck^cw%8*!hqC->jLL*) z2P#t*n8QVrDxOV^ibJSO*-V+Pkybz6bt5bWmpdxMXV?gh(`Fc<(TUdXtq|U(zID@0 zuSE-a!IU++iwgWSgC=(n=y=5_SA*0K+vK4&c2m4*hirsq^KRH7TcE4KPaRs8amBQu#qCBH99qKt(IuuW<}Il<%$Rwki5p`b zTSYeNe*&(fbxqdA^o)ZrqJdL}o@&y;8MYqk{0XP2j01q+lQe;#nP(hZ@-$B!O*&zY zT8xtpS#S?9&VATc_(nwylr+hJs^t| zGP@RP7%&$ZDHkBVs4I)cE(=yBZf#VTkt+M`>=lNmtPS{Tm;l`*zb53O1%#iFizZ7o zAs0a{!2;+xf?Wi)ixof*5$vK2o@USS32LVe7J^DEc;TE{{SK2QKw`bWJf_DPO&N$j?T$qp%%3|QmIZ=-6z1T8Fjr3pUU}r! zOw{Tw#x{-Bfu%gCHtkc;hI-Fwi9LD@ZK!18E^vU&0BxwUyw?D2=&1f=&%>AEe_rbU zr(!H?jMe`y{`miW$?p%~|GX=T>U<#!NFKSWfTf!%U}uaV8*hCQmFIqQ5wH(_6g?sM z7+2Rd$1Z%WR=Rq3ke%tN21r8ZJ=-<<$AVl%2X1>N(&m&G5hiz$ZrONV!|&-u`)+o# zWBD{j#p4QJzNuk9Xgzl%zM6@Aj7s3KAKcXW>MnO@o;>u3gb94O085m>HvW)lNhcH* zj~yf)YMSHk@vT!QEP29`-~Bc(Pe10>krCq4Gd?{-`yJTcFiV4{Xj@PcL-0BWm-5~K zzgQW+6&9_jAB&^>*G9mlsq0h3y3!M3UDGVo6F|}_`vtG_YD*ziR|2N$*yc>Jgt#E{ z`K(z<%;dqTNiGlY_mQ8MO=$$!Bn!LT11{GPXy^e)mI7mx#&KCg`NjWDH-bpStAsa~ zkK=Qn)d~$2_oi*me$nh|hwia_&PNXzIC!i$9630}u2D7uH#a*X{9Wbv)@z;@1)t*b zCQZ4Q%?F3K8A%x!id09}%jbL0=5})V^|DH}xx~p$y9b=yk|jdcp)9^OEb)Z0`0Vk9 zQ8Mig_$rfwU4SnWoZhi^lna1+(aU$-t0zGe-y5|8UzP%Z%%b={>_qW3D}zmFrV1>V zM$lCR!7cS3Lr56%G!Y~vxR=v5Bkn~@q=~dckqk~?ujVMZ!d|R}d5C%yyUQK*dPDw> zN4(3cYys~wJRr@-O@pyv3M#ZWxTysQp*@~9vt(Qq?Uef zzGonO@3pn&*om#?vLakbV`xm5R2-o(Q!SVeXAsvb_|O0Tzg_G9RW@%s{3pa8{O2ov ze*pe-n+G3qT`GLJ7g(&`6<_WJW<$KSyp}7T@CCEz3)T`J<;J&~N%+LRwhXekl*^WV zDqY|(;V}^~5ix;pBOh{IfG|y3E0C9#bNsQ0^;udea*Y7r*Pc3Z7&s55{-eCZzRcfJ zn(qsQ;K__;|1UZ=<3x09R(v6Y!5$s4NAK;hpAj~E`|ganM(o!S^FFdt>bpt4iL2ok zMvoT1FiJSQ$76!`n8^+uYkpe72k_TGA5h5J4jvL+#(PD2K*rb3_}ZP9p@w%D-xHxY z!pmp{6?0A&@LwvAn6ss|xkxctD^b_Xy9>UXbEulQ0b(`EGqL`^i+|V$EmSJ`mk2U- zQ^sC?EY3tGhUPTeYI1d3Aae1oWuNyIBlG#>&mw*PJe(Ej6jADIb|VBMcmL1w80+2o zalf%K*gWnx_PEDbpQWGk8yn`Srj(vixH#ka+*k+ljlq+<%B3ps;62783iO9NGVnBX zJ);93;)F2;AY^f8>QECeY&r=_t5q{x>Z)^XxcrPe`GmL=53J9JX{?&=kKj)C5hv}4 zjXHUYISrJn8VzxWJ5`453Op$v!wz|}Ij_i5OzftI{$h09kb3tZt5o*Dg!Cfxl!DDG z^kh7@)_|UT*=VoOlVMiTOB4GMj`Tj*ZG#N`pS?4@lRILfYe6sIE1`E!ie&jVE|rt&p!7 zOTRlo;m~B{f`}coLv<|yMkG(@Ae}XDt85b;L#9gESVoXiBkRI0EL<--<1oQ+lr^B@ zOlSDRb&e3gkFBKWB_2N%zgzs?6y`@d!1i7MM-Ucok&w?vS-Xiu*Th*rcQykZf6fn zQ-@Y{K21$#b!zJ?6*DxC14lD-YL&`U zw28E9zn;m(MYzx8>Qluld@gGMYvU|C)@BVrZDcSD)E2@7wb61#pf;C5tx2lwS*UGx zdNi&@EI6Tf(b;3b?Y%mi#72k2Jy)t62?>Obj*uL0Z!x=s98f!nlh zAvHVP7WL%k7)GOGTroO^&kb01fuSgoA<-qPIv90qxtwtD z@}gWt3CufU-VyWWEi`p&@j+~j(nI%UR1$9q%rs%93`~*L@^0G3CUAvDm(b`kW=dwS zy&G2F%rE0`l`((ei_sa%-Fh;AkOmMi^uBR8tD4rXCoCQ!O`_ zoEyPAohIJNm4q=rB)nvpf^qI1eC3~kuX=7~P70>N16mgy&+M{>i=!nNUycA`@wnPG z#{;v;S|>Lt4nIZ8`epsD`uzjtyNs=1%jB|Xs^i)zo<*95ouNhAgolocR@ohr)tW7G;A7j4!Pl9dq2GTQ66)pJoNy&zeoO0r#$EJq3$ljCAEYK0=T zjR}A(la=kQXeuBVdRRXHp2`yj7Fi|SCcj12l6?TjvaZD*S!iSW7J}t8^2PK7V3j%v z$QN@O>0-9EcQ3TIP2P;@V$qXWAJfHBjNx^^#YUh+{L00UPw^|AQx)&N)Niq^w4TSW ze6bbhqQ8q@)edWo9qLOu=eDeC}6wd2`^B({&YhlS3K+ms*Q{KaDgvXw|IWG z$3Ni<(ys4I`((klQ_gWiK8Jk z7h0GUg~oCL(XyKdc7_Expkodb*ayz}Ez;E@=5&r9^egV62=d&7&lPcb(*MGuCwzFq zq6@e{Pm7pHn7~XkW-3mdt#JgIr^_rRa3mIx&bZ;DP2Gh-x@Lnt;-3Q-?Uqd^kg6z#)O5 zyw)gpk-R<-?W*Sx)$8NQ!QjFPTu2>I(E4?Z`sbA9#X!Fx!c2p~7K3O7l5aLjv4^`+RMVQ@WaV$#=Z3G+>PBPuAc6)xTHpzyEYG|1So$^Z!&o z_}`cOeiQt!en#Q5}V==g22Igtkwt5(qE2!78$$E;GpWM$<<` z#si%(f(Ow5AQItBjh##HsX&KHWECB%*!Pu%$!T2FPT0-Qt z2k^Ec<{HCh(L8T;xa_xlchy-DMS8@!H;df7=oNePYoi4Ex5(>sT#+5sh%}^p=)vyZ z^>A^~)(nA}anlc~_?m6jC0h^5A=SB{igfHAc+oBMK|HZEYG`q%_SPzo3i#XyEH}9p zhMP%wsVaMr>58>-ceYL3+q4C2ZV}AcblD84qv__9!=~E?1+rWkNy%_c*_}8sT<)_R z&N8{&5l6m^43~Q_*{V@3Zamv+%Y_gClYN&If47FryXEQ2hST;B0sJtANpk9dqg9Px z%bY-ZO~M4MYgLoku_(0wmh{f9t?n}pS6NtzLlcs!i7eYX+Z|T{U({#(n(C9qQ zAs%Njo`Crb=IwFBUvNq?-UG9yUKAWWC*a!!Z1I3ONXS~c2j4DYreyBccXJdEsSQ4WebxxWgw?JHsKj%mt6J-f z=$JYV_*2Im5dWm9cE&&ZF*hfv_od9iEorXhIb={At6tU!$eMrT9z&WC!m$)LkB|t?y)3TZ=b|=s92GyL6bew0wo0&tOugTa0mJ zLzbo8o()M)5wMgmn!r*yCSWPwAz*20VZn!p9#wm1MQV)ZptV;3mZ~xp*|*M$jNa@; z^xpoae`q?0UaDKD*Bx+Ln{^^c=4?-K(^6B<;ilE<+9DVJCbYaPw*wDWE(ZEMM19?~ zj~K0Z$@|*R&QVnt4WO!(O4^o&Y@Nw=fYs$XzSw&JYnk@E4{Maupes4L!>rl2CwE$9 zX=Rs>VAfagzkm6Mi}m03@gGX!2mkwu-*1BdeS7F{c>V@=kNHn49*mFu$kCRi83p?SUS1mx{4^Ae-E zXJc~Ro_Qp;a*O5HE&ywjL-6FC-M!a3aD(#~ATnqOeM@RW3vbU`C|j5H3A?WB+d~*T z(%d$#32It=a@+kGUMoYF&1gFrnqk4x1F&+MuyhxSYd7*&3ZH?S(*~2_fNx=!N~P^Q zKht4#Q$3u5c;fl`$OyQbJX7F@?}509t$qRnm(1wF8BH$#GH={wJzx&E=CPQyzh)vk zoWr;T$I=z;j7QTrps({~1X`DFJ6N)1Yy0JnxF_B90m|NZ+s9|^F<&=3KZT_ZnfdFq zJPezsXTpWbK5@**R!CbHa_(AYIA-dx$heMoNAvtU4BA7hEXVu?th=B_(9eE$RfhxA ziAP28tIf`XI-F5jzZi(2kt81p0P3BaF(qZ9(Z{Si8Kx)J9n&${;WSu=j(~O7E|_D1 zy5trxsXk}r+_?~4dRsYn(U~{k+_~%rn529Yt(eu}N}J4JQi~%HX40K`Pc>Y^0w!6l zgI`+E$G~LDhD%v3!83fNshgCumnN)l9b*F4oe3GyB$JbKZ&Nr>a^pP<2WphRMY=0i zm{%MrxDWtGvWlIM8936>1CHc1Yuim13l^44GX=(xjBelDgmf3ntG~>-^LZ7A3$-Ji zi^Hjx!!VpI=G!{-72n#N^j$2d0;r|apF7uvqyYsgi=!0N@|8a50|1#12 z;6GpS`@w&{8vpSvSk6n%X|F;*pSW0l;H&VSiKX4)(y@iBS$sPmSUbuS@2ntMZI#_N zjLty1(pGgJuxsI*AA1mckY@VYs2FYS5-+t1d6BN0rrq1(EmoFO{?^uNrA-7Kh9(*r z!R!r1FVWS|%m{?biF+m^Wtt6#?TzxNHZf2Zdaj@>A;f{Q7^QlEJoBDyvJyoj*3XM$ zHzpZ;HIw=;fH1qi!3nXUvC zf6BwD0Kq*NWdTrP2O`FEj_g>exF*gEtp^btMkQZW|vBY12 z?#ggR1dQ6587blm?(G2j&DTqai5W>1+PA$gv$|36RL?7HaoS;cA zdiS;}h1t$X=!t2YOm8%AleKGdMj5-SQ05~Fg;a@}vBJ*U3F4&Rqav9Ej%4NOlZULZ ziFJE1jflR_JY|jF*ABb&T(`^amh%z@)s2MLVA+IQ_SP?FV5EIeyk~peNU*a#V1abZ zW8!qzE_o!Z<%DBiLen|KugJW4qf6G(HT^}CT#fB6nH@Gk#$i=VHKJ75Fx8&e8Ej7+ zm@O5gbBO4Bu9&S0K>o8s^H0}EVoE$+Tt)BgjBb4%xFxUoOH5EQ|6t6?>{WWe5Fa6rFlLIB^l65keC$lSQOKCqTbsgALg1LPr@Fau!qa1 zlsM%0f@%TdBv1~C=3NSyQHf_MF`E8xfY3Mw>1lq0F5i#gF!2y2DTD`>0)33wjW~m+ zNTb8!ADL{Y5X1D(6ZbUbc7QDpk2zPVUw!&dnPl)EvMV>coTU)* z4o9Ego4-rW-$~~t3uab@j>i={<0>Ea$ z*2--m9bs#ZI7qHjk^*|Vxrw2qn@_mN|Ce(#ba80Tl+4SjU=%H40@$2CXDFHE?6m+J z&lINso6fbxP64*)-eb~c3S!xMr8^E~8Dm&H*K7*_&^b%VMl<4B+Uhl`e+0rl?e_}) z_kUf=|0m^8+5V1V|nPw>my^^aOzzy2lLd#9V1z@Bt$_6wwA z*wF)aHiq^%aZ10bYun@=LL8|337ki!g6JZ54*<~gUYy^X>uq#TX*!0vx1{h6oxJG7eHh*Pr5bYZ#dZUYEv{ z-bV!@i2Ix_^)WnZpR4e?H^6JTUv#;CZ4s|a9P*Iw0+a_aIxZn^?Rk(DjE*bqBLe^|sbBwOGlVEflr*Q`9ENPX=CFB~p#^>A#_?xVE@j11%egWx9jywJS zV)c`LKLt7MT(_Ke@i{|QyZD@$0@ENyr^|zP0Xmh+YY+xqqbdSMM?R3;guzDi2DQGa z<#&`-YeeX@F_U_~U~DHaor}sI$WlcL0&z%wb3tkIHXI3iywg^4<-mk%aDK-+^wwuHq5uOm$`V^`YF^ayn=p)uhgQ`v`7BFWSq z$6B)8BWuZanTWZE40}qtEMNj(F5~;~g0U=ja8GGHU_cZ_o7anFVJRX}W#K>}xtZOS ze3{P6xN0`Lxy^53i(A?<%mTLb_)V8dAZ$8rI&C^{Mr}rK#%#uJ#XgMROxR4?Ox~>8 ztln&Sp53h5tlwJck3X#5zM9)jWHV=nr0K_ z=~Ei$D%mI74OJ-NH(JL40>cLI8>iwhB3q_?F(PZ4R1$B?_%e%^IZSv=UM>Q(u2S+$0!r%vP2FIPS!>#k?i8B`sr++ZasQDs)o+6L4XzYqGAcXP|{4 z6R25@m8qwB#=)5ZWRBRQe2>C0qsI&60Hb&t;|j5?y2V?zY&5bhMpH4y-WvnFERD9I z4!9|8DQ{VAS@X!7{g%U)%UGQ1DEv1FOK6KZI~Y3z31YiYM|M%RvE|>=dgcFRTfW6w zv8q*P?i*o`o_75DW=_g>m?uivM`h*G+n@>Qv=1Sez|XGi;v$fQbn*^&uVr+xxP2{k z|8g8bwuX>w>lwPI`waCT@MCi)CKEol(Ug}{@BT?6E<_p$ZZlzJ8 z++G{+8T7%G_DI3scfr#(oW~6;J=u7aGAc_M`vW|D`1i{G|G)g})&75er~hr@&;I`_ zen0%5=lDMj27ZE-aH0Z5VLA>;3GMNV&jTGhr6$M~B3VocEbakOsGpjhkJ@VEt|&Kodzm2IKEc`0t|+_?Avy6#v6NRfq4 ziw<3i9Jmy5g4qYr08&Ibbyt7{``5BIXdG$Q6F1-ps2!2qzq|C5ywPVHWRH0RW?7e7 z@mNf}o8wa^+OL@CL%xNoTO0(*^3blXAn?gsp4w=7+Z zoCPU?xkk)2VvR*KgYMzvhx;H|fw&L0mrVGQd-Lv>@qR9-j$M_7KxN@497qyoD(XP( z%--U~Lr0+{TT1iJ>g+1}Kub_L~SMYJtQMaGnyx0?~$>@5<4U?e}^@{|x zq*T~d`!OuG#!3AV2GVYoaL7G+J5ea7$$aktI4uX>ZV8q5g3AY@h{&IuBa(0?PcWMI zWAwSB))%RkQ*I6m0&nvP>>_88UBrtVfhl+t>@Xh}Xz~V3p=&brF}*X5GO2kp(5HQF z%ccSJRdwVQ=p+8hV{o5s+>$c^bDi23nM14(U_M7*1Sgn}0u>6*XS3UjYZquarJ)+U7cr~ut3(C@X&Evecg&SzXyE8i$Y=T@IUl_`whg!B2B0kXAK zO-)+TygL=xV=z=HbLVYB$ToOq&?hkIG*OOD5k8|`Hitfer(~nbE^>hIS%sqId~yJM zBv2>%I_upuZ!_NYYz0^{SW^46~7<+?~^wvZH$Y+w4RBcP8@!K%G}O3MD$hNfS!0DXChBHpjdkeGc0 zDKztedagWAmiBZn@Ab(+BjOp%FJpePPh&*Sx@3}=xnIzmP( z8t`#&A{c`AhJT|VsoRrT0*Rp_a){1KH}Yj1z!aO523(YAmA`*o`sd3j+!Y&AfQS)_a#Ay zx>4IM1Oa)-anR}-CW4zFV7H9Ng~90E%$)2}Rjq3cK+r|x{n0Qo1A zgMxwUVb zhan7RD}~Si3aF#1q3Q+-7?e9j0pCq-f?TK%R*djGg5in+8l{ovmndpuSKU`O0}N=X zphJ6KVYj1lc4;tY8}Bo9R50sPuS0Jh@j7f*O>947Znzx=V_wAq`&w%^%E+GQT!!B( zbBhC5x?J_KT~xx_O-D>XucBFG!c0XKhZ~~Pde8yO%LQ+LD_#Dt`n`hx{mZ{yi~kjy z+42AM5C88=et#VPS7*ki8~RPD3Q|6%{#n!9;Xa}WCQn>ZKz|nn^f&h~JNz%}i}d{K z*H>!}*Xq^vB)Y>DyOj7~-QG`;ih{8q3{Gdp=X?)L9(tv&A=LdnYXC`S5Zg2MlO(@> ztwD8bxeivZE81`-`Q@}ZX6{Krj)lL-VvdNmt<8>!wykXs0KWb_eE2OTFzS&jeXreh zgunCU84?}r(_!EVl-N^=%JQf=d^{ipMo(ubffMcNhC;}9YF>-}y)cYCD3DWv;e#?s z11zrt!15Xt$XhE*U{@n?UAqBe)@;A@Wbr4Z`x(E8Zs>vWnFLQ3(uhtxyLYcTl2sc|eKU9f+9u7SnPe73Q!5 z6t$i3#B!~&EJ-%-L>(oR!1VNiC%UlWiH>4gA)Xkr_GZBoT{hx4J4DQ)**On;9rI{F zXF~1`Sbc}d1D)dxMCCH7nALcvfF}CvR60cyE3+@p%)%6QU}6~_IVx_C#NhG@EC%fm zSmaB9Ux*oicI*`TZm>{Rs@RD^rR$R!Bqp^r8 z$z=zUc(qV>`El*j%^{{WUTcSJ1y+*BVRyLAMr{DuqD4ptlRU#z0Bl*O&}&v+f_K6> zWvnqV$RjusQl)sGFFOZi}T8hJV@hd5U&W5>B-W3Ml~Ic4L5b9ry$jB}Opg=kis z%jTfhfSNJ+(PGxf)00MC1)6H{0qwG? z33x1Sv|eQltx0#yp*54Wh;}&@{Xn})>t{32E-sqDU0TzJHGUBjeQSjVca;Li!{`2>LdolmZ#eMw8AN}_)`TgKO(^gk&bu2Ws5>@Cz$AEIGQRbb; zGl$z=UnMMVp+m-W_48ZHa(UE8d137#3p=G1f7$%D>z>^F_S^WYvsJ^vjLsx{x&#BD zgu#Txgu}#sdD~B6jVH`CW3IdtrotU_%IG?e39P-0xn|5&cE7Dc`|g)hy!HqlcE7PH zsLSrxXE$Wxtc!zSCK>!b5S6^quiP+q%cVBV%|n|Zs-S}V@D>`aw0?kY@dq9Ns>n!p z7TZk~`&^G_;Ny|?_5|A39A=V6pon=(B!kvjk8GP0l(%!kw5c2kJA2|U+};k1%aK>8 zhx-Gbh+rNGhpB`nmeImG?@SHnQ7QmKT=eLSFP(7!7w1tAfn!_I*v9!phKGrbXW9#} z^Qh5gY<5l3owea=Z1XM!SvNUlw*zu;&UG6f7XO2At<&nA&n+}heh}v(+rkOqd7Nt) z-Y4Q*XLM??mNM7HPWh6V?-N5)Qpd%L)L4-V=0(T;fA-#FS(X?%(|eV)TAxnCJZM)< zQYEt%DXJ;Sn!V#jt2V9r{Y?Pe9r%HW98a9QdF$pWtE!8P2@wIu@Wt=$*vDwRg?pVp z`^bNde2wYAhJ4YcYvk*`!C%Z)O(i{b8aVTl$Pv68rYsRDP~iDHF<7s{UvP@C=_Qs| zLtVAzH8AyAer$P4<~61}b5Xz;HNH-4Xp|K&W1`Y-fH9l3GeE|u|DDNL2pY2xn zoNfNx1&=vrd|dHZCbvz&V^nFuW7^ma9;IXo^ zcFHbzEQJ*3x2n6dCgU-qz3a&=buM24Wu~+%TZLUWIGJoIqp0kg&kvqXPP#=>*x}j0@mIO6`E>`BB?6 z1ZcL-1_1K07r>iBKB?e=CMu_V&QRrzJQ*!ctno3(*DV!|z+O* z3u_>Ic39XNaNmSi3TSQ-&5apEYnE)+bnS>2WdcaH60s3Ryw!-d5YZNd0A}!Eqt?&% zPF9jE?&iQOcE%~d1>};KEDR_Y>M8oC1VYeTHeZtl}hhe6X zWSF<(7?tqS^3{zBW*pBp%GQe=1KFsF(e)wrRlqgHtlAaaklqp6GV+PNsuikjfaIBS-SvupkWxlGs8@lCL% zjv8^-)RomKCIYC}{suW*gmrBYnS^yMxx*x^YkILsSf`s|iDoS|;gyJt+1{+!VYpshl#Mxsx|p+8O-zy4r}J`z%G*zk1lDo z>gtSfYdAVr1ySRjmUn2Qywe)=LG#v72jOUyg{W@Y1~)~ci|r*`@*mYL93R5NU~25U z9e9|Q#tfM$^ok7=U_;*8W725{Vmc}Im~`#xJtm#bjpnoOXn76hg70X(Y9+-tv7xt% zq|P>Ue@RkTThTWpb)jX9hksAlu&kNPWo&o_7}``DMb399>r_qVv5yROD9@}T!%&~L z{*4mTK9&FBVE(6e_@DdmznA=d_}_OHA!nU*jdA;^ETMGQZa*&74|;(%aq^<=`-U&5 zz5G4?7+=s(NBQB3Vs|IZeLwIE?Y~XaX3fiN1t$a_(UHTU^i4((U5!FvjC_i(Q%PQr z%hKe1;at0=%l6avc*=_8=o@aM_i1Tq$NSSd(EGW(#FzK)v8FGuu6EI@ES+p-Yh!&A zz8T@_RM=Qu4T8~@;Mkyh;?+92?GfS?xRd7Y7bZ3C0i)Dd!*c;|OyGJub;gT!=WPW+ z-aK$NHb;ji*cfj=CSoDsF?)tA#wtrY^el5}pmv|56+14g36m^PHaR6e{&%5l@{pco zZES`Yhq-QlcM`Y0|I55gY1F!9fS3JC?Q8r?yDe=#PFYmnwE$4Usg=Da;MzkB>=yp& z?RyV`T^rROy6fFR{q}JFbw|!sWL^rstclr@GO2VK!;jQDKb*(E#k~4uux)DWTQxkH zf9k@${mM&xy8|_)=(M1;5l0w`{ zvl^4$=2jpIq=pjBu0)Gz!5k5-xyQ~xtNB09Syo9TyQEo->>4WaNs|C*>5%e5v{Y2l zEksLaw@BeCk~JiS#fWGo#<09LV|0Yq=0f{0B}l7!{&s<*ued&<>u)p_jd!GFLNkeb zlyI?yp4&;YI!QZ~(JRsllD<~q5rVYnv>j>j&VDY2?k;M(e`vXewmsQu=?AUOPe(&D z-Y)qStTC69t!kfZaIzz#q0!{#aefucdke8j0B`ZDr1eF9RW%3b8LEA<{`cWmpTF<@ zJ;VS0`cKF5KkYX8AB=Y&{`ZQ%KaT&^xla|8{9?DHR)<&fKi6X09L4`!=p=#)U0IL^ ziQp};aO%I|+jxQwHs^_1(AQ4&K)g8XCL-t{E|rwz!<~f?HOXd(8t1%1&s;w4O}XF? z67{nVrp{O|u)t<>clgz}c+2;*Kxzk%i}uL=zGGu@l7MGidAk#P>jtyH3Af~U=)a+L zFe9W^$c)gm1xjaxZMPlEENj7$0fKE!!`Tu(b~Z^mbrSEd_%*Ufnvu%Y>MnWdXU2Du zu{Y?sThegHrL&0?Poo&ORjngJ$mOb=8@wPwI$OeHGVBJ3a3pi38xq6LRtTY~A&jh~ zbSZ17=u;SWE$6_O{YHea)#qEEz`BioX9$#&yo?RfTNfdoy{^Q&NC;OWJd_YlLtHQ5 z(@OaKcMQsy1TpEzI)6z_x-Bj2JyF<-=q_4?pmTUMUiBn!>~ zQjFSfk}R0!guH0v(n=I*F9eD~Q*4I`DAI0SAUEY}Z7#*LJ}xNA!GZZ&WA<~t*6JY} z-0E2CG&$k72Yn!(B9-Qd4c6-`5 zvkE=YrPlc`)W#VEiB^RKAknF;0VMLV(gu^RvSZQ4C70SL&m_^5(vyMaW`?L!o5o&X zh*noSI5eX|a_NfethQC7c9A6dR3q+Hx7b@Gu{_HQB+;Cs3f2Hg^wyZaZ|B*+gTH6^ z-@pCivHUM;yY>J5~d3wPjUNQDvGa}Y-^;EUgyd@tZdyO&*ksUx&!*y{wkiE1nuI6=lH zBFIsrDv^#6U1S^q0LpsTeL`d9JWq-gROV_-?Ml!QG5Ygi+>n$PBuM{-Q8L*jo{sa z@ey4a%|p|kWwfHZ^3gKO!K>Vtm9|n03|B}thb>g2MJ(Y8X$O4c8tvkqL>&e`wm{dn z3rN?FjtcmOw{xBgvmGkTUK7(iN5l6NnUkogv^US0dN&n}A0kYxLp<2=n6KvGk!xsm zH-IYj`S*%2vDN4aqDnJ4<1jbmmzu*4cJc=Jv~Oe#96}oSRK|@*m6!FjIV|MVRPWmv zoz`EFovPrc6dnsaZNUabk!cdEFDFGN1}9WyjvH5es?A1_X-(J!Cp4~w%RqqYozs2= zsHIAnqgJ=5L%>j3B?}DIm=G3*8nR2_YgT0XWP)25s?|{~Z?fhKS8lvdUz)g+_o-{n zTGJiJt4^^2=#CyPh{`NHL|OovUk+lR}btRzG_MXS+muu6m+MorSdfmai^^HO;ru`)0p)c z{`dbJtpD?7qyMw&lmGQ4f8XJMb*QVWm)8&nx!Ps!P(nIgbDwsDM}PDG2;niWrMg$l7i_ z1woXhNXHIz==~Vcv^CPsj9N~$4-?y!ug6Aj2V<=>J~y6Td&*`u2@ZJ&yi(60;DI2} z7JOoPvLCuOQ$W6UZ1G40AaIGEoR3*pV$Bnx;$Vq3xbB`Tr~flh;y10io98Wg@17l> zjdr3!?3Rd4^C~^OVA2B~&~LZsem6#k1#FHt4VViVtT|$H?5PYQ&_gO<7ZR}stX<@@ z1vF)>LBtwJyfRnw$tA2oLVJ)nf~w^ead4gFakqfGMKB@m0l0t{75_{s=wY9{zUJP5 zD?kBi92PttPZh{59ujo}IyVsncLO=O4idFu21s-4NMYJJjG$M3xHr>NW*9@)GfS+dhr*9?s!Kp&&Sk@-#~ga zFiztr|AvO0@SY_cFPW8x_MWh1CA@zbW$BpQ;@CSg^o-oze>4M0Ywo+A(6nh++els6 zo!Z75&<kgGdOkYUo}aI7X%qG{^R}bz@$=;b9P>0;O=&qy?2GC8tudz&Fk9u3 zdiT$yY4Wi4C9|~YGFc1R)g_|P^0xa`zD9e@!o2nl7L88ZZ&{nuZ@ZFN+Vm5W*>>iD zjg7EbG^Quth{f{F#@Cm22FvTeVWqEF;RxwJR`Fzu@)14^IL2GVH+QE$e>K9PR&8&b-}nW+-MQ+Mhg%7csFr#OcF$$X<58C()+X zY*P$sEm8?;_4KVD(!G`d2t)HBB1 z6@u}coNJG)N6GUZ6=kO8dbkr@8MSfBy@;%g@(8Vpk$QkuRgnhNDrk??ijVE?xb3Yj#cIAv4I`s_y`7eJvnE!0!zm-YchyT3d@56sy%ztzpKYmC2^YASB{#j#P z!i98g?pVj+?w&c%Ap0g>C@S*2T4s|TofM+!VV~*@tI6%UGo~KGi9eI}+_#kU7hEsz zH;_7+@#fo0$!}SR+{o4VP;HMH+)yiHp_5S|?pjVic2Zs#pCBZghct|I)`XYnGDeg& zDUe+7*&=R9Sjf<G5{Y`kS-j8X&PH&oyn)V?lb1q9$YjsB6c zjQ~#YRsc?!7kbO_6ycX4B}qI=_+~f> zYP$lTK;KPJosr{ukLs8h!JK7#BKghtIUW0 zyyEY}e}07%!3X`QgFhI`r1DF?{HGA@z&fRSFOaQMZbeqg?gyp#u95fKkp?$Oj#8n_v=R|M>mgXEipbb9P5wkO$xAX5;Sn>5=nP_} z4>Na|iNnMi%9KIdHAiHp44p5`WMN?nn%spZnMh8_tTGYrEI&k$i3Afm9x635S@l5t zrG_pl4ptOsI53pkKpyUzwbTDOQbU~x*edWchKw;p6GfH*~? zThTD#z6Fg;V(v66+%sxAhQF;l1u=Jci$OECP*I8A-E382Z&4xO*&@7!j2%_R+ZJO_ zl$o4^?r@%Yn&PVL#ZS zvV_hfJoOGEdj~ljwXUc16;?p2IVYz=AK~}$PJbqJQ&a_hKO5Wc6|wNDHKP?znvYS# zr{K@H*E9CA-64suDKZP1UUeuGa{~zsg}kBwCS5G!;z}w?H^@?#X-dQ~l2tMz&sxeE%wPw#zqUO2dzozIq<=kO$PtrAV4r*E)DUm_bVw=;Hqz!bg<>{L>Es5eN@h&kZ z`?Y9VJh3y>v}oVL%FLP;YoebxQ#r!KxY4v|m(mw_DVdzUhNdM2_F)>DmKvhaE&Rzj z<>&Z1rE1x^P2_9m?HXVwC~ZNWl$>#0p5)I_*)$?w$8)gW8$dlFM2)JJhF2=gH)#d9sdR5zhoh;#1J(t-ECE;o-_nfsv%dI-zkovm)4})~? ztFDk%B++!K@ExO&hEEvI*_Nm0edI#jY;H*v&e8Y=0C3e?))Kiddg(qT;ye`+7B0oy z2m@;yM_=w6)-LnyWP_NDD|5UY6@=2E(|$xoACb`mVUcZ$@Ga*TN{uR7ZeqDqbsgSV z{gc6Q#Lm7QB8OI_jHqbJ!s1t-Rn}h}OnYy`p_$jd7SFU8ojoidj;Z0jfIo5HVudgT zcEq7#S^uW5eNj>c%$S`^`Zty)*)mV>jyI(t#Tce&IA!Oz5Gd7OpFmhtS%fR@Ou_Xu@T3%8t>b_LIE z!9X1VeQgv;UtNnNr%V#HM!P4InY~zyRB2@M6n?@f>1;!)3F>b7B&imp=P*Um=kJw& z&+woBd~p6Z<-*E;jQ_-ce#zg5{~SKkub$F1Ba%Wo_R2_`Iw*hB_Wlbb+{5;|x*pYEG76#7?SF7edUW(Yz_SC+hM z)>{$z*STc)!(&AM{L;C8n7*OxqPKUTJ;_U-F%nrXtGQaGaFH#|=B9ylBl1{a-IA`$ zIhJejmezP}9Epj_QZ?0@By770n=bKKV{+9fNctw);<14DC33Cy)qZQ0QXPpU)J~A~ zcorGEI7yM#ZYN_`z-G$31vnnB&lXD?=<+d81PS^k=z<=Rgo-tSY{TSiM7B}Z2Hra{ zSW~9cM)~d^SJ%=_h42AbzXD+Ok?FlLRyTtg+Jb46Nvs=Dg1FJYgAW~5@+Q&}+rD+z z*YOs22^aBJ-y>pSXK1Frp{GRU!B|5@`_P=dWH~GA?i{+MmvyfTBY(ql@T*S?;Ia4m zuneQkVKnsQhsB5Hr_dEbE&&aT9Hg4jnOEL)8YX?{jAeKhBkp>Ma=9 z%6>kW9uunEZjRnTiZJcH2hEkrriCKCBRI5edEo904qZ$VV+C+8isp*W+%;Fc zvotrS+gDnKaM?8(7fY_Z(lyi9zT~QU;O%IxG9@}g9#@0*P*iA$6P>Cq?^2v-ZSvD$ zgL?nA?P7T9@;Ik6rFyAG1)4INS>^UaM%!`&7c-jaWIPD2RI)CA$lc%b-!uI0Z~u6# z{>wYH;eR21_}?r3Uc&#{NZG?JewItWR{!<-WfP^Fy(0`b?f9VbOIp_@Q42LaUML8t zBMp1(jvQ@XIP%E6F~gHPdLN^Z8oiHcNR1>macfpbm`QVv$zPk4ZS`VI?u<@x*Kq20 zbOVvU+d&B%si-HZfIa83AWs!6qzDyS5{{EWOtwY!;w5@?O$Nqr&PH^l^aG){>(H8A zdvdF!iw14np83hM?sU#!oNv022r`utPs*}l@>)so-?H)u-t-{+T%`}1`>nKP-B5mw z?<89dLGrS|6P=l~@0Ynwj(JZXVD?(%`$o5tUZBV9=HZkEP(!$gTp?@P^zVVT6|wQf z=vi{_A>S>^J3Tt|Rqwro_fR+2>6)<$Vs>+nxWw#^;1pLi=RJ8>U3-tD^DVJgipbW= z{T&^$J4GEXsm^L$TTTe}S`3sMPVFhsbcorlY>m*(gw|A$IMElxXwF*BZin%?9p?|5 zBx(I@$kR%%qVxjPv`u;r&8@3+iPNS*vNej}JxAuw?0iaSE;;6iiW%^22!nzlLXOF*r%tr#Y(7E+4oZmi~Q+I3>&-#btO1tcJ)KmQH&ms9MGfbg>CrGtVvAor*1;wPLLjHk!eZQ&|#rQfp*%g+Bn$*yS30x%+5?@XO&c90I;ZXoCsRQuWlk}Hv9U_ zC9PfQ;C%N2<-~$Ybdr?vc@9@k5$0K`rnMHqUpsefx-bE2-U;kgcs{-D*8 zYym{sUDV|eFT}2|&8F(tZ{@Z#O^1n1+^Kj`qh@L_wqxm98)+VgYpFbp(&%qT12aK~ zc!{p%U`*_EO`nr7%KZ*>?fw6r;eUVqZwKqY%$EP@PyGLv{C)V}OTWffO|$uV`PaEd zc+DHMK))U0{;6XCV9-v?z`*1>+kL>Nh7P_%9H!$E=Kt~ex?HX=?Atkc)*f865<{hC z)S-`oG;Md*yHAX;ANTO2xAQF-OU(dKW5E8HaI!c4TQ*aZ9k+nPdyD_p4_sa0l3h%; zLU-14)h7{t^}-deEV9dy9wQHOMg($#D15BVCkzd6O~3eM+{6 z7^}g(qd~0Ywp5GzDn=JJ602bn;>)6ExaHMI;sG=99jo}#EqwjtQ<*E2+oM>9KV3`| zOQTO^u&MF6*{8ByVxd?)^IxY}CYUA%#FU9TkzNofmJLcH#p2W3?ykBh9EjIqSdBqcWjKr8OL!jcsehua7AG$}s_`a+-(CPaD&59vqcO_Q6RbC&9 zrO0rfh*F=q( zsvF}q2@+Y1!opACsBUTa1~qmiSHpz0%H1Wu>b=tKC$QHOfoeNGFTWc7%3d!cB@toa zaGtg4(fD zvHp_%K9#Z*(F~~6;8A?)nMY9?iJ3s%&t^ZDM?tXOjU(smR2NyOg9i zqN?E1f}?yQ=XS(VWv`?c9A#^)sRc**+;UQO9914jhl%BuRkFh;@oY7590~Dd6M7_C zVBh3BFkdlW4)djAvQOt#yyT#GMMG8JRmD-)lvFBv z7w0%%AsDkCmA{J4mh6hwYTfBo&AjSr1hxN7P?rrM{a*0u^Y`t)XZYVg9L)c0+{XX< z#Q%TI-=D+(+I-6&^Ko9z^{xOz>bIW-fHqzA{A|I;AK`y~ciAADp3M-((OOmtcr`m@ z-vd?;{kQoOI0qI|Q%Pp55c8xg8YH@K`w|Vhuo?yUhjd}RN^fdVY)aj(UTILW{}Zm9 z?Xbs;tJ@6T?;VEbjo+aa{u(>%d)(tb76nxF0yN%)HBWf%1t!`NON{=FM!hw}Uf7sp zFW{9kUU_Sve9f(u%7#4tJ;)*&YJ14LmTHV4pDYH8ys*SN{0gvGSEsd>Xnd7bRdtPt za2t#oc?-S>hV^AR6xlTELY2)^&d;NsHr2ssYpT64gZ%b58A(##wqv~ATv;bX`EGW> zWILaLNh-u%-(4)}n->{lNxJzBmh^1iRo>DfDe!VAxBMTWUx3l1Q*9wkcja0h2tt$5 zxatQcXtG7RB9l*LW$MJ_jY}0_8N`5bg~=l%IU=5djUJb zg!ho(9?0&sQDG?QbR>VcgMCKhj4#QaEm%6r3)E5fo=$6>yO8#1xGC@82ZFEh**l1%mf+^%Rm3Sz zWpGXo#}=SJ`zhre`yyV;@Of65!R$HiT75F8yvr(duh9-TRaB%m-;chgECNnC=ZL{ZTO|e? z)u9tk+XkNzHI78JOgOEhyr_&g%l+A>5vOWRWkQ^~M$o&2I8)00U@y^TZw*HV)*)&AFK?o_mH`^W5TZU=5v6_Lm%K37VsU&M1r>5nn-YAZzAC!Suvk2!TFP{W)S_Qeq6luW7Tj&=zK%wJrHV`FI34no$h5+l7G|)E9Mi`2 zmKCYuoSU0l=fnby)?vc}v)V`=r%0SIp-%9 zSh@_IeOg#x2+pr8Fy&~w=WPwcpL3_Tz9kpwEHKsY?g_Fl7!zE;>6&5qMzA>TvR%NR^40?QbI#OAq}?;uWD`H)#+|>X z@<06b*!XY7&^P=~eeyrNNw(An55G8{zG#1Po?f>wn8A=!9Y1VHkDW7sQ(G zQ`r9L#y|b|=T(EL)37|EBr5Rwg_H_rEPcVh&cU*GEP8X#`^mqLo5^7FUc?zFgl&MtVU4T7+$ATcriaGyvOJ)-9B=R8VGj?egKu4R zvE}WfXUwCG-x^#qnl|+aGQb)SpTkU|OpAvm2knoShi^Y>am)4g0moauV}peefj?&; zS5D^ut%Z~qS~WnG;gmOXh&bD# z11^aUL_!5Vxr)Qa0jSCn-E45GL~(hAQ~4Yr&wuGBb(9^S9a1u66)Db`Gl_BRq8RFqRQeFEe0I-+K+h7X*wgjUF8zb=M} z%O=`AOx2*~g>Z503LsXqz^4LHG~rWp`jIb`4()X(W+!~A<`wwrLE}pE4&QLcwTo7* zw6eZ zw4xM&TPoByIV@}^w0%>;LWaV`jI7ZbKIGC4Fx8c(mGOP$08e7^#-JVOdd|7&<88vg z<}MAgq^)(56VRMv2zew0bSY1(T9+ZB)o+EEq@9`R^tc zU@Md=Jfit(`!AZW_S>yxv+TIIh|+J9x=ZI6R_o;b1V5#b)sx;M1E@&32(BAxF9a;m z%@|kLcJo@B>XY$uf}+SCHwIgisJ9G-4s1`d63_|oR%yMejcvzZ*T%*hb8}o_<25;e zu8V5iSbR$?*G!UH=1>W+Zof?`dTv$ zD#jsEqL%n8lNIy<3afgTR4ZN0=6&gl583~v(R&3|X!=fh9rnj<8L9WiZ5j#0^h4G| zbd@yaLR1YHRAA9HozEew{xBzSMK{6diu)euUcTp8*)J*Zim%4Vh5O5%>Y%K((g0XC zdd~dF&#HCEGr;oMAiyfm)(n6ZbPPS$fjZ}8r>u{4?}zeua>y)5(g)?wB!nTZ} zuaryrgEjksRk3-Mq6SMRWmgTBE3M5f@6&jfA^SlJF8AyQ<&{L8`}-^{%|?YlGKcD3 zH`rF-aQv4vSbkz#*7|J{gc^;|jm(`Z+lto3FBD(p3~;MhY#eY)yTG?Aa4VzuDy7^V zF-`T~)jeltdEUMSOZ&d~N?U(fd{v&n(NX4VLwEve#q#Fk9nvdf%Hn3Dy;1?QA|zFH zYaMNsc34`;M|<^_f6ws0|9oitx0+<^!~cHO--rKQ;}7|VG+_Bz_V*L|uR7^?NCRdE zQ?P^kNzzaL=Q#7SPOx`|@BMC%*IA4RkzuV{TLnv227YGYyCwDGIZltdSGpU;dZlLzNAF#@9QK{&R@G7IFs6Om+Q` z%r|-_hC#~)Cp)Wl=8lMzy+X`XkN7XuSb13+X+Q(!;+is)`fhYyti5(m8_Jo`CvZly zCfUQV{0q1lrO%oaVQMP~Q=GS9Kr^F)-7quuQxs~9`9f9L05fasnxH{N@7Dwk+IY^i zFo>D**~W#K)dVq+?bS#=0|KBS#wahe+^r>k*3*T?m@q*DWtW)6U}nkCP-dQS;%4=S zZH5Nk?@|CW@}(Ty%%Rg_&<;gmTpR(+B6`qfqrqv>C9NSxgHzc(nMt&^qGVUs#dMjT z>EKO%mY#7d+Es=BRm!W>Kus_Amp5Z_L`cDVv z|5V%jpTU3l&nx~u{O8sFe=Yj(`_P}UW^ENa_N#b1<<&@EvWpx<|t_NeyH&0K@h#l%gfhpOFv~q zb?H}Ue~4D1qCcjgV`__U7J~lE7ClFrL1cJq|uRFLr4!xxdu9-5&KSf z)b~e(v<}krV8;iV;bdsD(<0U^Pb^c4#RGW~U)sTyp*8$K41Dh}G8SF2yBAvaJewZN z92hI`(w%D@Ew~rT97fy=J%z{b>a3Pt@EHfgx|psyx>=Xia>-(ttkz}E>MW8wB59&u zF0ZrPqYAdCH!$a5!R=6yi`od4Umn-R@L03QVQRjGTe?JF zarQk9mHk48!znsG$G;c2;`NJg5Qq>9P5?nG( z+jgWhiza7}gQZZ~n>SA1_Bf28DzElE4wWf)gdT^!2G;+`vi|J9XZYXW4(5NxhAsbd zAO81>zYqUAe5usFV&xkYklfK;N&)4n$9R6~WG`md+V_yD*S^LA>5Lb=MEq6tSKniI zfkB%xT%<2E*cU`kC03fpJYxGhjAf#-j$I7)hoQjh5RjhWw~VOG&BMlhvrW7omxYm; z?K^QcTi6;@-(<0{M+a5&9a>C`ew(>qJ4M7s7V%0EuOxJk%nKVg%g5+Z2qUB|`1F|( zDi6s)$@VlHFR}bX+_TVbi~-(A7nIe7gxD-?LEB>F;amJ-wqM?2;205?wdd76wKceW z(lKGwGh+pW5Qf-o+hU|`JMlqBad(*y>TJZ{)1H$oGAlx;4i0&6{<@qq-Qjce3GYG) z=@~ui{K?jOzyQe4ejWwcj(-jtf@$``cJ%9;4uFSs5!GC(0U>sacxVi)>tKgr{o59- z@5aKanuPqD$rDF=e|S31S(!%Tp@pW#Ak6!whQ{8BvvKln6LO?mxJR{iV~%hGJkmIi zZR6q`p%*UC6l6BAH&dWH>e@E+A+?^uL(x~>t@FbZ^$CLdCB5*-@NY}{?9Gpk>(|FRfw3ip6plRol|GF6kt=QfI zBdctOsTjdJo83nERvW~MByBUFIe{mkUQFO=j5TH@k~$`g*G(Ik9GPcAB7tmzz)*PI;lWg^gkp1O-Ia{IQEi{?Uei-DSTkex!Hq@#H;+Xujc8 zM|)%2VKb&j@3HOd7_u0sftI+jY56xa6Si)j>Nn>AX0mv-w(2pcq_ao3?AF|6gTo`> zx)H2%rw^ciXE-?FQ|0b}%q79~5}KtjO0slDbG8A`h{q>*&g|FcTflDd?8~S$CW|*{ z$`*~>;V~XA${hoB;vAN)Mpo+`10O?o9c+Z$!pTnQMlH%1GX<6=OlhJTQRxi36>+~{ zodrlqH}ZW*+0XQpt@C>`&;$&g)#S0kD){#U_)_Slyf2Fvc$Q>R*8tVt(LYX|z^Y27 zx8cDqcgW^EinCcOXaoVeL9%yaeDynHUt7}xcirQ+juuYlw;K4hksM8V1)p@MYi`p# z26D32c_c>*<`ZDM?b%I|-W}2_kRKMz26!j~rRyyu6v$iqH+Fv-d-_c*y>3n1iQa=j z2PNj`aLtF;jmJU%o~S7FWcT~>%3%;e4?d>wG{j6hvK-TpPk+0Sl%qM+y|+Jis=*j_ zj>DaFqu3Atck=7*a?A{QN>|d!RXk&>A3nd?^^^g9D(Enl1uN?REs1TCcdXJf0bMR!O9F8{Da4Kmn%K z+5_(7#IKV8Gg8b##GPfhT;k)^(bagp;7;w;CP%5R;c>^C)WIRL_9UbaTR7UM2CoQ*oNrTx*=NAeuV*tkKG>d-~o~);OpumI7IBm=pgqP*<`HPIR zehs`Fw`|{m1|Kpa1Fq`;Yq>;EniiA*wb0TPW}0!~b6K zx5xjuuc8itF+p<+>nfjsE9q8nuv<@!Fd?v7VBBR*{gUQI=~6p}j=6#?gQdU=NAE4f z9cyr8`8Qns6uJ^52O#Zx-v)^(PCv%1)ybm=z3 zNyn2;C!J45os2#ib29c+4AS_M2`3XzCY?+^S#`4dWXsv?$-0yECmT*So@_ojb#nUT z%*ln5izk;)UY)!?`Ep@@^6});DX3G>r(jOOo`O4tQloGx<{!$Ye2VH6^(mTDvG?ds z(Vt?eaH+9BrEtpTluLzGsje#5EWLfDT*SEMMu<;ruSIepZd;_!Es;Qm*5$F;P>a;2 zqPnR;25fc#?IU0X7{<`66&lm786s}M<`6R6PQ>d(Y~B&;8S$cmW!kAD)_@js+L3+* z8zdVT-2$t}Ox6Rtv*@>KvuA6g z*TX9s8&YSs#Yo)9VCh=;F%P$s;U%&a=8!tF)z-#tg?uiyLY=Z2WX3r9uufL!UFwUT zSSEc@%c7@Dr^=3|hYgp9Cv2v?q|Rpe9*e=c#a#6dSS*>VuNFIO)q%O1YNdk}bw~hx zBehF8x zO8S({DcMtU+#jWQV#aW)M4|pqz^SON#X29I`NPZ*=z{?EM0$Fx)5wHlNy4!tO=F3H zE%T6ry=2DGtdBB0=FodiF+f5LucGOrjJGO@19h3B>pJFCtO)IMJh$@D(kbOrR;R3M zC!XCY`%{j!H~$MlfT@C5KfEVqE^IcmGRTRN_Du~>u?dm+l!6n(c8hlUy1yWfaJ9(?+Hyb!bLV2t8e{14ISZarC(-bw|CVw9lAdkgOz7YAV;ls@(?*sNX3o^Thp*wu(~xaKA&nK^yf=S(?_~rS>fKfGVYvx zj&2DE=54;f3N|spiZ%Nwu6{5ER8po)O7eGE!BhT!|9))z_oz4VzpM_Q_5UmW{#5#+OKiOTqPyzt*QdH=Dk@*xzjkBM%4J4G+6W=1 zb?UR+nnyA_aPi|z=Er;Zm65E)Y4}*l!||!hfESLj5@`w7g^U;7np`jNH$M8p?(i6o z))(-Yh+BB3rmIqnU*zG?FDa=)jm> zQ|~bP1^VqVDaoaw*kp|9CH(?9+bi-!qM%+Td-u&WjJw0Fj3*)^iO1#Q9E8YNr`NQKHFzw%J{QP&u)RKW&dPz8oQZ^w1|QPMhfLCL;zRBB%tcCMqN+JL zw&D>=UEKW*S*U}_70Fd`xXdMFMLAAE;<+fSD7cJr0L4H$zmnWsDkZsM4eQleQF(bz zZDEmMqTG~9kEB=(jpy#Nq0-})hk0-uFEZsP;&_#YWSmYno#m=~vAyIh=XL2iF^*Ri z6+MlCo{Il|H2;Za!+-22{?kkT{#5=`ryR9cecA!6!EBsu_un2RLZ$ovk%;h8p{KI~ zwxdN}(8PM*nuk}mUN!3v%*JW|T}DJI@LP=NlDe6~f6Bzv7>Mm4B?I@(6VoyW14QI> zpOzkrh<+Cv`iWJly!0g}V5m-U-(0aiU^lM&R`kL(QbdM=jVWSVTJkK=ZxcJ>-)7HA z`fZ{{)Mq8UQg^%Prqy@Dn@M<~5p*VXSx#%(Vt2F`KKqQoo z>k2e##?{qvdU#B6A^!z!P)#NNTHiici?v##e7DwYTlV&9t!1v|Yzs;&o|JqNS<1f$ zEqV(Jd<7?Bo7!00JAJ*FjAb)2frXUmw}H$EWE5`^>YaL!M2$7jT4TRc@zcB7{ zNqjK8;NQBwBg&>{Iv{EJ2uo<_D( z7ogN`G3AlKZA*tLAIaffMwHe#@2Y*>Kwl$W!WNCz4Qoz8?Q`0Md5_ktL6yoXH*DT# zN=W;3wi;z($?5(+?KvsT6Io*!1qZyy85esJNa00VU*ttm$NI5z_j zUZkyV)J}L&xi5(O-a|~0Ls51%4_qXN@-0-?uPnHzbbcm{u5CsnLRoJ@w4PuCNr*h0 z|BnJga?>|WOdjz;nF8Cn4#Y#!Y<5Fw`B<-ZujuZaDE{U?Vr@@r&I`!DfzkEfCeyRY z_l$sC5HLi>qv6>I7@~s10yb8W6VVn9Q`9=Fg!Z1W2g&%rs*RSJSdDu*Y&7>(Vw=#I z;Wyb%Eo6vHIpCHEHz#r;-))wDACYumHCayPhrd?0;8KThcHL*P%tlk0i2xV!df4o+ z;13-dPvb?5=+&y$ZUMXBEojp&BN}$IGNNHC=3EwVp?eb74n)5TBch(=F-FvH`)*PM zeE@LbHvUedHUD;fv<8C228vx>mlS0nNHMGa>81?ZmcRden;`XzV*knlc zxG*(z-w-?651OPE*Wx@)UxYr;{As2S-0gMxU=m~v3`uju=k|_roP#6Rdwx!FbV+M; zi5(4Uq?)JjOpPd09z!FmV~!hWWE%#Xp%I;FP7X*;c@s1$gUdEKARXJGkrWv-SUv*0 z&`jifj)NLm-SW~+UTDhu4K*?;G2$EV%|~b9y(Ni9vDp=n@LKjd)u_7*9R^CvZB6l!pW zhV9k7NK>}UF}fY@dPB8MBWYmTHN(DX!i6@34KC#U&|DH;X-`MSg*_b^nd(+YR+g8^ zeXSvCNzH|q%V-~48@_jPyghOi3*!LiT>3t8+yuuHJ8H_~WD_a*Iqqa6zbqr$6O~Ql?=0qyHkzRiElZBnP5e0|*sncF%XmJ(;2;H%metxkg#^c4&PBn4 zeAmLWJh^5G9t_z*3@hUU`*8_NR2w`f)$S4*4Z*CPw-$m~Cu=R@!CJL}2Wz?Z+Yh-V zHoAGqEm3*5AsDRb z*pvoTsI{x2>w5xL+16Bc^7f4YY%4a5#?RQ$#t9obz=qm5cBE8rx#39Z8^~oLPJtJQp;7T*Vkllik7w*NEeP06VCYOT;Sw;kPWveoRSRSN z0fxWd-!uI0fB%PL{Xc`-@IR~UhyT6e@5BGzX7N+wSk?jRUE_b%QSSkscR}Xo+oF42 z8ElgD(NB-Lcgj(#mq|}uGgbnYJS;f$S1CwttvcKFzGtoZ!%*DIjDugx!xlnET_fQw zgvl){k^L4Jr#GIR4pL_&op((~c60D=kB119t4%J#wKi5IZEwz~WkxT2Gbn&P1$d;#j9A-6Fc@$>w+>Ke=%l2XZ~F zQyLjD%UX$ot-B`Pb19%+j}cy&uJ9f}j-Tb*+1^jNbZYSE)IUEQeRCulWDZ<8jcw_s zBt0ahQ+o}WlY#1rR!<-8&$-(Hm}X#4J9QHOACkPusk0}#Ee|Z%Zr0^tv7g+LKAlNJ zqQ2qN`Arp`JfPK^Q|?ZX5BE%NK1i4r^`DDNXVU1>8OTG9DVuf@BCK_FHDuJ+)}!;> zR#-=9@XDFAzYW$(|4v~Vcfp#^DXd^kQ#zX^(pTJw@ap|9WX-eR<1E5+0m+&}zfEJ6 zS-_h7HpTgJkKZIcgkgT27jQdCvdb|hCLD|~{hm6zdL*sfc_y?hJ*zYo@& zidLhyX74x9tvBXDi@bA+oWYg0Os2zRTK>8l9 zF%!95z}lh7^xt-cSgnBx`Jw#+7A~1m{a&Aj8mny(HC8*PsIjOZT1hu#Cv-@F4J?cD z0fKtb;d$(p@roPU<7#ERcn<@w#dE6{0`3;Ekl@5{zr)wsoEv?f*9~@bMM1}+JiVA1alaZ+MLL`c!M6ts&Mr{2ix zTrvp}l6R?tKU?FMv->W&amMUXnx&&cFHRkt?nqvcp$JtfBqraFpycSn$~ zd`XXG&RJ`XLB4V@%H73{p347sDE}#4f86^2g-`tVm;C*<{O8QMYM=EvqMWfm8ppb# z^?Nb`w)?=Dwj8{wgW6j7rF2MY_lQPF9mI&_T)R=g=wUn?|6Os^Xa(o$QiReUjX9_d z678#oWiSD#QA#6-$l=te-TCiLjoLF_maFZz{e%i+F88w|vYJN)M3jkoS-O(3%{roX z`s+dB>rpHxqSIat5>IxaurM1M{l;G|Q=Jb*?5ZTqVCZCNcbR+EMzwIRcqPV3B(3kU z!1UJ$1qM0i>4*Tv&_zWGa1s^pWn{c$#)jOZ^$l$iZ@@duSb>b4p1Ao@A;HP=__vs| z7%+Ae!vi;s=zY;EKa@q5(}62L9T%WZZ$y+@eSU2`FiPNlAWM>0$7V?dw#U{FPgu#u z+!aS!hZ?~8WwFA@Ug!(0YRk2R%{`$-FWz!wHXf`zVM|Z=Aa+bGXQPMjAiaWPnG@9; z$Wyl{=r=U>fg0^rPX-g=5PYk5`4zUO_avdB%RD|YU^~ZeNMpKSrk;To?^;_4ELN7u z)%EU3F13vM-<2-$?d?dH6v8OJUpE)KhhVTX!2k-y&!)$rPo~RXYI99PKLYqkYhOXh zBlyX-0O1pVYIZRJs22JARw%LLNQO2Apw}c+6aPFNwgf7tjf~0Yt$$#gBZ=uU=){mW z1gcejASfwL*Pj^_v85^gyrR#TQ~dc9m@NT=igriF6ahimWcynzHypF-(lcG-za?<+ zZ0@9(t}&iG?GPKNWZ_FRor9w&{MA?U z!eo#QLtImhwF(7nR1w?MzRzGgDB?AQ@R>S=CGD7YzQ%5e_%ybrcV^SUi;DALvt&ko z)cQM#utP#d*X-f{{qQ8@V>Tw*4GS;Y;e6Y|1l?Lm(b4VC!F4j$pojlgBm6&|IpKy3 zXYSaqbroX2Aw&rL6TOnaKjxerIoeQcuat80YGCX~7wFiJdjWX-?*RW=t$vT8?)!d) zWL)>z;=6ekHalvKH8`V(wNR73h3!UbJWMdwhdF4S{kPjg`U2>5y!HTYNXXiIeFD&3 z9<%9r_c5DGtg(ryXZ<*v5Qh`-G4e5$vm4|ybY^x6Tq z<0mqy$hd`dr$g#Cncr1+Sa3QlO_pH685#hug1Odc zb}(La`Er1-Ah`<_YMHhHzNk{GA7aQ~i-;@|e49gjxi}*{&V?w=gO31&Cy*5!5fwSU zBf$&ab8IefM9e0xDl+S`_2W&(*z-r4bF|KPHDEmZ927e8nWzI2Jmb=&A!|x6Gjlxp z1wo$8ei!7iv`@ofGtUdwFRC&FKrd*!lT zo#)(6&Nk=kE}?R<+yTZ_?@-wt77kdQ4<4s8HcTGIlO-OdwUvJZXt%gp87SoH?W!Z+V(lah+39#3X z!3zml_k*j`?_gd1H@xzaS2xAQ$ohVCwPGt7=-evb zUJ6)gdU)f5k|Y^r^`4^sW(55esyT?AZ*>|jnYG5>*1`q$E2JX#ErNYAU7G2Rw?w{} z1~}t5tP|mwQd|X9GL7&ea|*hH9Gh*hKlWGmhxXKS}?4;MG)HIs>Yxe+JS)8?R zBmmGBbf#l;+dP^Za^_r2W+i8QWg%zUgb3u!k^3i-GdT;Qv$ESFeyiNWY{YLa`Q)Z| zRo+G>4QG2-Win^1>-i1p4W^Jg1vR?)by|Q<-nuD~X0eXDqIj*athdbtkl9FKy+H6b z09i+49g6jueRcOr=bi4cxzsuN5S|2Kcez(8^F8!6x|`88&;qU+n5Rfh-@Br%nFzJMW;xQ9BR)IH#28wXU9h5V zBKQEi7Wi^8~>3UMKo zd&=M%3@80!Fw~pmb1N}iA)`t*eTXGypWTRo#+`? z(+NYQcjuh)$cT&z4>6)fee^9-#5*x5`WhlC{@u;Rg%?S!gc=#jW-C6Q4jREWXh^@3fbJIMZqd}4=su|zpJ<7GyLb@{^?l%KU3fI!hfRv@Sj)wefZC- z`A@1bq#j($*74FlyP$<>IRv+M_M21lIW6?OlEpwBH^h zGQNHYy7{S-PtoC!{n~gHz*?0H@^Q+;oYqq$24+PjQ&MRfzk(fU1N%unz{tWoJi@y8 zR89i%c;P|Z*J`s2(A;(`u*^ln9VRHIDkLU!-#{tAWrQ%% z1_m*)`T1QoObf=$oGG^C((D@;Qgg$gYo<`$U3tmLyWvHdInmjKIkhbrFWLiwWym&2 z$50Kda}W`XPJj_WZP-d~EQ zWc*sZ1nt*IMVOaVz;aW&%0*}IehhuAmw|d8VeN;Xmn~ZdLfNu2-cuja*|c*bUSQcz zjTrQ0P1rvUnF>h!!A^wS!O%m?EqsuMuIDL;)o*qx3C^PT*l`wjnzrkjSZ6~xtL%+A z3~h?Dl4d+Ff1c(<>`v&tH=U8_>LZsxN2A(W`sa8Sd7fhkdisI5l`?99TD3x?LXi+z zq#T;iR@uX>Xe)+oBzhNOTmV;&No}=IIYz)-MjH%9pU7tsF;_VttbxFi3udBRrY6cW zs~4eTU^QM}4&DTLedTtdyzo-te2z|ML|nQC5*zPNyOivd&9F^yW;enbSL}OgC_c%^ zV5m4a8tbR$1csVp)$vy-l`(RevAM^fFCC=Q?b#>FXBf)ncq#suN;Qk(EuTT1)#@`C zTFA@`vZ+{_&a(te`Zu(Aw0F9I)lUVfx4I^Obhm++vnEeGtoE)dgCilAM}or`^Ur2D z{QO<}dxro0$-dOM;YzN62f(jZ7cs+?- z-YO}<%c+3RO`?}457EnM3*KeI8f3gzf)zT3I?iXTL06)+0^YX-GHRz5?nqmx2F9i# zmf_tpZ0WvIT;i#tNyA&JY*IoX?Kvc`MnZz9ot_9}41Xqql!tpy{yef&Y;UuEjhfK? z`Zc=pE|4tKL3fRRT(R?E;biU_PPp=sX3`D|>^xU*gbknClmJRP=f?a+6%+B&5g%1F za7@GsM63X@OP@XF#H1})1Cf`uyW-BFH20p%!0MK2T>_htZ8JKwcEC%jHTMUxMU~pR#yJo)`3fmERF-91dCu4k;W=m8x%Kr=TXgyC7)4{l8qDTl80e z^E`fgG=$=O?o`0i$IY=q`rU zz0{683A&|b1TI=10w(KJ-aJA_D=~9lORml((weG4E++Ax$&>o8dI`5kyv#yPv`fZL zzD%d3HJtrQOTEsUqzNf;lFlh9^LHYh@_*5IrwvIn37qI5^2ZP~U1fzoz^Q;x`)noVruBvp)h`(L27oDdm~6~s@Y3QLYK7u4o7XmSNL})sjWaJAHo%X)N3d;o>NPq zaFwK%nkv6Y3!B+GjLBw$(STBYE>qG+QR*}N?;rl#q5hx2Z}opxee!?4OPl=X9(h5 zRVEl!Nw<@e;=_D?g}>x)+dKchzL4)Q-n?D%M|?}&;ja7D2}00*{9~Knu@ehf)vCS} zd~LX@89j9BF!P3)G<;ogHvHOkGc3pD*0VEFm|4P%5hj43W_0k(!~ECLc#euA^|kQ} z?5liP-;Wx|nqJ9jUj3Zw-;qv#&n(H+Em_k|55M17zx2%d|6l%gtp3M`9sj@ZS^vM{ z@3a1YY)*Mr%2vjCHEEfy!ti^10o#s07{{0{u>Wnb-Nx0pQ0?IR-2r+3*(ad=b|5ck zA8NL7q1t8S!x$Ct3CM>rD&SknSa&yxpljFY#}GF|Ank#75V47i zuBO#!Yo7AVy5mldInGTw;T}!!I~n=b-3s!pn+h5W1`AjNF>ES$ zEMN`9u-mg7U%cHV!{$%d8t!P%u#H6hZ?y>Ccr@%*jmHp6?+(CL`)`j~Y`0N*Le5kH z(AIjZ@TejoLr=)7>Y2gW1j}SAu|3PeU>mWJpl%jxfCF$Ja_QQ^)sNLZyj0jC5A_SU^eC;`)T3km z5pkcH$<|we-gR6vCD!2%q&qbf{zkgv)W*+I=McXZ<&KTP&TOrzK)x2?PGAd@%Lk6} z&e9>nVyj8Gv$#3dC~`{KuUWZML+7u4j1 zR2uyp>!We^a5~v@n<7!0rJ0WB&KpPUcgZ|SkDEU9xVh-(qSQO9_Le2OSEBIz9NtSO zUDZfWCP!?NA=KxTS9&=+qVhWBV?%vWZ*e(1d~)Ur0d)Qxv(^qlpd7TDDKR^@YIEAo z|A)wTsyBb?fY6p!oUD1ri1E+xzyJ6j|MNfn$Nzgj1H2Xg-Iz81Uns>7|9i#X9{-c6 zysurPOth&Gp}-I;P{d}o8B?W&;?6?5Mc5*4EL8BYn@nbDOM*hgV}wn`I99g0g=I*% zn|P2>!ND;Jt0OZ`4{7bGz$;VRM6DSgNXA-cywi+NC*!Hb%}YVQEhT=YrVFmi zK#+VKV99vfl1qzQhq5iYsX5t`JNZ*M#Zx+E=u~a7t&=W&YB=d)XX&K#$*7ajCu2^= zo{A+Je=^}ztk9&B$tSB$R-bG+r9D}Hvf*Uo$)=OdC#OzMpPV@rdv^Zh!pWtR%O|f+ zUZ1=@`BI5=^7$0>DVS5Rr{GS-=tDk5eJaKs-6{H0EcJ}1m`}-^l07AVO5v2%DVtL+ z6;|bvWf-V@jOdufRw(VWy+Vu6SwK>I)4X1!-MAUsmSEZ8TbtT6dvVcg7tc*<#u^I- z3l^I`wvO2ju%ZD^9q?=nlc-GxY`J1CR0y~m-h$Xp1m6+Ua!9iw(J`|2BSSK{1)nto zr`B>KRv=;pm^X1Djg~2k#Aw_w(RQ-##^u1RGu8Os2`>u2S}(z-Vfx3LeYg4Ctes3fHQSDC+gg>AcE)9}&Dp6ZM_b+P$*F)g z6rs0FXebG7FyTm$u+7f>y@ywu;K@k~;zGjRS_OPEs(UJ_8my%}>@3gs&L_L{rmj8Q zZEtF!LydEvYNT8BCm-4iNT;Brb1knvwEi_o7mNLCX%YlWP8E&R{|PwD*0ort+A~O* zUB(b{DPwR%x2Oo7P;8<%$KckG_QqhYjts(F z5)zca>xoBe^7L>_NgTz34mQ=+PzNw|O1h0<;gpIImPfAZ7?z9m6|+S$B2Gr+Og=eb}s)dZ@v6~Z11d70eV1ZobwF7CMxP_-{IFp5v^ohPF-u~AZ1^OU(Vg@ z%t88Z4&JYD5M5Sf-2I`ZM z1=X%Bge2&&b#BrWPEZg@s5y{lL}Dp};KWGEmF$L*PQAXgLz=qE~2?Vu6ueOAKzudKwX=8Xj2O)D^olq1A+1|m`9>Ae{TfzY+K4ElJK z)(HYy8BL#X*}2L3+`^S5D*9p@7ve+R0ZeSQizzbHWm*!Fiuclz?jbl_nA*SDYe{Pw z#cJnLPE_CI9xaJZU!f)5pQCBX2auK+Q=OCcQ|i_Hh`SQ1bMQID&Phra7Sp>%O8@)( zdxrn~^S>UP|4(o7|5^RvKQH>TlvBR)_QYee2EbL8|!%UXkarUTlgAunMUjlQPo+>g-sE zw93nNB4=V4MrYbpN!S+ac1IQ<%~PO-?~&JsNP>Q&s#E{b!L^ICLCJ5zx+sei+JUgH zHs9Y(mJpO4fXlZqvAmMzgCs~1CiqJuX@V}J_lTivBZVQVu4?tudg|-wvUbsw)m``& z1qA;1tNlWMHEAYqFq-uCeQQkN=0^dBsyl%ggDLaO@bkWG(otOQ;`<=K%L4F%UTScuQ1UmQELc~mHGD;z0E*m!_8n5-CtJy7rSvi+;6j721P$sB@oXccy z?8>>6P8-f;vUL;ZqR2+>YuDRuoP-Hi4FVDt!d2xk@oSa=xt#P$xV#teI0%<9cJs1~ zHWBb;(8l$oey$Eyu@kOzt~yP?L+w$a4oItbrw*v4zr8!$d30YJ*S)I8&0&x%*{w@| zOpCNXJM)#7piFz^9H7VP5c0DOtGq0Ck9%LmjUgQ@_i0A@xT~LYbx82}X80Xtti6=k zkDxc^_bbiq;lMj@^7jn?`P+Xz*8i`x!fpJY5C3_|-`@%UXb*Xj1~9Z7!%KwkcE)QiM`aC`cjxo{VAf!?k0w{+iMHJrO+5X!o%8lhGSAnLAE<4a zIg+zJ?aqbkm>AOTjJTf(TatV(W;Z?s520(e6h`88Je#sDdkD{4i86VPC;0A^smzg5 zjl6jL%D8G{s+-J}6oJ~s`oZ1eb9dM}A9W1Wl(=q+&uvKRetGpQ7u%1|O`9esL8|Bu zm8vV0D*PvPS7{e6KVqe9mEo33AWmQi|{fcUMY%f$)W0|nI2kJXI2Sy z91w7u3v|(_>IYReWE0Ks42;1H&p@*3j2Gnq{A5(3{b(o1Sc8l;$XEl(7TDf_1l*=A z_~N=MBtgJ!x=;_mpVg3NYVyNsX70{`5&_XtxX!0D75#LY$9x0nVI1nmOSk&iuz7Yq z*1)JY2Tyr;S3G-dHu?e2-g8+&R~gC6!gA9M1Z+z`hQFra^5IV^-6r=S7@J;e(Jp3i zoTDNC)j0%HY@^<;v)t%&UX8(e4|Dqy(lW&J41zHj+XrJXtBFD!=?>Sb$vQFaOP~!L zgueQ9x+IKdJOaSDJL;0Kz!~DEoo7jy{Kk?n>w6Npa_vm{+8BUY?emla(AO+u&tR}p zQ{Qrf?mNeo_cJ@kRoql#aPPUuMMLj$N(R{W?gFrwqFumPjiMb_Fjk{NtYD1yLjjm` zK`&se;wK*fkLesnFsgGUIjfgkb!yXJvjEJLdkG63D-$iV;xXNk8Q`%TJVY&bNtqts zy41?qkmOZ{a#D|B%eBr9@mLuH{DIM|T5i7q#(G-75yg7R1Bi5toe4vieKm<3JI2LK znmyKemG)~c1hKx!$aHjil6g55qrV8sY;HvHKu~6^s~qrgQ0D7oCRV@b8yWwMcQu;z z1yGiB_5jLE^ywX);QrvhXZYX${ci`y|I(}fpD#A|;eW6AyNCZ(;N4cucTZ)iTA30H zj|t7oSl}@funfPh4jT8ez_Nd?DRw3NNIUpKcEGmjibjkdH!N!8fv)+&>Y4WQ0=7-x zQjPVK9PqWjPGFPy8sUcmh93$e{16um7AzJV7It|dZNfW9c-4g$>bU66`hNJ_GrrY~ zPe0>TGhVf)*)ibtDJA)a<{_F`a3jl3j%mak(mC7Tfgk>$jdpXq&r-WJZtb-jAhx7y z**xhbNq)a{fgg5jyoe&I-=Dw3UV8z1(lyIpa9?YzKl+WXWR1fFeqkHLDvStL*$aL&nQ?s=AmkHfjm1ajmCi$Ae z&1kMBc+C2c!CBRob2%WBG#V^P_~bX5Re8!6$7HgM7z1bNv#YCBB$K6T_mj!`@J!F< zw#xL%)|NmJ-BdLR#HSp5X>n6EO^hg%GAFyGl$4lIlJNci?7i8N?7EU1`YUDqT$YBw zj7PO}CAE6cx!p%Cx*QhLBXds(yYL5@3F_i(Ff(-5JQL-Z1gYYtk^ zrronWxih@fcYa!~k{J-?Z|6cL;7vcZ?q%}s%*xMK*SDpWTOpmNLevS&1@BQ8t z2Os~iBGl$Kceysx_O{Jr?pK7iNt{!7TZm@3+t!(ZLfqCgApLfbjdicPZX7 zK)0FZqiF;=gq{i${`G*)(zTG0Hoq>_({*tu&Y%zw1Mk~RjsdaW5Vrv((W1giwh_Ie zcP@vqCEN6cvc6E(7ozpO>z?SW#qL*Nr)lI7;k9E|nXnxq?$K4qt6toLci^KEkYbH6 z=?+bWSwX6SaVj9?F4@d++LB5q%W)bnp;*ucY4|f;4{sIeuTYWx2>s}Nn3swP3*DfZ zv0)5@7nA0w)#^ZE1u2G$4y4x-=%y&YbHr^6qcP(0_}hDvoE>TnJBSqv7$pU7SNal- zPHIy3ngn0bz^^*#C*dpZV&>w2ublQ;qpK2dVogUzXt7O)GI*7Y**MO};FVO-HqqGt zuaa}Zs)LKOc5?o15C39uDLCU7bV}h;&f681s;^<|o`zGhSygJ?2AA@lO}+*$1-y-8 zjjPeQt#2A?bTuLs0PYxsGsqEj0jJB?_9N;Y>f1ASZVkA zpYYA?&0Bfjkbi(O1a{)n-6-_nS^d#JC3;zgzVRXns4p&8CCu=PAha1X#!w8V2?MX| zI8DAIh9u@5i=_5tuE_+>Sl>#xL|xdfb(_RRa;@=k;)!ll-bO5V^>|rdh;7g@=rAbi z^jjI}n<*iNvO%YUzG%^1SJ53s(RWbv9h9i|Bwfg=b{Qz@XA^a1@G5Zz_5=(S0b0l) zR1}JJ%#w(gVo}M&yeT@%BjU_IB<$WOk=dX`7&pB+x`H_$=zG11-zlwZ8X6Qf>B8X{ zAOo0=<9kt}se8B|E0UO2Bd=`R33@7Q#$qYxZfAd7#?DH{<)E^))`h5Lhrzm*%*EX0 zPR29@tYDPTqIu$hN14g;QmA{vnScc(75xLx7`~>{jnxb6#vq6WA zJ%FiYTU`OB`YtxMWwv{xPxulPlNWr+rW`l$5>Ed_o5@9|uQh>8CgwSVVeJ?SCSKGa zQvk4e0hxl^W?sm3IFnabe`alx42I3C4D$ve%v5j77O(IcZ?X%MJHP4Q;O@y`*bNo# z)Mz?z;d5d>g@G{D8C)y_VKT{aRswzSU_SLc7Q}q2r7YPCn>T-UPl_~W)?N0u_UM|GsZ>uz$(cK}?WPH(Frk0-QceOKn|2_Ek4F31O z{`F-1&us8No6H;kd&S=y|NHgprrHC$oCZAn%4HURnNBn4ml4a4naq~oKbSdcPS{}_KkU4#wU`pq)rhdb2`y zavRq*>%Ciy2!S!Av_op2M+FDx>XK&L4vT~t0;WWnf!oBd{mL>5g61L8{|xr1B0bc-xJwnc&4EoX=%vyu$gQ-pu)gviIL_ z_4f?^_h0|{T>Yop`oGob{~P~%#ortMJCUwr+9d0a9H8c^Pt?!VexA05%4Ya6Vc|Kv z53BNk$)}uD>a0@n1(H=nJ|C>(^+el8n$S0q?>kXG*X?WW$H(dTpB5e1$hHwuC$IhU z`-8eH2@JK`rWSrHIwXv4t+g9r$w=N#6(Lbah|Pvq+_mY~C}0|0YV+_cjG8v5Hg6i; zJ&pcNqocOGHf#FlOJ$ay8#^(9%PZ6s)Mbh#=*kKuZ5;Eom7xNk6 zq<`oDfQ9eK!>Qr05{05{ZKR1C&#n-?``pn+Lfj?(lmw4a&;9Ju`WQo!IJp&9++w1B4@-{Sex_?VcIgP+ewWmNxNYKv;iYE7Fx$19 zPW>k9E3AHDnYoxvC=iElKJ7toByEjEaS1A##V#!R-8HW4in@T0RUix+7!*51U^W-! zn2%TD5apo6nR;{l{}knCPR!q|OU)dNMyz`O@h2cw5;s2$x03kKjq+X$>vkZ$2FV(s z;e2-@7uzuZ%``9^u+*3!+jOAqj}Kn5@Z2DSZ90kpQsb^WC}B9vI$bSOk3gZWyP+!s zH6A?@>1eBb?kDWDuV13AvwV$nq&(?lMfP4!uYZMx6 z1^cj>?T<8P<>YM|JTqY<{0!M{vU1{URM^=bYGxDV<`_BoEc%+CC*DJ zuvs0{=shS#n2ALtF38pmnXYd{DUo`HOHM{RbJbR1bQ(?wJss;EN>51M#1$?(0?JH4 z^DqR;21M5AU+Givzbq(>%y^`Dv5S~Rqfa7$h1}U$2$H#$jI;qlPbK0s&Ni1dP5rW^ zy`dv7dlN%Gm->~u*7%7`ob?4~*VLQ0G@kVmhk#jYRGRx`ZHQgt`3(N^-~ZRS_zy(8 z;s3<9|JO_Y-u$0eV?Hr_0rP?OCH@X`BD~6Xn!xu9>`WxvXPW+*SIwx~mnj=}=hb|s zRSMV--_9+m2CjP4_VZn1K;RKFkwjLur~<9ReW*aRY|4~`BZM=PCJ+yNvxOGar`HQF zMtim28&h)p9)E~}=&^;V{4A+^+l{hd+n4mK_VNA4*YH(5ps0x0i8ww{(ow=-5Js48 zU`anl(vOjJ+$3HvHB@DBl8;&{7_yQI;vT$Q=;l}ypeb9G8?B@v7^Fzo@4D!qD*B=V z5Tz`OLORT=`z`u`Su<#5X()TL{!LMbiDocl71wy6;JG=nW)Lnpr@(>j`;l2iHuV)h z3oYVW_&o-_FQY{`>gjg+dk~&DHbAFZplJ9`nV=o81QpciA#FP919WT&6KeUWBjfTe zV5IvGI_}z+9jt{-Z!!7_JYf31(;bgAV@iHHqei%mI)$ih#JHq8rhyuzVIyXi37v5IfD8ScO+$)QI|A))_i2 zGpuVm#orllQNv^!B7Z+<)b6|e;s`p*Ywkp|uP!tpksrFsnOF!Pybz5J;>J4+uRdc) zKEftxVk#R9DfztB7}EJfV;GDbfKrpetw|G2a-1bl03{E8HVZ(2{SgE$hP+-TX-jkUd!MP?a z0F(9E4Sk)zbP}k zi;!h%?@~^|m)cDw5R?g0LoAPd>$_RlvCOdEUdeap3~P&kxMWDQu|$P9Wnb)sIAxQ5 z&lHJ&>Az?2zrUZW|ML*zmjCtE|GngI5C7u{k?+YzXhMXg+7Z|f_u)UnNBl@1`J<@L zt7Y;0fZBJ}*O@*be?a-L=EK5=wI9}f)OT*fhm9XLec1eA%ZD=`4nABxrTcLH!-WqQ zKV157`NNeDZ$3PHc>Ce&75#?~A3lEg^x^Y|FCW2t1o#N{Be;)HZzz0(_z}`a$RDA6 zMDr2hBifJXKBE7K^?u_=ZG16*#PX5MM}m)JKWb}B{v(BtR39gOr2LV}M>ZcBKC=DD z?j!q;96oaV$n|OSM=l@5d=&U7_M^Cu;y+6GDDk7Dk5Vh6)kf>iYkf3NJ5%ez)Ca2l zdBcJb3F7*!aP3Hi4PC6r&sc+~Vs5t^Ti8 zas6+d`G3?If31RcW_)Pq&->A4)*o#d^U)`FzP$VHq9m`=@RRFaD1{JD?~mw zRkiC$Ua_X3Iiy6Z-An4yWlG52R2?=PezLCXh5&bevUVov^j9!xJGkh{V7OQ!OVGTT zKUq7|SA1kkY$0^pmn`46P5wSz$DIp^dc-`Uv{&(v&2YCukGEC@hu@y-YSWFCzH>9gBb8vP(P;qGT1@x?EOHv@!Q z#&_C)U|?)NAWA6AU*Y@V94p=O!|NSE?a&us)7~AE5N!LqENtARF18a(T}-V$u{)KC z%e6$q^fk?)5hYV+B1$O;w2$35kwPqDwi)`wUUL7UK%dyN2bJm>oKGXre#$5I9}zWg z3lVehMcs7YOqN{q7W6AEM5O86A+5lG;xFYrgr0EQbtBmx751WqORl3;wMIR_H=2-G%sFLN78}BMBSjk(6~@bC^MNh?Frau_(yfWL9$srbyl6d?<%d>zU}z=1 zM_-ljC2vLL!F?K|O#K8|UyflW+@milULd`Y^x1TzXZ<>geqajHlJYPEp~IXyLD6@> zVT*;Rqg>wsYdvre0a4kF2&Mvam@(-)-a?83L)kjz4~dl?b>4N!3}q@^2amdgO}ShC3{F0crPfwoUGU zs`#lz$$=`iVUZg)7P(Y2qU0z9Zjq7$ik5ODGiQwQEj7+FU{w=;OiGRhQleAq&~sQY zhiTvkdS#10&H!(HS9;7c4)jQw&?}R+=#`0-(n#fij|Ix-D&xTO4H<{k7#7{ZEaUKT zO#*KLlN)LshY!)MsiL5cWGmd*+&mQC=xs5g#<2jrKtsQ^=(89d$M#94C}$7=Kas5f ztb@BSEN^q((5xCR0jFGaS3fnn8wxJ*vEoXegOE~8ySqSI-j>Q8%-C|AXo za3tS=KEmI!3NgtnS)yud%*U`+u;q(cqDBWcIu`Cdp2!syE-A%yTg2gGu!qT_>I*A6 zS5)@7{C?=x`|sA@Gx*=X{?BvyUv&wy<$t+1{`ZQ%)9}Cc{l8BjetQ7pXDyIULjHog z2l=}X^Xun2@oWC>lHnodSHB}(8U!ax16~x2q_H1H z1$R{%K9FX8jEX}7zk%%VOtVXG$Za;ejTTOhN?@JO*50wo=2P6i)`p%fh1S}5gV$21 z;Z5y@67}e~%C3>b)(Lf18(db_34EaIeuQ=?+v)_kqyXZ$$(8fdV79+vr2LiGUOkI2 zH}+S9XECp22K;FP$8GVo$2g0B2OAAA> zYp!&k(2;!rV9=OKVFtkJeUb-?2Ed95pqz1QVE|z1;&K{d!&-&KOnx+f8}0fw=w)JT z=+V8}LQI>rvBUMA(`jKmfElVn`Bj|v5?d=2Ov*@Xt(Z$ZLb@P#U*Q?)YG1foLpi2y zF`Rg0irdcmEYc;jlAWI72?kefCcay!+)RjW!5%ZXeDl>E6fO%T{b3;2Gx*Ox|LeK< zPfR=fFZ0HKUh(&*^1n`zi|ZIq?uIO{!IPSoNaOPzjyF=!?RlncVY8*cfiCvm#hmadMPZn~Q(-8B zlo|qLThN7l6smVZx0Q!f9d}|;(jCl1F5LFmAiQExT%qz+hB^v2bq&a`sJ+Ii*1My6 z@uK}a-$u+Da1%c=pYs4{;+K92(@nB76>8RY9Cb@uUB5yzXb?A=;3ngPf}0G4oEEsL zw$U{W(*|zB%v@9U@_>x{32w?hS_L-&IQKbNSCGN2pc9>0gH9!s0G|u%${-Xvv94UU zs|T{p&MDSab_o>g%2392%wm2i&g(?r4P?~zxlJNE+2?i%sr{Txba9IUqipTOHo2KD zV8IOr*2M?kvqnu?!VG0MPm?!ZGq4P3Tneu*1gwCG&dKvCnivI_sx83v2Rty)?TIOG zF|eA_b7o-imVI2xfjKw3In8Ds$E9+s4w#jNJ<-}OIAwgTtHnjPPWha6(G4XJ9#(x8 zfOC0RPvw95_jC1sF>LW4^TvN(@^>Qt2b|9mK?d^${y|t!8wHyfeQ~|%_29EU;EFEL zh4yv)>RPv-V`r_)FF>+`x8t7W3(={*GIQr!ARa_EdGH{xR(QpWh2Cylo%_Wxm&ZL$ z7rZ+4n#Z_r)7KU`M*nG1dy2kxp`pHeIf`JRAEvL(>*8KFqFpLFg=znde)C1&LDBC? z04e+mN%LZdrv5Z9uD@bHst#cRGY*hru(kbbn9*(TC*V>)H+m%iAH$`lxa~6~_bGYD zF&cHBN0E%L^-3hyx9aR>?TzPC*ww|v{#ARQ>4ZV9;#sy~iwpu|@$D_7r@k%ehe`Tj zk`9KXFPd~9CVlCogJG{Lpi`5OulIP=6{qA|G<{l&K_Kdt9WUm|4s5Z_fW z*av_sEkgGC06g_hAHaK<*3=;Yyn_^lgCT{W4~yz~s1K-5J*ZW5>N3T-%)XU^5ucTT zGL|#-J|I};YQ&369#jv2ck$D}GJf^X>lfRve-7AupMJ5&J^^G@xH8yc!-#r#dL$yh zOWoK9(0z5|2&K9fk3$NK?f69mEgAHt5l}T`nT6^(%`r?S&%BvpOto=5(b$_}NXJ6k zHj@kKQfS)*x6cy_Ea<2z`g#L(FDl0scP+X{BcQFW+&%jl)Jo52fb<2RP3}ZLCFq!- z7neh~z6zuHUj^V~P}_y!#`9lvpoqm6_Q(P=QH8L@mv@w@yBDpoB(j?ho^+G44bcaa z^5pTAoEv~$^f6B+U-i~BY=^#2TiC8)Xnx9AeGhoY=bJKN+3o-*KwkS+ot?mW4U}9& zl>J?m0q21Sx5=trr=oF&^BSROg6m2B?=^Fq@26bew>Cn23x)y%J1ZKs{Ts zSyQYhgNds&lPrd07fjEGZAPpFAYxc(Eh_Rmjr9~IN_qfj`LQsI9OnmUccO)q^&Lzp z*1Kg_K4zBT-aM?p$`DmLgPMf#e#-*snQRBuOn$()9`0nmSz>!S>aGE_url}#ACj=r zmS`n0R%3<+Uk;U(9WPt?X3$lg8+5PC4Z9Hr+XVLr-HX{ijqWvEyj1|r`Wz874Pd85WLToo_Jm;X+Grd)m=V=|NYy) zoQwZC=id0=FZz4)zj$)hy7<@mf0fpc?<_O;P8jXO;|`fEeE7XMpBz6kTX5Sc>OkwP zlf^xrIO{v*Z}$DcmL&0bfY%2ceyf%v^p)l*w~w-xUnkpjw&6dAZCDIy%H0dPRTN!I zJmoG{Pr0c?BU}#3fFuUP7+#$%fmaq{Hj<`F-^UxnyM^JkTDsqN-gQS*uiv3(9JYh) z55?yl{LH&!QV!Iy&R`uDX0WbrBWQr)OhswkmfFNK>1Yy|t{3!G38o93(v|d8ldda@ z$k%W_dWQE?nL&& z+(TAOHl(%T9VFit2dseXkH8AZItBI;=Jn<@OqT&z0%x#s(=lw`H^)O4QW~K{0rCs|@ui(_x|VB< zH3h%*nSqX&N36$U_&hQUJskP5=hz$hDPYZ10#(r?e`;0~*94Zkga#p)VIF#p^%yo{ z2H0G517K@+^=v|UdcL{H&>GEq80^8JR-iTNAQ@VNO!`Vjd|+cq=F&i6`UhE~EXnHP zuw;Q@>cSgQ9D&yAy__q(Y^(FMz-iD88nk?`T=2)Ns?J+Zd|>wz&RdOX8Dv?#q6b-l&Q?} z1@eTXId8`+j2CaRQI=#DT*FcZl4e7D#rLQ)ks-FV)%TIpKDpm^t+nT1U&A3 zD7_j!02QZu&K+Z^-o zV*dcV)x}BZ=^98nURGsxU}d%xf-dMbo^%^u(o**N*^5%!KbU8IxvVdj_2pPb*W)nj zjw|ceybWO~=tnKODT(z_58a8(uou+$o1_a_A68UBsJCW%&phqruBms?_Rlp?cRsiV8Y{cS4E=K%<`c zCd@b5=w)iM4+>T>l5{r#`k7z~ju{HX1F|~cF7fJqRXqd+PCW~DCJGSTn<9*U#Hu{F z%M^in6_`r;lALPVWH&q|yes(u#+}>(z0A>_$o))!;Pg`HJ*e6{ErljMubAiK0}CG2 z8>NU~X~r~i0bpCvARwJj1hFZJy0T#&(TJyg$4~qO0@m|Qve@o9a0V3E^x&Vj#IcR~ zwX*5JBa*~kY$dE#Y<1DQfdHM|a_O=uae)9ECb}fmY#?9Ker%zb;m3Bd77TPsaaZT=74f-uXXY z^7qH#f9)G)`>J@xYNz$O?Sthm?+7n*4qx!;=TyFcR#q1;=l(I{)e@Y zbp0^5FSmKNjz+G{r0;!I;2X{7Ger;z+vx{MEA6(Oo41vZHh(?jdFyr z>zK(`XT}jMuh{*igcOuLI^NW;m)!Exy()?+?9{j@+rILROyci36cFkw3rkE=lcbo$ z*6}(N5F_9Y6c8gyH*Vp&nISceU5B?bLejWI;gwQntDVaB!|P1|Al@hFSOp!cl6n-_ zw@wO4bwLCJx@Ns`2MUORyX}dNJ{n>lqJw@V2dW+i?`RhhoO&7hk?!aACl>g)Mo(Er z5(YPvxX#AH-xr`Iwmix5PHsp|AY_}W!|%*XijBd~#XS?eabp)fO%&vh`fRbn>!a14 z6`pT!&~?nO9tDG1#+XVYT^-v%}cHiZQY z1V~{;1HtAEA+WYFn9;ySI}d(U)`E{(SnG{ZIZAtZN&LIdl~CsYnk zj6i3@s+aa@daFKAUfF)f&N(AydG!Hohw=o@jUEIGY{@4~+F*g5m#wfs`kpYrKqzP_ z#F;Vr75I%68?{lDkpf3;WK;(zb_pD+3Q6Y)RWKH>ag7GS@JmuCU(R~6g= zUIzKyLGW7vKD^gsfKQH4FrRE&=zK;CcBlkXiQWokSSK55h=~O|IC1@92_U{dWF%JZ zq4V_v7dl_twoB)$Q~UA=osZ(>F*=|8>>8;LLt>xQXB3==1>N%Q2(eyB`btT+yOr8! zlwcPND)waCM7pJIf^lh5pBZv{=%QAJ_IfkV`a)Sh7-J83Ski^83&JE+B3%z7f<4GG z8?RsVgNp4H3|tRSC0K#-zQRJ*g)+sgQM(kQPcd=oB~EGdHi4}&o3PLpVeFnGx9v~BD)46enAR%aQh3D`7;!&$?OQdeyXtFFN?=PGM+G83G(OQ$ml zg{TTb8{iq8VrJ4o+%V~&r`cY_v?x^8u5`s9yKWZKS^|5Br{^bEx`gRwCoyfr1f&`~ z3)Z+ze$yPuL{Q6VBXJ|gTMMZed27(k(Dq80;}ZpY2+Id4ig zwj(>bRAc#h@?2Q+OLQ6Qk&rfo{B+*aeVh#Y{>NprF<(;gx3iwMoG3?hIp?8FbUEwN zn=bdK{ypXY_qTKNzlN~&|AY9(|6cL;$Kii}BJy|6>Zs2H4;Kn|f_`nPn&Rh|pubz( zKAfCv;Xbugpkr{UkPO;$;T*_!u9H9k^!q;n?)woD@{O@^1-RSj;Rjf^8z&P$CxvT> zLT_HsCs6py*2%ed&FmowC(1pViK~ zd7WrEr6I0$nHKH@30fxQ zwGv}-nEB~!%A9R$)aMYn0qb9bRbAG&gQO3FT)@ZO%?<_z@9A32hUI&Z}a*D%wq$Fey~roagWA!4$4;Fhdn~sE^S!` z18cLWOrFxZf>y3Jc&4m?n@Mhy2co|I4dO;zK8?8f5-8_`Lfr6<1#zoqDhhG4taeq& zT|Lf6yRo@1JHmQxONlw znAc(U^BH72!q*J4oRw{z(|k1B>2!W7g{c$=GWRK5G#heHJDdflJF=|11733t@|(Dp z-5BRko0?CSrqUAY@$9Yjoy5@ct=_=bjO#fc_VKkE-BJ6|g{C6M|pv0eFNwj`zH~-9*zyJ?R~E{+;u;>s~;bDKGR;*ix8n3%FKRW ztjr9F^DW38s|zzagxg5C((Rmy#D&d^^qK8b+_gn6pD62!-3czPHilUH1qmI(8`t3` zp|S}&KAPYmyuISp6&6(#9-Z`gbXP&ZkWVnOD1?&2;ApuR%iw6GHbJ1ktdsOy0taSY zm*-?f6~!H)07C(pUTOFD*`@PNVS@+w;bPeb;Ek_uX)A2Ex|njmVr zZl9lrn(l0Di7<<+1TG86GMiB)my`z51Y?L{TeRWvL zlwg&Km}zyWV5O!6v@?&(nTEj~fJ-UlErUziWs7U;SBQzW4TuS>f|#O7R$)v92rxtH zQL-H|W62|c&M9gm&XK|HM=2m+IFxBoXoNRv9Cp3>EOd;2|9b&qTFx7{% zM+j5yd`tnD4CLnlrf2Y<|9Z0jSMA|9`oH+r|GnhzjsJY}jJtiqXoJM+`PH}mG!_uw z*j-$pv~YoV+jH}B`SmmtwJxZIY7s@zktDF6;yODhX?75mU@FlhA@`3%ia}XVIdMxqlI*us5_8mDq>A(p!0^jFB-^C!}i{6YbIWVi+A_U3xWkk}A zE$OzF^p&;|CA4~ zHgk|LYV}1agqAKl>i#ii>Qk=qk>m*<`|zV=f$4Ew;PpWrdk-Q0_U91St>Puz zJIhUozh`L#(+~;Lji|2t>6DylRbT1tb}ll!ggvjoOVkUBATe*4Fw`&wYH|dLG1QdE z)d``dlH%aPJO?#(wolZ6Q==%giPi)=xpy~YRBWHi)7dl_o-oDX)| z%Xgg65RKin0#dgKY6>lL>(fwETHW@cm}5p0SnwxPny~XYG}bbq<-WaUtX1#H+#wtc zE*#qI*9nl;4T7uFr60>{djH+`_muzFzn;tgiau@ie{cTROa9*Y-<=Df*2%(G9gZ3Q zg9P1t{H6FGKf#N>#dp53k~H;eU&a6Mh&^7I17MTz`jLR4KNR`FvWZeyik`Zd8mlSS@ew{3`ceP2IF4N{(^fl zUHl047snk&g^gYT)ilWb2)M0R>2vZw=?recZ3o}bu!8mio%UQ21aeO{biRo#x!{r^ zc+QVq*UPo1I8_`dSL07~2z`t_UlR(pjKIY!xD9KAAt74~86EYav(Udl5Q5-xAsrc^ zZ^>`qHkx}7Rs$(If!pBXT@;FtyOe}BO5)E|-_qIiuF#;O8}zPN3Z_b#=v|(8Z^QtD zvdMR8a%ZhgFqTG!VG&?&MUh?nKnq_vn`!RSsBgM0f ze2!t{b2K620+ps9rU>8TjqSWJDn2DABL>G0jS9X$W?*4q8zBt^$pg=^ea^>vzTSSB zb=4aq1Ejbo=si*Ip+#8ipla5K6&)HzwdJBO%1BSY9SX6!V<`OSu%NCZ+0TN`ex~pq z8~UQT{DTf4qs|};L#J@o1i-ATmXwDm8l8rb>hvipoRz>IUXZ`}R!;=hSNK*P+j%UM zBs6|0(1Z6tv5`tphUD0QUkdcdIJDO!@8VU-=MyQ+ppO^OXL)vd-09gjgRT@dL$4I{ zwTtco_xc4Y=sOtvtSLuB)E{6t+z~qnMR~Y88;3F6Ns>RD4B%6y&@Zi?@*A9`@X;kV zBBB9a7(6*Dkf_8JBeKqWg%Ks|oq!EZM`pcHvf{-zj+X+7TIYN&NTl(h+KYEK(GE&f zJM9=|lxW~X%{zZdfjA>WGbZ%8i2X_mVMT-Jj3V~qB7uYuR!j&IvH~aCRkCETKWJAG zUGX&};rKlc7QV`2|J|Q`wswM?m9>+ToP3|F@wc1u z@U_eHGS8_ze7I+hDne&wR27f&I_z}y(9({6idVI{=^cu`YS9lSkWbM0?y*3KPjHO8 z!lg}unOWxt{uA`i-hj`IfchrD2SbGUX6fN!McV&&4K5M`*RUTI7&hlTG<6ts-)Qti zLy_wAWt)z&ecBJ!+*7ol4dD-?bW8h@U5^d2>+rh7_cX>jHfR#)e2 z!`KduoP6UZDJZ8d$?_tr^Dz%uosTIW;W;f8;wCF!Z7N%naN9XRvq^a92;V?>peNbe zAUxKQak#W+m6i`|@mpOT%DgqgV;hTVLU`)^IRmRpxUGx#w7f`H*Yk??6JzostgF|x z-U$$wE};g4W^3i-G{}=&PY#Ye7NP-xfG!X*q9r$9f1-{C)oKs;aVKNZLwMdi902(~8V$QIE@zKUaw+seRjBZfcQ;u=uyKyNbaVY-5 zXwr9t71r!EJ1DHvQxPS6Y1auwcLW$6c21Ca!IH3j2_s^xkC)XkZ5g#Vi^uwwDew$0 z5}ON0`5f+R16t~J&7p_!f@8% zquULKX_&&a=rFaeD2xB-3dgCv_<-IJEl%SlmRyvgjL$i$`=_8zcsI|DY!r|ujBYfn zy$pfEValtQ|2PEoGyp|mbmte2DTEXiXAtzl2%Qj97zDl4)kLo+AHO9_^lHN2j!P5=Z6q3O&XAIg^WAG;u|q=%*t+T^hiXaX|Vi?IiAfSb!(z zvzeX58%D}$=ai#UW<{U^o&s}_5O{)O%K)ANI&=4zm|K3j@d{fTtMg|OtN>mv9geOdUj zzHCL8u)}zqYZU7wCa0E9^aifvT5VnNa55TK^5AoRdpP~Uf6w55|N8f{^Z&(n{=Z-J z_s0KT%>RO()9OXoU+wU7TLv>YQBo0j0(>l=U(E<;{Gm_9Ikd2T$LD0Lrn?ny3h!Bi z)Fx7ckwH!mtIt+~3JxwRgJM?kXyPdqU~@cczRSWyqgxE&tk)cK3La8Y$w^mTdR zjs<*F=k0K02g>C~%K>!Fpt!_NiY?jeN`V*i{t~kfEYWS2>^T^v4&)!II{!h~U9XE@ z8Fy4AFH{Q-UKfE+H%9y+OD~vr)19oK(v70^?5@zRJAo^H;z0tNQlS}o@rw?Zm>I7@&>!J#jem@Fm8k0;r$KlE>KQD z1`j)_Z36GGekbfMMq55-(wGJE&R3kV0%e8nvX2SI%PcWV=Ehh{o*F}am-WQXN2|~~ z>ubwZ=$-A@-aTgQHRi;OolBb>fVg>v^E`l?;k>NiJlB2p1l5Oh!bvSW#yqa0w0 zPXhB&!)KoZ^JW;&VA8f7&Xy4T$aA%|cqqZHD(i*86^rZ^4B+tM|Ee zFF(igq?Ptm*O_4e_s_`re)hRxeb+hgkS}eRKj4D3J07ML@Tp8I;7CWaqMhrn)N6q=n2#B-WZb8t!;^`UP(J~CA;=lw>=tnu_X+rtJJXeF|m1N$;6x74k8)&Y?QKzquHS~xs&B;Y-kiHG>S$(qbvUh!BM?le;f>aJxD2x z@5H0{_z9H)fJV0Z>^eC0K63Q)^TWgMUS{0{B!ePnODypR9vp9gh8beo+^p@lxqxfRWaP3Y_`xekjU!-*_w0tYI|?yd#tT=xCRdk_eK`!WSS%>!L{hdtkmg!$ccKogCdtCgj_~=1R^IhAyBpZYk-Kv$i z%{AzJTHvjKM*1_lWeLAxbSr4rt6~Z)=$6Tl%K~p%2k<#F)13Fj4AjgtW($t@*Vt-q zyg#47T7G}c)iD&oDw|cA(Q-ml&zCg3<-5q@4t&em?BgLtt;1GvMYaMsC4=NcoS;=? z+>gi#VUR&+Y)->+wrdlasFsT}f^F5Jg~r5sGUXung{Wqd^M?pmjfk)Mp!0lX^dmf4 zUP(KcucaMKbp#2expfV&tEVyy`-;exy>o)R_zDDkLF2C}*eknezSkZ7umAT9{`dEj z@jtL;oB!|a|NfG{KaT%(K{JA1Oae1cV|`yh`5KYp3?nc))k!wJfwP})xL@I(oPT_r zg7bJ&8UG&1|5OSxDlpQZ*kC30WHiJE^CA2WY%qGD=R$^l{Drt_>9*lP|dMWxX12 zSJzEm9iy(B)OFc;tp9rr(MvNm82}$Bov7yC>|5kzwyE@y1_ET*Ug|FD5q&G2+M4eapSL;WoCWifUk3In~ktg zY>j`D6t2f7jpJ^A4y@NJ=~;;=h(?tE{WZFo?~A9`CLnxR9{T+RvumHQxK&Q^@e4_1 zJPc;l%iJQCalAkFxo(I+`{?}0h6_ZrG0t$E>8FJjrrhfDc~MrH&&o zaGQa=HIynm2ETb!b}NpVof&40o;RsOFD6DmL2&pRg5g{Sw4l>4T+0wQV7NAjY+$%h z`XLhzhZmY~IB>SiI2?#cyawWGd-NKJ!{-!pvJ7R_h`Q{{oRY9!H-|8rlhqS6AGZmK zgXWz{l23l4^%07Rk|m%HX2E(v;!+I&mj#Jy_mQm8QeWpwQBYi+3YUp$)?MNc-N`i7 zESFDlCvz4j)bgs+hHw^xo0Am=1Z~N8PTed3_SE3e@;t>MHSyRkg zNctQ8J%j)K^FN)d|MY$*|KnT#`I5gs4*z>K^w*|FZNNBQ_{b68i~wF|_(5(nxF3=W zAnrT7ZPp3>lh_RX0T})w&npF9B#iYzw2mbxb@5a?og!$T$r+KrACC6@0^VM)?Vsde zehw~ftvL@E?@f1~_u6+|(`VVvW@YAFZ^zfd1S6K$)M+KL$N^Kx;5C@af`O)QT@q^G zeBDeXPalyE{F$FmJU!uri_bG zA21J`*jtn-#&_Z$Qbf|LRZmA)Tk_yWDp#M15hDDlR5p4y-$G>@U>er~E&Q!7VVJDV zFq!~p0-b#dTa5;oFVWSGh-#k)?rDsQ&3Kp~VKWA{qF)vt`#9~QaS&j^y-a7>j;xDj zPP%Be^s}CJV5XmW2>Em7pVgKh?B~osv&FCUGZz>ULi(9x&+IpBiH=BbB!`~iK;Fnm zxEPI{y!bWF)ntyH3_R#(Az2W4rJ!9lfpH4$!kfemJjp(r8{r|Y1umb7YdwQ#rCRgR<~tCrI>lePWnklgv}}X! z8&z#US~jKE6IDQw_VeJ_9Jf2_}g5kPk@OK1V%_GbPAStU}3uwkX>Fq z9SdS`&pwN+@6uN)`bvdoaNdt4Gwzv}%>8;aW%i-Zh>3twy7(;V!?G@rtSqAzfL>0* z2{240oUt1#AE|B613fUP;4GH(bBnGFo9Lg8N9{(b1l?1sZ+=5p1!;K1HcI)`-;<~^ z$huq#y6s2Z7Nc$h6vMP9={-l0EU^pfr;C~t5AeF6Vq3Q9>m}XCQG|yWM>YbijjZ1a z1vqvQ6yQ|Q0Y_*UoeeKqXY)yd9Yc}XX8qJfUzEk+LE&R{r5$B`9CMqWQ^?a{cn8IZ zj?|ixL`Q1t3T9Bw@TMu^@%J3@*qL+0r|ua=5$~+)llvC&b=3lC7@N7qQqf5;@e${c z|J`vj>AFrp&-h&5fuT_hZ3$-*c$@gVPfDuekP43zuLWPeIigBD?To8b23Y1E=Q6;k*f#U2ny&HK?*BG5%_FYPAZXhJy3-7S<_>)XDf&jI zuT>-5cV-QAD(0yNC=9pNS~EGHoaunBEnsDo%I{s^)8sZq2KpStHrg(h{K;rVY44iF zJS}yX&OvO8aYJmwkwJ)UG~Z%GC|OVm4_be#Sx~K-Cwg0Vq<;>t>ukP>+cvY>@Z9^p zX=x)YtuNaNj&}i%X*6fwv{<&jX>P^z>Zx2=fIY~CGHYsJFGR19J(Hs%w2ACg*{1mv zS7E8E)f*RNuhe^r3$j<=1FSB1AzP!A!8t2vuNj0YX>h*8VvBOYYgtsavJ{}JR3A@! z&?+9*R;%373^iS&k7Z410?_0&&-^@sri{vc0M2T=G@DFMQcCQ#=xa+X*&(YnsQ25L`216RFjI+u$3JYh7Vd^5Am+ynv659arfD3W- zOk>&3rJYslaXgae(wQ6&SSF%LV9ALO@i@sJLzOCrf3b)ewJ7P;!LZf6^cqmHPVJBbzP_iq+;*{?iqcE6JA;J3`oHx z6(lGIW{!bVh?E0sl$PNI`5)np|GeVwFNyzLnj5D3YfR3+ zU-^f1C0vl^r}=GDb-vpEq_yu_O~Cvx4Wa|Cty=Mjy$NjgK_;+j>e|mQuKrZQudCK4 zUZdiqLguc&7!2a){EIGV`SHFxa`-w+e#qViu6p%jz!-J-RbU8@m>E@gid{$u14Q>@ znlg6U*IQg&9Sn2MkV(9M9_fiL?bQo^Kxrs_`whKeTk&SQ3oPL! z#cl{&#GdLnG zA&FIf^PgaE{D31InvW5n6uj$2Mq`Qvs|igVoSE&p8e2-kO1MSI7Hx#a5L;m-XRMYj z);ALtSjhzAhHOy|VV+Yq@pI6eilKxKdZ#3`>~Eb}P90z(;bQRKJed-*z0B4Q=fsfl z*qqB+h+j+$IXb7&qwqj^Xq?|d|GII0fzI^O#`(dNeWb~_jaygo!7JbV2lsIr67XvaAu-5tqa4A9cwh}i}Lyv;|4G4 zz$*hOJPhw3M?W$x;;AVLW7kO(eFxhplmc;t(&XCQAC=d6E;zN$<5K4cHHiju2b!f+ z&We(U_b#67fQ!JNfdcX4KP{8%zy7%c(=J~KUvkuq_5pSshT0dwAdI1}afc|V=#znM zIAqcH_;QgOMvH2yGAOYa*1^%pJOMozBR4vdBhUw*eFlB{oh=wKZo4^P<6%2p1&_D8 zT?ObAid^cgFG29bcd9NQ%E_1zbueBv^;6xa@#uOvw1H#;xSOZ32Y?(6#{z)w+e% zwcX^DL4iVmX?_V5vIe20g=Dm1LfPdoi`?qn=143rC31t{X0;+TfnHG}x9GgrB%|O4 zIjqh?YlRFbuc;ri_H1`KHn!Ca3N=;PK@!E}Z99I2gW~LBMVdAZ2SKt01{?&=S~uVz zS1VswMzs>b#Q_IFaaQo4me?=#W5EvW^fE(ASE>~}L3o7SeysCg|I#8(Ng zBA`*0gVFhr3K!VXEIWM^;4iWF-Vq3tyAa+RBKdSH$wB-;qNF8`QO`tkoRQuZ)7AnXNJEa1baFo zsZlQK@?hd6^$=8d59;m-tHN#;REq}nAfQ_GJ-j5BugwougbKUAm6mjm(Cv;10zZM# zb%9-ui7|NTavR=gd=|%!i3?PZ$KewOnAs6|cJ?<8gRKPFn zB84Hj5;vLu+AmfN3E7M@hSahMe$GO**7u|pL$W0&g&~o#4-3^C5EV&bNOT7pL^84X z)dL;;N-Szua~r25aA*z{L{FCNcvs-9QFJg!E@=?SL~WE5eed)&hGe^fZuUbDiyykl zVNb6Hc4>se2;I6AKQ*Js`2ituk^RtXrNh9Gnvv45ac|G(M5xwGRLe;G*Emn!KM5kW zo}>xnG?Y|2>E{4Sa*)o}tKoF@af9?4LZy3|-H@w6@$SGasfLCxNufs#>GbZe?~VQ^ z{5^yJ{q5gQ)&Dh9vkm?SZ~ym~{QYtG-<$tsz5~~Lmicu*kar)3#}jj&lJjKz4c7gP zRvs=X_sr10TU-CZjXc&B5GLW8Tl!DoL;VGst+|5(^~;;+7rWz^GMf&X+iw?p=66JU z9tV298{@f!?i}DcGomwNIWvkg<2N&MBbbe#H8V~#BQ!HMGov!kRO8=9vw7H+`T$iC zJVlTc!B7M}kvkB?M6i(VzxVq8rBlpK9xjheG|$O#Zn~=ZstZs*f?a^HpeCZS?LZxNk1sSIxNlv8yH+y3 z*E*KP(z1Q^YZ7`r!IR_EG*7naD-G4kaJHoa5h}=cmOry5MMdWlQPIigwqHND&W$IB z7f8xT`X^!#on)VXot&)K_--aQ-1V%e%yp4JQxN(io`J(jByHnRc6nXU?QcIa`@Kco z=90eaB}#GICQ7BSiB&1+_P&kVo)IH_DskGdqQ)rW5bk%tnvxy|oJI-@QU3-n>Vh9> zr04`i{YJjw_h{}Ht+CZ@YOSgl3UK<3*S`t+Fua52B`RT#y)LJ3!@^#e5asR=-T$c8^6{Pu3A^2bybq~X*_}jC9tK&ay(=(W>?to+D-yiciRLxY< zPylBg7Os>`)p4eQM#MMd@WXNu7L=U{;u_QKKQfQZmAjq-SMc&Wn|d1u!6;mvS)*2ZHnK&dW_*_!{33{MhhK!pX{DN-0kL|o5bfun83ogePIyID(TwVIg7U*Q$@Ge6>!RSgLj-vj z)mJs7YPDFW5YM|8bz!Nd8Tp>>@yNZ%n|7@;X-2d zaG0A7ifc_}*kU__TD4z|mHZX|p27eA$GQBUlv3RCfBYN&d&S@Hj{mih-IP;NiJ$eM z`6T?WSCYt)OnLR{=Jg+J`8icun&J6maxTL}v}J1%SK;xypN7?a2TI3J`(RXXbw04- z@0U3vLik*Zo)5PjMoXJ8cMpWes2WqWNZ~MM#fMv;S zm1?g)cO>Uum{zjcwyV-fYm@n?#kqi;?a61T=8ITZub zqIH#!_(s=n9B~*l=@D}cZ^Og&OS%Vd8=Z#~7QLYDhk7+$@m%zCF|0+6rSZ1;Zdr$i9V=sLRLN&iwOY2j z2#YAMJN6voXI9{|+G&^7_uF#5T{^@<@e6(yoiD3C4?Kjl;Ab9C1~vdRe~Br_Ri9^5 z1Umq0kk~4jRZhz7K&>Iz?^)v;~myBkvDjMhdFz% zG5{8XsZ|+vaxrHOpc!ALRB{&x{gasn(1OW!0?@oq?Q=n9n=8|*fZmyhh>11^j20Id z%{rH~|988I0i!iNo-zQp*=xfmygN30vZe%O_!J|)Ll*0$uZZClXvB0 zv0e|xLlmuLyS;{@bs?t>v-?xY2kuX`^_RT3Kj9S=q84HB*J`+0XA>f7&)`4*{Z#&! zNi`6+{I9qF_e=hMcl_s#{Fv|mmfbu;!aWSHYxC?rQ?=I?rwxaRobBzInPoq}T6o%> z`DOIuyKU_ky>fWMhy1x*tvM?A34h1f;Cuhorr+%zz9laewshSP4=50QS5Qs!Fl6L_ zYp6~?;=n$?or#egJZ?9L$QpkeL}MRbEcJX_6iUHD91gs7-i%}k=4D|L@E?NV{M@*B z%hKj%UMIKR4dwTjsNEj@u8n(B_}=^VgF@F%CE_cMl!|r9V9-taOk4#=SzMM{Os}Cj zxo<#M@bScnCsP7=f-2bU8jI9%P3TH8SuvHO$;5sMJ$+I$*5Q?TUEMmQf-$uPBD~r) z8)7aqqB5`)6ACO|M>C4@c|{r5*6GH6enB7CvWw*vA!(eouplJC=Q2AOHCP}eehu}8 zLN4Pqq)RePK&tN{)<)n1sH9>5kU($0^(D1@>H?9N+T87zWOaOs>*6{&YLVEi=I$y^n1}PGSvEh3dGv25Gv?vTG3HU*NIn_!=pp~OB(L6cPK^w7i!xLjW;~z_ zDY8(zk2hK9{=aANpTD2V|EVLC-RS?``QKjj_r`zDo6EOpNE4IXp#p@SDdP1izy#;a z^&6KPyjt%jxHj*XBWUzV-X6@7@w8dr??Jve@Vhf+{?)$IC+^Z`=Vfp5Q;sUHm%V6| z$jQk=8OvVpOaDSd2vUZ)9A?zO#;&UAxR8 z+_kVE`nFpUDB-2zkXzD%JK?rXOmZRVMwoOPOuCkmzG`BH1!xsu-=m)_={wkqWazZ~ ztnYyMNX~VGaiM(R!1=wcHoS}|l+NdYx=nqf^WeJ>%Oj)x111{so@e)h)DnlKg zQ&;~_fxh^De!!sl3i%(lh^SlZi@-36A){OUAuuLGo^Humx1g*CvYlAUU6#t)z}_K# zH)S{?f{D8Qb)DG!%b62#z+o)|I8y!HY+5w1$89Meo

3~u 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 L>Mg^!)ADxSxGg-t6)q%+^(}arboo)8*X`M(hCA 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 Qozo2`RRW=^mu_HG%@&vA2JpK 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≪qJ>-kKm8=9o^h`$I*jA84=!b=yKw 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
Gog81Fz_P;ddV@Aezheorgcv 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

)j&dj#?6O|U7L)h#3wV#JRVHeV2Hh@S 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ĩ)TnoR?t3~p--LnWHpaD!UY zJ8ZjEkGa2y;hRfiH5k=s*hNFLN-CZ*WP@-8D@#&Ha5R6~z=^h`4Pb2HT-rx&@CnEq zifm$`@d?+6GDG-bcFdeR(fJV?uWK#@-jzl_-W#?u;_JsaH1DY?Q0nNh&bBPa!~)@Y-FRMYBCNBUK8})>!Itl7RB>`jO*+~-sXB;i zqAo7C7Gx8I>P=2k>zdSr17=WrS%FpH9E5Y@3?c4+5TR0d;E3yDEC~ZfTvy;qe9>qk z0^@g={)p4eRG%xeyUiwMtWdxz-Wm_x z02EozE6$d%F=irxGn-I{-PW|ZW;}~5+Z}o55^gGa<|+{GgMQWRD!Gc#wu2VpJyAn> z&|2b6#p06l*cp0oYY{vHy8vq+{x$1j$*kq50>FI;;N8POwn-e(<$fBpgVfjB<@U3= z0uFBn@8?hg!DG`H1TMXI9*T~77YzWV90JOI#ty2GVymZA$X}(9n0B;Y2oR>1`gKd+ z518y=0LFP(iv|>iW0YV_3?#fKyh6!Ir#jh`Iak%_cBu0x zKJWAk8T0tVeR67HbjFi(LNo7}%@LPlgTV7DCwKu=zkV>4Q6!#=9UAiBQO7YW zSoRmFbu3!`{ysL=!)w8FC{~Xpi$s*#DQFBD3&yIEBplh>*1@rVLa3jWp37Me54NSv zI`r_Y>6^y3XY@8%cg#I`VYZWkX`61OgKry(Js3jjq*pzd9+#XSf%W+)<(-U;as`xz zjz?jMYuHFKTyuGysx%vX66bG>L{78%*y><4_B}MB%Ss-ueg1hq))(FtZA2}XTI4y@ zq*;;qkysCc(H3K0@c8Zxza|b}Vtp&h8kbqSgDhz7@JK@=Ty%9z>$JdZf7N{E4R%W| z&rvSG)Utw|4yi12%_A>CXs=9a$;MRJR?vw)I%a=$){&YE-rTu$4fUVB3VY13j{D|v z(RhgBYy<6l|3jQdbuC0Ng)@`qlg=^c6RT=ZV2MauPJlPY^@o|H}*I#hCnmd8M>8mH$uTnN{-t*|n+Z-PH8%%QU?k zs*y65BFRnFR;02=2emY`&y+BxzRD17lM(b)hG@Kq=*j9crO0Ob(Nhrzqcp;HpYMiYtLU8g?!aSzq-d;w5k)G}20Sx5^BHD8zCbmQZOyhh3YI zv>!oGvAj&@0neUuiu^4Z31~vvGp1e(^UEmRFPeTC2Zhs!x#LebFihybtk3NQb*MekW2(e`MVt;i+?-A(pJZ4RX$gqyHwxvo7ez)r4}EdupBP zA`p&%)IvngTG^<)syWL0V7ZE`60T{bZ6z&J(VY#m66fY8+AWEnpl8T2 zK8p*b@PnR+;*(lD5k>Kj$lzq4#6A)hb=gaU$#O~jW;#gX((rcEt$Gc(8G8ei9jHNZ z#)Vv_q8(@a+RB&H^;yoms-DLCYm;c3?MaiUD%B8ME7%!!nb+27?)ogHF*e|&I9;h{ zQ0j#oXq$%4sWc?KW{hLN>Dl)-NVdf`7|1UEK)4F~y%*pwSqv?;Y&BL4lM|lJpOK0e z`%yR}??|cw_#{XU=E$U~Gjvk^_=uIRTB&fao|ati{Hw9z zWgd(28UK=^ex{Fu`euHN^){`qJUy{5%+IEpTF$P?l|V!mCOFe5h-*lQL6hXgyrf19 zydEn{)2taq7fCWyWwC?L`r(+;P#U|%?$3?X{qI$dk-9&B>)rQIfMlElmqfT~!WiLN zOq4{50&X)VZylla>q5GOCo`)C%aNfQ=1a`+VA{x&O@Bt7vU~`&5ga%rN%G-L1R54^pDg`T`mCU{*Mn{Y$aYtbCvf9c~tr21)#2#z574w6JT`Y@2 zm@&k6rM9F7ETs|WbyOK%Y|;%Wo>1WM*Jv_79D1eCG*Ze2<#^TRhKJx64v{Q|_qe(BdK zuDEopw#A8|zoac1Tn!cT!o|g&XUp4*kF%%i2s1k!GPEJ8sa;+nx6;L?Z100-n z^G-AG_;jOoQ5o({aQ}l(I&){5vRND21fz1;a+}R-=l%yJVa*l%E?}!_wh4E?Jm3?{ ztxl~KVj~lm7FQlyw%sthkQ2wJHlq?CLZ7H}mJSL4Xd#fO-XH;}&OiF&$Udjf`10Qr z-L!!M;UV(h@?zZnd$Ckrn#zAC@_c6d@1&`!A;HtU4cxXp_|3&{Q|s-|ZoU152yT=B zW?-N|DUnHj87iEySc@8b6}#|;M0YPam2QYrMlx2_sCm>o)Rkiu{XdAtA7-={EB6k~ z_v|$ds^yam`G$3DA|`$5jhM7?U#ulxiJ9N1tsZ9Z7h@)AhD~C3CKR=kyEmRA>YW3& zK=zQmEShHHF3OxV?wXxSSY)L@874U}2GGf_GF!4QxR~kUNZ7=%ic4JYRWIWXdxZ#r zdmBiz?h@ua%rwP_cB-6&#s@SO6g6f}B9>5R1TTq3OEtFXfRl6t46sI*5u-S$));9D@{ zB}-me^6$;c%J^h1)r0|73Xv~WZU)h?Q%kL>rPj?YwPH)_Gudnn_7^6Pp^8cCV zkK45WT39Zv#N+=iuau_oe<$+9?7!~X+GeN~jLC(M^Y9to7%T`FNe)pSV$o9;COw?h z&uG>OartAW8C-cr7-ytfjhJkE7tWtcZ#@%)nGNl4~ZlEN*Yte0F$*cMpH2pFLY2L zya=IF$9|rem-kQ6NgH%s(+}wB?d;2W#=ZafC|DWq`Zw(U2OrDv``^;yRR3!tPfY(S zv2PKR#QUTysq+?%rLmF6m>~f%vKn{;n%WctFkYd+|2bIBg;?G{~Q$!4Br3c z(!z4w|IaF*fa(69#1q^9Q~y6x|36dzKX(5*r_)op2z-^7!XnXT?No9Axz9dw_+$*9@$j__xLI`*Tn?4@HUwt`6&$V<;06B7`6 z*hOXvW2Cbn^E-!Io6mOeSZ;SP#`=}tY;xSfVl>0u{R`ymr;Jb#?lVu-ti(X~T#c@O zlAe*0wEZN+1AJQu0RB_w37Y}L_|GJ>-;uHA4IfFw$KyAir2iy=1G9SBc>_xC3D+nv z1pl>piH@6>SyKDPFMOavf z8Td1LFOdQ1G>si^2o%L^3=on~i{)CX%4KmY?udBs5Qn?85o;FJFhvsY3HM7xyFV|W zx!$z&7Q;iq8OVeA^^p$xr5hi;F7(aOHYFa8Sv@aIp9c!!7>URzM6YH=zvN;NG_xR> z6EPC`q$NHZ(H0{;QU(XPR!$5oV`nI^vtemUj}-3vtYtyXJEc6VDbw{%L0hZRokdej z09&s)Z350I663kmRgXowZAIpCv1N_enDOQq2O!SiW$4$)zQFiWp+0Fv#Ps4vmz!%6 zGI@3h4NmHau{A%KbyC+2ah(C6%i6J0yGsA(i3WI6)d1O#yOq%2L}y@zRda?9%5K=Xayzxuv3a1=mOmIoqYOd%=|eZpu#rvf z?G0UGTrA;5HN3tsFmKXWIesMAkG6q@+N_8LEoQMI9;-$hwoeqm>e4ceZ&$3fcTl5J z8?rEdd*?=Luc4rGSM43%&LJ(t&{nAn%k<!f*>1x({~;lyvx5jzpynNpOW zNwC2(Q~HiGYV(3BWHCkY5^+{UzhbgZiny;uaE2;i*^j)oXi;AlHixHA&>-tI2)Af* zH9qxyn!$-_2lprJ!}_+I1|AG!pe2A~K3N0~8bMb|27(?ynkA2K>{15mmw@Ezv=)t` zo2*JJkZk@NhoYCnvT^25+dB;`e&+m)1W34qhTrN58852*XwkvR*{p-L%x*H7}WI|kf5tOH6e`rs4;uvJ0Hb%Bo;=nzV- z!)jSScpUN4QBI^QS>Wb_UJL&sOva}7SC$0A$S;o!ICjcmsql$__NSjfpAziSM$|pV zx(9onfYUOf^Hu?oPS6h!pSWSVctUggAeqkc&>TSZ+}RDrsBi~NuGY?m$_dMQ_tk#& zNp?~z-1%Ppq2GgymeQ+=37%9yV7__zSU$Ua+cHIxyV(; zo+!+bB1RQUwIhJ5!ISxVJ7cNDr3NE-rvBSCZf_c&l{29@Wt2jUA(|p%i(^RT7zGm* zRVL;_0IJ~gq1&v_+& z+_rgv!5gcEle`{os01vdZBK$8o|bk_%iM6PINO=o` z;1$B@iME<aYbWz6n2ZtedtO9;yGzz*_lT<}wsGHad1Dz-k9Vop|WFB(sN%HLS{7^!1Ws&X3 z1eT@~n}JKHyMqbW#%WGlz~)pswQEW|3P^WuTkCEDm~&;|3`s7F7I$HMET5VpzIQ0} zO4*T}y0CV5nU>W||rq-T@Z>Oj;@&`Pi!Q_CcjT3XABO@vP?86c@{wX}kB-jCUP5)0EZU{$kf)~UWgCuXt;#ftcIDtp( z)Zy_epJA)5;afsP8Vr)A3|B*?>o9|7+qq1P-O?(cxLt4`B8I$zTn2``{($&m58Bpl zl@FV#G@}boFT?z=YafK7Q*9Rcfz0VB=}f;tr!6P8*Hm~GiMnE#iw`MG;vF?}2L%;u z+|(f-&LB8lh->`1RKH);8L5&ni$kqjcQnZor+_Y-7y()J|B`tpcctD#^=IXcoJA=1 zJ1^2jmwn=dN-0w!qGMv7o~Wcr3{-jPXLA_GXV1U1BPD<~^UMaQKH|rn`FpFtZ_qZX zFOGVX*^Bko{aWVrhQI5FpGIrd>+WP$NpqbnQ>6tZ{yAMcsk$Tz1}oYw6||w zj$S_Bxp_3+H9Q+K^}2jDq<*At0Tcq&Jv^UaoVvVHHvC_V-5M`@@;r;eOmlV2#>kfz6- z@P^22{X-2=6uu%U*y$Rt&Mx(TfS{wu8Dpw}<*05uOhERba2(Qs>?a!TUn`jfIbNb> zp2cvpZGP(5r{f6xwdw7an%J6D;CkxDOZDi+?Aay#arVCrdN|<>av=nIqSC6DX(s}9 zJMqbx9kUPs>_O9lYbwj!+kx8DH5PYo*GdEr*_+D%7JWJxfOpDP~|_bM?mc(eS}HVi?_ zRn>l}g|Qj(6=GC_UG%}!ThL<2L}R)gdH#>Ehw{K@9t`Xgkl9 z*Lq;ze9^Hz@+evF@+s0W&$@*iFgSxUJKgU9*^m7m~Cx3<{EpaBvjEsu8x z{uV^CB;;On*%%EM!mtEZPKo8dZj=GEGJP%GxI?}ib(W@72-TtnJFD>@V1F9a`F{9c zU{9Vn!UebI{yP+*1~SHQbQzL)KNol^=p$?Z&;AG4|Cu%ADT)GrTcmL&YR5?K%Z+Mn zHVj0kABEm&7*M~Ryt$dNx95o?P}QoDHn}Ahn9BxJZL;LkT54?Qhp_mKSX?5Ki<6%K zH0140Fvh^%sQ% z=~lSi_EuHXm_|BJN>d9Iz7<})z0mz-NdC38?){|eIn{Hzt25C1vYeB@V)Ku;QkAxa z@%RNa$YyQU4KT2U5@ho^vJB}z4=pT=C5v(*CQT-N>~>fTn`!qwJbR8_f@)M=%>Y@XU#Y5 z0ypEUhs}{fHSKR!-&ds9%uo7rcFudHo##cY9d9kYK}QQ&ITFayPb$))81eReh#f4D z?oHr>)GLB`YS}G*|cmCpfh1^SaeS4fh?%(6I z@O*QMA4qZYF1dzlr|2rRvxfL8kYZW%(L7!7dWhW^{gL3~Ad1aNIRAn0xNM{@K@Jhi zvCgnu%B$oQG{f+x4Z04B=u~B#XBpMOEvNHo;rTZtt2lQMfLd-6;jI3MJ&j;I8R7^WVJ>a z#|Y_5%zdMAnx^wqiweDiX{oTo73pgeE^7A%OfwZOknFNapO?!NfLM(=w_*G4KUyhy zL#@}cf?}T&CuVs}cF$`!L0L7gtAE3z^Xj8t?Tv}4MrvJaM)|9RjTLdg9_eluc-E<7 z{XPa67f|Pvu7{EDkT7beLPtVD;XiF14c>af!dWehIx+W*-=hB7;~d zzDOVj6bDflP8E^y<)`A8WOgsc&Hoqei|^oYb)*tD-0fT{F`^tw#$r%V|A|);vDq@n zhk&1-jm0tv#}`|J!oYX3o6cAL`@}7f$uq1Sweu_PKB47Km-f^{wr(T6DktA(Vkt)@V~= z351q=&;()gM+TB! z+7oQW+H|Zag-Jq10X>VhREsQ~z9M5F&6XA^Wkm%JK_ndK2o>4_m>vBO&$qOuF-5py zUfXT4ZxOGSI@Gsum?8op-7+T%71MiunUSlIO~CqR4Q&;&=0TNK;eY9=O=({{>t-FD zN_~PlCcYy!m=K;7EJ9!|( zQcEKF|AU|9KoZVE&4p-u5yr%$f97AR*=*zZk9)F_(-V3FqFR}d{==WUGFJgnuoM4r z=oCGGl&d0J+=nUus6@+5N^hE}9%)TwUEGhb`@Q|qUhCtYKojDwRvc0o5t?Vrd`ZH0 z(IAD;g#DO6`QiGg0J6k+Kx*{}e1z{r1A0 zS$)mJn5fwXV5S0}jNSlXmA`f({)_W%+kOwnR{h|7(f0wvFyQ(92so3Ct5KNKCPbG( zR{pu1WXx)=dB*?Z{6hQx!TEzBZ`jJKqarf+;&-PNL$B*$VD}7n?I*X&xeYG@&t9^i z{sk|+OJD$d%XZc+z)ynJ)wcve;`Q@=>xMPEzLaG`8}s;LLY<$;1oi<4rSlnPZ;9bc z5C6h#^a8gT%U|s+l+GpicC|P7EQl~>{?gxoNV}RNR-w6Exq~k7~_q|S*#6p0y(*HiZ4KO~s zkMHa^-kLwoSW-O4)qC~}j{lKi9N|~YR8+>wywza!Pf13H?jbP?1Wr(3Q@f-lMVg{+ zBUud@2i`yl>bDdMlpGU!jIrqfmh-FF9!3Dm3`{0ZpRt#KVxNqg0eD)uCsL|Ne%(95 z6PtkXfuAo$kM-M*l4m4<;%5xjH>RA+%`+HMt~&fCC5i+;cxW>7$dkNDN5LmU0VD}7 zQ|#wV?G%$_Qjq#X#Jxby4Lb=6mNO61A@&z;#vx7wPKali;)&odVAbnn%8xGrj#pU237w?Xt*tI73Glog%_pe=e z)`fy#*;e3~_T@*#cXywT_@0OWgA9m&FnyWy{dx|ryiw~>ww0EJI|J)Ou=fR|LzvenEwI!%YXg@^5^ovvGAk! z(SU`0ZR$=oYkH#A?NkYA&6abO&;eLs$KtnC8LOgeA|iZE1p2nZr$kVttA$iPBP$KU)8P4*P%Ek+`_KHv=O zYH;2&$_GfJj&YZPGM@I}=FP@W>Gg9{!3_|KbZ%1Fq9M-Sw+naNG+1+1UTD4-$K_9|#@9M_&qy95&+Cr{-<~erRRX(d(DJsjF)xfGuH^7a*2TD>##bk?Ew* zwplxPf-fTcl*x9o>1<^K?7;?yBo>eZbdi5C~CM6@ZhVxOozYDYOTkP5)^dP#J>430D;WCTj5tc(KH zaRoJ2$xt5s(fAz+<~2VW-$g2|g3N!#H$M+%G8ih+1j!@7_@~c4=TGYfWuJ?=Cc{Z{ zv?r6x16<`c++Jl3x{k}gOS?!YEt)59b7J%5MxyiQHtj#%W3KHFSs2yv=LMzNi3KLG$r+M zhpfXYm7{2P4F|2pgv23#4iTiIXLw_P<2P^)SW0d!67W}Ou~ApcII)fWhXs6}V7^6i z9iIi9{hcp9dUdpZ-}O^g@lW&P+M3D-#Ipn)Me(zkn!m<oD@_IjFVum3N`-%pnqu^py5;)=qFs;R$^-yi24GY~aKJg8H^*XfB+0lIqp z@%V8ms&X_JfUg(8XB`CQ31qf(40?OKnu++~VePcUGw-lOjy@y%Rowr4oB_E(22 z2?h4l(buE_w8kB9J;L9i`lbOIOw#2WkA4q$X-Ny~$?+1jAK4DA8t7%xdIiBd{hTyxu$3?1MDg&_*7WwA^xLpmVk7?A8QIeUrMF_DZ>F zQ#v}1>Q%UfEc0(xAwiaT9>T+W37(?dU)AM#>x@6S1T-_otvUMM{%lmz5WT~@%rl~Q zA@sT-2_KhgxZ(PnsIxzt_Trjfc9LN_jFP@Q_eE%gx>hRrCW~q_1BUQd4iP$LH$IXc zbmu&aBtU;*p5_%_*~>a12T9q|#Ifp^QuC0l)2Ch7-Of{fGZI3ti_c!~ycE2n^Bw$X z{N=6hx8A>hQBDA~bak>%Kdyaf+7JCKq#?n5Zg5*K?G4)Rryf~|0ELD8W(HY5feOf> z2wZ&C^<@rmJ&7-{L4%z7*GJz(NevUX)*3hyRT4z=fArEgjp~uFCcVx>d0~i`x81%e6ONm{8mYkeb08YDt%^u1XKF+qskykeBFy2$h=Qr2dliGO z&-QlI$OKRg{i@-K-1%UIX#A5!Qh#pNPy%S(bdnteB5wxVjH{|{k0 z+bH^%*PxkHq9npw1v1{^ zXnozog4k^J+OGH!ObxdrvUfp~$Z17L4Gq`xlj#1NRs&l31(MTHAvWh;wh$A866-ht zf}$j2(oDnLpr*7M>}kA%#{ZWu@l_3&&UMJEAXK5Rk65D%wWunkhFIPQ^jZI3ytMMV zlZm})^}l*)AKYkb8@5DJJ6B0akY-bW%v7aAiFDg@6Oq9bw)bW0$fZAli{3N8to8!ipJ_f3wm3p7$zX3#b{$ zqh&7~xpDpZEyNVvIy#e6J7JNGDlMDzqatSUk#ewX1u|3|30C%IN;Z znAwMhh=|73+07g29!7+(INC+rc);LMZwVN{&(cvEAb;5K&+i}{3ADxVlM8t-u5h*8 z7N2#I1e~1dSV9p6))G?WPXN<%uE$gDpzmruZ9g+w&&=@95`@2sVXJuC7q;|WkX4hq z2ssQY<->k8ipr_f_8e zq4@Jp8%OzDCVvLbIFK+U*9{(MaCB4*as1=U4!TfO9Ol5$;P3J$-^;9| zWA0$?;u9AzHBY^n&*-aPJP5t4$o(Wy+yM5-(k5=la5Lg2+fgo79tZ&=41zP=Q8_PH zv^N&HfB&%IO)_+|GM0yp#j>-q`*S1{8d9dyqNTZGHHIBBU~%$%KDuroEG8wJi*v2gW&m5<-)0mZj2AS+>7A4KP#VMr~jWh#_;y-~B z)&C8Y5RK|E#R+hoHdV=asLQ^^G6%qB?6zSUtbWxc|NVJ|%U$`A-)p@1O+0}Xd@P*> zt23;lQ#|+qo_c2v#s1$IiLC#PkpL0+|A~=s1@ik|@hi+LrV#7}pnhS1ILW?`0)(VG zpt2GH=HeFNdozCT68JF6-y6Lqvpp(0?I_*D$dtGG4RTfTuRP1%Pso0wVM2dOz?=me z5uNUU$GN$T1;3~Km>>=TpUytKFd>1qyx%VX99}#Di=cuD_jv^w`vG5K@$$Z zR8K2?CPej&T)LgVXv5TVEDg5?MsR;t%Jx(Uuidp<=Fecl9GN_^dw6W`HvjttFtN8j zIoq3tzrZR5bk;ZGZ2*pzj(%z}36N{=AKntvsJ-Xlf-q)#5_V>0G&V2euk+(-&T^gw ze=m8r-3UOq_S~#kSY~EN$p+v&diWm-iDZCI8!qwhgYWxWw1Qu8 zZrOuDTSfZpc{iNiVbe_~kPI&^?kzcMQzEZ?S?<1TJYFuh`(wc2Ct31wdR&m5)5iJOvCZ1%B&ij`;m- z<7K}|x&G=rVW^3)^ZG^6t_v`w2!0>Pm+piJ=*~=rlL5^Q1}bum^~Ib$8VL~!2ur$LLcs>To!295S?A$ZpA!q993mg5#c-US zm1;3?0a`aInLBg9mk*Pk32{f)YJNZK`L_x$&Q8W~bF!IwLjq zERCY3VXm}kXUyM}%Gzq^8Fs5}m1>p^N%I{Ugvl$}P$9E+eeeds?r8+vEyMse`c}sD zjJIQ4^ONo2GXXURMk(`wz`$1}&(0%rZ~$#*FO$OP6@YO}!%!%yIE&5TO#MoQ z7wby4CJK7OjY_&F`m;qB<00({A~8$P>m6IZ%XL|IL{F+wWFVUlb=+-_wjUd_DPcIy`;DL15#C=LV*M<3C8I9&L3fcZKfyT~59Ta*7T6Z&idnF=pn% z2s@8K+umNVMK3HYln=EZs%cS^_!L$H&0&W9V^sqX6`XrQFB^G&pEb*#E%^9X>K}GR zoi7*nGtRIK(%-6I`**|F%O7F#h4oJl1D@XY0_hhFt*P`sqfXY%-a-g@y`GJqI!j6< z!lLA#^$C4X0FTZ9C%ccUxna)(F~Hf5?~`87RnJa`*EL=3avG1o*XHNO#DrG&)AL;C zeWzLd0fEhP zmbd+h9_?q_7W75TdxE~6@AtxhSk1F>yPi$ji%eXLm&^`+wa%5z*Xu;5UHjeq!$efn z#!W8&wSedS;oZc!X_aE0GvN99=zebFs|UBo9*uCRk|C{yC#y<8x99w8{{1K|uduu9 z+CAoY$xNjR-Ce(#ppMu3<8w>Cw@vZQ@zvSV`g$d3r)B5GuLlmJbrZAB-EaN-y3>vB z-L>H1cJE?)Lm%+`AYZ4CiQAiv+3Kd2MsQuT=x6oy{=nmRlF_NFb7gDStE;iT)vn?B zc)w@u?pJm5jIf!PI)kZi_osEen|sISzT@#?;-yZn_OIULms^`Nb{D5Tr2UQ_zko(L zA$za)mxXif!$zmR8s^TI?cL~dkvgn;)}B32-3;PKm4Lumx81kScl$^A)2)=b-9yI5 zf$x!_iL$x;koP=yC-|^CyBb3?vRqOnwpfVZ6VK!*RE|lK7B60TiK1?b!X02 zjrvsBH^U7>WG@}PPLFrX?SkS*NG}#fRqu6+T9o|Y%My6+=iyP^M-&fi*jLFe-p>tb;K}v~kkx20;7M#TU>h@5aK_P6Aa<4(kn|$7J~RHGYoTa; z*|^mHQ)EBC6(FlO57-xaD z{q{5`SY}z}?G$XWiJ9&HA}c>PZwMFvw*&!U9N`LsXohHkoett3=-mF=w+BkyC5$T~ z7W7yeF5+_8b(TveLFElMn32K9ld&;|JQnoP9!I+oM7%~&&YKQ=O!iXXLI=Y%D(Bfz z<*6zth-jJJWYeZO8uEhMJPGrO_;z~05>zmL`%7ebuc@g$5GJLay{L1Ml*fsGV6EI# z1*N%7(UUxH9DUu8C%65ey;-*$!yLK;{w)FM@O#AIGyrbR5SS{U1x%U>F7wX`^<`I5 zgHwDsLg+axDE0wc$ z=9=h<&FyipYUH^xXy)2zK5q`cXHX*?1zby#=);>+igCIybNZlQ~*t zN=+-c7a}n~0|S1Y38b*Ymhrg1Z{z)mB-QCU>|m1|RHgPG_-BLuJ#3p}w7+_sRwk|7 zK{kch5Ns~X$Ziir^1)wFD=lBg?1r9 zp2|17(_~&pPo(5in&QE=mZEcxIS|v?x>UX3 zw1=)xYgz#TpC?(Ggr`vUxrMhyvjVa~=|e!vz;+CmH196+K-4fBvU{LZ9Iy?GHQdXL z;Lf8W9g_P!F?4njR3l{k4FT7wT@`V#LYY>Wo;V|Q6u6*c-?oBK3*zY^601WW;k;h> zsEG#-G|-aiobqG@p$2HhO%nt9^W*%}0$7f)QTC8&oyO3DCd69!b;(EB53 zkTL(Z)s|{CP=i(_LbEMjtllG55pvOB5Lq?gHe-ekxNql_ELpGAe;3@S+9P2!CS!b< zpJdB5kKYUnqO~O*)5g+iTk&MZUoIW3s)hk4fVCR>*iyqWJeP4=d5- z^hWhVKDKBEPBMWXLo#ZU9F!l5@p&`_7x-)u)=C@^u_9YzCa^a9*U%zeCaE+S2s|aG z&^P9zbxhBOHZ7in50i;@^ttGY;c83gC01U?^5DhK` zR`>V8{Y5X|_te)>=l1r-Z7YR#oc1-tP1fyoFN|KxjNj+mz3WBi1VxR~$EN;w^ZHKI zb6{Cob1$Fo$GiQC>v$b%Xyj-s)4#M6`iPejZ)G3so_VL z>IeM9*W2**U>;(#lOBH$um0zn!0ikDOJImA31zc3%Tu;VevkS`(4$^&%v})2zr!43 z3g=g!sy1&21rMKeN4b5{ke5MoZf$u z&Q*Uhmev<75dv`d`Q6$wnGcr!HT}(Cc#dl!{@Pv6Vze^}C5nw9Oa6E8M=U@x? zCRgRPq{u%!ALltKMvXDclLv+|klnjBC<%}n@PoeCq6LC z3=$BzycVXxI$tKaZg|G(`qkDph=q_}Dt*vMB0rH6YoR*-DOkAV>1)U9@2~J0Rb^M0 z<)UYQA?dz^Vf8Sd4`2^y+^B%8INff;9))8I`K;iH8-IY;37YQXL))|Ku!uR@*YB*4 zHB>33{s|JoIa3NPQ#7Bo(6YBBr=(HTJ4j5j{7cK8l4O4rZE=(^4QY&$;2g(vYzdFO z>B+wIPA#n|VqRDq*o3=Z5PZ&5PLJccE$bBWFo!}rTHVs&icc1Y&A=|@6QAxIyB!xn z`lnF&*E&)k_d;t=le+sfeT!?Ui0wo#@kfr=F zLCQNbP2rLr%pq{8TI^xhA_rQvD>roc4mV3ex`>bAZ)n|Flky|>(-%9Z-aTy$&cR^( zsH==5F&G<5a2MMJY;tlPAX_l<6oM@{Tb-+(dORI5*EYE5oY)SWndh%IAQT3Y`1mb> z#gi{HibfF6!UHV+IL}3~w6=O87nAQ=1X=^r4nA2NiX)J+#B4h$6#K1h^eAB9X~SEW zp}B;B>5S>|xrDA`!E}h*`5|r=bXy*eQwAUuS6g)oG%+2FfH+#Ff!8MvOuXMvt!qWq zHuH_8G6a9{W<}v#R^wvPgz^Q_jgeNkQBG3(BWLb*$gPF|^okEPbl8Y9y1CkGfNKx9 zzOFC*qm&f?uR0xizDA^)f;88HA;ZE(D=J{ST0B8=u|b?3Ib7-jBj7 zHu4|aXE4_lNGPVm=>fJ>)Evncia%4}zE=f0C*7vPi;!k_X;F!I(A7PM@57ipVjf(*bgjC)dflCo3L8MgcQB0R7n; zzkdgBKYv2lQ=Yfyr|ox5gQv&!hh{n8WmNe!MC&^z7AUt9(5nFV2sjcx+xsl@_B11S z%_nHp_U1RJ)Omi9Ane zS~Xzgw>9P*%8J}?r-&O~xZ!A+rS&ZH1IYTgiD>+}4I9712hBU=hdVe!a&Uj1=rQSe zwf1w;!i^G+R{<`82Fr7BYCUy?qz;ksXl$igVt)sY@di0N6K78mqMsK#ZjXg%hT`|2 z9qPj}w~J9{JcxM>5k@qgyIa9|(aAs1tVfn3eG_MgT{@L=!6y%WK-Q+8mc`DC0RHNb z8~*#vSRZr!d}>1|M0S9d+Amhzurw{{PywE#T(Zx9dhP-zn-?tus?2*;kcr_q?Uvrr zMBN_$d6Q}WjCl${`7&{Y`zXK-XjbtzEUZr)ee+BB^!w+|;B}oHIm8&%-WYD z7g10NZ;%?7?8Y(61Uc+;Hk-$nk*5<;<)JalcBpZA7Pj8K=Yni~SFT!@-L}ixuSIXx zsMJbZUvyLchG1`R_+){SuGeC;Tw!>#1W)drF1HZ#1~ zkZO3V@f=(3Qqc0ICK-wZ(VfY|oZ$vYJjI=rq`d?jp3V;~{9(6;;fv*{W4G=zo)*%h z?Ty8KqaAfWWpnqoGN;{{Wj$F(>r5@hzb&H8cQUYZsSyQRFItHb;U-UMiJOYnF0e5G z6Y1U$EN9Fwd(Sr^Kxdpe)7MVN%QM3f;W~gnH)OrnR^R{JsdaD%VBPc8tE36N4hTRd zcm#ZS_+0chj+3Uj^Ysc7Cqct9)H*zkhL`Mj@e*z7_Qce?oWVLYcZ-)MS0KVEfb7Ll z#aX=62zW_?a5~Wr>Ce}I_dceGPCE{&982U5n;3rY6A0fx94Vo!X1nT4BUP?q)-s3X zcUVv8J8wA@d;?5Z0FxU4RmzYLzwf=zn-9+(RDz)4T;4nWTwdZb-bef(J%lEPt~Rl$ z~8sDv*RavS*N0viuOCxVl1mqSAH1!L6{@(|Fz1wCiBoc&~eIgUYCN2F}3c9%U ze);}*G1@=;p@52<<#10UeZf{>lC~xH$N4t|L`S1+ma+~XnNBd-_9QUPh5o;P`@#Gt z><-b(8j{w@0=9QFg=*`D&}$9PU(rrutmCMJgolrSA&PM{_2?>%u&*NKFkEbj0z`9n zJHg;hkM5bU|2B!86#vWdG43MuIql$4mL1HzmP+S z5G?=7C!6xpaG((9ITf*^?1c~Uh~IkjD-gifQ@2~Q=nDBH#YTp?yIS(Ww2q5aB>VoN z7hb?QSmx~$w(N}T*uexGh2O{kgvsA}ZW+R$z#7kfK9?h3wXviQI|Te=%8ZtXuY(3k z^3Jg2@p=;}2R9dzFARH}mMl*M!P*^1aNKS^Bv}|qJWTS<)*wPJyaF2Nx;whONZn^( zJgE`bjN*8Lr|noNQj5w%u}`74+Z{!78bpywiH_5Ws`k6B5DX7hiWgD#8*DU`ClBl} zFgp#06mpzP518zDj_x$S@UTy-Vx@aXnfE!zlL8MGnSACVOV%Jym4;KEp^s4p!dejw zgUH-kPXt*tfiEQNq(KoyMUkz5;Dz9oh8-5WcDURda%$0YGzz`W9eE`UlaMI zADx$N=8=}-sK{~cV;JF(zev)3N; zFi*y`KKtxt0Atv&3nF*nP>`8ui^y`Da0Xx72#l;eTBPKdmE~&2je1}MM$!RGX6=8R z8iF7;6e+1fSyOZTa5Qh_=t@TjkMg2>Ki}jko=Di&@f}QcCnfL&A0=}x@tA0j4hM88 z@Vt;K!*zMcDgOY$a~`>!pI%%5Y{nSc<$vGi&aPN-N>N^sAGZJ3(LpR36qxxrQkVzq zDtbDSPr*EPd?#XBhNuGUPv{bp&5k~;$f81wL1Ut2HiC2URc18GugwJNU{+74mMX{E zy;ItBiXe4{z3E~1*g1}F{<2cf?RHj21_|Dj6hb{np1ib!&Efl~&|Gg7*iD&GQd*Uu z+wMURsS0f`ss&>2#_}sRmHn`($m^!~ua}8hK+Xj~mlEQuH}xR}5^&?~34&Y0Dny({ zL4xUW-NAd<`T7EzYP$KylqD^N#0~NuB>DzJ&&ekKMOzwN)+|<|E2F``h+&_$k+V3} zv8&On+J9JACHgv}{TJdyzsj{&^a|FT_jkJVdEyoY_sF3!9zKqPbPrd|qgbh^Qpgvi zjkUK2h7U#}V70d=Kbq&&FZmzhx4_Fi?dJC$JTYt<(+t441aA|dI?jMeIP$YAFloBq zV%&U`ni}5UWgJ%Iv-YQOwN`u|n#RXlgeO#V)ao)K;YGZs9>?VKP~Mo${eJ+9Ky<$w zKMF9Tqq)MrI6y~521Q`>uV4kZl2lSDHSD7G=aXxC7@K};r9C-fgYUY?9sKSb z<~*g4Er=N2wai{$kHSeKMx6T611uHsyDtXs;eycL4}Sk}Su7teX;H+PHb!F9r{c91 zrk{v`v@?C{)OMzqzaFNv;?S@Q#Uu}m%%4Yx^#0I2e3HspzBEUCs1;$9y)iKv zTlM4zgu(}%G`Pw~r1`M)A#<3M+BS;~_i8ICYjoj&ZHXrFO;5%ihD9}<{yZH!HX7#(X@RMZq>sR+@N#B3EX@~^)9Uu7h{p+FTG-PG zdd+OYkeL=%T6|3N3R4>04(N5{E;I9|0%ti#Y;itEfPA?HdA%TX7fW;iNLmn<-w>8~ zs$&TOOH089(2?w$6Z)x<;lMgf`O;%^Yk4*|UH8f$WPG@`2mD78=FmqiC}74;T71j_ z?g0xINsE<{CGv7zpae8k(@``-3(vU}qv;q(No&!As}Kk*kH8!h578P8nbpdT;-^p^ zd?1qh&iMiJ$zfzNYN3zZLLZ@pR8d*gN*}|m6h!YaloIS;3eLgD!%#O1KEeBnT>I>S z{B`J^d6@X#Nzke&t!2>pit)7Yl{T}i@XqZJu?{py(F6+v35U3h!q5t;;q)~cwPcJJ zaSW`EHHpSsYeoeujMoedW|xUpu7%2E)>&GLDl?K*-ChgXQ+T3ZT#2*D4&o~=8AfMD zDPvspQ3HDx)j>(>RUkEpd>M~}bwq3c$;W^ss{(P1wVZ8Zn_^}%uE((Z0A(iALd)X% z&9JZ5D%;bEJS~`34t!`t@a+wiCwPIX&BE3%s*&2ypt~sO@$rUII&({5_!MTjbCqF41BypcfdO2zg1TY z>lt!9iWq2TjTN($a6ocly(W5?yJ2XgQU9?%5PtqFnW%KLek$iQde-M6z7z+>i)W$_ z2*M|V@G1A|HNcWRPIW8H`HCjG`{GmMfmt8c&;c~#y;o%q$y55j@8a%wN*qG zGgc?b0(QcSHc7h^ShNp#lUNx5wK(F#F?4;Bud_}b1t8;tT{Njc z;+0(H<%BN*r_`v5Z<5v$)g!ezbjZBnHC2A03A~O38|c0o8u9Prx5Yr;>#`^s0kgoY ziIr@h&zqtUnS^geHwVyB@H`f7SIr&sh$3C;77x=hxyKkYg>llK5-R%9yy6OmN|;ky z^?0Zrct17bYbC-&c_tXiqG2=$%|Mu@dFbHt%0wbjkI$Un&ZUX8pne%?zA}mMnQbq@ z$7AJCopihK|HfL)$H%h(>|G5f#wFVTw7GxJ02b@=PB|30L!U1?n($_f{qxa`j=7W0 z@b^_C8XYA?+!n)T{4%xAC*+C?s;t_`1x#3)Z|4aS<_o>9Bd8X}bfFP%-e421+1y5- z4%u?$uSx)Ae^F9rz(1P23`)w`Dveh^U7NwtN%IWWl@?wRNsFW4!UzT6w37aUnvdQ9 z4tlF4HA@Gj$~q$sPYd{mV{QX~<^U#Ej{M}+E_a#BwfCvL zOA(9VeA|_FdA*uH@S>8NQ℘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%0DTjAyilYrKa3kT8|1T;T zAmu*z%fa-YBT#YyA`w4qY@|P^EXk)wm}O%|hD17-k(4-k<`(ne2nzWeqM=0LuZ_Rd z3O2v^>OeZG> z*$h$Pa>T`n$#%hGm_Zy1&`XDSfb`g;&4C!9hJ2V(TOB_Bf z)xR2<>*AQ#bdEXpJ68*G<2m>7hggFTfPf%g27@dIY9-3s+J~CPsgt$G{hTqfX{D)c_ONxlro__$Kx@MQ#S<468$(&$1*o)B)ey&Ss|3`zW1igv z+fFK~i#MT~_QYBfabgecF`r6)>=Nl%!l2}6<;7urf>j-xJ=}$b40km#6?w)6-RT4z zI+Uc5F(Fh*C0H2KA*&Ebej=;m!?|rk(Luz~`h2X|PSwNVZqYVRjC0HOjyP}zXt*9+ ziMHVY{bk>C7hXFjwqp+0W3h~Qk3Cj{izjdm9dnXKq8N@dJ)?^-#Q}E!>SMCy{oKrZ zaCt)*Xc9R*5_gOfNrao>+){OMaw)2g+(#x^%Ms?8H9>aajl+sw(;=-Vz?2Wza>%^c zfol1v<24^vl)C^@*P57Tj#}$rnkVs4d*WZ{2F(A~Sm3{Q!^dmIXD@^DBJV+kX3Jh@VmP6-;;!GrpB#(ysqwUbmM$>^O20Ikddp z@0!D$FKy~Mj`0AJC%(eybj;Dj@n%6dp}|e+$lfL$J2<u&_3uC7n8Q=~CXk&TR-9 z1@W$RHW~njArv6AJp@tZOh;_GV6dEf*5nIB!9;Xz(?J^;2tPmw2x0W`Abh&@!x|EK zKq86X>?w?7qk+}2P$YuzvytUc>$rlb3u8FR;thX@i2}(xE|uUsnf8IPPz^EK15?r1 zJ&%l9Y1hPq3%b}@4|tXaJvFi!^mXE#n=~adH2I_tT_eFdx8)EIT4gNuv}>KK<03l1 z0p>UkYUa~6ydH%POz`cf#WhH^IVm^#*vCD!8E;CdpQYfB`2k}!Kf@{jH}p(eA2kN5S?Ne)UOi>1DWzavA}Dm^=!}F%PjhXm*cjgsjTLm0 z<0dWOS>vNAa8I&eya9@X%jVclROA_aU;xUwixXszzID#4zJU4AG984E1KrpFZXvY* zWtZ8R;<>G924D^`l2@U5*&0D`m2mXXH|S;&al-a#4qEEr!sdVUvylDo4re~-&piLn zM4WKaf=%8%kwm*EfAl-xu}{xlPk-jf|CK@^=>K0@t~{*&+{=^8 z<-}7`X>qbZa|dUW#Z~TE45lflyM9uR|1{T9UL6}TcPC(!A4Q$QLe3P}>1n=$f_Od3 zJ;LX1L2J9J7`h4&lo3-~974wkoCEYQct?6TplHCIjgKCEQ+wYmE8n9>Kgx4*UDpc; zdy*r+bV(l9O!0hO+H=%~f?#d&Ojl)LeX4%!^VN^Ccp3Q2ZH_RZ{vIQ(R#P?yhw7

>Tti&5_@b*X>unZZ^^CVzeATku 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

-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�dM?lqJNeIJT^#l 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­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≫j7C~CnTO-Q+u=~sK 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

$*NfuZ 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

A$gptQD)U(;k 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