From 6d82cf91b9c43bd435b3263136fe29a6a95723fb Mon Sep 17 00:00:00 2001 From: Aditya Maru Date: Sat, 7 Dec 2024 13:31:23 -0500 Subject: [PATCH 01/17] *: initial scaffolding for the stickydisk action --- .github/workflows/basic.yaml | 73 + .github/workflows/build.yaml | 16 +- .gitignore | 23 + README.md | 86 +- action.yml | 21 +- dist/index.js | 15697 +++++++++----- dist/post/index.js | 36309 +++++++++++++++++++++++++++++++++ dist/post/package.json | 3 + package-lock.json | 229 +- package.json | 27 +- src/__tests__/main.test.ts | 210 - src/main.ts | 169 +- src/post.ts | 111 + src/utils.ts | 12 + 14 files changed, 47175 insertions(+), 5811 deletions(-) create mode 100644 .github/workflows/basic.yaml create mode 100644 dist/post/index.js create mode 100644 dist/post/package.json create mode 100644 src/post.ts create mode 100644 src/utils.ts diff --git a/.github/workflows/basic.yaml b/.github/workflows/basic.yaml new file mode 100644 index 0000000..dd780c3 --- /dev/null +++ b/.github/workflows/basic.yaml @@ -0,0 +1,73 @@ +name: Basic Sticky Disk Test +on: + workflow_dispatch: + pull_request: + +jobs: + test-sticky-disk: + name: Test Sticky Disk + runs-on: blacksmith-staging + strategy: + matrix: + iteration: [1, 2, 3, 4, 5, 6, 7, 8, 9, 10] + fail-fast: false + steps: + - name: Mount First Sticky Disk + uses: useblacksmith/stickydisk@initial-commit + with: + key: foo + path: /shouldseethis + + - name: List first directory if exists + run: | + if [ -d "/shouldseethis" ]; then + ls -la /shouldseethis + fi + + - name: Write test file to first disk + run: sudo sh -c 'echo "Hello from first sticky disk" > /shouldseethis/test.txt' + + - name: Mount Second Sticky Disk + uses: useblacksmith/stickydisk@initial-commit + with: + key: bar + path: /seconddisk + + - name: List second directory if exists + run: | + if [ -d "/seconddisk" ]; then + ls -la /seconddisk + fi + + - name: Write test file to second disk + run: sudo sh -c 'echo "Hello from second sticky disk" > /seconddisk/test.txt' + + - name: Mount Third Sticky Disk + uses: useblacksmith/stickydisk@initial-commit + with: + key: baz + path: /thirddisk + + - name: List third directory if exists + run: | + if [ -d "/thirddisk" ]; then + ls -la /thirddisk + fi + + - name: Write test file to third disk + run: sudo sh -c 'echo "Hello from third sticky disk" > /thirddisk/test.txt' + + - name: Mount First Sticky Disk Again + uses: useblacksmith/stickydisk@initial-commit + with: + key: foo + path: /shouldseethis_again + + - name: List first directory again if exists + run: | + if [ -d "/shouldseethis_again" ]; then + ls -la /shouldseethis_again + fi + + - name: Write test file to first disk again + run: sudo sh -c 'echo "Hello again from first sticky disk" > /shouldseethis_again/test2.txt' diff --git a/.github/workflows/build.yaml b/.github/workflows/build.yaml index c497f0b..0b354a7 100644 --- a/.github/workflows/build.yaml +++ b/.github/workflows/build.yaml @@ -17,6 +17,15 @@ jobs: with: node-version-file: .nvmrc + - name: Setup Buf + uses: bufbuild/buf-setup-action@v1 + + - name: Configure Buf Registry + run: | + npm config set @buf:registry https://buf.build/gen/npm/v1/ + npm config set //buf.build/gen/npm/v1/:_authToken ${{ secrets.BUF_TOKEN }} + npm install @buf/blacksmith_vm-agent.connectrpc_es@latest + - name: Install Dependencies run: npm ci @@ -26,4 +35,9 @@ jobs: - name: Build Action run: | npm run build - git diff && git diff-index --quiet --exit-code HEAD + # Check if any files were changed during build + if ! git diff --quiet; then + echo "Error: Build generated changes that aren't committed. Please run 'npm run build' locally and commit the changes." + git diff + exit 1 + fi diff --git a/.gitignore b/.gitignore index 9d4455b..9206374 100644 --- a/.gitignore +++ b/.gitignore @@ -3,4 +3,27 @@ !.git* !.nvmrc +# Dependencies node_modules/ + +# TypeScript +*.tsbuildinfo + +# IDE +.idea/ +.vscode/ +*.swp +*.swo + +# OS +.DS_Store +Thumbs.db + +# Test coverage +coverage/ + +# Logs +*.log +npm-debug.log* +yarn-debug.log* +yarn-error.log* diff --git a/README.md b/README.md index cd2d57d..0fbe4cd 100644 --- a/README.md +++ b/README.md @@ -1,76 +1,26 @@ -# Blacksmith Cache Delete Action +# Blacksmith Sticky Disk Action -A GitHub Action to delete caches from Blacksmith's cache storage. This action allows you to delete either a specific cache version or all versions of a cache key. This action only works Blacksmith runners. +A GitHub Action that helps persist state written to disk across jobs. Each sticky disk is backed by local NVMe storage and is formmatted as an ext4 filesystem. -## Usage - -```yaml -- name: Delete Cache - uses: useblacksmith/cache-delete@v1 - with: - key: Linux-composer-ecf6e2e236589e4d34ba89662b6bc2afe8e15237cd19a13df9dc0cb599ff4826 - version: v213asda2cf # Optional: specific version to delete -``` - -## Inputs - -| Input | Description | Required | Default | -| --------- | --------------------------------------- | -------- | ------- | -| `key` | The cache key to delete | No\* | - | -| `version` | Specific version of the cache to delete | No | - | -| `prefix` | Treat key as a prefix for bulk deletion | No | false | - -\* Required unless `prefix` is true, in which case it can be empty to match all cache keys - -## Examples - -### Delete All Versions of a Cache - -```yaml -- name: Delete All Cache Versions - uses: useblacksmith/cache-delete@v1 - with: - key: npm-cache -``` +Some common use cases of this action include: -### Delete a Specific Cache Version +- Caching Docker images to minimize pull and extract times +- Caching build artifacts such as NPM packages (egs: node_modules, yarn.lock, etc) +- Caching Bazel build artifacts +- Caching large GitHub repositories to minimize checkout times -```yaml -- name: Delete Specific Cache Version - uses: useblacksmith/cache-delete@v1 - with: - key: npm-cache - version: v1.0 -``` - -### Delete All Caches with a Prefix - -```yaml -- name: Delete All npm Caches - uses: useblacksmith/cache-delete@v1 - with: - key: npm- - prefix: true -``` - -### Delete All Caches +## Usage ```yaml -- name: Delete All Caches - uses: useblacksmith/cache-delete@v1 - with: - key: "" - prefix: true +jobs: + build: + runs-on: blacksmith + steps: + - name: Cache NPM packages + uses: useblacksmith/stickydisk-action@master + with: + key: ${{ github.repository }}-npm-cache + path: ~/.node_modules ``` -## Error Handling - -The action will: - -- Fail if the cache deletion request fails (non-404 error) -- Log a message if the cache is not found (404) -- Successfully complete if the cache is deleted - -## License - -This project is licensed under the MIT License - see the [LICENSE](LICENSE) file for details. +Each sticky disk is uniquely identified by a key. The sticky disk will be mounted at the specified path. Once the job completes, the sticky disk will be unmounted and committed for future invocations. At the moment, customers can use up to 5 sticky disks in a single GitHub Action job. diff --git a/action.yml b/action.yml index 5d83779..4c3c727 100644 --- a/action.yml +++ b/action.yml @@ -1,20 +1,17 @@ -name: "Delete Blacksmith Cache" -author: Aayush Shah -description: "Deletes a cache or specific cache version from Blacksmith" +name: "Blacksmith Sticky Disk" +author: Aditya Maru +description: "Creates a sticky disk on Blacksmith" branding: icon: folder-plus color: black inputs: key: - description: "The cache key to delete" - required: false - version: - description: "Specific version of the cache to delete (optional)" - required: false - prefix: - description: "Treat key as a prefix for bulk deletion" - required: false - default: "false" + description: "A unique key to identify the sticky disk" + required: true + path: + description: "The path at which to mount the sticky disk" + required: true runs: using: "node20" main: "dist/index.js" + post: "dist/post/index.js" diff --git a/dist/index.js b/dist/index.js index b7c61dc..793e7f8 100644 --- a/dist/index.js +++ b/dist/index.js @@ -3178,2000 +3178,6 @@ function copyFile(srcFile, destFile, force) { } //# sourceMappingURL=io.js.map -/***/ }), - -/***/ 6705: -/***/ ((module, exports, __nccwpck_require__) => { - - - -Object.defineProperty(exports, "__esModule", ({ value: true })); - -function _interopDefault (ex) { return (ex && (typeof ex === 'object') && 'default' in ex) ? ex['default'] : ex; } - -var Stream = _interopDefault(__nccwpck_require__(2203)); -var http = _interopDefault(__nccwpck_require__(8611)); -var Url = _interopDefault(__nccwpck_require__(7016)); -var whatwgUrl = _interopDefault(__nccwpck_require__(2686)); -var https = _interopDefault(__nccwpck_require__(5692)); -var zlib = _interopDefault(__nccwpck_require__(3106)); - -// Based on https://github.com/tmpvar/jsdom/blob/aa85b2abf07766ff7bf5c1f6daafb3726f2f2db5/lib/jsdom/living/blob.js - -// fix for "Readable" isn't a named export issue -const Readable = Stream.Readable; - -const BUFFER = Symbol('buffer'); -const TYPE = Symbol('type'); - -class Blob { - constructor() { - this[TYPE] = ''; - - const blobParts = arguments[0]; - const options = arguments[1]; - - const buffers = []; - let size = 0; - - if (blobParts) { - const a = blobParts; - const length = Number(a.length); - for (let i = 0; i < length; i++) { - const element = a[i]; - let buffer; - if (element instanceof Buffer) { - buffer = element; - } else if (ArrayBuffer.isView(element)) { - buffer = Buffer.from(element.buffer, element.byteOffset, element.byteLength); - } else if (element instanceof ArrayBuffer) { - buffer = Buffer.from(element); - } else if (element instanceof Blob) { - buffer = element[BUFFER]; - } else { - buffer = Buffer.from(typeof element === 'string' ? element : String(element)); - } - size += buffer.length; - buffers.push(buffer); - } - } - - this[BUFFER] = Buffer.concat(buffers); - - let type = options && options.type !== undefined && String(options.type).toLowerCase(); - if (type && !/[^\u0020-\u007E]/.test(type)) { - this[TYPE] = type; - } - } - get size() { - return this[BUFFER].length; - } - get type() { - return this[TYPE]; - } - text() { - return Promise.resolve(this[BUFFER].toString()); - } - arrayBuffer() { - const buf = this[BUFFER]; - const ab = buf.buffer.slice(buf.byteOffset, buf.byteOffset + buf.byteLength); - return Promise.resolve(ab); - } - stream() { - const readable = new Readable(); - readable._read = function () {}; - readable.push(this[BUFFER]); - readable.push(null); - return readable; - } - toString() { - return '[object Blob]'; - } - slice() { - const size = this.size; - - const start = arguments[0]; - const end = arguments[1]; - let relativeStart, relativeEnd; - if (start === undefined) { - relativeStart = 0; - } else if (start < 0) { - relativeStart = Math.max(size + start, 0); - } else { - relativeStart = Math.min(start, size); - } - if (end === undefined) { - relativeEnd = size; - } else if (end < 0) { - relativeEnd = Math.max(size + end, 0); - } else { - relativeEnd = Math.min(end, size); - } - const span = Math.max(relativeEnd - relativeStart, 0); - - const buffer = this[BUFFER]; - const slicedBuffer = buffer.slice(relativeStart, relativeStart + span); - const blob = new Blob([], { type: arguments[2] }); - blob[BUFFER] = slicedBuffer; - return blob; - } -} - -Object.defineProperties(Blob.prototype, { - size: { enumerable: true }, - type: { enumerable: true }, - slice: { enumerable: true } -}); - -Object.defineProperty(Blob.prototype, Symbol.toStringTag, { - value: 'Blob', - writable: false, - enumerable: false, - configurable: true -}); - -/** - * fetch-error.js - * - * FetchError interface for operational errors - */ - -/** - * Create FetchError instance - * - * @param String message Error message for human - * @param String type Error type for machine - * @param String systemError For Node.js system error - * @return FetchError - */ -function FetchError(message, type, systemError) { - Error.call(this, message); - - this.message = message; - this.type = type; - - // when err.type is `system`, err.code contains system error code - if (systemError) { - this.code = this.errno = systemError.code; - } - - // hide custom error implementation details from end-users - Error.captureStackTrace(this, this.constructor); -} - -FetchError.prototype = Object.create(Error.prototype); -FetchError.prototype.constructor = FetchError; -FetchError.prototype.name = 'FetchError'; - -let convert; -try { - convert = (__nccwpck_require__(2078).convert); -} catch (e) {} - -const INTERNALS = Symbol('Body internals'); - -// fix an issue where "PassThrough" isn't a named export for node <10 -const PassThrough = Stream.PassThrough; - -/** - * Body mixin - * - * Ref: https://fetch.spec.whatwg.org/#body - * - * @param Stream body Readable stream - * @param Object opts Response options - * @return Void - */ -function Body(body) { - var _this = this; - - var _ref = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : {}, - _ref$size = _ref.size; - - let size = _ref$size === undefined ? 0 : _ref$size; - var _ref$timeout = _ref.timeout; - let timeout = _ref$timeout === undefined ? 0 : _ref$timeout; - - if (body == null) { - // body is undefined or null - body = null; - } else if (isURLSearchParams(body)) { - // body is a URLSearchParams - body = Buffer.from(body.toString()); - } else if (isBlob(body)) ; else if (Buffer.isBuffer(body)) ; else if (Object.prototype.toString.call(body) === '[object ArrayBuffer]') { - // body is ArrayBuffer - body = Buffer.from(body); - } else if (ArrayBuffer.isView(body)) { - // body is ArrayBufferView - body = Buffer.from(body.buffer, body.byteOffset, body.byteLength); - } else if (body instanceof Stream) ; else { - // none of the above - // coerce to string then buffer - body = Buffer.from(String(body)); - } - this[INTERNALS] = { - body, - disturbed: false, - error: null - }; - this.size = size; - this.timeout = timeout; - - if (body instanceof Stream) { - body.on('error', function (err) { - const error = err.name === 'AbortError' ? err : new FetchError(`Invalid response body while trying to fetch ${_this.url}: ${err.message}`, 'system', err); - _this[INTERNALS].error = error; - }); - } -} - -Body.prototype = { - get body() { - return this[INTERNALS].body; - }, - - get bodyUsed() { - return this[INTERNALS].disturbed; - }, - - /** - * Decode response as ArrayBuffer - * - * @return Promise - */ - arrayBuffer() { - return consumeBody.call(this).then(function (buf) { - return buf.buffer.slice(buf.byteOffset, buf.byteOffset + buf.byteLength); - }); - }, - - /** - * Return raw response as Blob - * - * @return Promise - */ - blob() { - let ct = this.headers && this.headers.get('content-type') || ''; - return consumeBody.call(this).then(function (buf) { - return Object.assign( - // Prevent copying - new Blob([], { - type: ct.toLowerCase() - }), { - [BUFFER]: buf - }); - }); - }, - - /** - * Decode response as json - * - * @return Promise - */ - json() { - var _this2 = this; - - return consumeBody.call(this).then(function (buffer) { - try { - return JSON.parse(buffer.toString()); - } catch (err) { - return Body.Promise.reject(new FetchError(`invalid json response body at ${_this2.url} reason: ${err.message}`, 'invalid-json')); - } - }); - }, - - /** - * Decode response as text - * - * @return Promise - */ - text() { - return consumeBody.call(this).then(function (buffer) { - return buffer.toString(); - }); - }, - - /** - * Decode response as buffer (non-spec api) - * - * @return Promise - */ - buffer() { - return consumeBody.call(this); - }, - - /** - * Decode response as text, while automatically detecting the encoding and - * trying to decode to UTF-8 (non-spec api) - * - * @return Promise - */ - textConverted() { - var _this3 = this; - - return consumeBody.call(this).then(function (buffer) { - return convertBody(buffer, _this3.headers); - }); - } -}; - -// In browsers, all properties are enumerable. -Object.defineProperties(Body.prototype, { - body: { enumerable: true }, - bodyUsed: { enumerable: true }, - arrayBuffer: { enumerable: true }, - blob: { enumerable: true }, - json: { enumerable: true }, - text: { enumerable: true } -}); - -Body.mixIn = function (proto) { - for (const name of Object.getOwnPropertyNames(Body.prototype)) { - // istanbul ignore else: future proof - if (!(name in proto)) { - const desc = Object.getOwnPropertyDescriptor(Body.prototype, name); - Object.defineProperty(proto, name, desc); - } - } -}; - -/** - * Consume and convert an entire Body to a Buffer. - * - * Ref: https://fetch.spec.whatwg.org/#concept-body-consume-body - * - * @return Promise - */ -function consumeBody() { - var _this4 = this; - - if (this[INTERNALS].disturbed) { - return Body.Promise.reject(new TypeError(`body used already for: ${this.url}`)); - } - - this[INTERNALS].disturbed = true; - - if (this[INTERNALS].error) { - return Body.Promise.reject(this[INTERNALS].error); - } - - let body = this.body; - - // body is null - if (body === null) { - return Body.Promise.resolve(Buffer.alloc(0)); - } - - // body is blob - if (isBlob(body)) { - body = body.stream(); - } - - // body is buffer - if (Buffer.isBuffer(body)) { - return Body.Promise.resolve(body); - } - - // istanbul ignore if: should never happen - if (!(body instanceof Stream)) { - return Body.Promise.resolve(Buffer.alloc(0)); - } - - // body is stream - // get ready to actually consume the body - let accum = []; - let accumBytes = 0; - let abort = false; - - return new Body.Promise(function (resolve, reject) { - let resTimeout; - - // allow timeout on slow response body - if (_this4.timeout) { - resTimeout = setTimeout(function () { - abort = true; - reject(new FetchError(`Response timeout while trying to fetch ${_this4.url} (over ${_this4.timeout}ms)`, 'body-timeout')); - }, _this4.timeout); - } - - // handle stream errors - body.on('error', function (err) { - if (err.name === 'AbortError') { - // if the request was aborted, reject with this Error - abort = true; - reject(err); - } else { - // other errors, such as incorrect content-encoding - reject(new FetchError(`Invalid response body while trying to fetch ${_this4.url}: ${err.message}`, 'system', err)); - } - }); - - body.on('data', function (chunk) { - if (abort || chunk === null) { - return; - } - - if (_this4.size && accumBytes + chunk.length > _this4.size) { - abort = true; - reject(new FetchError(`content size at ${_this4.url} over limit: ${_this4.size}`, 'max-size')); - return; - } - - accumBytes += chunk.length; - accum.push(chunk); - }); - - body.on('end', function () { - if (abort) { - return; - } - - clearTimeout(resTimeout); - - try { - resolve(Buffer.concat(accum, accumBytes)); - } catch (err) { - // handle streams that have accumulated too much data (issue #414) - reject(new FetchError(`Could not create Buffer from response body for ${_this4.url}: ${err.message}`, 'system', err)); - } - }); - }); -} - -/** - * Detect buffer encoding and convert to target encoding - * ref: http://www.w3.org/TR/2011/WD-html5-20110113/parsing.html#determining-the-character-encoding - * - * @param Buffer buffer Incoming buffer - * @param String encoding Target encoding - * @return String - */ -function convertBody(buffer, headers) { - if (typeof convert !== 'function') { - throw new Error('The package `encoding` must be installed to use the textConverted() function'); - } - - const ct = headers.get('content-type'); - let charset = 'utf-8'; - let res, str; - - // header - if (ct) { - res = /charset=([^;]*)/i.exec(ct); - } - - // no charset in content type, peek at response body for at most 1024 bytes - str = buffer.slice(0, 1024).toString(); - - // html5 - if (!res && str) { - res = / 0 && arguments[0] !== undefined ? arguments[0] : undefined; - - this[MAP] = Object.create(null); - - if (init instanceof Headers) { - const rawHeaders = init.raw(); - const headerNames = Object.keys(rawHeaders); - - for (const headerName of headerNames) { - for (const value of rawHeaders[headerName]) { - this.append(headerName, value); - } - } - - return; - } - - // We don't worry about converting prop to ByteString here as append() - // will handle it. - if (init == null) ; else if (typeof init === 'object') { - const method = init[Symbol.iterator]; - if (method != null) { - if (typeof method !== 'function') { - throw new TypeError('Header pairs must be iterable'); - } - - // sequence> - // Note: per spec we have to first exhaust the lists then process them - const pairs = []; - for (const pair of init) { - if (typeof pair !== 'object' || typeof pair[Symbol.iterator] !== 'function') { - throw new TypeError('Each header pair must be iterable'); - } - pairs.push(Array.from(pair)); - } - - for (const pair of pairs) { - if (pair.length !== 2) { - throw new TypeError('Each header pair must be a name/value tuple'); - } - this.append(pair[0], pair[1]); - } - } else { - // record - for (const key of Object.keys(init)) { - const value = init[key]; - this.append(key, value); - } - } - } else { - throw new TypeError('Provided initializer must be an object'); - } - } - - /** - * Return combined header value given name - * - * @param String name Header name - * @return Mixed - */ - get(name) { - name = `${name}`; - validateName(name); - const key = find(this[MAP], name); - if (key === undefined) { - return null; - } - - return this[MAP][key].join(', '); - } - - /** - * Iterate over all headers - * - * @param Function callback Executed for each item with parameters (value, name, thisArg) - * @param Boolean thisArg `this` context for callback function - * @return Void - */ - forEach(callback) { - let thisArg = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : undefined; - - let pairs = getHeaders(this); - let i = 0; - while (i < pairs.length) { - var _pairs$i = pairs[i]; - const name = _pairs$i[0], - value = _pairs$i[1]; - - callback.call(thisArg, value, name, this); - pairs = getHeaders(this); - i++; - } - } - - /** - * Overwrite header values given name - * - * @param String name Header name - * @param String value Header value - * @return Void - */ - set(name, value) { - name = `${name}`; - value = `${value}`; - validateName(name); - validateValue(value); - const key = find(this[MAP], name); - this[MAP][key !== undefined ? key : name] = [value]; - } - - /** - * Append a value onto existing header - * - * @param String name Header name - * @param String value Header value - * @return Void - */ - append(name, value) { - name = `${name}`; - value = `${value}`; - validateName(name); - validateValue(value); - const key = find(this[MAP], name); - if (key !== undefined) { - this[MAP][key].push(value); - } else { - this[MAP][name] = [value]; - } - } - - /** - * Check for header name existence - * - * @param String name Header name - * @return Boolean - */ - has(name) { - name = `${name}`; - validateName(name); - return find(this[MAP], name) !== undefined; - } - - /** - * Delete all header values given name - * - * @param String name Header name - * @return Void - */ - delete(name) { - name = `${name}`; - validateName(name); - const key = find(this[MAP], name); - if (key !== undefined) { - delete this[MAP][key]; - } - } - - /** - * Return raw headers (non-spec api) - * - * @return Object - */ - raw() { - return this[MAP]; - } - - /** - * Get an iterator on keys. - * - * @return Iterator - */ - keys() { - return createHeadersIterator(this, 'key'); - } - - /** - * Get an iterator on values. - * - * @return Iterator - */ - values() { - return createHeadersIterator(this, 'value'); - } - - /** - * Get an iterator on entries. - * - * This is the default iterator of the Headers object. - * - * @return Iterator - */ - [Symbol.iterator]() { - return createHeadersIterator(this, 'key+value'); - } -} -Headers.prototype.entries = Headers.prototype[Symbol.iterator]; - -Object.defineProperty(Headers.prototype, Symbol.toStringTag, { - value: 'Headers', - writable: false, - enumerable: false, - configurable: true -}); - -Object.defineProperties(Headers.prototype, { - get: { enumerable: true }, - forEach: { enumerable: true }, - set: { enumerable: true }, - append: { enumerable: true }, - has: { enumerable: true }, - delete: { enumerable: true }, - keys: { enumerable: true }, - values: { enumerable: true }, - entries: { enumerable: true } -}); - -function getHeaders(headers) { - let kind = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : 'key+value'; - - const keys = Object.keys(headers[MAP]).sort(); - return keys.map(kind === 'key' ? function (k) { - return k.toLowerCase(); - } : kind === 'value' ? function (k) { - return headers[MAP][k].join(', '); - } : function (k) { - return [k.toLowerCase(), headers[MAP][k].join(', ')]; - }); -} - -const INTERNAL = Symbol('internal'); - -function createHeadersIterator(target, kind) { - const iterator = Object.create(HeadersIteratorPrototype); - iterator[INTERNAL] = { - target, - kind, - index: 0 - }; - return iterator; -} - -const HeadersIteratorPrototype = Object.setPrototypeOf({ - next() { - // istanbul ignore if - if (!this || Object.getPrototypeOf(this) !== HeadersIteratorPrototype) { - throw new TypeError('Value of `this` is not a HeadersIterator'); - } - - var _INTERNAL = this[INTERNAL]; - const target = _INTERNAL.target, - kind = _INTERNAL.kind, - index = _INTERNAL.index; - - const values = getHeaders(target, kind); - const len = values.length; - if (index >= len) { - return { - value: undefined, - done: true - }; - } - - this[INTERNAL].index = index + 1; - - return { - value: values[index], - done: false - }; - } -}, Object.getPrototypeOf(Object.getPrototypeOf([][Symbol.iterator]()))); - -Object.defineProperty(HeadersIteratorPrototype, Symbol.toStringTag, { - value: 'HeadersIterator', - writable: false, - enumerable: false, - configurable: true -}); - -/** - * Export the Headers object in a form that Node.js can consume. - * - * @param Headers headers - * @return Object - */ -function exportNodeCompatibleHeaders(headers) { - const obj = Object.assign({ __proto__: null }, headers[MAP]); - - // http.request() only supports string as Host header. This hack makes - // specifying custom Host header possible. - const hostHeaderKey = find(headers[MAP], 'Host'); - if (hostHeaderKey !== undefined) { - obj[hostHeaderKey] = obj[hostHeaderKey][0]; - } - - return obj; -} - -/** - * Create a Headers object from an object of headers, ignoring those that do - * not conform to HTTP grammar productions. - * - * @param Object obj Object of headers - * @return Headers - */ -function createHeadersLenient(obj) { - const headers = new Headers(); - for (const name of Object.keys(obj)) { - if (invalidTokenRegex.test(name)) { - continue; - } - if (Array.isArray(obj[name])) { - for (const val of obj[name]) { - if (invalidHeaderCharRegex.test(val)) { - continue; - } - if (headers[MAP][name] === undefined) { - headers[MAP][name] = [val]; - } else { - headers[MAP][name].push(val); - } - } - } else if (!invalidHeaderCharRegex.test(obj[name])) { - headers[MAP][name] = [obj[name]]; - } - } - return headers; -} - -const INTERNALS$1 = Symbol('Response internals'); - -// fix an issue where "STATUS_CODES" aren't a named export for node <10 -const STATUS_CODES = http.STATUS_CODES; - -/** - * Response class - * - * @param Stream body Readable stream - * @param Object opts Response options - * @return Void - */ -class Response { - constructor() { - let body = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : null; - let opts = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : {}; - - Body.call(this, body, opts); - - const status = opts.status || 200; - const headers = new Headers(opts.headers); - - if (body != null && !headers.has('Content-Type')) { - const contentType = extractContentType(body); - if (contentType) { - headers.append('Content-Type', contentType); - } - } - - this[INTERNALS$1] = { - url: opts.url, - status, - statusText: opts.statusText || STATUS_CODES[status], - headers, - counter: opts.counter - }; - } - - get url() { - return this[INTERNALS$1].url || ''; - } - - get status() { - return this[INTERNALS$1].status; - } - - /** - * Convenience property representing if the request ended normally - */ - get ok() { - return this[INTERNALS$1].status >= 200 && this[INTERNALS$1].status < 300; - } - - get redirected() { - return this[INTERNALS$1].counter > 0; - } - - get statusText() { - return this[INTERNALS$1].statusText; - } - - get headers() { - return this[INTERNALS$1].headers; - } - - /** - * Clone this response - * - * @return Response - */ - clone() { - return new Response(clone(this), { - url: this.url, - status: this.status, - statusText: this.statusText, - headers: this.headers, - ok: this.ok, - redirected: this.redirected - }); - } -} - -Body.mixIn(Response.prototype); - -Object.defineProperties(Response.prototype, { - url: { enumerable: true }, - status: { enumerable: true }, - ok: { enumerable: true }, - redirected: { enumerable: true }, - statusText: { enumerable: true }, - headers: { enumerable: true }, - clone: { enumerable: true } -}); - -Object.defineProperty(Response.prototype, Symbol.toStringTag, { - value: 'Response', - writable: false, - enumerable: false, - configurable: true -}); - -const INTERNALS$2 = Symbol('Request internals'); -const URL = Url.URL || whatwgUrl.URL; - -// fix an issue where "format", "parse" aren't a named export for node <10 -const parse_url = Url.parse; -const format_url = Url.format; - -/** - * Wrapper around `new URL` to handle arbitrary URLs - * - * @param {string} urlStr - * @return {void} - */ -function parseURL(urlStr) { - /* - Check whether the URL is absolute or not - Scheme: https://tools.ietf.org/html/rfc3986#section-3.1 - Absolute URL: https://tools.ietf.org/html/rfc3986#section-4.3 - */ - if (/^[a-zA-Z][a-zA-Z\d+\-.]*:/.exec(urlStr)) { - urlStr = new URL(urlStr).toString(); - } - - // Fallback to old implementation for arbitrary URLs - return parse_url(urlStr); -} - -const streamDestructionSupported = 'destroy' in Stream.Readable.prototype; - -/** - * Check if a value is an instance of Request. - * - * @param Mixed input - * @return Boolean - */ -function isRequest(input) { - return typeof input === 'object' && typeof input[INTERNALS$2] === 'object'; -} - -function isAbortSignal(signal) { - const proto = signal && typeof signal === 'object' && Object.getPrototypeOf(signal); - return !!(proto && proto.constructor.name === 'AbortSignal'); -} - -/** - * Request class - * - * @param Mixed input Url or Request instance - * @param Object init Custom options - * @return Void - */ -class Request { - constructor(input) { - let init = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : {}; - - let parsedURL; - - // normalize input - if (!isRequest(input)) { - if (input && input.href) { - // in order to support Node.js' Url objects; though WHATWG's URL objects - // will fall into this branch also (since their `toString()` will return - // `href` property anyway) - parsedURL = parseURL(input.href); - } else { - // coerce input to a string before attempting to parse - parsedURL = parseURL(`${input}`); - } - input = {}; - } else { - parsedURL = parseURL(input.url); - } - - let method = init.method || input.method || 'GET'; - method = method.toUpperCase(); - - if ((init.body != null || isRequest(input) && input.body !== null) && (method === 'GET' || method === 'HEAD')) { - throw new TypeError('Request with GET/HEAD method cannot have body'); - } - - let inputBody = init.body != null ? init.body : isRequest(input) && input.body !== null ? clone(input) : null; - - Body.call(this, inputBody, { - timeout: init.timeout || input.timeout || 0, - size: init.size || input.size || 0 - }); - - const headers = new Headers(init.headers || input.headers || {}); - - if (inputBody != null && !headers.has('Content-Type')) { - const contentType = extractContentType(inputBody); - if (contentType) { - headers.append('Content-Type', contentType); - } - } - - let signal = isRequest(input) ? input.signal : null; - if ('signal' in init) signal = init.signal; - - if (signal != null && !isAbortSignal(signal)) { - throw new TypeError('Expected signal to be an instanceof AbortSignal'); - } - - this[INTERNALS$2] = { - method, - redirect: init.redirect || input.redirect || 'follow', - headers, - parsedURL, - signal - }; - - // node-fetch-only options - this.follow = init.follow !== undefined ? init.follow : input.follow !== undefined ? input.follow : 20; - this.compress = init.compress !== undefined ? init.compress : input.compress !== undefined ? input.compress : true; - this.counter = init.counter || input.counter || 0; - this.agent = init.agent || input.agent; - } - - get method() { - return this[INTERNALS$2].method; - } - - get url() { - return format_url(this[INTERNALS$2].parsedURL); - } - - get headers() { - return this[INTERNALS$2].headers; - } - - get redirect() { - return this[INTERNALS$2].redirect; - } - - get signal() { - return this[INTERNALS$2].signal; - } - - /** - * Clone this request - * - * @return Request - */ - clone() { - return new Request(this); - } -} - -Body.mixIn(Request.prototype); - -Object.defineProperty(Request.prototype, Symbol.toStringTag, { - value: 'Request', - writable: false, - enumerable: false, - configurable: true -}); - -Object.defineProperties(Request.prototype, { - method: { enumerable: true }, - url: { enumerable: true }, - headers: { enumerable: true }, - redirect: { enumerable: true }, - clone: { enumerable: true }, - signal: { enumerable: true } -}); - -/** - * Convert a Request to Node.js http request options. - * - * @param Request A Request instance - * @return Object The options object to be passed to http.request - */ -function getNodeRequestOptions(request) { - const parsedURL = request[INTERNALS$2].parsedURL; - const headers = new Headers(request[INTERNALS$2].headers); - - // fetch step 1.3 - if (!headers.has('Accept')) { - headers.set('Accept', '*/*'); - } - - // Basic fetch - if (!parsedURL.protocol || !parsedURL.hostname) { - throw new TypeError('Only absolute URLs are supported'); - } - - if (!/^https?:$/.test(parsedURL.protocol)) { - throw new TypeError('Only HTTP(S) protocols are supported'); - } - - if (request.signal && request.body instanceof Stream.Readable && !streamDestructionSupported) { - throw new Error('Cancellation of streamed requests with AbortSignal is not supported in node < 8'); - } - - // HTTP-network-or-cache fetch steps 2.4-2.7 - let contentLengthValue = null; - if (request.body == null && /^(POST|PUT)$/i.test(request.method)) { - contentLengthValue = '0'; - } - if (request.body != null) { - const totalBytes = getTotalBytes(request); - if (typeof totalBytes === 'number') { - contentLengthValue = String(totalBytes); - } - } - if (contentLengthValue) { - headers.set('Content-Length', contentLengthValue); - } - - // HTTP-network-or-cache fetch step 2.11 - if (!headers.has('User-Agent')) { - headers.set('User-Agent', 'node-fetch/1.0 (+https://github.com/bitinn/node-fetch)'); - } - - // HTTP-network-or-cache fetch step 2.15 - if (request.compress && !headers.has('Accept-Encoding')) { - headers.set('Accept-Encoding', 'gzip,deflate'); - } - - let agent = request.agent; - if (typeof agent === 'function') { - agent = agent(parsedURL); - } - - // HTTP-network fetch step 4.2 - // chunked encoding is handled by Node.js - - return Object.assign({}, parsedURL, { - method: request.method, - headers: exportNodeCompatibleHeaders(headers), - agent - }); -} - -/** - * abort-error.js - * - * AbortError interface for cancelled requests - */ - -/** - * Create AbortError instance - * - * @param String message Error message for human - * @return AbortError - */ -function AbortError(message) { - Error.call(this, message); - - this.type = 'aborted'; - this.message = message; - - // hide custom error implementation details from end-users - Error.captureStackTrace(this, this.constructor); -} - -AbortError.prototype = Object.create(Error.prototype); -AbortError.prototype.constructor = AbortError; -AbortError.prototype.name = 'AbortError'; - -const URL$1 = Url.URL || whatwgUrl.URL; - -// fix an issue where "PassThrough", "resolve" aren't a named export for node <10 -const PassThrough$1 = Stream.PassThrough; - -const isDomainOrSubdomain = function isDomainOrSubdomain(destination, original) { - const orig = new URL$1(original).hostname; - const dest = new URL$1(destination).hostname; - - return orig === dest || orig[orig.length - dest.length - 1] === '.' && orig.endsWith(dest); -}; - -/** - * isSameProtocol reports whether the two provided URLs use the same protocol. - * - * Both domains must already be in canonical form. - * @param {string|URL} original - * @param {string|URL} destination - */ -const isSameProtocol = function isSameProtocol(destination, original) { - const orig = new URL$1(original).protocol; - const dest = new URL$1(destination).protocol; - - return orig === dest; -}; - -/** - * Fetch function - * - * @param Mixed url Absolute url or Request instance - * @param Object opts Fetch options - * @return Promise - */ -function fetch(url, opts) { - - // allow custom promise - if (!fetch.Promise) { - throw new Error('native promise missing, set fetch.Promise to your favorite alternative'); - } - - Body.Promise = fetch.Promise; - - // wrap http.request into fetch - return new fetch.Promise(function (resolve, reject) { - // build request object - const request = new Request(url, opts); - const options = getNodeRequestOptions(request); - - const send = (options.protocol === 'https:' ? https : http).request; - const signal = request.signal; - - let response = null; - - const abort = function abort() { - let error = new AbortError('The user aborted a request.'); - reject(error); - if (request.body && request.body instanceof Stream.Readable) { - destroyStream(request.body, error); - } - if (!response || !response.body) return; - response.body.emit('error', error); - }; - - if (signal && signal.aborted) { - abort(); - return; - } - - const abortAndFinalize = function abortAndFinalize() { - abort(); - finalize(); - }; - - // send request - const req = send(options); - let reqTimeout; - - if (signal) { - signal.addEventListener('abort', abortAndFinalize); - } - - function finalize() { - req.abort(); - if (signal) signal.removeEventListener('abort', abortAndFinalize); - clearTimeout(reqTimeout); - } - - if (request.timeout) { - req.once('socket', function (socket) { - reqTimeout = setTimeout(function () { - reject(new FetchError(`network timeout at: ${request.url}`, 'request-timeout')); - finalize(); - }, request.timeout); - }); - } - - req.on('error', function (err) { - reject(new FetchError(`request to ${request.url} failed, reason: ${err.message}`, 'system', err)); - - if (response && response.body) { - destroyStream(response.body, err); - } - - finalize(); - }); - - fixResponseChunkedTransferBadEnding(req, function (err) { - if (signal && signal.aborted) { - return; - } - - if (response && response.body) { - destroyStream(response.body, err); - } - }); - - /* c8 ignore next 18 */ - if (parseInt(process.version.substring(1)) < 14) { - // Before Node.js 14, pipeline() does not fully support async iterators and does not always - // properly handle when the socket close/end events are out of order. - req.on('socket', function (s) { - s.addListener('close', function (hadError) { - // if a data listener is still present we didn't end cleanly - const hasDataListener = s.listenerCount('data') > 0; - - // if end happened before close but the socket didn't emit an error, do it now - if (response && hasDataListener && !hadError && !(signal && signal.aborted)) { - const err = new Error('Premature close'); - err.code = 'ERR_STREAM_PREMATURE_CLOSE'; - response.body.emit('error', err); - } - }); - }); - } - - req.on('response', function (res) { - clearTimeout(reqTimeout); - - const headers = createHeadersLenient(res.headers); - - // HTTP fetch step 5 - if (fetch.isRedirect(res.statusCode)) { - // HTTP fetch step 5.2 - const location = headers.get('Location'); - - // HTTP fetch step 5.3 - let locationURL = null; - try { - locationURL = location === null ? null : new URL$1(location, request.url).toString(); - } catch (err) { - // error here can only be invalid URL in Location: header - // do not throw when options.redirect == manual - // let the user extract the errorneous redirect URL - if (request.redirect !== 'manual') { - reject(new FetchError(`uri requested responds with an invalid redirect URL: ${location}`, 'invalid-redirect')); - finalize(); - return; - } - } - - // HTTP fetch step 5.5 - switch (request.redirect) { - case 'error': - reject(new FetchError(`uri requested responds with a redirect, redirect mode is set to error: ${request.url}`, 'no-redirect')); - finalize(); - return; - case 'manual': - // node-fetch-specific step: make manual redirect a bit easier to use by setting the Location header value to the resolved URL. - if (locationURL !== null) { - // handle corrupted header - try { - headers.set('Location', locationURL); - } catch (err) { - // istanbul ignore next: nodejs server prevent invalid response headers, we can't test this through normal request - reject(err); - } - } - break; - case 'follow': - // HTTP-redirect fetch step 2 - if (locationURL === null) { - break; - } - - // HTTP-redirect fetch step 5 - if (request.counter >= request.follow) { - reject(new FetchError(`maximum redirect reached at: ${request.url}`, 'max-redirect')); - finalize(); - return; - } - - // HTTP-redirect fetch step 6 (counter increment) - // Create a new Request object. - const requestOpts = { - headers: new Headers(request.headers), - follow: request.follow, - counter: request.counter + 1, - agent: request.agent, - compress: request.compress, - method: request.method, - body: request.body, - signal: request.signal, - timeout: request.timeout, - size: request.size - }; - - if (!isDomainOrSubdomain(request.url, locationURL) || !isSameProtocol(request.url, locationURL)) { - for (const name of ['authorization', 'www-authenticate', 'cookie', 'cookie2']) { - requestOpts.headers.delete(name); - } - } - - // HTTP-redirect fetch step 9 - if (res.statusCode !== 303 && request.body && getTotalBytes(request) === null) { - reject(new FetchError('Cannot follow redirect with body being a readable stream', 'unsupported-redirect')); - finalize(); - return; - } - - // HTTP-redirect fetch step 11 - if (res.statusCode === 303 || (res.statusCode === 301 || res.statusCode === 302) && request.method === 'POST') { - requestOpts.method = 'GET'; - requestOpts.body = undefined; - requestOpts.headers.delete('content-length'); - } - - // HTTP-redirect fetch step 15 - resolve(fetch(new Request(locationURL, requestOpts))); - finalize(); - return; - } - } - - // prepare response - res.once('end', function () { - if (signal) signal.removeEventListener('abort', abortAndFinalize); - }); - let body = res.pipe(new PassThrough$1()); - - const response_options = { - url: request.url, - status: res.statusCode, - statusText: res.statusMessage, - headers: headers, - size: request.size, - timeout: request.timeout, - counter: request.counter - }; - - // HTTP-network fetch step 12.1.1.3 - const codings = headers.get('Content-Encoding'); - - // HTTP-network fetch step 12.1.1.4: handle content codings - - // in following scenarios we ignore compression support - // 1. compression support is disabled - // 2. HEAD request - // 3. no Content-Encoding header - // 4. no content response (204) - // 5. content not modified response (304) - if (!request.compress || request.method === 'HEAD' || codings === null || res.statusCode === 204 || res.statusCode === 304) { - response = new Response(body, response_options); - resolve(response); - return; - } - - // For Node v6+ - // Be less strict when decoding compressed responses, since sometimes - // servers send slightly invalid responses that are still accepted - // by common browsers. - // Always using Z_SYNC_FLUSH is what cURL does. - const zlibOptions = { - flush: zlib.Z_SYNC_FLUSH, - finishFlush: zlib.Z_SYNC_FLUSH - }; - - // for gzip - if (codings == 'gzip' || codings == 'x-gzip') { - body = body.pipe(zlib.createGunzip(zlibOptions)); - response = new Response(body, response_options); - resolve(response); - return; - } - - // for deflate - if (codings == 'deflate' || codings == 'x-deflate') { - // handle the infamous raw deflate response from old servers - // a hack for old IIS and Apache servers - const raw = res.pipe(new PassThrough$1()); - raw.once('data', function (chunk) { - // see http://stackoverflow.com/questions/37519828 - if ((chunk[0] & 0x0F) === 0x08) { - body = body.pipe(zlib.createInflate()); - } else { - body = body.pipe(zlib.createInflateRaw()); - } - response = new Response(body, response_options); - resolve(response); - }); - raw.on('end', function () { - // some old IIS servers return zero-length OK deflate responses, so 'data' is never emitted. - if (!response) { - response = new Response(body, response_options); - resolve(response); - } - }); - return; - } - - // for br - if (codings == 'br' && typeof zlib.createBrotliDecompress === 'function') { - body = body.pipe(zlib.createBrotliDecompress()); - response = new Response(body, response_options); - resolve(response); - return; - } - - // otherwise, use response as-is - response = new Response(body, response_options); - resolve(response); - }); - - writeToStream(req, request); - }); -} -function fixResponseChunkedTransferBadEnding(request, errorCallback) { - let socket; - - request.on('socket', function (s) { - socket = s; - }); - - request.on('response', function (response) { - const headers = response.headers; - - if (headers['transfer-encoding'] === 'chunked' && !headers['content-length']) { - response.once('close', function (hadError) { - // tests for socket presence, as in some situations the - // the 'socket' event is not triggered for the request - // (happens in deno), avoids `TypeError` - // if a data listener is still present we didn't end cleanly - const hasDataListener = socket && socket.listenerCount('data') > 0; - - if (hasDataListener && !hadError) { - const err = new Error('Premature close'); - err.code = 'ERR_STREAM_PREMATURE_CLOSE'; - errorCallback(err); - } - }); - } - }); -} - -function destroyStream(stream, err) { - if (stream.destroy) { - stream.destroy(err); - } else { - // node < 8 - stream.emit('error', err); - stream.end(); - } -} - -/** - * Redirect code matching - * - * @param Number code Status code - * @return Boolean - */ -fetch.isRedirect = function (code) { - return code === 301 || code === 302 || code === 303 || code === 307 || code === 308; -}; - -// expose Promise -fetch.Promise = global.Promise; - -module.exports = exports = fetch; -Object.defineProperty(exports, "__esModule", ({ value: true })); -exports["default"] = exports; -exports.Headers = Headers; -exports.Request = Request; -exports.Response = Response; -exports.FetchError = FetchError; -exports.AbortError = AbortError; - - -/***/ }), - -/***/ 1552: -/***/ ((module, __unused_webpack_exports, __nccwpck_require__) => { - - - -var punycode = __nccwpck_require__(4876); -var mappingTable = __nccwpck_require__(2472); - -var PROCESSING_OPTIONS = { - TRANSITIONAL: 0, - NONTRANSITIONAL: 1 -}; - -function normalize(str) { // fix bug in v8 - return str.split('\u0000').map(function (s) { return s.normalize('NFC'); }).join('\u0000'); -} - -function findStatus(val) { - var start = 0; - var end = mappingTable.length - 1; - - while (start <= end) { - var mid = Math.floor((start + end) / 2); - - var target = mappingTable[mid]; - if (target[0][0] <= val && target[0][1] >= val) { - return target; - } else if (target[0][0] > val) { - end = mid - 1; - } else { - start = mid + 1; - } - } - - return null; -} - -var regexAstralSymbols = /[\uD800-\uDBFF][\uDC00-\uDFFF]/g; - -function countSymbols(string) { - return string - // replace every surrogate pair with a BMP symbol - .replace(regexAstralSymbols, '_') - // then get the length - .length; -} - -function mapChars(domain_name, useSTD3, processing_option) { - var hasError = false; - var processed = ""; - - var len = countSymbols(domain_name); - for (var i = 0; i < len; ++i) { - var codePoint = domain_name.codePointAt(i); - var status = findStatus(codePoint); - - switch (status[1]) { - case "disallowed": - hasError = true; - processed += String.fromCodePoint(codePoint); - break; - case "ignored": - break; - case "mapped": - processed += String.fromCodePoint.apply(String, status[2]); - break; - case "deviation": - if (processing_option === PROCESSING_OPTIONS.TRANSITIONAL) { - processed += String.fromCodePoint.apply(String, status[2]); - } else { - processed += String.fromCodePoint(codePoint); - } - break; - case "valid": - processed += String.fromCodePoint(codePoint); - break; - case "disallowed_STD3_mapped": - if (useSTD3) { - hasError = true; - processed += String.fromCodePoint(codePoint); - } else { - processed += String.fromCodePoint.apply(String, status[2]); - } - break; - case "disallowed_STD3_valid": - if (useSTD3) { - hasError = true; - } - - processed += String.fromCodePoint(codePoint); - break; - } - } - - return { - string: processed, - error: hasError - }; -} - -var combiningMarksRegex = /[\u0300-\u036F\u0483-\u0489\u0591-\u05BD\u05BF\u05C1\u05C2\u05C4\u05C5\u05C7\u0610-\u061A\u064B-\u065F\u0670\u06D6-\u06DC\u06DF-\u06E4\u06E7\u06E8\u06EA-\u06ED\u0711\u0730-\u074A\u07A6-\u07B0\u07EB-\u07F3\u0816-\u0819\u081B-\u0823\u0825-\u0827\u0829-\u082D\u0859-\u085B\u08E4-\u0903\u093A-\u093C\u093E-\u094F\u0951-\u0957\u0962\u0963\u0981-\u0983\u09BC\u09BE-\u09C4\u09C7\u09C8\u09CB-\u09CD\u09D7\u09E2\u09E3\u0A01-\u0A03\u0A3C\u0A3E-\u0A42\u0A47\u0A48\u0A4B-\u0A4D\u0A51\u0A70\u0A71\u0A75\u0A81-\u0A83\u0ABC\u0ABE-\u0AC5\u0AC7-\u0AC9\u0ACB-\u0ACD\u0AE2\u0AE3\u0B01-\u0B03\u0B3C\u0B3E-\u0B44\u0B47\u0B48\u0B4B-\u0B4D\u0B56\u0B57\u0B62\u0B63\u0B82\u0BBE-\u0BC2\u0BC6-\u0BC8\u0BCA-\u0BCD\u0BD7\u0C00-\u0C03\u0C3E-\u0C44\u0C46-\u0C48\u0C4A-\u0C4D\u0C55\u0C56\u0C62\u0C63\u0C81-\u0C83\u0CBC\u0CBE-\u0CC4\u0CC6-\u0CC8\u0CCA-\u0CCD\u0CD5\u0CD6\u0CE2\u0CE3\u0D01-\u0D03\u0D3E-\u0D44\u0D46-\u0D48\u0D4A-\u0D4D\u0D57\u0D62\u0D63\u0D82\u0D83\u0DCA\u0DCF-\u0DD4\u0DD6\u0DD8-\u0DDF\u0DF2\u0DF3\u0E31\u0E34-\u0E3A\u0E47-\u0E4E\u0EB1\u0EB4-\u0EB9\u0EBB\u0EBC\u0EC8-\u0ECD\u0F18\u0F19\u0F35\u0F37\u0F39\u0F3E\u0F3F\u0F71-\u0F84\u0F86\u0F87\u0F8D-\u0F97\u0F99-\u0FBC\u0FC6\u102B-\u103E\u1056-\u1059\u105E-\u1060\u1062-\u1064\u1067-\u106D\u1071-\u1074\u1082-\u108D\u108F\u109A-\u109D\u135D-\u135F\u1712-\u1714\u1732-\u1734\u1752\u1753\u1772\u1773\u17B4-\u17D3\u17DD\u180B-\u180D\u18A9\u1920-\u192B\u1930-\u193B\u19B0-\u19C0\u19C8\u19C9\u1A17-\u1A1B\u1A55-\u1A5E\u1A60-\u1A7C\u1A7F\u1AB0-\u1ABE\u1B00-\u1B04\u1B34-\u1B44\u1B6B-\u1B73\u1B80-\u1B82\u1BA1-\u1BAD\u1BE6-\u1BF3\u1C24-\u1C37\u1CD0-\u1CD2\u1CD4-\u1CE8\u1CED\u1CF2-\u1CF4\u1CF8\u1CF9\u1DC0-\u1DF5\u1DFC-\u1DFF\u20D0-\u20F0\u2CEF-\u2CF1\u2D7F\u2DE0-\u2DFF\u302A-\u302F\u3099\u309A\uA66F-\uA672\uA674-\uA67D\uA69F\uA6F0\uA6F1\uA802\uA806\uA80B\uA823-\uA827\uA880\uA881\uA8B4-\uA8C4\uA8E0-\uA8F1\uA926-\uA92D\uA947-\uA953\uA980-\uA983\uA9B3-\uA9C0\uA9E5\uAA29-\uAA36\uAA43\uAA4C\uAA4D\uAA7B-\uAA7D\uAAB0\uAAB2-\uAAB4\uAAB7\uAAB8\uAABE\uAABF\uAAC1\uAAEB-\uAAEF\uAAF5\uAAF6\uABE3-\uABEA\uABEC\uABED\uFB1E\uFE00-\uFE0F\uFE20-\uFE2D]|\uD800[\uDDFD\uDEE0\uDF76-\uDF7A]|\uD802[\uDE01-\uDE03\uDE05\uDE06\uDE0C-\uDE0F\uDE38-\uDE3A\uDE3F\uDEE5\uDEE6]|\uD804[\uDC00-\uDC02\uDC38-\uDC46\uDC7F-\uDC82\uDCB0-\uDCBA\uDD00-\uDD02\uDD27-\uDD34\uDD73\uDD80-\uDD82\uDDB3-\uDDC0\uDE2C-\uDE37\uDEDF-\uDEEA\uDF01-\uDF03\uDF3C\uDF3E-\uDF44\uDF47\uDF48\uDF4B-\uDF4D\uDF57\uDF62\uDF63\uDF66-\uDF6C\uDF70-\uDF74]|\uD805[\uDCB0-\uDCC3\uDDAF-\uDDB5\uDDB8-\uDDC0\uDE30-\uDE40\uDEAB-\uDEB7]|\uD81A[\uDEF0-\uDEF4\uDF30-\uDF36]|\uD81B[\uDF51-\uDF7E\uDF8F-\uDF92]|\uD82F[\uDC9D\uDC9E]|\uD834[\uDD65-\uDD69\uDD6D-\uDD72\uDD7B-\uDD82\uDD85-\uDD8B\uDDAA-\uDDAD\uDE42-\uDE44]|\uD83A[\uDCD0-\uDCD6]|\uDB40[\uDD00-\uDDEF]/; - -function validateLabel(label, processing_option) { - if (label.substr(0, 4) === "xn--") { - label = punycode.toUnicode(label); - processing_option = PROCESSING_OPTIONS.NONTRANSITIONAL; - } - - var error = false; - - if (normalize(label) !== label || - (label[3] === "-" && label[4] === "-") || - label[0] === "-" || label[label.length - 1] === "-" || - label.indexOf(".") !== -1 || - label.search(combiningMarksRegex) === 0) { - error = true; - } - - var len = countSymbols(label); - for (var i = 0; i < len; ++i) { - var status = findStatus(label.codePointAt(i)); - if ((processing === PROCESSING_OPTIONS.TRANSITIONAL && status[1] !== "valid") || - (processing === PROCESSING_OPTIONS.NONTRANSITIONAL && - status[1] !== "valid" && status[1] !== "deviation")) { - error = true; - break; - } - } - - return { - label: label, - error: error - }; -} - -function processing(domain_name, useSTD3, processing_option) { - var result = mapChars(domain_name, useSTD3, processing_option); - result.string = normalize(result.string); - - var labels = result.string.split("."); - for (var i = 0; i < labels.length; ++i) { - try { - var validation = validateLabel(labels[i]); - labels[i] = validation.label; - result.error = result.error || validation.error; - } catch(e) { - result.error = true; - } - } - - return { - string: labels.join("."), - error: result.error - }; -} - -module.exports.toASCII = function(domain_name, useSTD3, processing_option, verifyDnsLength) { - var result = processing(domain_name, useSTD3, processing_option); - var labels = result.string.split("."); - labels = labels.map(function(l) { - try { - return punycode.toASCII(l); - } catch(e) { - result.error = true; - return l; - } - }); - - if (verifyDnsLength) { - var total = labels.slice(0, labels.length - 1).join(".").length; - if (total.length > 253 || total.length === 0) { - result.error = true; - } - - for (var i=0; i < labels.length; ++i) { - if (labels.length > 63 || labels.length === 0) { - result.error = true; - break; - } - } - } - - if (result.error) return null; - return labels.join("."); -}; - -module.exports.toUnicode = function(domain_name, useSTD3) { - var result = processing(domain_name, useSTD3, PROCESSING_OPTIONS.NONTRANSITIONAL); - - return { - domain: result.string, - error: result.error - }; -}; - -module.exports.PROCESSING_OPTIONS = PROCESSING_OPTIONS; - - /***/ }), /***/ 770: @@ -27541,3940 +25547,10767 @@ module.exports = { /***/ }), -/***/ 7125: +/***/ 2613: /***/ ((module) => { +module.exports = __WEBPACK_EXTERNAL_createRequire(import.meta.url)("assert"); +/***/ }), -var conversions = {}; -module.exports = conversions; +/***/ 290: +/***/ ((module) => { -function sign(x) { - return x < 0 ? -1 : 1; -} +module.exports = __WEBPACK_EXTERNAL_createRequire(import.meta.url)("async_hooks"); -function evenRound(x) { - // Round x to the nearest integer, choosing the even integer if it lies halfway between two. - if ((x % 1) === 0.5 && (x & 1) === 0) { // [even number].5; round down (i.e. floor) - return Math.floor(x); - } else { - return Math.round(x); - } -} +/***/ }), -function createNumberConversion(bitLength, typeOpts) { - if (!typeOpts.unsigned) { - --bitLength; - } - const lowerBound = typeOpts.unsigned ? 0 : -Math.pow(2, bitLength); - const upperBound = Math.pow(2, bitLength) - 1; +/***/ 181: +/***/ ((module) => { - const moduloVal = typeOpts.moduloBitLength ? Math.pow(2, typeOpts.moduloBitLength) : Math.pow(2, bitLength); - const moduloBound = typeOpts.moduloBitLength ? Math.pow(2, typeOpts.moduloBitLength - 1) : Math.pow(2, bitLength - 1); +module.exports = __WEBPACK_EXTERNAL_createRequire(import.meta.url)("buffer"); - return function(V, opts) { - if (!opts) opts = {}; +/***/ }), - let x = +V; +/***/ 5317: +/***/ ((module) => { - if (opts.enforceRange) { - if (!Number.isFinite(x)) { - throw new TypeError("Argument is not a finite number"); - } - - x = sign(x) * Math.floor(Math.abs(x)); - if (x < lowerBound || x > upperBound) { - throw new TypeError("Argument is not in byte range"); - } - - return x; - } - - if (!isNaN(x) && opts.clamp) { - x = evenRound(x); - - if (x < lowerBound) x = lowerBound; - if (x > upperBound) x = upperBound; - return x; - } - - if (!Number.isFinite(x) || x === 0) { - return 0; - } - - x = sign(x) * Math.floor(Math.abs(x)); - x = x % moduloVal; +module.exports = __WEBPACK_EXTERNAL_createRequire(import.meta.url)("child_process"); - if (!typeOpts.unsigned && x >= moduloBound) { - return x - moduloVal; - } else if (typeOpts.unsigned) { - if (x < 0) { - x += moduloVal; - } else if (x === -0) { // don't return negative zero - return 0; - } - } +/***/ }), - return x; - } -} +/***/ 4236: +/***/ ((module) => { -conversions["void"] = function () { - return undefined; -}; +module.exports = __WEBPACK_EXTERNAL_createRequire(import.meta.url)("console"); -conversions["boolean"] = function (val) { - return !!val; -}; +/***/ }), -conversions["byte"] = createNumberConversion(8, { unsigned: false }); -conversions["octet"] = createNumberConversion(8, { unsigned: true }); +/***/ 6982: +/***/ ((module) => { -conversions["short"] = createNumberConversion(16, { unsigned: false }); -conversions["unsigned short"] = createNumberConversion(16, { unsigned: true }); +module.exports = __WEBPACK_EXTERNAL_createRequire(import.meta.url)("crypto"); -conversions["long"] = createNumberConversion(32, { unsigned: false }); -conversions["unsigned long"] = createNumberConversion(32, { unsigned: true }); +/***/ }), -conversions["long long"] = createNumberConversion(32, { unsigned: false, moduloBitLength: 64 }); -conversions["unsigned long long"] = createNumberConversion(32, { unsigned: true, moduloBitLength: 64 }); +/***/ 1637: +/***/ ((module) => { -conversions["double"] = function (V) { - const x = +V; +module.exports = __WEBPACK_EXTERNAL_createRequire(import.meta.url)("diagnostics_channel"); - if (!Number.isFinite(x)) { - throw new TypeError("Argument is not a finite floating-point value"); - } +/***/ }), - return x; -}; +/***/ 4434: +/***/ ((module) => { -conversions["unrestricted double"] = function (V) { - const x = +V; +module.exports = __WEBPACK_EXTERNAL_createRequire(import.meta.url)("events"); - if (isNaN(x)) { - throw new TypeError("Argument is NaN"); - } +/***/ }), - return x; -}; +/***/ 9896: +/***/ ((module) => { -// not quite valid, but good enough for JS -conversions["float"] = conversions["double"]; -conversions["unrestricted float"] = conversions["unrestricted double"]; +module.exports = __WEBPACK_EXTERNAL_createRequire(import.meta.url)("fs"); -conversions["DOMString"] = function (V, opts) { - if (!opts) opts = {}; +/***/ }), - if (opts.treatNullAsEmptyString && V === null) { - return ""; - } +/***/ 8611: +/***/ ((module) => { - return String(V); -}; +module.exports = __WEBPACK_EXTERNAL_createRequire(import.meta.url)("http"); -conversions["ByteString"] = function (V, opts) { - const x = String(V); - let c = undefined; - for (let i = 0; (c = x.codePointAt(i)) !== undefined; ++i) { - if (c > 255) { - throw new TypeError("Argument is not a valid bytestring"); - } - } +/***/ }), - return x; -}; +/***/ 5675: +/***/ ((module) => { -conversions["USVString"] = function (V) { - const S = String(V); - const n = S.length; - const U = []; - for (let i = 0; i < n; ++i) { - const c = S.charCodeAt(i); - if (c < 0xD800 || c > 0xDFFF) { - U.push(String.fromCodePoint(c)); - } else if (0xDC00 <= c && c <= 0xDFFF) { - U.push(String.fromCodePoint(0xFFFD)); - } else { - if (i === n - 1) { - U.push(String.fromCodePoint(0xFFFD)); - } else { - const d = S.charCodeAt(i + 1); - if (0xDC00 <= d && d <= 0xDFFF) { - const a = c & 0x3FF; - const b = d & 0x3FF; - U.push(String.fromCodePoint((2 << 15) + (2 << 9) * a + b)); - ++i; - } else { - U.push(String.fromCodePoint(0xFFFD)); - } - } - } - } +module.exports = __WEBPACK_EXTERNAL_createRequire(import.meta.url)("http2"); - return U.join(''); -}; +/***/ }), -conversions["Date"] = function (V, opts) { - if (!(V instanceof Date)) { - throw new TypeError("Argument is not a Date object"); - } - if (isNaN(V)) { - return undefined; - } +/***/ 5692: +/***/ ((module) => { - return V; -}; +module.exports = __WEBPACK_EXTERNAL_createRequire(import.meta.url)("https"); -conversions["RegExp"] = function (V, opts) { - if (!(V instanceof RegExp)) { - V = new RegExp(V); - } +/***/ }), - return V; -}; +/***/ 9278: +/***/ ((module) => { +module.exports = __WEBPACK_EXTERNAL_createRequire(import.meta.url)("net"); /***/ }), -/***/ 3184: -/***/ ((__unused_webpack_module, exports, __nccwpck_require__) => { - +/***/ 8474: +/***/ ((module) => { -const usm = __nccwpck_require__(905); +module.exports = __WEBPACK_EXTERNAL_createRequire(import.meta.url)("node:events"); -exports.implementation = class URLImpl { - constructor(constructorArgs) { - const url = constructorArgs[0]; - const base = constructorArgs[1]; +/***/ }), - let parsedBase = null; - if (base !== undefined) { - parsedBase = usm.basicURLParse(base); - if (parsedBase === "failure") { - throw new TypeError("Invalid base URL"); - } - } +/***/ 7075: +/***/ ((module) => { - const parsedURL = usm.basicURLParse(url, { baseURL: parsedBase }); - if (parsedURL === "failure") { - throw new TypeError("Invalid URL"); - } +module.exports = __WEBPACK_EXTERNAL_createRequire(import.meta.url)("node:stream"); - this._url = parsedURL; +/***/ }), - // TODO: query stuff - } +/***/ 7975: +/***/ ((module) => { - get href() { - return usm.serializeURL(this._url); - } +module.exports = __WEBPACK_EXTERNAL_createRequire(import.meta.url)("node:util"); - set href(v) { - const parsedURL = usm.basicURLParse(v); - if (parsedURL === "failure") { - throw new TypeError("Invalid URL"); - } +/***/ }), - this._url = parsedURL; - } +/***/ 857: +/***/ ((module) => { - get origin() { - return usm.serializeURLOrigin(this._url); - } +module.exports = __WEBPACK_EXTERNAL_createRequire(import.meta.url)("os"); - get protocol() { - return this._url.scheme + ":"; - } +/***/ }), - set protocol(v) { - usm.basicURLParse(v + ":", { url: this._url, stateOverride: "scheme start" }); - } +/***/ 6928: +/***/ ((module) => { - get username() { - return this._url.username; - } +module.exports = __WEBPACK_EXTERNAL_createRequire(import.meta.url)("path"); - set username(v) { - if (usm.cannotHaveAUsernamePasswordPort(this._url)) { - return; - } +/***/ }), - usm.setTheUsername(this._url, v); - } +/***/ 2987: +/***/ ((module) => { - get password() { - return this._url.password; - } +module.exports = __WEBPACK_EXTERNAL_createRequire(import.meta.url)("perf_hooks"); - set password(v) { - if (usm.cannotHaveAUsernamePasswordPort(this._url)) { - return; - } +/***/ }), - usm.setThePassword(this._url, v); - } +/***/ 3480: +/***/ ((module) => { - get host() { - const url = this._url; +module.exports = __WEBPACK_EXTERNAL_createRequire(import.meta.url)("querystring"); - if (url.host === null) { - return ""; - } +/***/ }), - if (url.port === null) { - return usm.serializeHost(url.host); - } +/***/ 2203: +/***/ ((module) => { - return usm.serializeHost(url.host) + ":" + usm.serializeInteger(url.port); - } +module.exports = __WEBPACK_EXTERNAL_createRequire(import.meta.url)("stream"); - set host(v) { - if (this._url.cannotBeABaseURL) { - return; - } +/***/ }), - usm.basicURLParse(v, { url: this._url, stateOverride: "host" }); - } +/***/ 3774: +/***/ ((module) => { - get hostname() { - if (this._url.host === null) { - return ""; - } +module.exports = __WEBPACK_EXTERNAL_createRequire(import.meta.url)("stream/web"); - return usm.serializeHost(this._url.host); - } +/***/ }), - set hostname(v) { - if (this._url.cannotBeABaseURL) { - return; - } +/***/ 3193: +/***/ ((module) => { - usm.basicURLParse(v, { url: this._url, stateOverride: "hostname" }); - } +module.exports = __WEBPACK_EXTERNAL_createRequire(import.meta.url)("string_decoder"); - get port() { - if (this._url.port === null) { - return ""; - } +/***/ }), - return usm.serializeInteger(this._url.port); - } +/***/ 3557: +/***/ ((module) => { - set port(v) { - if (usm.cannotHaveAUsernamePasswordPort(this._url)) { - return; - } +module.exports = __WEBPACK_EXTERNAL_createRequire(import.meta.url)("timers"); - if (v === "") { - this._url.port = null; - } else { - usm.basicURLParse(v, { url: this._url, stateOverride: "port" }); - } - } +/***/ }), - get pathname() { - if (this._url.cannotBeABaseURL) { - return this._url.path[0]; - } +/***/ 4756: +/***/ ((module) => { - if (this._url.path.length === 0) { - return ""; - } +module.exports = __WEBPACK_EXTERNAL_createRequire(import.meta.url)("tls"); - return "/" + this._url.path.join("/"); - } +/***/ }), - set pathname(v) { - if (this._url.cannotBeABaseURL) { - return; - } +/***/ 7016: +/***/ ((module) => { - this._url.path = []; - usm.basicURLParse(v, { url: this._url, stateOverride: "path start" }); - } +module.exports = __WEBPACK_EXTERNAL_createRequire(import.meta.url)("url"); - get search() { - if (this._url.query === null || this._url.query === "") { - return ""; - } +/***/ }), - return "?" + this._url.query; - } +/***/ 9023: +/***/ ((module) => { - set search(v) { - // TODO: query stuff +module.exports = __WEBPACK_EXTERNAL_createRequire(import.meta.url)("util"); - const url = this._url; +/***/ }), - if (v === "") { - url.query = null; - return; - } +/***/ 8253: +/***/ ((module) => { - const input = v[0] === "?" ? v.substring(1) : v; - url.query = ""; - usm.basicURLParse(input, { url, stateOverride: "query" }); - } +module.exports = __WEBPACK_EXTERNAL_createRequire(import.meta.url)("util/types"); - get hash() { - if (this._url.fragment === null || this._url.fragment === "") { - return ""; - } +/***/ }), - return "#" + this._url.fragment; - } +/***/ 8167: +/***/ ((module) => { - set hash(v) { - if (v === "") { - this._url.fragment = null; - return; - } +module.exports = __WEBPACK_EXTERNAL_createRequire(import.meta.url)("worker_threads"); - const input = v[0] === "#" ? v.substring(1) : v; - this._url.fragment = ""; - usm.basicURLParse(input, { url: this._url, stateOverride: "fragment" }); - } +/***/ }), - toJSON() { - return this.href; - } -}; +/***/ 3106: +/***/ ((module) => { +module.exports = __WEBPACK_EXTERNAL_createRequire(import.meta.url)("zlib"); /***/ }), -/***/ 6633: +/***/ 7182: /***/ ((module, __unused_webpack_exports, __nccwpck_require__) => { -const conversions = __nccwpck_require__(7125); -const utils = __nccwpck_require__(9857); -const Impl = __nccwpck_require__(3184); +const WritableStream = (__nccwpck_require__(7075).Writable) +const inherits = (__nccwpck_require__(7975).inherits) -const impl = utils.implSymbol; +const StreamSearch = __nccwpck_require__(4136) -function URL(url) { - if (!this || this[impl] || !(this instanceof URL)) { - throw new TypeError("Failed to construct 'URL': Please use the 'new' operator, this DOM object constructor cannot be called as a function."); - } - if (arguments.length < 1) { - throw new TypeError("Failed to construct 'URL': 1 argument required, but only " + arguments.length + " present."); - } - const args = []; - for (let i = 0; i < arguments.length && i < 2; ++i) { - args[i] = arguments[i]; - } - args[0] = conversions["USVString"](args[0]); - if (args[1] !== undefined) { - args[1] = conversions["USVString"](args[1]); - } +const PartStream = __nccwpck_require__(612) +const HeaderParser = __nccwpck_require__(2271) - module.exports.setup(this, args); -} +const DASH = 45 +const B_ONEDASH = Buffer.from('-') +const B_CRLF = Buffer.from('\r\n') +const EMPTY_FN = function () {} -URL.prototype.toJSON = function toJSON() { - if (!this || !module.exports.is(this)) { - throw new TypeError("Illegal invocation"); - } - const args = []; - for (let i = 0; i < arguments.length && i < 0; ++i) { - args[i] = arguments[i]; - } - return this[impl].toJSON.apply(this[impl], args); -}; -Object.defineProperty(URL.prototype, "href", { - get() { - return this[impl].href; - }, - set(V) { - V = conversions["USVString"](V); - this[impl].href = V; - }, - enumerable: true, - configurable: true -}); +function Dicer (cfg) { + if (!(this instanceof Dicer)) { return new Dicer(cfg) } + WritableStream.call(this, cfg) -URL.prototype.toString = function () { - if (!this || !module.exports.is(this)) { - throw new TypeError("Illegal invocation"); - } - return this.href; -}; + if (!cfg || (!cfg.headerFirst && typeof cfg.boundary !== 'string')) { throw new TypeError('Boundary required') } -Object.defineProperty(URL.prototype, "origin", { - get() { - return this[impl].origin; - }, - enumerable: true, - configurable: true -}); + if (typeof cfg.boundary === 'string') { this.setBoundary(cfg.boundary) } else { this._bparser = undefined } -Object.defineProperty(URL.prototype, "protocol", { - get() { - return this[impl].protocol; - }, - set(V) { - V = conversions["USVString"](V); - this[impl].protocol = V; - }, - enumerable: true, - configurable: true -}); + this._headerFirst = cfg.headerFirst -Object.defineProperty(URL.prototype, "username", { - get() { - return this[impl].username; - }, - set(V) { - V = conversions["USVString"](V); - this[impl].username = V; - }, - enumerable: true, - configurable: true -}); + this._dashes = 0 + this._parts = 0 + this._finished = false + this._realFinish = false + this._isPreamble = true + this._justMatched = false + this._firstWrite = true + this._inHeader = true + this._part = undefined + this._cb = undefined + this._ignoreData = false + this._partOpts = { highWaterMark: cfg.partHwm } + this._pause = false -Object.defineProperty(URL.prototype, "password", { - get() { - return this[impl].password; - }, - set(V) { - V = conversions["USVString"](V); - this[impl].password = V; - }, - enumerable: true, - configurable: true -}); + const self = this + this._hparser = new HeaderParser(cfg) + this._hparser.on('header', function (header) { + self._inHeader = false + self._part.emit('header', header) + }) +} +inherits(Dicer, WritableStream) -Object.defineProperty(URL.prototype, "host", { - get() { - return this[impl].host; - }, - set(V) { - V = conversions["USVString"](V); - this[impl].host = V; - }, - enumerable: true, - configurable: true -}); +Dicer.prototype.emit = function (ev) { + if (ev === 'finish' && !this._realFinish) { + if (!this._finished) { + const self = this + process.nextTick(function () { + self.emit('error', new Error('Unexpected end of multipart data')) + if (self._part && !self._ignoreData) { + const type = (self._isPreamble ? 'Preamble' : 'Part') + self._part.emit('error', new Error(type + ' terminated early due to unexpected end of multipart data')) + self._part.push(null) + process.nextTick(function () { + self._realFinish = true + self.emit('finish') + self._realFinish = false + }) + return + } + self._realFinish = true + self.emit('finish') + self._realFinish = false + }) + } + } else { WritableStream.prototype.emit.apply(this, arguments) } +} -Object.defineProperty(URL.prototype, "hostname", { - get() { - return this[impl].hostname; - }, - set(V) { - V = conversions["USVString"](V); - this[impl].hostname = V; - }, - enumerable: true, - configurable: true -}); +Dicer.prototype._write = function (data, encoding, cb) { + // ignore unexpected data (e.g. extra trailer data after finished) + if (!this._hparser && !this._bparser) { return cb() } -Object.defineProperty(URL.prototype, "port", { - get() { - return this[impl].port; - }, - set(V) { - V = conversions["USVString"](V); - this[impl].port = V; - }, - enumerable: true, - configurable: true -}); + if (this._headerFirst && this._isPreamble) { + if (!this._part) { + this._part = new PartStream(this._partOpts) + if (this.listenerCount('preamble') !== 0) { this.emit('preamble', this._part) } else { this._ignore() } + } + const r = this._hparser.push(data) + if (!this._inHeader && r !== undefined && r < data.length) { data = data.slice(r) } else { return cb() } + } -Object.defineProperty(URL.prototype, "pathname", { - get() { - return this[impl].pathname; - }, - set(V) { - V = conversions["USVString"](V); - this[impl].pathname = V; - }, - enumerable: true, - configurable: true -}); + // allows for "easier" testing + if (this._firstWrite) { + this._bparser.push(B_CRLF) + this._firstWrite = false + } -Object.defineProperty(URL.prototype, "search", { - get() { - return this[impl].search; - }, - set(V) { - V = conversions["USVString"](V); - this[impl].search = V; - }, - enumerable: true, - configurable: true -}); + this._bparser.push(data) -Object.defineProperty(URL.prototype, "hash", { - get() { - return this[impl].hash; - }, - set(V) { - V = conversions["USVString"](V); - this[impl].hash = V; - }, - enumerable: true, - configurable: true -}); + if (this._pause) { this._cb = cb } else { cb() } +} +Dicer.prototype.reset = function () { + this._part = undefined + this._bparser = undefined + this._hparser = undefined +} -module.exports = { - is(obj) { - return !!obj && obj[impl] instanceof Impl.implementation; - }, - create(constructorArgs, privateData) { - let obj = Object.create(URL.prototype); - this.setup(obj, constructorArgs, privateData); - return obj; - }, - setup(obj, constructorArgs, privateData) { - if (!privateData) privateData = {}; - privateData.wrapper = obj; +Dicer.prototype.setBoundary = function (boundary) { + const self = this + this._bparser = new StreamSearch('\r\n--' + boundary) + this._bparser.on('info', function (isMatch, data, start, end) { + self._oninfo(isMatch, data, start, end) + }) +} - obj[impl] = new Impl.implementation(constructorArgs, privateData); - obj[impl][utils.wrapperSymbol] = obj; - }, - interface: URL, - expose: { - Window: { URL: URL }, - Worker: { URL: URL } +Dicer.prototype._ignore = function () { + if (this._part && !this._ignoreData) { + this._ignoreData = true + this._part.on('error', EMPTY_FN) + // we must perform some kind of read on the stream even though we are + // ignoring the data, otherwise node's Readable stream will not emit 'end' + // after pushing null to the stream + this._part.resume() } -}; - - +} -/***/ }), +Dicer.prototype._oninfo = function (isMatch, data, start, end) { + let buf; const self = this; let i = 0; let r; let shouldWriteMore = true -/***/ 2686: -/***/ ((__unused_webpack_module, exports, __nccwpck_require__) => { + if (!this._part && this._justMatched && data) { + while (this._dashes < 2 && (start + i) < end) { + if (data[start + i] === DASH) { + ++i + ++this._dashes + } else { + if (this._dashes) { buf = B_ONEDASH } + this._dashes = 0 + break + } + } + if (this._dashes === 2) { + if ((start + i) < end && this.listenerCount('trailer') !== 0) { this.emit('trailer', data.slice(start + i, end)) } + this.reset() + this._finished = true + // no more parts will be added + if (self._parts === 0) { + self._realFinish = true + self.emit('finish') + self._realFinish = false + } + } + if (this._dashes) { return } + } + if (this._justMatched) { this._justMatched = false } + if (!this._part) { + this._part = new PartStream(this._partOpts) + this._part._read = function (n) { + self._unpause() + } + if (this._isPreamble && this.listenerCount('preamble') !== 0) { + this.emit('preamble', this._part) + } else if (this._isPreamble !== true && this.listenerCount('part') !== 0) { + this.emit('part', this._part) + } else { + this._ignore() + } + if (!this._isPreamble) { this._inHeader = true } + } + if (data && start < end && !this._ignoreData) { + if (this._isPreamble || !this._inHeader) { + if (buf) { shouldWriteMore = this._part.push(buf) } + shouldWriteMore = this._part.push(data.slice(start, end)) + if (!shouldWriteMore) { this._pause = true } + } else if (!this._isPreamble && this._inHeader) { + if (buf) { this._hparser.push(buf) } + r = this._hparser.push(data.slice(start, end)) + if (!this._inHeader && r !== undefined && r < end) { this._oninfo(false, data, start + r, end) } + } + } + if (isMatch) { + this._hparser.reset() + if (this._isPreamble) { this._isPreamble = false } else { + if (start !== end) { + ++this._parts + this._part.on('end', function () { + if (--self._parts === 0) { + if (self._finished) { + self._realFinish = true + self.emit('finish') + self._realFinish = false + } else { + self._unpause() + } + } + }) + } + } + this._part.push(null) + this._part = undefined + this._ignoreData = false + this._justMatched = true + this._dashes = 0 + } +} +Dicer.prototype._unpause = function () { + if (!this._pause) { return } + this._pause = false + if (this._cb) { + const cb = this._cb + this._cb = undefined + cb() + } +} -exports.URL = __nccwpck_require__(6633)["interface"]; -exports.serializeURL = __nccwpck_require__(905).serializeURL; -exports.serializeURLOrigin = __nccwpck_require__(905).serializeURLOrigin; -exports.basicURLParse = __nccwpck_require__(905).basicURLParse; -exports.setTheUsername = __nccwpck_require__(905).setTheUsername; -exports.setThePassword = __nccwpck_require__(905).setThePassword; -exports.serializeHost = __nccwpck_require__(905).serializeHost; -exports.serializeInteger = __nccwpck_require__(905).serializeInteger; -exports.parseURL = __nccwpck_require__(905).parseURL; +module.exports = Dicer /***/ }), -/***/ 905: +/***/ 2271: /***/ ((module, __unused_webpack_exports, __nccwpck_require__) => { - -const punycode = __nccwpck_require__(4876); -const tr46 = __nccwpck_require__(1552); - -const specialSchemes = { - ftp: 21, - file: null, - gopher: 70, - http: 80, - https: 443, - ws: 80, - wss: 443 -}; - -const failure = Symbol("failure"); - -function countSymbols(str) { - return punycode.ucs2.decode(str).length; -} - -function at(input, idx) { - const c = input[idx]; - return isNaN(c) ? undefined : String.fromCodePoint(c); -} - -function isASCIIDigit(c) { - return c >= 0x30 && c <= 0x39; -} - -function isASCIIAlpha(c) { - return (c >= 0x41 && c <= 0x5A) || (c >= 0x61 && c <= 0x7A); -} - -function isASCIIAlphanumeric(c) { - return isASCIIAlpha(c) || isASCIIDigit(c); -} - -function isASCIIHex(c) { - return isASCIIDigit(c) || (c >= 0x41 && c <= 0x46) || (c >= 0x61 && c <= 0x66); -} - -function isSingleDot(buffer) { - return buffer === "." || buffer.toLowerCase() === "%2e"; -} - -function isDoubleDot(buffer) { - buffer = buffer.toLowerCase(); - return buffer === ".." || buffer === "%2e." || buffer === ".%2e" || buffer === "%2e%2e"; -} - -function isWindowsDriveLetterCodePoints(cp1, cp2) { - return isASCIIAlpha(cp1) && (cp2 === 58 || cp2 === 124); -} - -function isWindowsDriveLetterString(string) { - return string.length === 2 && isASCIIAlpha(string.codePointAt(0)) && (string[1] === ":" || string[1] === "|"); -} - -function isNormalizedWindowsDriveLetterString(string) { - return string.length === 2 && isASCIIAlpha(string.codePointAt(0)) && string[1] === ":"; -} - -function containsForbiddenHostCodePoint(string) { - return string.search(/\u0000|\u0009|\u000A|\u000D|\u0020|#|%|\/|:|\?|@|\[|\\|\]/) !== -1; -} - -function containsForbiddenHostCodePointExcludingPercent(string) { - return string.search(/\u0000|\u0009|\u000A|\u000D|\u0020|#|\/|:|\?|@|\[|\\|\]/) !== -1; -} - -function isSpecialScheme(scheme) { - return specialSchemes[scheme] !== undefined; -} - -function isSpecial(url) { - return isSpecialScheme(url.scheme); -} - -function defaultPort(scheme) { - return specialSchemes[scheme]; -} - -function percentEncode(c) { - let hex = c.toString(16).toUpperCase(); - if (hex.length === 1) { - hex = "0" + hex; - } - - return "%" + hex; -} - -function utf8PercentEncode(c) { - const buf = new Buffer(c); - - let str = ""; - - for (let i = 0; i < buf.length; ++i) { - str += percentEncode(buf[i]); - } - - return str; -} - -function utf8PercentDecode(str) { - const input = new Buffer(str); - const output = []; - for (let i = 0; i < input.length; ++i) { - if (input[i] !== 37) { - output.push(input[i]); - } else if (input[i] === 37 && isASCIIHex(input[i + 1]) && isASCIIHex(input[i + 2])) { - output.push(parseInt(input.slice(i + 1, i + 3).toString(), 16)); - i += 2; - } else { - output.push(input[i]); - } - } - return new Buffer(output).toString(); -} - -function isC0ControlPercentEncode(c) { - return c <= 0x1F || c > 0x7E; -} - -const extraPathPercentEncodeSet = new Set([32, 34, 35, 60, 62, 63, 96, 123, 125]); -function isPathPercentEncode(c) { - return isC0ControlPercentEncode(c) || extraPathPercentEncodeSet.has(c); -} - -const extraUserinfoPercentEncodeSet = - new Set([47, 58, 59, 61, 64, 91, 92, 93, 94, 124]); -function isUserinfoPercentEncode(c) { - return isPathPercentEncode(c) || extraUserinfoPercentEncodeSet.has(c); -} - -function percentEncodeChar(c, encodeSetPredicate) { - const cStr = String.fromCodePoint(c); - - if (encodeSetPredicate(c)) { - return utf8PercentEncode(cStr); - } - - return cStr; -} - -function parseIPv4Number(input) { - let R = 10; - - if (input.length >= 2 && input.charAt(0) === "0" && input.charAt(1).toLowerCase() === "x") { - input = input.substring(2); - R = 16; - } else if (input.length >= 2 && input.charAt(0) === "0") { - input = input.substring(1); - R = 8; - } - - if (input === "") { - return 0; - } - - const regex = R === 10 ? /[^0-9]/ : (R === 16 ? /[^0-9A-Fa-f]/ : /[^0-7]/); - if (regex.test(input)) { - return failure; - } - - return parseInt(input, R); -} - -function parseIPv4(input) { - const parts = input.split("."); - if (parts[parts.length - 1] === "") { - if (parts.length > 1) { - parts.pop(); - } - } - - if (parts.length > 4) { - return input; - } - - const numbers = []; - for (const part of parts) { - if (part === "") { - return input; - } - const n = parseIPv4Number(part); - if (n === failure) { - return input; - } - - numbers.push(n); - } - - for (let i = 0; i < numbers.length - 1; ++i) { - if (numbers[i] > 255) { - return failure; - } - } - if (numbers[numbers.length - 1] >= Math.pow(256, 5 - numbers.length)) { - return failure; - } - - let ipv4 = numbers.pop(); - let counter = 0; - - for (const n of numbers) { - ipv4 += n * Math.pow(256, 3 - counter); - ++counter; - } - - return ipv4; -} - -function serializeIPv4(address) { - let output = ""; - let n = address; - - for (let i = 1; i <= 4; ++i) { - output = String(n % 256) + output; - if (i !== 4) { - output = "." + output; - } - n = Math.floor(n / 256); - } - - return output; -} - -function parseIPv6(input) { - const address = [0, 0, 0, 0, 0, 0, 0, 0]; - let pieceIndex = 0; - let compress = null; - let pointer = 0; - - input = punycode.ucs2.decode(input); - - if (input[pointer] === 58) { - if (input[pointer + 1] !== 58) { - return failure; - } - - pointer += 2; - ++pieceIndex; - compress = pieceIndex; - } - - while (pointer < input.length) { - if (pieceIndex === 8) { - return failure; - } - - if (input[pointer] === 58) { - if (compress !== null) { - return failure; - } - ++pointer; - ++pieceIndex; - compress = pieceIndex; - continue; - } - - let value = 0; - let length = 0; - - while (length < 4 && isASCIIHex(input[pointer])) { - value = value * 0x10 + parseInt(at(input, pointer), 16); - ++pointer; - ++length; - } - - if (input[pointer] === 46) { - if (length === 0) { - return failure; - } - - pointer -= length; - - if (pieceIndex > 6) { - return failure; - } - - let numbersSeen = 0; - - while (input[pointer] !== undefined) { - let ipv4Piece = null; - - if (numbersSeen > 0) { - if (input[pointer] === 46 && numbersSeen < 4) { - ++pointer; - } else { - return failure; - } - } - - if (!isASCIIDigit(input[pointer])) { - return failure; - } - - while (isASCIIDigit(input[pointer])) { - const number = parseInt(at(input, pointer)); - if (ipv4Piece === null) { - ipv4Piece = number; - } else if (ipv4Piece === 0) { - return failure; - } else { - ipv4Piece = ipv4Piece * 10 + number; - } - if (ipv4Piece > 255) { - return failure; - } - ++pointer; - } - - address[pieceIndex] = address[pieceIndex] * 0x100 + ipv4Piece; - - ++numbersSeen; - - if (numbersSeen === 2 || numbersSeen === 4) { - ++pieceIndex; - } - } - - if (numbersSeen !== 4) { - return failure; - } - - break; - } else if (input[pointer] === 58) { - ++pointer; - if (input[pointer] === undefined) { - return failure; - } - } else if (input[pointer] !== undefined) { - return failure; - } - - address[pieceIndex] = value; - ++pieceIndex; - } - - if (compress !== null) { - let swaps = pieceIndex - compress; - pieceIndex = 7; - while (pieceIndex !== 0 && swaps > 0) { - const temp = address[compress + swaps - 1]; - address[compress + swaps - 1] = address[pieceIndex]; - address[pieceIndex] = temp; - --pieceIndex; - --swaps; - } - } else if (compress === null && pieceIndex !== 8) { - return failure; - } - - return address; -} - -function serializeIPv6(address) { - let output = ""; - const seqResult = findLongestZeroSequence(address); - const compress = seqResult.idx; - let ignore0 = false; - - for (let pieceIndex = 0; pieceIndex <= 7; ++pieceIndex) { - if (ignore0 && address[pieceIndex] === 0) { - continue; - } else if (ignore0) { - ignore0 = false; - } - - if (compress === pieceIndex) { - const separator = pieceIndex === 0 ? "::" : ":"; - output += separator; - ignore0 = true; - continue; - } - - output += address[pieceIndex].toString(16); - - if (pieceIndex !== 7) { - output += ":"; - } - } - - return output; -} - -function parseHost(input, isSpecialArg) { - if (input[0] === "[") { - if (input[input.length - 1] !== "]") { - return failure; - } - - return parseIPv6(input.substring(1, input.length - 1)); - } - - if (!isSpecialArg) { - return parseOpaqueHost(input); - } - - const domain = utf8PercentDecode(input); - const asciiDomain = tr46.toASCII(domain, false, tr46.PROCESSING_OPTIONS.NONTRANSITIONAL, false); - if (asciiDomain === null) { - return failure; - } - - if (containsForbiddenHostCodePoint(asciiDomain)) { - return failure; - } - - const ipv4Host = parseIPv4(asciiDomain); - if (typeof ipv4Host === "number" || ipv4Host === failure) { - return ipv4Host; - } - - return asciiDomain; -} - -function parseOpaqueHost(input) { - if (containsForbiddenHostCodePointExcludingPercent(input)) { - return failure; - } - - let output = ""; - const decoded = punycode.ucs2.decode(input); - for (let i = 0; i < decoded.length; ++i) { - output += percentEncodeChar(decoded[i], isC0ControlPercentEncode); - } - return output; -} - -function findLongestZeroSequence(arr) { - let maxIdx = null; - let maxLen = 1; // only find elements > 1 - let currStart = null; - let currLen = 0; - - for (let i = 0; i < arr.length; ++i) { - if (arr[i] !== 0) { - if (currLen > maxLen) { - maxIdx = currStart; - maxLen = currLen; - } - - currStart = null; - currLen = 0; - } else { - if (currStart === null) { - currStart = i; - } - ++currLen; - } - } - - // if trailing zeros - if (currLen > maxLen) { - maxIdx = currStart; - maxLen = currLen; - } - - return { - idx: maxIdx, - len: maxLen - }; -} - -function serializeHost(host) { - if (typeof host === "number") { - return serializeIPv4(host); - } - - // IPv6 serializer - if (host instanceof Array) { - return "[" + serializeIPv6(host) + "]"; - } - - return host; -} - -function trimControlChars(url) { - return url.replace(/^[\u0000-\u001F\u0020]+|[\u0000-\u001F\u0020]+$/g, ""); -} - -function trimTabAndNewline(url) { - return url.replace(/\u0009|\u000A|\u000D/g, ""); -} - -function shortenPath(url) { - const path = url.path; - if (path.length === 0) { - return; - } - if (url.scheme === "file" && path.length === 1 && isNormalizedWindowsDriveLetter(path[0])) { - return; - } - - path.pop(); -} - -function includesCredentials(url) { - return url.username !== "" || url.password !== ""; -} - -function cannotHaveAUsernamePasswordPort(url) { - return url.host === null || url.host === "" || url.cannotBeABaseURL || url.scheme === "file"; -} - -function isNormalizedWindowsDriveLetter(string) { - return /^[A-Za-z]:$/.test(string); -} - -function URLStateMachine(input, base, encodingOverride, url, stateOverride) { - this.pointer = 0; - this.input = input; - this.base = base || null; - this.encodingOverride = encodingOverride || "utf-8"; - this.stateOverride = stateOverride; - this.url = url; - this.failure = false; - this.parseError = false; - - if (!this.url) { - this.url = { - scheme: "", - username: "", - password: "", - host: null, - port: null, - path: [], - query: null, - fragment: null, - - cannotBeABaseURL: false - }; - - const res = trimControlChars(this.input); - if (res !== this.input) { - this.parseError = true; - } - this.input = res; - } - - const res = trimTabAndNewline(this.input); - if (res !== this.input) { - this.parseError = true; - } - this.input = res; - - this.state = stateOverride || "scheme start"; - - this.buffer = ""; - this.atFlag = false; - this.arrFlag = false; - this.passwordTokenSeenFlag = false; - - this.input = punycode.ucs2.decode(this.input); - - for (; this.pointer <= this.input.length; ++this.pointer) { - const c = this.input[this.pointer]; - const cStr = isNaN(c) ? undefined : String.fromCodePoint(c); - - // exec state machine - const ret = this["parse " + this.state](c, cStr); - if (!ret) { - break; // terminate algorithm - } else if (ret === failure) { - this.failure = true; - break; - } - } -} - -URLStateMachine.prototype["parse scheme start"] = function parseSchemeStart(c, cStr) { - if (isASCIIAlpha(c)) { - this.buffer += cStr.toLowerCase(); - this.state = "scheme"; - } else if (!this.stateOverride) { - this.state = "no scheme"; - --this.pointer; - } else { - this.parseError = true; - return failure; - } - - return true; -}; - -URLStateMachine.prototype["parse scheme"] = function parseScheme(c, cStr) { - if (isASCIIAlphanumeric(c) || c === 43 || c === 45 || c === 46) { - this.buffer += cStr.toLowerCase(); - } else if (c === 58) { - if (this.stateOverride) { - if (isSpecial(this.url) && !isSpecialScheme(this.buffer)) { - return false; - } - - if (!isSpecial(this.url) && isSpecialScheme(this.buffer)) { - return false; - } - - if ((includesCredentials(this.url) || this.url.port !== null) && this.buffer === "file") { - return false; - } - - if (this.url.scheme === "file" && (this.url.host === "" || this.url.host === null)) { - return false; - } - } - this.url.scheme = this.buffer; - this.buffer = ""; - if (this.stateOverride) { - return false; - } - if (this.url.scheme === "file") { - if (this.input[this.pointer + 1] !== 47 || this.input[this.pointer + 2] !== 47) { - this.parseError = true; - } - this.state = "file"; - } else if (isSpecial(this.url) && this.base !== null && this.base.scheme === this.url.scheme) { - this.state = "special relative or authority"; - } else if (isSpecial(this.url)) { - this.state = "special authority slashes"; - } else if (this.input[this.pointer + 1] === 47) { - this.state = "path or authority"; - ++this.pointer; - } else { - this.url.cannotBeABaseURL = true; - this.url.path.push(""); - this.state = "cannot-be-a-base-URL path"; - } - } else if (!this.stateOverride) { - this.buffer = ""; - this.state = "no scheme"; - this.pointer = -1; - } else { - this.parseError = true; - return failure; - } - - return true; -}; - -URLStateMachine.prototype["parse no scheme"] = function parseNoScheme(c) { - if (this.base === null || (this.base.cannotBeABaseURL && c !== 35)) { - return failure; - } else if (this.base.cannotBeABaseURL && c === 35) { - this.url.scheme = this.base.scheme; - this.url.path = this.base.path.slice(); - this.url.query = this.base.query; - this.url.fragment = ""; - this.url.cannotBeABaseURL = true; - this.state = "fragment"; - } else if (this.base.scheme === "file") { - this.state = "file"; - --this.pointer; - } else { - this.state = "relative"; - --this.pointer; - } - - return true; -}; - -URLStateMachine.prototype["parse special relative or authority"] = function parseSpecialRelativeOrAuthority(c) { - if (c === 47 && this.input[this.pointer + 1] === 47) { - this.state = "special authority ignore slashes"; - ++this.pointer; - } else { - this.parseError = true; - this.state = "relative"; - --this.pointer; - } - - return true; -}; - -URLStateMachine.prototype["parse path or authority"] = function parsePathOrAuthority(c) { - if (c === 47) { - this.state = "authority"; - } else { - this.state = "path"; - --this.pointer; - } - - return true; -}; - -URLStateMachine.prototype["parse relative"] = function parseRelative(c) { - this.url.scheme = this.base.scheme; - if (isNaN(c)) { - this.url.username = this.base.username; - this.url.password = this.base.password; - this.url.host = this.base.host; - this.url.port = this.base.port; - this.url.path = this.base.path.slice(); - this.url.query = this.base.query; - } else if (c === 47) { - this.state = "relative slash"; - } else if (c === 63) { - this.url.username = this.base.username; - this.url.password = this.base.password; - this.url.host = this.base.host; - this.url.port = this.base.port; - this.url.path = this.base.path.slice(); - this.url.query = ""; - this.state = "query"; - } else if (c === 35) { - this.url.username = this.base.username; - this.url.password = this.base.password; - this.url.host = this.base.host; - this.url.port = this.base.port; - this.url.path = this.base.path.slice(); - this.url.query = this.base.query; - this.url.fragment = ""; - this.state = "fragment"; - } else if (isSpecial(this.url) && c === 92) { - this.parseError = true; - this.state = "relative slash"; - } else { - this.url.username = this.base.username; - this.url.password = this.base.password; - this.url.host = this.base.host; - this.url.port = this.base.port; - this.url.path = this.base.path.slice(0, this.base.path.length - 1); - - this.state = "path"; - --this.pointer; - } - - return true; -}; - -URLStateMachine.prototype["parse relative slash"] = function parseRelativeSlash(c) { - if (isSpecial(this.url) && (c === 47 || c === 92)) { - if (c === 92) { - this.parseError = true; - } - this.state = "special authority ignore slashes"; - } else if (c === 47) { - this.state = "authority"; - } else { - this.url.username = this.base.username; - this.url.password = this.base.password; - this.url.host = this.base.host; - this.url.port = this.base.port; - this.state = "path"; - --this.pointer; - } - - return true; -}; - -URLStateMachine.prototype["parse special authority slashes"] = function parseSpecialAuthoritySlashes(c) { - if (c === 47 && this.input[this.pointer + 1] === 47) { - this.state = "special authority ignore slashes"; - ++this.pointer; - } else { - this.parseError = true; - this.state = "special authority ignore slashes"; - --this.pointer; - } - - return true; -}; - -URLStateMachine.prototype["parse special authority ignore slashes"] = function parseSpecialAuthorityIgnoreSlashes(c) { - if (c !== 47 && c !== 92) { - this.state = "authority"; - --this.pointer; - } else { - this.parseError = true; - } - - return true; -}; - -URLStateMachine.prototype["parse authority"] = function parseAuthority(c, cStr) { - if (c === 64) { - this.parseError = true; - if (this.atFlag) { - this.buffer = "%40" + this.buffer; - } - this.atFlag = true; - - // careful, this is based on buffer and has its own pointer (this.pointer != pointer) and inner chars - const len = countSymbols(this.buffer); - for (let pointer = 0; pointer < len; ++pointer) { - const codePoint = this.buffer.codePointAt(pointer); - - if (codePoint === 58 && !this.passwordTokenSeenFlag) { - this.passwordTokenSeenFlag = true; - continue; - } - const encodedCodePoints = percentEncodeChar(codePoint, isUserinfoPercentEncode); - if (this.passwordTokenSeenFlag) { - this.url.password += encodedCodePoints; - } else { - this.url.username += encodedCodePoints; - } - } - this.buffer = ""; - } else if (isNaN(c) || c === 47 || c === 63 || c === 35 || - (isSpecial(this.url) && c === 92)) { - if (this.atFlag && this.buffer === "") { - this.parseError = true; - return failure; - } - this.pointer -= countSymbols(this.buffer) + 1; - this.buffer = ""; - this.state = "host"; - } else { - this.buffer += cStr; - } - - return true; -}; - -URLStateMachine.prototype["parse hostname"] = -URLStateMachine.prototype["parse host"] = function parseHostName(c, cStr) { - if (this.stateOverride && this.url.scheme === "file") { - --this.pointer; - this.state = "file host"; - } else if (c === 58 && !this.arrFlag) { - if (this.buffer === "") { - this.parseError = true; - return failure; - } - - const host = parseHost(this.buffer, isSpecial(this.url)); - if (host === failure) { - return failure; - } - - this.url.host = host; - this.buffer = ""; - this.state = "port"; - if (this.stateOverride === "hostname") { - return false; - } - } else if (isNaN(c) || c === 47 || c === 63 || c === 35 || - (isSpecial(this.url) && c === 92)) { - --this.pointer; - if (isSpecial(this.url) && this.buffer === "") { - this.parseError = true; - return failure; - } else if (this.stateOverride && this.buffer === "" && - (includesCredentials(this.url) || this.url.port !== null)) { - this.parseError = true; - return false; - } - - const host = parseHost(this.buffer, isSpecial(this.url)); - if (host === failure) { - return failure; - } - - this.url.host = host; - this.buffer = ""; - this.state = "path start"; - if (this.stateOverride) { - return false; - } - } else { - if (c === 91) { - this.arrFlag = true; - } else if (c === 93) { - this.arrFlag = false; - } - this.buffer += cStr; - } - - return true; -}; - -URLStateMachine.prototype["parse port"] = function parsePort(c, cStr) { - if (isASCIIDigit(c)) { - this.buffer += cStr; - } else if (isNaN(c) || c === 47 || c === 63 || c === 35 || - (isSpecial(this.url) && c === 92) || - this.stateOverride) { - if (this.buffer !== "") { - const port = parseInt(this.buffer); - if (port > Math.pow(2, 16) - 1) { - this.parseError = true; - return failure; - } - this.url.port = port === defaultPort(this.url.scheme) ? null : port; - this.buffer = ""; - } - if (this.stateOverride) { - return false; - } - this.state = "path start"; - --this.pointer; - } else { - this.parseError = true; - return failure; - } - - return true; -}; - -const fileOtherwiseCodePoints = new Set([47, 92, 63, 35]); - -URLStateMachine.prototype["parse file"] = function parseFile(c) { - this.url.scheme = "file"; - - if (c === 47 || c === 92) { - if (c === 92) { - this.parseError = true; - } - this.state = "file slash"; - } else if (this.base !== null && this.base.scheme === "file") { - if (isNaN(c)) { - this.url.host = this.base.host; - this.url.path = this.base.path.slice(); - this.url.query = this.base.query; - } else if (c === 63) { - this.url.host = this.base.host; - this.url.path = this.base.path.slice(); - this.url.query = ""; - this.state = "query"; - } else if (c === 35) { - this.url.host = this.base.host; - this.url.path = this.base.path.slice(); - this.url.query = this.base.query; - this.url.fragment = ""; - this.state = "fragment"; - } else { - if (this.input.length - this.pointer - 1 === 0 || // remaining consists of 0 code points - !isWindowsDriveLetterCodePoints(c, this.input[this.pointer + 1]) || - (this.input.length - this.pointer - 1 >= 2 && // remaining has at least 2 code points - !fileOtherwiseCodePoints.has(this.input[this.pointer + 2]))) { - this.url.host = this.base.host; - this.url.path = this.base.path.slice(); - shortenPath(this.url); - } else { - this.parseError = true; - } - - this.state = "path"; - --this.pointer; - } - } else { - this.state = "path"; - --this.pointer; - } - - return true; -}; - -URLStateMachine.prototype["parse file slash"] = function parseFileSlash(c) { - if (c === 47 || c === 92) { - if (c === 92) { - this.parseError = true; - } - this.state = "file host"; - } else { - if (this.base !== null && this.base.scheme === "file") { - if (isNormalizedWindowsDriveLetterString(this.base.path[0])) { - this.url.path.push(this.base.path[0]); - } else { - this.url.host = this.base.host; - } - } - this.state = "path"; - --this.pointer; - } - - return true; -}; - -URLStateMachine.prototype["parse file host"] = function parseFileHost(c, cStr) { - if (isNaN(c) || c === 47 || c === 92 || c === 63 || c === 35) { - --this.pointer; - if (!this.stateOverride && isWindowsDriveLetterString(this.buffer)) { - this.parseError = true; - this.state = "path"; - } else if (this.buffer === "") { - this.url.host = ""; - if (this.stateOverride) { - return false; - } - this.state = "path start"; - } else { - let host = parseHost(this.buffer, isSpecial(this.url)); - if (host === failure) { - return failure; - } - if (host === "localhost") { - host = ""; - } - this.url.host = host; - - if (this.stateOverride) { - return false; - } - - this.buffer = ""; - this.state = "path start"; - } - } else { - this.buffer += cStr; - } - - return true; -}; - -URLStateMachine.prototype["parse path start"] = function parsePathStart(c) { - if (isSpecial(this.url)) { - if (c === 92) { - this.parseError = true; - } - this.state = "path"; - - if (c !== 47 && c !== 92) { - --this.pointer; - } - } else if (!this.stateOverride && c === 63) { - this.url.query = ""; - this.state = "query"; - } else if (!this.stateOverride && c === 35) { - this.url.fragment = ""; - this.state = "fragment"; - } else if (c !== undefined) { - this.state = "path"; - if (c !== 47) { - --this.pointer; - } - } - - return true; -}; - -URLStateMachine.prototype["parse path"] = function parsePath(c) { - if (isNaN(c) || c === 47 || (isSpecial(this.url) && c === 92) || - (!this.stateOverride && (c === 63 || c === 35))) { - if (isSpecial(this.url) && c === 92) { - this.parseError = true; - } - - if (isDoubleDot(this.buffer)) { - shortenPath(this.url); - if (c !== 47 && !(isSpecial(this.url) && c === 92)) { - this.url.path.push(""); - } - } else if (isSingleDot(this.buffer) && c !== 47 && - !(isSpecial(this.url) && c === 92)) { - this.url.path.push(""); - } else if (!isSingleDot(this.buffer)) { - if (this.url.scheme === "file" && this.url.path.length === 0 && isWindowsDriveLetterString(this.buffer)) { - if (this.url.host !== "" && this.url.host !== null) { - this.parseError = true; - this.url.host = ""; - } - this.buffer = this.buffer[0] + ":"; - } - this.url.path.push(this.buffer); - } - this.buffer = ""; - if (this.url.scheme === "file" && (c === undefined || c === 63 || c === 35)) { - while (this.url.path.length > 1 && this.url.path[0] === "") { - this.parseError = true; - this.url.path.shift(); - } - } - if (c === 63) { - this.url.query = ""; - this.state = "query"; - } - if (c === 35) { - this.url.fragment = ""; - this.state = "fragment"; - } - } else { - // TODO: If c is not a URL code point and not "%", parse error. - - if (c === 37 && - (!isASCIIHex(this.input[this.pointer + 1]) || - !isASCIIHex(this.input[this.pointer + 2]))) { - this.parseError = true; - } - - this.buffer += percentEncodeChar(c, isPathPercentEncode); - } - - return true; -}; - -URLStateMachine.prototype["parse cannot-be-a-base-URL path"] = function parseCannotBeABaseURLPath(c) { - if (c === 63) { - this.url.query = ""; - this.state = "query"; - } else if (c === 35) { - this.url.fragment = ""; - this.state = "fragment"; - } else { - // TODO: Add: not a URL code point - if (!isNaN(c) && c !== 37) { - this.parseError = true; - } - - if (c === 37 && - (!isASCIIHex(this.input[this.pointer + 1]) || - !isASCIIHex(this.input[this.pointer + 2]))) { - this.parseError = true; - } - - if (!isNaN(c)) { - this.url.path[0] = this.url.path[0] + percentEncodeChar(c, isC0ControlPercentEncode); - } - } - - return true; -}; - -URLStateMachine.prototype["parse query"] = function parseQuery(c, cStr) { - if (isNaN(c) || (!this.stateOverride && c === 35)) { - if (!isSpecial(this.url) || this.url.scheme === "ws" || this.url.scheme === "wss") { - this.encodingOverride = "utf-8"; - } - - const buffer = new Buffer(this.buffer); // TODO: Use encoding override instead - for (let i = 0; i < buffer.length; ++i) { - if (buffer[i] < 0x21 || buffer[i] > 0x7E || buffer[i] === 0x22 || buffer[i] === 0x23 || - buffer[i] === 0x3C || buffer[i] === 0x3E) { - this.url.query += percentEncode(buffer[i]); - } else { - this.url.query += String.fromCodePoint(buffer[i]); - } - } - - this.buffer = ""; - if (c === 35) { - this.url.fragment = ""; - this.state = "fragment"; - } - } else { - // TODO: If c is not a URL code point and not "%", parse error. - if (c === 37 && - (!isASCIIHex(this.input[this.pointer + 1]) || - !isASCIIHex(this.input[this.pointer + 2]))) { - this.parseError = true; - } - - this.buffer += cStr; - } - - return true; -}; - -URLStateMachine.prototype["parse fragment"] = function parseFragment(c) { - if (isNaN(c)) { // do nothing - } else if (c === 0x0) { - this.parseError = true; - } else { - // TODO: If c is not a URL code point and not "%", parse error. - if (c === 37 && - (!isASCIIHex(this.input[this.pointer + 1]) || - !isASCIIHex(this.input[this.pointer + 2]))) { - this.parseError = true; - } - - this.url.fragment += percentEncodeChar(c, isC0ControlPercentEncode); - } - - return true; -}; - -function serializeURL(url, excludeFragment) { - let output = url.scheme + ":"; - if (url.host !== null) { - output += "//"; - - if (url.username !== "" || url.password !== "") { - output += url.username; - if (url.password !== "") { - output += ":" + url.password; - } - output += "@"; - } - - output += serializeHost(url.host); - - if (url.port !== null) { - output += ":" + url.port; - } - } else if (url.host === null && url.scheme === "file") { - output += "//"; - } - - if (url.cannotBeABaseURL) { - output += url.path[0]; - } else { - for (const string of url.path) { - output += "/" + string; - } - } - - if (url.query !== null) { - output += "?" + url.query; - } - - if (!excludeFragment && url.fragment !== null) { - output += "#" + url.fragment; - } - - return output; -} - -function serializeOrigin(tuple) { - let result = tuple.scheme + "://"; - result += serializeHost(tuple.host); - - if (tuple.port !== null) { - result += ":" + tuple.port; - } - - return result; -} - -module.exports.serializeURL = serializeURL; - -module.exports.serializeURLOrigin = function (url) { - // https://url.spec.whatwg.org/#concept-url-origin - switch (url.scheme) { - case "blob": - try { - return module.exports.serializeURLOrigin(module.exports.parseURL(url.path[0])); - } catch (e) { - // serializing an opaque origin returns "null" - return "null"; - } - case "ftp": - case "gopher": - case "http": - case "https": - case "ws": - case "wss": - return serializeOrigin({ - scheme: url.scheme, - host: url.host, - port: url.port - }); - case "file": - // spec says "exercise to the reader", chrome says "file://" - return "file://"; - default: - // serializing an opaque origin returns "null" - return "null"; - } -}; - -module.exports.basicURLParse = function (input, options) { - if (options === undefined) { - options = {}; - } - - const usm = new URLStateMachine(input, options.baseURL, options.encodingOverride, options.url, options.stateOverride); - if (usm.failure) { - return "failure"; - } - - return usm.url; -}; - -module.exports.setTheUsername = function (url, username) { - url.username = ""; - const decoded = punycode.ucs2.decode(username); - for (let i = 0; i < decoded.length; ++i) { - url.username += percentEncodeChar(decoded[i], isUserinfoPercentEncode); - } -}; - -module.exports.setThePassword = function (url, password) { - url.password = ""; - const decoded = punycode.ucs2.decode(password); - for (let i = 0; i < decoded.length; ++i) { - url.password += percentEncodeChar(decoded[i], isUserinfoPercentEncode); - } -}; - -module.exports.serializeHost = serializeHost; - -module.exports.cannotHaveAUsernamePasswordPort = cannotHaveAUsernamePasswordPort; - -module.exports.serializeInteger = function (integer) { - return String(integer); -}; - -module.exports.parseURL = function (input, options) { - if (options === undefined) { - options = {}; - } - - // We don't handle blobs, so this just delegates: - return module.exports.basicURLParse(input, { baseURL: options.baseURL, encodingOverride: options.encodingOverride }); -}; -/***/ }), +const EventEmitter = (__nccwpck_require__(8474).EventEmitter) +const inherits = (__nccwpck_require__(7975).inherits) +const getLimit = __nccwpck_require__(2393) -/***/ 9857: -/***/ ((module) => { +const StreamSearch = __nccwpck_require__(4136) +const B_DCRLF = Buffer.from('\r\n\r\n') +const RE_CRLF = /\r\n/g +const RE_HDR = /^([^:]+):[ \t]?([\x00-\xFF]+)?$/ // eslint-disable-line no-control-regex +function HeaderParser (cfg) { + EventEmitter.call(this) -module.exports.mixin = function mixin(target, source) { - const keys = Object.getOwnPropertyNames(source); - for (let i = 0; i < keys.length; ++i) { - Object.defineProperty(target, keys[i], Object.getOwnPropertyDescriptor(source, keys[i])); - } -}; + cfg = cfg || {} + const self = this + this.nread = 0 + this.maxed = false + this.npairs = 0 + this.maxHeaderPairs = getLimit(cfg, 'maxHeaderPairs', 2000) + this.maxHeaderSize = getLimit(cfg, 'maxHeaderSize', 80 * 1024) + this.buffer = '' + this.header = {} + this.finished = false + this.ss = new StreamSearch(B_DCRLF) + this.ss.on('info', function (isMatch, data, start, end) { + if (data && !self.maxed) { + if (self.nread + end - start >= self.maxHeaderSize) { + end = self.maxHeaderSize - self.nread + start + self.nread = self.maxHeaderSize + self.maxed = true + } else { self.nread += (end - start) } -module.exports.wrapperSymbol = Symbol("wrapper"); -module.exports.implSymbol = Symbol("impl"); + self.buffer += data.toString('binary', start, end) + } + if (isMatch) { self._finish() } + }) +} +inherits(HeaderParser, EventEmitter) -module.exports.wrapperForImpl = function (impl) { - return impl[module.exports.wrapperSymbol]; -}; +HeaderParser.prototype.push = function (data) { + const r = this.ss.push(data) + if (this.finished) { return r } +} -module.exports.implForWrapper = function (wrapper) { - return wrapper[module.exports.implSymbol]; -}; +HeaderParser.prototype.reset = function () { + this.finished = false + this.buffer = '' + this.header = {} + this.ss.reset() +} +HeaderParser.prototype._finish = function () { + if (this.buffer) { this._parseHeader() } + this.ss.matches = this.ss.maxMatches + const header = this.header + this.header = {} + this.buffer = '' + this.finished = true + this.nread = this.npairs = 0 + this.maxed = false + this.emit('header', header) +} +HeaderParser.prototype._parseHeader = function () { + if (this.npairs === this.maxHeaderPairs) { return } -/***/ }), - -/***/ 2078: -/***/ ((module) => { - -module.exports = eval("require")("encoding"); + const lines = this.buffer.split(RE_CRLF) + const len = lines.length + let m, h + for (var i = 0; i < len; ++i) { // eslint-disable-line no-var + if (lines[i].length === 0) { continue } + if (lines[i][0] === '\t' || lines[i][0] === ' ') { + // folded header content + // RFC2822 says to just remove the CRLF and not the whitespace following + // it, so we follow the RFC and include the leading whitespace ... + if (h) { + this.header[h][this.header[h].length - 1] += lines[i] + continue + } + } -/***/ }), + const posColon = lines[i].indexOf(':') + if ( + posColon === -1 || + posColon === 0 + ) { + return + } + m = RE_HDR.exec(lines[i]) + h = m[1].toLowerCase() + this.header[h] = this.header[h] || [] + this.header[h].push((m[2] || '')) + if (++this.npairs === this.maxHeaderPairs) { break } + } +} -/***/ 2613: -/***/ ((module) => { +module.exports = HeaderParser -module.exports = __WEBPACK_EXTERNAL_createRequire(import.meta.url)("assert"); /***/ }), -/***/ 290: -/***/ ((module) => { +/***/ 612: +/***/ ((module, __unused_webpack_exports, __nccwpck_require__) => { -module.exports = __WEBPACK_EXTERNAL_createRequire(import.meta.url)("async_hooks"); -/***/ }), -/***/ 181: -/***/ ((module) => { +const inherits = (__nccwpck_require__(7975).inherits) +const ReadableStream = (__nccwpck_require__(7075).Readable) -module.exports = __WEBPACK_EXTERNAL_createRequire(import.meta.url)("buffer"); +function PartStream (opts) { + ReadableStream.call(this, opts) +} +inherits(PartStream, ReadableStream) -/***/ }), +PartStream.prototype._read = function (n) {} -/***/ 5317: -/***/ ((module) => { +module.exports = PartStream -module.exports = __WEBPACK_EXTERNAL_createRequire(import.meta.url)("child_process"); /***/ }), -/***/ 4236: -/***/ ((module) => { +/***/ 4136: +/***/ ((module, __unused_webpack_exports, __nccwpck_require__) => { -module.exports = __WEBPACK_EXTERNAL_createRequire(import.meta.url)("console"); -/***/ }), -/***/ 6982: -/***/ ((module) => { +/** + * Copyright Brian White. All rights reserved. + * + * @see https://github.com/mscdex/streamsearch + * + * Permission is hereby granted, free of charge, to any person obtaining a copy + * of this software and associated documentation files (the "Software"), to + * deal in the Software without restriction, including without limitation the + * rights to use, copy, modify, merge, publish, distribute, sublicense, and/or + * sell copies of the Software, and to permit persons to whom the Software is + * furnished to do so, subject to the following conditions: + * + * The above copyright notice and this permission notice shall be included in + * all copies or substantial portions of the Software. + * + * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR + * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, + * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE + * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER + * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING + * FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS + * IN THE SOFTWARE. + * + * Based heavily on the Streaming Boyer-Moore-Horspool C++ implementation + * by Hongli Lai at: https://github.com/FooBarWidget/boyer-moore-horspool + */ +const EventEmitter = (__nccwpck_require__(8474).EventEmitter) +const inherits = (__nccwpck_require__(7975).inherits) -module.exports = __WEBPACK_EXTERNAL_createRequire(import.meta.url)("crypto"); +function SBMH (needle) { + if (typeof needle === 'string') { + needle = Buffer.from(needle) + } -/***/ }), + if (!Buffer.isBuffer(needle)) { + throw new TypeError('The needle has to be a String or a Buffer.') + } -/***/ 1637: -/***/ ((module) => { + const needleLength = needle.length -module.exports = __WEBPACK_EXTERNAL_createRequire(import.meta.url)("diagnostics_channel"); + if (needleLength === 0) { + throw new Error('The needle cannot be an empty String/Buffer.') + } -/***/ }), + if (needleLength > 256) { + throw new Error('The needle cannot have a length bigger than 256.') + } -/***/ 4434: -/***/ ((module) => { + this.maxMatches = Infinity + this.matches = 0 -module.exports = __WEBPACK_EXTERNAL_createRequire(import.meta.url)("events"); + this._occ = new Array(256) + .fill(needleLength) // Initialize occurrence table. + this._lookbehind_size = 0 + this._needle = needle + this._bufpos = 0 -/***/ }), + this._lookbehind = Buffer.alloc(needleLength) -/***/ 9896: -/***/ ((module) => { + // Populate occurrence table with analysis of the needle, + // ignoring last letter. + for (var i = 0; i < needleLength - 1; ++i) { // eslint-disable-line no-var + this._occ[needle[i]] = needleLength - 1 - i + } +} +inherits(SBMH, EventEmitter) -module.exports = __WEBPACK_EXTERNAL_createRequire(import.meta.url)("fs"); +SBMH.prototype.reset = function () { + this._lookbehind_size = 0 + this.matches = 0 + this._bufpos = 0 +} -/***/ }), +SBMH.prototype.push = function (chunk, pos) { + if (!Buffer.isBuffer(chunk)) { + chunk = Buffer.from(chunk, 'binary') + } + const chlen = chunk.length + this._bufpos = pos || 0 + let r + while (r !== chlen && this.matches < this.maxMatches) { r = this._sbmh_feed(chunk) } + return r +} -/***/ 8611: -/***/ ((module) => { +SBMH.prototype._sbmh_feed = function (data) { + const len = data.length + const needle = this._needle + const needleLength = needle.length + const lastNeedleChar = needle[needleLength - 1] -module.exports = __WEBPACK_EXTERNAL_createRequire(import.meta.url)("http"); + // Positive: points to a position in `data` + // pos == 3 points to data[3] + // Negative: points to a position in the lookbehind buffer + // pos == -2 points to lookbehind[lookbehind_size - 2] + let pos = -this._lookbehind_size + let ch -/***/ }), + if (pos < 0) { + // Lookbehind buffer is not empty. Perform Boyer-Moore-Horspool + // search with character lookup code that considers both the + // lookbehind buffer and the current round's haystack data. + // + // Loop until + // there is a match. + // or until + // we've moved past the position that requires the + // lookbehind buffer. In this case we switch to the + // optimized loop. + // or until + // the character to look at lies outside the haystack. + while (pos < 0 && pos <= len - needleLength) { + ch = this._sbmh_lookup_char(data, pos + needleLength - 1) -/***/ 5675: -/***/ ((module) => { + if ( + ch === lastNeedleChar && + this._sbmh_memcmp(data, pos, needleLength - 1) + ) { + this._lookbehind_size = 0 + ++this.matches + this.emit('info', true) -module.exports = __WEBPACK_EXTERNAL_createRequire(import.meta.url)("http2"); + return (this._bufpos = pos + needleLength) + } + pos += this._occ[ch] + } -/***/ }), + // No match. -/***/ 5692: -/***/ ((module) => { + if (pos < 0) { + // There's too few data for Boyer-Moore-Horspool to run, + // so let's use a different algorithm to skip as much as + // we can. + // Forward pos until + // the trailing part of lookbehind + data + // looks like the beginning of the needle + // or until + // pos == 0 + while (pos < 0 && !this._sbmh_memcmp(data, pos, len - pos)) { ++pos } + } -module.exports = __WEBPACK_EXTERNAL_createRequire(import.meta.url)("https"); + if (pos >= 0) { + // Discard lookbehind buffer. + this.emit('info', false, this._lookbehind, 0, this._lookbehind_size) + this._lookbehind_size = 0 + } else { + // Cut off part of the lookbehind buffer that has + // been processed and append the entire haystack + // into it. + const bytesToCutOff = this._lookbehind_size + pos + if (bytesToCutOff > 0) { + // The cut off data is guaranteed not to contain the needle. + this.emit('info', false, this._lookbehind, 0, bytesToCutOff) + } -/***/ }), + this._lookbehind.copy(this._lookbehind, 0, bytesToCutOff, + this._lookbehind_size - bytesToCutOff) + this._lookbehind_size -= bytesToCutOff -/***/ 9278: -/***/ ((module) => { + data.copy(this._lookbehind, this._lookbehind_size) + this._lookbehind_size += len -module.exports = __WEBPACK_EXTERNAL_createRequire(import.meta.url)("net"); + this._bufpos = len + return len + } + } -/***/ }), + pos += (pos >= 0) * this._bufpos -/***/ 8474: -/***/ ((module) => { + // Lookbehind buffer is now empty. We only need to check if the + // needle is in the haystack. + if (data.indexOf(needle, pos) !== -1) { + pos = data.indexOf(needle, pos) + ++this.matches + if (pos > 0) { this.emit('info', true, data, this._bufpos, pos) } else { this.emit('info', true) } -module.exports = __WEBPACK_EXTERNAL_createRequire(import.meta.url)("node:events"); + return (this._bufpos = pos + needleLength) + } else { + pos = len - needleLength + } -/***/ }), - -/***/ 7075: -/***/ ((module) => { - -module.exports = __WEBPACK_EXTERNAL_createRequire(import.meta.url)("node:stream"); - -/***/ }), - -/***/ 7975: -/***/ ((module) => { - -module.exports = __WEBPACK_EXTERNAL_createRequire(import.meta.url)("node:util"); + // There was no match. If there's trailing haystack data that we cannot + // match yet using the Boyer-Moore-Horspool algorithm (because the trailing + // data is less than the needle size) then match using a modified + // algorithm that starts matching from the beginning instead of the end. + // Whatever trailing data is left after running this algorithm is added to + // the lookbehind buffer. + while ( + pos < len && + ( + data[pos] !== needle[0] || + ( + (Buffer.compare( + data.subarray(pos, pos + len - pos), + needle.subarray(0, len - pos) + ) !== 0) + ) + ) + ) { + ++pos + } + if (pos < len) { + data.copy(this._lookbehind, 0, pos, pos + (len - pos)) + this._lookbehind_size = len - pos + } -/***/ }), + // Everything until pos is guaranteed not to contain needle data. + if (pos > 0) { this.emit('info', false, data, this._bufpos, pos < len ? pos : len) } -/***/ 857: -/***/ ((module) => { + this._bufpos = len + return len +} -module.exports = __WEBPACK_EXTERNAL_createRequire(import.meta.url)("os"); +SBMH.prototype._sbmh_lookup_char = function (data, pos) { + return (pos < 0) + ? this._lookbehind[this._lookbehind_size + pos] + : data[pos] +} -/***/ }), +SBMH.prototype._sbmh_memcmp = function (data, pos, len) { + for (var i = 0; i < len; ++i) { // eslint-disable-line no-var + if (this._sbmh_lookup_char(data, pos + i) !== this._needle[i]) { return false } + } + return true +} -/***/ 6928: -/***/ ((module) => { +module.exports = SBMH -module.exports = __WEBPACK_EXTERNAL_createRequire(import.meta.url)("path"); /***/ }), -/***/ 2987: -/***/ ((module) => { - -module.exports = __WEBPACK_EXTERNAL_createRequire(import.meta.url)("perf_hooks"); - -/***/ }), +/***/ 9581: +/***/ ((module, __unused_webpack_exports, __nccwpck_require__) => { -/***/ 4876: -/***/ ((module) => { -module.exports = __WEBPACK_EXTERNAL_createRequire(import.meta.url)("punycode"); -/***/ }), +const WritableStream = (__nccwpck_require__(7075).Writable) +const { inherits } = __nccwpck_require__(7975) +const Dicer = __nccwpck_require__(7182) -/***/ 3480: -/***/ ((module) => { +const MultipartParser = __nccwpck_require__(1192) +const UrlencodedParser = __nccwpck_require__(855) +const parseParams = __nccwpck_require__(8929) -module.exports = __WEBPACK_EXTERNAL_createRequire(import.meta.url)("querystring"); +function Busboy (opts) { + if (!(this instanceof Busboy)) { return new Busboy(opts) } -/***/ }), + if (typeof opts !== 'object') { + throw new TypeError('Busboy expected an options-Object.') + } + if (typeof opts.headers !== 'object') { + throw new TypeError('Busboy expected an options-Object with headers-attribute.') + } + if (typeof opts.headers['content-type'] !== 'string') { + throw new TypeError('Missing Content-Type-header.') + } -/***/ 2203: -/***/ ((module) => { + const { + headers, + ...streamOptions + } = opts -module.exports = __WEBPACK_EXTERNAL_createRequire(import.meta.url)("stream"); + this.opts = { + autoDestroy: false, + ...streamOptions + } + WritableStream.call(this, this.opts) -/***/ }), + this._done = false + this._parser = this.getParserByHeaders(headers) + this._finished = false +} +inherits(Busboy, WritableStream) -/***/ 3774: -/***/ ((module) => { +Busboy.prototype.emit = function (ev) { + if (ev === 'finish') { + if (!this._done) { + this._parser?.end() + return + } else if (this._finished) { + return + } + this._finished = true + } + WritableStream.prototype.emit.apply(this, arguments) +} -module.exports = __WEBPACK_EXTERNAL_createRequire(import.meta.url)("stream/web"); +Busboy.prototype.getParserByHeaders = function (headers) { + const parsed = parseParams(headers['content-type']) -/***/ }), + const cfg = { + defCharset: this.opts.defCharset, + fileHwm: this.opts.fileHwm, + headers, + highWaterMark: this.opts.highWaterMark, + isPartAFile: this.opts.isPartAFile, + limits: this.opts.limits, + parsedConType: parsed, + preservePath: this.opts.preservePath + } -/***/ 3193: -/***/ ((module) => { + if (MultipartParser.detect.test(parsed[0])) { + return new MultipartParser(this, cfg) + } + if (UrlencodedParser.detect.test(parsed[0])) { + return new UrlencodedParser(this, cfg) + } + throw new Error('Unsupported Content-Type.') +} -module.exports = __WEBPACK_EXTERNAL_createRequire(import.meta.url)("string_decoder"); +Busboy.prototype._write = function (chunk, encoding, cb) { + this._parser.write(chunk, cb) +} -/***/ }), +module.exports = Busboy +module.exports["default"] = Busboy +module.exports.Busboy = Busboy -/***/ 3557: -/***/ ((module) => { +module.exports.Dicer = Dicer -module.exports = __WEBPACK_EXTERNAL_createRequire(import.meta.url)("timers"); /***/ }), -/***/ 4756: -/***/ ((module) => { - -module.exports = __WEBPACK_EXTERNAL_createRequire(import.meta.url)("tls"); +/***/ 1192: +/***/ ((module, __unused_webpack_exports, __nccwpck_require__) => { -/***/ }), -/***/ 7016: -/***/ ((module) => { -module.exports = __WEBPACK_EXTERNAL_createRequire(import.meta.url)("url"); +// TODO: +// * support 1 nested multipart level +// (see second multipart example here: +// http://www.w3.org/TR/html401/interact/forms.html#didx-multipartform-data) +// * support limits.fieldNameSize +// -- this will require modifications to utils.parseParams -/***/ }), +const { Readable } = __nccwpck_require__(7075) +const { inherits } = __nccwpck_require__(7975) -/***/ 9023: -/***/ ((module) => { +const Dicer = __nccwpck_require__(7182) -module.exports = __WEBPACK_EXTERNAL_createRequire(import.meta.url)("util"); +const parseParams = __nccwpck_require__(8929) +const decodeText = __nccwpck_require__(2747) +const basename = __nccwpck_require__(692) +const getLimit = __nccwpck_require__(2393) -/***/ }), +const RE_BOUNDARY = /^boundary$/i +const RE_FIELD = /^form-data$/i +const RE_CHARSET = /^charset$/i +const RE_FILENAME = /^filename$/i +const RE_NAME = /^name$/i -/***/ 8253: -/***/ ((module) => { +Multipart.detect = /^multipart\/form-data/i +function Multipart (boy, cfg) { + let i + let len + const self = this + let boundary + const limits = cfg.limits + const isPartAFile = cfg.isPartAFile || ((fieldName, contentType, fileName) => (contentType === 'application/octet-stream' || fileName !== undefined)) + const parsedConType = cfg.parsedConType || [] + const defCharset = cfg.defCharset || 'utf8' + const preservePath = cfg.preservePath + const fileOpts = { highWaterMark: cfg.fileHwm } -module.exports = __WEBPACK_EXTERNAL_createRequire(import.meta.url)("util/types"); + for (i = 0, len = parsedConType.length; i < len; ++i) { + if (Array.isArray(parsedConType[i]) && + RE_BOUNDARY.test(parsedConType[i][0])) { + boundary = parsedConType[i][1] + break + } + } -/***/ }), + function checkFinished () { + if (nends === 0 && finished && !boy._done) { + finished = false + self.end() + } + } -/***/ 8167: -/***/ ((module) => { + if (typeof boundary !== 'string') { throw new Error('Multipart: Boundary not found') } -module.exports = __WEBPACK_EXTERNAL_createRequire(import.meta.url)("worker_threads"); + const fieldSizeLimit = getLimit(limits, 'fieldSize', 1 * 1024 * 1024) + const fileSizeLimit = getLimit(limits, 'fileSize', Infinity) + const filesLimit = getLimit(limits, 'files', Infinity) + const fieldsLimit = getLimit(limits, 'fields', Infinity) + const partsLimit = getLimit(limits, 'parts', Infinity) + const headerPairsLimit = getLimit(limits, 'headerPairs', 2000) + const headerSizeLimit = getLimit(limits, 'headerSize', 80 * 1024) -/***/ }), + let nfiles = 0 + let nfields = 0 + let nends = 0 + let curFile + let curField + let finished = false -/***/ 3106: -/***/ ((module) => { + this._needDrain = false + this._pause = false + this._cb = undefined + this._nparts = 0 + this._boy = boy -module.exports = __WEBPACK_EXTERNAL_createRequire(import.meta.url)("zlib"); + const parserCfg = { + boundary, + maxHeaderPairs: headerPairsLimit, + maxHeaderSize: headerSizeLimit, + partHwm: fileOpts.highWaterMark, + highWaterMark: cfg.highWaterMark + } -/***/ }), + this.parser = new Dicer(parserCfg) + this.parser.on('drain', function () { + self._needDrain = false + if (self._cb && !self._pause) { + const cb = self._cb + self._cb = undefined + cb() + } + }).on('part', function onPart (part) { + if (++self._nparts > partsLimit) { + self.parser.removeListener('part', onPart) + self.parser.on('part', skipPart) + boy.hitPartsLimit = true + boy.emit('partsLimit') + return skipPart(part) + } -/***/ 7182: -/***/ ((module, __unused_webpack_exports, __nccwpck_require__) => { + // hack because streams2 _always_ doesn't emit 'end' until nextTick, so let + // us emit 'end' early since we know the part has ended if we are already + // seeing the next part + if (curField) { + const field = curField + field.emit('end') + field.removeAllListeners('end') + } + part.on('header', function (header) { + let contype + let fieldname + let parsed + let charset + let encoding + let filename + let nsize = 0 + if (header['content-type']) { + parsed = parseParams(header['content-type'][0]) + if (parsed[0]) { + contype = parsed[0].toLowerCase() + for (i = 0, len = parsed.length; i < len; ++i) { + if (RE_CHARSET.test(parsed[i][0])) { + charset = parsed[i][1].toLowerCase() + break + } + } + } + } -const WritableStream = (__nccwpck_require__(7075).Writable) -const inherits = (__nccwpck_require__(7975).inherits) + if (contype === undefined) { contype = 'text/plain' } + if (charset === undefined) { charset = defCharset } -const StreamSearch = __nccwpck_require__(4136) + if (header['content-disposition']) { + parsed = parseParams(header['content-disposition'][0]) + if (!RE_FIELD.test(parsed[0])) { return skipPart(part) } + for (i = 0, len = parsed.length; i < len; ++i) { + if (RE_NAME.test(parsed[i][0])) { + fieldname = parsed[i][1] + } else if (RE_FILENAME.test(parsed[i][0])) { + filename = parsed[i][1] + if (!preservePath) { filename = basename(filename) } + } + } + } else { return skipPart(part) } -const PartStream = __nccwpck_require__(612) -const HeaderParser = __nccwpck_require__(2271) + if (header['content-transfer-encoding']) { encoding = header['content-transfer-encoding'][0].toLowerCase() } else { encoding = '7bit' } -const DASH = 45 -const B_ONEDASH = Buffer.from('-') -const B_CRLF = Buffer.from('\r\n') -const EMPTY_FN = function () {} + let onData, + onEnd -function Dicer (cfg) { - if (!(this instanceof Dicer)) { return new Dicer(cfg) } - WritableStream.call(this, cfg) + if (isPartAFile(fieldname, contype, filename)) { + // file/binary field + if (nfiles === filesLimit) { + if (!boy.hitFilesLimit) { + boy.hitFilesLimit = true + boy.emit('filesLimit') + } + return skipPart(part) + } - if (!cfg || (!cfg.headerFirst && typeof cfg.boundary !== 'string')) { throw new TypeError('Boundary required') } + ++nfiles - if (typeof cfg.boundary === 'string') { this.setBoundary(cfg.boundary) } else { this._bparser = undefined } + if (boy.listenerCount('file') === 0) { + self.parser._ignore() + return + } - this._headerFirst = cfg.headerFirst + ++nends + const file = new FileStream(fileOpts) + curFile = file + file.on('end', function () { + --nends + self._pause = false + checkFinished() + if (self._cb && !self._needDrain) { + const cb = self._cb + self._cb = undefined + cb() + } + }) + file._read = function (n) { + if (!self._pause) { return } + self._pause = false + if (self._cb && !self._needDrain) { + const cb = self._cb + self._cb = undefined + cb() + } + } + boy.emit('file', fieldname, file, filename, encoding, contype) - this._dashes = 0 - this._parts = 0 - this._finished = false - this._realFinish = false - this._isPreamble = true - this._justMatched = false - this._firstWrite = true - this._inHeader = true - this._part = undefined - this._cb = undefined - this._ignoreData = false - this._partOpts = { highWaterMark: cfg.partHwm } - this._pause = false + onData = function (data) { + if ((nsize += data.length) > fileSizeLimit) { + const extralen = fileSizeLimit - nsize + data.length + if (extralen > 0) { file.push(data.slice(0, extralen)) } + file.truncated = true + file.bytesRead = fileSizeLimit + part.removeAllListeners('data') + file.emit('limit') + return + } else if (!file.push(data)) { self._pause = true } - const self = this - this._hparser = new HeaderParser(cfg) - this._hparser.on('header', function (header) { - self._inHeader = false - self._part.emit('header', header) - }) -} -inherits(Dicer, WritableStream) + file.bytesRead = nsize + } -Dicer.prototype.emit = function (ev) { - if (ev === 'finish' && !this._realFinish) { - if (!this._finished) { - const self = this - process.nextTick(function () { - self.emit('error', new Error('Unexpected end of multipart data')) - if (self._part && !self._ignoreData) { - const type = (self._isPreamble ? 'Preamble' : 'Part') - self._part.emit('error', new Error(type + ' terminated early due to unexpected end of multipart data')) - self._part.push(null) - process.nextTick(function () { - self._realFinish = true - self.emit('finish') - self._realFinish = false - }) - return + onEnd = function () { + curFile = undefined + file.push(null) + } + } else { + // non-file field + if (nfields === fieldsLimit) { + if (!boy.hitFieldsLimit) { + boy.hitFieldsLimit = true + boy.emit('fieldsLimit') + } + return skipPart(part) } - self._realFinish = true - self.emit('finish') - self._realFinish = false - }) - } - } else { WritableStream.prototype.emit.apply(this, arguments) } -} -Dicer.prototype._write = function (data, encoding, cb) { - // ignore unexpected data (e.g. extra trailer data after finished) - if (!this._hparser && !this._bparser) { return cb() } + ++nfields + ++nends + let buffer = '' + let truncated = false + curField = part - if (this._headerFirst && this._isPreamble) { - if (!this._part) { - this._part = new PartStream(this._partOpts) - if (this.listenerCount('preamble') !== 0) { this.emit('preamble', this._part) } else { this._ignore() } - } - const r = this._hparser.push(data) - if (!this._inHeader && r !== undefined && r < data.length) { data = data.slice(r) } else { return cb() } - } + onData = function (data) { + if ((nsize += data.length) > fieldSizeLimit) { + const extralen = (fieldSizeLimit - (nsize - data.length)) + buffer += data.toString('binary', 0, extralen) + truncated = true + part.removeAllListeners('data') + } else { buffer += data.toString('binary') } + } - // allows for "easier" testing - if (this._firstWrite) { - this._bparser.push(B_CRLF) - this._firstWrite = false - } + onEnd = function () { + curField = undefined + if (buffer.length) { buffer = decodeText(buffer, 'binary', charset) } + boy.emit('field', fieldname, buffer, false, truncated, encoding, contype) + --nends + checkFinished() + } + } - this._bparser.push(data) + /* As of node@2efe4ab761666 (v0.10.29+/v0.11.14+), busboy had become + broken. Streams2/streams3 is a huge black box of confusion, but + somehow overriding the sync state seems to fix things again (and still + seems to work for previous node versions). + */ + part._readableState.sync = false - if (this._pause) { this._cb = cb } else { cb() } + part.on('data', onData) + part.on('end', onEnd) + }).on('error', function (err) { + if (curFile) { curFile.emit('error', err) } + }) + }).on('error', function (err) { + boy.emit('error', err) + }).on('finish', function () { + finished = true + checkFinished() + }) } -Dicer.prototype.reset = function () { - this._part = undefined - this._bparser = undefined - this._hparser = undefined +Multipart.prototype.write = function (chunk, cb) { + const r = this.parser.write(chunk) + if (r && !this._pause) { + cb() + } else { + this._needDrain = !r + this._cb = cb + } } -Dicer.prototype.setBoundary = function (boundary) { +Multipart.prototype.end = function () { const self = this - this._bparser = new StreamSearch('\r\n--' + boundary) - this._bparser.on('info', function (isMatch, data, start, end) { - self._oninfo(isMatch, data, start, end) - }) -} -Dicer.prototype._ignore = function () { - if (this._part && !this._ignoreData) { - this._ignoreData = true - this._part.on('error', EMPTY_FN) - // we must perform some kind of read on the stream even though we are - // ignoring the data, otherwise node's Readable stream will not emit 'end' - // after pushing null to the stream - this._part.resume() + if (self.parser.writable) { + self.parser.end() + } else if (!self._boy._done) { + process.nextTick(function () { + self._boy._done = true + self._boy.emit('finish') + }) } } -Dicer.prototype._oninfo = function (isMatch, data, start, end) { - let buf; const self = this; let i = 0; let r; let shouldWriteMore = true - - if (!this._part && this._justMatched && data) { - while (this._dashes < 2 && (start + i) < end) { - if (data[start + i] === DASH) { - ++i - ++this._dashes - } else { - if (this._dashes) { buf = B_ONEDASH } - this._dashes = 0 - break - } - } - if (this._dashes === 2) { - if ((start + i) < end && this.listenerCount('trailer') !== 0) { this.emit('trailer', data.slice(start + i, end)) } - this.reset() - this._finished = true - // no more parts will be added - if (self._parts === 0) { - self._realFinish = true - self.emit('finish') - self._realFinish = false - } - } - if (this._dashes) { return } - } - if (this._justMatched) { this._justMatched = false } - if (!this._part) { - this._part = new PartStream(this._partOpts) - this._part._read = function (n) { - self._unpause() - } - if (this._isPreamble && this.listenerCount('preamble') !== 0) { - this.emit('preamble', this._part) - } else if (this._isPreamble !== true && this.listenerCount('part') !== 0) { - this.emit('part', this._part) - } else { - this._ignore() - } - if (!this._isPreamble) { this._inHeader = true } - } - if (data && start < end && !this._ignoreData) { - if (this._isPreamble || !this._inHeader) { - if (buf) { shouldWriteMore = this._part.push(buf) } - shouldWriteMore = this._part.push(data.slice(start, end)) - if (!shouldWriteMore) { this._pause = true } - } else if (!this._isPreamble && this._inHeader) { - if (buf) { this._hparser.push(buf) } - r = this._hparser.push(data.slice(start, end)) - if (!this._inHeader && r !== undefined && r < end) { this._oninfo(false, data, start + r, end) } - } - } - if (isMatch) { - this._hparser.reset() - if (this._isPreamble) { this._isPreamble = false } else { - if (start !== end) { - ++this._parts - this._part.on('end', function () { - if (--self._parts === 0) { - if (self._finished) { - self._realFinish = true - self.emit('finish') - self._realFinish = false - } else { - self._unpause() - } - } - }) - } - } - this._part.push(null) - this._part = undefined - this._ignoreData = false - this._justMatched = true - this._dashes = 0 - } +function skipPart (part) { + part.resume() } -Dicer.prototype._unpause = function () { - if (!this._pause) { return } +function FileStream (opts) { + Readable.call(this, opts) - this._pause = false - if (this._cb) { - const cb = this._cb - this._cb = undefined - cb() - } + this.bytesRead = 0 + + this.truncated = false } -module.exports = Dicer +inherits(FileStream, Readable) + +FileStream.prototype._read = function (n) {} + +module.exports = Multipart /***/ }), -/***/ 2271: +/***/ 855: /***/ ((module, __unused_webpack_exports, __nccwpck_require__) => { -const EventEmitter = (__nccwpck_require__(8474).EventEmitter) -const inherits = (__nccwpck_require__(7975).inherits) +const Decoder = __nccwpck_require__(1496) +const decodeText = __nccwpck_require__(2747) const getLimit = __nccwpck_require__(2393) -const StreamSearch = __nccwpck_require__(4136) - -const B_DCRLF = Buffer.from('\r\n\r\n') -const RE_CRLF = /\r\n/g -const RE_HDR = /^([^:]+):[ \t]?([\x00-\xFF]+)?$/ // eslint-disable-line no-control-regex +const RE_CHARSET = /^charset$/i -function HeaderParser (cfg) { - EventEmitter.call(this) +UrlEncoded.detect = /^application\/x-www-form-urlencoded/i +function UrlEncoded (boy, cfg) { + const limits = cfg.limits + const parsedConType = cfg.parsedConType + this.boy = boy - cfg = cfg || {} - const self = this - this.nread = 0 - this.maxed = false - this.npairs = 0 - this.maxHeaderPairs = getLimit(cfg, 'maxHeaderPairs', 2000) - this.maxHeaderSize = getLimit(cfg, 'maxHeaderSize', 80 * 1024) - this.buffer = '' - this.header = {} - this.finished = false - this.ss = new StreamSearch(B_DCRLF) - this.ss.on('info', function (isMatch, data, start, end) { - if (data && !self.maxed) { - if (self.nread + end - start >= self.maxHeaderSize) { - end = self.maxHeaderSize - self.nread + start - self.nread = self.maxHeaderSize - self.maxed = true - } else { self.nread += (end - start) } + this.fieldSizeLimit = getLimit(limits, 'fieldSize', 1 * 1024 * 1024) + this.fieldNameSizeLimit = getLimit(limits, 'fieldNameSize', 100) + this.fieldsLimit = getLimit(limits, 'fields', Infinity) - self.buffer += data.toString('binary', start, end) + let charset + for (var i = 0, len = parsedConType.length; i < len; ++i) { // eslint-disable-line no-var + if (Array.isArray(parsedConType[i]) && + RE_CHARSET.test(parsedConType[i][0])) { + charset = parsedConType[i][1].toLowerCase() + break } - if (isMatch) { self._finish() } - }) -} -inherits(HeaderParser, EventEmitter) - -HeaderParser.prototype.push = function (data) { - const r = this.ss.push(data) - if (this.finished) { return r } -} + } -HeaderParser.prototype.reset = function () { - this.finished = false - this.buffer = '' - this.header = {} - this.ss.reset() -} + if (charset === undefined) { charset = cfg.defCharset || 'utf8' } -HeaderParser.prototype._finish = function () { - if (this.buffer) { this._parseHeader() } - this.ss.matches = this.ss.maxMatches - const header = this.header - this.header = {} - this.buffer = '' - this.finished = true - this.nread = this.npairs = 0 - this.maxed = false - this.emit('header', header) + this.decoder = new Decoder() + this.charset = charset + this._fields = 0 + this._state = 'key' + this._checkingBytes = true + this._bytesKey = 0 + this._bytesVal = 0 + this._key = '' + this._val = '' + this._keyTrunc = false + this._valTrunc = false + this._hitLimit = false } -HeaderParser.prototype._parseHeader = function () { - if (this.npairs === this.maxHeaderPairs) { return } - - const lines = this.buffer.split(RE_CRLF) - const len = lines.length - let m, h - - for (var i = 0; i < len; ++i) { // eslint-disable-line no-var - if (lines[i].length === 0) { continue } - if (lines[i][0] === '\t' || lines[i][0] === ' ') { - // folded header content - // RFC2822 says to just remove the CRLF and not the whitespace following - // it, so we follow the RFC and include the leading whitespace ... - if (h) { - this.header[h][this.header[h].length - 1] += lines[i] - continue - } - } - - const posColon = lines[i].indexOf(':') - if ( - posColon === -1 || - posColon === 0 - ) { - return +UrlEncoded.prototype.write = function (data, cb) { + if (this._fields === this.fieldsLimit) { + if (!this.boy.hitFieldsLimit) { + this.boy.hitFieldsLimit = true + this.boy.emit('fieldsLimit') } - m = RE_HDR.exec(lines[i]) - h = m[1].toLowerCase() - this.header[h] = this.header[h] || [] - this.header[h].push((m[2] || '')) - if (++this.npairs === this.maxHeaderPairs) { break } + return cb() } -} - -module.exports = HeaderParser + let idxeq; let idxamp; let i; let p = 0; const len = data.length -/***/ }), - -/***/ 612: -/***/ ((module, __unused_webpack_exports, __nccwpck_require__) => { - - - -const inherits = (__nccwpck_require__(7975).inherits) -const ReadableStream = (__nccwpck_require__(7075).Readable) - -function PartStream (opts) { - ReadableStream.call(this, opts) -} -inherits(PartStream, ReadableStream) - -PartStream.prototype._read = function (n) {} + while (p < len) { + if (this._state === 'key') { + idxeq = idxamp = undefined + for (i = p; i < len; ++i) { + if (!this._checkingBytes) { ++p } + if (data[i] === 0x3D/* = */) { + idxeq = i + break + } else if (data[i] === 0x26/* & */) { + idxamp = i + break + } + if (this._checkingBytes && this._bytesKey === this.fieldNameSizeLimit) { + this._hitLimit = true + break + } else if (this._checkingBytes) { ++this._bytesKey } + } -module.exports = PartStream + if (idxeq !== undefined) { + // key with assignment + if (idxeq > p) { this._key += this.decoder.write(data.toString('binary', p, idxeq)) } + this._state = 'val' + this._hitLimit = false + this._checkingBytes = true + this._val = '' + this._bytesVal = 0 + this._valTrunc = false + this.decoder.reset() -/***/ }), + p = idxeq + 1 + } else if (idxamp !== undefined) { + // key with no assignment + ++this._fields + let key; const keyTrunc = this._keyTrunc + if (idxamp > p) { key = (this._key += this.decoder.write(data.toString('binary', p, idxamp))) } else { key = this._key } -/***/ 4136: -/***/ ((module, __unused_webpack_exports, __nccwpck_require__) => { + this._hitLimit = false + this._checkingBytes = true + this._key = '' + this._bytesKey = 0 + this._keyTrunc = false + this.decoder.reset() + if (key.length) { + this.boy.emit('field', decodeText(key, 'binary', this.charset), + '', + keyTrunc, + false) + } + p = idxamp + 1 + if (this._fields === this.fieldsLimit) { return cb() } + } else if (this._hitLimit) { + // we may not have hit the actual limit if there are encoded bytes... + if (i > p) { this._key += this.decoder.write(data.toString('binary', p, i)) } + p = i + if ((this._bytesKey = this._key.length) === this.fieldNameSizeLimit) { + // yep, we actually did hit the limit + this._checkingBytes = false + this._keyTrunc = true + } + } else { + if (p < len) { this._key += this.decoder.write(data.toString('binary', p)) } + p = len + } + } else { + idxamp = undefined + for (i = p; i < len; ++i) { + if (!this._checkingBytes) { ++p } + if (data[i] === 0x26/* & */) { + idxamp = i + break + } + if (this._checkingBytes && this._bytesVal === this.fieldSizeLimit) { + this._hitLimit = true + break + } else if (this._checkingBytes) { ++this._bytesVal } + } -/** - * Copyright Brian White. All rights reserved. - * - * @see https://github.com/mscdex/streamsearch - * - * Permission is hereby granted, free of charge, to any person obtaining a copy - * of this software and associated documentation files (the "Software"), to - * deal in the Software without restriction, including without limitation the - * rights to use, copy, modify, merge, publish, distribute, sublicense, and/or - * sell copies of the Software, and to permit persons to whom the Software is - * furnished to do so, subject to the following conditions: - * - * The above copyright notice and this permission notice shall be included in - * all copies or substantial portions of the Software. - * - * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR - * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, - * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE - * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER - * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING - * FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS - * IN THE SOFTWARE. - * - * Based heavily on the Streaming Boyer-Moore-Horspool C++ implementation - * by Hongli Lai at: https://github.com/FooBarWidget/boyer-moore-horspool - */ -const EventEmitter = (__nccwpck_require__(8474).EventEmitter) -const inherits = (__nccwpck_require__(7975).inherits) + if (idxamp !== undefined) { + ++this._fields + if (idxamp > p) { this._val += this.decoder.write(data.toString('binary', p, idxamp)) } + this.boy.emit('field', decodeText(this._key, 'binary', this.charset), + decodeText(this._val, 'binary', this.charset), + this._keyTrunc, + this._valTrunc) + this._state = 'key' -function SBMH (needle) { - if (typeof needle === 'string') { - needle = Buffer.from(needle) - } + this._hitLimit = false + this._checkingBytes = true + this._key = '' + this._bytesKey = 0 + this._keyTrunc = false + this.decoder.reset() - if (!Buffer.isBuffer(needle)) { - throw new TypeError('The needle has to be a String or a Buffer.') + p = idxamp + 1 + if (this._fields === this.fieldsLimit) { return cb() } + } else if (this._hitLimit) { + // we may not have hit the actual limit if there are encoded bytes... + if (i > p) { this._val += this.decoder.write(data.toString('binary', p, i)) } + p = i + if ((this._val === '' && this.fieldSizeLimit === 0) || + (this._bytesVal = this._val.length) === this.fieldSizeLimit) { + // yep, we actually did hit the limit + this._checkingBytes = false + this._valTrunc = true + } + } else { + if (p < len) { this._val += this.decoder.write(data.toString('binary', p)) } + p = len + } + } } + cb() +} - const needleLength = needle.length +UrlEncoded.prototype.end = function () { + if (this.boy._done) { return } - if (needleLength === 0) { - throw new Error('The needle cannot be an empty String/Buffer.') + if (this._state === 'key' && this._key.length > 0) { + this.boy.emit('field', decodeText(this._key, 'binary', this.charset), + '', + this._keyTrunc, + false) + } else if (this._state === 'val') { + this.boy.emit('field', decodeText(this._key, 'binary', this.charset), + decodeText(this._val, 'binary', this.charset), + this._keyTrunc, + this._valTrunc) } + this.boy._done = true + this.boy.emit('finish') +} - if (needleLength > 256) { - throw new Error('The needle cannot have a length bigger than 256.') - } +module.exports = UrlEncoded - this.maxMatches = Infinity - this.matches = 0 - this._occ = new Array(256) - .fill(needleLength) // Initialize occurrence table. - this._lookbehind_size = 0 - this._needle = needle - this._bufpos = 0 +/***/ }), - this._lookbehind = Buffer.alloc(needleLength) +/***/ 1496: +/***/ ((module) => { - // Populate occurrence table with analysis of the needle, - // ignoring last letter. - for (var i = 0; i < needleLength - 1; ++i) { // eslint-disable-line no-var - this._occ[needle[i]] = needleLength - 1 - i - } -} -inherits(SBMH, EventEmitter) -SBMH.prototype.reset = function () { - this._lookbehind_size = 0 - this.matches = 0 - this._bufpos = 0 -} -SBMH.prototype.push = function (chunk, pos) { - if (!Buffer.isBuffer(chunk)) { - chunk = Buffer.from(chunk, 'binary') +const RE_PLUS = /\+/g + +const HEX = [ + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0, + 0, 1, 1, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 1, 1, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0 +] + +function Decoder () { + this.buffer = undefined +} +Decoder.prototype.write = function (str) { + // Replace '+' with ' ' before decoding + str = str.replace(RE_PLUS, ' ') + let res = '' + let i = 0; let p = 0; const len = str.length + for (; i < len; ++i) { + if (this.buffer !== undefined) { + if (!HEX[str.charCodeAt(i)]) { + res += '%' + this.buffer + this.buffer = undefined + --i // retry character + } else { + this.buffer += str[i] + ++p + if (this.buffer.length === 2) { + res += String.fromCharCode(parseInt(this.buffer, 16)) + this.buffer = undefined + } + } + } else if (str[i] === '%') { + if (i > p) { + res += str.substring(p, i) + p = i + } + this.buffer = '' + ++p + } } - const chlen = chunk.length - this._bufpos = pos || 0 - let r - while (r !== chlen && this.matches < this.maxMatches) { r = this._sbmh_feed(chunk) } - return r + if (p < len && this.buffer === undefined) { res += str.substring(p) } + return res +} +Decoder.prototype.reset = function () { + this.buffer = undefined } -SBMH.prototype._sbmh_feed = function (data) { - const len = data.length - const needle = this._needle - const needleLength = needle.length - const lastNeedleChar = needle[needleLength - 1] +module.exports = Decoder - // Positive: points to a position in `data` - // pos == 3 points to data[3] - // Negative: points to a position in the lookbehind buffer - // pos == -2 points to lookbehind[lookbehind_size - 2] - let pos = -this._lookbehind_size - let ch - if (pos < 0) { - // Lookbehind buffer is not empty. Perform Boyer-Moore-Horspool - // search with character lookup code that considers both the - // lookbehind buffer and the current round's haystack data. - // - // Loop until - // there is a match. - // or until - // we've moved past the position that requires the - // lookbehind buffer. In this case we switch to the - // optimized loop. - // or until - // the character to look at lies outside the haystack. - while (pos < 0 && pos <= len - needleLength) { - ch = this._sbmh_lookup_char(data, pos + needleLength - 1) +/***/ }), - if ( - ch === lastNeedleChar && - this._sbmh_memcmp(data, pos, needleLength - 1) - ) { - this._lookbehind_size = 0 - ++this.matches - this.emit('info', true) +/***/ 692: +/***/ ((module) => { - return (this._bufpos = pos + needleLength) - } - pos += this._occ[ch] - } - // No match. - if (pos < 0) { - // There's too few data for Boyer-Moore-Horspool to run, - // so let's use a different algorithm to skip as much as - // we can. - // Forward pos until - // the trailing part of lookbehind + data - // looks like the beginning of the needle - // or until - // pos == 0 - while (pos < 0 && !this._sbmh_memcmp(data, pos, len - pos)) { ++pos } +module.exports = function basename (path) { + if (typeof path !== 'string') { return '' } + for (var i = path.length - 1; i >= 0; --i) { // eslint-disable-line no-var + switch (path.charCodeAt(i)) { + case 0x2F: // '/' + case 0x5C: // '\' + path = path.slice(i + 1) + return (path === '..' || path === '.' ? '' : path) } + } + return (path === '..' || path === '.' ? '' : path) +} - if (pos >= 0) { - // Discard lookbehind buffer. - this.emit('info', false, this._lookbehind, 0, this._lookbehind_size) - this._lookbehind_size = 0 - } else { - // Cut off part of the lookbehind buffer that has - // been processed and append the entire haystack - // into it. - const bytesToCutOff = this._lookbehind_size + pos - if (bytesToCutOff > 0) { - // The cut off data is guaranteed not to contain the needle. - this.emit('info', false, this._lookbehind, 0, bytesToCutOff) - } - this._lookbehind.copy(this._lookbehind, 0, bytesToCutOff, - this._lookbehind_size - bytesToCutOff) - this._lookbehind_size -= bytesToCutOff +/***/ }), - data.copy(this._lookbehind, this._lookbehind_size) - this._lookbehind_size += len +/***/ 2747: +/***/ (function(module) { - this._bufpos = len - return len - } - } - pos += (pos >= 0) * this._bufpos - // Lookbehind buffer is now empty. We only need to check if the - // needle is in the haystack. - if (data.indexOf(needle, pos) !== -1) { - pos = data.indexOf(needle, pos) - ++this.matches - if (pos > 0) { this.emit('info', true, data, this._bufpos, pos) } else { this.emit('info', true) } +// Node has always utf-8 +const utf8Decoder = new TextDecoder('utf-8') +const textDecoders = new Map([ + ['utf-8', utf8Decoder], + ['utf8', utf8Decoder] +]) - return (this._bufpos = pos + needleLength) - } else { - pos = len - needleLength +function getDecoder (charset) { + let lc + while (true) { + switch (charset) { + case 'utf-8': + case 'utf8': + return decoders.utf8 + case 'latin1': + case 'ascii': // TODO: Make these a separate, strict decoder? + case 'us-ascii': + case 'iso-8859-1': + case 'iso8859-1': + case 'iso88591': + case 'iso_8859-1': + case 'windows-1252': + case 'iso_8859-1:1987': + case 'cp1252': + case 'x-cp1252': + return decoders.latin1 + case 'utf16le': + case 'utf-16le': + case 'ucs2': + case 'ucs-2': + return decoders.utf16le + case 'base64': + return decoders.base64 + default: + if (lc === undefined) { + lc = true + charset = charset.toLowerCase() + continue + } + return decoders.other.bind(charset) + } } +} - // There was no match. If there's trailing haystack data that we cannot - // match yet using the Boyer-Moore-Horspool algorithm (because the trailing - // data is less than the needle size) then match using a modified - // algorithm that starts matching from the beginning instead of the end. - // Whatever trailing data is left after running this algorithm is added to - // the lookbehind buffer. - while ( - pos < len && - ( - data[pos] !== needle[0] || - ( - (Buffer.compare( - data.subarray(pos, pos + len - pos), - needle.subarray(0, len - pos) - ) !== 0) - ) - ) - ) { - ++pos - } - if (pos < len) { - data.copy(this._lookbehind, 0, pos, pos + (len - pos)) - this._lookbehind_size = len - pos - } +const decoders = { + utf8: (data, sourceEncoding) => { + if (data.length === 0) { + return '' + } + if (typeof data === 'string') { + data = Buffer.from(data, sourceEncoding) + } + return data.utf8Slice(0, data.length) + }, - // Everything until pos is guaranteed not to contain needle data. - if (pos > 0) { this.emit('info', false, data, this._bufpos, pos < len ? pos : len) } + latin1: (data, sourceEncoding) => { + if (data.length === 0) { + return '' + } + if (typeof data === 'string') { + return data + } + return data.latin1Slice(0, data.length) + }, - this._bufpos = len - return len -} + utf16le: (data, sourceEncoding) => { + if (data.length === 0) { + return '' + } + if (typeof data === 'string') { + data = Buffer.from(data, sourceEncoding) + } + return data.ucs2Slice(0, data.length) + }, -SBMH.prototype._sbmh_lookup_char = function (data, pos) { - return (pos < 0) - ? this._lookbehind[this._lookbehind_size + pos] - : data[pos] + base64: (data, sourceEncoding) => { + if (data.length === 0) { + return '' + } + if (typeof data === 'string') { + data = Buffer.from(data, sourceEncoding) + } + return data.base64Slice(0, data.length) + }, + + other: (data, sourceEncoding) => { + if (data.length === 0) { + return '' + } + if (typeof data === 'string') { + data = Buffer.from(data, sourceEncoding) + } + + if (textDecoders.has(this.toString())) { + try { + return textDecoders.get(this).decode(data) + } catch {} + } + return typeof data === 'string' + ? data + : data.toString() + } } -SBMH.prototype._sbmh_memcmp = function (data, pos, len) { - for (var i = 0; i < len; ++i) { // eslint-disable-line no-var - if (this._sbmh_lookup_char(data, pos + i) !== this._needle[i]) { return false } +function decodeText (text, sourceEncoding, destEncoding) { + if (text) { + return getDecoder(destEncoding)(text, sourceEncoding) } - return true + return text } -module.exports = SBMH +module.exports = decodeText /***/ }), -/***/ 9581: -/***/ ((module, __unused_webpack_exports, __nccwpck_require__) => { +/***/ 2393: +/***/ ((module) => { -const WritableStream = (__nccwpck_require__(7075).Writable) -const { inherits } = __nccwpck_require__(7975) -const Dicer = __nccwpck_require__(7182) +module.exports = function getLimit (limits, name, defaultLimit) { + if ( + !limits || + limits[name] === undefined || + limits[name] === null + ) { return defaultLimit } -const MultipartParser = __nccwpck_require__(1192) -const UrlencodedParser = __nccwpck_require__(855) -const parseParams = __nccwpck_require__(8929) + if ( + typeof limits[name] !== 'number' || + isNaN(limits[name]) + ) { throw new TypeError('Limit ' + name + ' is not a valid number') } -function Busboy (opts) { - if (!(this instanceof Busboy)) { return new Busboy(opts) } + return limits[name] +} - if (typeof opts !== 'object') { - throw new TypeError('Busboy expected an options-Object.') - } - if (typeof opts.headers !== 'object') { - throw new TypeError('Busboy expected an options-Object with headers-attribute.') - } - if (typeof opts.headers['content-type'] !== 'string') { - throw new TypeError('Missing Content-Type-header.') - } - const { - headers, - ...streamOptions - } = opts +/***/ }), - this.opts = { - autoDestroy: false, - ...streamOptions - } - WritableStream.call(this, this.opts) +/***/ 8929: +/***/ ((module, __unused_webpack_exports, __nccwpck_require__) => { - this._done = false - this._parser = this.getParserByHeaders(headers) - this._finished = false -} -inherits(Busboy, WritableStream) +/* eslint-disable object-property-newline */ -Busboy.prototype.emit = function (ev) { - if (ev === 'finish') { - if (!this._done) { - this._parser?.end() - return - } else if (this._finished) { - return - } - this._finished = true - } - WritableStream.prototype.emit.apply(this, arguments) -} -Busboy.prototype.getParserByHeaders = function (headers) { - const parsed = parseParams(headers['content-type']) +const decodeText = __nccwpck_require__(2747) - const cfg = { - defCharset: this.opts.defCharset, - fileHwm: this.opts.fileHwm, - headers, - highWaterMark: this.opts.highWaterMark, - isPartAFile: this.opts.isPartAFile, - limits: this.opts.limits, - parsedConType: parsed, - preservePath: this.opts.preservePath - } +const RE_ENCODED = /%[a-fA-F0-9][a-fA-F0-9]/g - if (MultipartParser.detect.test(parsed[0])) { - return new MultipartParser(this, cfg) - } - if (UrlencodedParser.detect.test(parsed[0])) { - return new UrlencodedParser(this, cfg) - } - throw new Error('Unsupported Content-Type.') +const EncodedLookup = { + '%00': '\x00', '%01': '\x01', '%02': '\x02', '%03': '\x03', '%04': '\x04', + '%05': '\x05', '%06': '\x06', '%07': '\x07', '%08': '\x08', '%09': '\x09', + '%0a': '\x0a', '%0A': '\x0a', '%0b': '\x0b', '%0B': '\x0b', '%0c': '\x0c', + '%0C': '\x0c', '%0d': '\x0d', '%0D': '\x0d', '%0e': '\x0e', '%0E': '\x0e', + '%0f': '\x0f', '%0F': '\x0f', '%10': '\x10', '%11': '\x11', '%12': '\x12', + '%13': '\x13', '%14': '\x14', '%15': '\x15', '%16': '\x16', '%17': '\x17', + '%18': '\x18', '%19': '\x19', '%1a': '\x1a', '%1A': '\x1a', '%1b': '\x1b', + '%1B': '\x1b', '%1c': '\x1c', '%1C': '\x1c', '%1d': '\x1d', '%1D': '\x1d', + '%1e': '\x1e', '%1E': '\x1e', '%1f': '\x1f', '%1F': '\x1f', '%20': '\x20', + '%21': '\x21', '%22': '\x22', '%23': '\x23', '%24': '\x24', '%25': '\x25', + '%26': '\x26', '%27': '\x27', '%28': '\x28', '%29': '\x29', '%2a': '\x2a', + '%2A': '\x2a', '%2b': '\x2b', '%2B': '\x2b', '%2c': '\x2c', '%2C': '\x2c', + '%2d': '\x2d', '%2D': '\x2d', '%2e': '\x2e', '%2E': '\x2e', '%2f': '\x2f', + '%2F': '\x2f', '%30': '\x30', '%31': '\x31', '%32': '\x32', '%33': '\x33', + '%34': '\x34', '%35': '\x35', '%36': '\x36', '%37': '\x37', '%38': '\x38', + '%39': '\x39', '%3a': '\x3a', '%3A': '\x3a', '%3b': '\x3b', '%3B': '\x3b', + '%3c': '\x3c', '%3C': '\x3c', '%3d': '\x3d', '%3D': '\x3d', '%3e': '\x3e', + '%3E': '\x3e', '%3f': '\x3f', '%3F': '\x3f', '%40': '\x40', '%41': '\x41', + '%42': '\x42', '%43': '\x43', '%44': '\x44', '%45': '\x45', '%46': '\x46', + '%47': '\x47', '%48': '\x48', '%49': '\x49', '%4a': '\x4a', '%4A': '\x4a', + '%4b': '\x4b', '%4B': '\x4b', '%4c': '\x4c', '%4C': '\x4c', '%4d': '\x4d', + '%4D': '\x4d', '%4e': '\x4e', '%4E': '\x4e', '%4f': '\x4f', '%4F': '\x4f', + '%50': '\x50', '%51': '\x51', '%52': '\x52', '%53': '\x53', '%54': '\x54', + '%55': '\x55', '%56': '\x56', '%57': '\x57', '%58': '\x58', '%59': '\x59', + '%5a': '\x5a', '%5A': '\x5a', '%5b': '\x5b', '%5B': '\x5b', '%5c': '\x5c', + '%5C': '\x5c', '%5d': '\x5d', '%5D': '\x5d', '%5e': '\x5e', '%5E': '\x5e', + '%5f': '\x5f', '%5F': '\x5f', '%60': '\x60', '%61': '\x61', '%62': '\x62', + '%63': '\x63', '%64': '\x64', '%65': '\x65', '%66': '\x66', '%67': '\x67', + '%68': '\x68', '%69': '\x69', '%6a': '\x6a', '%6A': '\x6a', '%6b': '\x6b', + '%6B': '\x6b', '%6c': '\x6c', '%6C': '\x6c', '%6d': '\x6d', '%6D': '\x6d', + '%6e': '\x6e', '%6E': '\x6e', '%6f': '\x6f', '%6F': '\x6f', '%70': '\x70', + '%71': '\x71', '%72': '\x72', '%73': '\x73', '%74': '\x74', '%75': '\x75', + '%76': '\x76', '%77': '\x77', '%78': '\x78', '%79': '\x79', '%7a': '\x7a', + '%7A': '\x7a', '%7b': '\x7b', '%7B': '\x7b', '%7c': '\x7c', '%7C': '\x7c', + '%7d': '\x7d', '%7D': '\x7d', '%7e': '\x7e', '%7E': '\x7e', '%7f': '\x7f', + '%7F': '\x7f', '%80': '\x80', '%81': '\x81', '%82': '\x82', '%83': '\x83', + '%84': '\x84', '%85': '\x85', '%86': '\x86', '%87': '\x87', '%88': '\x88', + '%89': '\x89', '%8a': '\x8a', '%8A': '\x8a', '%8b': '\x8b', '%8B': '\x8b', + '%8c': '\x8c', '%8C': '\x8c', '%8d': '\x8d', '%8D': '\x8d', '%8e': '\x8e', + '%8E': '\x8e', '%8f': '\x8f', '%8F': '\x8f', '%90': '\x90', '%91': '\x91', + '%92': '\x92', '%93': '\x93', '%94': '\x94', '%95': '\x95', '%96': '\x96', + '%97': '\x97', '%98': '\x98', '%99': '\x99', '%9a': '\x9a', '%9A': '\x9a', + '%9b': '\x9b', '%9B': '\x9b', '%9c': '\x9c', '%9C': '\x9c', '%9d': '\x9d', + '%9D': '\x9d', '%9e': '\x9e', '%9E': '\x9e', '%9f': '\x9f', '%9F': '\x9f', + '%a0': '\xa0', '%A0': '\xa0', '%a1': '\xa1', '%A1': '\xa1', '%a2': '\xa2', + '%A2': '\xa2', '%a3': '\xa3', '%A3': '\xa3', '%a4': '\xa4', '%A4': '\xa4', + '%a5': '\xa5', '%A5': '\xa5', '%a6': '\xa6', '%A6': '\xa6', '%a7': '\xa7', + '%A7': '\xa7', '%a8': '\xa8', '%A8': '\xa8', '%a9': '\xa9', '%A9': '\xa9', + '%aa': '\xaa', '%Aa': '\xaa', '%aA': '\xaa', '%AA': '\xaa', '%ab': '\xab', + '%Ab': '\xab', '%aB': '\xab', '%AB': '\xab', '%ac': '\xac', '%Ac': '\xac', + '%aC': '\xac', '%AC': '\xac', '%ad': '\xad', '%Ad': '\xad', '%aD': '\xad', + '%AD': '\xad', '%ae': '\xae', '%Ae': '\xae', '%aE': '\xae', '%AE': '\xae', + '%af': '\xaf', '%Af': '\xaf', '%aF': '\xaf', '%AF': '\xaf', '%b0': '\xb0', + '%B0': '\xb0', '%b1': '\xb1', '%B1': '\xb1', '%b2': '\xb2', '%B2': '\xb2', + '%b3': '\xb3', '%B3': '\xb3', '%b4': '\xb4', '%B4': '\xb4', '%b5': '\xb5', + '%B5': '\xb5', '%b6': '\xb6', '%B6': '\xb6', '%b7': '\xb7', '%B7': '\xb7', + '%b8': '\xb8', '%B8': '\xb8', '%b9': '\xb9', '%B9': '\xb9', '%ba': '\xba', + '%Ba': '\xba', '%bA': '\xba', '%BA': '\xba', '%bb': '\xbb', '%Bb': '\xbb', + '%bB': '\xbb', '%BB': '\xbb', '%bc': '\xbc', '%Bc': '\xbc', '%bC': '\xbc', + '%BC': '\xbc', '%bd': '\xbd', '%Bd': '\xbd', '%bD': '\xbd', '%BD': '\xbd', + '%be': '\xbe', '%Be': '\xbe', '%bE': '\xbe', '%BE': '\xbe', '%bf': '\xbf', + '%Bf': '\xbf', '%bF': '\xbf', '%BF': '\xbf', '%c0': '\xc0', '%C0': '\xc0', + '%c1': '\xc1', '%C1': '\xc1', '%c2': '\xc2', '%C2': '\xc2', '%c3': '\xc3', + '%C3': '\xc3', '%c4': '\xc4', '%C4': '\xc4', '%c5': '\xc5', '%C5': '\xc5', + '%c6': '\xc6', '%C6': '\xc6', '%c7': '\xc7', '%C7': '\xc7', '%c8': '\xc8', + '%C8': '\xc8', '%c9': '\xc9', '%C9': '\xc9', '%ca': '\xca', '%Ca': '\xca', + '%cA': '\xca', '%CA': '\xca', '%cb': '\xcb', '%Cb': '\xcb', '%cB': '\xcb', + '%CB': '\xcb', '%cc': '\xcc', '%Cc': '\xcc', '%cC': '\xcc', '%CC': '\xcc', + '%cd': '\xcd', '%Cd': '\xcd', '%cD': '\xcd', '%CD': '\xcd', '%ce': '\xce', + '%Ce': '\xce', '%cE': '\xce', '%CE': '\xce', '%cf': '\xcf', '%Cf': '\xcf', + '%cF': '\xcf', '%CF': '\xcf', '%d0': '\xd0', '%D0': '\xd0', '%d1': '\xd1', + '%D1': '\xd1', '%d2': '\xd2', '%D2': '\xd2', '%d3': '\xd3', '%D3': '\xd3', + '%d4': '\xd4', '%D4': '\xd4', '%d5': '\xd5', '%D5': '\xd5', '%d6': '\xd6', + '%D6': '\xd6', '%d7': '\xd7', '%D7': '\xd7', '%d8': '\xd8', '%D8': '\xd8', + '%d9': '\xd9', '%D9': '\xd9', '%da': '\xda', '%Da': '\xda', '%dA': '\xda', + '%DA': '\xda', '%db': '\xdb', '%Db': '\xdb', '%dB': '\xdb', '%DB': '\xdb', + '%dc': '\xdc', '%Dc': '\xdc', '%dC': '\xdc', '%DC': '\xdc', '%dd': '\xdd', + '%Dd': '\xdd', '%dD': '\xdd', '%DD': '\xdd', '%de': '\xde', '%De': '\xde', + '%dE': '\xde', '%DE': '\xde', '%df': '\xdf', '%Df': '\xdf', '%dF': '\xdf', + '%DF': '\xdf', '%e0': '\xe0', '%E0': '\xe0', '%e1': '\xe1', '%E1': '\xe1', + '%e2': '\xe2', '%E2': '\xe2', '%e3': '\xe3', '%E3': '\xe3', '%e4': '\xe4', + '%E4': '\xe4', '%e5': '\xe5', '%E5': '\xe5', '%e6': '\xe6', '%E6': '\xe6', + '%e7': '\xe7', '%E7': '\xe7', '%e8': '\xe8', '%E8': '\xe8', '%e9': '\xe9', + '%E9': '\xe9', '%ea': '\xea', '%Ea': '\xea', '%eA': '\xea', '%EA': '\xea', + '%eb': '\xeb', '%Eb': '\xeb', '%eB': '\xeb', '%EB': '\xeb', '%ec': '\xec', + '%Ec': '\xec', '%eC': '\xec', '%EC': '\xec', '%ed': '\xed', '%Ed': '\xed', + '%eD': '\xed', '%ED': '\xed', '%ee': '\xee', '%Ee': '\xee', '%eE': '\xee', + '%EE': '\xee', '%ef': '\xef', '%Ef': '\xef', '%eF': '\xef', '%EF': '\xef', + '%f0': '\xf0', '%F0': '\xf0', '%f1': '\xf1', '%F1': '\xf1', '%f2': '\xf2', + '%F2': '\xf2', '%f3': '\xf3', '%F3': '\xf3', '%f4': '\xf4', '%F4': '\xf4', + '%f5': '\xf5', '%F5': '\xf5', '%f6': '\xf6', '%F6': '\xf6', '%f7': '\xf7', + '%F7': '\xf7', '%f8': '\xf8', '%F8': '\xf8', '%f9': '\xf9', '%F9': '\xf9', + '%fa': '\xfa', '%Fa': '\xfa', '%fA': '\xfa', '%FA': '\xfa', '%fb': '\xfb', + '%Fb': '\xfb', '%fB': '\xfb', '%FB': '\xfb', '%fc': '\xfc', '%Fc': '\xfc', + '%fC': '\xfc', '%FC': '\xfc', '%fd': '\xfd', '%Fd': '\xfd', '%fD': '\xfd', + '%FD': '\xfd', '%fe': '\xfe', '%Fe': '\xfe', '%fE': '\xfe', '%FE': '\xfe', + '%ff': '\xff', '%Ff': '\xff', '%fF': '\xff', '%FF': '\xff' } -Busboy.prototype._write = function (chunk, encoding, cb) { - this._parser.write(chunk, cb) +function encodedReplacer (match) { + return EncodedLookup[match] } -module.exports = Busboy -module.exports["default"] = Busboy -module.exports.Busboy = Busboy - -module.exports.Dicer = Dicer - +const STATE_KEY = 0 +const STATE_VALUE = 1 +const STATE_CHARSET = 2 +const STATE_LANG = 3 -/***/ }), +function parseParams (str) { + const res = [] + let state = STATE_KEY + let charset = '' + let inquote = false + let escaping = false + let p = 0 + let tmp = '' + const len = str.length -/***/ 1192: -/***/ ((module, __unused_webpack_exports, __nccwpck_require__) => { + for (var i = 0; i < len; ++i) { // eslint-disable-line no-var + const char = str[i] + if (char === '\\' && inquote) { + if (escaping) { escaping = false } else { + escaping = true + continue + } + } else if (char === '"') { + if (!escaping) { + if (inquote) { + inquote = false + state = STATE_KEY + } else { inquote = true } + continue + } else { escaping = false } + } else { + if (escaping && inquote) { tmp += '\\' } + escaping = false + if ((state === STATE_CHARSET || state === STATE_LANG) && char === "'") { + if (state === STATE_CHARSET) { + state = STATE_LANG + charset = tmp.substring(1) + } else { state = STATE_VALUE } + tmp = '' + continue + } else if (state === STATE_KEY && + (char === '*' || char === '=') && + res.length) { + state = char === '*' + ? STATE_CHARSET + : STATE_VALUE + res[p] = [tmp, undefined] + tmp = '' + continue + } else if (!inquote && char === ';') { + state = STATE_KEY + if (charset) { + if (tmp.length) { + tmp = decodeText(tmp.replace(RE_ENCODED, encodedReplacer), + 'binary', + charset) + } + charset = '' + } else if (tmp.length) { + tmp = decodeText(tmp, 'binary', 'utf8') + } + if (res[p] === undefined) { res[p] = tmp } else { res[p][1] = tmp } + tmp = '' + ++p + continue + } else if (!inquote && (char === ' ' || char === '\t')) { continue } + } + tmp += char + } + if (charset && tmp.length) { + tmp = decodeText(tmp.replace(RE_ENCODED, encodedReplacer), + 'binary', + charset) + } else if (tmp) { + tmp = decodeText(tmp, 'binary', 'utf8') + } + if (res[p] === undefined) { + if (tmp) { res[p] = tmp } + } else { res[p][1] = tmp } + return res +} -// TODO: -// * support 1 nested multipart level -// (see second multipart example here: -// http://www.w3.org/TR/html401/interact/forms.html#didx-multipartform-data) -// * support limits.fieldNameSize -// -- this will require modifications to utils.parseParams +module.exports = parseParams -const { Readable } = __nccwpck_require__(7075) -const { inherits } = __nccwpck_require__(7975) -const Dicer = __nccwpck_require__(7182) +/***/ }) -const parseParams = __nccwpck_require__(8929) -const decodeText = __nccwpck_require__(2747) -const basename = __nccwpck_require__(692) -const getLimit = __nccwpck_require__(2393) +/******/ }); +/************************************************************************/ +/******/ // The module cache +/******/ var __webpack_module_cache__ = {}; +/******/ +/******/ // The require function +/******/ function __nccwpck_require__(moduleId) { +/******/ // Check if module is in cache +/******/ var cachedModule = __webpack_module_cache__[moduleId]; +/******/ if (cachedModule !== undefined) { +/******/ return cachedModule.exports; +/******/ } +/******/ // Create a new module (and put it into the cache) +/******/ var module = __webpack_module_cache__[moduleId] = { +/******/ // no module.id needed +/******/ // no module.loaded needed +/******/ exports: {} +/******/ }; +/******/ +/******/ // Execute the module function +/******/ var threw = true; +/******/ try { +/******/ __webpack_modules__[moduleId].call(module.exports, module, module.exports, __nccwpck_require__); +/******/ threw = false; +/******/ } finally { +/******/ if(threw) delete __webpack_module_cache__[moduleId]; +/******/ } +/******/ +/******/ // Return the exports of the module +/******/ return module.exports; +/******/ } +/******/ +/************************************************************************/ +/******/ /* webpack/runtime/compat */ +/******/ +/******/ if (typeof __nccwpck_require__ !== 'undefined') __nccwpck_require__.ab = new URL('.', import.meta.url).pathname.slice(import.meta.url.match(/^file:\/\/\/\w:/) ? 1 : 0, -1) + "/"; +/******/ +/************************************************************************/ +var __webpack_exports__ = {}; + +// EXTERNAL MODULE: ./node_modules/@actions/core/lib/core.js +var core = __nccwpck_require__(7484); +// EXTERNAL MODULE: external "util" +var external_util_ = __nccwpck_require__(9023); +// EXTERNAL MODULE: external "child_process" +var external_child_process_ = __nccwpck_require__(5317); +;// CONCATENATED MODULE: ./node_modules/@bufbuild/protobuf/dist/esm/service-type.js +// Copyright 2021-2024 Buf Technologies, Inc. +// +// Licensed under the Apache License, Version 2.0 (the "License"); +// you may not use this file except in compliance with the License. +// You may obtain a copy of the License at +// +// http://www.apache.org/licenses/LICENSE-2.0 +// +// Unless required by applicable law or agreed to in writing, software +// distributed under the License is distributed on an "AS IS" BASIS, +// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. +// See the License for the specific language governing permissions and +// limitations under the License. +/** + * MethodKind represents the four method types that can be declared in + * protobuf with the `stream` keyword: + * + * 1. Unary: rpc (Input) returns (Output) + * 2. ServerStreaming: rpc (Input) returns (stream Output) + * 3. ClientStreaming: rpc (stream Input) returns (Output) + * 4. BiDiStreaming: rpc (stream Input) returns (stream Output) + */ +var MethodKind; +(function (MethodKind) { + MethodKind[MethodKind["Unary"] = 0] = "Unary"; + MethodKind[MethodKind["ServerStreaming"] = 1] = "ServerStreaming"; + MethodKind[MethodKind["ClientStreaming"] = 2] = "ClientStreaming"; + MethodKind[MethodKind["BiDiStreaming"] = 3] = "BiDiStreaming"; +})(MethodKind || (MethodKind = {})); +/** + * Is this method side-effect-free (or safe in HTTP parlance), or just + * idempotent, or neither? HTTP based RPC implementation may choose GET verb + * for safe methods, and PUT verb for idempotent methods instead of the + * default POST. + * + * This enum matches the protobuf enum google.protobuf.MethodOptions.IdempotencyLevel, + * defined in the well-known type google/protobuf/descriptor.proto, but + * drops UNKNOWN. + */ +var MethodIdempotency; +(function (MethodIdempotency) { + /** + * Idempotent, no side effects. + */ + MethodIdempotency[MethodIdempotency["NoSideEffects"] = 1] = "NoSideEffects"; + /** + * Idempotent, but may have side effects. + */ + MethodIdempotency[MethodIdempotency["Idempotent"] = 2] = "Idempotent"; +})(MethodIdempotency || (MethodIdempotency = {})); + +;// CONCATENATED MODULE: ./node_modules/@connectrpc/connect/dist/esm/any-client.js +// Copyright 2021-2024 The Connect Authors +// +// Licensed under the Apache License, Version 2.0 (the "License"); +// you may not use this file except in compliance with the License. +// You may obtain a copy of the License at +// +// http://www.apache.org/licenses/LICENSE-2.0 +// +// Unless required by applicable law or agreed to in writing, software +// distributed under the License is distributed on an "AS IS" BASIS, +// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. +// See the License for the specific language governing permissions and +// limitations under the License. +/** + * Create any client for the given service. + * + * The given createMethod function is called for each method definition + * of the service. The function it returns is added to the client object + * as a method. + */ +function makeAnyClient(service, createMethod) { + const client = {}; + for (const [localName, methodInfo] of Object.entries(service.methods)) { + const method = createMethod(Object.assign(Object.assign({}, methodInfo), { localName, + service })); + if (method != null) { + client[localName] = method; + } + } + return client; +} + +;// CONCATENATED MODULE: ./node_modules/@connectrpc/connect/dist/esm/code.js +// Copyright 2021-2024 The Connect Authors +// +// Licensed under the Apache License, Version 2.0 (the "License"); +// you may not use this file except in compliance with the License. +// You may obtain a copy of the License at +// +// http://www.apache.org/licenses/LICENSE-2.0 +// +// Unless required by applicable law or agreed to in writing, software +// distributed under the License is distributed on an "AS IS" BASIS, +// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. +// See the License for the specific language governing permissions and +// limitations under the License. +/** + * Connect represents categories of errors as codes, and each code maps to a + * specific HTTP status code. The codes and their semantics were chosen to + * match gRPC. Only the codes below are valid — there are no user-defined + * codes. + * + * See the specification at https://connectrpc.com/docs/protocol#error-codes + * for details. + */ +var code_Code; +(function (Code) { + /** + * Canceled, usually be the user + */ + Code[Code["Canceled"] = 1] = "Canceled"; + /** + * Unknown error + */ + Code[Code["Unknown"] = 2] = "Unknown"; + /** + * Argument invalid regardless of system state + */ + Code[Code["InvalidArgument"] = 3] = "InvalidArgument"; + /** + * Operation expired, may or may not have completed. + */ + Code[Code["DeadlineExceeded"] = 4] = "DeadlineExceeded"; + /** + * Entity not found. + */ + Code[Code["NotFound"] = 5] = "NotFound"; + /** + * Entity already exists. + */ + Code[Code["AlreadyExists"] = 6] = "AlreadyExists"; + /** + * Operation not authorized. + */ + Code[Code["PermissionDenied"] = 7] = "PermissionDenied"; + /** + * Quota exhausted. + */ + Code[Code["ResourceExhausted"] = 8] = "ResourceExhausted"; + /** + * Argument invalid in current system state. + */ + Code[Code["FailedPrecondition"] = 9] = "FailedPrecondition"; + /** + * Operation aborted. + */ + Code[Code["Aborted"] = 10] = "Aborted"; + /** + * Out of bounds, use instead of FailedPrecondition. + */ + Code[Code["OutOfRange"] = 11] = "OutOfRange"; + /** + * Operation not implemented or disabled. + */ + Code[Code["Unimplemented"] = 12] = "Unimplemented"; + /** + * Internal error, reserved for "serious errors". + */ + Code[Code["Internal"] = 13] = "Internal"; + /** + * Unavailable, client should back off and retry. + */ + Code[Code["Unavailable"] = 14] = "Unavailable"; + /** + * Unrecoverable data loss or corruption. + */ + Code[Code["DataLoss"] = 15] = "DataLoss"; + /** + * Request isn't authenticated. + */ + Code[Code["Unauthenticated"] = 16] = "Unauthenticated"; +})(code_Code || (code_Code = {})); + +;// CONCATENATED MODULE: ./node_modules/@connectrpc/connect/dist/esm/protocol-connect/code-string.js +// Copyright 2021-2024 The Connect Authors +// +// Licensed under the Apache License, Version 2.0 (the "License"); +// you may not use this file except in compliance with the License. +// You may obtain a copy of the License at +// +// http://www.apache.org/licenses/LICENSE-2.0 +// +// Unless required by applicable law or agreed to in writing, software +// distributed under the License is distributed on an "AS IS" BASIS, +// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. +// See the License for the specific language governing permissions and +// limitations under the License. + +/** + * codeToString returns the string representation of a Code. + * + * @private Internal code, does not follow semantic versioning. + */ +function codeToString(value) { + const name = code_Code[value]; + if (typeof name != "string") { + return value.toString(); + } + return (name[0].toLowerCase() + + name.substring(1).replace(/[A-Z]/g, (c) => "_" + c.toLowerCase())); +} +let stringToCode; +/** + * codeFromString parses the string representation of a Code in snake_case. + * For example, the string "permission_denied" parses into Code.PermissionDenied. + * + * If the given string cannot be parsed, the function returns undefined. + * + * @private Internal code, does not follow semantic versioning. + */ +function codeFromString(value) { + if (!stringToCode) { + stringToCode = {}; + for (const value of Object.values(Code)) { + if (typeof value == "string") { + continue; + } + stringToCode[codeToString(value)] = value; + } + } + return stringToCode[value]; +} + +;// CONCATENATED MODULE: ./node_modules/@connectrpc/connect/dist/esm/connect-error.js +// Copyright 2021-2024 The Connect Authors +// +// Licensed under the Apache License, Version 2.0 (the "License"); +// you may not use this file except in compliance with the License. +// You may obtain a copy of the License at +// +// http://www.apache.org/licenses/LICENSE-2.0 +// +// Unless required by applicable law or agreed to in writing, software +// distributed under the License is distributed on an "AS IS" BASIS, +// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. +// See the License for the specific language governing permissions and +// limitations under the License. + + +/** + * ConnectError captures four pieces of information: a Code, an error + * message, an optional cause of the error, and an optional collection of + * arbitrary Protobuf messages called "details". + * + * Because developer tools typically show just the error message, we prefix + * it with the status code, so that the most important information is always + * visible immediately. + * + * Error details are wrapped with google.protobuf.Any on the wire, so that + * a server or middleware can attach arbitrary data to an error. Use the + * method findDetails() to retrieve the details. + */ +class connect_error_ConnectError extends Error { + /** + * Create a new ConnectError. + * If no code is provided, code "unknown" is used. + * Outgoing details are only relevant for the server side - a service may + * raise an error with details, and it is up to the protocol implementation + * to encode and send the details along with error. + */ + constructor(message, code = code_Code.Unknown, metadata, outgoingDetails, cause) { + super(createMessage(message, code)); + this.name = "ConnectError"; + // see https://www.typescriptlang.org/docs/handbook/release-notes/typescript-2-2.html#example + Object.setPrototypeOf(this, new.target.prototype); + this.rawMessage = message; + this.code = code; + this.metadata = new Headers(metadata !== null && metadata !== void 0 ? metadata : {}); + this.details = outgoingDetails !== null && outgoingDetails !== void 0 ? outgoingDetails : []; + this.cause = cause; + } + /** + * Convert any value - typically a caught error into a ConnectError, + * following these rules: + * - If the value is already a ConnectError, return it as is. + * - If the value is an AbortError from the fetch API, return the message + * of the AbortError with code Canceled. + * - For other Errors, return the error message with code Unknown by default. + * - For other values, return the values String representation as a message, + * with the code Unknown by default. + * The original value will be used for the "cause" property for the new + * ConnectError. + */ + static from(reason, code = code_Code.Unknown) { + if (reason instanceof connect_error_ConnectError) { + return reason; + } + if (reason instanceof Error) { + if (reason.name == "AbortError") { + // Fetch requests can only be canceled with an AbortController. + // We detect that condition by looking at the name of the raised + // error object, and translate to the appropriate status code. + return new connect_error_ConnectError(reason.message, code_Code.Canceled); + } + return new connect_error_ConnectError(reason.message, code, undefined, undefined, reason); + } + return new connect_error_ConnectError(String(reason), code, undefined, undefined, reason); + } + static [Symbol.hasInstance](v) { + if (!(v instanceof Error)) { + return false; + } + if (Object.getPrototypeOf(v) === connect_error_ConnectError.prototype) { + return true; + } + return (v.name === "ConnectError" && + "code" in v && + typeof v.code === "number" && + "metadata" in v && + "details" in v && + Array.isArray(v.details) && + "rawMessage" in v && + typeof v.rawMessage == "string" && + "cause" in v); + } + findDetails(typeOrRegistry) { + const registry = "typeName" in typeOrRegistry + ? { + findMessage: (typeName) => typeName === typeOrRegistry.typeName ? typeOrRegistry : undefined, + } + : typeOrRegistry; + const details = []; + for (const data of this.details) { + if ("getType" in data) { + if (registry.findMessage(data.getType().typeName)) { + details.push(data); + } + continue; + } + const type = registry.findMessage(data.type); + if (type) { + try { + details.push(type.fromBinary(data.value)); + } + catch (_) { + // We silently give up if we are unable to parse the detail, because + // that appears to be the least worst behavior. + // It is very unlikely that a user surrounds a catch body handling the + // error with another try-catch statement, and we do not want to + // recommend doing so. + } + } + } + return details; + } +} +/** + * Create an error message, prefixing the given code. + */ +function createMessage(message, code) { + return message.length + ? `[${codeToString(code)}] ${message}` + : `[${codeToString(code)}]`; +} + +;// CONCATENATED MODULE: ./node_modules/@connectrpc/connect/dist/esm/protocol/compression.js +// Copyright 2021-2024 The Connect Authors +// +// Licensed under the Apache License, Version 2.0 (the "License"); +// you may not use this file except in compliance with the License. +// You may obtain a copy of the License at +// +// http://www.apache.org/licenses/LICENSE-2.0 +// +// Unless required by applicable law or agreed to in writing, software +// distributed under the License is distributed on an "AS IS" BASIS, +// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. +// See the License for the specific language governing permissions and +// limitations under the License. + + +/** + * compressedFlag indicates that the data in a EnvelopedMessage is + * compressed. It has the same meaning in the gRPC-Web, gRPC-HTTP2, + * and Connect protocols. + * + * @private Internal code, does not follow semantic versioning. + */ +const compressedFlag = 0b00000001; +/** + * Validates the request encoding and determines the accepted response encoding. + * + * Returns the request and response compression to use. If the client requested + * an encoding that is not available, the returned object contains an error that + * must be used for the response. + * + * @private Internal code, does not follow semantic versioning. + */ +function compressionNegotiate(available, requested, // e.g. the value of the Grpc-Encoding header +accepted, // e.g. the value of the Grpc-Accept-Encoding header +headerNameAcceptEncoding) { + let request = null; + let response = null; + let error = undefined; + if (requested !== null && requested !== "identity") { + const found = available.find((c) => c.name === requested); + if (found) { + request = found; + } + else { + // To comply with https://github.com/grpc/grpc/blob/master/doc/compression.md + // and the Connect protocol, we return code "unimplemented" and specify + // acceptable compression(s). + const acceptable = available.map((c) => c.name).join(","); + error = new ConnectError(`unknown compression "${requested}": supported encodings are ${acceptable}`, Code.Unimplemented, { + [headerNameAcceptEncoding]: acceptable, + }); + } + } + if (accepted === null || accepted === "") { + // Support asymmetric compression. This logic follows + // https://github.com/grpc/grpc/blob/master/doc/compression.md and common + // sense. + response = request; + } + else { + const acceptNames = accepted.split(",").map((n) => n.trim()); + for (const name of acceptNames) { + const found = available.find((c) => c.name === name); + if (found) { + response = found; + break; + } + } + } + return { request, response, error }; +} + +;// CONCATENATED MODULE: ./node_modules/@connectrpc/connect/dist/esm/protocol/envelope.js +// Copyright 2021-2024 The Connect Authors +// +// Licensed under the Apache License, Version 2.0 (the "License"); +// you may not use this file except in compliance with the License. +// You may obtain a copy of the License at +// +// http://www.apache.org/licenses/LICENSE-2.0 +// +// Unless required by applicable law or agreed to in writing, software +// distributed under the License is distributed on an "AS IS" BASIS, +// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. +// See the License for the specific language governing permissions and +// limitations under the License. + + + +/** + * Create a WHATWG ReadableStream of enveloped messages from a ReadableStream + * of bytes. + * + * Ideally, this would simply be a TransformStream, but ReadableStream.pipeThrough + * does not have the necessary availability at this time. + * + * @private Internal code, does not follow semantic versioning. + */ +function createEnvelopeReadableStream(stream) { + let reader; + let buffer = new Uint8Array(0); + function append(chunk) { + const n = new Uint8Array(buffer.length + chunk.length); + n.set(buffer); + n.set(chunk, buffer.length); + buffer = n; + } + return new ReadableStream({ + start() { + reader = stream.getReader(); + }, + async pull(controller) { + let header = undefined; + for (;;) { + if (header === undefined && buffer.byteLength >= 5) { + let length = 0; + for (let i = 1; i < 5; i++) { + length = (length << 8) + buffer[i]; + } + header = { flags: buffer[0], length }; + } + if (header !== undefined && buffer.byteLength >= header.length + 5) { + break; + } + const result = await reader.read(); + if (result.done) { + break; + } + append(result.value); + } + if (header === undefined) { + if (buffer.byteLength == 0) { + controller.close(); + return; + } + controller.error(new ConnectError("premature end of stream", Code.DataLoss)); + return; + } + const data = buffer.subarray(5, 5 + header.length); + buffer = buffer.subarray(5 + header.length); + controller.enqueue({ + flags: header.flags, + data, + }); + }, + }); +} +/** + * Compress an EnvelopedMessage. + * + * Raises Internal if an enveloped message is already compressed. + * + * @private Internal code, does not follow semantic versioning. + */ +async function envelopeCompress(envelope, compression, compressMinBytes) { + let { flags, data } = envelope; + if ((flags & compressedFlag) === compressedFlag) { + throw new connect_error_ConnectError("invalid envelope, already compressed", code_Code.Internal); + } + if (compression && data.byteLength >= compressMinBytes) { + data = await compression.compress(data); + flags = flags | compressedFlag; + } + return { data, flags }; +} +/** + * Decompress an EnvelopedMessage. + * + * Raises InvalidArgument if an envelope is compressed, but compression is null. + * + * Relies on the provided Compression to raise ResourceExhausted if the + * *decompressed* message size is larger than readMaxBytes. If the envelope is + * not compressed, readMaxBytes is not honored. + * + * @private Internal code, does not follow semantic versioning. + */ +async function envelopeDecompress(envelope, compression, readMaxBytes) { + let { flags, data } = envelope; + if ((flags & compressedFlag) === compressedFlag) { + if (!compression) { + throw new connect_error_ConnectError("received compressed envelope, but do not know how to decompress", code_Code.Internal); + } + data = await compression.decompress(data, readMaxBytes); + flags = flags ^ compressedFlag; + } + return { data, flags }; +} +/** + * Encode a single enveloped message. + * + * @private Internal code, does not follow semantic versioning. + */ +function encodeEnvelope(flags, data) { + const bytes = new Uint8Array(data.length + 5); + bytes.set(data, 5); + const v = new DataView(bytes.buffer, bytes.byteOffset, bytes.byteLength); + v.setUint8(0, flags); // first byte is flags + v.setUint32(1, data.length); // 4 bytes message length + return bytes; +} +/** + * Encode a set of enveloped messages. + * + * @private Internal code, does not follow semantic versioning. + */ +function encodeEnvelopes(...envelopes) { + const len = envelopes.reduce((previousValue, currentValue) => previousValue + currentValue.data.length + 5, 0); + const bytes = new Uint8Array(len); + const v = new DataView(bytes.buffer); + let offset = 0; + for (const e of envelopes) { + v.setUint8(offset, e.flags); // first byte is flags + v.setUint32(offset + 1, e.data.length); // 4 bytes message length + bytes.set(e.data, offset + 5); + offset += e.data.length + 5; + } + return bytes; +} + +;// CONCATENATED MODULE: ./node_modules/@connectrpc/connect/dist/esm/protocol/limit-io.js +// Copyright 2021-2024 The Connect Authors +// +// Licensed under the Apache License, Version 2.0 (the "License"); +// you may not use this file except in compliance with the License. +// You may obtain a copy of the License at +// +// http://www.apache.org/licenses/LICENSE-2.0 +// +// Unless required by applicable law or agreed to in writing, software +// distributed under the License is distributed on an "AS IS" BASIS, +// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. +// See the License for the specific language governing permissions and +// limitations under the License. + + +/** + * At most, allow ~4GiB to be received or sent per message. + * zlib used by Node.js caps maxOutputLength at this value. It also happens to + * be the maximum theoretical message size supported by protobuf-es. + */ +const maxReadMaxBytes = 0xffffffff; +const maxWriteMaxBytes = maxReadMaxBytes; +/** + * The default value for the compressMinBytes option. The CPU cost of compressing + * very small messages usually isn't worth the small reduction in network I/O, so + * the default value is 1 kibibyte. + */ +const defaultCompressMinBytes = 1024; +/** + * Asserts that the options writeMaxBytes, readMaxBytes, and compressMinBytes + * are within sane limits, and returns default values where no value is + * provided. + * + * @private Internal code, does not follow semantic versioning. + */ +function validateReadWriteMaxBytes(readMaxBytes, writeMaxBytes, compressMinBytes) { + writeMaxBytes !== null && writeMaxBytes !== void 0 ? writeMaxBytes : (writeMaxBytes = maxWriteMaxBytes); + readMaxBytes !== null && readMaxBytes !== void 0 ? readMaxBytes : (readMaxBytes = maxReadMaxBytes); + compressMinBytes !== null && compressMinBytes !== void 0 ? compressMinBytes : (compressMinBytes = defaultCompressMinBytes); + if (writeMaxBytes < 1 || writeMaxBytes > maxWriteMaxBytes) { + throw new connect_error_ConnectError(`writeMaxBytes ${writeMaxBytes} must be >= 1 and <= ${maxWriteMaxBytes}`, code_Code.Internal); + } + if (readMaxBytes < 1 || readMaxBytes > maxReadMaxBytes) { + throw new connect_error_ConnectError(`readMaxBytes ${readMaxBytes} must be >= 1 and <= ${maxReadMaxBytes}`, code_Code.Internal); + } + return { + readMaxBytes, + writeMaxBytes, + compressMinBytes, + }; +} +/** + * Raise an error ResourceExhausted if more than writeMaxByte are written. + * + * @private Internal code, does not follow semantic versioning. + */ +function assertWriteMaxBytes(writeMaxBytes, bytesWritten) { + if (bytesWritten > writeMaxBytes) { + throw new connect_error_ConnectError(`message size ${bytesWritten} is larger than configured writeMaxBytes ${writeMaxBytes}`, code_Code.ResourceExhausted); + } +} +/** + * Raise an error ResourceExhausted if more than readMaxBytes are read. + * + * @private Internal code, does not follow semantic versioning. + */ +function limit_io_assertReadMaxBytes(readMaxBytes, bytesRead, totalSizeKnown = false) { + if (bytesRead > readMaxBytes) { + let message = `message size is larger than configured readMaxBytes ${readMaxBytes}`; + if (totalSizeKnown) { + message = `message size ${bytesRead} is larger than configured readMaxBytes ${readMaxBytes}`; + } + throw new connect_error_ConnectError(message, code_Code.ResourceExhausted); + } +} + +;// CONCATENATED MODULE: ./node_modules/@connectrpc/connect/dist/esm/protocol/async-iterable.js +// Copyright 2021-2024 The Connect Authors +// +// Licensed under the Apache License, Version 2.0 (the "License"); +// you may not use this file except in compliance with the License. +// You may obtain a copy of the License at +// +// http://www.apache.org/licenses/LICENSE-2.0 +// +// Unless required by applicable law or agreed to in writing, software +// distributed under the License is distributed on an "AS IS" BASIS, +// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. +// See the License for the specific language governing permissions and +// limitations under the License. +var __asyncValues = (undefined && undefined.__asyncValues) || function (o) { + if (!Symbol.asyncIterator) throw new TypeError("Symbol.asyncIterator is not defined."); + var m = o[Symbol.asyncIterator], i; + return m ? m.call(o) : (o = typeof __values === "function" ? __values(o) : o[Symbol.iterator](), i = {}, verb("next"), verb("throw"), verb("return"), i[Symbol.asyncIterator] = function () { return this; }, i); + function verb(n) { i[n] = o[n] && function (v) { return new Promise(function (resolve, reject) { v = o[n](v), settle(resolve, reject, v.done, v.value); }); }; } + function settle(resolve, reject, d, v) { Promise.resolve(v).then(function(v) { resolve({ value: v, done: d }); }, reject); } +}; +var __await = (undefined && undefined.__await) || function (v) { return this instanceof __await ? (this.v = v, this) : new __await(v); } +var __asyncGenerator = (undefined && undefined.__asyncGenerator) || function (thisArg, _arguments, generator) { + if (!Symbol.asyncIterator) throw new TypeError("Symbol.asyncIterator is not defined."); + var g = generator.apply(thisArg, _arguments || []), i, q = []; + return i = {}, verb("next"), verb("throw"), verb("return", awaitReturn), i[Symbol.asyncIterator] = function () { return this; }, i; + function awaitReturn(f) { return function (v) { return Promise.resolve(v).then(f, reject); }; } + function verb(n, f) { if (g[n]) { i[n] = function (v) { return new Promise(function (a, b) { q.push([n, v, a, b]) > 1 || resume(n, v); }); }; if (f) i[n] = f(i[n]); } } + function resume(n, v) { try { step(g[n](v)); } catch (e) { settle(q[0][3], e); } } + function step(r) { r.value instanceof __await ? Promise.resolve(r.value.v).then(fulfill, reject) : settle(q[0][2], r); } + function fulfill(value) { resume("next", value); } + function reject(value) { resume("throw", value); } + function settle(f, v) { if (f(v), q.shift(), q.length) resume(q[0][0], q[0][1]); } +}; +var __asyncDelegator = (undefined && undefined.__asyncDelegator) || function (o) { + var i, p; + return i = {}, verb("next"), verb("throw", function (e) { throw e; }), verb("return"), i[Symbol.iterator] = function () { return this; }, i; + function verb(n, f) { i[n] = o[n] ? function (v) { return (p = !p) ? { value: __await(o[n](v)), done: false } : f ? f(v) : v; } : f; } +}; + + + + +function pipeTo(source, ...rest) { + const [transforms, sink, opt] = pickTransformsAndSink(rest); + let iterable = source; + let abortable; + if ((opt === null || opt === void 0 ? void 0 : opt.propagateDownStreamError) === true) { + iterable = abortable = makeIterableAbortable(iterable); + } + // eslint-disable-next-line @typescript-eslint/ban-ts-comment + // @ts-ignore + iterable = pipe(iterable, ...transforms, { propagateDownStreamError: false }); + return sink(iterable).catch((reason) => { + if (abortable) { + return abortable.abort(reason).then(() => Promise.reject(reason)); + } + return Promise.reject(reason); + }); +} +// pick transforms, the sink, and options from the pipeTo() rest parameter +function pickTransformsAndSink(rest) { + let opt; + if (typeof rest[rest.length - 1] != "function") { + opt = rest.pop(); + } + const sink = rest.pop(); + return [rest, sink, opt]; +} +/** + * Creates an AsyncIterableSink that concatenates all elements from the input. + * + * @private Internal code, does not follow semantic versioning. + */ +function sinkAll() { + return async function (iterable) { + var _a, e_1, _b, _c; + const all = []; + try { + for (var _d = true, iterable_1 = __asyncValues(iterable), iterable_1_1; iterable_1_1 = await iterable_1.next(), _a = iterable_1_1.done, !_a; _d = true) { + _c = iterable_1_1.value; + _d = false; + const chunk = _c; + all.push(chunk); + } + } + catch (e_1_1) { e_1 = { error: e_1_1 }; } + finally { + try { + if (!_d && !_a && (_b = iterable_1.return)) await _b.call(iterable_1); + } + finally { if (e_1) throw e_1.error; } + } + return all; + }; +} +/** + * Creates an AsyncIterableSink that concatenates all chunks from the input into + * a single Uint8Array. + * + * The iterable raises an error if the more than readMaxBytes are read. + * + * An optional length hint can be provided to optimize allocation and validation. + * If more or less bytes are present in the source that the length hint indicates, + * and error is raised. + * If the length hint is larger than readMaxBytes, an error is raised. + * If the length hint is not a positive integer, it is ignored. + * + * @private Internal code, does not follow semantic versioning. + */ +function sinkAllBytes(readMaxBytes, lengthHint) { + return async function (iterable) { + return await readAllBytes(iterable, readMaxBytes, lengthHint); + }; +} +function pipe(source, ...rest) { + return __asyncGenerator(this, arguments, function* pipe_1() { + var _a; + const [transforms, opt] = pickTransforms(rest); + let abortable; + const sourceIt = source[Symbol.asyncIterator](); + const cachedSource = { + [Symbol.asyncIterator]() { + return sourceIt; + }, + }; + let iterable = cachedSource; + if ((opt === null || opt === void 0 ? void 0 : opt.propagateDownStreamError) === true) { + iterable = abortable = makeIterableAbortable(iterable); + } + for (const t of transforms) { + iterable = t(iterable); + } + const it = iterable[Symbol.asyncIterator](); + try { + for (;;) { + const r = yield __await(it.next()); + if (r.done === true) { + break; + } + if (!abortable) { + yield yield __await(r.value); + continue; + } + try { + yield yield __await(r.value); + } + catch (e) { + yield __await(abortable.abort(e)); // propagate downstream error to the source + throw e; + } + } + } + finally { + if ((opt === null || opt === void 0 ? void 0 : opt.propagateDownStreamError) === true) { + // Call return on the source iterable to indicate + // that we will no longer consume it and it should + // cleanup any allocated resources. + (_a = sourceIt.return) === null || _a === void 0 ? void 0 : _a.call(sourceIt).catch(() => { + // return returns a promise, which we don't care about. + // + // Uncaught promises are thrown at sometime/somewhere by the event loop, + // this is to ensure error is caught and ignored. + }); + } + } + }); +} +function pickTransforms(rest) { + let opt; + if (typeof rest[rest.length - 1] != "function") { + opt = rest.pop(); + } + return [rest, opt]; +} +/** + * Creates an AsyncIterableTransform that catches any error from the input, and + * passes it to the given catchError function. + * + * The catchError function may return a final value. + * + * @private Internal code, does not follow semantic versioning. + */ +function transformCatch(catchError) { + return function (iterable) { + return __asyncGenerator(this, arguments, function* () { + // we deliberate avoid a for-await loop because we only want to catch upstream + // errors, not downstream errors (yield). + const it = iterable[Symbol.asyncIterator](); + for (;;) { + let r; + try { + r = yield __await(it.next()); + } + catch (e) { + const caught = yield __await(catchError(e)); + if (caught !== undefined) { + yield yield __await(caught); + } + break; + } + if (r.done === true) { + break; + } + yield yield __await(r.value); + } + }); + }; +} +/** + * Creates an AsyncIterableTransform that catches any error from the input, and + * passes it to the given function. Unlike transformCatch(), the given function + * is also called when no error is raised. + * + * @private Internal code, does not follow semantic versioning. + */ +function transformCatchFinally(catchFinally) { + return function (iterable) { + return __asyncGenerator(this, arguments, function* () { + // we deliberate avoid a for-await loop because we only want to catch upstream + // errors, not downstream errors (yield). + let err; + const it = iterable[Symbol.asyncIterator](); + for (;;) { + let r; + try { + r = yield __await(it.next()); + } + catch (e) { + err = e; + break; + } + if (r.done === true) { + break; + } + yield yield __await(r.value); + } + const caught = yield __await(catchFinally(err)); + if (caught !== undefined) { + yield yield __await(caught); + } + }); + }; +} +/** + * Creates an AsyncIterableTransform that appends a value. + * + * The element to append is provided by a function. If the function returns + * undefined, no element is appended. + * + * @private Internal code, does not follow semantic versioning. + */ +function transformAppend(provide) { + return function (iterable) { + return __asyncGenerator(this, arguments, function* () { + var _a, e_2, _b, _c; + try { + for (var _d = true, iterable_2 = __asyncValues(iterable), iterable_2_1; iterable_2_1 = yield __await(iterable_2.next()), _a = iterable_2_1.done, !_a; _d = true) { + _c = iterable_2_1.value; + _d = false; + const chunk = _c; + yield yield __await(chunk); + } + } + catch (e_2_1) { e_2 = { error: e_2_1 }; } + finally { + try { + if (!_d && !_a && (_b = iterable_2.return)) yield __await(_b.call(iterable_2)); + } + finally { if (e_2) throw e_2.error; } + } + const append = yield __await(provide()); + if (append !== undefined) { + yield yield __await(append); + } + }); + }; +} +/** + * Creates an AsyncIterableTransform that prepends an element. + * + * The element to prepend is provided by a function. If the function returns + * undefined, no element is appended. + * + * @private Internal code, does not follow semantic versioning. + */ +function transformPrepend(provide) { + return function (iterable) { + return __asyncGenerator(this, arguments, function* () { + var _a, e_3, _b, _c; + const prepend = yield __await(provide()); + if (prepend !== undefined) { + yield yield __await(prepend); + } + try { + for (var _d = true, iterable_3 = __asyncValues(iterable), iterable_3_1; iterable_3_1 = yield __await(iterable_3.next()), _a = iterable_3_1.done, !_a; _d = true) { + _c = iterable_3_1.value; + _d = false; + const chunk = _c; + yield yield __await(chunk); + } + } + catch (e_3_1) { e_3 = { error: e_3_1 }; } + finally { + try { + if (!_d && !_a && (_b = iterable_3.return)) yield __await(_b.call(iterable_3)); + } + finally { if (e_3) throw e_3.error; } + } + }); + }; +} +/** + * Creates an AsyncIterableTransform that reads all bytes from the input, and + * concatenates them to a single Uint8Array. + * + * The iterable raises an error if the more than readMaxBytes are read. + * + * An optional length hint can be provided to optimize allocation and validation. + * If more or less bytes are present in the source that the length hint indicates, + * and error is raised. + * If the length hint is larger than readMaxBytes, an error is raised. + * If the length hint is not a positive integer, it is ignored. + * + * @private Internal code, does not follow semantic versioning. + */ +function transformReadAllBytes(readMaxBytes, lengthHint) { + return function (iterable) { + return __asyncGenerator(this, arguments, function* () { + yield yield __await(yield __await(readAllBytes(iterable, readMaxBytes, lengthHint))); + }); + }; +} +function transformSerializeEnvelope(serialization, endStreamFlag, endSerialization) { + if (endStreamFlag === undefined || endSerialization === undefined) { + return function (iterable) { + return __asyncGenerator(this, arguments, function* () { + var _a, e_4, _b, _c; + try { + for (var _d = true, iterable_4 = __asyncValues(iterable), iterable_4_1; iterable_4_1 = yield __await(iterable_4.next()), _a = iterable_4_1.done, !_a; _d = true) { + _c = iterable_4_1.value; + _d = false; + const chunk = _c; + const data = serialization.serialize(chunk); + yield yield __await({ flags: 0, data }); + } + } + catch (e_4_1) { e_4 = { error: e_4_1 }; } + finally { + try { + if (!_d && !_a && (_b = iterable_4.return)) yield __await(_b.call(iterable_4)); + } + finally { if (e_4) throw e_4.error; } + } + }); + }; + } + return function (iterable) { + return __asyncGenerator(this, arguments, function* () { + var _a, e_5, _b, _c; + try { + for (var _d = true, iterable_5 = __asyncValues(iterable), iterable_5_1; iterable_5_1 = yield __await(iterable_5.next()), _a = iterable_5_1.done, !_a; _d = true) { + _c = iterable_5_1.value; + _d = false; + const chunk = _c; + let data; + let flags = 0; + if (chunk.end) { + flags = flags | endStreamFlag; + data = endSerialization.serialize(chunk.value); + } + else { + data = serialization.serialize(chunk.value); + } + yield yield __await({ flags, data }); + } + } + catch (e_5_1) { e_5 = { error: e_5_1 }; } + finally { + try { + if (!_d && !_a && (_b = iterable_5.return)) yield __await(_b.call(iterable_5)); + } + finally { if (e_5) throw e_5.error; } + } + }); + }; +} +function transformParseEnvelope(serialization, endStreamFlag, endSerialization) { + // code path always yields ParsedEnvelopedMessage + if (endSerialization && endStreamFlag !== undefined) { + return function (iterable) { + return __asyncGenerator(this, arguments, function* () { + var _a, e_6, _b, _c; + try { + for (var _d = true, iterable_6 = __asyncValues(iterable), iterable_6_1; iterable_6_1 = yield __await(iterable_6.next()), _a = iterable_6_1.done, !_a; _d = true) { + _c = iterable_6_1.value; + _d = false; + const { flags, data } = _c; + if ((flags & endStreamFlag) === endStreamFlag) { + yield yield __await({ value: endSerialization.parse(data), end: true }); + } + else { + yield yield __await({ value: serialization.parse(data), end: false }); + } + } + } + catch (e_6_1) { e_6 = { error: e_6_1 }; } + finally { + try { + if (!_d && !_a && (_b = iterable_6.return)) yield __await(_b.call(iterable_6)); + } + finally { if (e_6) throw e_6.error; } + } + }); + }; + } + // code path always yields T + return function (iterable) { + return __asyncGenerator(this, arguments, function* () { + var _a, e_7, _b, _c; + try { + for (var _d = true, iterable_7 = __asyncValues(iterable), iterable_7_1; iterable_7_1 = yield __await(iterable_7.next()), _a = iterable_7_1.done, !_a; _d = true) { + _c = iterable_7_1.value; + _d = false; + const { flags, data } = _c; + if (endStreamFlag !== undefined && + (flags & endStreamFlag) === endStreamFlag) { + if (endSerialization === null) { + throw new connect_error_ConnectError("unexpected end flag", code_Code.InvalidArgument); + } + // skips end-of-stream envelope + continue; + } + yield yield __await(serialization.parse(data)); + } + } + catch (e_7_1) { e_7 = { error: e_7_1 }; } + finally { + try { + if (!_d && !_a && (_b = iterable_7.return)) yield __await(_b.call(iterable_7)); + } + finally { if (e_7) throw e_7.error; } + } + }); + }; +} +/** + * Creates an AsyncIterableTransform that takes enveloped messages as a source, + * and compresses them if they are larger than compressMinBytes. + * + * @private Internal code, does not follow semantic versioning. + */ +function transformCompressEnvelope(compression, compressMinBytes) { + return function (iterable) { + return __asyncGenerator(this, arguments, function* () { + var _a, e_8, _b, _c; + try { + for (var _d = true, iterable_8 = __asyncValues(iterable), iterable_8_1; iterable_8_1 = yield __await(iterable_8.next()), _a = iterable_8_1.done, !_a; _d = true) { + _c = iterable_8_1.value; + _d = false; + const env = _c; + yield yield __await(yield __await(envelopeCompress(env, compression, compressMinBytes))); + } + } + catch (e_8_1) { e_8 = { error: e_8_1 }; } + finally { + try { + if (!_d && !_a && (_b = iterable_8.return)) yield __await(_b.call(iterable_8)); + } + finally { if (e_8) throw e_8.error; } + } + }); + }; +} +/** + * Creates an AsyncIterableTransform that takes enveloped messages as a source, + * and decompresses them using the given compression. + * + * The iterable raises an error if the decompressed payload of an enveloped + * message is larger than readMaxBytes, or if no compression is provided. + * + * @private Internal code, does not follow semantic versioning. + */ +function transformDecompressEnvelope(compression, readMaxBytes) { + return function (iterable) { + return __asyncGenerator(this, arguments, function* () { + var _a, e_9, _b, _c; + try { + for (var _d = true, iterable_9 = __asyncValues(iterable), iterable_9_1; iterable_9_1 = yield __await(iterable_9.next()), _a = iterable_9_1.done, !_a; _d = true) { + _c = iterable_9_1.value; + _d = false; + const env = _c; + yield yield __await(yield __await(envelopeDecompress(env, compression, readMaxBytes))); + } + } + catch (e_9_1) { e_9 = { error: e_9_1 }; } + finally { + try { + if (!_d && !_a && (_b = iterable_9.return)) yield __await(_b.call(iterable_9)); + } + finally { if (e_9) throw e_9.error; } + } + }); + }; +} +/** + * Create an AsyncIterableTransform that takes enveloped messages as a source, + * and joins them into a stream of raw bytes. + * + * @private Internal code, does not follow semantic versioning. + */ +function transformJoinEnvelopes() { + return function (iterable) { + return __asyncGenerator(this, arguments, function* () { + var _a, e_10, _b, _c; + try { + for (var _d = true, iterable_10 = __asyncValues(iterable), iterable_10_1; iterable_10_1 = yield __await(iterable_10.next()), _a = iterable_10_1.done, !_a; _d = true) { + _c = iterable_10_1.value; + _d = false; + const { flags, data } = _c; + yield yield __await(encodeEnvelope(flags, data)); + } + } + catch (e_10_1) { e_10 = { error: e_10_1 }; } + finally { + try { + if (!_d && !_a && (_b = iterable_10.return)) yield __await(_b.call(iterable_10)); + } + finally { if (e_10) throw e_10.error; } + } + }); + }; +} +/** + * Create an AsyncIterableTransform that takes raw bytes as a source, and splits + * them into enveloped messages. + * + * The iterable raises an error + * - if the payload of an enveloped message is larger than readMaxBytes, + * - if the stream ended before an enveloped message fully arrived, + * - or if the stream ended with extraneous data. + * + * @private Internal code, does not follow semantic versioning. + */ +function transformSplitEnvelope(readMaxBytes) { + // append chunk to buffer, returning updated buffer + function append(buffer, chunk) { + const n = new Uint8Array(buffer.byteLength + chunk.byteLength); + n.set(buffer); + n.set(chunk, buffer.length); + return n; + } + // tuple 0: envelope, or undefined if incomplete + // tuple 1: remainder of the buffer + function shiftEnvelope(buffer, header) { + if (buffer.byteLength < 5 + header.length) { + return [undefined, buffer]; + } + return [ + { flags: header.flags, data: buffer.subarray(5, 5 + header.length) }, + buffer.subarray(5 + header.length), + ]; + } + // undefined: header is incomplete + function peekHeader(buffer) { + if (buffer.byteLength < 5) { + return undefined; + } + const view = new DataView(buffer.buffer, buffer.byteOffset, buffer.byteLength); + const length = view.getUint32(1); // 4 bytes message length + const flags = view.getUint8(0); // first byte is flags + return { length, flags }; + } + return function (iterable) { + return __asyncGenerator(this, arguments, function* () { + var _a, e_11, _b, _c; + let buffer = new Uint8Array(0); + try { + for (var _d = true, iterable_11 = __asyncValues(iterable), iterable_11_1; iterable_11_1 = yield __await(iterable_11.next()), _a = iterable_11_1.done, !_a; _d = true) { + _c = iterable_11_1.value; + _d = false; + const chunk = _c; + buffer = append(buffer, chunk); + for (;;) { + const header = peekHeader(buffer); + if (!header) { + break; + } + limit_io_assertReadMaxBytes(readMaxBytes, header.length, true); + let env; + [env, buffer] = shiftEnvelope(buffer, header); + if (!env) { + break; + } + yield yield __await(env); + } + } + } + catch (e_11_1) { e_11 = { error: e_11_1 }; } + finally { + try { + if (!_d && !_a && (_b = iterable_11.return)) yield __await(_b.call(iterable_11)); + } + finally { if (e_11) throw e_11.error; } + } + if (buffer.byteLength > 0) { + const header = peekHeader(buffer); + let message = "protocol error: incomplete envelope"; + if (header) { + message = `protocol error: promised ${header.length} bytes in enveloped message, got ${buffer.byteLength - 5} bytes`; + } + throw new connect_error_ConnectError(message, code_Code.InvalidArgument); + } + }); + }; +} +/** + * Reads all bytes from the source, and concatenates them to a single Uint8Array. + * + * Raises an error if: + * - more than readMaxBytes are read + * - lengthHint is a positive integer, but larger than readMaxBytes + * - lengthHint is a positive integer, and the source contains more or less bytes + * than promised + * + * @private Internal code, does not follow semantic versioning. + */ +async function readAllBytes(iterable, readMaxBytes, lengthHint) { + var _a, e_12, _b, _c, _d, e_13, _e, _f; + const [ok, hint] = parseLengthHint(lengthHint); + if (ok) { + if (hint > readMaxBytes) { + assertReadMaxBytes(readMaxBytes, hint, true); + } + const buffer = new Uint8Array(hint); + let offset = 0; + try { + for (var _g = true, iterable_12 = __asyncValues(iterable), iterable_12_1; iterable_12_1 = await iterable_12.next(), _a = iterable_12_1.done, !_a; _g = true) { + _c = iterable_12_1.value; + _g = false; + const chunk = _c; + if (offset + chunk.byteLength > hint) { + throw new ConnectError(`protocol error: promised ${hint} bytes, received ${offset + chunk.byteLength}`, Code.InvalidArgument); + } + buffer.set(chunk, offset); + offset += chunk.byteLength; + } + } + catch (e_12_1) { e_12 = { error: e_12_1 }; } + finally { + try { + if (!_g && !_a && (_b = iterable_12.return)) await _b.call(iterable_12); + } + finally { if (e_12) throw e_12.error; } + } + if (offset < hint) { + throw new ConnectError(`protocol error: promised ${hint} bytes, received ${offset}`, Code.InvalidArgument); + } + return buffer; + } + const chunks = []; + let count = 0; + try { + for (var _h = true, iterable_13 = __asyncValues(iterable), iterable_13_1; iterable_13_1 = await iterable_13.next(), _d = iterable_13_1.done, !_d; _h = true) { + _f = iterable_13_1.value; + _h = false; + const chunk = _f; + count += chunk.byteLength; + assertReadMaxBytes(readMaxBytes, count); + chunks.push(chunk); + } + } + catch (e_13_1) { e_13 = { error: e_13_1 }; } + finally { + try { + if (!_h && !_d && (_e = iterable_13.return)) await _e.call(iterable_13); + } + finally { if (e_13) throw e_13.error; } + } + const all = new Uint8Array(count); + let offset = 0; + for (let chunk = chunks.shift(); chunk; chunk = chunks.shift()) { + all.set(chunk, offset); + offset += chunk.byteLength; + } + return all; +} +// parse the lengthHint argument of readAllBytes() +function parseLengthHint(lengthHint) { + if (lengthHint === undefined || lengthHint === null) { + return [false, 0]; + } + const n = typeof lengthHint == "string" ? parseInt(lengthHint, 10) : lengthHint; + if (!Number.isSafeInteger(n) || n < 0) { + return [false, n]; + } + return [true, n]; +} +/** + * Wait for the first element of an iterable without modifying the iterable. + * This consumes the first element, but pushes it back on the stack. + * + * @private Internal code, does not follow semantic versioning. + */ +async function untilFirst(iterable) { + const it = iterable[Symbol.asyncIterator](); + let first = await it.next(); + return { + [Symbol.asyncIterator]() { + const w = { + async next() { + if (first !== null) { + const n = first; + first = null; + return n; + } + return await it.next(); + }, + }; + if (it.throw !== undefined) { + // eslint-disable-next-line @typescript-eslint/no-non-null-assertion -- can't handle mutated object sensibly + w.throw = (e) => it.throw(e); + } + if (it.return !== undefined) { + // eslint-disable-next-line @typescript-eslint/no-non-null-assertion,@typescript-eslint/no-explicit-any -- can't handle mutated object sensibly + w.return = (value) => it.return(value); + } + return w; + }, + }; +} +/** + * Wrap the given iterable and return an iterable with an abort() method. + * + * This function exists purely for convenience. Where one would typically have + * to access the iterator directly, advance through all elements, and call + * AsyncIterator.throw() to notify the upstream iterable, this function allows + * to use convenient for-await loops and still notify the upstream iterable: + * + * ```ts + * const abortable = makeIterableAbortable(iterable); + * for await (const ele of abortable) { + * await abortable.abort("ERR"); + * } + * ``` + * There are a couple of limitations of this function: + * - the given async iterable must implement throw + * - the async iterable cannot be re-use + * - if source catches errors and yields values for them, they are ignored, and + * the source may still dangle + * + * There are four possible ways an async function* can handle yield errors: + * 1. don't catch errors at all - Abortable.abort() will resolve "rethrown" + * 2. catch errors and rethrow - Abortable.abort() will resolve "rethrown" + * 3. catch errors and return - Abortable.abort() will resolve "completed" + * 4. catch errors and yield a value - Abortable.abort() will resolve "caught" + * + * Note that catching errors and yielding a value is problematic, and it should + * be documented that this may leave the source in a dangling state. + * + * @private Internal code, does not follow semantic versioning. + */ +function makeIterableAbortable(iterable) { + const innerCandidate = iterable[Symbol.asyncIterator](); + if (innerCandidate.throw === undefined) { + throw new Error("AsyncIterable does not implement throw"); + } + const inner = innerCandidate; + let aborted; + let resultPromise; + let it = { + next() { + resultPromise = inner.next().finally(() => { + resultPromise = undefined; + }); + return resultPromise; + }, + throw(e) { + return inner.throw(e); + }, + }; + if (innerCandidate.return !== undefined) { + it = Object.assign(Object.assign({}, it), { return(value) { + return inner.return(value); + } }); + } + let used = false; + return { + abort(reason) { + if (aborted) { + return aborted.state; + } + const f = () => { + return inner.throw(reason).then((r) => (r.done === true ? "completed" : "caught"), () => "rethrown"); + }; + if (resultPromise) { + aborted = { reason, state: resultPromise.then(f, f) }; + return aborted.state; + } + aborted = { reason, state: f() }; + return aborted.state; + }, + [Symbol.asyncIterator]() { + if (used) { + throw new Error("AsyncIterable cannot be re-used"); + } + used = true; + return it; + }, + }; +} +/** + * Create a new WritableIterable. + */ +function createWritableIterable() { + // We start with two queues to capture the read and write attempts. + // + // The writes and reads each check of their counterpart is + // already available and either interact/add themselves to the queue. + const readQueue = []; + const writeQueue = []; + let err = undefined; + let nextResolve; + let nextReject; + let nextPromise = new Promise((resolve, reject) => { + nextResolve = resolve; + nextReject = reject; + }); + let closed = false; + // drain the readQueue in case of error/writer is closed by sending a + // done result. + function drain() { + for (const next of readQueue.splice(0, readQueue.length)) { + next({ done: true, value: undefined }); + } + } + return { + close() { + closed = true; + drain(); + }, + async write(payload) { + if (closed) { + throw err !== null && err !== void 0 ? err : new Error("cannot write, WritableIterable already closed"); + } + const read = readQueue.shift(); + if (read === undefined) { + // We didn't find a pending read so we add the payload to the write queue. + writeQueue.push(payload); + } + else { + // We found a pending read so we respond with the payload. + read({ done: false, value: payload }); + if (readQueue.length > 0) { + // If there are more in the read queue we can mark the write as complete. + // as the error reporting is not guaranteed to be sequential and therefore cannot + // to linked to a specific write. + return; + } + } + // We await the next call for as many times as there are items in the queue + 1 + // + // If there are no items in the write queue that means write happened and we just have + // to wait for one more call likewise if we are the nth write in the queue we + // have to wait for n writes to complete and one more. + const limit = writeQueue.length + 1; + for (let i = 0; i < limit; i++) { + await nextPromise; + } + }, + [Symbol.asyncIterator]() { + return { + next() { + // Resolve the nextPromise to indicate + // pending writes that a read attempt has been made + // after their write. + // + // We also need to reset the promise for future writes. + nextResolve(); + nextPromise = new Promise((resolve, reject) => { + nextResolve = resolve; + nextReject = reject; + }); + const write = writeQueue.shift(); + if (write !== undefined) { + // We found a pending write so response with the payload. + return Promise.resolve({ done: false, value: write }); + } + if (closed) { + return Promise.resolve({ done: true, value: undefined }); + } + // We return a promise immediately that is either resolved/rejected + // as writes happen. + let readResolve; + const readPromise = new Promise((resolve) => (readResolve = resolve)); + readQueue.push(readResolve); // eslint-disable-line @typescript-eslint/no-non-null-assertion + return readPromise; + }, + throw(throwErr) { + err = throwErr; + closed = true; + writeQueue.splice(0, writeQueue.length); + nextPromise.catch(() => { + // To make sure that the nextPromise is always resolved. + }); + // This will reject all pending writes. + nextReject(err); + drain(); + return Promise.resolve({ done: true, value: undefined }); + }, + return() { + closed = true; + writeQueue.splice(0, writeQueue.length); + // Resolve once for the write awaiting confirmation. + nextResolve(); + // Reject all future writes. + nextPromise = Promise.reject(new Error("cannot write, consumer called return")); + nextPromise.catch(() => { + // To make sure that the nextPromise is always resolved. + }); + drain(); + return Promise.resolve({ done: true, value: undefined }); + }, + }; + }, + }; +} +/** + * Create an asynchronous iterable from an array. + * + * @private Internal code, does not follow semantic versioning. + */ +// eslint-disable-next-line @typescript-eslint/require-await +function createAsyncIterable(items) { + return __asyncGenerator(this, arguments, function* createAsyncIterable_1() { + yield __await(yield* __asyncDelegator(__asyncValues(items))); + }); +} + +;// CONCATENATED MODULE: ./node_modules/@connectrpc/connect/dist/esm/promise-client.js +// Copyright 2021-2024 The Connect Authors +// +// Licensed under the Apache License, Version 2.0 (the "License"); +// you may not use this file except in compliance with the License. +// You may obtain a copy of the License at +// +// http://www.apache.org/licenses/LICENSE-2.0 +// +// Unless required by applicable law or agreed to in writing, software +// distributed under the License is distributed on an "AS IS" BASIS, +// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. +// See the License for the specific language governing permissions and +// limitations under the License. +var promise_client_asyncValues = (undefined && undefined.__asyncValues) || function (o) { + if (!Symbol.asyncIterator) throw new TypeError("Symbol.asyncIterator is not defined."); + var m = o[Symbol.asyncIterator], i; + return m ? m.call(o) : (o = typeof __values === "function" ? __values(o) : o[Symbol.iterator](), i = {}, verb("next"), verb("throw"), verb("return"), i[Symbol.asyncIterator] = function () { return this; }, i); + function verb(n) { i[n] = o[n] && function (v) { return new Promise(function (resolve, reject) { v = o[n](v), settle(resolve, reject, v.done, v.value); }); }; } + function settle(resolve, reject, d, v) { Promise.resolve(v).then(function(v) { resolve({ value: v, done: d }); }, reject); } +}; +var promise_client_await = (undefined && undefined.__await) || function (v) { return this instanceof promise_client_await ? (this.v = v, this) : new promise_client_await(v); } +var promise_client_asyncDelegator = (undefined && undefined.__asyncDelegator) || function (o) { + var i, p; + return i = {}, verb("next"), verb("throw", function (e) { throw e; }), verb("return"), i[Symbol.iterator] = function () { return this; }, i; + function verb(n, f) { i[n] = o[n] ? function (v) { return (p = !p) ? { value: promise_client_await(o[n](v)), done: false } : f ? f(v) : v; } : f; } +}; +var promise_client_asyncGenerator = (undefined && undefined.__asyncGenerator) || function (thisArg, _arguments, generator) { + if (!Symbol.asyncIterator) throw new TypeError("Symbol.asyncIterator is not defined."); + var g = generator.apply(thisArg, _arguments || []), i, q = []; + return i = {}, verb("next"), verb("throw"), verb("return", awaitReturn), i[Symbol.asyncIterator] = function () { return this; }, i; + function awaitReturn(f) { return function (v) { return Promise.resolve(v).then(f, reject); }; } + function verb(n, f) { if (g[n]) { i[n] = function (v) { return new Promise(function (a, b) { q.push([n, v, a, b]) > 1 || resume(n, v); }); }; if (f) i[n] = f(i[n]); } } + function resume(n, v) { try { step(g[n](v)); } catch (e) { settle(q[0][3], e); } } + function step(r) { r.value instanceof promise_client_await ? Promise.resolve(r.value.v).then(fulfill, reject) : settle(q[0][2], r); } + function fulfill(value) { resume("next", value); } + function reject(value) { resume("throw", value); } + function settle(f, v) { if (f(v), q.shift(), q.length) resume(q[0][0], q[0][1]); } +}; + + + + + +/** + * Create a Client for the given service, invoking RPCs through the + * given transport. + */ +function createClient(service, transport) { + return makeAnyClient(service, (method) => { + switch (method.kind) { + case MethodKind.Unary: + return createUnaryFn(transport, service, method); + case MethodKind.ServerStreaming: + return createServerStreamingFn(transport, service, method); + case MethodKind.ClientStreaming: + return createClientStreamingFn(transport, service, method); + case MethodKind.BiDiStreaming: + return createBiDiStreamingFn(transport, service, method); + default: + return null; + } + }); +} +/** + * @deprecated use createClient. + */ +function createPromiseClient(service, transport) { + return createClient(service, transport); +} +function createUnaryFn(transport, service, method) { + return async function (input, options) { + var _a, _b; + const response = await transport.unary(service, method, options === null || options === void 0 ? void 0 : options.signal, options === null || options === void 0 ? void 0 : options.timeoutMs, options === null || options === void 0 ? void 0 : options.headers, input, options === null || options === void 0 ? void 0 : options.contextValues); + (_a = options === null || options === void 0 ? void 0 : options.onHeader) === null || _a === void 0 ? void 0 : _a.call(options, response.header); + (_b = options === null || options === void 0 ? void 0 : options.onTrailer) === null || _b === void 0 ? void 0 : _b.call(options, response.trailer); + return response.message; + }; +} +function createServerStreamingFn(transport, service, method) { + return function (input, options) { + return handleStreamResponse(transport.stream(service, method, options === null || options === void 0 ? void 0 : options.signal, options === null || options === void 0 ? void 0 : options.timeoutMs, options === null || options === void 0 ? void 0 : options.headers, createAsyncIterable([input]), options === null || options === void 0 ? void 0 : options.contextValues), options); + }; +} +function createClientStreamingFn(transport, service, method) { + return async function (request, options) { + var _a, e_1, _b, _c; + var _d, _e; + const response = await transport.stream(service, method, options === null || options === void 0 ? void 0 : options.signal, options === null || options === void 0 ? void 0 : options.timeoutMs, options === null || options === void 0 ? void 0 : options.headers, request, options === null || options === void 0 ? void 0 : options.contextValues); + (_d = options === null || options === void 0 ? void 0 : options.onHeader) === null || _d === void 0 ? void 0 : _d.call(options, response.header); + let singleMessage; + let count = 0; + try { + for (var _f = true, _g = promise_client_asyncValues(response.message), _h; _h = await _g.next(), _a = _h.done, !_a; _f = true) { + _c = _h.value; + _f = false; + const message = _c; + singleMessage = message; + count++; + } + } + catch (e_1_1) { e_1 = { error: e_1_1 }; } + finally { + try { + if (!_f && !_a && (_b = _g.return)) await _b.call(_g); + } + finally { if (e_1) throw e_1.error; } + } + if (!singleMessage) { + throw new connect_error_ConnectError("protocol error: missing response message", code_Code.Unimplemented); + } + if (count > 1) { + throw new connect_error_ConnectError("protocol error: received extra messages for client streaming method", code_Code.Unimplemented); + } + (_e = options === null || options === void 0 ? void 0 : options.onTrailer) === null || _e === void 0 ? void 0 : _e.call(options, response.trailer); + return singleMessage; + }; +} +function createBiDiStreamingFn(transport, service, method) { + return function (request, options) { + return handleStreamResponse(transport.stream(service, method, options === null || options === void 0 ? void 0 : options.signal, options === null || options === void 0 ? void 0 : options.timeoutMs, options === null || options === void 0 ? void 0 : options.headers, request, options === null || options === void 0 ? void 0 : options.contextValues), options); + }; +} +function handleStreamResponse(stream, options) { + const it = (function () { + return promise_client_asyncGenerator(this, arguments, function* () { + var _a, _b; + const response = yield promise_client_await(stream); + (_a = options === null || options === void 0 ? void 0 : options.onHeader) === null || _a === void 0 ? void 0 : _a.call(options, response.header); + yield promise_client_await(yield* promise_client_asyncDelegator(promise_client_asyncValues(response.message))); + (_b = options === null || options === void 0 ? void 0 : options.onTrailer) === null || _b === void 0 ? void 0 : _b.call(options, response.trailer); + }); + })()[Symbol.asyncIterator](); + // Create a new iterable to omit throw/return. + return { + [Symbol.asyncIterator]: () => ({ + next: () => it.next(), + }), + }; +} + +// EXTERNAL MODULE: ./node_modules/undici/index.js +var undici = __nccwpck_require__(6752); +;// CONCATENATED MODULE: ./node_modules/@connectrpc/connect-node/dist/esm/node-headers-polyfill.js +// Copyright 2021-2024 The Connect Authors +// +// Licensed under the Apache License, Version 2.0 (the "License"); +// you may not use this file except in compliance with the License. +// You may obtain a copy of the License at +// +// http://www.apache.org/licenses/LICENSE-2.0 +// +// Unless required by applicable law or agreed to in writing, software +// distributed under the License is distributed on an "AS IS" BASIS, +// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. +// See the License for the specific language governing permissions and +// limitations under the License. + +// The global Headers class was introduced in Node v16.15.0, behind the +// --experimental-fetch flag. It became available by default with Node +// v18.0.0. +// If this code runs in Node < 18, it installs an alternative +// implementation if one has not already been polyfilled. +const [major] = process.versions.node + .split(".") + .map((value) => parseInt(value, 10)); +if (major < 18) { + if (typeof globalThis.Headers === "undefined") { + globalThis.Headers = undici.Headers; + } +} + +// EXTERNAL MODULE: external "zlib" +var external_zlib_ = __nccwpck_require__(3106); +;// CONCATENATED MODULE: ./node_modules/@connectrpc/connect-node/dist/esm/node-error.js +// Copyright 2021-2024 The Connect Authors +// +// Licensed under the Apache License, Version 2.0 (the "License"); +// you may not use this file except in compliance with the License. +// You may obtain a copy of the License at +// +// http://www.apache.org/licenses/LICENSE-2.0 +// +// Unless required by applicable law or agreed to in writing, software +// distributed under the License is distributed on an "AS IS" BASIS, +// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. +// See the License for the specific language governing permissions and +// limitations under the License. + +/** + * Similar to ConnectError.from(), this function turns any value into + * a ConnectError, but special cases some Node.js specific error codes and + * sets an appropriate Connect error code. + */ +function node_error_connectErrorFromNodeReason(reason) { + let code = code_Code.Internal; + const chain = unwrapNodeErrorChain(reason).map(getNodeErrorProps); + if (chain.some((p) => p.code == "ERR_STREAM_WRITE_AFTER_END")) { + // We do not want intentional errors from the server to be shadowed + // by client-side errors. + // This can occur if the server has written a response with an error + // and has ended the connection. This response may already sit in a + // buffer on the client, while it is still writing to the request + // body. + // To avoid this problem, we wrap ERR_STREAM_WRITE_AFTER_END as a + // ConnectError with Code.Aborted. The special meaning of this code + // in this situation is documented in StreamingConn.send() and in + // createServerStreamingFn(). + code = code_Code.Aborted; + } + else if (chain.some((p) => p.code == "ERR_STREAM_DESTROYED" || + p.code == "ERR_HTTP2_INVALID_STREAM" || + p.code == "ECONNRESET")) { + // A handler whose stream is suddenly destroyed usually means the client + // hung up. This behavior is triggered by the conformance test "cancel_after_begin". + code = code_Code.Aborted; + } + else if (chain.some((p) => p.code == "ETIMEDOUT" || + p.code == "ENOTFOUND" || + p.code == "EAI_AGAIN" || + p.code == "ECONNREFUSED")) { + // Calling an unresolvable host should raise a ConnectError with + // Code.Aborted. + // This behavior is covered by the conformance test "unresolvable_host". + code = code_Code.Unavailable; + } + const ce = connect_error_ConnectError.from(reason, code); + if (ce !== reason) { + ce.cause = reason; + } + return ce; +} +/** + * Unwraps a chain of errors, by walking through all "cause" properties + * recursively. + * This function is useful to find the root cause of an error. + */ +function unwrapNodeErrorChain(reason) { + const chain = []; + for (;;) { + if (!(reason instanceof Error)) { + break; + } + if (chain.includes(reason)) { + // safeguard against infinite loop when "cause" points to an ancestor + break; + } + chain.push(reason); + if (!("cause" in reason)) { + break; + } + reason = reason.cause; + } + return chain; +} +/** + * Returns standard Node.js error properties from the given reason, if present. + * + * For context: Every error raised by Node.js APIs should expose a `code` + * property - a string that permanently identifies the error. Some errors may + * have an additional `syscall` property - a string that identifies native + * components, for example "getaddrinfo" of libuv. + * For more information, see https://github.com/nodejs/node/blob/f6052c68c1f9a4400a723e9c0b79da14197ab754/lib/internal/errors.js + */ +function getNodeErrorProps(reason) { + const props = {}; + if (reason instanceof Error) { + if ("code" in reason && typeof reason.code == "string") { + props.code = reason.code; + } + if ("syscall" in reason && typeof reason.syscall == "string") { + props.syscall = reason.syscall; + } + } + return props; +} +/** + * Returns a ConnectError for an HTTP/2 error code. + */ +function node_error_connectErrorFromH2ResetCode(rstCode) { + switch (rstCode) { + case H2Code.PROTOCOL_ERROR: + case H2Code.INTERNAL_ERROR: + case H2Code.FLOW_CONTROL_ERROR: + case H2Code.SETTINGS_TIMEOUT: + case H2Code.FRAME_SIZE_ERROR: + case H2Code.COMPRESSION_ERROR: + case H2Code.CONNECT_ERROR: + return new connect_error_ConnectError(`http/2 stream closed with error code ${H2Code[rstCode]} (0x${rstCode.toString(16)})`, code_Code.Internal); + case H2Code.REFUSED_STREAM: + return new connect_error_ConnectError(`http/2 stream closed with error code ${H2Code[rstCode]} (0x${rstCode.toString(16)})`, code_Code.Unavailable); + case H2Code.CANCEL: + return new connect_error_ConnectError(`http/2 stream closed with error code ${H2Code[rstCode]} (0x${rstCode.toString(16)})`, code_Code.Canceled); + case H2Code.ENHANCE_YOUR_CALM: + return new connect_error_ConnectError(`http/2 stream closed with error code ${H2Code[rstCode]} (0x${rstCode.toString(16)})`, code_Code.ResourceExhausted); + case H2Code.INADEQUATE_SECURITY: + return new connect_error_ConnectError(`http/2 stream closed with error code ${H2Code[rstCode]} (0x${rstCode.toString(16)})`, code_Code.PermissionDenied); + case H2Code.HTTP_1_1_REQUIRED: + return new connect_error_ConnectError(`http/2 stream closed with error code ${H2Code[rstCode]} (0x${rstCode.toString(16)})`, code_Code.PermissionDenied); + case H2Code.STREAM_CLOSED: + default: + // Intentionally not mapping STREAM_CLOSED (0x5), see https://github.com/grpc/grpc/blob/master/doc/PROTOCOL-HTTP2.md#errors + break; + } + return undefined; +} +var H2Code; +(function (H2Code) { + H2Code[H2Code["PROTOCOL_ERROR"] = 1] = "PROTOCOL_ERROR"; + H2Code[H2Code["INTERNAL_ERROR"] = 2] = "INTERNAL_ERROR"; + H2Code[H2Code["FLOW_CONTROL_ERROR"] = 3] = "FLOW_CONTROL_ERROR"; + H2Code[H2Code["SETTINGS_TIMEOUT"] = 4] = "SETTINGS_TIMEOUT"; + H2Code[H2Code["STREAM_CLOSED"] = 5] = "STREAM_CLOSED"; + H2Code[H2Code["FRAME_SIZE_ERROR"] = 6] = "FRAME_SIZE_ERROR"; + H2Code[H2Code["REFUSED_STREAM"] = 7] = "REFUSED_STREAM"; + H2Code[H2Code["CANCEL"] = 8] = "CANCEL"; + H2Code[H2Code["COMPRESSION_ERROR"] = 9] = "COMPRESSION_ERROR"; + H2Code[H2Code["CONNECT_ERROR"] = 10] = "CONNECT_ERROR"; + H2Code[H2Code["ENHANCE_YOUR_CALM"] = 11] = "ENHANCE_YOUR_CALM"; + H2Code[H2Code["INADEQUATE_SECURITY"] = 12] = "INADEQUATE_SECURITY"; + H2Code[H2Code["HTTP_1_1_REQUIRED"] = 13] = "HTTP_1_1_REQUIRED"; +})(H2Code || (H2Code = {})); + +;// CONCATENATED MODULE: ./node_modules/@connectrpc/connect-node/dist/esm/compression.js +// Copyright 2021-2024 The Connect Authors +// +// Licensed under the Apache License, Version 2.0 (the "License"); +// you may not use this file except in compliance with the License. +// You may obtain a copy of the License at +// +// http://www.apache.org/licenses/LICENSE-2.0 +// +// Unless required by applicable law or agreed to in writing, software +// distributed under the License is distributed on an "AS IS" BASIS, +// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. +// See the License for the specific language governing permissions and +// limitations under the License. + + + + +const gzip = (0,external_util_.promisify)(external_zlib_.gzip); +const gunzip = (0,external_util_.promisify)(external_zlib_.gunzip); +const brotliCompress = (0,external_util_.promisify)(external_zlib_.brotliCompress); +const brotliDecompress = (0,external_util_.promisify)(external_zlib_.brotliDecompress); +/** + * The gzip compression algorithm, implemented with the Node.js built-in module + * zlib. This value can be used for the `sendCompression` and `acceptCompression` + * option of client transports, or for the `acceptCompression` option of server + * plugins like `fastifyConnectPlugin` from @connectrpc/connect-fastify. + */ +const compression_compressionGzip = { + name: "gzip", + compress(bytes) { + return gzip(bytes, {}); + }, + decompress(bytes, readMaxBytes) { + if (bytes.length == 0) { + return Promise.resolve(new Uint8Array(0)); + } + return wrapZLibErrors(gunzip(bytes, { + maxOutputLength: readMaxBytes, + }), readMaxBytes); + }, +}; +/** + * The brotli compression algorithm, implemented with the Node.js built-in module + * zlib. This value can be used for the `sendCompression` and `acceptCompression` + * option of client transports, or for the `acceptCompression` option of server + * plugins like `fastifyConnectPlugin` from @connectrpc/connect-fastify. + */ +const compression_compressionBrotli = { + name: "br", + compress(bytes) { + return brotliCompress(bytes, {}); + }, + decompress(bytes, readMaxBytes) { + if (bytes.length == 0) { + return Promise.resolve(new Uint8Array(0)); + } + return wrapZLibErrors(brotliDecompress(bytes, { + maxOutputLength: readMaxBytes, + }), readMaxBytes); + }, +}; +function wrapZLibErrors(promise, readMaxBytes) { + return promise.catch((e) => { + const props = getNodeErrorProps(e); + let code = code_Code.Internal; + let message = "decompression failed"; + // eslint-disable-next-line @typescript-eslint/switch-exhaustiveness-check + switch (props.code) { + case "ERR_BUFFER_TOO_LARGE": + code = code_Code.ResourceExhausted; + message = `message is larger than configured readMaxBytes ${readMaxBytes} after decompression`; + break; + case "Z_DATA_ERROR": + case "ERR_PADDING_2": + code = code_Code.InvalidArgument; + break; + default: + if (props.code !== undefined && + props.code.startsWith("ERR__ERROR_FORMAT_")) { + code = code_Code.InvalidArgument; + } + break; + } + return Promise.reject(new connect_error_ConnectError(message, code, undefined, undefined, e)); + }); +} + +// EXTERNAL MODULE: external "http2" +var external_http2_ = __nccwpck_require__(5675); +// EXTERNAL MODULE: external "http" +var external_http_ = __nccwpck_require__(8611); +// EXTERNAL MODULE: external "https" +var external_https_ = __nccwpck_require__(5692); +;// CONCATENATED MODULE: ./node_modules/@connectrpc/connect-node/dist/esm/node-universal-header.js +// Copyright 2021-2024 The Connect Authors +// +// Licensed under the Apache License, Version 2.0 (the "License"); +// you may not use this file except in compliance with the License. +// You may obtain a copy of the License at +// +// http://www.apache.org/licenses/LICENSE-2.0 +// +// Unless required by applicable law or agreed to in writing, software +// distributed under the License is distributed on an "AS IS" BASIS, +// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. +// See the License for the specific language governing permissions and +// limitations under the License. +/** + * Convert a Node.js header object to a fetch API Headers object. + * + * This function works for Node.js incoming and outgoing headers, and for the + * http and the http2 package. + * + * HTTP/2 pseudo-headers (:method, :path, etc.) are stripped. + */ +function node_universal_header_nodeHeaderToWebHeader(nodeHeaders) { + const header = new Headers(); + for (const [k, v] of Object.entries(nodeHeaders)) { + if (k.startsWith(":")) { + continue; + } + if (v === undefined) { + continue; + } + if (typeof v == "string") { + header.append(k, v); + } + else if (typeof v == "number") { + header.append(k, String(v)); + } + else { + for (const e of v) { + header.append(k, e); + } + } + } + return header; +} +function node_universal_header_webHeaderToNodeHeaders(headersInit, defaultNodeHeaders) { + if (headersInit === undefined && defaultNodeHeaders === undefined) { + return undefined; + } + const o = Object.create(null); + if (defaultNodeHeaders !== undefined) { + for (const [key, value] of Object.entries(defaultNodeHeaders)) { + if (Array.isArray(value)) { + o[key] = value.concat(); + } + else if (value !== undefined) { + o[key] = value; + } + } + } + if (headersInit !== undefined) { + if (Array.isArray(headersInit)) { + for (const [key, value] of headersInit) { + appendWebHeader(o, key, value); + } + } + else if ("forEach" in headersInit) { + if (typeof headersInit.forEach == "function") { + headersInit.forEach((value, key) => { + appendWebHeader(o, key, value); + }); + } + } + else { + for (const [key, value] of Object.entries(headersInit)) { + appendWebHeader(o, key, value); + } + } + } + return o; +} +function appendWebHeader(o, key, value) { + key = key.toLowerCase(); + const existing = o[key]; + if (Array.isArray(existing)) { + existing.push(value); + } + else if (existing === undefined) { + o[key] = value; + } + else { + o[key] = [existing.toString(), value]; + } +} + +;// CONCATENATED MODULE: ./node_modules/@connectrpc/connect/dist/esm/protocol/signals.js +// Copyright 2021-2024 The Connect Authors +// +// Licensed under the Apache License, Version 2.0 (the "License"); +// you may not use this file except in compliance with the License. +// You may obtain a copy of the License at +// +// http://www.apache.org/licenses/LICENSE-2.0 +// +// Unless required by applicable law or agreed to in writing, software +// distributed under the License is distributed on an "AS IS" BASIS, +// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. +// See the License for the specific language governing permissions and +// limitations under the License. + + +/** + * Create an AbortController that is automatically aborted if one of the given + * signals is aborted. + * + * For convenience, the linked AbortSignals can be undefined. + * + * If the controller or any of the signals is aborted, all event listeners are + * removed. + * + * @private Internal code, does not follow semantic versioning. + */ +function createLinkedAbortController(...signals) { + const controller = new AbortController(); + const sa = signals.filter((s) => s !== undefined).concat(controller.signal); + for (const signal of sa) { + if (signal.aborted) { + onAbort.apply(signal); + break; + } + signal.addEventListener("abort", onAbort); + } + function onAbort() { + if (!controller.signal.aborted) { + controller.abort(getAbortSignalReason(this)); + } + for (const signal of sa) { + signal.removeEventListener("abort", onAbort); + } + } + return controller; +} +/** + * Create a deadline signal. The returned object contains an AbortSignal, but + * also a cleanup function to stop the timer, which must be called once the + * calling code is no longer interested in the signal. + * + * Ideally, we would simply use AbortSignal.timeout(), but it is not widely + * available yet. + * + * @private Internal code, does not follow semantic versioning. + */ +function createDeadlineSignal(timeoutMs) { + const controller = new AbortController(); + const listener = () => { + controller.abort(new connect_error_ConnectError("the operation timed out", code_Code.DeadlineExceeded)); + }; + let timeoutId; + if (timeoutMs !== undefined) { + if (timeoutMs <= 0) + listener(); + else + timeoutId = setTimeout(listener, timeoutMs); + } + return { + signal: controller.signal, + cleanup: () => clearTimeout(timeoutId), + }; +} +/** + * Returns the reason why an AbortSignal was aborted. Returns undefined if the + * signal has not been aborted. + * + * The property AbortSignal.reason is not widely available. This function + * returns an AbortError if the signal is aborted, but reason is undefined. + * + * @private Internal code, does not follow semantic versioning. + */ +function getAbortSignalReason(signal) { + if (!signal.aborted) { + return undefined; + } + if (signal.reason !== undefined) { + return signal.reason; + } + // AbortSignal.reason is available in Node.js v16, v18, and later, + // and in all browsers since early 2022. + const e = new Error("This operation was aborted"); + e.name = "AbortError"; + return e; +} + +;// CONCATENATED MODULE: ./node_modules/@connectrpc/connect-node/dist/esm/http2-session-manager.js +// Copyright 2021-2024 The Connect Authors +// +// Licensed under the Apache License, Version 2.0 (the "License"); +// you may not use this file except in compliance with the License. +// You may obtain a copy of the License at +// +// http://www.apache.org/licenses/LICENSE-2.0 +// +// Unless required by applicable law or agreed to in writing, software +// distributed under the License is distributed on an "AS IS" BASIS, +// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. +// See the License for the specific language governing permissions and +// limitations under the License. + + + +/** + * Manage an HTTP/2 connection and keep it alive with PING frames. + * + * The logic is based on "Basic Keepalive" described in + * https://github.com/grpc/proposal/blob/0ba0c1905050525f9b0aee46f3f23c8e1e515489/A8-client-side-keepalive.md#basic-keepalive + * as well as the client channel arguments described in + * https://github.com/grpc/grpc/blob/8e137e524a1b1da7bbf4603662876d5719563b57/doc/keepalive.md + * + * Usually, the managers tracks exactly one connection, but if a connection + * receives a GOAWAY frame with NO_ERROR, the connection is maintained until + * all streams have finished, and new requests will open a new connection. + */ +class Http2SessionManager { + /** + * The current state of the connection: + * + * - "closed" + * The connection is closed, or no connection has been opened yet. + * - connecting + * Currently establishing a connection. + * + * - "open" + * A connection is open and has open streams. PING frames are sent every + * pingIntervalMs, unless a stream received data. + * If a PING frame is not responded to within pingTimeoutMs, the connection + * and all open streams close. + * + * - "idle" + * A connection is open, but it does not have any open streams. + * If pingIdleConnection is enabled, PING frames are used to keep the + * connection alive, similar to an "open" connection. + * If a connection is idle for longer than idleConnectionTimeoutMs, it closes. + * If a request is made on an idle connection that has not been used for + * longer than pingIntervalMs, the connection is verified. + * + * - "verifying" + * Verifying a connection after a long period of inactivity before issuing a + * request. A PING frame is sent, and if it times out within pingTimeoutMs, a + * new connection is opened. + * + * - "error" + * The connection is closed because of a transient error. A connection + * may have failed to reach the host, or the connection may have died, + * or it may have been aborted. + */ + state() { + if (this.s.t == "ready") { + if (this.verifying !== undefined) { + return "verifying"; + } + return this.s.streamCount() > 0 ? "open" : "idle"; + } + return this.s.t; + } + /** + * Returns the error object if the connection is in the "error" state, + * `undefined` otherwise. + */ + error() { + if (this.s.t == "error") { + return this.s.reason; + } + return undefined; + } + constructor(url, pingOptions, http2SessionOptions) { + var _a, _b, _c, _d; + this.s = http2_session_manager_closed(); + this.shuttingDown = []; + this.authority = new URL(url).origin; + this.http2SessionOptions = http2SessionOptions; + this.options = { + pingIntervalMs: (_a = pingOptions === null || pingOptions === void 0 ? void 0 : pingOptions.pingIntervalMs) !== null && _a !== void 0 ? _a : Number.POSITIVE_INFINITY, + pingTimeoutMs: (_b = pingOptions === null || pingOptions === void 0 ? void 0 : pingOptions.pingTimeoutMs) !== null && _b !== void 0 ? _b : 1000 * 15, + pingIdleConnection: (_c = pingOptions === null || pingOptions === void 0 ? void 0 : pingOptions.pingIdleConnection) !== null && _c !== void 0 ? _c : false, + idleConnectionTimeoutMs: (_d = pingOptions === null || pingOptions === void 0 ? void 0 : pingOptions.idleConnectionTimeoutMs) !== null && _d !== void 0 ? _d : 1000 * 60 * 15, + }; + } + /** + * Open a connection if none exists, verify an existing connection if + * necessary. + */ + async connect() { + try { + const ready = await this.gotoReady(); + return ready.streamCount() > 0 ? "open" : "idle"; + } + catch (e) { + return "error"; + } + } + /** + * Issue a request. + * + * This method automatically opens a connection if none exists, and verifies + * an existing connection if necessary. It calls http2.ClientHttp2Session.request(), + * and keeps track of all open http2.ClientHttp2Stream. + * + * Clients must call notifyResponseByteRead() whenever they successfully read + * data from the http2.ClientHttp2Stream. + */ + async request(method, path, headers, options) { + // Request sometimes fails with goaway/destroyed + // errors, we use a loop to retry. + // + // This is not expected to happen often, but it is possible that a + // connection is closed while we are trying to open a stream. + // + // Ref: https://github.com/nodejs/help/issues/2105 + for (;;) { + const ready = await this.gotoReady(); + try { + const stream = ready.conn.request(Object.assign(Object.assign({}, headers), { ":method": method, ":path": path }), options); + ready.registerRequest(stream); + return stream; + } + catch (e) { + // Check to see if the connection is closed or destroyed + // and if so, we try again. + if (ready.conn.closed || ready.conn.destroyed) { + continue; + } + throw e; + } + } + } + /** + * Notify the manager of a successful read from a http2.ClientHttp2Stream. + * + * Clients must call this function whenever they successfully read data from + * a http2.ClientHttp2Stream obtained from request(). This informs the + * keep-alive logic that the connection is alive, and prevents it from sending + * unnecessary PING frames. + */ + notifyResponseByteRead(stream) { + if (this.s.t == "ready") { + this.s.responseByteRead(stream); + } + for (const s of this.shuttingDown) { + s.responseByteRead(stream); + } + } + /** + * If there is an open connection, close it. This also closes any open streams. + */ + abort(reason) { + var _a, _b, _c; + const err = reason !== null && reason !== void 0 ? reason : new connect_error_ConnectError("connection aborted", code_Code.Canceled); + (_b = (_a = this.s).abort) === null || _b === void 0 ? void 0 : _b.call(_a, err); + for (const s of this.shuttingDown) { + (_c = s.abort) === null || _c === void 0 ? void 0 : _c.call(s, err); + } + this.setState(closedOrError(err)); + } + async gotoReady() { + if (this.s.t == "ready") { + if (this.s.isShuttingDown() || + this.s.conn.closed || + this.s.conn.destroyed) { + this.setState(connect(this.authority, this.http2SessionOptions)); + } + else if (this.s.requiresVerify()) { + await this.verify(this.s); + } + } + else if (this.s.t == "closed" || this.s.t == "error") { + this.setState(connect(this.authority, this.http2SessionOptions)); + } + while (this.s.t !== "ready") { + if (this.s.t === "error") { + throw this.s.reason; + } + if (this.s.t === "connecting") { + await this.s.conn; + } + } + return this.s; + } + setState(state) { + var _a, _b; + (_b = (_a = this.s).onExitState) === null || _b === void 0 ? void 0 : _b.call(_a); + if (this.s.t == "ready" && this.s.isShuttingDown()) { + // Maintain connections that have been asked to shut down. + const sd = this.s; + this.shuttingDown.push(sd); + sd.onClose = sd.onError = () => { + const i = this.shuttingDown.indexOf(sd); + if (i !== -1) { + this.shuttingDown.splice(i, 1); + } + }; + } + switch (state.t) { + case "connecting": + state.conn.then((value) => { + this.setState(ready(value, this.options)); + }, (reason) => { + this.setState(closedOrError(reason)); + }); + break; + case "ready": + state.onClose = () => this.setState(http2_session_manager_closed()); + state.onError = (err) => this.setState(closedOrError(err)); + break; + case "closed": + break; + case "error": + break; + } + this.s = state; + } + verify(stateReady) { + if (this.verifying !== undefined) { + return this.verifying; + } + this.verifying = stateReady + .verify() + .then((success) => { + if (success) { + return; + } + // verify() has destroyed the old connection + this.setState(connect(this.authority, this.http2SessionOptions)); + }, (reason) => { + this.setState(closedOrError(reason)); + }) + .finally(() => { + this.verifying = undefined; + }); + return this.verifying; + } +} +function http2_session_manager_closed() { + return { + t: "closed", + }; +} +function error(reason) { + return { + t: "error", + reason, + }; +} +function closedOrError(reason) { + const isCancel = reason instanceof connect_error_ConnectError && + connect_error_ConnectError.from(reason).code == code_Code.Canceled; + return isCancel ? http2_session_manager_closed() : error(reason); +} +function connect(authority, http2SessionOptions) { + let resolve; + let reject; + const conn = new Promise((res, rej) => { + resolve = res; + reject = rej; + }); + const newConn = external_http2_.connect(authority, http2SessionOptions); + newConn.on("connect", onConnect); + newConn.on("error", onError); + function onConnect() { + resolve === null || resolve === void 0 ? void 0 : resolve(newConn); + cleanup(); + } + function onError(err) { + reject === null || reject === void 0 ? void 0 : reject(node_error_connectErrorFromNodeReason(err)); + cleanup(); + } + function cleanup() { + newConn.off("connect", onConnect); + newConn.off("error", onError); + } + return { + t: "connecting", + conn, + abort(reason) { + if (!newConn.destroyed) { + newConn.destroy(undefined, external_http2_.constants.NGHTTP2_CANCEL); + } + // According to the documentation, destroy() should immediately terminate + // the session and the socket, but we still receive a "connect" event. + // We must not resolve a broken connection, so we reject it manually here. + reject === null || reject === void 0 ? void 0 : reject(reason); + }, + onExitState() { + cleanup(); + }, + }; +} +function ready(conn, options) { + // Users have reported an error "The session has been destroyed" raised + // from H2SessionManager.request(), see https://github.com/connectrpc/connect-es/issues/683 + // This assertion will show whether the session already died in the + // "connecting" state. + assertSessionOpen(conn); + // Do not block Node.js from exiting on an idle connection. + // Note that we ref() again for the first stream to open, and unref() again + // for the last stream to close. + conn.unref(); + // the last time we were sure that the connection is alive, via a PING + // response, or via received response bytes + let lastAliveAt = Date.now(); + // how many streams are currently open on this session + let streamCount = 0; + // timer for the keep-alive interval + let pingIntervalId; + // timer for waiting for a PING response + let pingTimeoutId; + // keep track of GOAWAY - gracefully shut down open streams / wait for connection to error + let receivedGoAway = false; + // keep track of GOAWAY with ENHANCE_YOUR_CALM and with debug data too_many_pings + let receivedGoAwayEnhanceYourCalmTooManyPings = false; + // timer for closing connections without open streams, must be initialized + let idleTimeoutId; + resetIdleTimeout(); + const state = { + t: "ready", + conn, + streamCount() { + return streamCount; + }, + requiresVerify() { + const elapsedMs = Date.now() - lastAliveAt; + return elapsedMs > options.pingIntervalMs; + }, + isShuttingDown() { + return receivedGoAway; + }, + onClose: undefined, + onError: undefined, + registerRequest(stream) { + streamCount++; + if (streamCount == 1) { + conn.ref(); + resetPingInterval(); // reset to ping with the appropriate interval for "open" + stopIdleTimeout(); + } + stream.once("response", () => { + lastAliveAt = Date.now(); + resetPingInterval(); + }); + stream.once("close", () => { + streamCount--; + if (streamCount == 0) { + conn.unref(); + resetPingInterval(); // reset to ping with the appropriate interval for "idle" + resetIdleTimeout(); + } + }); + }, + responseByteRead(stream) { + if (stream.session !== conn) { + return; + } + if (conn.closed || conn.destroyed) { + return; + } + if (streamCount <= 0) { + return; + } + lastAliveAt = Date.now(); + resetPingInterval(); + }, + verify() { + conn.ref(); + return new Promise((resolve) => { + commonPing(() => { + if (streamCount == 0) + conn.unref(); + resolve(true); + }); + conn.once("error", () => resolve(false)); + }); + }, + abort(reason) { + if (!conn.destroyed) { + conn.once("error", () => { + // conn.destroy() may raise an error after onExitState() was called + // and our error listeners are removed. + // We attach this one to swallow uncaught exceptions. + }); + conn.destroy(reason, external_http2_.constants.NGHTTP2_CANCEL); + } + }, + onExitState() { + if (state.isShuttingDown()) { + // Per the interface, this method is called when the manager is leaving + // the state. We maintain this connection in the session manager until + // all streams have finished, so we do not detach event listeners here. + return; + } + cleanup(); + this.onError = undefined; + this.onClose = undefined; + }, + }; + // start or restart the ping interval + function resetPingInterval() { + stopPingInterval(); + if (streamCount > 0 || options.pingIdleConnection) { + pingIntervalId = safeSetTimeout(onPingInterval, options.pingIntervalMs); + } + } + function stopPingInterval() { + clearTimeout(pingIntervalId); + clearTimeout(pingTimeoutId); + } + function onPingInterval() { + commonPing(resetPingInterval); + } + function commonPing(onSuccess) { + clearTimeout(pingTimeoutId); + pingTimeoutId = safeSetTimeout(() => { + conn.destroy(new connect_error_ConnectError("PING timed out", code_Code.Unavailable), external_http2_.constants.NGHTTP2_CANCEL); + }, options.pingTimeoutMs); + conn.ping((err, duration) => { + clearTimeout(pingTimeoutId); + if (err !== null) { + // We will receive an ERR_HTTP2_PING_CANCEL here if we destroy the + // connection with a pending ping. + // We might also see other errors, but they should be picked up by the + // "error" event listener. + return; + } + if (duration > options.pingTimeoutMs) { + // setTimeout is not precise, and HTTP/2 pings take less than 1ms in + // tests. + conn.destroy(new connect_error_ConnectError("PING timed out", code_Code.Unavailable), external_http2_.constants.NGHTTP2_CANCEL); + return; + } + lastAliveAt = Date.now(); + onSuccess(); + }); + } + function stopIdleTimeout() { + clearTimeout(idleTimeoutId); + } + function resetIdleTimeout() { + idleTimeoutId = safeSetTimeout(onIdleTimeout, options.idleConnectionTimeoutMs); + } + function onIdleTimeout() { + conn.close(); + onClose(); // trigger a state change right away, so we are not open to races + } + function onGoaway(errorCode, lastStreamID, opaqueData) { + receivedGoAway = true; + const tooManyPingsAscii = Buffer.from("too_many_pings", "ascii"); + if (errorCode === external_http2_.constants.NGHTTP2_ENHANCE_YOUR_CALM && + opaqueData != null && + opaqueData.equals(tooManyPingsAscii)) { + // double pingIntervalMs, following the last paragraph of https://github.com/grpc/proposal/blob/0ba0c1905050525f9b0aee46f3f23c8e1e515489/A8-client-side-keepalive.md#basic-keepalive + options.pingIntervalMs = options.pingIntervalMs * 2; + receivedGoAwayEnhanceYourCalmTooManyPings = true; + } + if (errorCode === external_http2_.constants.NGHTTP2_NO_ERROR) { + const nodeMajor = parseInt(process.versions.node.split(".")[0], 10); + // Node.js v16 closes a connection on its own when it receives a GOAWAY + // frame and there are no open streams (emitting a "close" event and + // destroying the session), but more recent versions do not. + // Calling close() ourselves is ineffective here - it appears that the + // method is already being called, see https://github.com/nodejs/node/blob/198affc63973805ce5102d246f6b7822be57f5fc/lib/internal/http2/core.js#L681 + if (streamCount == 0 && nodeMajor >= 18) { + conn.destroy(new connect_error_ConnectError("received GOAWAY without any open streams", code_Code.Canceled), external_http2_.constants.NGHTTP2_NO_ERROR); + } + } + } + function onClose() { + var _a; + cleanup(); + (_a = state.onClose) === null || _a === void 0 ? void 0 : _a.call(state); + } + function onError(err) { + var _a, _b; + cleanup(); + if (receivedGoAwayEnhanceYourCalmTooManyPings) { + // We cannot prevent node from destroying session and streams with its own + // error that does not carry debug data, but at least we can wrap the error + // we surface on the manager. + const ce = new connect_error_ConnectError(`http/2 connection closed with error code ENHANCE_YOUR_CALM (0x${external_http2_.constants.NGHTTP2_ENHANCE_YOUR_CALM.toString(16)}), too_many_pings, doubled the interval`, code_Code.ResourceExhausted); + (_a = state.onError) === null || _a === void 0 ? void 0 : _a.call(state, ce); + } + else { + (_b = state.onError) === null || _b === void 0 ? void 0 : _b.call(state, node_error_connectErrorFromNodeReason(err)); + } + } + function cleanup() { + stopPingInterval(); + stopIdleTimeout(); + conn.off("error", onError); + conn.off("close", onClose); + conn.off("goaway", onGoaway); + } + conn.on("error", onError); + conn.on("close", onClose); + conn.on("goaway", onGoaway); + return state; +} +/** + * setTimeout(), but simply ignores values larger than the maximum supported + * value (signed 32-bit integer) instead of calling the callback right away, + * and does not block Node.js from exiting. + */ +function safeSetTimeout(callback, ms) { + if (ms > 0x7fffffff) { + return; + } + return setTimeout(callback, ms).unref(); +} +function assertSessionOpen(conn) { + if (conn.connecting) { + throw new connect_error_ConnectError("expected open session, but it is connecting", code_Code.Internal); + } + if (conn.destroyed) { + throw new connect_error_ConnectError("expected open session, but it is destroyed", code_Code.Internal); + } + if (conn.closed) { + throw new connect_error_ConnectError("expected open session, but it is closed", code_Code.Internal); + } +} + +;// CONCATENATED MODULE: ./node_modules/@connectrpc/connect-node/dist/esm/node-universal-client.js +// Copyright 2021-2024 The Connect Authors +// +// Licensed under the Apache License, Version 2.0 (the "License"); +// you may not use this file except in compliance with the License. +// You may obtain a copy of the License at +// +// http://www.apache.org/licenses/LICENSE-2.0 +// +// Unless required by applicable law or agreed to in writing, software +// distributed under the License is distributed on an "AS IS" BASIS, +// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. +// See the License for the specific language governing permissions and +// limitations under the License. + + + + + + + + +/** + * Create a universal client function, a minimal abstraction of an HTTP client, + * using the Node.js `http`, `https`, or `http2` module. + * + * @private Internal code, does not follow semantic versioning. + */ +function createNodeHttpClient(options) { + var _a; + if (options.httpVersion == "1.1") { + return createNodeHttp1Client(options.nodeOptions); + } + const sessionProvider = (_a = options.sessionProvider) !== null && _a !== void 0 ? _a : ((url) => new Http2SessionManager(url)); + return createNodeHttp2Client(sessionProvider); +} +/** + * Create an HTTP client using the Node.js `http` or `https` package. + * + * The HTTP client is a simple function conforming to the type UniversalClientFn. + * It takes an UniversalClientRequest as an argument, and returns a promise for + * an UniversalClientResponse. + */ +function createNodeHttp1Client(httpOptions) { + return async function request(req) { + const sentinel = createSentinel(req.signal); + return new Promise((resolve, reject) => { + sentinel.catch((e) => { + reject(e); + }); + h1Request(sentinel, req.url, Object.assign(Object.assign({}, httpOptions), { headers: node_universal_header_webHeaderToNodeHeaders(req.header, httpOptions === null || httpOptions === void 0 ? void 0 : httpOptions.headers), method: req.method }), (request) => { + void sinkRequest(req, request, sentinel); + request.on("response", (response) => { + var _a; + response.on("error", sentinel.reject); + sentinel.catch((reason) => response.destroy(node_error_connectErrorFromNodeReason(reason))); + const trailer = new Headers(); + resolve({ + status: (_a = response.statusCode) !== null && _a !== void 0 ? _a : 0, + header: node_universal_header_nodeHeaderToWebHeader(response.headers), + body: h1ResponseIterable(sentinel, response, trailer), + trailer, + }); + }); + }); + }); + }; +} +/** + * Create an HTTP client using the Node.js `http2` package. + * + * The HTTP client is a simple function conforming to the type UniversalClientFn. + * It takes an UniversalClientRequest as an argument, and returns a promise for + * an UniversalClientResponse. + */ +function createNodeHttp2Client(sessionProvider) { + return function request(req) { + const sentinel = createSentinel(req.signal); + const sessionManager = sessionProvider(req.url); + return new Promise((resolve, reject) => { + sentinel.catch((e) => { + reject(e); + }); + h2Request(sentinel, sessionManager, req.url, req.method, node_universal_header_webHeaderToNodeHeaders(req.header), {}, (stream) => { + void sinkRequest(req, stream, sentinel); + stream.on("response", (headers) => { + var _a; + const response = { + status: (_a = headers[":status"]) !== null && _a !== void 0 ? _a : 0, + header: node_universal_header_nodeHeaderToWebHeader(headers), + body: h2ResponseIterable(sentinel, stream, sessionManager), + trailer: h2ResponseTrailer(stream), + }; + resolve(response); + }); + }); + }); + }; +} +function h1Request(sentinel, url, options, onRequest) { + let request; + if (new URL(url).protocol.startsWith("https")) { + request = external_https_.request(url, options); + } + else { + request = external_http_.request(url, options); + } + sentinel.catch((reason) => request.destroy(node_error_connectErrorFromNodeReason(reason))); + // Node.js will only send headers with the first request body byte by default. + // We force it to send headers right away for consistent behavior between + // HTTP/1.1 and HTTP/2.2 clients. + request.flushHeaders(); + request.on("error", sentinel.reject); + request.on("socket", function onRequestSocket(socket) { + function onSocketConnect() { + socket.off("connect", onSocketConnect); + onRequest(request); + } + // If readyState is open, then socket is already open due to keepAlive, so + // the 'connect' event will never fire so call onRequest explicitly + if (socket.readyState === "open") { + onRequest(request); + } + else { + socket.on("connect", onSocketConnect); + } + }); +} +function h1ResponseIterable(sentinel, response, trailer) { + const inner = response[Symbol.asyncIterator](); + return { + [Symbol.asyncIterator]() { + return { + async next() { + const r = await sentinel.race(inner.next()); + if (r.done === true) { + node_universal_header_nodeHeaderToWebHeader(response.trailers).forEach((value, key) => { + trailer.set(key, value); + }); + sentinel.resolve(); + await sentinel; + } + return r; + }, + throw(e) { + sentinel.reject(e); + throw e; + }, + }; + }, + }; +} +function h2Request(sentinel, sm, url, method, headers, options, onStream) { + const requestUrl = new URL(url); + if (requestUrl.origin !== sm.authority) { + const message = `cannot make a request to ${requestUrl.origin}: the http2 session is connected to ${sm.authority}`; + sentinel.reject(new connect_error_ConnectError(message, code_Code.Internal)); + return; + } + sm.request(method, requestUrl.pathname + requestUrl.search, headers, {}).then((stream) => { + sentinel.catch((reason) => { + if (stream.closed) { + return; + } + // Node.js http2 streams that are aborted via an AbortSignal close with + // an RST_STREAM with code INTERNAL_ERROR. + // To comply with the mapping between gRPC and HTTP/2 codes, we need to + // close with code CANCEL. + // See https://github.com/grpc/grpc/blob/master/doc/PROTOCOL-HTTP2.md#errors + // See https://www.rfc-editor.org/rfc/rfc7540#section-7 + const rstCode = reason instanceof connect_error_ConnectError && reason.code == code_Code.Canceled + ? H2Code.CANCEL + : H2Code.INTERNAL_ERROR; + return new Promise((resolve) => stream.close(rstCode, resolve)); + }); + stream.on("error", function h2StreamError(e) { + if (stream.writableEnded && + unwrapNodeErrorChain(e) + .map(getNodeErrorProps) + .some((p) => p.code == "ERR_STREAM_WRITE_AFTER_END")) { + return; + } + sentinel.reject(e); + }); + stream.on("close", function h2StreamClose() { + const err = node_error_connectErrorFromH2ResetCode(stream.rstCode); + if (err) { + sentinel.reject(err); + } + }); + onStream(stream); + }, (reason) => { + sentinel.reject(reason); + }); +} +function h2ResponseTrailer(response) { + const trailer = new Headers(); + response.on("trailers", (args) => { + node_universal_header_nodeHeaderToWebHeader(args).forEach((value, key) => { + trailer.set(key, value); + }); + }); + return trailer; +} +function h2ResponseIterable(sentinel, response, sm) { + const inner = response[Symbol.asyncIterator](); + return { + [Symbol.asyncIterator]() { + return { + async next() { + const r = await sentinel.race(inner.next()); + if (r.done === true) { + sentinel.resolve(); + await sentinel; + } + sm === null || sm === void 0 ? void 0 : sm.notifyResponseByteRead(response); + return r; + }, + throw(e) { + sentinel.reject(e); + throw e; + }, + }; + }, + }; +} +async function sinkRequest(request, nodeRequest, sentinel) { + if (request.body === undefined) { + await new Promise((resolve) => nodeRequest.end(resolve)); + return; + } + const it = request.body[Symbol.asyncIterator](); + return new Promise((resolve) => { + writeNext(); + function writeNext() { + if (sentinel.isRejected()) { + return; + } + it.next().then((r) => { + if (r.done === true) { + nodeRequest.end(resolve); + return; + } + nodeRequest.write(r.value, "binary", function (e) { + if (e === null || e === undefined) { + writeNext(); + return; + } + if (it.throw !== undefined) { + it.throw(node_error_connectErrorFromNodeReason(e)).catch(() => { + // + }); + } + // If the server responds and closes the connection before the client has written the entire response + // body, we get an ERR_STREAM_WRITE_AFTER_END error code from Node.js here. + // We do want to notify the iterable of the error condition, but we do not want to reject our sentinel, + // because that would also affect the reading side. + if (nodeRequest.writableEnded && + unwrapNodeErrorChain(e) + .map(getNodeErrorProps) + .some((p) => p.code == "ERR_STREAM_WRITE_AFTER_END")) { + return; + } + sentinel.reject(e); + }); + }, (e) => { + sentinel.reject(e); + }); + } + }); +} +function createSentinel(signal) { + let res; + let rej; + let resolved = false; + let rejected = false; + const p = new Promise((resolve, reject) => { + res = resolve; + rej = reject; + }); + const c = { + resolve() { + if (!resolved && !rejected) { + resolved = true; + res === null || res === void 0 ? void 0 : res(); + } + }, + isResolved() { + return resolved; + }, + reject(reason) { + if (!resolved && !rejected) { + rejected = true; + rej === null || rej === void 0 ? void 0 : rej(node_error_connectErrorFromNodeReason(reason)); + } + }, + isRejected() { + return rejected; + }, + async race(promise) { + const r = await Promise.race([promise, p]); + if (r === undefined && resolved) { + throw new connect_error_ConnectError("sentinel completed early", code_Code.Internal); + } + return r; + }, + }; + const s = Object.assign(p, c); + function onSignalAbort() { + c.reject(getAbortSignalReason(this)); + } + if (signal) { + if (signal.aborted) { + c.reject(getAbortSignalReason(signal)); + } + else { + signal.addEventListener("abort", onSignalAbort); + } + p.finally(() => signal.removeEventListener("abort", onSignalAbort)).catch(() => { + // We intentionally swallow sentinel rejection - errors must + // propagate through the request or response iterables. + }); + } + return s; +} + +;// CONCATENATED MODULE: ./node_modules/@connectrpc/connect-node/dist/esm/node-transport-options.js +// Copyright 2021-2024 The Connect Authors +// +// Licensed under the Apache License, Version 2.0 (the "License"); +// you may not use this file except in compliance with the License. +// You may obtain a copy of the License at +// +// http://www.apache.org/licenses/LICENSE-2.0 +// +// Unless required by applicable law or agreed to in writing, software +// distributed under the License is distributed on an "AS IS" BASIS, +// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. +// See the License for the specific language governing permissions and +// limitations under the License. + + + + + + + +/** + * Asserts that the options are within sane limits, and returns default values + * where no value is provided. + * + * @private Internal code, does not follow semantic versioning. + */ +function node_transport_options_validateNodeTransportOptions(options) { + var _a, _b, _c, _d; + let httpClient; + if (options.httpVersion == "2") { + let sessionManager; + if (options.sessionManager) { + sessionManager = options.sessionManager; + } + else { + sessionManager = new Http2SessionManager(options.baseUrl, { + pingIntervalMs: options.pingIntervalMs, + pingIdleConnection: options.pingIdleConnection, + pingTimeoutMs: options.pingTimeoutMs, + idleConnectionTimeoutMs: options.idleConnectionTimeoutMs, + }, options.nodeOptions); + } + httpClient = createNodeHttpClient({ + httpVersion: "2", + sessionProvider: () => sessionManager, + }); + } + else { + httpClient = createNodeHttpClient({ + httpVersion: "1.1", + nodeOptions: options.nodeOptions, + }); + } + return Object.assign(Object.assign(Object.assign({}, options), { httpClient, useBinaryFormat: (_a = options.useBinaryFormat) !== null && _a !== void 0 ? _a : true, interceptors: (_b = options.interceptors) !== null && _b !== void 0 ? _b : [], sendCompression: (_c = options.sendCompression) !== null && _c !== void 0 ? _c : null, acceptCompression: (_d = options.acceptCompression) !== null && _d !== void 0 ? _d : [ + compression_compressionGzip, + compression_compressionBrotli, + ] }), validateReadWriteMaxBytes(options.readMaxBytes, options.writeMaxBytes, options.compressMinBytes)); +} + +;// CONCATENATED MODULE: ./node_modules/@connectrpc/connect-node/dist/esm/grpc-web-transport.js +// Copyright 2021-2024 The Connect Authors +// +// Licensed under the Apache License, Version 2.0 (the "License"); +// you may not use this file except in compliance with the License. +// You may obtain a copy of the License at +// +// http://www.apache.org/licenses/LICENSE-2.0 +// +// Unless required by applicable law or agreed to in writing, software +// distributed under the License is distributed on an "AS IS" BASIS, +// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. +// See the License for the specific language governing permissions and +// limitations under the License. + + +/** + * Create a Transport for the gRPC-web protocol using the Node.js `http`, + * `http2`, or `http2` module. + */ +function createGrpcWebTransport(options) { + return createTransport(validateNodeTransportOptions(options)); +} + +;// CONCATENATED MODULE: ./node_modules/@connectrpc/connect/dist/esm/protocol-grpc/headers.js +// Copyright 2021-2024 The Connect Authors +// +// Licensed under the Apache License, Version 2.0 (the "License"); +// you may not use this file except in compliance with the License. +// You may obtain a copy of the License at +// +// http://www.apache.org/licenses/LICENSE-2.0 +// +// Unless required by applicable law or agreed to in writing, software +// distributed under the License is distributed on an "AS IS" BASIS, +// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. +// See the License for the specific language governing permissions and +// limitations under the License. +/** + * @private Internal code, does not follow semantic versioning. + */ +const headerContentType = "Content-Type"; +const headerEncoding = "Grpc-Encoding"; +const headerAcceptEncoding = "Grpc-Accept-Encoding"; +const headerTimeout = "Grpc-Timeout"; +const headers_headerGrpcStatus = "Grpc-Status"; +const headers_headerGrpcMessage = "Grpc-Message"; +const headers_headerStatusDetailsBin = "Grpc-Status-Details-Bin"; +const headerMessageType = "Grpc-Message-Type"; +const headerUserAgent = "User-Agent"; + +;// CONCATENATED MODULE: ./node_modules/@connectrpc/connect/dist/esm/protocol-grpc/content-type.js +// Copyright 2021-2024 The Connect Authors +// +// Licensed under the Apache License, Version 2.0 (the "License"); +// you may not use this file except in compliance with the License. +// You may obtain a copy of the License at +// +// http://www.apache.org/licenses/LICENSE-2.0 +// +// Unless required by applicable law or agreed to in writing, software +// distributed under the License is distributed on an "AS IS" BASIS, +// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. +// See the License for the specific language governing permissions and +// limitations under the License. +/** + * Regular Expression that matches any valid gRPC Content-Type header value. + * + * @private Internal code, does not follow semantic versioning. + */ +const contentTypeRegExp = /^application\/grpc(?:\+(?:(json)(?:; ?charset=utf-?8)?|proto))?$/i; +const contentTypeProto = "application/grpc+proto"; +const contentTypeJson = "application/grpc+json"; +/** + * Parse a gRPC Content-Type header. + * + * @private Internal code, does not follow semantic versioning. + */ +function parseContentType(contentType) { + const match = contentType === null || contentType === void 0 ? void 0 : contentType.match(contentTypeRegExp); + if (!match) { + return undefined; + } + const binary = !match[1]; + return { binary }; +} + +;// CONCATENATED MODULE: ./node_modules/@connectrpc/connect/dist/esm/protocol-grpc/request-header.js +// Copyright 2021-2024 The Connect Authors +// +// Licensed under the Apache License, Version 2.0 (the "License"); +// you may not use this file except in compliance with the License. +// You may obtain a copy of the License at +// +// http://www.apache.org/licenses/LICENSE-2.0 +// +// Unless required by applicable law or agreed to in writing, software +// distributed under the License is distributed on an "AS IS" BASIS, +// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. +// See the License for the specific language governing permissions and +// limitations under the License. + + +/** + * Creates headers for a gRPC request. + * + * @private Internal code, does not follow semantic versioning. + */ +function requestHeader(useBinaryFormat, timeoutMs, userProvidedHeaders) { + const result = new Headers(userProvidedHeaders !== null && userProvidedHeaders !== void 0 ? userProvidedHeaders : {}); + result.set(headerContentType, useBinaryFormat ? contentTypeProto : contentTypeJson); + // Note that we do not strictly comply with gRPC user agents. + // We use "connect-es/1.2.3" where gRPC would use "grpc-es/1.2.3". + // See https://github.com/grpc/grpc/blob/c462bb8d485fc1434ecfae438823ca8d14cf3154/doc/PROTOCOL-HTTP2.md#user-agents + result.set(headerUserAgent, "connect-es/1.6.1"); + if (timeoutMs !== undefined) { + result.set(headerTimeout, `${timeoutMs}m`); + } + // The gRPC-HTTP2 specification requires this - it flushes out proxies that + // don't support HTTP trailers. + result.set("Te", "trailers"); + return result; +} +/** + * Creates headers for a gRPC request with compression. + * + * @private Internal code, does not follow semantic versioning. + */ +function requestHeaderWithCompression(useBinaryFormat, timeoutMs, userProvidedHeaders, acceptCompression, sendCompression) { + const result = requestHeader(useBinaryFormat, timeoutMs, userProvidedHeaders); + if (sendCompression != null) { + result.set(headerEncoding, sendCompression.name); + } + if (acceptCompression.length > 0) { + result.set(headerAcceptEncoding, acceptCompression.map((c) => c.name).join(",")); + } + return result; +} + +;// CONCATENATED MODULE: ./node_modules/@connectrpc/connect/dist/esm/protocol-grpc/http-status.js +// Copyright 2021-2024 The Connect Authors +// +// Licensed under the Apache License, Version 2.0 (the "License"); +// you may not use this file except in compliance with the License. +// You may obtain a copy of the License at +// +// http://www.apache.org/licenses/LICENSE-2.0 +// +// Unless required by applicable law or agreed to in writing, software +// distributed under the License is distributed on an "AS IS" BASIS, +// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. +// See the License for the specific language governing permissions and +// limitations under the License. + +/** + * Determine the gRPC-web error code for the given HTTP status code. + * See https://github.com/grpc/grpc/blob/master/doc/http-grpc-status-mapping.md. + * + * @private Internal code, does not follow semantic versioning. + */ +function codeFromHttpStatus(httpStatus) { + switch (httpStatus) { + case 400: // Bad Request + return code_Code.Internal; + case 401: // Unauthorized + return code_Code.Unauthenticated; + case 403: // Forbidden + return code_Code.PermissionDenied; + case 404: // Not Found + return code_Code.Unimplemented; + case 429: // Too Many Requests + return code_Code.Unavailable; + case 502: // Bad Gateway + return code_Code.Unavailable; + case 503: // Service Unavailable + return code_Code.Unavailable; + case 504: // Gateway Timeout + return code_Code.Unavailable; + default: + // 200 is UNKNOWN because there should be a grpc-status in case of truly OK response. + return code_Code.Unknown; + } +} + +;// CONCATENATED MODULE: ./node_modules/@bufbuild/protobuf/dist/esm/message.js +// Copyright 2021-2024 Buf Technologies, Inc. +// +// Licensed under the Apache License, Version 2.0 (the "License"); +// you may not use this file except in compliance with the License. +// You may obtain a copy of the License at +// +// http://www.apache.org/licenses/LICENSE-2.0 +// +// Unless required by applicable law or agreed to in writing, software +// distributed under the License is distributed on an "AS IS" BASIS, +// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. +// See the License for the specific language governing permissions and +// limitations under the License. +/** + * Message is the base class of every message, generated, or created at + * runtime. + * + * It is _not_ safe to extend this class. If you want to create a message at + * run time, use proto3.makeMessageType(). + */ +class Message { + /** + * Compare with a message of the same type. + * Note that this function disregards extensions and unknown fields. + */ + equals(other) { + return this.getType().runtime.util.equals(this.getType(), this, other); + } + /** + * Create a deep copy. + */ + clone() { + return this.getType().runtime.util.clone(this); + } + /** + * Parse from binary data, merging fields. + * + * Repeated fields are appended. Map entries are added, overwriting + * existing keys. + * + * If a message field is already present, it will be merged with the + * new data. + */ + fromBinary(bytes, options) { + const type = this.getType(), format = type.runtime.bin, opt = format.makeReadOptions(options); + format.readMessage(this, opt.readerFactory(bytes), bytes.byteLength, opt); + return this; + } + /** + * Parse a message from a JSON value. + */ + fromJson(jsonValue, options) { + const type = this.getType(), format = type.runtime.json, opt = format.makeReadOptions(options); + format.readMessage(type, jsonValue, opt, this); + return this; + } + /** + * Parse a message from a JSON string. + */ + fromJsonString(jsonString, options) { + let json; + try { + json = JSON.parse(jsonString); + } + catch (e) { + throw new Error(`cannot decode ${this.getType().typeName} from JSON: ${e instanceof Error ? e.message : String(e)}`); + } + return this.fromJson(json, options); + } + /** + * Serialize the message to binary data. + */ + toBinary(options) { + const type = this.getType(), bin = type.runtime.bin, opt = bin.makeWriteOptions(options), writer = opt.writerFactory(); + bin.writeMessage(this, writer, opt); + return writer.finish(); + } + /** + * Serialize the message to a JSON value, a JavaScript value that can be + * passed to JSON.stringify(). + */ + toJson(options) { + const type = this.getType(), json = type.runtime.json, opt = json.makeWriteOptions(options); + return json.writeMessage(this, opt); + } + /** + * Serialize the message to a JSON string. + */ + toJsonString(options) { + var _a; + const value = this.toJson(options); + return JSON.stringify(value, null, (_a = options === null || options === void 0 ? void 0 : options.prettySpaces) !== null && _a !== void 0 ? _a : 0); + } + /** + * Override for serialization behavior. This will be invoked when calling + * JSON.stringify on this message (i.e. JSON.stringify(msg)). + * + * Note that this will not serialize google.protobuf.Any with a packed + * message because the protobuf JSON format specifies that it needs to be + * unpacked, and this is only possible with a type registry to look up the + * message type. As a result, attempting to serialize a message with this + * type will throw an Error. + * + * This method is protected because you should not need to invoke it + * directly -- instead use JSON.stringify or toJsonString for + * stringified JSON. Alternatively, if actual JSON is desired, you should + * use toJson. + */ + toJSON() { + return this.toJson({ + emitDefaultValues: true, + }); + } + /** + * Retrieve the MessageType of this message - a singleton that represents + * the protobuf message declaration and provides metadata for reflection- + * based operations. + */ + getType() { + // Any class that extends Message _must_ provide a complete static + // implementation of MessageType. + // eslint-disable-next-line @typescript-eslint/no-unsafe-member-access,@typescript-eslint/no-unsafe-return + return Object.getPrototypeOf(this).constructor; + } +} + +;// CONCATENATED MODULE: ./node_modules/@bufbuild/protobuf/dist/esm/private/assert.js +// Copyright 2021-2024 Buf Technologies, Inc. +// +// Licensed under the Apache License, Version 2.0 (the "License"); +// you may not use this file except in compliance with the License. +// You may obtain a copy of the License at +// +// http://www.apache.org/licenses/LICENSE-2.0 +// +// Unless required by applicable law or agreed to in writing, software +// distributed under the License is distributed on an "AS IS" BASIS, +// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. +// See the License for the specific language governing permissions and +// limitations under the License. +/** + * Assert that condition is truthy or throw error (with message) + */ +function assert(condition, msg) { + // eslint-disable-next-line @typescript-eslint/strict-boolean-expressions -- we want the implicit conversion to boolean + if (!condition) { + throw new Error(msg); + } +} +const FLOAT32_MAX = 3.4028234663852886e38, FLOAT32_MIN = -3.4028234663852886e38, UINT32_MAX = 0xffffffff, INT32_MAX = 0x7fffffff, INT32_MIN = -0x80000000; +/** + * Assert a valid signed protobuf 32-bit integer. + */ +function assertInt32(arg) { + if (typeof arg !== "number") + throw new Error("invalid int 32: " + typeof arg); + if (!Number.isInteger(arg) || arg > INT32_MAX || arg < INT32_MIN) + throw new Error("invalid int 32: " + arg); // eslint-disable-line @typescript-eslint/restrict-plus-operands -- we want the implicit conversion to string +} +/** + * Assert a valid unsigned protobuf 32-bit integer. + */ +function assertUInt32(arg) { + if (typeof arg !== "number") + throw new Error("invalid uint 32: " + typeof arg); + if (!Number.isInteger(arg) || arg > UINT32_MAX || arg < 0) + throw new Error("invalid uint 32: " + arg); // eslint-disable-line @typescript-eslint/restrict-plus-operands -- we want the implicit conversion to string +} +/** + * Assert a valid protobuf float value. + */ +function assertFloat32(arg) { + if (typeof arg !== "number") + throw new Error("invalid float 32: " + typeof arg); + if (!Number.isFinite(arg)) + return; + if (arg > FLOAT32_MAX || arg < FLOAT32_MIN) + throw new Error("invalid float 32: " + arg); // eslint-disable-line @typescript-eslint/restrict-plus-operands -- we want the implicit conversion to string +} + +;// CONCATENATED MODULE: ./node_modules/@bufbuild/protobuf/dist/esm/private/enum.js +// Copyright 2021-2024 Buf Technologies, Inc. +// +// Licensed under the Apache License, Version 2.0 (the "License"); +// you may not use this file except in compliance with the License. +// You may obtain a copy of the License at +// +// http://www.apache.org/licenses/LICENSE-2.0 +// +// Unless required by applicable law or agreed to in writing, software +// distributed under the License is distributed on an "AS IS" BASIS, +// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. +// See the License for the specific language governing permissions and +// limitations under the License. + +const enumTypeSymbol = Symbol("@bufbuild/protobuf/enum-type"); +/** + * Get reflection information from a generated enum. + * If this function is called on something other than a generated + * enum, it raises an error. + */ +function getEnumType(enumObject) { + // eslint-disable-next-line @typescript-eslint/no-unsafe-member-access,@typescript-eslint/no-unsafe-assignment,@typescript-eslint/no-explicit-any + const t = enumObject[enumTypeSymbol]; + assert(t, "missing enum type on enum object"); + return t; // eslint-disable-line @typescript-eslint/no-unsafe-return +} +/** + * Sets reflection information on a generated enum. + */ +function setEnumType(enumObject, typeName, values, opt) { + // eslint-disable-next-line @typescript-eslint/no-unsafe-member-access, @typescript-eslint/no-explicit-any + enumObject[enumTypeSymbol] = makeEnumType(typeName, values.map((v) => ({ + no: v.no, + name: v.name, + localName: enumObject[v.no], + })), opt); +} +/** + * Create a new EnumType with the given values. + */ +function makeEnumType(typeName, values, +// eslint-disable-next-line @typescript-eslint/no-unused-vars +_opt) { + const names = Object.create(null); + const numbers = Object.create(null); + const normalValues = []; + for (const value of values) { + // We do not surface options at this time + // const value: EnumValueInfo = {...v, options: v.options ?? emptyReadonlyObject}; + const n = normalizeEnumValue(value); + normalValues.push(n); + names[value.name] = n; + numbers[value.no] = n; + } + return { + typeName, + values: normalValues, + // We do not surface options at this time + // options: opt?.options ?? Object.create(null), + findName(name) { + return names[name]; + }, + findNumber(no) { + return numbers[no]; + }, + }; +} +/** + * Create a new enum object with the given values. + * Sets reflection information. + */ +function makeEnum(typeName, values, opt) { + const enumObject = {}; + for (const value of values) { + const n = normalizeEnumValue(value); + enumObject[n.localName] = n.no; + enumObject[n.no] = n.localName; + } + setEnumType(enumObject, typeName, values, opt); + return enumObject; +} +function normalizeEnumValue(value) { + if ("localName" in value) { + return value; + } + return Object.assign(Object.assign({}, value), { localName: value.name }); +} + +;// CONCATENATED MODULE: ./node_modules/@bufbuild/protobuf/dist/esm/private/message-type.js +// Copyright 2021-2024 Buf Technologies, Inc. +// +// Licensed under the Apache License, Version 2.0 (the "License"); +// you may not use this file except in compliance with the License. +// You may obtain a copy of the License at +// +// http://www.apache.org/licenses/LICENSE-2.0 +// +// Unless required by applicable law or agreed to in writing, software +// distributed under the License is distributed on an "AS IS" BASIS, +// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. +// See the License for the specific language governing permissions and +// limitations under the License. + +/** + * Create a new message type using the given runtime. + */ +function makeMessageType(runtime, typeName, fields, opt) { + var _a; + const localName = (_a = opt === null || opt === void 0 ? void 0 : opt.localName) !== null && _a !== void 0 ? _a : typeName.substring(typeName.lastIndexOf(".") + 1); + const type = { + [localName]: function (data) { + runtime.util.initFields(this); + runtime.util.initPartial(data, this); + }, + }[localName]; + Object.setPrototypeOf(type.prototype, new Message()); + Object.assign(type, { + runtime, + typeName, + fields: runtime.util.newFieldList(fields), + fromBinary(bytes, options) { + return new type().fromBinary(bytes, options); + }, + fromJson(jsonValue, options) { + return new type().fromJson(jsonValue, options); + }, + fromJsonString(jsonString, options) { + return new type().fromJsonString(jsonString, options); + }, + equals(a, b) { + return runtime.util.equals(type, a, b); + }, + }); + return type; +} + +;// CONCATENATED MODULE: ./node_modules/@bufbuild/protobuf/dist/esm/google/varint.js +// Copyright 2008 Google Inc. All rights reserved. +// +// Redistribution and use in source and binary forms, with or without +// modification, are permitted provided that the following conditions are +// met: +// +// * Redistributions of source code must retain the above copyright +// notice, this list of conditions and the following disclaimer. +// * Redistributions in binary form must reproduce the above +// copyright notice, this list of conditions and the following disclaimer +// in the documentation and/or other materials provided with the +// distribution. +// * Neither the name of Google Inc. nor the names of its +// contributors may be used to endorse or promote products derived from +// this software without specific prior written permission. +// +// THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS +// "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT +// LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR +// A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT +// OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, +// SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT +// LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, +// DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY +// THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT +// (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE +// OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. +// +// Code generated by the Protocol Buffer compiler is owned by the owner +// of the input file used when generating it. This code is not +// standalone and requires a support library to be linked with it. This +// support library is itself covered by the above license. +/* eslint-disable prefer-const,@typescript-eslint/restrict-plus-operands */ +/** + * Read a 64 bit varint as two JS numbers. + * + * Returns tuple: + * [0]: low bits + * [1]: high bits + * + * Copyright 2008 Google Inc. All rights reserved. + * + * See https://github.com/protocolbuffers/protobuf/blob/8a71927d74a4ce34efe2d8769fda198f52d20d12/js/experimental/runtime/kernel/buffer_decoder.js#L175 + */ +function varint64read() { + let lowBits = 0; + let highBits = 0; + for (let shift = 0; shift < 28; shift += 7) { + let b = this.buf[this.pos++]; + lowBits |= (b & 0x7f) << shift; + if ((b & 0x80) == 0) { + this.assertBounds(); + return [lowBits, highBits]; + } + } + let middleByte = this.buf[this.pos++]; + // last four bits of the first 32 bit number + lowBits |= (middleByte & 0x0f) << 28; + // 3 upper bits are part of the next 32 bit number + highBits = (middleByte & 0x70) >> 4; + if ((middleByte & 0x80) == 0) { + this.assertBounds(); + return [lowBits, highBits]; + } + for (let shift = 3; shift <= 31; shift += 7) { + let b = this.buf[this.pos++]; + highBits |= (b & 0x7f) << shift; + if ((b & 0x80) == 0) { + this.assertBounds(); + return [lowBits, highBits]; + } + } + throw new Error("invalid varint"); +} +/** + * Write a 64 bit varint, given as two JS numbers, to the given bytes array. + * + * Copyright 2008 Google Inc. All rights reserved. + * + * See https://github.com/protocolbuffers/protobuf/blob/8a71927d74a4ce34efe2d8769fda198f52d20d12/js/experimental/runtime/kernel/writer.js#L344 + */ +function varint64write(lo, hi, bytes) { + for (let i = 0; i < 28; i = i + 7) { + const shift = lo >>> i; + const hasNext = !(shift >>> 7 == 0 && hi == 0); + const byte = (hasNext ? shift | 0x80 : shift) & 0xff; + bytes.push(byte); + if (!hasNext) { + return; + } + } + const splitBits = ((lo >>> 28) & 0x0f) | ((hi & 0x07) << 4); + const hasMoreBits = !(hi >> 3 == 0); + bytes.push((hasMoreBits ? splitBits | 0x80 : splitBits) & 0xff); + if (!hasMoreBits) { + return; + } + for (let i = 3; i < 31; i = i + 7) { + const shift = hi >>> i; + const hasNext = !(shift >>> 7 == 0); + const byte = (hasNext ? shift | 0x80 : shift) & 0xff; + bytes.push(byte); + if (!hasNext) { + return; + } + } + bytes.push((hi >>> 31) & 0x01); +} +// constants for binary math +const TWO_PWR_32_DBL = 0x100000000; +/** + * Parse decimal string of 64 bit integer value as two JS numbers. + * + * Copyright 2008 Google Inc. All rights reserved. + * + * See https://github.com/protocolbuffers/protobuf-javascript/blob/a428c58273abad07c66071d9753bc4d1289de426/experimental/runtime/int64.js#L10 + */ +function int64FromString(dec) { + // Check for minus sign. + const minus = dec[0] === "-"; + if (minus) { + dec = dec.slice(1); + } + // Work 6 decimal digits at a time, acting like we're converting base 1e6 + // digits to binary. This is safe to do with floating point math because + // Number.isSafeInteger(ALL_32_BITS * 1e6) == true. + const base = 1e6; + let lowBits = 0; + let highBits = 0; + function add1e6digit(begin, end) { + // Note: Number('') is 0. + const digit1e6 = Number(dec.slice(begin, end)); + highBits *= base; + lowBits = lowBits * base + digit1e6; + // Carry bits from lowBits to + if (lowBits >= TWO_PWR_32_DBL) { + highBits = highBits + ((lowBits / TWO_PWR_32_DBL) | 0); + lowBits = lowBits % TWO_PWR_32_DBL; + } + } + add1e6digit(-24, -18); + add1e6digit(-18, -12); + add1e6digit(-12, -6); + add1e6digit(-6); + return minus ? negate(lowBits, highBits) : newBits(lowBits, highBits); +} +/** + * Losslessly converts a 64-bit signed integer in 32:32 split representation + * into a decimal string. + * + * Copyright 2008 Google Inc. All rights reserved. + * + * See https://github.com/protocolbuffers/protobuf-javascript/blob/a428c58273abad07c66071d9753bc4d1289de426/experimental/runtime/int64.js#L10 + */ +function int64ToString(lo, hi) { + let bits = newBits(lo, hi); + // If we're treating the input as a signed value and the high bit is set, do + // a manual two's complement conversion before the decimal conversion. + const negative = (bits.hi & 0x80000000); + if (negative) { + bits = negate(bits.lo, bits.hi); + } + const result = uInt64ToString(bits.lo, bits.hi); + return negative ? "-" + result : result; +} +/** + * Losslessly converts a 64-bit unsigned integer in 32:32 split representation + * into a decimal string. + * + * Copyright 2008 Google Inc. All rights reserved. + * + * See https://github.com/protocolbuffers/protobuf-javascript/blob/a428c58273abad07c66071d9753bc4d1289de426/experimental/runtime/int64.js#L10 + */ +function uInt64ToString(lo, hi) { + ({ lo, hi } = toUnsigned(lo, hi)); + // Skip the expensive conversion if the number is small enough to use the + // built-in conversions. + // Number.MAX_SAFE_INTEGER = 0x001FFFFF FFFFFFFF, thus any number with + // highBits <= 0x1FFFFF can be safely expressed with a double and retain + // integer precision. + // Proven by: Number.isSafeInteger(0x1FFFFF * 2**32 + 0xFFFFFFFF) == true. + if (hi <= 0x1FFFFF) { + return String(TWO_PWR_32_DBL * hi + lo); + } + // What this code is doing is essentially converting the input number from + // base-2 to base-1e7, which allows us to represent the 64-bit range with + // only 3 (very large) digits. Those digits are then trivial to convert to + // a base-10 string. + // The magic numbers used here are - + // 2^24 = 16777216 = (1,6777216) in base-1e7. + // 2^48 = 281474976710656 = (2,8147497,6710656) in base-1e7. + // Split 32:32 representation into 16:24:24 representation so our + // intermediate digits don't overflow. + const low = lo & 0xFFFFFF; + const mid = ((lo >>> 24) | (hi << 8)) & 0xFFFFFF; + const high = (hi >> 16) & 0xFFFF; + // Assemble our three base-1e7 digits, ignoring carries. The maximum + // value in a digit at this step is representable as a 48-bit integer, which + // can be stored in a 64-bit floating point number. + let digitA = low + (mid * 6777216) + (high * 6710656); + let digitB = mid + (high * 8147497); + let digitC = (high * 2); + // Apply carries from A to B and from B to C. + const base = 10000000; + if (digitA >= base) { + digitB += Math.floor(digitA / base); + digitA %= base; + } + if (digitB >= base) { + digitC += Math.floor(digitB / base); + digitB %= base; + } + // If digitC is 0, then we should have returned in the trivial code path + // at the top for non-safe integers. Given this, we can assume both digitB + // and digitA need leading zeros. + return digitC.toString() + decimalFrom1e7WithLeadingZeros(digitB) + + decimalFrom1e7WithLeadingZeros(digitA); +} +function toUnsigned(lo, hi) { + return { lo: lo >>> 0, hi: hi >>> 0 }; +} +function newBits(lo, hi) { + return { lo: lo | 0, hi: hi | 0 }; +} +/** + * Returns two's compliment negation of input. + * @see https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Operators/Bitwise_Operators#Signed_32-bit_integers + */ +function negate(lowBits, highBits) { + highBits = ~highBits; + if (lowBits) { + lowBits = ~lowBits + 1; + } + else { + // If lowBits is 0, then bitwise-not is 0xFFFFFFFF, + // adding 1 to that, results in 0x100000000, which leaves + // the low bits 0x0 and simply adds one to the high bits. + highBits += 1; + } + return newBits(lowBits, highBits); +} +/** + * Returns decimal representation of digit1e7 with leading zeros. + */ +const decimalFrom1e7WithLeadingZeros = (digit1e7) => { + const partial = String(digit1e7); + return "0000000".slice(partial.length) + partial; +}; +/** + * Write a 32 bit varint, signed or unsigned. Same as `varint64write(0, value, bytes)` + * + * Copyright 2008 Google Inc. All rights reserved. + * + * See https://github.com/protocolbuffers/protobuf/blob/1b18833f4f2a2f681f4e4a25cdf3b0a43115ec26/js/binary/encoder.js#L144 + */ +function varint32write(value, bytes) { + if (value >= 0) { + // write value as varint 32 + while (value > 0x7f) { + bytes.push((value & 0x7f) | 0x80); + value = value >>> 7; + } + bytes.push(value); + } + else { + for (let i = 0; i < 9; i++) { + bytes.push((value & 127) | 128); + value = value >> 7; + } + bytes.push(1); + } +} +/** + * Read an unsigned 32 bit varint. + * + * See https://github.com/protocolbuffers/protobuf/blob/8a71927d74a4ce34efe2d8769fda198f52d20d12/js/experimental/runtime/kernel/buffer_decoder.js#L220 + */ +function varint32read() { + let b = this.buf[this.pos++]; + let result = b & 0x7f; + if ((b & 0x80) == 0) { + this.assertBounds(); + return result; + } + b = this.buf[this.pos++]; + result |= (b & 0x7f) << 7; + if ((b & 0x80) == 0) { + this.assertBounds(); + return result; + } + b = this.buf[this.pos++]; + result |= (b & 0x7f) << 14; + if ((b & 0x80) == 0) { + this.assertBounds(); + return result; + } + b = this.buf[this.pos++]; + result |= (b & 0x7f) << 21; + if ((b & 0x80) == 0) { + this.assertBounds(); + return result; + } + // Extract only last 4 bits + b = this.buf[this.pos++]; + result |= (b & 0x0f) << 28; + for (let readBytes = 5; (b & 0x80) !== 0 && readBytes < 10; readBytes++) + b = this.buf[this.pos++]; + if ((b & 0x80) != 0) + throw new Error("invalid varint"); + this.assertBounds(); + // Result can have 32 bits, convert it to unsigned + return result >>> 0; +} + +;// CONCATENATED MODULE: ./node_modules/@bufbuild/protobuf/dist/esm/proto-int64.js +// Copyright 2021-2024 Buf Technologies, Inc. +// +// Licensed under the Apache License, Version 2.0 (the "License"); +// you may not use this file except in compliance with the License. +// You may obtain a copy of the License at +// +// http://www.apache.org/licenses/LICENSE-2.0 +// +// Unless required by applicable law or agreed to in writing, software +// distributed under the License is distributed on an "AS IS" BASIS, +// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. +// See the License for the specific language governing permissions and +// limitations under the License. + + +function makeInt64Support() { + const dv = new DataView(new ArrayBuffer(8)); + // note that Safari 14 implements BigInt, but not the DataView methods + const ok = typeof BigInt === "function" && + typeof dv.getBigInt64 === "function" && + typeof dv.getBigUint64 === "function" && + typeof dv.setBigInt64 === "function" && + typeof dv.setBigUint64 === "function" && + (typeof process != "object" || + typeof process.env != "object" || + process.env.BUF_BIGINT_DISABLE !== "1"); + if (ok) { + const MIN = BigInt("-9223372036854775808"), MAX = BigInt("9223372036854775807"), UMIN = BigInt("0"), UMAX = BigInt("18446744073709551615"); + return { + zero: BigInt(0), + supported: true, + parse(value) { + const bi = typeof value == "bigint" ? value : BigInt(value); + if (bi > MAX || bi < MIN) { + throw new Error(`int64 invalid: ${value}`); + } + return bi; + }, + uParse(value) { + const bi = typeof value == "bigint" ? value : BigInt(value); + if (bi > UMAX || bi < UMIN) { + throw new Error(`uint64 invalid: ${value}`); + } + return bi; + }, + enc(value) { + dv.setBigInt64(0, this.parse(value), true); + return { + lo: dv.getInt32(0, true), + hi: dv.getInt32(4, true), + }; + }, + uEnc(value) { + dv.setBigInt64(0, this.uParse(value), true); + return { + lo: dv.getInt32(0, true), + hi: dv.getInt32(4, true), + }; + }, + dec(lo, hi) { + dv.setInt32(0, lo, true); + dv.setInt32(4, hi, true); + return dv.getBigInt64(0, true); + }, + uDec(lo, hi) { + dv.setInt32(0, lo, true); + dv.setInt32(4, hi, true); + return dv.getBigUint64(0, true); + }, + }; + } + const assertInt64String = (value) => assert(/^-?[0-9]+$/.test(value), `int64 invalid: ${value}`); + const assertUInt64String = (value) => assert(/^[0-9]+$/.test(value), `uint64 invalid: ${value}`); + return { + zero: "0", + supported: false, + parse(value) { + if (typeof value != "string") { + value = value.toString(); + } + assertInt64String(value); + return value; + }, + uParse(value) { + if (typeof value != "string") { + value = value.toString(); + } + assertUInt64String(value); + return value; + }, + enc(value) { + if (typeof value != "string") { + value = value.toString(); + } + assertInt64String(value); + return int64FromString(value); + }, + uEnc(value) { + if (typeof value != "string") { + value = value.toString(); + } + assertUInt64String(value); + return int64FromString(value); + }, + dec(lo, hi) { + return int64ToString(lo, hi); + }, + uDec(lo, hi) { + return uInt64ToString(lo, hi); + }, + }; +} +const protoInt64 = makeInt64Support(); + +;// CONCATENATED MODULE: ./node_modules/@bufbuild/protobuf/dist/esm/scalar.js +// Copyright 2021-2024 Buf Technologies, Inc. +// +// Licensed under the Apache License, Version 2.0 (the "License"); +// you may not use this file except in compliance with the License. +// You may obtain a copy of the License at +// +// http://www.apache.org/licenses/LICENSE-2.0 +// +// Unless required by applicable law or agreed to in writing, software +// distributed under the License is distributed on an "AS IS" BASIS, +// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. +// See the License for the specific language governing permissions and +// limitations under the License. +/** + * Scalar value types. This is a subset of field types declared by protobuf + * enum google.protobuf.FieldDescriptorProto.Type The types GROUP and MESSAGE + * are omitted, but the numerical values are identical. + */ +var ScalarType; +(function (ScalarType) { + // 0 is reserved for errors. + // Order is weird for historical reasons. + ScalarType[ScalarType["DOUBLE"] = 1] = "DOUBLE"; + ScalarType[ScalarType["FLOAT"] = 2] = "FLOAT"; + // Not ZigZag encoded. Negative numbers take 10 bytes. Use TYPE_SINT64 if + // negative values are likely. + ScalarType[ScalarType["INT64"] = 3] = "INT64"; + ScalarType[ScalarType["UINT64"] = 4] = "UINT64"; + // Not ZigZag encoded. Negative numbers take 10 bytes. Use TYPE_SINT32 if + // negative values are likely. + ScalarType[ScalarType["INT32"] = 5] = "INT32"; + ScalarType[ScalarType["FIXED64"] = 6] = "FIXED64"; + ScalarType[ScalarType["FIXED32"] = 7] = "FIXED32"; + ScalarType[ScalarType["BOOL"] = 8] = "BOOL"; + ScalarType[ScalarType["STRING"] = 9] = "STRING"; + // Tag-delimited aggregate. + // Group type is deprecated and not supported in proto3. However, Proto3 + // implementations should still be able to parse the group wire format and + // treat group fields as unknown fields. + // TYPE_GROUP = 10, + // TYPE_MESSAGE = 11, // Length-delimited aggregate. + // New in version 2. + ScalarType[ScalarType["BYTES"] = 12] = "BYTES"; + ScalarType[ScalarType["UINT32"] = 13] = "UINT32"; + // TYPE_ENUM = 14, + ScalarType[ScalarType["SFIXED32"] = 15] = "SFIXED32"; + ScalarType[ScalarType["SFIXED64"] = 16] = "SFIXED64"; + ScalarType[ScalarType["SINT32"] = 17] = "SINT32"; + ScalarType[ScalarType["SINT64"] = 18] = "SINT64"; +})(ScalarType || (ScalarType = {})); +/** + * JavaScript representation of fields with 64 bit integral types (int64, uint64, + * sint64, fixed64, sfixed64). + * + * This is a subset of google.protobuf.FieldOptions.JSType, which defines JS_NORMAL, + * JS_STRING, and JS_NUMBER. Protobuf-ES uses BigInt by default, but will use + * String if `[jstype = JS_STRING]` is specified. + * + * ```protobuf + * uint64 field_a = 1; // BigInt + * uint64 field_b = 2 [jstype = JS_NORMAL]; // BigInt + * uint64 field_b = 2 [jstype = JS_NUMBER]; // BigInt + * uint64 field_b = 2 [jstype = JS_STRING]; // String + * ``` + */ +var LongType; +(function (LongType) { + /** + * Use JavaScript BigInt. + */ + LongType[LongType["BIGINT"] = 0] = "BIGINT"; + /** + * Use JavaScript String. + * + * Field option `[jstype = JS_STRING]`. + */ + LongType[LongType["STRING"] = 1] = "STRING"; +})(LongType || (LongType = {})); + +;// CONCATENATED MODULE: ./node_modules/@bufbuild/protobuf/dist/esm/private/scalars.js +// Copyright 2021-2024 Buf Technologies, Inc. +// +// Licensed under the Apache License, Version 2.0 (the "License"); +// you may not use this file except in compliance with the License. +// You may obtain a copy of the License at +// +// http://www.apache.org/licenses/LICENSE-2.0 +// +// Unless required by applicable law or agreed to in writing, software +// distributed under the License is distributed on an "AS IS" BASIS, +// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. +// See the License for the specific language governing permissions and +// limitations under the License. + + +/** + * Returns true if both scalar values are equal. + */ +function scalarEquals(type, a, b) { + if (a === b) { + // This correctly matches equal values except BYTES and (possibly) 64-bit integers. + return true; + } + // Special case BYTES - we need to compare each byte individually + if (type == ScalarType.BYTES) { + if (!(a instanceof Uint8Array) || !(b instanceof Uint8Array)) { + return false; + } + if (a.length !== b.length) { + return false; + } + for (let i = 0; i < a.length; i++) { + if (a[i] !== b[i]) { + return false; + } + } + return true; + } + // Special case 64-bit integers - we support number, string and bigint representation. + // eslint-disable-next-line @typescript-eslint/switch-exhaustiveness-check + switch (type) { + case ScalarType.UINT64: + case ScalarType.FIXED64: + case ScalarType.INT64: + case ScalarType.SFIXED64: + case ScalarType.SINT64: + // Loose comparison will match between 0n, 0 and "0". + return a == b; + } + // Anything that hasn't been caught by strict comparison or special cased + // BYTES and 64-bit integers is not equal. + return false; +} +/** + * Returns the zero value for the given scalar type. + */ +function scalarZeroValue(type, longType) { + switch (type) { + case ScalarType.BOOL: + return false; + case ScalarType.UINT64: + case ScalarType.FIXED64: + case ScalarType.INT64: + case ScalarType.SFIXED64: + case ScalarType.SINT64: + // eslint-disable-next-line @typescript-eslint/no-unsafe-enum-comparison -- acceptable since it's covered by tests + return (longType == 0 ? protoInt64.zero : "0"); + case ScalarType.DOUBLE: + case ScalarType.FLOAT: + return 0.0; + case ScalarType.BYTES: + return new Uint8Array(0); + case ScalarType.STRING: + return ""; + default: + // Handles INT32, UINT32, SINT32, FIXED32, SFIXED32. + // We do not use individual cases to save a few bytes code size. + return 0; + } +} +/** + * Returns true for a zero-value. For example, an integer has the zero-value `0`, + * a boolean is `false`, a string is `""`, and bytes is an empty Uint8Array. + * + * In proto3, zero-values are not written to the wire, unless the field is + * optional or repeated. + */ +function isScalarZeroValue(type, value) { + switch (type) { + case ScalarType.BOOL: + return value === false; + case ScalarType.STRING: + return value === ""; + case ScalarType.BYTES: + return value instanceof Uint8Array && !value.byteLength; + default: + return value == 0; // Loose comparison matches 0n, 0 and "0" + } +} + +;// CONCATENATED MODULE: ./node_modules/@bufbuild/protobuf/dist/esm/private/extensions.js +// Copyright 2021-2024 Buf Technologies, Inc. +// +// Licensed under the Apache License, Version 2.0 (the "License"); +// you may not use this file except in compliance with the License. +// You may obtain a copy of the License at +// +// http://www.apache.org/licenses/LICENSE-2.0 +// +// Unless required by applicable law or agreed to in writing, software +// distributed under the License is distributed on an "AS IS" BASIS, +// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. +// See the License for the specific language governing permissions and +// limitations under the License. + + +/** + * Create a new extension using the given runtime. + */ +function makeExtension(runtime, typeName, extendee, field) { + let fi; + return { + typeName, + extendee, + get field() { + if (!fi) { + const i = (typeof field == "function" ? field() : field); + i.name = typeName.split(".").pop(); + i.jsonName = `[${typeName}]`; + fi = runtime.util.newFieldList([i]).list()[0]; + } + return fi; + }, + runtime, + }; +} +/** + * Create a container that allows us to read extension fields into it with the + * same logic as regular fields. + */ +function createExtensionContainer(extension) { + const localName = extension.field.localName; + const container = Object.create(null); + container[localName] = initExtensionField(extension); + return [container, () => container[localName]]; +} +function initExtensionField(ext) { + const field = ext.field; + if (field.repeated) { + return []; + } + if (field.default !== undefined) { + return field.default; + } + switch (field.kind) { + case "enum": + return field.T.values[0].no; + case "scalar": + return scalarZeroValue(field.T, field.L); + case "message": + // eslint-disable-next-line no-case-declarations + const T = field.T, value = new T(); + return T.fieldWrapper ? T.fieldWrapper.unwrapField(value) : value; + case "map": + throw "map fields are not allowed to be extensions"; + } +} +/** + * Helper to filter unknown fields, optimized based on field type. + */ +function filterUnknownFields(unknownFields, field) { + if (!field.repeated && (field.kind == "enum" || field.kind == "scalar")) { + // singular scalar fields do not merge, we pick the last + for (let i = unknownFields.length - 1; i >= 0; --i) { + if (unknownFields[i].no == field.no) { + return [unknownFields[i]]; + } + } + return []; + } + return unknownFields.filter((uf) => uf.no === field.no); +} + +;// CONCATENATED MODULE: ./node_modules/@bufbuild/protobuf/dist/esm/proto-base64.js +// Copyright 2021-2024 Buf Technologies, Inc. +// +// Licensed under the Apache License, Version 2.0 (the "License"); +// you may not use this file except in compliance with the License. +// You may obtain a copy of the License at +// +// http://www.apache.org/licenses/LICENSE-2.0 +// +// Unless required by applicable law or agreed to in writing, software +// distributed under the License is distributed on an "AS IS" BASIS, +// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. +// See the License for the specific language governing permissions and +// limitations under the License. +/* eslint-disable @typescript-eslint/ban-ts-comment, @typescript-eslint/no-unnecessary-condition, prefer-const */ +// lookup table from base64 character to byte +let encTable = "ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/".split(""); +// lookup table from base64 character *code* to byte because lookup by number is fast +let decTable = []; +for (let i = 0; i < encTable.length; i++) + decTable[encTable[i].charCodeAt(0)] = i; +// support base64url variants +decTable["-".charCodeAt(0)] = encTable.indexOf("+"); +decTable["_".charCodeAt(0)] = encTable.indexOf("/"); +const proto_base64_protoBase64 = { + /** + * Decodes a base64 string to a byte array. + * + * - ignores white-space, including line breaks and tabs + * - allows inner padding (can decode concatenated base64 strings) + * - does not require padding + * - understands base64url encoding: + * "-" instead of "+", + * "_" instead of "/", + * no padding + */ + dec(base64Str) { + // estimate byte size, not accounting for inner padding and whitespace + let es = (base64Str.length * 3) / 4; + if (base64Str[base64Str.length - 2] == "=") + es -= 2; + else if (base64Str[base64Str.length - 1] == "=") + es -= 1; + let bytes = new Uint8Array(es), bytePos = 0, // position in byte array + groupPos = 0, // position in base64 group + b, // current byte + p = 0; // previous byte + for (let i = 0; i < base64Str.length; i++) { + b = decTable[base64Str.charCodeAt(i)]; + if (b === undefined) { + switch (base64Str[i]) { + // @ts-ignore TS7029: Fallthrough case in switch + case "=": + groupPos = 0; // reset state when padding found + // @ts-ignore TS7029: Fallthrough case in switch + case "\n": + case "\r": + case "\t": + case " ": + continue; // skip white-space, and padding + default: + throw Error("invalid base64 string."); + } + } + switch (groupPos) { + case 0: + p = b; + groupPos = 1; + break; + case 1: + bytes[bytePos++] = (p << 2) | ((b & 48) >> 4); + p = b; + groupPos = 2; + break; + case 2: + bytes[bytePos++] = ((p & 15) << 4) | ((b & 60) >> 2); + p = b; + groupPos = 3; + break; + case 3: + bytes[bytePos++] = ((p & 3) << 6) | b; + groupPos = 0; + break; + } + } + if (groupPos == 1) + throw Error("invalid base64 string."); + return bytes.subarray(0, bytePos); + }, + /** + * Encode a byte array to a base64 string. + */ + enc(bytes) { + let base64 = "", groupPos = 0, // position in base64 group + b, // current byte + p = 0; // carry over from previous byte + for (let i = 0; i < bytes.length; i++) { + b = bytes[i]; + switch (groupPos) { + case 0: + base64 += encTable[b >> 2]; + p = (b & 3) << 4; + groupPos = 1; + break; + case 1: + base64 += encTable[p | (b >> 4)]; + p = (b & 15) << 2; + groupPos = 2; + break; + case 2: + base64 += encTable[p | (b >> 6)]; + base64 += encTable[b & 63]; + groupPos = 0; + break; + } + } + // add output padding + if (groupPos) { + base64 += encTable[p]; + base64 += "="; + if (groupPos == 1) + base64 += "="; + } + return base64; + }, +}; + +;// CONCATENATED MODULE: ./node_modules/@bufbuild/protobuf/dist/esm/extension-accessor.js +// Copyright 2021-2024 Buf Technologies, Inc. +// +// Licensed under the Apache License, Version 2.0 (the "License"); +// you may not use this file except in compliance with the License. +// You may obtain a copy of the License at +// +// http://www.apache.org/licenses/LICENSE-2.0 +// +// Unless required by applicable law or agreed to in writing, software +// distributed under the License is distributed on an "AS IS" BASIS, +// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. +// See the License for the specific language governing permissions and +// limitations under the License. + + +/** + * Retrieve an extension value from a message. + * + * The function never returns undefined. Use hasExtension() to check whether an + * extension is set. If the extension is not set, this function returns the + * default value (if one was specified in the protobuf source), or the zero value + * (for example `0` for numeric types, `[]` for repeated extension fields, and + * an empty message instance for message fields). + * + * Extensions are stored as unknown fields on a message. To mutate an extension + * value, make sure to store the new value with setExtension() after mutating. + * + * If the extension does not extend the given message, an error is raised. + */ +function getExtension(message, extension, options) { + assertExtendee(extension, message); + const opt = extension.runtime.bin.makeReadOptions(options); + const ufs = filterUnknownFields(message.getType().runtime.bin.listUnknownFields(message), extension.field); + const [container, get] = createExtensionContainer(extension); + for (const uf of ufs) { + extension.runtime.bin.readField(container, opt.readerFactory(uf.data), extension.field, uf.wireType, opt); + } + return get(); +} +/** + * Set an extension value on a message. If the message already has a value for + * this extension, the value is replaced. + * + * If the extension does not extend the given message, an error is raised. + */ +function setExtension(message, extension, value, options) { + assertExtendee(extension, message); + const readOpt = extension.runtime.bin.makeReadOptions(options); + const writeOpt = extension.runtime.bin.makeWriteOptions(options); + if (hasExtension(message, extension)) { + const ufs = message + .getType() + .runtime.bin.listUnknownFields(message) + .filter((uf) => uf.no != extension.field.no); + message.getType().runtime.bin.discardUnknownFields(message); + for (const uf of ufs) { + message + .getType() + .runtime.bin.onUnknownField(message, uf.no, uf.wireType, uf.data); + } + } + const writer = writeOpt.writerFactory(); + let f = extension.field; + // Implicit presence does not apply to extensions, see https://github.com/protocolbuffers/protobuf/issues/8234 + // We patch the field info to use explicit presence: + if (!f.opt && !f.repeated && (f.kind == "enum" || f.kind == "scalar")) { + f = Object.assign(Object.assign({}, extension.field), { opt: true }); + } + extension.runtime.bin.writeField(f, value, writer, writeOpt); + const reader = readOpt.readerFactory(writer.finish()); + while (reader.pos < reader.len) { + const [no, wireType] = reader.tag(); + const data = reader.skip(wireType, no); + message.getType().runtime.bin.onUnknownField(message, no, wireType, data); + } +} +/** + * Remove an extension value from a message. + * + * If the extension does not extend the given message, an error is raised. + */ +function clearExtension(message, extension) { + assertExtendee(extension, message); + if (hasExtension(message, extension)) { + const bin = message.getType().runtime.bin; + const ufs = bin + .listUnknownFields(message) + .filter((uf) => uf.no != extension.field.no); + bin.discardUnknownFields(message); + for (const uf of ufs) { + bin.onUnknownField(message, uf.no, uf.wireType, uf.data); + } + } +} +/** + * Check whether an extension is set on a message. + */ +function hasExtension(message, extension) { + const messageType = message.getType(); + return (extension.extendee.typeName === messageType.typeName && + !!messageType.runtime.bin + .listUnknownFields(message) + .find((uf) => uf.no == extension.field.no)); +} +function assertExtendee(extension, message) { + assert(extension.extendee.typeName == message.getType().typeName, `extension ${extension.typeName} can only be applied to message ${extension.extendee.typeName}`); +} + +;// CONCATENATED MODULE: ./node_modules/@bufbuild/protobuf/dist/esm/private/reflect.js +// Copyright 2021-2024 Buf Technologies, Inc. +// +// Licensed under the Apache License, Version 2.0 (the "License"); +// you may not use this file except in compliance with the License. +// You may obtain a copy of the License at +// +// http://www.apache.org/licenses/LICENSE-2.0 +// +// Unless required by applicable law or agreed to in writing, software +// distributed under the License is distributed on an "AS IS" BASIS, +// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. +// See the License for the specific language governing permissions and +// limitations under the License. + +/** + * Returns true if the field is set. + */ +function isFieldSet(field, target) { + const localName = field.localName; + if (field.repeated) { + return target[localName].length > 0; + } + if (field.oneof) { + return target[field.oneof.localName].case === localName; // eslint-disable-line @typescript-eslint/no-unsafe-member-access + } + switch (field.kind) { + case "enum": + case "scalar": + if (field.opt || field.req) { + // explicit presence + return target[localName] !== undefined; + } + // implicit presence + if (field.kind == "enum") { + return target[localName] !== field.T.values[0].no; + } + return !isScalarZeroValue(field.T, target[localName]); + case "message": + return target[localName] !== undefined; + case "map": + return Object.keys(target[localName]).length > 0; // eslint-disable-line @typescript-eslint/no-unsafe-argument + } +} +/** + * Resets the field, so that isFieldSet() will return false. + */ +function clearField(field, target) { + const localName = field.localName; + const implicitPresence = !field.opt && !field.req; + if (field.repeated) { + target[localName] = []; + } + else if (field.oneof) { + target[field.oneof.localName] = { case: undefined }; + } + else { + switch (field.kind) { + case "map": + target[localName] = {}; + break; + case "enum": + target[localName] = implicitPresence ? field.T.values[0].no : undefined; + break; + case "scalar": + target[localName] = implicitPresence + ? scalarZeroValue(field.T, field.L) + : undefined; + break; + case "message": + target[localName] = undefined; + break; + } + } +} + +;// CONCATENATED MODULE: ./node_modules/@bufbuild/protobuf/dist/esm/is-message.js +// Copyright 2021-2024 Buf Technologies, Inc. +// +// Licensed under the Apache License, Version 2.0 (the "License"); +// you may not use this file except in compliance with the License. +// You may obtain a copy of the License at +// +// http://www.apache.org/licenses/LICENSE-2.0 +// +// Unless required by applicable law or agreed to in writing, software +// distributed under the License is distributed on an "AS IS" BASIS, +// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. +// See the License for the specific language governing permissions and +// limitations under the License. + +/** + * Check whether the given object is any subtype of Message or is a specific + * Message by passing the type. + * + * Just like `instanceof`, `isMessage` narrows the type. The advantage of + * `isMessage` is that it compares identity by the message type name, not by + * class identity. This makes it robust against the dual package hazard and + * similar situations, where the same message is duplicated. + * + * This function is _mostly_ equivalent to the `instanceof` operator. For + * example, `isMessage(foo, MyMessage)` is the same as `foo instanceof MyMessage`, + * and `isMessage(foo)` is the same as `foo instanceof Message`. In most cases, + * `isMessage` should be preferred over `instanceof`. + * + * However, due to the fact that `isMessage` does not use class identity, there + * are subtle differences between this function and `instanceof`. Notably, + * calling `isMessage` on an explicit type of Message will return false. + */ +function isMessage(arg, type) { + if (arg === null || typeof arg != "object") { + return false; + } + if (!Object.getOwnPropertyNames(Message.prototype).every((m) => m in arg && typeof arg[m] == "function")) { + return false; + } + const actualType = arg.getType(); + if (actualType === null || + typeof actualType != "function" || + !("typeName" in actualType) || + typeof actualType.typeName != "string") { + return false; + } + return type === undefined ? true : actualType.typeName == type.typeName; +} + +;// CONCATENATED MODULE: ./node_modules/@bufbuild/protobuf/dist/esm/private/field-wrapper.js +// Copyright 2021-2024 Buf Technologies, Inc. +// +// Licensed under the Apache License, Version 2.0 (the "License"); +// you may not use this file except in compliance with the License. +// You may obtain a copy of the License at +// +// http://www.apache.org/licenses/LICENSE-2.0 +// +// Unless required by applicable law or agreed to in writing, software +// distributed under the License is distributed on an "AS IS" BASIS, +// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. +// See the License for the specific language governing permissions and +// limitations under the License. + + + +/** + * Wrap a primitive message field value in its corresponding wrapper + * message. This function is idempotent. + */ +function wrapField(type, value) { + if (isMessage(value) || !type.fieldWrapper) { + return value; + } + return type.fieldWrapper.wrapField(value); +} +/** + * If the given field uses one of the well-known wrapper types, return + * the primitive type it wraps. + */ +function getUnwrappedFieldType(field) { + if (field.fieldKind !== "message") { + return undefined; + } + if (field.repeated) { + return undefined; + } + if (field.oneof != undefined) { + return undefined; + } + return wktWrapperToScalarType[field.message.typeName]; +} +const wktWrapperToScalarType = { + "google.protobuf.DoubleValue": ScalarType.DOUBLE, + "google.protobuf.FloatValue": ScalarType.FLOAT, + "google.protobuf.Int64Value": ScalarType.INT64, + "google.protobuf.UInt64Value": ScalarType.UINT64, + "google.protobuf.Int32Value": ScalarType.INT32, + "google.protobuf.UInt32Value": ScalarType.UINT32, + "google.protobuf.BoolValue": ScalarType.BOOL, + "google.protobuf.StringValue": ScalarType.STRING, + "google.protobuf.BytesValue": ScalarType.BYTES, +}; + +;// CONCATENATED MODULE: ./node_modules/@bufbuild/protobuf/dist/esm/private/json-format.js +// Copyright 2021-2024 Buf Technologies, Inc. +// +// Licensed under the Apache License, Version 2.0 (the "License"); +// you may not use this file except in compliance with the License. +// You may obtain a copy of the License at +// +// http://www.apache.org/licenses/LICENSE-2.0 +// +// Unless required by applicable law or agreed to in writing, software +// distributed under the License is distributed on an "AS IS" BASIS, +// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. +// See the License for the specific language governing permissions and +// limitations under the License. + + + + + + + + + + + + +/* eslint-disable no-case-declarations,@typescript-eslint/no-unsafe-argument,@typescript-eslint/no-unsafe-assignment,@typescript-eslint/no-unsafe-member-access,@typescript-eslint/no-unsafe-call */ +// Default options for parsing JSON. +const jsonReadDefaults = { + ignoreUnknownFields: false, +}; +// Default options for serializing to JSON. +const jsonWriteDefaults = { + emitDefaultValues: false, + enumAsInteger: false, + useProtoFieldName: false, + prettySpaces: 0, +}; +function makeReadOptions(options) { + return options ? Object.assign(Object.assign({}, jsonReadDefaults), options) : jsonReadDefaults; +} +function makeWriteOptions(options) { + return options ? Object.assign(Object.assign({}, jsonWriteDefaults), options) : jsonWriteDefaults; +} +const tokenNull = Symbol(); +const tokenIgnoredUnknownEnum = Symbol(); +function makeJsonFormat() { + return { + makeReadOptions, + makeWriteOptions, + readMessage(type, json, options, message) { + if (json == null || Array.isArray(json) || typeof json != "object") { + throw new Error(`cannot decode message ${type.typeName} from JSON: ${debugJsonValue(json)}`); + } + message = message !== null && message !== void 0 ? message : new type(); + const oneofSeen = new Map(); + const registry = options.typeRegistry; + for (const [jsonKey, jsonValue] of Object.entries(json)) { + const field = type.fields.findJsonName(jsonKey); + if (field) { + if (field.oneof) { + if (jsonValue === null && field.kind == "scalar") { + // see conformance test Required.Proto3.JsonInput.OneofFieldNull{First,Second} + continue; + } + const seen = oneofSeen.get(field.oneof); + if (seen !== undefined) { + throw new Error(`cannot decode message ${type.typeName} from JSON: multiple keys for oneof "${field.oneof.name}" present: "${seen}", "${jsonKey}"`); + } + oneofSeen.set(field.oneof, jsonKey); + } + readField(message, jsonValue, field, options, type); + } + else { + let found = false; + if ((registry === null || registry === void 0 ? void 0 : registry.findExtension) && + jsonKey.startsWith("[") && + jsonKey.endsWith("]")) { + const ext = registry.findExtension(jsonKey.substring(1, jsonKey.length - 1)); + if (ext && ext.extendee.typeName == type.typeName) { + found = true; + const [container, get] = createExtensionContainer(ext); + readField(container, jsonValue, ext.field, options, ext); + // We pass on the options as BinaryReadOptions/BinaryWriteOptions, + // so that users can bring their own binary reader and writer factories + // if necessary. + setExtension(message, ext, get(), options); + } + } + if (!found && !options.ignoreUnknownFields) { + throw new Error(`cannot decode message ${type.typeName} from JSON: key "${jsonKey}" is unknown`); + } + } + } + return message; + }, + writeMessage(message, options) { + const type = message.getType(); + const json = {}; + let field; + try { + for (field of type.fields.byNumber()) { + if (!isFieldSet(field, message)) { + // eslint-disable-next-line @typescript-eslint/strict-boolean-expressions + if (field.req) { + throw `required field not set`; + } + if (!options.emitDefaultValues) { + continue; + } + if (!canEmitFieldDefaultValue(field)) { + continue; + } + } + const value = field.oneof + ? message[field.oneof.localName].value + : message[field.localName]; + const jsonValue = writeField(field, value, options); + if (jsonValue !== undefined) { + json[options.useProtoFieldName ? field.name : field.jsonName] = + jsonValue; + } + } + const registry = options.typeRegistry; + if (registry === null || registry === void 0 ? void 0 : registry.findExtensionFor) { + for (const uf of type.runtime.bin.listUnknownFields(message)) { + const ext = registry.findExtensionFor(type.typeName, uf.no); + if (ext && hasExtension(message, ext)) { + // We pass on the options as BinaryReadOptions, so that users can bring their own + // binary reader factory if necessary. + const value = getExtension(message, ext, options); + const jsonValue = writeField(ext.field, value, options); + if (jsonValue !== undefined) { + json[ext.field.jsonName] = jsonValue; + } + } + } + } + } + catch (e) { + const m = field + ? `cannot encode field ${type.typeName}.${field.name} to JSON` + : `cannot encode message ${type.typeName} to JSON`; + const r = e instanceof Error ? e.message : String(e); + throw new Error(m + (r.length > 0 ? `: ${r}` : "")); + } + return json; + }, + readScalar(type, json, longType) { + // The signature of our internal function has changed. For backwards- + // compatibility, we support the old form that is part of the public API + // through the interface JsonFormat. + return readScalar(type, json, longType !== null && longType !== void 0 ? longType : LongType.BIGINT, true); + }, + writeScalar(type, value, emitDefaultValues) { + // The signature of our internal function has changed. For backwards- + // compatibility, we support the old form that is part of the public API + // through the interface JsonFormat. + if (value === undefined) { + return undefined; + } + if (emitDefaultValues || isScalarZeroValue(type, value)) { + return writeScalar(type, value); + } + return undefined; + }, + debug: debugJsonValue, + }; +} +function debugJsonValue(json) { + if (json === null) { + return "null"; + } + switch (typeof json) { + case "object": + return Array.isArray(json) ? "array" : "object"; + case "string": + return json.length > 100 ? "string" : `"${json.split('"').join('\\"')}"`; + default: + return String(json); + } +} +// Read a JSON value for a field. +// The "parentType" argument is only used to provide context in errors. +function readField(target, jsonValue, field, options, parentType) { + let localName = field.localName; + if (field.repeated) { + assert(field.kind != "map"); + if (jsonValue === null) { + return; + } + if (!Array.isArray(jsonValue)) { + throw new Error(`cannot decode field ${parentType.typeName}.${field.name} from JSON: ${debugJsonValue(jsonValue)}`); + } + const targetArray = target[localName]; + for (const jsonItem of jsonValue) { + if (jsonItem === null) { + throw new Error(`cannot decode field ${parentType.typeName}.${field.name} from JSON: ${debugJsonValue(jsonItem)}`); + } + switch (field.kind) { + case "message": + targetArray.push(field.T.fromJson(jsonItem, options)); + break; + case "enum": + const enumValue = readEnum(field.T, jsonItem, options.ignoreUnknownFields, true); + if (enumValue !== tokenIgnoredUnknownEnum) { + targetArray.push(enumValue); + } + break; + case "scalar": + try { + targetArray.push(readScalar(field.T, jsonItem, field.L, true)); + } + catch (e) { + let m = `cannot decode field ${parentType.typeName}.${field.name} from JSON: ${debugJsonValue(jsonItem)}`; + if (e instanceof Error && e.message.length > 0) { + m += `: ${e.message}`; + } + throw new Error(m); + } + break; + } + } + } + else if (field.kind == "map") { + if (jsonValue === null) { + return; + } + if (typeof jsonValue != "object" || Array.isArray(jsonValue)) { + throw new Error(`cannot decode field ${parentType.typeName}.${field.name} from JSON: ${debugJsonValue(jsonValue)}`); + } + const targetMap = target[localName]; + for (const [jsonMapKey, jsonMapValue] of Object.entries(jsonValue)) { + if (jsonMapValue === null) { + throw new Error(`cannot decode field ${parentType.typeName}.${field.name} from JSON: map value null`); + } + let key; + try { + key = readMapKey(field.K, jsonMapKey); + } + catch (e) { + let m = `cannot decode map key for field ${parentType.typeName}.${field.name} from JSON: ${debugJsonValue(jsonValue)}`; + if (e instanceof Error && e.message.length > 0) { + m += `: ${e.message}`; + } + throw new Error(m); + } + switch (field.V.kind) { + case "message": + targetMap[key] = field.V.T.fromJson(jsonMapValue, options); + break; + case "enum": + const enumValue = readEnum(field.V.T, jsonMapValue, options.ignoreUnknownFields, true); + if (enumValue !== tokenIgnoredUnknownEnum) { + targetMap[key] = enumValue; + } + break; + case "scalar": + try { + targetMap[key] = readScalar(field.V.T, jsonMapValue, LongType.BIGINT, true); + } + catch (e) { + let m = `cannot decode map value for field ${parentType.typeName}.${field.name} from JSON: ${debugJsonValue(jsonValue)}`; + if (e instanceof Error && e.message.length > 0) { + m += `: ${e.message}`; + } + throw new Error(m); + } + break; + } + } + } + else { + if (field.oneof) { + target = target[field.oneof.localName] = { case: localName }; + localName = "value"; + } + switch (field.kind) { + case "message": + const messageType = field.T; + if (jsonValue === null && + messageType.typeName != "google.protobuf.Value") { + return; + } + let currentValue = target[localName]; + if (isMessage(currentValue)) { + currentValue.fromJson(jsonValue, options); + } + else { + target[localName] = currentValue = messageType.fromJson(jsonValue, options); + if (messageType.fieldWrapper && !field.oneof) { + target[localName] = + messageType.fieldWrapper.unwrapField(currentValue); + } + } + break; + case "enum": + const enumValue = readEnum(field.T, jsonValue, options.ignoreUnknownFields, false); + switch (enumValue) { + case tokenNull: + clearField(field, target); + break; + case tokenIgnoredUnknownEnum: + break; + default: + target[localName] = enumValue; + break; + } + break; + case "scalar": + try { + const scalarValue = readScalar(field.T, jsonValue, field.L, false); + switch (scalarValue) { + case tokenNull: + clearField(field, target); + break; + default: + target[localName] = scalarValue; + break; + } + } + catch (e) { + let m = `cannot decode field ${parentType.typeName}.${field.name} from JSON: ${debugJsonValue(jsonValue)}`; + if (e instanceof Error && e.message.length > 0) { + m += `: ${e.message}`; + } + throw new Error(m); + } + break; + } + } +} +function readMapKey(type, json) { + if (type === ScalarType.BOOL) { + // eslint-disable-next-line @typescript-eslint/switch-exhaustiveness-check + switch (json) { + case "true": + json = true; + break; + case "false": + json = false; + break; + } + } + return readScalar(type, json, LongType.BIGINT, true).toString(); +} +function readScalar(type, json, longType, nullAsZeroValue) { + if (json === null) { + if (nullAsZeroValue) { + return scalarZeroValue(type, longType); + } + return tokenNull; + } + // every valid case in the switch below returns, and every fall + // through is regarded as a failure. + switch (type) { + // float, double: JSON value will be a number or one of the special string values "NaN", "Infinity", and "-Infinity". + // Either numbers or strings are accepted. Exponent notation is also accepted. + case ScalarType.DOUBLE: + case ScalarType.FLOAT: + if (json === "NaN") + return Number.NaN; + if (json === "Infinity") + return Number.POSITIVE_INFINITY; + if (json === "-Infinity") + return Number.NEGATIVE_INFINITY; + if (json === "") { + // empty string is not a number + break; + } + if (typeof json == "string" && json.trim().length !== json.length) { + // extra whitespace + break; + } + if (typeof json != "string" && typeof json != "number") { + break; + } + const float = Number(json); + if (Number.isNaN(float)) { + // not a number + break; + } + if (!Number.isFinite(float)) { + // infinity and -infinity are handled by string representation above, so this is an error + break; + } + if (type == ScalarType.FLOAT) + assertFloat32(float); + return float; + // int32, fixed32, uint32: JSON value will be a decimal number. Either numbers or strings are accepted. + case ScalarType.INT32: + case ScalarType.FIXED32: + case ScalarType.SFIXED32: + case ScalarType.SINT32: + case ScalarType.UINT32: + let int32; + if (typeof json == "number") + int32 = json; + else if (typeof json == "string" && json.length > 0) { + if (json.trim().length === json.length) + int32 = Number(json); + } + if (int32 === undefined) + break; + if (type == ScalarType.UINT32 || type == ScalarType.FIXED32) + assertUInt32(int32); + else + assertInt32(int32); + return int32; + // int64, fixed64, uint64: JSON value will be a decimal string. Either numbers or strings are accepted. + case ScalarType.INT64: + case ScalarType.SFIXED64: + case ScalarType.SINT64: + if (typeof json != "number" && typeof json != "string") + break; + const long = protoInt64.parse(json); + // eslint-disable-next-line @typescript-eslint/strict-boolean-expressions + return longType ? long.toString() : long; + case ScalarType.FIXED64: + case ScalarType.UINT64: + if (typeof json != "number" && typeof json != "string") + break; + const uLong = protoInt64.uParse(json); + // eslint-disable-next-line @typescript-eslint/strict-boolean-expressions + return longType ? uLong.toString() : uLong; + // bool: + case ScalarType.BOOL: + if (typeof json !== "boolean") + break; + return json; + // string: + case ScalarType.STRING: + if (typeof json !== "string") { + break; + } + // A string must always contain UTF-8 encoded or 7-bit ASCII. + // We validate with encodeURIComponent, which appears to be the fastest widely available option. + try { + encodeURIComponent(json); + } + catch (e) { + throw new Error("invalid UTF8"); + } + return json; + // bytes: JSON value will be the data encoded as a string using standard base64 encoding with paddings. + // Either standard or URL-safe base64 encoding with/without paddings are accepted. + case ScalarType.BYTES: + if (json === "") + return new Uint8Array(0); + if (typeof json !== "string") + break; + return proto_base64_protoBase64.dec(json); + } + throw new Error(); +} +function readEnum(type, json, ignoreUnknownFields, nullAsZeroValue) { + if (json === null) { + if (type.typeName == "google.protobuf.NullValue") { + return 0; // google.protobuf.NullValue.NULL_VALUE = 0 + } + return nullAsZeroValue ? type.values[0].no : tokenNull; + } + // eslint-disable-next-line @typescript-eslint/switch-exhaustiveness-check + switch (typeof json) { + case "number": + if (Number.isInteger(json)) { + return json; + } + break; + case "string": + const value = type.findName(json); + if (value !== undefined) { + return value.no; + } + if (ignoreUnknownFields) { + return tokenIgnoredUnknownEnum; + } + break; + } + throw new Error(`cannot decode enum ${type.typeName} from JSON: ${debugJsonValue(json)}`); +} +// Decide whether an unset field should be emitted with JSON write option `emitDefaultValues` +function canEmitFieldDefaultValue(field) { + if (field.repeated || field.kind == "map") { + // maps are {}, repeated fields are [] + return true; + } + if (field.oneof) { + // oneof fields are never emitted + return false; + } + if (field.kind == "message") { + // singular message field are allowed to emit JSON null, but we do not + return false; + } + // eslint-disable-next-line @typescript-eslint/strict-boolean-expressions + if (field.opt || field.req) { + // the field uses explicit presence, so we cannot emit a zero value + return false; + } + return true; +} +function writeField(field, value, options) { + if (field.kind == "map") { + assert(typeof value == "object" && value != null); + const jsonObj = {}; + const entries = Object.entries(value); + switch (field.V.kind) { + case "scalar": + for (const [entryKey, entryValue] of entries) { + jsonObj[entryKey.toString()] = writeScalar(field.V.T, entryValue); // JSON standard allows only (double quoted) string as property key + } + break; + case "message": + for (const [entryKey, entryValue] of entries) { + // JSON standard allows only (double quoted) string as property key + jsonObj[entryKey.toString()] = entryValue.toJson(options); + } + break; + case "enum": + const enumType = field.V.T; + for (const [entryKey, entryValue] of entries) { + // JSON standard allows only (double quoted) string as property key + jsonObj[entryKey.toString()] = writeEnum(enumType, entryValue, options.enumAsInteger); + } + break; + } + return options.emitDefaultValues || entries.length > 0 + ? jsonObj + : undefined; + } + if (field.repeated) { + assert(Array.isArray(value)); + const jsonArr = []; + switch (field.kind) { + case "scalar": + for (let i = 0; i < value.length; i++) { + jsonArr.push(writeScalar(field.T, value[i])); + } + break; + case "enum": + for (let i = 0; i < value.length; i++) { + jsonArr.push(writeEnum(field.T, value[i], options.enumAsInteger)); + } + break; + case "message": + for (let i = 0; i < value.length; i++) { + jsonArr.push(value[i].toJson(options)); + } + break; + } + return options.emitDefaultValues || jsonArr.length > 0 + ? jsonArr + : undefined; + } + switch (field.kind) { + case "scalar": + return writeScalar(field.T, value); + case "enum": + return writeEnum(field.T, value, options.enumAsInteger); + case "message": + return wrapField(field.T, value).toJson(options); + } +} +function writeEnum(type, value, enumAsInteger) { + var _a; + assert(typeof value == "number"); + if (type.typeName == "google.protobuf.NullValue") { + return null; + } + if (enumAsInteger) { + return value; + } + const val = type.findNumber(value); + return (_a = val === null || val === void 0 ? void 0 : val.name) !== null && _a !== void 0 ? _a : value; // if we don't know the enum value, just return the number +} +function writeScalar(type, value) { + switch (type) { + // int32, fixed32, uint32: JSON value will be a decimal number. Either numbers or strings are accepted. + case ScalarType.INT32: + case ScalarType.SFIXED32: + case ScalarType.SINT32: + case ScalarType.FIXED32: + case ScalarType.UINT32: + assert(typeof value == "number"); + return value; + // float, double: JSON value will be a number or one of the special string values "NaN", "Infinity", and "-Infinity". + // Either numbers or strings are accepted. Exponent notation is also accepted. + case ScalarType.FLOAT: + // assertFloat32(value); + case ScalarType.DOUBLE: // eslint-disable-line no-fallthrough + assert(typeof value == "number"); + if (Number.isNaN(value)) + return "NaN"; + if (value === Number.POSITIVE_INFINITY) + return "Infinity"; + if (value === Number.NEGATIVE_INFINITY) + return "-Infinity"; + return value; + // string: + case ScalarType.STRING: + assert(typeof value == "string"); + return value; + // bool: + case ScalarType.BOOL: + assert(typeof value == "boolean"); + return value; + // JSON value will be a decimal string. Either numbers or strings are accepted. + case ScalarType.UINT64: + case ScalarType.FIXED64: + case ScalarType.INT64: + case ScalarType.SFIXED64: + case ScalarType.SINT64: + assert(typeof value == "bigint" || + typeof value == "string" || + typeof value == "number"); + return value.toString(); + // bytes: JSON value will be the data encoded as a string using standard base64 encoding with paddings. + // Either standard or URL-safe base64 encoding with/without paddings are accepted. + case ScalarType.BYTES: + assert(value instanceof Uint8Array); + return proto_base64_protoBase64.enc(value); + } +} + +;// CONCATENATED MODULE: ./node_modules/@bufbuild/protobuf/dist/esm/binary-encoding.js +// Copyright 2021-2024 Buf Technologies, Inc. +// +// Licensed under the Apache License, Version 2.0 (the "License"); +// you may not use this file except in compliance with the License. +// You may obtain a copy of the License at +// +// http://www.apache.org/licenses/LICENSE-2.0 +// +// Unless required by applicable law or agreed to in writing, software +// distributed under the License is distributed on an "AS IS" BASIS, +// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. +// See the License for the specific language governing permissions and +// limitations under the License. + + + +/* eslint-disable prefer-const,no-case-declarations,@typescript-eslint/restrict-plus-operands */ +/** + * Protobuf binary format wire types. + * + * A wire type provides just enough information to find the length of the + * following value. + * + * See https://developers.google.com/protocol-buffers/docs/encoding#structure + */ +var WireType; +(function (WireType) { + /** + * Used for int32, int64, uint32, uint64, sint32, sint64, bool, enum + */ + WireType[WireType["Varint"] = 0] = "Varint"; + /** + * Used for fixed64, sfixed64, double. + * Always 8 bytes with little-endian byte order. + */ + WireType[WireType["Bit64"] = 1] = "Bit64"; + /** + * Used for string, bytes, embedded messages, packed repeated fields + * + * Only repeated numeric types (types which use the varint, 32-bit, + * or 64-bit wire types) can be packed. In proto3, such fields are + * packed by default. + */ + WireType[WireType["LengthDelimited"] = 2] = "LengthDelimited"; + /** + * Start of a tag-delimited aggregate, such as a proto2 group, or a message + * in editions with message_encoding = DELIMITED. + */ + WireType[WireType["StartGroup"] = 3] = "StartGroup"; + /** + * End of a tag-delimited aggregate. + */ + WireType[WireType["EndGroup"] = 4] = "EndGroup"; + /** + * Used for fixed32, sfixed32, float. + * Always 4 bytes with little-endian byte order. + */ + WireType[WireType["Bit32"] = 5] = "Bit32"; +})(WireType || (WireType = {})); +class BinaryWriter { + constructor(textEncoder) { + /** + * Previous fork states. + */ + this.stack = []; + this.textEncoder = textEncoder !== null && textEncoder !== void 0 ? textEncoder : new TextEncoder(); + this.chunks = []; + this.buf = []; + } + /** + * Return all bytes written and reset this writer. + */ + finish() { + this.chunks.push(new Uint8Array(this.buf)); // flush the buffer + let len = 0; + for (let i = 0; i < this.chunks.length; i++) + len += this.chunks[i].length; + let bytes = new Uint8Array(len); + let offset = 0; + for (let i = 0; i < this.chunks.length; i++) { + bytes.set(this.chunks[i], offset); + offset += this.chunks[i].length; + } + this.chunks = []; + return bytes; + } + /** + * Start a new fork for length-delimited data like a message + * or a packed repeated field. + * + * Must be joined later with `join()`. + */ + fork() { + this.stack.push({ chunks: this.chunks, buf: this.buf }); + this.chunks = []; + this.buf = []; + return this; + } + /** + * Join the last fork. Write its length and bytes, then + * return to the previous state. + */ + join() { + // get chunk of fork + let chunk = this.finish(); + // restore previous state + let prev = this.stack.pop(); + if (!prev) + throw new Error("invalid state, fork stack empty"); + this.chunks = prev.chunks; + this.buf = prev.buf; + // write length of chunk as varint + this.uint32(chunk.byteLength); + return this.raw(chunk); + } + /** + * Writes a tag (field number and wire type). + * + * Equivalent to `uint32( (fieldNo << 3 | type) >>> 0 )`. + * + * Generated code should compute the tag ahead of time and call `uint32()`. + */ + tag(fieldNo, type) { + return this.uint32(((fieldNo << 3) | type) >>> 0); + } + /** + * Write a chunk of raw bytes. + */ + raw(chunk) { + if (this.buf.length) { + this.chunks.push(new Uint8Array(this.buf)); + this.buf = []; + } + this.chunks.push(chunk); + return this; + } + /** + * Write a `uint32` value, an unsigned 32 bit varint. + */ + uint32(value) { + assertUInt32(value); + // write value as varint 32, inlined for speed + while (value > 0x7f) { + this.buf.push((value & 0x7f) | 0x80); + value = value >>> 7; + } + this.buf.push(value); + return this; + } + /** + * Write a `int32` value, a signed 32 bit varint. + */ + int32(value) { + assertInt32(value); + varint32write(value, this.buf); + return this; + } + /** + * Write a `bool` value, a variant. + */ + bool(value) { + this.buf.push(value ? 1 : 0); + return this; + } + /** + * Write a `bytes` value, length-delimited arbitrary data. + */ + bytes(value) { + this.uint32(value.byteLength); // write length of chunk as varint + return this.raw(value); + } + /** + * Write a `string` value, length-delimited data converted to UTF-8 text. + */ + string(value) { + let chunk = this.textEncoder.encode(value); + this.uint32(chunk.byteLength); // write length of chunk as varint + return this.raw(chunk); + } + /** + * Write a `float` value, 32-bit floating point number. + */ + float(value) { + assertFloat32(value); + let chunk = new Uint8Array(4); + new DataView(chunk.buffer).setFloat32(0, value, true); + return this.raw(chunk); + } + /** + * Write a `double` value, a 64-bit floating point number. + */ + double(value) { + let chunk = new Uint8Array(8); + new DataView(chunk.buffer).setFloat64(0, value, true); + return this.raw(chunk); + } + /** + * Write a `fixed32` value, an unsigned, fixed-length 32-bit integer. + */ + fixed32(value) { + assertUInt32(value); + let chunk = new Uint8Array(4); + new DataView(chunk.buffer).setUint32(0, value, true); + return this.raw(chunk); + } + /** + * Write a `sfixed32` value, a signed, fixed-length 32-bit integer. + */ + sfixed32(value) { + assertInt32(value); + let chunk = new Uint8Array(4); + new DataView(chunk.buffer).setInt32(0, value, true); + return this.raw(chunk); + } + /** + * Write a `sint32` value, a signed, zigzag-encoded 32-bit varint. + */ + sint32(value) { + assertInt32(value); + // zigzag encode + value = ((value << 1) ^ (value >> 31)) >>> 0; + varint32write(value, this.buf); + return this; + } + /** + * Write a `fixed64` value, a signed, fixed-length 64-bit integer. + */ + sfixed64(value) { + let chunk = new Uint8Array(8), view = new DataView(chunk.buffer), tc = protoInt64.enc(value); + view.setInt32(0, tc.lo, true); + view.setInt32(4, tc.hi, true); + return this.raw(chunk); + } + /** + * Write a `fixed64` value, an unsigned, fixed-length 64 bit integer. + */ + fixed64(value) { + let chunk = new Uint8Array(8), view = new DataView(chunk.buffer), tc = protoInt64.uEnc(value); + view.setInt32(0, tc.lo, true); + view.setInt32(4, tc.hi, true); + return this.raw(chunk); + } + /** + * Write a `int64` value, a signed 64-bit varint. + */ + int64(value) { + let tc = protoInt64.enc(value); + varint64write(tc.lo, tc.hi, this.buf); + return this; + } + /** + * Write a `sint64` value, a signed, zig-zag-encoded 64-bit varint. + */ + sint64(value) { + let tc = protoInt64.enc(value), + // zigzag encode + sign = tc.hi >> 31, lo = (tc.lo << 1) ^ sign, hi = ((tc.hi << 1) | (tc.lo >>> 31)) ^ sign; + varint64write(lo, hi, this.buf); + return this; + } + /** + * Write a `uint64` value, an unsigned 64-bit varint. + */ + uint64(value) { + let tc = protoInt64.uEnc(value); + varint64write(tc.lo, tc.hi, this.buf); + return this; + } +} +class BinaryReader { + constructor(buf, textDecoder) { + this.varint64 = varint64read; // dirty cast for `this` + /** + * Read a `uint32` field, an unsigned 32 bit varint. + */ + this.uint32 = varint32read; // dirty cast for `this` and access to protected `buf` + this.buf = buf; + this.len = buf.length; + this.pos = 0; + this.view = new DataView(buf.buffer, buf.byteOffset, buf.byteLength); + this.textDecoder = textDecoder !== null && textDecoder !== void 0 ? textDecoder : new TextDecoder(); + } + /** + * Reads a tag - field number and wire type. + */ + tag() { + let tag = this.uint32(), fieldNo = tag >>> 3, wireType = tag & 7; + if (fieldNo <= 0 || wireType < 0 || wireType > 5) + throw new Error("illegal tag: field no " + fieldNo + " wire type " + wireType); + return [fieldNo, wireType]; + } + /** + * Skip one element and return the skipped data. + * + * When skipping StartGroup, provide the tags field number to check for + * matching field number in the EndGroup tag. + */ + skip(wireType, fieldNo) { + let start = this.pos; + switch (wireType) { + case WireType.Varint: + while (this.buf[this.pos++] & 0x80) { + // ignore + } + break; + // eslint-disable-next-line + // @ts-ignore TS7029: Fallthrough case in switch + case WireType.Bit64: + this.pos += 4; + // eslint-disable-next-line + // @ts-ignore TS7029: Fallthrough case in switch + case WireType.Bit32: + this.pos += 4; + break; + case WireType.LengthDelimited: + let len = this.uint32(); + this.pos += len; + break; + case WireType.StartGroup: + for (;;) { + const [fn, wt] = this.tag(); + if (wt === WireType.EndGroup) { + if (fieldNo !== undefined && fn !== fieldNo) { + throw new Error("invalid end group tag"); + } + break; + } + this.skip(wt, fn); + } + break; + default: + throw new Error("cant skip wire type " + wireType); + } + this.assertBounds(); + return this.buf.subarray(start, this.pos); + } + /** + * Throws error if position in byte array is out of range. + */ + assertBounds() { + if (this.pos > this.len) + throw new RangeError("premature EOF"); + } + /** + * Read a `int32` field, a signed 32 bit varint. + */ + int32() { + return this.uint32() | 0; + } + /** + * Read a `sint32` field, a signed, zigzag-encoded 32-bit varint. + */ + sint32() { + let zze = this.uint32(); + // decode zigzag + return (zze >>> 1) ^ -(zze & 1); + } + /** + * Read a `int64` field, a signed 64-bit varint. + */ + int64() { + return protoInt64.dec(...this.varint64()); + } + /** + * Read a `uint64` field, an unsigned 64-bit varint. + */ + uint64() { + return protoInt64.uDec(...this.varint64()); + } + /** + * Read a `sint64` field, a signed, zig-zag-encoded 64-bit varint. + */ + sint64() { + let [lo, hi] = this.varint64(); + // decode zig zag + let s = -(lo & 1); + lo = ((lo >>> 1) | ((hi & 1) << 31)) ^ s; + hi = (hi >>> 1) ^ s; + return protoInt64.dec(lo, hi); + } + /** + * Read a `bool` field, a variant. + */ + bool() { + let [lo, hi] = this.varint64(); + return lo !== 0 || hi !== 0; + } + /** + * Read a `fixed32` field, an unsigned, fixed-length 32-bit integer. + */ + fixed32() { + return this.view.getUint32((this.pos += 4) - 4, true); + } + /** + * Read a `sfixed32` field, a signed, fixed-length 32-bit integer. + */ + sfixed32() { + return this.view.getInt32((this.pos += 4) - 4, true); + } + /** + * Read a `fixed64` field, an unsigned, fixed-length 64 bit integer. + */ + fixed64() { + return protoInt64.uDec(this.sfixed32(), this.sfixed32()); + } + /** + * Read a `fixed64` field, a signed, fixed-length 64-bit integer. + */ + sfixed64() { + return protoInt64.dec(this.sfixed32(), this.sfixed32()); + } + /** + * Read a `float` field, 32-bit floating point number. + */ + float() { + return this.view.getFloat32((this.pos += 4) - 4, true); + } + /** + * Read a `double` field, a 64-bit floating point number. + */ + double() { + return this.view.getFloat64((this.pos += 8) - 8, true); + } + /** + * Read a `bytes` field, length-delimited arbitrary data. + */ + bytes() { + let len = this.uint32(), start = this.pos; + this.pos += len; + this.assertBounds(); + return this.buf.subarray(start, start + len); + } + /** + * Read a `string` field, length-delimited data converted to UTF-8 text. + */ + string() { + return this.textDecoder.decode(this.bytes()); + } +} + +;// CONCATENATED MODULE: ./node_modules/@bufbuild/protobuf/dist/esm/private/binary-format.js +// Copyright 2021-2024 Buf Technologies, Inc. +// +// Licensed under the Apache License, Version 2.0 (the "License"); +// you may not use this file except in compliance with the License. +// You may obtain a copy of the License at +// +// http://www.apache.org/licenses/LICENSE-2.0 +// +// Unless required by applicable law or agreed to in writing, software +// distributed under the License is distributed on an "AS IS" BASIS, +// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. +// See the License for the specific language governing permissions and +// limitations under the License. + + + + + + + + +/* eslint-disable prefer-const,no-case-declarations,@typescript-eslint/no-explicit-any,@typescript-eslint/no-unsafe-argument,@typescript-eslint/no-unsafe-assignment,@typescript-eslint/no-unsafe-member-access,@typescript-eslint/no-unsafe-call,@typescript-eslint/no-unsafe-return */ +const unknownFieldsSymbol = Symbol("@bufbuild/protobuf/unknown-fields"); +// Default options for parsing binary data. +const readDefaults = { + readUnknownFields: true, + readerFactory: (bytes) => new BinaryReader(bytes), +}; +// Default options for serializing binary data. +const writeDefaults = { + writeUnknownFields: true, + writerFactory: () => new BinaryWriter(), +}; +function binary_format_makeReadOptions(options) { + return options ? Object.assign(Object.assign({}, readDefaults), options) : readDefaults; +} +function binary_format_makeWriteOptions(options) { + return options ? Object.assign(Object.assign({}, writeDefaults), options) : writeDefaults; +} +function makeBinaryFormat() { + return { + makeReadOptions: binary_format_makeReadOptions, + makeWriteOptions: binary_format_makeWriteOptions, + listUnknownFields(message) { + var _a; + return (_a = message[unknownFieldsSymbol]) !== null && _a !== void 0 ? _a : []; + }, + discardUnknownFields(message) { + delete message[unknownFieldsSymbol]; + }, + writeUnknownFields(message, writer) { + const m = message; + const c = m[unknownFieldsSymbol]; + if (c) { + for (const f of c) { + writer.tag(f.no, f.wireType).raw(f.data); + } + } + }, + onUnknownField(message, no, wireType, data) { + const m = message; + if (!Array.isArray(m[unknownFieldsSymbol])) { + m[unknownFieldsSymbol] = []; + } + m[unknownFieldsSymbol].push({ no, wireType, data }); + }, + readMessage(message, reader, lengthOrEndTagFieldNo, options, delimitedMessageEncoding) { + const type = message.getType(); + // eslint-disable-next-line @typescript-eslint/strict-boolean-expressions + const end = delimitedMessageEncoding + ? reader.len + : reader.pos + lengthOrEndTagFieldNo; + let fieldNo, wireType; + while (reader.pos < end) { + [fieldNo, wireType] = reader.tag(); + if (delimitedMessageEncoding === true && + wireType == WireType.EndGroup) { + break; + } + const field = type.fields.find(fieldNo); + if (!field) { + const data = reader.skip(wireType, fieldNo); + if (options.readUnknownFields) { + this.onUnknownField(message, fieldNo, wireType, data); + } + continue; + } + binary_format_readField(message, reader, field, wireType, options); + } + if (delimitedMessageEncoding && // eslint-disable-line @typescript-eslint/strict-boolean-expressions + (wireType != WireType.EndGroup || fieldNo !== lengthOrEndTagFieldNo)) { + throw new Error(`invalid end group tag`); + } + }, + readField: binary_format_readField, + writeMessage(message, writer, options) { + const type = message.getType(); + for (const field of type.fields.byNumber()) { + if (!isFieldSet(field, message)) { + if (field.req) { + throw new Error(`cannot encode field ${type.typeName}.${field.name} to binary: required field not set`); + } + continue; + } + const value = field.oneof + ? message[field.oneof.localName].value + : message[field.localName]; + binary_format_writeField(field, value, writer, options); + } + if (options.writeUnknownFields) { + this.writeUnknownFields(message, writer); + } + return writer; + }, + writeField(field, value, writer, options) { + // The behavior of our internal function has changed, it does no longer + // accept `undefined` values for singular scalar and map. + // For backwards-compatibility, we support the old form that is part of + // the public API through the interface BinaryFormat. + if (value === undefined) { + return undefined; + } + binary_format_writeField(field, value, writer, options); + }, + }; +} +function binary_format_readField(target, // eslint-disable-line @typescript-eslint/no-explicit-any -- `any` is the best choice for dynamic access +reader, field, wireType, options) { + let { repeated, localName } = field; + if (field.oneof) { + target = target[field.oneof.localName]; + if (target.case != localName) { + delete target.value; + } + target.case = localName; + localName = "value"; + } + switch (field.kind) { + case "scalar": + case "enum": + const scalarType = field.kind == "enum" ? ScalarType.INT32 : field.T; + let read = binary_format_readScalar; + // eslint-disable-next-line @typescript-eslint/no-unsafe-enum-comparison -- acceptable since it's covered by tests + if (field.kind == "scalar" && field.L > 0) { + read = readScalarLTString; + } + if (repeated) { + let arr = target[localName]; // safe to assume presence of array, oneof cannot contain repeated values + const isPacked = wireType == WireType.LengthDelimited && + scalarType != ScalarType.STRING && + scalarType != ScalarType.BYTES; + if (isPacked) { + let e = reader.uint32() + reader.pos; + while (reader.pos < e) { + arr.push(read(reader, scalarType)); + } + } + else { + arr.push(read(reader, scalarType)); + } + } + else { + target[localName] = read(reader, scalarType); + } + break; + case "message": + const messageType = field.T; + if (repeated) { + // safe to assume presence of array, oneof cannot contain repeated values + target[localName].push(readMessageField(reader, new messageType(), options, field)); + } + else { + if (isMessage(target[localName])) { + readMessageField(reader, target[localName], options, field); + } + else { + target[localName] = readMessageField(reader, new messageType(), options, field); + if (messageType.fieldWrapper && !field.oneof && !field.repeated) { + target[localName] = messageType.fieldWrapper.unwrapField(target[localName]); + } + } + } + break; + case "map": + let [mapKey, mapVal] = readMapEntry(field, reader, options); + // safe to assume presence of map object, oneof cannot contain repeated values + target[localName][mapKey] = mapVal; + break; + } +} +// Read a message, avoiding MessageType.fromBinary() to re-use the +// BinaryReadOptions and the IBinaryReader. +function readMessageField(reader, message, options, field) { + const format = message.getType().runtime.bin; + const delimited = field === null || field === void 0 ? void 0 : field.delimited; + format.readMessage(message, reader, delimited ? field.no : reader.uint32(), // eslint-disable-line @typescript-eslint/strict-boolean-expressions + options, delimited); + return message; +} +// Read a map field, expecting key field = 1, value field = 2 +function readMapEntry(field, reader, options) { + const length = reader.uint32(), end = reader.pos + length; + let key, val; + while (reader.pos < end) { + const [fieldNo] = reader.tag(); + switch (fieldNo) { + case 1: + key = binary_format_readScalar(reader, field.K); + break; + case 2: + switch (field.V.kind) { + case "scalar": + val = binary_format_readScalar(reader, field.V.T); + break; + case "enum": + val = reader.int32(); + break; + case "message": + val = readMessageField(reader, new field.V.T(), options, undefined); + break; + } + break; + } + } + if (key === undefined) { + key = scalarZeroValue(field.K, LongType.BIGINT); + } + if (typeof key != "string" && typeof key != "number") { + key = key.toString(); + } + if (val === undefined) { + switch (field.V.kind) { + case "scalar": + val = scalarZeroValue(field.V.T, LongType.BIGINT); + break; + case "enum": + val = field.V.T.values[0].no; + break; + case "message": + val = new field.V.T(); + break; + } + } + return [key, val]; +} +// Read a scalar value, but return 64 bit integral types (int64, uint64, +// sint64, fixed64, sfixed64) as string instead of bigint. +function readScalarLTString(reader, type) { + const v = binary_format_readScalar(reader, type); + return typeof v == "bigint" ? v.toString() : v; +} +// Does not use scalarTypeInfo() for better performance. +function binary_format_readScalar(reader, type) { + switch (type) { + case ScalarType.STRING: + return reader.string(); + case ScalarType.BOOL: + return reader.bool(); + case ScalarType.DOUBLE: + return reader.double(); + case ScalarType.FLOAT: + return reader.float(); + case ScalarType.INT32: + return reader.int32(); + case ScalarType.INT64: + return reader.int64(); + case ScalarType.UINT64: + return reader.uint64(); + case ScalarType.FIXED64: + return reader.fixed64(); + case ScalarType.BYTES: + return reader.bytes(); + case ScalarType.FIXED32: + return reader.fixed32(); + case ScalarType.SFIXED32: + return reader.sfixed32(); + case ScalarType.SFIXED64: + return reader.sfixed64(); + case ScalarType.SINT64: + return reader.sint64(); + case ScalarType.UINT32: + return reader.uint32(); + case ScalarType.SINT32: + return reader.sint32(); + } +} +function binary_format_writeField(field, value, writer, options) { + assert(value !== undefined); + const repeated = field.repeated; + switch (field.kind) { + case "scalar": + case "enum": + let scalarType = field.kind == "enum" ? ScalarType.INT32 : field.T; + if (repeated) { + assert(Array.isArray(value)); + if (field.packed) { + writePacked(writer, scalarType, field.no, value); + } + else { + for (const item of value) { + binary_format_writeScalar(writer, scalarType, field.no, item); + } + } + } + else { + binary_format_writeScalar(writer, scalarType, field.no, value); + } + break; + case "message": + if (repeated) { + assert(Array.isArray(value)); + for (const item of value) { + writeMessageField(writer, options, field, item); + } + } + else { + writeMessageField(writer, options, field, value); + } + break; + case "map": + assert(typeof value == "object" && value != null); + for (const [key, val] of Object.entries(value)) { + writeMapEntry(writer, options, field, key, val); + } + break; + } +} +function writeMapEntry(writer, options, field, key, value) { + writer.tag(field.no, WireType.LengthDelimited); + writer.fork(); + // javascript only allows number or string for object properties + // we convert from our representation to the protobuf type + let keyValue = key; + // eslint-disable-next-line @typescript-eslint/switch-exhaustiveness-check -- we deliberately handle just the special cases for map keys + switch (field.K) { + case ScalarType.INT32: + case ScalarType.FIXED32: + case ScalarType.UINT32: + case ScalarType.SFIXED32: + case ScalarType.SINT32: + keyValue = Number.parseInt(key); + break; + case ScalarType.BOOL: + assert(key == "true" || key == "false"); + keyValue = key == "true"; + break; + } + // write key, expecting key field number = 1 + binary_format_writeScalar(writer, field.K, 1, keyValue); + // write value, expecting value field number = 2 + switch (field.V.kind) { + case "scalar": + binary_format_writeScalar(writer, field.V.T, 2, value); + break; + case "enum": + binary_format_writeScalar(writer, ScalarType.INT32, 2, value); + break; + case "message": + assert(value !== undefined); + writer.tag(2, WireType.LengthDelimited).bytes(value.toBinary(options)); + break; + } + writer.join(); +} +// Value must not be undefined +function writeMessageField(writer, options, field, value) { + const message = wrapField(field.T, value); + // eslint-disable-next-line @typescript-eslint/strict-boolean-expressions + if (field.delimited) + writer + .tag(field.no, WireType.StartGroup) + .raw(message.toBinary(options)) + .tag(field.no, WireType.EndGroup); + else + writer + .tag(field.no, WireType.LengthDelimited) + .bytes(message.toBinary(options)); +} +function binary_format_writeScalar(writer, type, fieldNo, value) { + assert(value !== undefined); + let [wireType, method] = scalarTypeInfo(type); + writer.tag(fieldNo, wireType)[method](value); +} +function writePacked(writer, type, fieldNo, value) { + if (!value.length) { + return; + } + writer.tag(fieldNo, WireType.LengthDelimited).fork(); + let [, method] = scalarTypeInfo(type); + for (let i = 0; i < value.length; i++) { + writer[method](value[i]); + } + writer.join(); +} +/** + * Get information for writing a scalar value. + * + * Returns tuple: + * [0]: appropriate WireType + * [1]: name of the appropriate method of IBinaryWriter + * [2]: whether the given value is a default value for proto3 semantics + * + * If argument `value` is omitted, [2] is always false. + */ +// TODO replace call-sites writeScalar() and writePacked(), then remove +function scalarTypeInfo(type) { + let wireType = WireType.Varint; + // eslint-disable-next-line @typescript-eslint/switch-exhaustiveness-check -- INT32, UINT32, SINT32 are covered by the defaults + switch (type) { + case ScalarType.BYTES: + case ScalarType.STRING: + wireType = WireType.LengthDelimited; + break; + case ScalarType.DOUBLE: + case ScalarType.FIXED64: + case ScalarType.SFIXED64: + wireType = WireType.Bit64; + break; + case ScalarType.FIXED32: + case ScalarType.SFIXED32: + case ScalarType.FLOAT: + wireType = WireType.Bit32; + break; + } + const method = ScalarType[type].toLowerCase(); + return [wireType, method]; +} + +;// CONCATENATED MODULE: ./node_modules/@bufbuild/protobuf/dist/esm/private/util-common.js +// Copyright 2021-2024 Buf Technologies, Inc. +// +// Licensed under the Apache License, Version 2.0 (the "License"); +// you may not use this file except in compliance with the License. +// You may obtain a copy of the License at +// +// http://www.apache.org/licenses/LICENSE-2.0 +// +// Unless required by applicable law or agreed to in writing, software +// distributed under the License is distributed on an "AS IS" BASIS, +// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. +// See the License for the specific language governing permissions and +// limitations under the License. -const RE_BOUNDARY = /^boundary$/i -const RE_FIELD = /^form-data$/i -const RE_CHARSET = /^charset$/i -const RE_FILENAME = /^filename$/i -const RE_NAME = /^name$/i -Multipart.detect = /^multipart\/form-data/i -function Multipart (boy, cfg) { - let i - let len - const self = this - let boundary - const limits = cfg.limits - const isPartAFile = cfg.isPartAFile || ((fieldName, contentType, fileName) => (contentType === 'application/octet-stream' || fileName !== undefined)) - const parsedConType = cfg.parsedConType || [] - const defCharset = cfg.defCharset || 'utf8' - const preservePath = cfg.preservePath - const fileOpts = { highWaterMark: cfg.fileHwm } - for (i = 0, len = parsedConType.length; i < len; ++i) { - if (Array.isArray(parsedConType[i]) && - RE_BOUNDARY.test(parsedConType[i][0])) { - boundary = parsedConType[i][1] - break - } - } - function checkFinished () { - if (nends === 0 && finished && !boy._done) { - finished = false - self.end() + +/* eslint-disable @typescript-eslint/no-explicit-any,@typescript-eslint/no-unsafe-assignment,@typescript-eslint/no-unsafe-member-access,@typescript-eslint/no-unsafe-return,@typescript-eslint/no-unsafe-argument,no-case-declarations */ +function makeUtilCommon() { + return { + setEnumType: setEnumType, + initPartial(source, target) { + if (source === undefined) { + return; + } + const type = target.getType(); + for (const member of type.fields.byMember()) { + const localName = member.localName, t = target, s = source; + if (s[localName] == null) { + // TODO if source is a Message instance, we should use isFieldSet() here to support future field presence + continue; + } + switch (member.kind) { + case "oneof": + const sk = s[localName].case; + if (sk === undefined) { + continue; + } + const sourceField = member.findField(sk); + let val = s[localName].value; + if (sourceField && + sourceField.kind == "message" && + !isMessage(val, sourceField.T)) { + val = new sourceField.T(val); + } + else if (sourceField && + sourceField.kind === "scalar" && + sourceField.T === ScalarType.BYTES) { + val = toU8Arr(val); + } + t[localName] = { case: sk, value: val }; + break; + case "scalar": + case "enum": + let copy = s[localName]; + if (member.T === ScalarType.BYTES) { + copy = member.repeated + ? copy.map(toU8Arr) + : toU8Arr(copy); + } + t[localName] = copy; + break; + case "map": + switch (member.V.kind) { + case "scalar": + case "enum": + if (member.V.T === ScalarType.BYTES) { + for (const [k, v] of Object.entries(s[localName])) { + t[localName][k] = toU8Arr(v); + } + } + else { + Object.assign(t[localName], s[localName]); + } + break; + case "message": + const messageType = member.V.T; + for (const k of Object.keys(s[localName])) { + let val = s[localName][k]; + if (!messageType.fieldWrapper) { + // We only take partial input for messages that are not a wrapper type. + // For those messages, we recursively normalize the partial input. + val = new messageType(val); + } + t[localName][k] = val; + } + break; + } + break; + case "message": + const mt = member.T; + if (member.repeated) { + t[localName] = s[localName].map((val) => isMessage(val, mt) ? val : new mt(val)); + } + else { + const val = s[localName]; + if (mt.fieldWrapper) { + if ( + // We can't use BytesValue.typeName as that will create a circular import + mt.typeName === "google.protobuf.BytesValue") { + t[localName] = toU8Arr(val); + } + else { + t[localName] = val; + } + } + else { + t[localName] = isMessage(val, mt) ? val : new mt(val); + } + } + break; + } + } + }, + // TODO use isFieldSet() here to support future field presence + equals(type, a, b) { + if (a === b) { + return true; + } + if (!a || !b) { + return false; + } + return type.fields.byMember().every((m) => { + const va = a[m.localName]; + const vb = b[m.localName]; + if (m.repeated) { + if (va.length !== vb.length) { + return false; + } + // eslint-disable-next-line @typescript-eslint/switch-exhaustiveness-check -- repeated fields are never "map" + switch (m.kind) { + case "message": + return va.every((a, i) => m.T.equals(a, vb[i])); + case "scalar": + return va.every((a, i) => scalarEquals(m.T, a, vb[i])); + case "enum": + return va.every((a, i) => scalarEquals(ScalarType.INT32, a, vb[i])); + } + throw new Error(`repeated cannot contain ${m.kind}`); + } + switch (m.kind) { + case "message": + return m.T.equals(va, vb); + case "enum": + return scalarEquals(ScalarType.INT32, va, vb); + case "scalar": + return scalarEquals(m.T, va, vb); + case "oneof": + if (va.case !== vb.case) { + return false; + } + const s = m.findField(va.case); + if (s === undefined) { + return true; + } + // eslint-disable-next-line @typescript-eslint/switch-exhaustiveness-check -- oneof fields are never "map" + switch (s.kind) { + case "message": + return s.T.equals(va.value, vb.value); + case "enum": + return scalarEquals(ScalarType.INT32, va.value, vb.value); + case "scalar": + return scalarEquals(s.T, va.value, vb.value); + } + throw new Error(`oneof cannot contain ${s.kind}`); + case "map": + const keys = Object.keys(va).concat(Object.keys(vb)); + switch (m.V.kind) { + case "message": + const messageType = m.V.T; + return keys.every((k) => messageType.equals(va[k], vb[k])); + case "enum": + return keys.every((k) => scalarEquals(ScalarType.INT32, va[k], vb[k])); + case "scalar": + const scalarType = m.V.T; + return keys.every((k) => scalarEquals(scalarType, va[k], vb[k])); + } + break; + } + }); + }, + // TODO use isFieldSet() here to support future field presence + clone(message) { + const type = message.getType(), target = new type(), any = target; + for (const member of type.fields.byMember()) { + const source = message[member.localName]; + let copy; + if (member.repeated) { + copy = source.map(cloneSingularField); + } + else if (member.kind == "map") { + copy = any[member.localName]; + for (const [key, v] of Object.entries(source)) { + copy[key] = cloneSingularField(v); + } + } + else if (member.kind == "oneof") { + const f = member.findField(source.case); + copy = f + ? { case: source.case, value: cloneSingularField(source.value) } + : { case: undefined }; + } + else { + copy = cloneSingularField(source); + } + any[member.localName] = copy; + } + for (const uf of type.runtime.bin.listUnknownFields(message)) { + type.runtime.bin.onUnknownField(any, uf.no, uf.wireType, uf.data); + } + return target; + }, + }; +} +// clone a single field value - i.e. the element type of repeated fields, the value type of maps +function cloneSingularField(value) { + if (value === undefined) { + return value; } - } + if (isMessage(value)) { + return value.clone(); + } + if (value instanceof Uint8Array) { + const c = new Uint8Array(value.byteLength); + c.set(value); + return c; + } + return value; +} +// converts any ArrayLike to Uint8Array if necessary. +function toU8Arr(input) { + return input instanceof Uint8Array ? input : new Uint8Array(input); +} - if (typeof boundary !== 'string') { throw new Error('Multipart: Boundary not found') } +;// CONCATENATED MODULE: ./node_modules/@bufbuild/protobuf/dist/esm/private/proto-runtime.js +// Copyright 2021-2024 Buf Technologies, Inc. +// +// Licensed under the Apache License, Version 2.0 (the "License"); +// you may not use this file except in compliance with the License. +// You may obtain a copy of the License at +// +// http://www.apache.org/licenses/LICENSE-2.0 +// +// Unless required by applicable law or agreed to in writing, software +// distributed under the License is distributed on an "AS IS" BASIS, +// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. +// See the License for the specific language governing permissions and +// limitations under the License. - const fieldSizeLimit = getLimit(limits, 'fieldSize', 1 * 1024 * 1024) - const fileSizeLimit = getLimit(limits, 'fileSize', Infinity) - const filesLimit = getLimit(limits, 'files', Infinity) - const fieldsLimit = getLimit(limits, 'fields', Infinity) - const partsLimit = getLimit(limits, 'parts', Infinity) - const headerPairsLimit = getLimit(limits, 'headerPairs', 2000) - const headerSizeLimit = getLimit(limits, 'headerSize', 80 * 1024) - let nfiles = 0 - let nfields = 0 - let nends = 0 - let curFile - let curField - let finished = false - this._needDrain = false - this._pause = false - this._cb = undefined - this._nparts = 0 - this._boy = boy - const parserCfg = { - boundary, - maxHeaderPairs: headerPairsLimit, - maxHeaderSize: headerSizeLimit, - partHwm: fileOpts.highWaterMark, - highWaterMark: cfg.highWaterMark - } - this.parser = new Dicer(parserCfg) - this.parser.on('drain', function () { - self._needDrain = false - if (self._cb && !self._pause) { - const cb = self._cb - self._cb = undefined - cb() + +function makeProtoRuntime(syntax, newFieldList, initFields) { + return { + syntax, + json: makeJsonFormat(), + bin: makeBinaryFormat(), + util: Object.assign(Object.assign({}, makeUtilCommon()), { newFieldList, + initFields }), + makeMessageType(typeName, fields, opt) { + return makeMessageType(this, typeName, fields, opt); + }, + makeEnum: makeEnum, + makeEnumType: makeEnumType, + getEnumType: getEnumType, + makeExtension(typeName, extendee, field) { + return makeExtension(this, typeName, extendee, field); + }, + }; +} + +;// CONCATENATED MODULE: ./node_modules/@bufbuild/protobuf/dist/esm/private/field-list.js +// Copyright 2021-2024 Buf Technologies, Inc. +// +// Licensed under the Apache License, Version 2.0 (the "License"); +// you may not use this file except in compliance with the License. +// You may obtain a copy of the License at +// +// http://www.apache.org/licenses/LICENSE-2.0 +// +// Unless required by applicable law or agreed to in writing, software +// distributed under the License is distributed on an "AS IS" BASIS, +// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. +// See the License for the specific language governing permissions and +// limitations under the License. +class InternalFieldList { + constructor(fields, normalizer) { + this._fields = fields; + this._normalizer = normalizer; + } + findJsonName(jsonName) { + if (!this.jsonNames) { + const t = {}; + for (const f of this.list()) { + t[f.jsonName] = t[f.name] = f; + } + this.jsonNames = t; + } + return this.jsonNames[jsonName]; } - }).on('part', function onPart (part) { - if (++self._nparts > partsLimit) { - self.parser.removeListener('part', onPart) - self.parser.on('part', skipPart) - boy.hitPartsLimit = true - boy.emit('partsLimit') - return skipPart(part) + find(fieldNo) { + if (!this.numbers) { + const t = {}; + for (const f of this.list()) { + t[f.no] = f; + } + this.numbers = t; + } + return this.numbers[fieldNo]; + } + list() { + if (!this.all) { + this.all = this._normalizer(this._fields); + } + return this.all; + } + byNumber() { + if (!this.numbersAsc) { + this.numbersAsc = this.list() + .concat() + .sort((a, b) => a.no - b.no); + } + return this.numbersAsc; + } + byMember() { + if (!this.members) { + this.members = []; + const a = this.members; + let o; + for (const f of this.list()) { + if (f.oneof) { + if (f.oneof !== o) { + o = f.oneof; + a.push(o); + } + } + else { + a.push(f); + } + } + } + return this.members; + } +} + +;// CONCATENATED MODULE: ./node_modules/@bufbuild/protobuf/dist/esm/private/names.js +// Copyright 2021-2024 Buf Technologies, Inc. +// +// Licensed under the Apache License, Version 2.0 (the "License"); +// you may not use this file except in compliance with the License. +// You may obtain a copy of the License at +// +// http://www.apache.org/licenses/LICENSE-2.0 +// +// Unless required by applicable law or agreed to in writing, software +// distributed under the License is distributed on an "AS IS" BASIS, +// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. +// See the License for the specific language governing permissions and +// limitations under the License. +/** + * Returns the name of a protobuf element in generated code. + * + * Field names - including oneofs - are converted to lowerCamelCase. For + * messages, enumerations and services, the package name is stripped from + * the type name. For nested messages and enumerations, the names are joined + * with an underscore. For methods, the first character is made lowercase. + */ +function localName(desc) { + switch (desc.kind) { + case "field": + return localFieldName(desc.name, desc.oneof !== undefined); + case "oneof": + return localOneofName(desc.name); + case "enum": + case "message": + case "service": + case "extension": { + const pkg = desc.file.proto.package; + const offset = pkg === undefined ? 0 : pkg.length + 1; + const name = desc.typeName.substring(offset).replace(/\./g, "_"); + // For services, we only care about safe identifiers, not safe object properties, + // but we have shipped v1 with a bug that respected object properties, and we + // do not want to introduce a breaking change, so we continue to escape for + // safe object properties. + // See https://github.com/bufbuild/protobuf-es/pull/391 + return safeObjectProperty(safeIdentifier(name)); + } + case "enum_value": { + let name = desc.name; + const sharedPrefix = desc.parent.sharedPrefix; + if (sharedPrefix !== undefined) { + name = name.substring(sharedPrefix.length); + } + return safeObjectProperty(name); + } + case "rpc": { + let name = desc.name; + if (name.length == 0) { + return name; + } + name = name[0].toLowerCase() + name.substring(1); + return safeObjectProperty(name); + } + } +} +/** + * Returns the name of a field in generated code. + */ +function localFieldName(protoName, inOneof) { + const name = protoCamelCase(protoName); + if (inOneof) { + // oneof member names are not properties, but values of the `case` property. + return name; + } + return safeObjectProperty(safeMessageProperty(name)); +} +/** + * Returns the name of a oneof group in generated code. + */ +function localOneofName(protoName) { + return localFieldName(protoName, false); +} +/** + * Returns the JSON name for a protobuf field, exactly like protoc does. + */ +const fieldJsonName = protoCamelCase; +/** + * Finds a prefix shared by enum values, for example `MY_ENUM_` for + * `enum MyEnum {MY_ENUM_A=0; MY_ENUM_B=1;}`. + */ +function findEnumSharedPrefix(enumName, valueNames) { + const prefix = camelToSnakeCase(enumName) + "_"; + for (const name of valueNames) { + if (!name.toLowerCase().startsWith(prefix)) { + return undefined; + } + const shortName = name.substring(prefix.length); + if (shortName.length == 0) { + return undefined; + } + if (/^\d/.test(shortName)) { + // identifiers must not start with numbers + return undefined; + } + } + return prefix; +} +/** + * Converts lowerCamelCase or UpperCamelCase into lower_snake_case. + * This is used to find shared prefixes in an enum. + */ +function camelToSnakeCase(camel) { + return (camel.substring(0, 1) + camel.substring(1).replace(/[A-Z]/g, (c) => "_" + c)).toLowerCase(); +} +/** + * Converts snake_case to protoCamelCase according to the convention + * used by protoc to convert a field name to a JSON name. + */ +function protoCamelCase(snakeCase) { + let capNext = false; + const b = []; + for (let i = 0; i < snakeCase.length; i++) { + let c = snakeCase.charAt(i); + switch (c) { + case "_": + capNext = true; + break; + case "0": + case "1": + case "2": + case "3": + case "4": + case "5": + case "6": + case "7": + case "8": + case "9": + b.push(c); + capNext = false; + break; + default: + if (capNext) { + capNext = false; + c = c.toUpperCase(); + } + b.push(c); + break; + } + } + return b.join(""); +} +/** + * Names that cannot be used for identifiers, such as class names, + * but _can_ be used for object properties. + */ +const reservedIdentifiers = new Set([ + // ECMAScript 2015 keywords + "break", + "case", + "catch", + "class", + "const", + "continue", + "debugger", + "default", + "delete", + "do", + "else", + "export", + "extends", + "false", + "finally", + "for", + "function", + "if", + "import", + "in", + "instanceof", + "new", + "null", + "return", + "super", + "switch", + "this", + "throw", + "true", + "try", + "typeof", + "var", + "void", + "while", + "with", + "yield", + // ECMAScript 2015 future reserved keywords + "enum", + "implements", + "interface", + "let", + "package", + "private", + "protected", + "public", + "static", + // Class name cannot be 'Object' when targeting ES5 with module CommonJS + "Object", + // TypeScript keywords that cannot be used for types (as opposed to variables) + "bigint", + "number", + "boolean", + "string", + "object", + // Identifiers reserved for the runtime, so we can generate legible code + "globalThis", + "Uint8Array", + "Partial", +]); +/** + * Names that cannot be used for object properties because they are reserved + * by built-in JavaScript properties. + */ +const reservedObjectProperties = new Set([ + // names reserved by JavaScript + "constructor", + "toString", + "toJSON", + "valueOf", +]); +/** + * Names that cannot be used for object properties because they are reserved + * by the runtime. + */ +const reservedMessageProperties = new Set([ + // names reserved by the runtime + "getType", + "clone", + "equals", + "fromBinary", + "fromJson", + "fromJsonString", + "toBinary", + "toJson", + "toJsonString", + // names reserved by the runtime for the future + "toObject", +]); +const fallback = (name) => `${name}$`; +/** + * Will wrap names that are Object prototype properties or names reserved + * for `Message`s. + */ +const safeMessageProperty = (name) => { + if (reservedMessageProperties.has(name)) { + return fallback(name); + } + return name; +}; +/** + * Names that cannot be used for object properties because they are reserved + * by built-in JavaScript properties. + */ +const safeObjectProperty = (name) => { + if (reservedObjectProperties.has(name)) { + return fallback(name); } - - // hack because streams2 _always_ doesn't emit 'end' until nextTick, so let - // us emit 'end' early since we know the part has ended if we are already - // seeing the next part - if (curField) { - const field = curField - field.emit('end') - field.removeAllListeners('end') + return name; +}; +/** + * Names that can be used for identifiers or class properties + */ +const safeIdentifier = (name) => { + if (reservedIdentifiers.has(name)) { + return fallback(name); } + return name; +}; - part.on('header', function (header) { - let contype - let fieldname - let parsed - let charset - let encoding - let filename - let nsize = 0 - - if (header['content-type']) { - parsed = parseParams(header['content-type'][0]) - if (parsed[0]) { - contype = parsed[0].toLowerCase() - for (i = 0, len = parsed.length; i < len; ++i) { - if (RE_CHARSET.test(parsed[i][0])) { - charset = parsed[i][1].toLowerCase() - break +;// CONCATENATED MODULE: ./node_modules/@bufbuild/protobuf/dist/esm/private/field.js +// Copyright 2021-2024 Buf Technologies, Inc. +// +// Licensed under the Apache License, Version 2.0 (the "License"); +// you may not use this file except in compliance with the License. +// You may obtain a copy of the License at +// +// http://www.apache.org/licenses/LICENSE-2.0 +// +// Unless required by applicable law or agreed to in writing, software +// distributed under the License is distributed on an "AS IS" BASIS, +// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. +// See the License for the specific language governing permissions and +// limitations under the License. + + +class InternalOneofInfo { + constructor(name) { + this.kind = "oneof"; + this.repeated = false; + this.packed = false; + this.opt = false; + this.req = false; + this.default = undefined; + this.fields = []; + this.name = name; + this.localName = localOneofName(name); + } + addField(field) { + assert(field.oneof === this, `field ${field.name} not one of ${this.name}`); + this.fields.push(field); + } + findField(localName) { + if (!this._lookup) { + this._lookup = Object.create(null); + for (let i = 0; i < this.fields.length; i++) { + this._lookup[this.fields[i].localName] = this.fields[i]; } - } } - } - - if (contype === undefined) { contype = 'text/plain' } - if (charset === undefined) { charset = defCharset } + return this._lookup[localName]; + } +} - if (header['content-disposition']) { - parsed = parseParams(header['content-disposition'][0]) - if (!RE_FIELD.test(parsed[0])) { return skipPart(part) } - for (i = 0, len = parsed.length; i < len; ++i) { - if (RE_NAME.test(parsed[i][0])) { - fieldname = parsed[i][1] - } else if (RE_FILENAME.test(parsed[i][0])) { - filename = parsed[i][1] - if (!preservePath) { filename = basename(filename) } - } - } - } else { return skipPart(part) } +;// CONCATENATED MODULE: ./node_modules/@bufbuild/protobuf/dist/esm/private/field-normalize.js +// Copyright 2021-2024 Buf Technologies, Inc. +// +// Licensed under the Apache License, Version 2.0 (the "License"); +// you may not use this file except in compliance with the License. +// You may obtain a copy of the License at +// +// http://www.apache.org/licenses/LICENSE-2.0 +// +// Unless required by applicable law or agreed to in writing, software +// distributed under the License is distributed on an "AS IS" BASIS, +// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. +// See the License for the specific language governing permissions and +// limitations under the License. - if (header['content-transfer-encoding']) { encoding = header['content-transfer-encoding'][0].toLowerCase() } else { encoding = '7bit' } - let onData, - onEnd - if (isPartAFile(fieldname, contype, filename)) { - // file/binary field - if (nfiles === filesLimit) { - if (!boy.hitFilesLimit) { - boy.hitFilesLimit = true - boy.emit('filesLimit') - } - return skipPart(part) +/** + * Convert a collection of field info to an array of normalized FieldInfo. + * + * The argument `packedByDefault` specifies whether fields that do not specify + * `packed` should be packed (proto3) or unpacked (proto2). + */ +function normalizeFieldInfos(fieldInfos, packedByDefault) { + var _a, _b, _c, _d, _e, _f; + const r = []; + let o; + for (const field of typeof fieldInfos == "function" + ? fieldInfos() + : fieldInfos) { + const f = field; + f.localName = localFieldName(field.name, field.oneof !== undefined); + f.jsonName = (_a = field.jsonName) !== null && _a !== void 0 ? _a : fieldJsonName(field.name); + f.repeated = (_b = field.repeated) !== null && _b !== void 0 ? _b : false; + if (field.kind == "scalar") { + f.L = (_c = field.L) !== null && _c !== void 0 ? _c : LongType.BIGINT; } - - ++nfiles - - if (boy.listenerCount('file') === 0) { - self.parser._ignore() - return + f.delimited = (_d = field.delimited) !== null && _d !== void 0 ? _d : false; + f.req = (_e = field.req) !== null && _e !== void 0 ? _e : false; + f.opt = (_f = field.opt) !== null && _f !== void 0 ? _f : false; + if (field.packed === undefined) { + if (packedByDefault) { + f.packed = + field.kind == "enum" || + (field.kind == "scalar" && + field.T != ScalarType.BYTES && + field.T != ScalarType.STRING); + } + else { + f.packed = false; + } } - - ++nends - const file = new FileStream(fileOpts) - curFile = file - file.on('end', function () { - --nends - self._pause = false - checkFinished() - if (self._cb && !self._needDrain) { - const cb = self._cb - self._cb = undefined - cb() - } - }) - file._read = function (n) { - if (!self._pause) { return } - self._pause = false - if (self._cb && !self._needDrain) { - const cb = self._cb - self._cb = undefined - cb() - } + // We do not surface options at this time + // f.options = field.options ?? emptyReadonlyObject; + if (field.oneof !== undefined) { + const ooname = typeof field.oneof == "string" ? field.oneof : field.oneof.name; + if (!o || o.name != ooname) { + o = new InternalOneofInfo(ooname); + } + f.oneof = o; + o.addField(f); } - boy.emit('file', fieldname, file, filename, encoding, contype) + r.push(f); + } + return r; +} - onData = function (data) { - if ((nsize += data.length) > fileSizeLimit) { - const extralen = fileSizeLimit - nsize + data.length - if (extralen > 0) { file.push(data.slice(0, extralen)) } - file.truncated = true - file.bytesRead = fileSizeLimit - part.removeAllListeners('data') - file.emit('limit') - return - } else if (!file.push(data)) { self._pause = true } +;// CONCATENATED MODULE: ./node_modules/@bufbuild/protobuf/dist/esm/proto3.js +// Copyright 2021-2024 Buf Technologies, Inc. +// +// Licensed under the Apache License, Version 2.0 (the "License"); +// you may not use this file except in compliance with the License. +// You may obtain a copy of the License at +// +// http://www.apache.org/licenses/LICENSE-2.0 +// +// Unless required by applicable law or agreed to in writing, software +// distributed under the License is distributed on an "AS IS" BASIS, +// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. +// See the License for the specific language governing permissions and +// limitations under the License. - file.bytesRead = nsize - } - onEnd = function () { - curFile = undefined - file.push(null) - } - } else { - // non-file field - if (nfields === fieldsLimit) { - if (!boy.hitFieldsLimit) { - boy.hitFieldsLimit = true - boy.emit('fieldsLimit') - } - return skipPart(part) - } - ++nfields - ++nends - let buffer = '' - let truncated = false - curField = part - onData = function (data) { - if ((nsize += data.length) > fieldSizeLimit) { - const extralen = (fieldSizeLimit - (nsize - data.length)) - buffer += data.toString('binary', 0, extralen) - truncated = true - part.removeAllListeners('data') - } else { buffer += data.toString('binary') } +/** + * Provides functionality for messages defined with the proto3 syntax. + */ +const proto3 = makeProtoRuntime("proto3", (fields) => { + return new InternalFieldList(fields, (source) => normalizeFieldInfos(source, true)); +}, +// TODO merge with proto2 and initExtensionField, also see initPartial, equals, clone +(target) => { + for (const member of target.getType().fields.byMember()) { + if (member.opt) { + continue; } - - onEnd = function () { - curField = undefined - if (buffer.length) { buffer = decodeText(buffer, 'binary', charset) } - boy.emit('field', fieldname, buffer, false, truncated, encoding, contype) - --nends - checkFinished() + const name = member.localName, t = target; + if (member.repeated) { + t[name] = []; + continue; } - } - - /* As of node@2efe4ab761666 (v0.10.29+/v0.11.14+), busboy had become - broken. Streams2/streams3 is a huge black box of confusion, but - somehow overriding the sync state seems to fix things again (and still - seems to work for previous node versions). - */ - part._readableState.sync = false - - part.on('data', onData) - part.on('end', onEnd) - }).on('error', function (err) { - if (curFile) { curFile.emit('error', err) } - }) - }).on('error', function (err) { - boy.emit('error', err) - }).on('finish', function () { - finished = true - checkFinished() - }) -} - -Multipart.prototype.write = function (chunk, cb) { - const r = this.parser.write(chunk) - if (r && !this._pause) { - cb() - } else { - this._needDrain = !r - this._cb = cb - } -} - -Multipart.prototype.end = function () { - const self = this - - if (self.parser.writable) { - self.parser.end() - } else if (!self._boy._done) { - process.nextTick(function () { - self._boy._done = true - self._boy.emit('finish') - }) - } -} - -function skipPart (part) { - part.resume() -} + switch (member.kind) { + case "oneof": + t[name] = { case: undefined }; + break; + case "enum": + t[name] = 0; + break; + case "map": + t[name] = {}; + break; + case "scalar": + t[name] = scalarZeroValue(member.T, member.L); + break; + case "message": + // message fields are always optional in proto3 + break; + } + } +}); -function FileStream (opts) { - Readable.call(this, opts) +;// CONCATENATED MODULE: ./node_modules/@bufbuild/protobuf/dist/esm/google/protobuf/any_pb.js +// Copyright 2021-2024 Buf Technologies, Inc. +// +// Licensed under the Apache License, Version 2.0 (the "License"); +// you may not use this file except in compliance with the License. +// You may obtain a copy of the License at +// +// http://www.apache.org/licenses/LICENSE-2.0 +// +// Unless required by applicable law or agreed to in writing, software +// distributed under the License is distributed on an "AS IS" BASIS, +// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. +// See the License for the specific language governing permissions and +// limitations under the License. - this.bytesRead = 0 - this.truncated = false +/** + * `Any` contains an arbitrary serialized protocol buffer message along with a + * URL that describes the type of the serialized message. + * + * Protobuf library provides support to pack/unpack Any values in the form + * of utility functions or additional generated methods of the Any type. + * + * Example 1: Pack and unpack a message in C++. + * + * Foo foo = ...; + * Any any; + * any.PackFrom(foo); + * ... + * if (any.UnpackTo(&foo)) { + * ... + * } + * + * Example 2: Pack and unpack a message in Java. + * + * Foo foo = ...; + * Any any = Any.pack(foo); + * ... + * if (any.is(Foo.class)) { + * foo = any.unpack(Foo.class); + * } + * // or ... + * if (any.isSameTypeAs(Foo.getDefaultInstance())) { + * foo = any.unpack(Foo.getDefaultInstance()); + * } + * + * Example 3: Pack and unpack a message in Python. + * + * foo = Foo(...) + * any = Any() + * any.Pack(foo) + * ... + * if any.Is(Foo.DESCRIPTOR): + * any.Unpack(foo) + * ... + * + * Example 4: Pack and unpack a message in Go + * + * foo := &pb.Foo{...} + * any, err := anypb.New(foo) + * if err != nil { + * ... + * } + * ... + * foo := &pb.Foo{} + * if err := any.UnmarshalTo(foo); err != nil { + * ... + * } + * + * The pack methods provided by protobuf library will by default use + * 'type.googleapis.com/full.type.name' as the type URL and the unpack + * methods only use the fully qualified type name after the last '/' + * in the type URL, for example "foo.bar.com/x/y.z" will yield type + * name "y.z". + * + * JSON + * ==== + * The JSON representation of an `Any` value uses the regular + * representation of the deserialized, embedded message, with an + * additional field `@type` which contains the type URL. Example: + * + * package google.profile; + * message Person { + * string first_name = 1; + * string last_name = 2; + * } + * + * { + * "@type": "type.googleapis.com/google.profile.Person", + * "firstName": , + * "lastName": + * } + * + * If the embedded message type is well-known and has a custom JSON + * representation, that representation will be embedded adding a field + * `value` which holds the custom JSON in addition to the `@type` + * field. Example (for message [google.protobuf.Duration][]): + * + * { + * "@type": "type.googleapis.com/google.protobuf.Duration", + * "value": "1.212s" + * } + * + * + * @generated from message google.protobuf.Any + */ +class any_pb_Any extends Message { + constructor(data) { + super(); + /** + * A URL/resource name that uniquely identifies the type of the serialized + * protocol buffer message. This string must contain at least + * one "/" character. The last segment of the URL's path must represent + * the fully qualified name of the type (as in + * `path/google.protobuf.Duration`). The name should be in a canonical form + * (e.g., leading "." is not accepted). + * + * In practice, teams usually precompile into the binary all types that they + * expect it to use in the context of Any. However, for URLs which use the + * scheme `http`, `https`, or no scheme, one can optionally set up a type + * server that maps type URLs to message definitions as follows: + * + * * If no scheme is provided, `https` is assumed. + * * An HTTP GET on the URL must yield a [google.protobuf.Type][] + * value in binary format, or produce an error. + * * Applications are allowed to cache lookup results based on the + * URL, or have them precompiled into a binary to avoid any + * lookup. Therefore, binary compatibility needs to be preserved + * on changes to types. (Use versioned type names to manage + * breaking changes.) + * + * Note: this functionality is not currently available in the official + * protobuf release, and it is not used for type URLs beginning with + * type.googleapis.com. As of May 2023, there are no widely used type server + * implementations and no plans to implement one. + * + * Schemes other than `http`, `https` (or the empty scheme) might be + * used with implementation specific semantics. + * + * + * @generated from field: string type_url = 1; + */ + this.typeUrl = ""; + /** + * Must be a valid serialized protocol buffer of the above specified type. + * + * @generated from field: bytes value = 2; + */ + this.value = new Uint8Array(0); + proto3.util.initPartial(data, this); + } + toJson(options) { + var _a; + if (this.typeUrl === "") { + return {}; + } + const typeName = this.typeUrlToName(this.typeUrl); + const messageType = (_a = options === null || options === void 0 ? void 0 : options.typeRegistry) === null || _a === void 0 ? void 0 : _a.findMessage(typeName); + if (!messageType) { + throw new Error(`cannot encode message google.protobuf.Any to JSON: "${this.typeUrl}" is not in the type registry`); + } + const message = messageType.fromBinary(this.value); + let json = message.toJson(options); + if (typeName.startsWith("google.protobuf.") || (json === null || Array.isArray(json) || typeof json !== "object")) { + json = { value: json }; + } + json["@type"] = this.typeUrl; + return json; + } + fromJson(json, options) { + var _a; + if (json === null || Array.isArray(json) || typeof json != "object") { + throw new Error(`cannot decode message google.protobuf.Any from JSON: expected object but got ${json === null ? "null" : Array.isArray(json) ? "array" : typeof json}`); + } + if (Object.keys(json).length == 0) { + return this; + } + const typeUrl = json["@type"]; + if (typeof typeUrl != "string" || typeUrl == "") { + throw new Error(`cannot decode message google.protobuf.Any from JSON: "@type" is empty`); + } + const typeName = this.typeUrlToName(typeUrl), messageType = (_a = options === null || options === void 0 ? void 0 : options.typeRegistry) === null || _a === void 0 ? void 0 : _a.findMessage(typeName); + if (!messageType) { + throw new Error(`cannot decode message google.protobuf.Any from JSON: ${typeUrl} is not in the type registry`); + } + let message; + if (typeName.startsWith("google.protobuf.") && Object.prototype.hasOwnProperty.call(json, "value")) { + message = messageType.fromJson(json["value"], options); + } + else { + const copy = Object.assign({}, json); + delete copy["@type"]; + message = messageType.fromJson(copy, options); + } + this.packFrom(message); + return this; + } + packFrom(message) { + this.value = message.toBinary(); + this.typeUrl = this.typeNameToUrl(message.getType().typeName); + } + unpackTo(target) { + if (!this.is(target.getType())) { + return false; + } + target.fromBinary(this.value); + return true; + } + unpack(registry) { + if (this.typeUrl === "") { + return undefined; + } + const messageType = registry.findMessage(this.typeUrlToName(this.typeUrl)); + if (!messageType) { + return undefined; + } + return messageType.fromBinary(this.value); + } + is(type) { + if (this.typeUrl === '') { + return false; + } + const name = this.typeUrlToName(this.typeUrl); + let typeName = ''; + if (typeof type === 'string') { + typeName = type; + } + else { + typeName = type.typeName; + } + return name === typeName; + } + typeNameToUrl(name) { + return `type.googleapis.com/${name}`; + } + typeUrlToName(url) { + if (!url.length) { + throw new Error(`invalid type url: ${url}`); + } + const slash = url.lastIndexOf("/"); + const name = slash >= 0 ? url.substring(slash + 1) : url; + if (!name.length) { + throw new Error(`invalid type url: ${url}`); + } + return name; + } + static pack(message) { + const any = new any_pb_Any(); + any.packFrom(message); + return any; + } + static fromBinary(bytes, options) { + return new any_pb_Any().fromBinary(bytes, options); + } + static fromJson(jsonValue, options) { + return new any_pb_Any().fromJson(jsonValue, options); + } + static fromJsonString(jsonString, options) { + return new any_pb_Any().fromJsonString(jsonString, options); + } + static equals(a, b) { + return proto3.util.equals(any_pb_Any, a, b); + } } +any_pb_Any.runtime = proto3; +any_pb_Any.typeName = "google.protobuf.Any"; +any_pb_Any.fields = proto3.util.newFieldList(() => [ + { no: 1, name: "type_url", kind: "scalar", T: 9 /* ScalarType.STRING */ }, + { no: 2, name: "value", kind: "scalar", T: 12 /* ScalarType.BYTES */ }, +]); -inherits(FileStream, Readable) - -FileStream.prototype._read = function (n) {} - -module.exports = Multipart - - -/***/ }), - -/***/ 855: -/***/ ((module, __unused_webpack_exports, __nccwpck_require__) => { - - - -const Decoder = __nccwpck_require__(1496) -const decodeText = __nccwpck_require__(2747) -const getLimit = __nccwpck_require__(2393) +;// CONCATENATED MODULE: ./node_modules/@connectrpc/connect/dist/esm/protocol-grpc/gen/status_pb.js +// Copyright 2021-2024 The Connect Authors +// +// Licensed under the Apache License, Version 2.0 (the "License"); +// you may not use this file except in compliance with the License. +// You may obtain a copy of the License at +// +// http://www.apache.org/licenses/LICENSE-2.0 +// +// Unless required by applicable law or agreed to in writing, software +// distributed under the License is distributed on an "AS IS" BASIS, +// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. +// See the License for the specific language governing permissions and +// limitations under the License. -const RE_CHARSET = /^charset$/i +/** + * The `Status` type defines a logical error model that is suitable for different + * programming environments, including REST APIs and RPC APIs. It is used by + * [gRPC](https://github.com/grpc). The error model is designed to be: + * + * - Simple to use and understand for most users + * - Flexible enough to meet unexpected needs + * + * # Overview + * + * The `Status` message contains three pieces of data: error code, error message, + * and error details. The error code should be an enum value of + * [google.rpc.Code][google.rpc.Code], but it may accept additional error codes if needed. The + * error message should be a developer-facing English message that helps + * developers *understand* and *resolve* the error. If a localized user-facing + * error message is needed, put the localized message in the error details or + * localize it in the client. The optional error details may contain arbitrary + * information about the error. There is a predefined set of error detail types + * in the package `google.rpc` which can be used for common error conditions. + * + * # Language mapping + * + * The `Status` message is the logical representation of the error model, but it + * is not necessarily the actual wire format. When the `Status` message is + * exposed in different client libraries and different wire protocols, it can be + * mapped differently. For example, it will likely be mapped to some exceptions + * in Java, but more likely mapped to some error codes in C. + * + * # Other uses + * + * The error model and the `Status` message can be used in a variety of + * environments, either with or without APIs, to provide a + * consistent developer experience across different environments. + * + * Example uses of this error model include: + * + * - Partial errors. If a service needs to return partial errors to the client, + * it may embed the `Status` in the normal response to indicate the partial + * errors. + * + * - Workflow errors. A typical workflow has multiple steps. Each step may + * have a `Status` message for error reporting purpose. + * + * - Batch operations. If a client uses batch request and batch response, the + * `Status` message should be used directly inside batch response, one for + * each error sub-response. + * + * - Asynchronous operations. If an API call embeds asynchronous operation + * results in its response, the status of those operations should be + * represented directly using the `Status` message. + * + * - Logging. If some API errors are stored in logs, the message `Status` could + * be used directly after any stripping needed for security/privacy reasons. + * + * @generated from message google.rpc.Status + */ +class status_pb_Status extends Message { + constructor(data) { + super(); + /** + * The status code, which should be an enum value of [google.rpc.Code][google.rpc.Code]. + * + * @generated from field: int32 code = 1; + */ + this.code = 0; + /** + * A developer-facing error message, which should be in English. Any + * user-facing error message should be localized and sent in the + * [google.rpc.Status.details][google.rpc.Status.details] field, or localized by the client. + * + * @generated from field: string message = 2; + */ + this.message = ""; + /** + * A list of messages that carry the error details. There will be a + * common set of message types for APIs to use. + * + * @generated from field: repeated google.protobuf.Any details = 3; + */ + this.details = []; + proto3.util.initPartial(data, this); + } + static fromBinary(bytes, options) { + return new status_pb_Status().fromBinary(bytes, options); + } + static fromJson(jsonValue, options) { + return new status_pb_Status().fromJson(jsonValue, options); + } + static fromJsonString(jsonString, options) { + return new status_pb_Status().fromJsonString(jsonString, options); + } + static equals(a, b) { + return proto3.util.equals(status_pb_Status, a, b); + } +} +status_pb_Status.runtime = proto3; +status_pb_Status.typeName = "google.rpc.Status"; +status_pb_Status.fields = proto3.util.newFieldList(() => [ + { no: 1, name: "code", kind: "scalar", T: 5 /* ScalarType.INT32 */ }, + { no: 2, name: "message", kind: "scalar", T: 9 /* ScalarType.STRING */ }, + { no: 3, name: "details", kind: "message", T: any_pb_Any, repeated: true }, +]); + +;// CONCATENATED MODULE: ./node_modules/@connectrpc/connect/dist/esm/http-headers.js +// Copyright 2021-2024 The Connect Authors +// +// Licensed under the Apache License, Version 2.0 (the "License"); +// you may not use this file except in compliance with the License. +// You may obtain a copy of the License at +// +// http://www.apache.org/licenses/LICENSE-2.0 +// +// Unless required by applicable law or agreed to in writing, software +// distributed under the License is distributed on an "AS IS" BASIS, +// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. +// See the License for the specific language governing permissions and +// limitations under the License. -UrlEncoded.detect = /^application\/x-www-form-urlencoded/i -function UrlEncoded (boy, cfg) { - const limits = cfg.limits - const parsedConType = cfg.parsedConType - this.boy = boy - this.fieldSizeLimit = getLimit(limits, 'fieldSize', 1 * 1024 * 1024) - this.fieldNameSizeLimit = getLimit(limits, 'fieldNameSize', 100) - this.fieldsLimit = getLimit(limits, 'fields', Infinity) - let charset - for (var i = 0, len = parsedConType.length; i < len; ++i) { // eslint-disable-line no-var - if (Array.isArray(parsedConType[i]) && - RE_CHARSET.test(parsedConType[i][0])) { - charset = parsedConType[i][1].toLowerCase() - break +/** + * Encode a single binary header value according to the Connect + * and gRPC specifications. + * + * This function accepts raw binary data from a buffer, a string + * with UTF-8 text, or a protobuf message. It encodes the input + * with unpadded base64 and returns a string that can be used for + * a header whose name ends with `-bin`. + */ +function http_headers_encodeBinaryHeader(value) { + let bytes; + if (typeof value == "object" && "getType" in value) { + bytes = value.toBinary(); } - } - - if (charset === undefined) { charset = cfg.defCharset || 'utf8' } - - this.decoder = new Decoder() - this.charset = charset - this._fields = 0 - this._state = 'key' - this._checkingBytes = true - this._bytesKey = 0 - this._bytesVal = 0 - this._key = '' - this._val = '' - this._keyTrunc = false - this._valTrunc = false - this._hitLimit = false -} - -UrlEncoded.prototype.write = function (data, cb) { - if (this._fields === this.fieldsLimit) { - if (!this.boy.hitFieldsLimit) { - this.boy.hitFieldsLimit = true - this.boy.emit('fieldsLimit') + else if (typeof value == "string") { + bytes = new TextEncoder().encode(value); } - return cb() - } - - let idxeq; let idxamp; let i; let p = 0; const len = data.length - - while (p < len) { - if (this._state === 'key') { - idxeq = idxamp = undefined - for (i = p; i < len; ++i) { - if (!this._checkingBytes) { ++p } - if (data[i] === 0x3D/* = */) { - idxeq = i - break - } else if (data[i] === 0x26/* & */) { - idxamp = i - break + else { + bytes = value instanceof Uint8Array ? value : new Uint8Array(value); + } + return protoBase64.enc(bytes).replace(/=+$/, ""); +} +function decodeBinaryHeader(value, type, options) { + try { + const bytes = proto_base64_protoBase64.dec(value); + if (type) { + return type.fromBinary(bytes, options); } - if (this._checkingBytes && this._bytesKey === this.fieldNameSizeLimit) { - this._hitLimit = true - break - } else if (this._checkingBytes) { ++this._bytesKey } - } - - if (idxeq !== undefined) { - // key with assignment - if (idxeq > p) { this._key += this.decoder.write(data.toString('binary', p, idxeq)) } - this._state = 'val' - - this._hitLimit = false - this._checkingBytes = true - this._val = '' - this._bytesVal = 0 - this._valTrunc = false - this.decoder.reset() + return bytes; + } + catch (e) { + throw connect_error_ConnectError.from(e, code_Code.DataLoss); + } +} +/** + * Merge two or more Headers objects by appending all fields from + * all inputs to a new Headers object. + */ +function appendHeaders(...headers) { + const h = new Headers(); + for (const e of headers) { + e.forEach((value, key) => { + h.append(key, value); + }); + } + return h; +} - p = idxeq + 1 - } else if (idxamp !== undefined) { - // key with no assignment - ++this._fields - let key; const keyTrunc = this._keyTrunc - if (idxamp > p) { key = (this._key += this.decoder.write(data.toString('binary', p, idxamp))) } else { key = this._key } +;// CONCATENATED MODULE: ./node_modules/@connectrpc/connect/dist/esm/protocol-grpc/trailer-status.js +// Copyright 2021-2024 The Connect Authors +// +// Licensed under the Apache License, Version 2.0 (the "License"); +// you may not use this file except in compliance with the License. +// You may obtain a copy of the License at +// +// http://www.apache.org/licenses/LICENSE-2.0 +// +// Unless required by applicable law or agreed to in writing, software +// distributed under the License is distributed on an "AS IS" BASIS, +// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. +// See the License for the specific language governing permissions and +// limitations under the License. - this._hitLimit = false - this._checkingBytes = true - this._key = '' - this._bytesKey = 0 - this._keyTrunc = false - this.decoder.reset() - if (key.length) { - this.boy.emit('field', decodeText(key, 'binary', this.charset), - '', - keyTrunc, - false) - } - p = idxamp + 1 - if (this._fields === this.fieldsLimit) { return cb() } - } else if (this._hitLimit) { - // we may not have hit the actual limit if there are encoded bytes... - if (i > p) { this._key += this.decoder.write(data.toString('binary', p, i)) } - p = i - if ((this._bytesKey = this._key.length) === this.fieldNameSizeLimit) { - // yep, we actually did hit the limit - this._checkingBytes = false - this._keyTrunc = true - } - } else { - if (p < len) { this._key += this.decoder.write(data.toString('binary', p)) } - p = len - } - } else { - idxamp = undefined - for (i = p; i < len; ++i) { - if (!this._checkingBytes) { ++p } - if (data[i] === 0x26/* & */) { - idxamp = i - break - } - if (this._checkingBytes && this._bytesVal === this.fieldSizeLimit) { - this._hitLimit = true - break - } else if (this._checkingBytes) { ++this._bytesVal } - } - if (idxamp !== undefined) { - ++this._fields - if (idxamp > p) { this._val += this.decoder.write(data.toString('binary', p, idxamp)) } - this.boy.emit('field', decodeText(this._key, 'binary', this.charset), - decodeText(this._val, 'binary', this.charset), - this._keyTrunc, - this._valTrunc) - this._state = 'key' - this._hitLimit = false - this._checkingBytes = true - this._key = '' - this._bytesKey = 0 - this._keyTrunc = false - this.decoder.reset() - p = idxamp + 1 - if (this._fields === this.fieldsLimit) { return cb() } - } else if (this._hitLimit) { - // we may not have hit the actual limit if there are encoded bytes... - if (i > p) { this._val += this.decoder.write(data.toString('binary', p, i)) } - p = i - if ((this._val === '' && this.fieldSizeLimit === 0) || - (this._bytesVal = this._val.length) === this.fieldSizeLimit) { - // yep, we actually did hit the limit - this._checkingBytes = false - this._valTrunc = true +/** + * The value of the Grpc-Status header or trailer in case of success. + * Used by the gRPC and gRPC-web protocols. + * + * @private Internal code, does not follow semantic versioning. + */ +const grpcStatusOk = "0"; +/** + * Sets the fields "grpc-status" and "grpc-message" in the given + * Headers object. + * If an error is given and contains error details, the function + * will also set the field "grpc-status-details-bin" with an encoded + * google.rpc.Status message including the error details. + * + * @private Internal code, does not follow semantic versioning. + */ +function setTrailerStatus(target, error) { + if (error) { + target.set(headerGrpcStatus, error.code.toString(10)); + target.set(headerGrpcMessage, encodeURIComponent(error.rawMessage)); + if (error.details.length > 0) { + const status = new Status({ + code: error.code, + message: error.rawMessage, + details: error.details.map((value) => "getType" in value + ? Any.pack(value) + : new Any({ + typeUrl: `type.googleapis.com/${value.type}`, + value: value.value, + })), + }); + target.set(headerStatusDetailsBin, encodeBinaryHeader(status)); } - } else { - if (p < len) { this._val += this.decoder.write(data.toString('binary', p)) } - p = len - } } - } - cb() + else { + target.set(headerGrpcStatus, grpcStatusOk.toString()); + } + return target; } - -UrlEncoded.prototype.end = function () { - if (this.boy._done) { return } - - if (this._state === 'key' && this._key.length > 0) { - this.boy.emit('field', decodeText(this._key, 'binary', this.charset), - '', - this._keyTrunc, - false) - } else if (this._state === 'val') { - this.boy.emit('field', decodeText(this._key, 'binary', this.charset), - decodeText(this._val, 'binary', this.charset), - this._keyTrunc, - this._valTrunc) - } - this.boy._done = true - this.boy.emit('finish') +/** + * Find an error status in the given Headers object, which can be either + * a trailer, or a header (as allowed for so-called trailers-only responses). + * The field "grpc-status-details-bin" is inspected, and if not present, + * the fields "grpc-status" and "grpc-message" are used. + * Returns an error only if the gRPC status code is > 0. + * + * @private Internal code, does not follow semantic versioning. + */ +function findTrailerError(headerOrTrailer) { + // TODO + // let code: Code; + // let message: string = ""; + var _a; + // Prefer the protobuf-encoded data to the grpc-status header. + const statusBytes = headerOrTrailer.get(headers_headerStatusDetailsBin); + if (statusBytes != null) { + const status = decodeBinaryHeader(statusBytes, status_pb_Status); + if (status.code == 0) { + return undefined; + } + const error = new connect_error_ConnectError(status.message, status.code, headerOrTrailer); + error.details = status.details.map((any) => ({ + type: any.typeUrl.substring(any.typeUrl.lastIndexOf("/") + 1), + value: any.value, + })); + return error; + } + const grpcStatus = headerOrTrailer.get(headers_headerGrpcStatus); + if (grpcStatus != null) { + if (grpcStatus === grpcStatusOk) { + return undefined; + } + const code = parseInt(grpcStatus, 10); + if (code in code_Code) { + return new connect_error_ConnectError(decodeURIComponent((_a = headerOrTrailer.get(headers_headerGrpcMessage)) !== null && _a !== void 0 ? _a : ""), code, headerOrTrailer); + } + return new connect_error_ConnectError(`invalid grpc-status: ${grpcStatus}`, code_Code.Internal, headerOrTrailer); + } + return undefined; } -module.exports = UrlEncoded - - -/***/ }), +;// CONCATENATED MODULE: ./node_modules/@connectrpc/connect/dist/esm/protocol-grpc/validate-response.js +// Copyright 2021-2024 The Connect Authors +// +// Licensed under the Apache License, Version 2.0 (the "License"); +// you may not use this file except in compliance with the License. +// You may obtain a copy of the License at +// +// http://www.apache.org/licenses/LICENSE-2.0 +// +// Unless required by applicable law or agreed to in writing, software +// distributed under the License is distributed on an "AS IS" BASIS, +// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. +// See the License for the specific language governing permissions and +// limitations under the License. -/***/ 1496: -/***/ ((module) => { -const RE_PLUS = /\+/g -const HEX = [ - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0, - 0, 1, 1, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 1, 1, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0 -] -function Decoder () { - this.buffer = undefined +/** + * Validates response status and header for the gRPC protocol. + * Throws a ConnectError if the header contains an error status, + * or if the HTTP status indicates an error. + * + * Returns an object that indicates whether a gRPC status was found + * in the response header. In this case, clients can not expect a + * trailer. + * + * @private Internal code, does not follow semantic versioning. + */ +function validateResponse(status, headers) { + if (status != 200) { + throw new connect_error_ConnectError(`HTTP ${status}`, codeFromHttpStatus(status), headers); + } + const mimeType = headers.get(headerContentType); + const parsedType = parseContentType(mimeType); + if (parsedType == undefined) { + throw new connect_error_ConnectError(`unsupported content type ${mimeType}`, code_Code.Unknown); + } + return { + foundStatus: headers.has(headers_headerGrpcStatus), + headerError: findTrailerError(headers), + }; } -Decoder.prototype.write = function (str) { - // Replace '+' with ' ' before decoding - str = str.replace(RE_PLUS, ' ') - let res = '' - let i = 0; let p = 0; const len = str.length - for (; i < len; ++i) { - if (this.buffer !== undefined) { - if (!HEX[str.charCodeAt(i)]) { - res += '%' + this.buffer - this.buffer = undefined - --i // retry character - } else { - this.buffer += str[i] - ++p - if (this.buffer.length === 2) { - res += String.fromCharCode(parseInt(this.buffer, 16)) - this.buffer = undefined +/** + * Validates response status and header for the gRPC protocol. + * This function is identical to validateResponse(), but also verifies + * that a given encoding header is acceptable. + * + * Returns an object with the response compression, and a boolean + * indicating whether a gRPC status was found in the response header + * (in this case, clients can not expect a trailer). + * + * @private Internal code, does not follow semantic versioning. + */ +function validateResponseWithCompression(acceptCompression, status, headers) { + const { foundStatus, headerError } = validateResponse(status, headers); + let compression; + const encoding = headers.get(headerEncoding); + if (encoding !== null && encoding.toLowerCase() !== "identity") { + compression = acceptCompression.find((c) => c.name === encoding); + if (!compression) { + throw new connect_error_ConnectError(`unsupported response encoding "${encoding}"`, code_Code.Internal, headers); } - } - } else if (str[i] === '%') { - if (i > p) { - res += str.substring(p, i) - p = i - } - this.buffer = '' - ++p } - } - if (p < len && this.buffer === undefined) { res += str.substring(p) } - return res -} -Decoder.prototype.reset = function () { - this.buffer = undefined + return { + foundStatus, + compression, + headerError, + }; } -module.exports = Decoder +;// CONCATENATED MODULE: ./node_modules/@connectrpc/connect/dist/esm/protocol-grpc/validate-trailer.js +// Copyright 2021-2024 The Connect Authors +// +// Licensed under the Apache License, Version 2.0 (the "License"); +// you may not use this file except in compliance with the License. +// You may obtain a copy of the License at +// +// http://www.apache.org/licenses/LICENSE-2.0 +// +// Unless required by applicable law or agreed to in writing, software +// distributed under the License is distributed on an "AS IS" BASIS, +// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. +// See the License for the specific language governing permissions and +// limitations under the License. -/***/ }), -/***/ 692: -/***/ ((module) => { +/** + * Validates a trailer for the gRPC and the gRPC-web protocol. + * + * If the trailer contains an error status, a ConnectError is + * thrown. It will include trailer and header in the error's + * "metadata" property. + * + * Throws a ConnectError with code "internal" if neither the trailer + * nor the header contain the Grpc-Status field. + * + * @private Internal code, does not follow semantic versioning. + */ +function validateTrailer(trailer, header) { + const err = findTrailerError(trailer); + if (err) { + header.forEach((value, key) => { + err.metadata.append(key, value); + }); + throw err; + } + if (!header.has(headers_headerGrpcStatus) && !trailer.has(headers_headerGrpcStatus)) { + throw new connect_error_ConnectError("protocol error: missing status", code_Code.Internal); + } +} +;// CONCATENATED MODULE: ./node_modules/@connectrpc/connect/dist/esm/protocol/create-method-url.js +// Copyright 2021-2024 The Connect Authors +// +// Licensed under the Apache License, Version 2.0 (the "License"); +// you may not use this file except in compliance with the License. +// You may obtain a copy of the License at +// +// http://www.apache.org/licenses/LICENSE-2.0 +// +// Unless required by applicable law or agreed to in writing, software +// distributed under the License is distributed on an "AS IS" BASIS, +// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. +// See the License for the specific language governing permissions and +// limitations under the License. +/** + * Create a URL for the given RPC. This simply adds the qualified + * service name, a slash, and the method name to the path of the given + * baseUrl. + * + * For example, the baseUri https://example.com and method "Say" from + * the service example.ElizaService results in: + * https://example.com/example.ElizaService/Say + * + * This format is used by the protocols Connect, gRPC and Twirp. + * + * Note that this function also accepts a protocol-relative baseUrl. + * If given an empty string or "/" as a baseUrl, it returns just the + * path. + */ +function createMethodUrl(baseUrl, service, method) { + const s = typeof service == "string" ? service : service.typeName; + const m = typeof method == "string" ? method : method.name; + return baseUrl.toString().replace(/\/?$/, `/${s}/${m}`); +} -module.exports = function basename (path) { - if (typeof path !== 'string') { return '' } - for (var i = path.length - 1; i >= 0; --i) { // eslint-disable-line no-var - switch (path.charCodeAt(i)) { - case 0x2F: // '/' - case 0x5C: // '\' - path = path.slice(i + 1) - return (path === '..' || path === '.' ? '' : path) - } - } - return (path === '..' || path === '.' ? '' : path) +;// CONCATENATED MODULE: ./node_modules/@connectrpc/connect/dist/esm/interceptor.js +// Copyright 2021-2024 The Connect Authors +// +// Licensed under the Apache License, Version 2.0 (the "License"); +// you may not use this file except in compliance with the License. +// You may obtain a copy of the License at +// +// http://www.apache.org/licenses/LICENSE-2.0 +// +// Unless required by applicable law or agreed to in writing, software +// distributed under the License is distributed on an "AS IS" BASIS, +// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. +// See the License for the specific language governing permissions and +// limitations under the License. +/** + * applyInterceptors takes the given UnaryFn or ServerStreamingFn, and wraps + * it with each of the given interceptors, returning a new UnaryFn or + * ServerStreamingFn. + */ +function applyInterceptors(next, interceptors) { + var _a; + return ((_a = interceptors === null || interceptors === void 0 ? void 0 : interceptors.concat().reverse().reduce( + // eslint-disable-next-line @typescript-eslint/no-unsafe-argument + (n, i) => i(n), next)) !== null && _a !== void 0 ? _a : next); } +;// CONCATENATED MODULE: ./node_modules/@connectrpc/connect/dist/esm/protocol/normalize.js +// Copyright 2021-2024 The Connect Authors +// +// Licensed under the Apache License, Version 2.0 (the "License"); +// you may not use this file except in compliance with the License. +// You may obtain a copy of the License at +// +// http://www.apache.org/licenses/LICENSE-2.0 +// +// Unless required by applicable law or agreed to in writing, software +// distributed under the License is distributed on an "AS IS" BASIS, +// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. +// See the License for the specific language governing permissions and +// limitations under the License. -/***/ }), +/** + * Takes a partial protobuf messages of the + * specified message type as input, and returns full instances. + */ +function normalize(type, message) { + return message instanceof type + ? message + : new type(message); +} +/** + * Takes an AsyncIterable of partial protobuf messages of the + * specified message type as input, and yields full instances. + */ +function normalizeIterable(messageType, input) { + function transform(result) { + if (result.done === true) { + return result; + } + return { + done: result.done, + value: normalize(messageType, result.value), + }; + } + return { + [Symbol.asyncIterator]() { + const it = input[Symbol.asyncIterator](); + const res = { + next: () => it.next().then(transform), + }; + if (it.throw !== undefined) { + res.throw = (e) => it.throw(e).then(transform); // eslint-disable-line @typescript-eslint/no-non-null-assertion + } + if (it.return !== undefined) { + res.return = (v) => it.return(v).then(transform); // eslint-disable-line @typescript-eslint/no-non-null-assertion + } + return res; + }, + }; +} -/***/ 2747: -/***/ (function(module) { +;// CONCATENATED MODULE: ./node_modules/@connectrpc/connect/dist/esm/protocol/run-call.js +// Copyright 2021-2024 The Connect Authors +// +// Licensed under the Apache License, Version 2.0 (the "License"); +// you may not use this file except in compliance with the License. +// You may obtain a copy of the License at +// +// http://www.apache.org/licenses/LICENSE-2.0 +// +// Unless required by applicable law or agreed to in writing, software +// distributed under the License is distributed on an "AS IS" BASIS, +// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. +// See the License for the specific language governing permissions and +// limitations under the License. -// Node has always utf-8 -const utf8Decoder = new TextDecoder('utf-8') -const textDecoders = new Map([ - ['utf-8', utf8Decoder], - ['utf8', utf8Decoder] -]) -function getDecoder (charset) { - let lc - while (true) { - switch (charset) { - case 'utf-8': - case 'utf8': - return decoders.utf8 - case 'latin1': - case 'ascii': // TODO: Make these a separate, strict decoder? - case 'us-ascii': - case 'iso-8859-1': - case 'iso8859-1': - case 'iso88591': - case 'iso_8859-1': - case 'windows-1252': - case 'iso_8859-1:1987': - case 'cp1252': - case 'x-cp1252': - return decoders.latin1 - case 'utf16le': - case 'utf-16le': - case 'ucs2': - case 'ucs-2': - return decoders.utf16le - case 'base64': - return decoders.base64 - default: - if (lc === undefined) { - lc = true - charset = charset.toLowerCase() - continue +/** + * Runs a unary method with the given interceptors. Note that this function + * is only used when implementing a Transport. + */ +function runUnaryCall(opt) { + const next = applyInterceptors(opt.next, opt.interceptors); + const [signal, abort, done] = setupSignal(opt); + const req = Object.assign(Object.assign({}, opt.req), { message: normalize(opt.req.method.I, opt.req.message), signal }); + return next(req).then((res) => { + done(); + return res; + }, abort); +} +/** + * Runs a server-streaming method with the given interceptors. Note that this + * function is only used when implementing a Transport. + */ +function runStreamingCall(opt) { + const next = applyInterceptors(opt.next, opt.interceptors); + const [signal, abort, done] = setupSignal(opt); + const req = Object.assign(Object.assign({}, opt.req), { message: normalizeIterable(opt.req.method.I, opt.req.message), signal }); + let doneCalled = false; + // Call return on the request iterable to indicate + // that we will no longer consume it and it should + // cleanup any allocated resources. + signal.addEventListener("abort", function () { + var _a, _b; + const it = opt.req.message[Symbol.asyncIterator](); + // If the signal is aborted due to an error, we want to throw + // the error to the request iterator. + if (!doneCalled) { + (_a = it.throw) === null || _a === void 0 ? void 0 : _a.call(it, this.reason).catch(() => { + // throw returns a promise, which we don't care about. + // + // Uncaught promises are thrown at sometime/somewhere by the event loop, + // this is to ensure error is caught and ignored. + }); } - return decoders.other.bind(charset) - } - } + (_b = it.return) === null || _b === void 0 ? void 0 : _b.call(it).catch(() => { + // return returns a promise, which we don't care about. + // + // Uncaught promises are thrown at sometime/somewhere by the event loop, + // this is to ensure error is caught and ignored. + }); + }); + return next(req).then((res) => { + return Object.assign(Object.assign({}, res), { message: { + [Symbol.asyncIterator]() { + const it = res.message[Symbol.asyncIterator](); + return { + next() { + return it.next().then((r) => { + if (r.done == true) { + doneCalled = true; + done(); + } + return r; + }, abort); + }, + // We deliberately omit throw/return. + }; + }, + } }); + }, abort); +} +/** + * Create an AbortSignal for Transport implementations. The signal is available + * in UnaryRequest and StreamingRequest, and is triggered when the call is + * aborted (via a timeout or explicit cancellation), errored (e.g. when reading + * an error from the server from the wire), or finished successfully. + * + * Transport implementations can pass the signal to HTTP clients to ensure that + * there are no unused connections leak. + * + * Returns a tuple: + * [0]: The signal, which is also aborted if the optional deadline is reached. + * [1]: Function to call if the Transport encountered an error. + * [2]: Function to call if the Transport finished without an error. + */ +function setupSignal(opt) { + const { signal, cleanup } = createDeadlineSignal(opt.timeoutMs); + const controller = createLinkedAbortController(opt.signal, signal); + return [ + controller.signal, + function abort(reason) { + // We peek at the deadline signal because fetch() will throw an error on + // abort that discards the signal reason. + const e = connect_error_ConnectError.from(signal.aborted ? getAbortSignalReason(signal) : reason); + controller.abort(e); + cleanup(); + return Promise.reject(e); + }, + function done() { + cleanup(); + controller.abort(); + }, + ]; +} + +;// CONCATENATED MODULE: ./node_modules/@connectrpc/connect/dist/esm/protocol/serialization.js +// Copyright 2021-2024 The Connect Authors +// +// Licensed under the Apache License, Version 2.0 (the "License"); +// you may not use this file except in compliance with the License. +// You may obtain a copy of the License at +// +// http://www.apache.org/licenses/LICENSE-2.0 +// +// Unless required by applicable law or agreed to in writing, software +// distributed under the License is distributed on an "AS IS" BASIS, +// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. +// See the License for the specific language governing permissions and +// limitations under the License. + + + +/** + * Sets default JSON serialization options for connect-es. + * + * With standard protobuf JSON serialization, unknown JSON fields are + * rejected by default. In connect-es, unknown JSON fields are ignored + * by default. + */ +function getJsonOptions(options) { + var _a; + const o = Object.assign({}, options); + (_a = o.ignoreUnknownFields) !== null && _a !== void 0 ? _a : (o.ignoreUnknownFields = true); + return o; +} +/** + * Create an object that provides convenient access to request and response + * message serialization for a given method. + * + * @private Internal code, does not follow semantic versioning. + */ +function createMethodSerializationLookup(method, binaryOptions, jsonOptions, limitOptions) { + const inputBinary = limitSerialization(createBinarySerialization(method.I, binaryOptions), limitOptions); + const inputJson = limitSerialization(createJsonSerialization(method.I, jsonOptions), limitOptions); + const outputBinary = limitSerialization(createBinarySerialization(method.O, binaryOptions), limitOptions); + const outputJson = limitSerialization(createJsonSerialization(method.O, jsonOptions), limitOptions); + return { + getI(useBinaryFormat) { + return useBinaryFormat ? inputBinary : inputJson; + }, + getO(useBinaryFormat) { + return useBinaryFormat ? outputBinary : outputJson; + }, + }; +} +/** + * Returns functions to normalize and serialize the input message + * of an RPC, and to parse the output message of an RPC. + * + * @private Internal code, does not follow semantic versioning. + */ +function createClientMethodSerializers(method, useBinaryFormat, jsonOptions, binaryOptions) { + const input = useBinaryFormat + ? createBinarySerialization(method.I, binaryOptions) + : createJsonSerialization(method.I, jsonOptions); + const output = useBinaryFormat + ? createBinarySerialization(method.O, binaryOptions) + : createJsonSerialization(method.O, jsonOptions); + return { parse: output.parse, serialize: input.serialize }; +} +/** + * Apply I/O limits to a Serialization object, returning a new object. + * + * @private Internal code, does not follow semantic versioning. + */ +function limitSerialization(serialization, limitOptions) { + return { + serialize(data) { + const bytes = serialization.serialize(data); + assertWriteMaxBytes(limitOptions.writeMaxBytes, bytes.byteLength); + return bytes; + }, + parse(data) { + limit_io_assertReadMaxBytes(limitOptions.readMaxBytes, data.byteLength, true); + return serialization.parse(data); + }, + }; +} +/** + * Creates a Serialization object for serializing the given protobuf message + * with the protobuf binary format. + */ +function createBinarySerialization(messageType, options) { + return { + parse(data) { + try { + return messageType.fromBinary(data, options); + } + catch (e) { + const m = e instanceof Error ? e.message : String(e); + throw new connect_error_ConnectError(`parse binary: ${m}`, code_Code.Internal); + } + }, + serialize(data) { + try { + return data.toBinary(options); + } + catch (e) { + const m = e instanceof Error ? e.message : String(e); + throw new connect_error_ConnectError(`serialize binary: ${m}`, code_Code.Internal); + } + }, + }; +} +/** + * Creates a Serialization object for serializing the given protobuf message + * with the protobuf canonical JSON encoding. + * + * By default, unknown fields are ignored. + */ +function createJsonSerialization(messageType, options) { + var _a, _b; + const textEncoder = (_a = options === null || options === void 0 ? void 0 : options.textEncoder) !== null && _a !== void 0 ? _a : new TextEncoder(); + const textDecoder = (_b = options === null || options === void 0 ? void 0 : options.textDecoder) !== null && _b !== void 0 ? _b : new TextDecoder(); + const o = getJsonOptions(options); + return { + parse(data) { + try { + const json = textDecoder.decode(data); + return messageType.fromJsonString(json, o); + } + catch (e) { + throw connect_error_ConnectError.from(e, code_Code.InvalidArgument); + } + }, + serialize(data) { + try { + const json = data.toJsonString(o); + return textEncoder.encode(json); + } + catch (e) { + throw connect_error_ConnectError.from(e, code_Code.Internal); + } + }, + }; } -const decoders = { - utf8: (data, sourceEncoding) => { - if (data.length === 0) { - return '' - } - if (typeof data === 'string') { - data = Buffer.from(data, sourceEncoding) - } - return data.utf8Slice(0, data.length) - }, +;// CONCATENATED MODULE: ./node_modules/@connectrpc/connect/dist/esm/context-values.js +// Copyright 2021-2024 The Connect Authors +// +// Licensed under the Apache License, Version 2.0 (the "License"); +// you may not use this file except in compliance with the License. +// You may obtain a copy of the License at +// +// http://www.apache.org/licenses/LICENSE-2.0 +// +// Unless required by applicable law or agreed to in writing, software +// distributed under the License is distributed on an "AS IS" BASIS, +// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. +// See the License for the specific language governing permissions and +// limitations under the License. +/** + * createContextValues creates a new ContextValues. + */ +function createContextValues() { + return { + get(key) { + return key.id in this ? this[key.id] : key.defaultValue; + }, + set(key, value) { + this[key.id] = value; + return this; + }, + delete(key) { + delete this[key.id]; + return this; + }, + }; +} +/** + * createContextKey creates a new ContextKey. + */ +function createContextKey(defaultValue, options) { + return { id: Symbol(options === null || options === void 0 ? void 0 : options.description), defaultValue }; +} - latin1: (data, sourceEncoding) => { - if (data.length === 0) { - return '' - } - if (typeof data === 'string') { - return data - } - return data.latin1Slice(0, data.length) - }, +;// CONCATENATED MODULE: ./node_modules/@connectrpc/connect/dist/esm/protocol-grpc/transport.js +// Copyright 2021-2024 The Connect Authors +// +// Licensed under the Apache License, Version 2.0 (the "License"); +// you may not use this file except in compliance with the License. +// You may obtain a copy of the License at +// +// http://www.apache.org/licenses/LICENSE-2.0 +// +// Unless required by applicable law or agreed to in writing, software +// distributed under the License is distributed on an "AS IS" BASIS, +// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. +// See the License for the specific language governing permissions and +// limitations under the License. +var transport_asyncValues = (undefined && undefined.__asyncValues) || function (o) { + if (!Symbol.asyncIterator) throw new TypeError("Symbol.asyncIterator is not defined."); + var m = o[Symbol.asyncIterator], i; + return m ? m.call(o) : (o = typeof __values === "function" ? __values(o) : o[Symbol.iterator](), i = {}, verb("next"), verb("throw"), verb("return"), i[Symbol.asyncIterator] = function () { return this; }, i); + function verb(n) { i[n] = o[n] && function (v) { return new Promise(function (resolve, reject) { v = o[n](v), settle(resolve, reject, v.done, v.value); }); }; } + function settle(resolve, reject, d, v) { Promise.resolve(v).then(function(v) { resolve({ value: v, done: d }); }, reject); } +}; +var transport_await = (undefined && undefined.__await) || function (v) { return this instanceof transport_await ? (this.v = v, this) : new transport_await(v); } +var transport_asyncDelegator = (undefined && undefined.__asyncDelegator) || function (o) { + var i, p; + return i = {}, verb("next"), verb("throw", function (e) { throw e; }), verb("return"), i[Symbol.iterator] = function () { return this; }, i; + function verb(n, f) { i[n] = o[n] ? function (v) { return (p = !p) ? { value: transport_await(o[n](v)), done: false } : f ? f(v) : v; } : f; } +}; +var transport_asyncGenerator = (undefined && undefined.__asyncGenerator) || function (thisArg, _arguments, generator) { + if (!Symbol.asyncIterator) throw new TypeError("Symbol.asyncIterator is not defined."); + var g = generator.apply(thisArg, _arguments || []), i, q = []; + return i = {}, verb("next"), verb("throw"), verb("return", awaitReturn), i[Symbol.asyncIterator] = function () { return this; }, i; + function awaitReturn(f) { return function (v) { return Promise.resolve(v).then(f, reject); }; } + function verb(n, f) { if (g[n]) { i[n] = function (v) { return new Promise(function (a, b) { q.push([n, v, a, b]) > 1 || resume(n, v); }); }; if (f) i[n] = f(i[n]); } } + function resume(n, v) { try { step(g[n](v)); } catch (e) { settle(q[0][3], e); } } + function step(r) { r.value instanceof transport_await ? Promise.resolve(r.value.v).then(fulfill, reject) : settle(q[0][2], r); } + function fulfill(value) { resume("next", value); } + function reject(value) { resume("throw", value); } + function settle(f, v) { if (f(v), q.shift(), q.length) resume(q[0][0], q[0][1]); } +}; - utf16le: (data, sourceEncoding) => { - if (data.length === 0) { - return '' - } - if (typeof data === 'string') { - data = Buffer.from(data, sourceEncoding) - } - return data.ucs2Slice(0, data.length) - }, - base64: (data, sourceEncoding) => { - if (data.length === 0) { - return '' - } - if (typeof data === 'string') { - data = Buffer.from(data, sourceEncoding) - } - return data.base64Slice(0, data.length) - }, - other: (data, sourceEncoding) => { - if (data.length === 0) { - return '' - } - if (typeof data === 'string') { - data = Buffer.from(data, sourceEncoding) - } - if (textDecoders.has(this.toString())) { - try { - return textDecoders.get(this).decode(data) - } catch {} - } - return typeof data === 'string' - ? data - : data.toString() - } -} -function decodeText (text, sourceEncoding, destEncoding) { - if (text) { - return getDecoder(destEncoding)(text, sourceEncoding) - } - return text -} -module.exports = decodeText -/***/ }), -/***/ 2393: -/***/ ((module) => { +/** + * Create a Transport for the gRPC protocol. + */ +function transport_createTransport(opt) { + return { + async unary(service, method, signal, timeoutMs, header, message, contextValues) { + const serialization = createMethodSerializationLookup(method, opt.binaryOptions, opt.jsonOptions, opt); + timeoutMs = + timeoutMs === undefined + ? opt.defaultTimeoutMs + : timeoutMs <= 0 + ? undefined + : timeoutMs; + return await runUnaryCall({ + interceptors: opt.interceptors, + signal, + timeoutMs, + req: { + stream: false, + service, + method, + url: createMethodUrl(opt.baseUrl, service, method), + init: {}, + header: requestHeaderWithCompression(opt.useBinaryFormat, timeoutMs, header, opt.acceptCompression, opt.sendCompression), + contextValues: contextValues !== null && contextValues !== void 0 ? contextValues : createContextValues(), + message, + }, + next: async (req) => { + const uRes = await opt.httpClient({ + url: req.url, + method: "POST", + header: req.header, + signal: req.signal, + body: pipe(createAsyncIterable([req.message]), transformSerializeEnvelope(serialization.getI(opt.useBinaryFormat)), transformCompressEnvelope(opt.sendCompression, opt.compressMinBytes), transformJoinEnvelopes(), { + propagateDownStreamError: true, + }), + }); + const { compression, headerError } = validateResponseWithCompression(opt.acceptCompression, uRes.status, uRes.header); + const message = await pipeTo(uRes.body, transformSplitEnvelope(opt.readMaxBytes), transformDecompressEnvelope(compression !== null && compression !== void 0 ? compression : null, opt.readMaxBytes), transformParseEnvelope(serialization.getO(opt.useBinaryFormat)), async (iterable) => { + var _a, e_1, _b, _c; + let message; + try { + for (var _d = true, iterable_1 = transport_asyncValues(iterable), iterable_1_1; iterable_1_1 = await iterable_1.next(), _a = iterable_1_1.done, !_a; _d = true) { + _c = iterable_1_1.value; + _d = false; + const chunk = _c; + if (message !== undefined) { + throw new connect_error_ConnectError("protocol error: received extra output message for unary method", code_Code.Unimplemented); + } + message = chunk; + } + } + catch (e_1_1) { e_1 = { error: e_1_1 }; } + finally { + try { + if (!_d && !_a && (_b = iterable_1.return)) await _b.call(iterable_1); + } + finally { if (e_1) throw e_1.error; } + } + return message; + }, { propagateDownStreamError: false }); + validateTrailer(uRes.trailer, uRes.header); + if (message === undefined) { + // Trailers only response + if (headerError) { + throw headerError; + } + throw new connect_error_ConnectError("protocol error: missing output message for unary method", uRes.trailer.has(headers_headerGrpcStatus) + ? code_Code.Unimplemented + : code_Code.Unknown); + } + if (headerError) { + throw new connect_error_ConnectError("protocol error: received output message for unary method with error status", code_Code.Unknown); + } + return { + stream: false, + service, + method, + header: uRes.header, + message, + trailer: uRes.trailer, + }; + }, + }); + }, + async stream(service, method, signal, timeoutMs, header, input, contextValues) { + const serialization = createMethodSerializationLookup(method, opt.binaryOptions, opt.jsonOptions, opt); + timeoutMs = + timeoutMs === undefined + ? opt.defaultTimeoutMs + : timeoutMs <= 0 + ? undefined + : timeoutMs; + return runStreamingCall({ + interceptors: opt.interceptors, + signal, + timeoutMs, + req: { + stream: true, + service, + method, + url: createMethodUrl(opt.baseUrl, service, method), + init: {}, + header: requestHeaderWithCompression(opt.useBinaryFormat, timeoutMs, header, opt.acceptCompression, opt.sendCompression), + contextValues: contextValues !== null && contextValues !== void 0 ? contextValues : createContextValues(), + message: input, + }, + next: async (req) => { + const uRes = await opt.httpClient({ + url: req.url, + method: "POST", + header: req.header, + signal: req.signal, + body: pipe(req.message, transformSerializeEnvelope(serialization.getI(opt.useBinaryFormat)), transformCompressEnvelope(opt.sendCompression, opt.compressMinBytes), transformJoinEnvelopes(), { propagateDownStreamError: true }), + }); + const { compression, foundStatus, headerError } = validateResponseWithCompression(opt.acceptCompression, uRes.status, uRes.header); + if (headerError) { + throw headerError; + } + const res = Object.assign(Object.assign({}, req), { header: uRes.header, trailer: uRes.trailer, message: pipe(uRes.body, transformSplitEnvelope(opt.readMaxBytes), transformDecompressEnvelope(compression !== null && compression !== void 0 ? compression : null, opt.readMaxBytes), transformParseEnvelope(serialization.getO(opt.useBinaryFormat)), function (iterable) { + return transport_asyncGenerator(this, arguments, function* () { + yield transport_await(yield* transport_asyncDelegator(transport_asyncValues(iterable))); + if (!foundStatus) { + validateTrailer(uRes.trailer, uRes.header); + } + }); + }, { propagateDownStreamError: true }) }); + return res; + }, + }); + }, + }; +} -module.exports = function getLimit (limits, name, defaultLimit) { - if ( - !limits || - limits[name] === undefined || - limits[name] === null - ) { return defaultLimit } +;// CONCATENATED MODULE: ./node_modules/@connectrpc/connect-node/dist/esm/grpc-transport.js +// Copyright 2021-2024 The Connect Authors +// +// Licensed under the Apache License, Version 2.0 (the "License"); +// you may not use this file except in compliance with the License. +// You may obtain a copy of the License at +// +// http://www.apache.org/licenses/LICENSE-2.0 +// +// Unless required by applicable law or agreed to in writing, software +// distributed under the License is distributed on an "AS IS" BASIS, +// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. +// See the License for the specific language governing permissions and +// limitations under the License. - if ( - typeof limits[name] !== 'number' || - isNaN(limits[name]) - ) { throw new TypeError('Limit ' + name + ' is not a valid number') } - return limits[name] +/** + * Create a Transport for the gRPC protocol using the Node.js `http`, `http2`, + * or `http2` module. + */ +function createGrpcTransport(options) { + return transport_createTransport(node_transport_options_validateNodeTransportOptions(options)); } +;// CONCATENATED MODULE: ./node_modules/@connectrpc/connect-node/dist/esm/connect-transport.js +// Copyright 2021-2024 The Connect Authors +// +// Licensed under the Apache License, Version 2.0 (the "License"); +// you may not use this file except in compliance with the License. +// You may obtain a copy of the License at +// +// http://www.apache.org/licenses/LICENSE-2.0 +// +// Unless required by applicable law or agreed to in writing, software +// distributed under the License is distributed on an "AS IS" BASIS, +// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. +// See the License for the specific language governing permissions and +// limitations under the License. -/***/ }), - -/***/ 8929: -/***/ ((module, __unused_webpack_exports, __nccwpck_require__) => { -/* eslint-disable object-property-newline */ +/** + * Create a Transport for the Connect protocol using the Node.js `http`, `http2`, + * or `http2` module. + */ +function createConnectTransport(options) { + return createTransport(validateNodeTransportOptions(options)); +} +;// CONCATENATED MODULE: ./node_modules/@connectrpc/connect-node/dist/esm/node-universal-handler.js +// Copyright 2021-2024 The Connect Authors +// +// Licensed under the Apache License, Version 2.0 (the "License"); +// you may not use this file except in compliance with the License. +// You may obtain a copy of the License at +// +// http://www.apache.org/licenses/LICENSE-2.0 +// +// Unless required by applicable law or agreed to in writing, software +// distributed under the License is distributed on an "AS IS" BASIS, +// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. +// See the License for the specific language governing permissions and +// limitations under the License. +var node_universal_handler_asyncValues = (undefined && undefined.__asyncValues) || function (o) { + if (!Symbol.asyncIterator) throw new TypeError("Symbol.asyncIterator is not defined."); + var m = o[Symbol.asyncIterator], i; + return m ? m.call(o) : (o = typeof __values === "function" ? __values(o) : o[Symbol.iterator](), i = {}, verb("next"), verb("throw"), verb("return"), i[Symbol.asyncIterator] = function () { return this; }, i); + function verb(n) { i[n] = o[n] && function (v) { return new Promise(function (resolve, reject) { v = o[n](v), settle(resolve, reject, v.done, v.value); }); }; } + function settle(resolve, reject, d, v) { Promise.resolve(v).then(function(v) { resolve({ value: v, done: d }); }, reject); } +}; +var node_universal_handler_await = (undefined && undefined.__await) || function (v) { return this instanceof node_universal_handler_await ? (this.v = v, this) : new node_universal_handler_await(v); } +var node_universal_handler_asyncGenerator = (undefined && undefined.__asyncGenerator) || function (thisArg, _arguments, generator) { + if (!Symbol.asyncIterator) throw new TypeError("Symbol.asyncIterator is not defined."); + var g = generator.apply(thisArg, _arguments || []), i, q = []; + return i = {}, verb("next"), verb("throw"), verb("return", awaitReturn), i[Symbol.asyncIterator] = function () { return this; }, i; + function awaitReturn(f) { return function (v) { return Promise.resolve(v).then(f, reject); }; } + function verb(n, f) { if (g[n]) { i[n] = function (v) { return new Promise(function (a, b) { q.push([n, v, a, b]) > 1 || resume(n, v); }); }; if (f) i[n] = f(i[n]); } } + function resume(n, v) { try { step(g[n](v)); } catch (e) { settle(q[0][3], e); } } + function step(r) { r.value instanceof node_universal_handler_await ? Promise.resolve(r.value.v).then(fulfill, reject) : settle(q[0][2], r); } + function fulfill(value) { resume("next", value); } + function reject(value) { resume("throw", value); } + function settle(f, v) { if (f(v), q.shift(), q.length) resume(q[0][0], q[0][1]); } +}; -const decodeText = __nccwpck_require__(2747) -const RE_ENCODED = /%[a-fA-F0-9][a-fA-F0-9]/g -const EncodedLookup = { - '%00': '\x00', '%01': '\x01', '%02': '\x02', '%03': '\x03', '%04': '\x04', - '%05': '\x05', '%06': '\x06', '%07': '\x07', '%08': '\x08', '%09': '\x09', - '%0a': '\x0a', '%0A': '\x0a', '%0b': '\x0b', '%0B': '\x0b', '%0c': '\x0c', - '%0C': '\x0c', '%0d': '\x0d', '%0D': '\x0d', '%0e': '\x0e', '%0E': '\x0e', - '%0f': '\x0f', '%0F': '\x0f', '%10': '\x10', '%11': '\x11', '%12': '\x12', - '%13': '\x13', '%14': '\x14', '%15': '\x15', '%16': '\x16', '%17': '\x17', - '%18': '\x18', '%19': '\x19', '%1a': '\x1a', '%1A': '\x1a', '%1b': '\x1b', - '%1B': '\x1b', '%1c': '\x1c', '%1C': '\x1c', '%1d': '\x1d', '%1D': '\x1d', - '%1e': '\x1e', '%1E': '\x1e', '%1f': '\x1f', '%1F': '\x1f', '%20': '\x20', - '%21': '\x21', '%22': '\x22', '%23': '\x23', '%24': '\x24', '%25': '\x25', - '%26': '\x26', '%27': '\x27', '%28': '\x28', '%29': '\x29', '%2a': '\x2a', - '%2A': '\x2a', '%2b': '\x2b', '%2B': '\x2b', '%2c': '\x2c', '%2C': '\x2c', - '%2d': '\x2d', '%2D': '\x2d', '%2e': '\x2e', '%2E': '\x2e', '%2f': '\x2f', - '%2F': '\x2f', '%30': '\x30', '%31': '\x31', '%32': '\x32', '%33': '\x33', - '%34': '\x34', '%35': '\x35', '%36': '\x36', '%37': '\x37', '%38': '\x38', - '%39': '\x39', '%3a': '\x3a', '%3A': '\x3a', '%3b': '\x3b', '%3B': '\x3b', - '%3c': '\x3c', '%3C': '\x3c', '%3d': '\x3d', '%3D': '\x3d', '%3e': '\x3e', - '%3E': '\x3e', '%3f': '\x3f', '%3F': '\x3f', '%40': '\x40', '%41': '\x41', - '%42': '\x42', '%43': '\x43', '%44': '\x44', '%45': '\x45', '%46': '\x46', - '%47': '\x47', '%48': '\x48', '%49': '\x49', '%4a': '\x4a', '%4A': '\x4a', - '%4b': '\x4b', '%4B': '\x4b', '%4c': '\x4c', '%4C': '\x4c', '%4d': '\x4d', - '%4D': '\x4d', '%4e': '\x4e', '%4E': '\x4e', '%4f': '\x4f', '%4F': '\x4f', - '%50': '\x50', '%51': '\x51', '%52': '\x52', '%53': '\x53', '%54': '\x54', - '%55': '\x55', '%56': '\x56', '%57': '\x57', '%58': '\x58', '%59': '\x59', - '%5a': '\x5a', '%5A': '\x5a', '%5b': '\x5b', '%5B': '\x5b', '%5c': '\x5c', - '%5C': '\x5c', '%5d': '\x5d', '%5D': '\x5d', '%5e': '\x5e', '%5E': '\x5e', - '%5f': '\x5f', '%5F': '\x5f', '%60': '\x60', '%61': '\x61', '%62': '\x62', - '%63': '\x63', '%64': '\x64', '%65': '\x65', '%66': '\x66', '%67': '\x67', - '%68': '\x68', '%69': '\x69', '%6a': '\x6a', '%6A': '\x6a', '%6b': '\x6b', - '%6B': '\x6b', '%6c': '\x6c', '%6C': '\x6c', '%6d': '\x6d', '%6D': '\x6d', - '%6e': '\x6e', '%6E': '\x6e', '%6f': '\x6f', '%6F': '\x6f', '%70': '\x70', - '%71': '\x71', '%72': '\x72', '%73': '\x73', '%74': '\x74', '%75': '\x75', - '%76': '\x76', '%77': '\x77', '%78': '\x78', '%79': '\x79', '%7a': '\x7a', - '%7A': '\x7a', '%7b': '\x7b', '%7B': '\x7b', '%7c': '\x7c', '%7C': '\x7c', - '%7d': '\x7d', '%7D': '\x7d', '%7e': '\x7e', '%7E': '\x7e', '%7f': '\x7f', - '%7F': '\x7f', '%80': '\x80', '%81': '\x81', '%82': '\x82', '%83': '\x83', - '%84': '\x84', '%85': '\x85', '%86': '\x86', '%87': '\x87', '%88': '\x88', - '%89': '\x89', '%8a': '\x8a', '%8A': '\x8a', '%8b': '\x8b', '%8B': '\x8b', - '%8c': '\x8c', '%8C': '\x8c', '%8d': '\x8d', '%8D': '\x8d', '%8e': '\x8e', - '%8E': '\x8e', '%8f': '\x8f', '%8F': '\x8f', '%90': '\x90', '%91': '\x91', - '%92': '\x92', '%93': '\x93', '%94': '\x94', '%95': '\x95', '%96': '\x96', - '%97': '\x97', '%98': '\x98', '%99': '\x99', '%9a': '\x9a', '%9A': '\x9a', - '%9b': '\x9b', '%9B': '\x9b', '%9c': '\x9c', '%9C': '\x9c', '%9d': '\x9d', - '%9D': '\x9d', '%9e': '\x9e', '%9E': '\x9e', '%9f': '\x9f', '%9F': '\x9f', - '%a0': '\xa0', '%A0': '\xa0', '%a1': '\xa1', '%A1': '\xa1', '%a2': '\xa2', - '%A2': '\xa2', '%a3': '\xa3', '%A3': '\xa3', '%a4': '\xa4', '%A4': '\xa4', - '%a5': '\xa5', '%A5': '\xa5', '%a6': '\xa6', '%A6': '\xa6', '%a7': '\xa7', - '%A7': '\xa7', '%a8': '\xa8', '%A8': '\xa8', '%a9': '\xa9', '%A9': '\xa9', - '%aa': '\xaa', '%Aa': '\xaa', '%aA': '\xaa', '%AA': '\xaa', '%ab': '\xab', - '%Ab': '\xab', '%aB': '\xab', '%AB': '\xab', '%ac': '\xac', '%Ac': '\xac', - '%aC': '\xac', '%AC': '\xac', '%ad': '\xad', '%Ad': '\xad', '%aD': '\xad', - '%AD': '\xad', '%ae': '\xae', '%Ae': '\xae', '%aE': '\xae', '%AE': '\xae', - '%af': '\xaf', '%Af': '\xaf', '%aF': '\xaf', '%AF': '\xaf', '%b0': '\xb0', - '%B0': '\xb0', '%b1': '\xb1', '%B1': '\xb1', '%b2': '\xb2', '%B2': '\xb2', - '%b3': '\xb3', '%B3': '\xb3', '%b4': '\xb4', '%B4': '\xb4', '%b5': '\xb5', - '%B5': '\xb5', '%b6': '\xb6', '%B6': '\xb6', '%b7': '\xb7', '%B7': '\xb7', - '%b8': '\xb8', '%B8': '\xb8', '%b9': '\xb9', '%B9': '\xb9', '%ba': '\xba', - '%Ba': '\xba', '%bA': '\xba', '%BA': '\xba', '%bb': '\xbb', '%Bb': '\xbb', - '%bB': '\xbb', '%BB': '\xbb', '%bc': '\xbc', '%Bc': '\xbc', '%bC': '\xbc', - '%BC': '\xbc', '%bd': '\xbd', '%Bd': '\xbd', '%bD': '\xbd', '%BD': '\xbd', - '%be': '\xbe', '%Be': '\xbe', '%bE': '\xbe', '%BE': '\xbe', '%bf': '\xbf', - '%Bf': '\xbf', '%bF': '\xbf', '%BF': '\xbf', '%c0': '\xc0', '%C0': '\xc0', - '%c1': '\xc1', '%C1': '\xc1', '%c2': '\xc2', '%C2': '\xc2', '%c3': '\xc3', - '%C3': '\xc3', '%c4': '\xc4', '%C4': '\xc4', '%c5': '\xc5', '%C5': '\xc5', - '%c6': '\xc6', '%C6': '\xc6', '%c7': '\xc7', '%C7': '\xc7', '%c8': '\xc8', - '%C8': '\xc8', '%c9': '\xc9', '%C9': '\xc9', '%ca': '\xca', '%Ca': '\xca', - '%cA': '\xca', '%CA': '\xca', '%cb': '\xcb', '%Cb': '\xcb', '%cB': '\xcb', - '%CB': '\xcb', '%cc': '\xcc', '%Cc': '\xcc', '%cC': '\xcc', '%CC': '\xcc', - '%cd': '\xcd', '%Cd': '\xcd', '%cD': '\xcd', '%CD': '\xcd', '%ce': '\xce', - '%Ce': '\xce', '%cE': '\xce', '%CE': '\xce', '%cf': '\xcf', '%Cf': '\xcf', - '%cF': '\xcf', '%CF': '\xcf', '%d0': '\xd0', '%D0': '\xd0', '%d1': '\xd1', - '%D1': '\xd1', '%d2': '\xd2', '%D2': '\xd2', '%d3': '\xd3', '%D3': '\xd3', - '%d4': '\xd4', '%D4': '\xd4', '%d5': '\xd5', '%D5': '\xd5', '%d6': '\xd6', - '%D6': '\xd6', '%d7': '\xd7', '%D7': '\xd7', '%d8': '\xd8', '%D8': '\xd8', - '%d9': '\xd9', '%D9': '\xd9', '%da': '\xda', '%Da': '\xda', '%dA': '\xda', - '%DA': '\xda', '%db': '\xdb', '%Db': '\xdb', '%dB': '\xdb', '%DB': '\xdb', - '%dc': '\xdc', '%Dc': '\xdc', '%dC': '\xdc', '%DC': '\xdc', '%dd': '\xdd', - '%Dd': '\xdd', '%dD': '\xdd', '%DD': '\xdd', '%de': '\xde', '%De': '\xde', - '%dE': '\xde', '%DE': '\xde', '%df': '\xdf', '%Df': '\xdf', '%dF': '\xdf', - '%DF': '\xdf', '%e0': '\xe0', '%E0': '\xe0', '%e1': '\xe1', '%E1': '\xe1', - '%e2': '\xe2', '%E2': '\xe2', '%e3': '\xe3', '%E3': '\xe3', '%e4': '\xe4', - '%E4': '\xe4', '%e5': '\xe5', '%E5': '\xe5', '%e6': '\xe6', '%E6': '\xe6', - '%e7': '\xe7', '%E7': '\xe7', '%e8': '\xe8', '%E8': '\xe8', '%e9': '\xe9', - '%E9': '\xe9', '%ea': '\xea', '%Ea': '\xea', '%eA': '\xea', '%EA': '\xea', - '%eb': '\xeb', '%Eb': '\xeb', '%eB': '\xeb', '%EB': '\xeb', '%ec': '\xec', - '%Ec': '\xec', '%eC': '\xec', '%EC': '\xec', '%ed': '\xed', '%Ed': '\xed', - '%eD': '\xed', '%ED': '\xed', '%ee': '\xee', '%Ee': '\xee', '%eE': '\xee', - '%EE': '\xee', '%ef': '\xef', '%Ef': '\xef', '%eF': '\xef', '%EF': '\xef', - '%f0': '\xf0', '%F0': '\xf0', '%f1': '\xf1', '%F1': '\xf1', '%f2': '\xf2', - '%F2': '\xf2', '%f3': '\xf3', '%F3': '\xf3', '%f4': '\xf4', '%F4': '\xf4', - '%f5': '\xf5', '%F5': '\xf5', '%f6': '\xf6', '%F6': '\xf6', '%f7': '\xf7', - '%F7': '\xf7', '%f8': '\xf8', '%F8': '\xf8', '%f9': '\xf9', '%F9': '\xf9', - '%fa': '\xfa', '%Fa': '\xfa', '%fA': '\xfa', '%FA': '\xfa', '%fb': '\xfb', - '%Fb': '\xfb', '%fB': '\xfb', '%FB': '\xfb', '%fc': '\xfc', '%Fc': '\xfc', - '%fC': '\xfc', '%FC': '\xfc', '%fd': '\xfd', '%Fd': '\xfd', '%fD': '\xfd', - '%FD': '\xfd', '%fe': '\xfe', '%Fe': '\xfe', '%fE': '\xfe', '%FE': '\xfe', - '%ff': '\xff', '%Ff': '\xff', '%fF': '\xff', '%FF': '\xff' +function node_universal_handler_universalRequestFromNodeRequest(nodeRequest, ...rest) { + var _a, _b; + const nodeResponse = rest.length === 3 ? rest[0] : undefined; + const parsedJsonBody = rest.length === 3 ? rest[1] : rest[0]; + const contextValues = rest.length === 3 ? rest[2] : rest[1]; + const encrypted = "encrypted" in nodeRequest.socket && nodeRequest.socket.encrypted; + const protocol = encrypted ? "https" : "http"; + const authority = "authority" in nodeRequest + ? nodeRequest.authority + : nodeRequest.headers.host; + const pathname = (_a = nodeRequest.url) !== null && _a !== void 0 ? _a : ""; + if (authority === undefined) { + throw new ConnectError("unable to determine request authority from Node.js server request", Code.Internal); + } + const body = parsedJsonBody !== undefined + ? parsedJsonBody + : asyncIterableFromNodeServerRequest(nodeRequest); + const abortController = new AbortController(); + if ("stream" in nodeRequest) { + // HTTP/2 has error codes we want to honor + nodeRequest.once("close", () => { + const err = connectErrorFromH2ResetCode(nodeRequest.stream.rstCode); + if (err !== undefined) { + abortController.abort(err); + } + else { + abortController.abort(); + } + }); + } + else { + // HTTP/1.1 does not have error codes, but Node.js has ECONNRESET + const nodeResponsOrRequest = nodeResponse !== null && nodeResponse !== void 0 ? nodeResponse : nodeRequest; + const onH1Error = (e) => { + nodeRequest.off("error", onH1Error); + nodeResponsOrRequest.off("close", onH1Close); + abortController.abort(connectErrorFromNodeReason(e)); + }; + const onH1Close = () => { + nodeRequest.off("error", onH1Error); + nodeResponsOrRequest.off("close", onH1Close); + // When subscribed to the response, this can get called before "error" + abortController.abort(nodeRequest.errored + ? connectErrorFromNodeReason(nodeRequest.errored) + : undefined); + }; + nodeRequest.once("error", onH1Error); + // Node emits close on the request as soon as all data is read. + // We instead subscribe to the response (if available) + // + // Ref: https://github.com/nodejs/node/issues/40775 + nodeResponsOrRequest.once("close", onH1Close); + } + return { + httpVersion: nodeRequest.httpVersion, + method: (_b = nodeRequest.method) !== null && _b !== void 0 ? _b : "", + url: new URL(pathname, `${protocol}://${authority}`).toString(), + header: nodeHeaderToWebHeader(nodeRequest.headers), + body, + signal: abortController.signal, + contextValues: contextValues, + }; +} +/** + * Writes a UniversalServerResponse to a Node.js server response. + * This function helps to implement adapters to server frameworks running + * on Node.js. Please be careful using this function in your own code, as we + * may have to make changes to it in the future. + */ +async function node_universal_handler_universalResponseToNodeResponse(universalResponse, nodeResponse) { + var _a, _b, _c; + const it = (_a = universalResponse.body) === null || _a === void 0 ? void 0 : _a[Symbol.asyncIterator](); + let isWriteError = false; + try { + if (it !== undefined) { + let chunk = await it.next(); + isWriteError = true; + // we deliberately send headers after first read, not before, + // because we have to give the implementation a chance to + // set response headers + nodeResponse.writeHead(universalResponse.status, webHeaderToNodeHeaders(universalResponse.header)); + isWriteError = false; + for (; chunk.done !== true; chunk = await it.next()) { + isWriteError = true; + await write(nodeResponse, chunk.value); + if ("flush" in nodeResponse && + typeof nodeResponse.flush == "function") { + // The npm package "compression" is an express middleware that is widely used, + // for example in next.js. It uses the npm package "compressible" to determine + // whether to apply compression to a response. Unfortunately, "compressible" + // matches every mime type that ends with "+json", causing our server-streaming + // RPCs to be buffered. + // The package modifies the response object, and adds a flush() method, which + // flushes the underlying gzip or deflate stream from the Node.js zlib module. + // The method is added here: + // https://github.com/expressjs/compression/blob/ad5113b98cafe1382a0ece30bb4673707ac59ce7/index.js#L70 + nodeResponse.flush(); + } + isWriteError = false; + } + } + if (!nodeResponse.headersSent) { + nodeResponse.writeHead(universalResponse.status, webHeaderToNodeHeaders(universalResponse.header)); + } + if (universalResponse.trailer) { + nodeResponse.addTrailers(webHeaderToNodeHeaders(universalResponse.trailer)); + } + await new Promise((resolve) => { + // The npm package "compression" crashes when a callback is passed to end() + // https://github.com/expressjs/compression/blob/ad5113b98cafe1382a0ece30bb4673707ac59ce7/index.js#L115 + nodeResponse.once("end", resolve); + nodeResponse.end(); + }); + } + catch (e) { + // Report write errors to the handler. + if (isWriteError) { + (_b = it === null || it === void 0 ? void 0 : it.throw) === null || _b === void 0 ? void 0 : _b.call(it, e).catch(() => { }); + } + throw connectErrorFromNodeReason(e); + } + finally { + (_c = it === null || it === void 0 ? void 0 : it.return) === null || _c === void 0 ? void 0 : _c.call(it).catch(() => { }); + } +} +function asyncIterableFromNodeServerRequest(request) { + return node_universal_handler_asyncGenerator(this, arguments, function* asyncIterableFromNodeServerRequest_1() { + var _a, e_1, _b, _c; + const it = request.iterator({ + // Node.js v16 closes request and response when this option isn't disabled. + // When one of our handlers receives invalid data (such as an unexpected + // compression flag in a streaming request), we're unable to write the error + // response. + // Later major versions have a more sensible behavior - we can revert this + // workaround once we stop supporting v16. + destroyOnReturn: false, + }); + try { + for (var _d = true, it_1 = node_universal_handler_asyncValues(it), it_1_1; it_1_1 = yield node_universal_handler_await(it_1.next()), _a = it_1_1.done, !_a; _d = true) { + _c = it_1_1.value; + _d = false; + const chunk = _c; + yield yield node_universal_handler_await(chunk); + } + } + catch (e_1_1) { e_1 = { error: e_1_1 }; } + finally { + try { + if (!_d && !_a && (_b = it_1.return)) yield node_universal_handler_await(_b.call(it_1)); + } + finally { if (e_1) throw e_1.error; } + } + }); } - -function encodedReplacer (match) { - return EncodedLookup[match] +function write(stream, data) { + return new Promise((resolve, reject) => { + if (stream.errored) { + return error(stream.errored); + } + stream.once("error", error); + stream.once("drain", drain); + // flushed == false: the stream wishes for the calling code to wait for + // the 'drain' event to be emitted before continuing to write additional + // data. + const flushed = stream.write(data, "binary", function (err) { + if (err && !flushed) { + // We are never getting a "drain" nor an "error" event if the stream + // has already ended (ERR_STREAM_WRITE_AFTER_END), so we have to + // resolve our promise in this callback. + error(err); + // However, once we do that (and remove our event listeners), we _do_ + // get an "error" event, which ends up as an uncaught exception. + // We silence this error specifically with the following listener. + // All of this seems very fragile. + stream.once("error", () => { + // + }); + } + }); + if (flushed) { + drain(); + } + function error(err) { + stream.off("error", error); + stream.off("drain", drain); + reject(err); + } + function drain() { + stream.off("error", error); + stream.off("drain", drain); + resolve(); + } + }); } -const STATE_KEY = 0 -const STATE_VALUE = 1 -const STATE_CHARSET = 2 -const STATE_LANG = 3 +;// CONCATENATED MODULE: ./node_modules/@connectrpc/connect-node/dist/esm/connect-node-adapter.js +// Copyright 2021-2024 The Connect Authors +// +// Licensed under the Apache License, Version 2.0 (the "License"); +// you may not use this file except in compliance with the License. +// You may obtain a copy of the License at +// +// http://www.apache.org/licenses/LICENSE-2.0 +// +// Unless required by applicable law or agreed to in writing, software +// distributed under the License is distributed on an "AS IS" BASIS, +// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. +// See the License for the specific language governing permissions and +// limitations under the License. -function parseParams (str) { - const res = [] - let state = STATE_KEY - let charset = '' - let inquote = false - let escaping = false - let p = 0 - let tmp = '' - const len = str.length - for (var i = 0; i < len; ++i) { // eslint-disable-line no-var - const char = str[i] - if (char === '\\' && inquote) { - if (escaping) { escaping = false } else { - escaping = true - continue - } - } else if (char === '"') { - if (!escaping) { - if (inquote) { - inquote = false - state = STATE_KEY - } else { inquote = true } - continue - } else { escaping = false } - } else { - if (escaping && inquote) { tmp += '\\' } - escaping = false - if ((state === STATE_CHARSET || state === STATE_LANG) && char === "'") { - if (state === STATE_CHARSET) { - state = STATE_LANG - charset = tmp.substring(1) - } else { state = STATE_VALUE } - tmp = '' - continue - } else if (state === STATE_KEY && - (char === '*' || char === '=') && - res.length) { - state = char === '*' - ? STATE_CHARSET - : STATE_VALUE - res[p] = [tmp, undefined] - tmp = '' - continue - } else if (!inquote && char === ';') { - state = STATE_KEY - if (charset) { - if (tmp.length) { - tmp = decodeText(tmp.replace(RE_ENCODED, encodedReplacer), - 'binary', - charset) - } - charset = '' - } else if (tmp.length) { - tmp = decodeText(tmp, 'binary', 'utf8') + + +/** + * Create a Node.js request handler from a ConnectRouter. + * + * The returned function is compatible with http.RequestListener and its equivalent for http2. + */ +function connectNodeAdapter(options) { + var _a; + if (options.acceptCompression === undefined) { + options.acceptCompression = [compressionGzip, compressionBrotli]; + } + const router = createConnectRouter(options); + options.routes(router); + const prefix = (_a = options.requestPathPrefix) !== null && _a !== void 0 ? _a : ""; + const paths = new Map(); + for (const uHandler of router.handlers) { + paths.set(prefix + uHandler.requestPath, uHandler); + } + return function nodeRequestHandler(req, res) { + var _a, _b, _c, _d; + // Strip the query parameter when matching paths. + const uHandler = paths.get((_b = (_a = req.url) === null || _a === void 0 ? void 0 : _a.split("?", 2)[0]) !== null && _b !== void 0 ? _b : ""); + if (!uHandler) { + ((_c = options.fallback) !== null && _c !== void 0 ? _c : connect_node_adapter_fallback)(req, res); + return; } - if (res[p] === undefined) { res[p] = tmp } else { res[p][1] = tmp } - tmp = '' - ++p - continue - } else if (!inquote && (char === ' ' || char === '\t')) { continue } - } - tmp += char - } - if (charset && tmp.length) { - tmp = decodeText(tmp.replace(RE_ENCODED, encodedReplacer), - 'binary', - charset) - } else if (tmp) { - tmp = decodeText(tmp, 'binary', 'utf8') + const uReq = universalRequestFromNodeRequest(req, res, undefined, (_d = options.contextValues) === null || _d === void 0 ? void 0 : _d.call(options, req)); + uHandler(uReq) + .then((uRes) => universalResponseToNodeResponse(uRes, res)) + .catch((reason) => { + if (ConnectError.from(reason).code == Code.Aborted) { + return; + } + // eslint-disable-next-line no-console + console.error(`handler for rpc ${uHandler.method.name} of ${uHandler.service.typeName} failed`, reason); + }); + }; +} +const connect_node_adapter_fallback = (request, response) => { + response.writeHead(uResponseNotFound.status); + response.end(); +}; + +;// CONCATENATED MODULE: ./node_modules/@connectrpc/connect-node/dist/esm/index.js +// Copyright 2021-2024 The Connect Authors +// +// Licensed under the Apache License, Version 2.0 (the "License"); +// you may not use this file except in compliance with the License. +// You may obtain a copy of the License at +// +// http://www.apache.org/licenses/LICENSE-2.0 +// +// Unless required by applicable law or agreed to in writing, software +// distributed under the License is distributed on an "AS IS" BASIS, +// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. +// See the License for the specific language governing permissions and +// limitations under the License. +// Polyfill the Headers API for Node versions < 18 + + + + + + + + + + +;// CONCATENATED MODULE: ./node_modules/@buf/blacksmith_vm-agent.bufbuild_es/stickydisk/v1/stickydisk_pb.js +// @generated by protoc-gen-es v1.10.0 +// @generated from file stickydisk/v1/stickydisk.proto (package stickydisk.v1, syntax proto3) +/* eslint-disable */ +// @ts-nocheck + + + +/** + * @generated from message stickydisk.v1.GetStickyDiskRequest + */ +const GetStickyDiskRequest = /*@__PURE__*/ proto3.makeMessageType( + "stickydisk.v1.GetStickyDiskRequest", + () => [ + { no: 1, name: "sticky_disk_key", kind: "scalar", T: 9 /* ScalarType.STRING */ }, + { no: 2, name: "region", kind: "scalar", T: 9 /* ScalarType.STRING */ }, + { no: 3, name: "installation_model_id", kind: "scalar", T: 9 /* ScalarType.STRING */ }, + { no: 4, name: "vm_id", kind: "scalar", T: 9 /* ScalarType.STRING */ }, + { no: 5, name: "sticky_disk_type", kind: "scalar", T: 9 /* ScalarType.STRING */ }, + { no: 6, name: "repo_name", kind: "scalar", T: 9 /* ScalarType.STRING */ }, + { no: 7, name: "sticky_disk_token", kind: "scalar", T: 9 /* ScalarType.STRING */ }, + ], +); + +/** + * @generated from message stickydisk.v1.GetStickyDiskResponse + */ +const GetStickyDiskResponse = /*@__PURE__*/ proto3.makeMessageType( + "stickydisk.v1.GetStickyDiskResponse", + () => [ + { no: 1, name: "expose_id", kind: "scalar", T: 9 /* ScalarType.STRING */ }, + { no: 2, name: "disk_identifier", kind: "scalar", T: 9 /* ScalarType.STRING */ }, + ], +); + +/** + * @generated from message stickydisk.v1.CommitStickyDiskRequest + */ +const CommitStickyDiskRequest = /*@__PURE__*/ proto3.makeMessageType( + "stickydisk.v1.CommitStickyDiskRequest", + () => [ + { no: 1, name: "expose_id", kind: "scalar", T: 9 /* ScalarType.STRING */ }, + { no: 2, name: "sticky_disk_key", kind: "scalar", T: 9 /* ScalarType.STRING */ }, + { no: 3, name: "vm_id", kind: "scalar", T: 9 /* ScalarType.STRING */ }, + { no: 4, name: "should_commit", kind: "scalar", T: 8 /* ScalarType.BOOL */ }, + { no: 5, name: "repo_name", kind: "scalar", T: 9 /* ScalarType.STRING */ }, + { no: 6, name: "sticky_disk_token", kind: "scalar", T: 9 /* ScalarType.STRING */ }, + ], +); + +/** + * @generated from message stickydisk.v1.CommitStickyDiskResponse + */ +const CommitStickyDiskResponse = /*@__PURE__*/ proto3.makeMessageType( + "stickydisk.v1.CommitStickyDiskResponse", + [], +); + +/** + * @generated from message stickydisk.v1.UpRequest + */ +const UpRequest = /*@__PURE__*/ proto3.makeMessageType( + "stickydisk.v1.UpRequest", + [], +); + +/** + * @generated from message stickydisk.v1.UpResponse + */ +const UpResponse = /*@__PURE__*/ proto3.makeMessageType( + "stickydisk.v1.UpResponse", + [], +); + + +;// CONCATENATED MODULE: ./node_modules/@buf/blacksmith_vm-agent.connectrpc_es/stickydisk/v1/stickydisk_connect.js +// @generated by protoc-gen-connect-es v1.6.1 +// @generated from file stickydisk/v1/stickydisk.proto (package stickydisk.v1, syntax proto3) +/* eslint-disable */ +// @ts-nocheck + + + + +/** + * @generated from service stickydisk.v1.StickyDiskService + */ +const StickyDiskService = { + typeName: "stickydisk.v1.StickyDiskService", + methods: { + /** + * @generated from rpc stickydisk.v1.StickyDiskService.GetStickyDisk + */ + getStickyDisk: { + name: "GetStickyDisk", + I: GetStickyDiskRequest, + O: GetStickyDiskResponse, + kind: MethodKind.Unary, + }, + /** + * @generated from rpc stickydisk.v1.StickyDiskService.CommitStickyDisk + */ + commitStickyDisk: { + name: "CommitStickyDisk", + I: CommitStickyDiskRequest, + O: CommitStickyDiskResponse, + kind: MethodKind.Unary, + }, + /** + * @generated from rpc stickydisk.v1.StickyDiskService.Up + */ + up: { + name: "Up", + I: UpRequest, + O: UpResponse, + kind: MethodKind.Unary, + }, } +}; - if (res[p] === undefined) { - if (tmp) { res[p] = tmp } - } else { res[p][1] = tmp } - return res -} +;// CONCATENATED MODULE: ./src/utils.ts -module.exports = parseParams -/***/ }), +function createStickyDiskClient() { + const transport = createGrpcTransport({ + baseUrl: 'http://192.168.127.1:5557', + httpVersion: '2', + }); + return createClient(StickyDiskService, transport); +} -/***/ 2472: -/***/ ((module) => { +;// CONCATENATED MODULE: ./src/main.ts -module.exports = /*#__PURE__*/JSON.parse('[[[0,44],"disallowed_STD3_valid"],[[45,46],"valid"],[[47,47],"disallowed_STD3_valid"],[[48,57],"valid"],[[58,64],"disallowed_STD3_valid"],[[65,65],"mapped",[97]],[[66,66],"mapped",[98]],[[67,67],"mapped",[99]],[[68,68],"mapped",[100]],[[69,69],"mapped",[101]],[[70,70],"mapped",[102]],[[71,71],"mapped",[103]],[[72,72],"mapped",[104]],[[73,73],"mapped",[105]],[[74,74],"mapped",[106]],[[75,75],"mapped",[107]],[[76,76],"mapped",[108]],[[77,77],"mapped",[109]],[[78,78],"mapped",[110]],[[79,79],"mapped",[111]],[[80,80],"mapped",[112]],[[81,81],"mapped",[113]],[[82,82],"mapped",[114]],[[83,83],"mapped",[115]],[[84,84],"mapped",[116]],[[85,85],"mapped",[117]],[[86,86],"mapped",[118]],[[87,87],"mapped",[119]],[[88,88],"mapped",[120]],[[89,89],"mapped",[121]],[[90,90],"mapped",[122]],[[91,96],"disallowed_STD3_valid"],[[97,122],"valid"],[[123,127],"disallowed_STD3_valid"],[[128,159],"disallowed"],[[160,160],"disallowed_STD3_mapped",[32]],[[161,167],"valid",[],"NV8"],[[168,168],"disallowed_STD3_mapped",[32,776]],[[169,169],"valid",[],"NV8"],[[170,170],"mapped",[97]],[[171,172],"valid",[],"NV8"],[[173,173],"ignored"],[[174,174],"valid",[],"NV8"],[[175,175],"disallowed_STD3_mapped",[32,772]],[[176,177],"valid",[],"NV8"],[[178,178],"mapped",[50]],[[179,179],"mapped",[51]],[[180,180],"disallowed_STD3_mapped",[32,769]],[[181,181],"mapped",[956]],[[182,182],"valid",[],"NV8"],[[183,183],"valid"],[[184,184],"disallowed_STD3_mapped",[32,807]],[[185,185],"mapped",[49]],[[186,186],"mapped",[111]],[[187,187],"valid",[],"NV8"],[[188,188],"mapped",[49,8260,52]],[[189,189],"mapped",[49,8260,50]],[[190,190],"mapped",[51,8260,52]],[[191,191],"valid",[],"NV8"],[[192,192],"mapped",[224]],[[193,193],"mapped",[225]],[[194,194],"mapped",[226]],[[195,195],"mapped",[227]],[[196,196],"mapped",[228]],[[197,197],"mapped",[229]],[[198,198],"mapped",[230]],[[199,199],"mapped",[231]],[[200,200],"mapped",[232]],[[201,201],"mapped",[233]],[[202,202],"mapped",[234]],[[203,203],"mapped",[235]],[[204,204],"mapped",[236]],[[205,205],"mapped",[237]],[[206,206],"mapped",[238]],[[207,207],"mapped",[239]],[[208,208],"mapped",[240]],[[209,209],"mapped",[241]],[[210,210],"mapped",[242]],[[211,211],"mapped",[243]],[[212,212],"mapped",[244]],[[213,213],"mapped",[245]],[[214,214],"mapped",[246]],[[215,215],"valid",[],"NV8"],[[216,216],"mapped",[248]],[[217,217],"mapped",[249]],[[218,218],"mapped",[250]],[[219,219],"mapped",[251]],[[220,220],"mapped",[252]],[[221,221],"mapped",[253]],[[222,222],"mapped",[254]],[[223,223],"deviation",[115,115]],[[224,246],"valid"],[[247,247],"valid",[],"NV8"],[[248,255],"valid"],[[256,256],"mapped",[257]],[[257,257],"valid"],[[258,258],"mapped",[259]],[[259,259],"valid"],[[260,260],"mapped",[261]],[[261,261],"valid"],[[262,262],"mapped",[263]],[[263,263],"valid"],[[264,264],"mapped",[265]],[[265,265],"valid"],[[266,266],"mapped",[267]],[[267,267],"valid"],[[268,268],"mapped",[269]],[[269,269],"valid"],[[270,270],"mapped",[271]],[[271,271],"valid"],[[272,272],"mapped",[273]],[[273,273],"valid"],[[274,274],"mapped",[275]],[[275,275],"valid"],[[276,276],"mapped",[277]],[[277,277],"valid"],[[278,278],"mapped",[279]],[[279,279],"valid"],[[280,280],"mapped",[281]],[[281,281],"valid"],[[282,282],"mapped",[283]],[[283,283],"valid"],[[284,284],"mapped",[285]],[[285,285],"valid"],[[286,286],"mapped",[287]],[[287,287],"valid"],[[288,288],"mapped",[289]],[[289,289],"valid"],[[290,290],"mapped",[291]],[[291,291],"valid"],[[292,292],"mapped",[293]],[[293,293],"valid"],[[294,294],"mapped",[295]],[[295,295],"valid"],[[296,296],"mapped",[297]],[[297,297],"valid"],[[298,298],"mapped",[299]],[[299,299],"valid"],[[300,300],"mapped",[301]],[[301,301],"valid"],[[302,302],"mapped",[303]],[[303,303],"valid"],[[304,304],"mapped",[105,775]],[[305,305],"valid"],[[306,307],"mapped",[105,106]],[[308,308],"mapped",[309]],[[309,309],"valid"],[[310,310],"mapped",[311]],[[311,312],"valid"],[[313,313],"mapped",[314]],[[314,314],"valid"],[[315,315],"mapped",[316]],[[316,316],"valid"],[[317,317],"mapped",[318]],[[318,318],"valid"],[[319,320],"mapped",[108,183]],[[321,321],"mapped",[322]],[[322,322],"valid"],[[323,323],"mapped",[324]],[[324,324],"valid"],[[325,325],"mapped",[326]],[[326,326],"valid"],[[327,327],"mapped",[328]],[[328,328],"valid"],[[329,329],"mapped",[700,110]],[[330,330],"mapped",[331]],[[331,331],"valid"],[[332,332],"mapped",[333]],[[333,333],"valid"],[[334,334],"mapped",[335]],[[335,335],"valid"],[[336,336],"mapped",[337]],[[337,337],"valid"],[[338,338],"mapped",[339]],[[339,339],"valid"],[[340,340],"mapped",[341]],[[341,341],"valid"],[[342,342],"mapped",[343]],[[343,343],"valid"],[[344,344],"mapped",[345]],[[345,345],"valid"],[[346,346],"mapped",[347]],[[347,347],"valid"],[[348,348],"mapped",[349]],[[349,349],"valid"],[[350,350],"mapped",[351]],[[351,351],"valid"],[[352,352],"mapped",[353]],[[353,353],"valid"],[[354,354],"mapped",[355]],[[355,355],"valid"],[[356,356],"mapped",[357]],[[357,357],"valid"],[[358,358],"mapped",[359]],[[359,359],"valid"],[[360,360],"mapped",[361]],[[361,361],"valid"],[[362,362],"mapped",[363]],[[363,363],"valid"],[[364,364],"mapped",[365]],[[365,365],"valid"],[[366,366],"mapped",[367]],[[367,367],"valid"],[[368,368],"mapped",[369]],[[369,369],"valid"],[[370,370],"mapped",[371]],[[371,371],"valid"],[[372,372],"mapped",[373]],[[373,373],"valid"],[[374,374],"mapped",[375]],[[375,375],"valid"],[[376,376],"mapped",[255]],[[377,377],"mapped",[378]],[[378,378],"valid"],[[379,379],"mapped",[380]],[[380,380],"valid"],[[381,381],"mapped",[382]],[[382,382],"valid"],[[383,383],"mapped",[115]],[[384,384],"valid"],[[385,385],"mapped",[595]],[[386,386],"mapped",[387]],[[387,387],"valid"],[[388,388],"mapped",[389]],[[389,389],"valid"],[[390,390],"mapped",[596]],[[391,391],"mapped",[392]],[[392,392],"valid"],[[393,393],"mapped",[598]],[[394,394],"mapped",[599]],[[395,395],"mapped",[396]],[[396,397],"valid"],[[398,398],"mapped",[477]],[[399,399],"mapped",[601]],[[400,400],"mapped",[603]],[[401,401],"mapped",[402]],[[402,402],"valid"],[[403,403],"mapped",[608]],[[404,404],"mapped",[611]],[[405,405],"valid"],[[406,406],"mapped",[617]],[[407,407],"mapped",[616]],[[408,408],"mapped",[409]],[[409,411],"valid"],[[412,412],"mapped",[623]],[[413,413],"mapped",[626]],[[414,414],"valid"],[[415,415],"mapped",[629]],[[416,416],"mapped",[417]],[[417,417],"valid"],[[418,418],"mapped",[419]],[[419,419],"valid"],[[420,420],"mapped",[421]],[[421,421],"valid"],[[422,422],"mapped",[640]],[[423,423],"mapped",[424]],[[424,424],"valid"],[[425,425],"mapped",[643]],[[426,427],"valid"],[[428,428],"mapped",[429]],[[429,429],"valid"],[[430,430],"mapped",[648]],[[431,431],"mapped",[432]],[[432,432],"valid"],[[433,433],"mapped",[650]],[[434,434],"mapped",[651]],[[435,435],"mapped",[436]],[[436,436],"valid"],[[437,437],"mapped",[438]],[[438,438],"valid"],[[439,439],"mapped",[658]],[[440,440],"mapped",[441]],[[441,443],"valid"],[[444,444],"mapped",[445]],[[445,451],"valid"],[[452,454],"mapped",[100,382]],[[455,457],"mapped",[108,106]],[[458,460],"mapped",[110,106]],[[461,461],"mapped",[462]],[[462,462],"valid"],[[463,463],"mapped",[464]],[[464,464],"valid"],[[465,465],"mapped",[466]],[[466,466],"valid"],[[467,467],"mapped",[468]],[[468,468],"valid"],[[469,469],"mapped",[470]],[[470,470],"valid"],[[471,471],"mapped",[472]],[[472,472],"valid"],[[473,473],"mapped",[474]],[[474,474],"valid"],[[475,475],"mapped",[476]],[[476,477],"valid"],[[478,478],"mapped",[479]],[[479,479],"valid"],[[480,480],"mapped",[481]],[[481,481],"valid"],[[482,482],"mapped",[483]],[[483,483],"valid"],[[484,484],"mapped",[485]],[[485,485],"valid"],[[486,486],"mapped",[487]],[[487,487],"valid"],[[488,488],"mapped",[489]],[[489,489],"valid"],[[490,490],"mapped",[491]],[[491,491],"valid"],[[492,492],"mapped",[493]],[[493,493],"valid"],[[494,494],"mapped",[495]],[[495,496],"valid"],[[497,499],"mapped",[100,122]],[[500,500],"mapped",[501]],[[501,501],"valid"],[[502,502],"mapped",[405]],[[503,503],"mapped",[447]],[[504,504],"mapped",[505]],[[505,505],"valid"],[[506,506],"mapped",[507]],[[507,507],"valid"],[[508,508],"mapped",[509]],[[509,509],"valid"],[[510,510],"mapped",[511]],[[511,511],"valid"],[[512,512],"mapped",[513]],[[513,513],"valid"],[[514,514],"mapped",[515]],[[515,515],"valid"],[[516,516],"mapped",[517]],[[517,517],"valid"],[[518,518],"mapped",[519]],[[519,519],"valid"],[[520,520],"mapped",[521]],[[521,521],"valid"],[[522,522],"mapped",[523]],[[523,523],"valid"],[[524,524],"mapped",[525]],[[525,525],"valid"],[[526,526],"mapped",[527]],[[527,527],"valid"],[[528,528],"mapped",[529]],[[529,529],"valid"],[[530,530],"mapped",[531]],[[531,531],"valid"],[[532,532],"mapped",[533]],[[533,533],"valid"],[[534,534],"mapped",[535]],[[535,535],"valid"],[[536,536],"mapped",[537]],[[537,537],"valid"],[[538,538],"mapped",[539]],[[539,539],"valid"],[[540,540],"mapped",[541]],[[541,541],"valid"],[[542,542],"mapped",[543]],[[543,543],"valid"],[[544,544],"mapped",[414]],[[545,545],"valid"],[[546,546],"mapped",[547]],[[547,547],"valid"],[[548,548],"mapped",[549]],[[549,549],"valid"],[[550,550],"mapped",[551]],[[551,551],"valid"],[[552,552],"mapped",[553]],[[553,553],"valid"],[[554,554],"mapped",[555]],[[555,555],"valid"],[[556,556],"mapped",[557]],[[557,557],"valid"],[[558,558],"mapped",[559]],[[559,559],"valid"],[[560,560],"mapped",[561]],[[561,561],"valid"],[[562,562],"mapped",[563]],[[563,563],"valid"],[[564,566],"valid"],[[567,569],"valid"],[[570,570],"mapped",[11365]],[[571,571],"mapped",[572]],[[572,572],"valid"],[[573,573],"mapped",[410]],[[574,574],"mapped",[11366]],[[575,576],"valid"],[[577,577],"mapped",[578]],[[578,578],"valid"],[[579,579],"mapped",[384]],[[580,580],"mapped",[649]],[[581,581],"mapped",[652]],[[582,582],"mapped",[583]],[[583,583],"valid"],[[584,584],"mapped",[585]],[[585,585],"valid"],[[586,586],"mapped",[587]],[[587,587],"valid"],[[588,588],"mapped",[589]],[[589,589],"valid"],[[590,590],"mapped",[591]],[[591,591],"valid"],[[592,680],"valid"],[[681,685],"valid"],[[686,687],"valid"],[[688,688],"mapped",[104]],[[689,689],"mapped",[614]],[[690,690],"mapped",[106]],[[691,691],"mapped",[114]],[[692,692],"mapped",[633]],[[693,693],"mapped",[635]],[[694,694],"mapped",[641]],[[695,695],"mapped",[119]],[[696,696],"mapped",[121]],[[697,705],"valid"],[[706,709],"valid",[],"NV8"],[[710,721],"valid"],[[722,727],"valid",[],"NV8"],[[728,728],"disallowed_STD3_mapped",[32,774]],[[729,729],"disallowed_STD3_mapped",[32,775]],[[730,730],"disallowed_STD3_mapped",[32,778]],[[731,731],"disallowed_STD3_mapped",[32,808]],[[732,732],"disallowed_STD3_mapped",[32,771]],[[733,733],"disallowed_STD3_mapped",[32,779]],[[734,734],"valid",[],"NV8"],[[735,735],"valid",[],"NV8"],[[736,736],"mapped",[611]],[[737,737],"mapped",[108]],[[738,738],"mapped",[115]],[[739,739],"mapped",[120]],[[740,740],"mapped",[661]],[[741,745],"valid",[],"NV8"],[[746,747],"valid",[],"NV8"],[[748,748],"valid"],[[749,749],"valid",[],"NV8"],[[750,750],"valid"],[[751,767],"valid",[],"NV8"],[[768,831],"valid"],[[832,832],"mapped",[768]],[[833,833],"mapped",[769]],[[834,834],"valid"],[[835,835],"mapped",[787]],[[836,836],"mapped",[776,769]],[[837,837],"mapped",[953]],[[838,846],"valid"],[[847,847],"ignored"],[[848,855],"valid"],[[856,860],"valid"],[[861,863],"valid"],[[864,865],"valid"],[[866,866],"valid"],[[867,879],"valid"],[[880,880],"mapped",[881]],[[881,881],"valid"],[[882,882],"mapped",[883]],[[883,883],"valid"],[[884,884],"mapped",[697]],[[885,885],"valid"],[[886,886],"mapped",[887]],[[887,887],"valid"],[[888,889],"disallowed"],[[890,890],"disallowed_STD3_mapped",[32,953]],[[891,893],"valid"],[[894,894],"disallowed_STD3_mapped",[59]],[[895,895],"mapped",[1011]],[[896,899],"disallowed"],[[900,900],"disallowed_STD3_mapped",[32,769]],[[901,901],"disallowed_STD3_mapped",[32,776,769]],[[902,902],"mapped",[940]],[[903,903],"mapped",[183]],[[904,904],"mapped",[941]],[[905,905],"mapped",[942]],[[906,906],"mapped",[943]],[[907,907],"disallowed"],[[908,908],"mapped",[972]],[[909,909],"disallowed"],[[910,910],"mapped",[973]],[[911,911],"mapped",[974]],[[912,912],"valid"],[[913,913],"mapped",[945]],[[914,914],"mapped",[946]],[[915,915],"mapped",[947]],[[916,916],"mapped",[948]],[[917,917],"mapped",[949]],[[918,918],"mapped",[950]],[[919,919],"mapped",[951]],[[920,920],"mapped",[952]],[[921,921],"mapped",[953]],[[922,922],"mapped",[954]],[[923,923],"mapped",[955]],[[924,924],"mapped",[956]],[[925,925],"mapped",[957]],[[926,926],"mapped",[958]],[[927,927],"mapped",[959]],[[928,928],"mapped",[960]],[[929,929],"mapped",[961]],[[930,930],"disallowed"],[[931,931],"mapped",[963]],[[932,932],"mapped",[964]],[[933,933],"mapped",[965]],[[934,934],"mapped",[966]],[[935,935],"mapped",[967]],[[936,936],"mapped",[968]],[[937,937],"mapped",[969]],[[938,938],"mapped",[970]],[[939,939],"mapped",[971]],[[940,961],"valid"],[[962,962],"deviation",[963]],[[963,974],"valid"],[[975,975],"mapped",[983]],[[976,976],"mapped",[946]],[[977,977],"mapped",[952]],[[978,978],"mapped",[965]],[[979,979],"mapped",[973]],[[980,980],"mapped",[971]],[[981,981],"mapped",[966]],[[982,982],"mapped",[960]],[[983,983],"valid"],[[984,984],"mapped",[985]],[[985,985],"valid"],[[986,986],"mapped",[987]],[[987,987],"valid"],[[988,988],"mapped",[989]],[[989,989],"valid"],[[990,990],"mapped",[991]],[[991,991],"valid"],[[992,992],"mapped",[993]],[[993,993],"valid"],[[994,994],"mapped",[995]],[[995,995],"valid"],[[996,996],"mapped",[997]],[[997,997],"valid"],[[998,998],"mapped",[999]],[[999,999],"valid"],[[1000,1000],"mapped",[1001]],[[1001,1001],"valid"],[[1002,1002],"mapped",[1003]],[[1003,1003],"valid"],[[1004,1004],"mapped",[1005]],[[1005,1005],"valid"],[[1006,1006],"mapped",[1007]],[[1007,1007],"valid"],[[1008,1008],"mapped",[954]],[[1009,1009],"mapped",[961]],[[1010,1010],"mapped",[963]],[[1011,1011],"valid"],[[1012,1012],"mapped",[952]],[[1013,1013],"mapped",[949]],[[1014,1014],"valid",[],"NV8"],[[1015,1015],"mapped",[1016]],[[1016,1016],"valid"],[[1017,1017],"mapped",[963]],[[1018,1018],"mapped",[1019]],[[1019,1019],"valid"],[[1020,1020],"valid"],[[1021,1021],"mapped",[891]],[[1022,1022],"mapped",[892]],[[1023,1023],"mapped",[893]],[[1024,1024],"mapped",[1104]],[[1025,1025],"mapped",[1105]],[[1026,1026],"mapped",[1106]],[[1027,1027],"mapped",[1107]],[[1028,1028],"mapped",[1108]],[[1029,1029],"mapped",[1109]],[[1030,1030],"mapped",[1110]],[[1031,1031],"mapped",[1111]],[[1032,1032],"mapped",[1112]],[[1033,1033],"mapped",[1113]],[[1034,1034],"mapped",[1114]],[[1035,1035],"mapped",[1115]],[[1036,1036],"mapped",[1116]],[[1037,1037],"mapped",[1117]],[[1038,1038],"mapped",[1118]],[[1039,1039],"mapped",[1119]],[[1040,1040],"mapped",[1072]],[[1041,1041],"mapped",[1073]],[[1042,1042],"mapped",[1074]],[[1043,1043],"mapped",[1075]],[[1044,1044],"mapped",[1076]],[[1045,1045],"mapped",[1077]],[[1046,1046],"mapped",[1078]],[[1047,1047],"mapped",[1079]],[[1048,1048],"mapped",[1080]],[[1049,1049],"mapped",[1081]],[[1050,1050],"mapped",[1082]],[[1051,1051],"mapped",[1083]],[[1052,1052],"mapped",[1084]],[[1053,1053],"mapped",[1085]],[[1054,1054],"mapped",[1086]],[[1055,1055],"mapped",[1087]],[[1056,1056],"mapped",[1088]],[[1057,1057],"mapped",[1089]],[[1058,1058],"mapped",[1090]],[[1059,1059],"mapped",[1091]],[[1060,1060],"mapped",[1092]],[[1061,1061],"mapped",[1093]],[[1062,1062],"mapped",[1094]],[[1063,1063],"mapped",[1095]],[[1064,1064],"mapped",[1096]],[[1065,1065],"mapped",[1097]],[[1066,1066],"mapped",[1098]],[[1067,1067],"mapped",[1099]],[[1068,1068],"mapped",[1100]],[[1069,1069],"mapped",[1101]],[[1070,1070],"mapped",[1102]],[[1071,1071],"mapped",[1103]],[[1072,1103],"valid"],[[1104,1104],"valid"],[[1105,1116],"valid"],[[1117,1117],"valid"],[[1118,1119],"valid"],[[1120,1120],"mapped",[1121]],[[1121,1121],"valid"],[[1122,1122],"mapped",[1123]],[[1123,1123],"valid"],[[1124,1124],"mapped",[1125]],[[1125,1125],"valid"],[[1126,1126],"mapped",[1127]],[[1127,1127],"valid"],[[1128,1128],"mapped",[1129]],[[1129,1129],"valid"],[[1130,1130],"mapped",[1131]],[[1131,1131],"valid"],[[1132,1132],"mapped",[1133]],[[1133,1133],"valid"],[[1134,1134],"mapped",[1135]],[[1135,1135],"valid"],[[1136,1136],"mapped",[1137]],[[1137,1137],"valid"],[[1138,1138],"mapped",[1139]],[[1139,1139],"valid"],[[1140,1140],"mapped",[1141]],[[1141,1141],"valid"],[[1142,1142],"mapped",[1143]],[[1143,1143],"valid"],[[1144,1144],"mapped",[1145]],[[1145,1145],"valid"],[[1146,1146],"mapped",[1147]],[[1147,1147],"valid"],[[1148,1148],"mapped",[1149]],[[1149,1149],"valid"],[[1150,1150],"mapped",[1151]],[[1151,1151],"valid"],[[1152,1152],"mapped",[1153]],[[1153,1153],"valid"],[[1154,1154],"valid",[],"NV8"],[[1155,1158],"valid"],[[1159,1159],"valid"],[[1160,1161],"valid",[],"NV8"],[[1162,1162],"mapped",[1163]],[[1163,1163],"valid"],[[1164,1164],"mapped",[1165]],[[1165,1165],"valid"],[[1166,1166],"mapped",[1167]],[[1167,1167],"valid"],[[1168,1168],"mapped",[1169]],[[1169,1169],"valid"],[[1170,1170],"mapped",[1171]],[[1171,1171],"valid"],[[1172,1172],"mapped",[1173]],[[1173,1173],"valid"],[[1174,1174],"mapped",[1175]],[[1175,1175],"valid"],[[1176,1176],"mapped",[1177]],[[1177,1177],"valid"],[[1178,1178],"mapped",[1179]],[[1179,1179],"valid"],[[1180,1180],"mapped",[1181]],[[1181,1181],"valid"],[[1182,1182],"mapped",[1183]],[[1183,1183],"valid"],[[1184,1184],"mapped",[1185]],[[1185,1185],"valid"],[[1186,1186],"mapped",[1187]],[[1187,1187],"valid"],[[1188,1188],"mapped",[1189]],[[1189,1189],"valid"],[[1190,1190],"mapped",[1191]],[[1191,1191],"valid"],[[1192,1192],"mapped",[1193]],[[1193,1193],"valid"],[[1194,1194],"mapped",[1195]],[[1195,1195],"valid"],[[1196,1196],"mapped",[1197]],[[1197,1197],"valid"],[[1198,1198],"mapped",[1199]],[[1199,1199],"valid"],[[1200,1200],"mapped",[1201]],[[1201,1201],"valid"],[[1202,1202],"mapped",[1203]],[[1203,1203],"valid"],[[1204,1204],"mapped",[1205]],[[1205,1205],"valid"],[[1206,1206],"mapped",[1207]],[[1207,1207],"valid"],[[1208,1208],"mapped",[1209]],[[1209,1209],"valid"],[[1210,1210],"mapped",[1211]],[[1211,1211],"valid"],[[1212,1212],"mapped",[1213]],[[1213,1213],"valid"],[[1214,1214],"mapped",[1215]],[[1215,1215],"valid"],[[1216,1216],"disallowed"],[[1217,1217],"mapped",[1218]],[[1218,1218],"valid"],[[1219,1219],"mapped",[1220]],[[1220,1220],"valid"],[[1221,1221],"mapped",[1222]],[[1222,1222],"valid"],[[1223,1223],"mapped",[1224]],[[1224,1224],"valid"],[[1225,1225],"mapped",[1226]],[[1226,1226],"valid"],[[1227,1227],"mapped",[1228]],[[1228,1228],"valid"],[[1229,1229],"mapped",[1230]],[[1230,1230],"valid"],[[1231,1231],"valid"],[[1232,1232],"mapped",[1233]],[[1233,1233],"valid"],[[1234,1234],"mapped",[1235]],[[1235,1235],"valid"],[[1236,1236],"mapped",[1237]],[[1237,1237],"valid"],[[1238,1238],"mapped",[1239]],[[1239,1239],"valid"],[[1240,1240],"mapped",[1241]],[[1241,1241],"valid"],[[1242,1242],"mapped",[1243]],[[1243,1243],"valid"],[[1244,1244],"mapped",[1245]],[[1245,1245],"valid"],[[1246,1246],"mapped",[1247]],[[1247,1247],"valid"],[[1248,1248],"mapped",[1249]],[[1249,1249],"valid"],[[1250,1250],"mapped",[1251]],[[1251,1251],"valid"],[[1252,1252],"mapped",[1253]],[[1253,1253],"valid"],[[1254,1254],"mapped",[1255]],[[1255,1255],"valid"],[[1256,1256],"mapped",[1257]],[[1257,1257],"valid"],[[1258,1258],"mapped",[1259]],[[1259,1259],"valid"],[[1260,1260],"mapped",[1261]],[[1261,1261],"valid"],[[1262,1262],"mapped",[1263]],[[1263,1263],"valid"],[[1264,1264],"mapped",[1265]],[[1265,1265],"valid"],[[1266,1266],"mapped",[1267]],[[1267,1267],"valid"],[[1268,1268],"mapped",[1269]],[[1269,1269],"valid"],[[1270,1270],"mapped",[1271]],[[1271,1271],"valid"],[[1272,1272],"mapped",[1273]],[[1273,1273],"valid"],[[1274,1274],"mapped",[1275]],[[1275,1275],"valid"],[[1276,1276],"mapped",[1277]],[[1277,1277],"valid"],[[1278,1278],"mapped",[1279]],[[1279,1279],"valid"],[[1280,1280],"mapped",[1281]],[[1281,1281],"valid"],[[1282,1282],"mapped",[1283]],[[1283,1283],"valid"],[[1284,1284],"mapped",[1285]],[[1285,1285],"valid"],[[1286,1286],"mapped",[1287]],[[1287,1287],"valid"],[[1288,1288],"mapped",[1289]],[[1289,1289],"valid"],[[1290,1290],"mapped",[1291]],[[1291,1291],"valid"],[[1292,1292],"mapped",[1293]],[[1293,1293],"valid"],[[1294,1294],"mapped",[1295]],[[1295,1295],"valid"],[[1296,1296],"mapped",[1297]],[[1297,1297],"valid"],[[1298,1298],"mapped",[1299]],[[1299,1299],"valid"],[[1300,1300],"mapped",[1301]],[[1301,1301],"valid"],[[1302,1302],"mapped",[1303]],[[1303,1303],"valid"],[[1304,1304],"mapped",[1305]],[[1305,1305],"valid"],[[1306,1306],"mapped",[1307]],[[1307,1307],"valid"],[[1308,1308],"mapped",[1309]],[[1309,1309],"valid"],[[1310,1310],"mapped",[1311]],[[1311,1311],"valid"],[[1312,1312],"mapped",[1313]],[[1313,1313],"valid"],[[1314,1314],"mapped",[1315]],[[1315,1315],"valid"],[[1316,1316],"mapped",[1317]],[[1317,1317],"valid"],[[1318,1318],"mapped",[1319]],[[1319,1319],"valid"],[[1320,1320],"mapped",[1321]],[[1321,1321],"valid"],[[1322,1322],"mapped",[1323]],[[1323,1323],"valid"],[[1324,1324],"mapped",[1325]],[[1325,1325],"valid"],[[1326,1326],"mapped",[1327]],[[1327,1327],"valid"],[[1328,1328],"disallowed"],[[1329,1329],"mapped",[1377]],[[1330,1330],"mapped",[1378]],[[1331,1331],"mapped",[1379]],[[1332,1332],"mapped",[1380]],[[1333,1333],"mapped",[1381]],[[1334,1334],"mapped",[1382]],[[1335,1335],"mapped",[1383]],[[1336,1336],"mapped",[1384]],[[1337,1337],"mapped",[1385]],[[1338,1338],"mapped",[1386]],[[1339,1339],"mapped",[1387]],[[1340,1340],"mapped",[1388]],[[1341,1341],"mapped",[1389]],[[1342,1342],"mapped",[1390]],[[1343,1343],"mapped",[1391]],[[1344,1344],"mapped",[1392]],[[1345,1345],"mapped",[1393]],[[1346,1346],"mapped",[1394]],[[1347,1347],"mapped",[1395]],[[1348,1348],"mapped",[1396]],[[1349,1349],"mapped",[1397]],[[1350,1350],"mapped",[1398]],[[1351,1351],"mapped",[1399]],[[1352,1352],"mapped",[1400]],[[1353,1353],"mapped",[1401]],[[1354,1354],"mapped",[1402]],[[1355,1355],"mapped",[1403]],[[1356,1356],"mapped",[1404]],[[1357,1357],"mapped",[1405]],[[1358,1358],"mapped",[1406]],[[1359,1359],"mapped",[1407]],[[1360,1360],"mapped",[1408]],[[1361,1361],"mapped",[1409]],[[1362,1362],"mapped",[1410]],[[1363,1363],"mapped",[1411]],[[1364,1364],"mapped",[1412]],[[1365,1365],"mapped",[1413]],[[1366,1366],"mapped",[1414]],[[1367,1368],"disallowed"],[[1369,1369],"valid"],[[1370,1375],"valid",[],"NV8"],[[1376,1376],"disallowed"],[[1377,1414],"valid"],[[1415,1415],"mapped",[1381,1410]],[[1416,1416],"disallowed"],[[1417,1417],"valid",[],"NV8"],[[1418,1418],"valid",[],"NV8"],[[1419,1420],"disallowed"],[[1421,1422],"valid",[],"NV8"],[[1423,1423],"valid",[],"NV8"],[[1424,1424],"disallowed"],[[1425,1441],"valid"],[[1442,1442],"valid"],[[1443,1455],"valid"],[[1456,1465],"valid"],[[1466,1466],"valid"],[[1467,1469],"valid"],[[1470,1470],"valid",[],"NV8"],[[1471,1471],"valid"],[[1472,1472],"valid",[],"NV8"],[[1473,1474],"valid"],[[1475,1475],"valid",[],"NV8"],[[1476,1476],"valid"],[[1477,1477],"valid"],[[1478,1478],"valid",[],"NV8"],[[1479,1479],"valid"],[[1480,1487],"disallowed"],[[1488,1514],"valid"],[[1515,1519],"disallowed"],[[1520,1524],"valid"],[[1525,1535],"disallowed"],[[1536,1539],"disallowed"],[[1540,1540],"disallowed"],[[1541,1541],"disallowed"],[[1542,1546],"valid",[],"NV8"],[[1547,1547],"valid",[],"NV8"],[[1548,1548],"valid",[],"NV8"],[[1549,1551],"valid",[],"NV8"],[[1552,1557],"valid"],[[1558,1562],"valid"],[[1563,1563],"valid",[],"NV8"],[[1564,1564],"disallowed"],[[1565,1565],"disallowed"],[[1566,1566],"valid",[],"NV8"],[[1567,1567],"valid",[],"NV8"],[[1568,1568],"valid"],[[1569,1594],"valid"],[[1595,1599],"valid"],[[1600,1600],"valid",[],"NV8"],[[1601,1618],"valid"],[[1619,1621],"valid"],[[1622,1624],"valid"],[[1625,1630],"valid"],[[1631,1631],"valid"],[[1632,1641],"valid"],[[1642,1645],"valid",[],"NV8"],[[1646,1647],"valid"],[[1648,1652],"valid"],[[1653,1653],"mapped",[1575,1652]],[[1654,1654],"mapped",[1608,1652]],[[1655,1655],"mapped",[1735,1652]],[[1656,1656],"mapped",[1610,1652]],[[1657,1719],"valid"],[[1720,1721],"valid"],[[1722,1726],"valid"],[[1727,1727],"valid"],[[1728,1742],"valid"],[[1743,1743],"valid"],[[1744,1747],"valid"],[[1748,1748],"valid",[],"NV8"],[[1749,1756],"valid"],[[1757,1757],"disallowed"],[[1758,1758],"valid",[],"NV8"],[[1759,1768],"valid"],[[1769,1769],"valid",[],"NV8"],[[1770,1773],"valid"],[[1774,1775],"valid"],[[1776,1785],"valid"],[[1786,1790],"valid"],[[1791,1791],"valid"],[[1792,1805],"valid",[],"NV8"],[[1806,1806],"disallowed"],[[1807,1807],"disallowed"],[[1808,1836],"valid"],[[1837,1839],"valid"],[[1840,1866],"valid"],[[1867,1868],"disallowed"],[[1869,1871],"valid"],[[1872,1901],"valid"],[[1902,1919],"valid"],[[1920,1968],"valid"],[[1969,1969],"valid"],[[1970,1983],"disallowed"],[[1984,2037],"valid"],[[2038,2042],"valid",[],"NV8"],[[2043,2047],"disallowed"],[[2048,2093],"valid"],[[2094,2095],"disallowed"],[[2096,2110],"valid",[],"NV8"],[[2111,2111],"disallowed"],[[2112,2139],"valid"],[[2140,2141],"disallowed"],[[2142,2142],"valid",[],"NV8"],[[2143,2207],"disallowed"],[[2208,2208],"valid"],[[2209,2209],"valid"],[[2210,2220],"valid"],[[2221,2226],"valid"],[[2227,2228],"valid"],[[2229,2274],"disallowed"],[[2275,2275],"valid"],[[2276,2302],"valid"],[[2303,2303],"valid"],[[2304,2304],"valid"],[[2305,2307],"valid"],[[2308,2308],"valid"],[[2309,2361],"valid"],[[2362,2363],"valid"],[[2364,2381],"valid"],[[2382,2382],"valid"],[[2383,2383],"valid"],[[2384,2388],"valid"],[[2389,2389],"valid"],[[2390,2391],"valid"],[[2392,2392],"mapped",[2325,2364]],[[2393,2393],"mapped",[2326,2364]],[[2394,2394],"mapped",[2327,2364]],[[2395,2395],"mapped",[2332,2364]],[[2396,2396],"mapped",[2337,2364]],[[2397,2397],"mapped",[2338,2364]],[[2398,2398],"mapped",[2347,2364]],[[2399,2399],"mapped",[2351,2364]],[[2400,2403],"valid"],[[2404,2405],"valid",[],"NV8"],[[2406,2415],"valid"],[[2416,2416],"valid",[],"NV8"],[[2417,2418],"valid"],[[2419,2423],"valid"],[[2424,2424],"valid"],[[2425,2426],"valid"],[[2427,2428],"valid"],[[2429,2429],"valid"],[[2430,2431],"valid"],[[2432,2432],"valid"],[[2433,2435],"valid"],[[2436,2436],"disallowed"],[[2437,2444],"valid"],[[2445,2446],"disallowed"],[[2447,2448],"valid"],[[2449,2450],"disallowed"],[[2451,2472],"valid"],[[2473,2473],"disallowed"],[[2474,2480],"valid"],[[2481,2481],"disallowed"],[[2482,2482],"valid"],[[2483,2485],"disallowed"],[[2486,2489],"valid"],[[2490,2491],"disallowed"],[[2492,2492],"valid"],[[2493,2493],"valid"],[[2494,2500],"valid"],[[2501,2502],"disallowed"],[[2503,2504],"valid"],[[2505,2506],"disallowed"],[[2507,2509],"valid"],[[2510,2510],"valid"],[[2511,2518],"disallowed"],[[2519,2519],"valid"],[[2520,2523],"disallowed"],[[2524,2524],"mapped",[2465,2492]],[[2525,2525],"mapped",[2466,2492]],[[2526,2526],"disallowed"],[[2527,2527],"mapped",[2479,2492]],[[2528,2531],"valid"],[[2532,2533],"disallowed"],[[2534,2545],"valid"],[[2546,2554],"valid",[],"NV8"],[[2555,2555],"valid",[],"NV8"],[[2556,2560],"disallowed"],[[2561,2561],"valid"],[[2562,2562],"valid"],[[2563,2563],"valid"],[[2564,2564],"disallowed"],[[2565,2570],"valid"],[[2571,2574],"disallowed"],[[2575,2576],"valid"],[[2577,2578],"disallowed"],[[2579,2600],"valid"],[[2601,2601],"disallowed"],[[2602,2608],"valid"],[[2609,2609],"disallowed"],[[2610,2610],"valid"],[[2611,2611],"mapped",[2610,2620]],[[2612,2612],"disallowed"],[[2613,2613],"valid"],[[2614,2614],"mapped",[2616,2620]],[[2615,2615],"disallowed"],[[2616,2617],"valid"],[[2618,2619],"disallowed"],[[2620,2620],"valid"],[[2621,2621],"disallowed"],[[2622,2626],"valid"],[[2627,2630],"disallowed"],[[2631,2632],"valid"],[[2633,2634],"disallowed"],[[2635,2637],"valid"],[[2638,2640],"disallowed"],[[2641,2641],"valid"],[[2642,2648],"disallowed"],[[2649,2649],"mapped",[2582,2620]],[[2650,2650],"mapped",[2583,2620]],[[2651,2651],"mapped",[2588,2620]],[[2652,2652],"valid"],[[2653,2653],"disallowed"],[[2654,2654],"mapped",[2603,2620]],[[2655,2661],"disallowed"],[[2662,2676],"valid"],[[2677,2677],"valid"],[[2678,2688],"disallowed"],[[2689,2691],"valid"],[[2692,2692],"disallowed"],[[2693,2699],"valid"],[[2700,2700],"valid"],[[2701,2701],"valid"],[[2702,2702],"disallowed"],[[2703,2705],"valid"],[[2706,2706],"disallowed"],[[2707,2728],"valid"],[[2729,2729],"disallowed"],[[2730,2736],"valid"],[[2737,2737],"disallowed"],[[2738,2739],"valid"],[[2740,2740],"disallowed"],[[2741,2745],"valid"],[[2746,2747],"disallowed"],[[2748,2757],"valid"],[[2758,2758],"disallowed"],[[2759,2761],"valid"],[[2762,2762],"disallowed"],[[2763,2765],"valid"],[[2766,2767],"disallowed"],[[2768,2768],"valid"],[[2769,2783],"disallowed"],[[2784,2784],"valid"],[[2785,2787],"valid"],[[2788,2789],"disallowed"],[[2790,2799],"valid"],[[2800,2800],"valid",[],"NV8"],[[2801,2801],"valid",[],"NV8"],[[2802,2808],"disallowed"],[[2809,2809],"valid"],[[2810,2816],"disallowed"],[[2817,2819],"valid"],[[2820,2820],"disallowed"],[[2821,2828],"valid"],[[2829,2830],"disallowed"],[[2831,2832],"valid"],[[2833,2834],"disallowed"],[[2835,2856],"valid"],[[2857,2857],"disallowed"],[[2858,2864],"valid"],[[2865,2865],"disallowed"],[[2866,2867],"valid"],[[2868,2868],"disallowed"],[[2869,2869],"valid"],[[2870,2873],"valid"],[[2874,2875],"disallowed"],[[2876,2883],"valid"],[[2884,2884],"valid"],[[2885,2886],"disallowed"],[[2887,2888],"valid"],[[2889,2890],"disallowed"],[[2891,2893],"valid"],[[2894,2901],"disallowed"],[[2902,2903],"valid"],[[2904,2907],"disallowed"],[[2908,2908],"mapped",[2849,2876]],[[2909,2909],"mapped",[2850,2876]],[[2910,2910],"disallowed"],[[2911,2913],"valid"],[[2914,2915],"valid"],[[2916,2917],"disallowed"],[[2918,2927],"valid"],[[2928,2928],"valid",[],"NV8"],[[2929,2929],"valid"],[[2930,2935],"valid",[],"NV8"],[[2936,2945],"disallowed"],[[2946,2947],"valid"],[[2948,2948],"disallowed"],[[2949,2954],"valid"],[[2955,2957],"disallowed"],[[2958,2960],"valid"],[[2961,2961],"disallowed"],[[2962,2965],"valid"],[[2966,2968],"disallowed"],[[2969,2970],"valid"],[[2971,2971],"disallowed"],[[2972,2972],"valid"],[[2973,2973],"disallowed"],[[2974,2975],"valid"],[[2976,2978],"disallowed"],[[2979,2980],"valid"],[[2981,2983],"disallowed"],[[2984,2986],"valid"],[[2987,2989],"disallowed"],[[2990,2997],"valid"],[[2998,2998],"valid"],[[2999,3001],"valid"],[[3002,3005],"disallowed"],[[3006,3010],"valid"],[[3011,3013],"disallowed"],[[3014,3016],"valid"],[[3017,3017],"disallowed"],[[3018,3021],"valid"],[[3022,3023],"disallowed"],[[3024,3024],"valid"],[[3025,3030],"disallowed"],[[3031,3031],"valid"],[[3032,3045],"disallowed"],[[3046,3046],"valid"],[[3047,3055],"valid"],[[3056,3058],"valid",[],"NV8"],[[3059,3066],"valid",[],"NV8"],[[3067,3071],"disallowed"],[[3072,3072],"valid"],[[3073,3075],"valid"],[[3076,3076],"disallowed"],[[3077,3084],"valid"],[[3085,3085],"disallowed"],[[3086,3088],"valid"],[[3089,3089],"disallowed"],[[3090,3112],"valid"],[[3113,3113],"disallowed"],[[3114,3123],"valid"],[[3124,3124],"valid"],[[3125,3129],"valid"],[[3130,3132],"disallowed"],[[3133,3133],"valid"],[[3134,3140],"valid"],[[3141,3141],"disallowed"],[[3142,3144],"valid"],[[3145,3145],"disallowed"],[[3146,3149],"valid"],[[3150,3156],"disallowed"],[[3157,3158],"valid"],[[3159,3159],"disallowed"],[[3160,3161],"valid"],[[3162,3162],"valid"],[[3163,3167],"disallowed"],[[3168,3169],"valid"],[[3170,3171],"valid"],[[3172,3173],"disallowed"],[[3174,3183],"valid"],[[3184,3191],"disallowed"],[[3192,3199],"valid",[],"NV8"],[[3200,3200],"disallowed"],[[3201,3201],"valid"],[[3202,3203],"valid"],[[3204,3204],"disallowed"],[[3205,3212],"valid"],[[3213,3213],"disallowed"],[[3214,3216],"valid"],[[3217,3217],"disallowed"],[[3218,3240],"valid"],[[3241,3241],"disallowed"],[[3242,3251],"valid"],[[3252,3252],"disallowed"],[[3253,3257],"valid"],[[3258,3259],"disallowed"],[[3260,3261],"valid"],[[3262,3268],"valid"],[[3269,3269],"disallowed"],[[3270,3272],"valid"],[[3273,3273],"disallowed"],[[3274,3277],"valid"],[[3278,3284],"disallowed"],[[3285,3286],"valid"],[[3287,3293],"disallowed"],[[3294,3294],"valid"],[[3295,3295],"disallowed"],[[3296,3297],"valid"],[[3298,3299],"valid"],[[3300,3301],"disallowed"],[[3302,3311],"valid"],[[3312,3312],"disallowed"],[[3313,3314],"valid"],[[3315,3328],"disallowed"],[[3329,3329],"valid"],[[3330,3331],"valid"],[[3332,3332],"disallowed"],[[3333,3340],"valid"],[[3341,3341],"disallowed"],[[3342,3344],"valid"],[[3345,3345],"disallowed"],[[3346,3368],"valid"],[[3369,3369],"valid"],[[3370,3385],"valid"],[[3386,3386],"valid"],[[3387,3388],"disallowed"],[[3389,3389],"valid"],[[3390,3395],"valid"],[[3396,3396],"valid"],[[3397,3397],"disallowed"],[[3398,3400],"valid"],[[3401,3401],"disallowed"],[[3402,3405],"valid"],[[3406,3406],"valid"],[[3407,3414],"disallowed"],[[3415,3415],"valid"],[[3416,3422],"disallowed"],[[3423,3423],"valid"],[[3424,3425],"valid"],[[3426,3427],"valid"],[[3428,3429],"disallowed"],[[3430,3439],"valid"],[[3440,3445],"valid",[],"NV8"],[[3446,3448],"disallowed"],[[3449,3449],"valid",[],"NV8"],[[3450,3455],"valid"],[[3456,3457],"disallowed"],[[3458,3459],"valid"],[[3460,3460],"disallowed"],[[3461,3478],"valid"],[[3479,3481],"disallowed"],[[3482,3505],"valid"],[[3506,3506],"disallowed"],[[3507,3515],"valid"],[[3516,3516],"disallowed"],[[3517,3517],"valid"],[[3518,3519],"disallowed"],[[3520,3526],"valid"],[[3527,3529],"disallowed"],[[3530,3530],"valid"],[[3531,3534],"disallowed"],[[3535,3540],"valid"],[[3541,3541],"disallowed"],[[3542,3542],"valid"],[[3543,3543],"disallowed"],[[3544,3551],"valid"],[[3552,3557],"disallowed"],[[3558,3567],"valid"],[[3568,3569],"disallowed"],[[3570,3571],"valid"],[[3572,3572],"valid",[],"NV8"],[[3573,3584],"disallowed"],[[3585,3634],"valid"],[[3635,3635],"mapped",[3661,3634]],[[3636,3642],"valid"],[[3643,3646],"disallowed"],[[3647,3647],"valid",[],"NV8"],[[3648,3662],"valid"],[[3663,3663],"valid",[],"NV8"],[[3664,3673],"valid"],[[3674,3675],"valid",[],"NV8"],[[3676,3712],"disallowed"],[[3713,3714],"valid"],[[3715,3715],"disallowed"],[[3716,3716],"valid"],[[3717,3718],"disallowed"],[[3719,3720],"valid"],[[3721,3721],"disallowed"],[[3722,3722],"valid"],[[3723,3724],"disallowed"],[[3725,3725],"valid"],[[3726,3731],"disallowed"],[[3732,3735],"valid"],[[3736,3736],"disallowed"],[[3737,3743],"valid"],[[3744,3744],"disallowed"],[[3745,3747],"valid"],[[3748,3748],"disallowed"],[[3749,3749],"valid"],[[3750,3750],"disallowed"],[[3751,3751],"valid"],[[3752,3753],"disallowed"],[[3754,3755],"valid"],[[3756,3756],"disallowed"],[[3757,3762],"valid"],[[3763,3763],"mapped",[3789,3762]],[[3764,3769],"valid"],[[3770,3770],"disallowed"],[[3771,3773],"valid"],[[3774,3775],"disallowed"],[[3776,3780],"valid"],[[3781,3781],"disallowed"],[[3782,3782],"valid"],[[3783,3783],"disallowed"],[[3784,3789],"valid"],[[3790,3791],"disallowed"],[[3792,3801],"valid"],[[3802,3803],"disallowed"],[[3804,3804],"mapped",[3755,3737]],[[3805,3805],"mapped",[3755,3745]],[[3806,3807],"valid"],[[3808,3839],"disallowed"],[[3840,3840],"valid"],[[3841,3850],"valid",[],"NV8"],[[3851,3851],"valid"],[[3852,3852],"mapped",[3851]],[[3853,3863],"valid",[],"NV8"],[[3864,3865],"valid"],[[3866,3871],"valid",[],"NV8"],[[3872,3881],"valid"],[[3882,3892],"valid",[],"NV8"],[[3893,3893],"valid"],[[3894,3894],"valid",[],"NV8"],[[3895,3895],"valid"],[[3896,3896],"valid",[],"NV8"],[[3897,3897],"valid"],[[3898,3901],"valid",[],"NV8"],[[3902,3906],"valid"],[[3907,3907],"mapped",[3906,4023]],[[3908,3911],"valid"],[[3912,3912],"disallowed"],[[3913,3916],"valid"],[[3917,3917],"mapped",[3916,4023]],[[3918,3921],"valid"],[[3922,3922],"mapped",[3921,4023]],[[3923,3926],"valid"],[[3927,3927],"mapped",[3926,4023]],[[3928,3931],"valid"],[[3932,3932],"mapped",[3931,4023]],[[3933,3944],"valid"],[[3945,3945],"mapped",[3904,4021]],[[3946,3946],"valid"],[[3947,3948],"valid"],[[3949,3952],"disallowed"],[[3953,3954],"valid"],[[3955,3955],"mapped",[3953,3954]],[[3956,3956],"valid"],[[3957,3957],"mapped",[3953,3956]],[[3958,3958],"mapped",[4018,3968]],[[3959,3959],"mapped",[4018,3953,3968]],[[3960,3960],"mapped",[4019,3968]],[[3961,3961],"mapped",[4019,3953,3968]],[[3962,3968],"valid"],[[3969,3969],"mapped",[3953,3968]],[[3970,3972],"valid"],[[3973,3973],"valid",[],"NV8"],[[3974,3979],"valid"],[[3980,3983],"valid"],[[3984,3986],"valid"],[[3987,3987],"mapped",[3986,4023]],[[3988,3989],"valid"],[[3990,3990],"valid"],[[3991,3991],"valid"],[[3992,3992],"disallowed"],[[3993,3996],"valid"],[[3997,3997],"mapped",[3996,4023]],[[3998,4001],"valid"],[[4002,4002],"mapped",[4001,4023]],[[4003,4006],"valid"],[[4007,4007],"mapped",[4006,4023]],[[4008,4011],"valid"],[[4012,4012],"mapped",[4011,4023]],[[4013,4013],"valid"],[[4014,4016],"valid"],[[4017,4023],"valid"],[[4024,4024],"valid"],[[4025,4025],"mapped",[3984,4021]],[[4026,4028],"valid"],[[4029,4029],"disallowed"],[[4030,4037],"valid",[],"NV8"],[[4038,4038],"valid"],[[4039,4044],"valid",[],"NV8"],[[4045,4045],"disallowed"],[[4046,4046],"valid",[],"NV8"],[[4047,4047],"valid",[],"NV8"],[[4048,4049],"valid",[],"NV8"],[[4050,4052],"valid",[],"NV8"],[[4053,4056],"valid",[],"NV8"],[[4057,4058],"valid",[],"NV8"],[[4059,4095],"disallowed"],[[4096,4129],"valid"],[[4130,4130],"valid"],[[4131,4135],"valid"],[[4136,4136],"valid"],[[4137,4138],"valid"],[[4139,4139],"valid"],[[4140,4146],"valid"],[[4147,4149],"valid"],[[4150,4153],"valid"],[[4154,4159],"valid"],[[4160,4169],"valid"],[[4170,4175],"valid",[],"NV8"],[[4176,4185],"valid"],[[4186,4249],"valid"],[[4250,4253],"valid"],[[4254,4255],"valid",[],"NV8"],[[4256,4293],"disallowed"],[[4294,4294],"disallowed"],[[4295,4295],"mapped",[11559]],[[4296,4300],"disallowed"],[[4301,4301],"mapped",[11565]],[[4302,4303],"disallowed"],[[4304,4342],"valid"],[[4343,4344],"valid"],[[4345,4346],"valid"],[[4347,4347],"valid",[],"NV8"],[[4348,4348],"mapped",[4316]],[[4349,4351],"valid"],[[4352,4441],"valid",[],"NV8"],[[4442,4446],"valid",[],"NV8"],[[4447,4448],"disallowed"],[[4449,4514],"valid",[],"NV8"],[[4515,4519],"valid",[],"NV8"],[[4520,4601],"valid",[],"NV8"],[[4602,4607],"valid",[],"NV8"],[[4608,4614],"valid"],[[4615,4615],"valid"],[[4616,4678],"valid"],[[4679,4679],"valid"],[[4680,4680],"valid"],[[4681,4681],"disallowed"],[[4682,4685],"valid"],[[4686,4687],"disallowed"],[[4688,4694],"valid"],[[4695,4695],"disallowed"],[[4696,4696],"valid"],[[4697,4697],"disallowed"],[[4698,4701],"valid"],[[4702,4703],"disallowed"],[[4704,4742],"valid"],[[4743,4743],"valid"],[[4744,4744],"valid"],[[4745,4745],"disallowed"],[[4746,4749],"valid"],[[4750,4751],"disallowed"],[[4752,4782],"valid"],[[4783,4783],"valid"],[[4784,4784],"valid"],[[4785,4785],"disallowed"],[[4786,4789],"valid"],[[4790,4791],"disallowed"],[[4792,4798],"valid"],[[4799,4799],"disallowed"],[[4800,4800],"valid"],[[4801,4801],"disallowed"],[[4802,4805],"valid"],[[4806,4807],"disallowed"],[[4808,4814],"valid"],[[4815,4815],"valid"],[[4816,4822],"valid"],[[4823,4823],"disallowed"],[[4824,4846],"valid"],[[4847,4847],"valid"],[[4848,4878],"valid"],[[4879,4879],"valid"],[[4880,4880],"valid"],[[4881,4881],"disallowed"],[[4882,4885],"valid"],[[4886,4887],"disallowed"],[[4888,4894],"valid"],[[4895,4895],"valid"],[[4896,4934],"valid"],[[4935,4935],"valid"],[[4936,4954],"valid"],[[4955,4956],"disallowed"],[[4957,4958],"valid"],[[4959,4959],"valid"],[[4960,4960],"valid",[],"NV8"],[[4961,4988],"valid",[],"NV8"],[[4989,4991],"disallowed"],[[4992,5007],"valid"],[[5008,5017],"valid",[],"NV8"],[[5018,5023],"disallowed"],[[5024,5108],"valid"],[[5109,5109],"valid"],[[5110,5111],"disallowed"],[[5112,5112],"mapped",[5104]],[[5113,5113],"mapped",[5105]],[[5114,5114],"mapped",[5106]],[[5115,5115],"mapped",[5107]],[[5116,5116],"mapped",[5108]],[[5117,5117],"mapped",[5109]],[[5118,5119],"disallowed"],[[5120,5120],"valid",[],"NV8"],[[5121,5740],"valid"],[[5741,5742],"valid",[],"NV8"],[[5743,5750],"valid"],[[5751,5759],"valid"],[[5760,5760],"disallowed"],[[5761,5786],"valid"],[[5787,5788],"valid",[],"NV8"],[[5789,5791],"disallowed"],[[5792,5866],"valid"],[[5867,5872],"valid",[],"NV8"],[[5873,5880],"valid"],[[5881,5887],"disallowed"],[[5888,5900],"valid"],[[5901,5901],"disallowed"],[[5902,5908],"valid"],[[5909,5919],"disallowed"],[[5920,5940],"valid"],[[5941,5942],"valid",[],"NV8"],[[5943,5951],"disallowed"],[[5952,5971],"valid"],[[5972,5983],"disallowed"],[[5984,5996],"valid"],[[5997,5997],"disallowed"],[[5998,6000],"valid"],[[6001,6001],"disallowed"],[[6002,6003],"valid"],[[6004,6015],"disallowed"],[[6016,6067],"valid"],[[6068,6069],"disallowed"],[[6070,6099],"valid"],[[6100,6102],"valid",[],"NV8"],[[6103,6103],"valid"],[[6104,6107],"valid",[],"NV8"],[[6108,6108],"valid"],[[6109,6109],"valid"],[[6110,6111],"disallowed"],[[6112,6121],"valid"],[[6122,6127],"disallowed"],[[6128,6137],"valid",[],"NV8"],[[6138,6143],"disallowed"],[[6144,6149],"valid",[],"NV8"],[[6150,6150],"disallowed"],[[6151,6154],"valid",[],"NV8"],[[6155,6157],"ignored"],[[6158,6158],"disallowed"],[[6159,6159],"disallowed"],[[6160,6169],"valid"],[[6170,6175],"disallowed"],[[6176,6263],"valid"],[[6264,6271],"disallowed"],[[6272,6313],"valid"],[[6314,6314],"valid"],[[6315,6319],"disallowed"],[[6320,6389],"valid"],[[6390,6399],"disallowed"],[[6400,6428],"valid"],[[6429,6430],"valid"],[[6431,6431],"disallowed"],[[6432,6443],"valid"],[[6444,6447],"disallowed"],[[6448,6459],"valid"],[[6460,6463],"disallowed"],[[6464,6464],"valid",[],"NV8"],[[6465,6467],"disallowed"],[[6468,6469],"valid",[],"NV8"],[[6470,6509],"valid"],[[6510,6511],"disallowed"],[[6512,6516],"valid"],[[6517,6527],"disallowed"],[[6528,6569],"valid"],[[6570,6571],"valid"],[[6572,6575],"disallowed"],[[6576,6601],"valid"],[[6602,6607],"disallowed"],[[6608,6617],"valid"],[[6618,6618],"valid",[],"XV8"],[[6619,6621],"disallowed"],[[6622,6623],"valid",[],"NV8"],[[6624,6655],"valid",[],"NV8"],[[6656,6683],"valid"],[[6684,6685],"disallowed"],[[6686,6687],"valid",[],"NV8"],[[6688,6750],"valid"],[[6751,6751],"disallowed"],[[6752,6780],"valid"],[[6781,6782],"disallowed"],[[6783,6793],"valid"],[[6794,6799],"disallowed"],[[6800,6809],"valid"],[[6810,6815],"disallowed"],[[6816,6822],"valid",[],"NV8"],[[6823,6823],"valid"],[[6824,6829],"valid",[],"NV8"],[[6830,6831],"disallowed"],[[6832,6845],"valid"],[[6846,6846],"valid",[],"NV8"],[[6847,6911],"disallowed"],[[6912,6987],"valid"],[[6988,6991],"disallowed"],[[6992,7001],"valid"],[[7002,7018],"valid",[],"NV8"],[[7019,7027],"valid"],[[7028,7036],"valid",[],"NV8"],[[7037,7039],"disallowed"],[[7040,7082],"valid"],[[7083,7085],"valid"],[[7086,7097],"valid"],[[7098,7103],"valid"],[[7104,7155],"valid"],[[7156,7163],"disallowed"],[[7164,7167],"valid",[],"NV8"],[[7168,7223],"valid"],[[7224,7226],"disallowed"],[[7227,7231],"valid",[],"NV8"],[[7232,7241],"valid"],[[7242,7244],"disallowed"],[[7245,7293],"valid"],[[7294,7295],"valid",[],"NV8"],[[7296,7359],"disallowed"],[[7360,7367],"valid",[],"NV8"],[[7368,7375],"disallowed"],[[7376,7378],"valid"],[[7379,7379],"valid",[],"NV8"],[[7380,7410],"valid"],[[7411,7414],"valid"],[[7415,7415],"disallowed"],[[7416,7417],"valid"],[[7418,7423],"disallowed"],[[7424,7467],"valid"],[[7468,7468],"mapped",[97]],[[7469,7469],"mapped",[230]],[[7470,7470],"mapped",[98]],[[7471,7471],"valid"],[[7472,7472],"mapped",[100]],[[7473,7473],"mapped",[101]],[[7474,7474],"mapped",[477]],[[7475,7475],"mapped",[103]],[[7476,7476],"mapped",[104]],[[7477,7477],"mapped",[105]],[[7478,7478],"mapped",[106]],[[7479,7479],"mapped",[107]],[[7480,7480],"mapped",[108]],[[7481,7481],"mapped",[109]],[[7482,7482],"mapped",[110]],[[7483,7483],"valid"],[[7484,7484],"mapped",[111]],[[7485,7485],"mapped",[547]],[[7486,7486],"mapped",[112]],[[7487,7487],"mapped",[114]],[[7488,7488],"mapped",[116]],[[7489,7489],"mapped",[117]],[[7490,7490],"mapped",[119]],[[7491,7491],"mapped",[97]],[[7492,7492],"mapped",[592]],[[7493,7493],"mapped",[593]],[[7494,7494],"mapped",[7426]],[[7495,7495],"mapped",[98]],[[7496,7496],"mapped",[100]],[[7497,7497],"mapped",[101]],[[7498,7498],"mapped",[601]],[[7499,7499],"mapped",[603]],[[7500,7500],"mapped",[604]],[[7501,7501],"mapped",[103]],[[7502,7502],"valid"],[[7503,7503],"mapped",[107]],[[7504,7504],"mapped",[109]],[[7505,7505],"mapped",[331]],[[7506,7506],"mapped",[111]],[[7507,7507],"mapped",[596]],[[7508,7508],"mapped",[7446]],[[7509,7509],"mapped",[7447]],[[7510,7510],"mapped",[112]],[[7511,7511],"mapped",[116]],[[7512,7512],"mapped",[117]],[[7513,7513],"mapped",[7453]],[[7514,7514],"mapped",[623]],[[7515,7515],"mapped",[118]],[[7516,7516],"mapped",[7461]],[[7517,7517],"mapped",[946]],[[7518,7518],"mapped",[947]],[[7519,7519],"mapped",[948]],[[7520,7520],"mapped",[966]],[[7521,7521],"mapped",[967]],[[7522,7522],"mapped",[105]],[[7523,7523],"mapped",[114]],[[7524,7524],"mapped",[117]],[[7525,7525],"mapped",[118]],[[7526,7526],"mapped",[946]],[[7527,7527],"mapped",[947]],[[7528,7528],"mapped",[961]],[[7529,7529],"mapped",[966]],[[7530,7530],"mapped",[967]],[[7531,7531],"valid"],[[7532,7543],"valid"],[[7544,7544],"mapped",[1085]],[[7545,7578],"valid"],[[7579,7579],"mapped",[594]],[[7580,7580],"mapped",[99]],[[7581,7581],"mapped",[597]],[[7582,7582],"mapped",[240]],[[7583,7583],"mapped",[604]],[[7584,7584],"mapped",[102]],[[7585,7585],"mapped",[607]],[[7586,7586],"mapped",[609]],[[7587,7587],"mapped",[613]],[[7588,7588],"mapped",[616]],[[7589,7589],"mapped",[617]],[[7590,7590],"mapped",[618]],[[7591,7591],"mapped",[7547]],[[7592,7592],"mapped",[669]],[[7593,7593],"mapped",[621]],[[7594,7594],"mapped",[7557]],[[7595,7595],"mapped",[671]],[[7596,7596],"mapped",[625]],[[7597,7597],"mapped",[624]],[[7598,7598],"mapped",[626]],[[7599,7599],"mapped",[627]],[[7600,7600],"mapped",[628]],[[7601,7601],"mapped",[629]],[[7602,7602],"mapped",[632]],[[7603,7603],"mapped",[642]],[[7604,7604],"mapped",[643]],[[7605,7605],"mapped",[427]],[[7606,7606],"mapped",[649]],[[7607,7607],"mapped",[650]],[[7608,7608],"mapped",[7452]],[[7609,7609],"mapped",[651]],[[7610,7610],"mapped",[652]],[[7611,7611],"mapped",[122]],[[7612,7612],"mapped",[656]],[[7613,7613],"mapped",[657]],[[7614,7614],"mapped",[658]],[[7615,7615],"mapped",[952]],[[7616,7619],"valid"],[[7620,7626],"valid"],[[7627,7654],"valid"],[[7655,7669],"valid"],[[7670,7675],"disallowed"],[[7676,7676],"valid"],[[7677,7677],"valid"],[[7678,7679],"valid"],[[7680,7680],"mapped",[7681]],[[7681,7681],"valid"],[[7682,7682],"mapped",[7683]],[[7683,7683],"valid"],[[7684,7684],"mapped",[7685]],[[7685,7685],"valid"],[[7686,7686],"mapped",[7687]],[[7687,7687],"valid"],[[7688,7688],"mapped",[7689]],[[7689,7689],"valid"],[[7690,7690],"mapped",[7691]],[[7691,7691],"valid"],[[7692,7692],"mapped",[7693]],[[7693,7693],"valid"],[[7694,7694],"mapped",[7695]],[[7695,7695],"valid"],[[7696,7696],"mapped",[7697]],[[7697,7697],"valid"],[[7698,7698],"mapped",[7699]],[[7699,7699],"valid"],[[7700,7700],"mapped",[7701]],[[7701,7701],"valid"],[[7702,7702],"mapped",[7703]],[[7703,7703],"valid"],[[7704,7704],"mapped",[7705]],[[7705,7705],"valid"],[[7706,7706],"mapped",[7707]],[[7707,7707],"valid"],[[7708,7708],"mapped",[7709]],[[7709,7709],"valid"],[[7710,7710],"mapped",[7711]],[[7711,7711],"valid"],[[7712,7712],"mapped",[7713]],[[7713,7713],"valid"],[[7714,7714],"mapped",[7715]],[[7715,7715],"valid"],[[7716,7716],"mapped",[7717]],[[7717,7717],"valid"],[[7718,7718],"mapped",[7719]],[[7719,7719],"valid"],[[7720,7720],"mapped",[7721]],[[7721,7721],"valid"],[[7722,7722],"mapped",[7723]],[[7723,7723],"valid"],[[7724,7724],"mapped",[7725]],[[7725,7725],"valid"],[[7726,7726],"mapped",[7727]],[[7727,7727],"valid"],[[7728,7728],"mapped",[7729]],[[7729,7729],"valid"],[[7730,7730],"mapped",[7731]],[[7731,7731],"valid"],[[7732,7732],"mapped",[7733]],[[7733,7733],"valid"],[[7734,7734],"mapped",[7735]],[[7735,7735],"valid"],[[7736,7736],"mapped",[7737]],[[7737,7737],"valid"],[[7738,7738],"mapped",[7739]],[[7739,7739],"valid"],[[7740,7740],"mapped",[7741]],[[7741,7741],"valid"],[[7742,7742],"mapped",[7743]],[[7743,7743],"valid"],[[7744,7744],"mapped",[7745]],[[7745,7745],"valid"],[[7746,7746],"mapped",[7747]],[[7747,7747],"valid"],[[7748,7748],"mapped",[7749]],[[7749,7749],"valid"],[[7750,7750],"mapped",[7751]],[[7751,7751],"valid"],[[7752,7752],"mapped",[7753]],[[7753,7753],"valid"],[[7754,7754],"mapped",[7755]],[[7755,7755],"valid"],[[7756,7756],"mapped",[7757]],[[7757,7757],"valid"],[[7758,7758],"mapped",[7759]],[[7759,7759],"valid"],[[7760,7760],"mapped",[7761]],[[7761,7761],"valid"],[[7762,7762],"mapped",[7763]],[[7763,7763],"valid"],[[7764,7764],"mapped",[7765]],[[7765,7765],"valid"],[[7766,7766],"mapped",[7767]],[[7767,7767],"valid"],[[7768,7768],"mapped",[7769]],[[7769,7769],"valid"],[[7770,7770],"mapped",[7771]],[[7771,7771],"valid"],[[7772,7772],"mapped",[7773]],[[7773,7773],"valid"],[[7774,7774],"mapped",[7775]],[[7775,7775],"valid"],[[7776,7776],"mapped",[7777]],[[7777,7777],"valid"],[[7778,7778],"mapped",[7779]],[[7779,7779],"valid"],[[7780,7780],"mapped",[7781]],[[7781,7781],"valid"],[[7782,7782],"mapped",[7783]],[[7783,7783],"valid"],[[7784,7784],"mapped",[7785]],[[7785,7785],"valid"],[[7786,7786],"mapped",[7787]],[[7787,7787],"valid"],[[7788,7788],"mapped",[7789]],[[7789,7789],"valid"],[[7790,7790],"mapped",[7791]],[[7791,7791],"valid"],[[7792,7792],"mapped",[7793]],[[7793,7793],"valid"],[[7794,7794],"mapped",[7795]],[[7795,7795],"valid"],[[7796,7796],"mapped",[7797]],[[7797,7797],"valid"],[[7798,7798],"mapped",[7799]],[[7799,7799],"valid"],[[7800,7800],"mapped",[7801]],[[7801,7801],"valid"],[[7802,7802],"mapped",[7803]],[[7803,7803],"valid"],[[7804,7804],"mapped",[7805]],[[7805,7805],"valid"],[[7806,7806],"mapped",[7807]],[[7807,7807],"valid"],[[7808,7808],"mapped",[7809]],[[7809,7809],"valid"],[[7810,7810],"mapped",[7811]],[[7811,7811],"valid"],[[7812,7812],"mapped",[7813]],[[7813,7813],"valid"],[[7814,7814],"mapped",[7815]],[[7815,7815],"valid"],[[7816,7816],"mapped",[7817]],[[7817,7817],"valid"],[[7818,7818],"mapped",[7819]],[[7819,7819],"valid"],[[7820,7820],"mapped",[7821]],[[7821,7821],"valid"],[[7822,7822],"mapped",[7823]],[[7823,7823],"valid"],[[7824,7824],"mapped",[7825]],[[7825,7825],"valid"],[[7826,7826],"mapped",[7827]],[[7827,7827],"valid"],[[7828,7828],"mapped",[7829]],[[7829,7833],"valid"],[[7834,7834],"mapped",[97,702]],[[7835,7835],"mapped",[7777]],[[7836,7837],"valid"],[[7838,7838],"mapped",[115,115]],[[7839,7839],"valid"],[[7840,7840],"mapped",[7841]],[[7841,7841],"valid"],[[7842,7842],"mapped",[7843]],[[7843,7843],"valid"],[[7844,7844],"mapped",[7845]],[[7845,7845],"valid"],[[7846,7846],"mapped",[7847]],[[7847,7847],"valid"],[[7848,7848],"mapped",[7849]],[[7849,7849],"valid"],[[7850,7850],"mapped",[7851]],[[7851,7851],"valid"],[[7852,7852],"mapped",[7853]],[[7853,7853],"valid"],[[7854,7854],"mapped",[7855]],[[7855,7855],"valid"],[[7856,7856],"mapped",[7857]],[[7857,7857],"valid"],[[7858,7858],"mapped",[7859]],[[7859,7859],"valid"],[[7860,7860],"mapped",[7861]],[[7861,7861],"valid"],[[7862,7862],"mapped",[7863]],[[7863,7863],"valid"],[[7864,7864],"mapped",[7865]],[[7865,7865],"valid"],[[7866,7866],"mapped",[7867]],[[7867,7867],"valid"],[[7868,7868],"mapped",[7869]],[[7869,7869],"valid"],[[7870,7870],"mapped",[7871]],[[7871,7871],"valid"],[[7872,7872],"mapped",[7873]],[[7873,7873],"valid"],[[7874,7874],"mapped",[7875]],[[7875,7875],"valid"],[[7876,7876],"mapped",[7877]],[[7877,7877],"valid"],[[7878,7878],"mapped",[7879]],[[7879,7879],"valid"],[[7880,7880],"mapped",[7881]],[[7881,7881],"valid"],[[7882,7882],"mapped",[7883]],[[7883,7883],"valid"],[[7884,7884],"mapped",[7885]],[[7885,7885],"valid"],[[7886,7886],"mapped",[7887]],[[7887,7887],"valid"],[[7888,7888],"mapped",[7889]],[[7889,7889],"valid"],[[7890,7890],"mapped",[7891]],[[7891,7891],"valid"],[[7892,7892],"mapped",[7893]],[[7893,7893],"valid"],[[7894,7894],"mapped",[7895]],[[7895,7895],"valid"],[[7896,7896],"mapped",[7897]],[[7897,7897],"valid"],[[7898,7898],"mapped",[7899]],[[7899,7899],"valid"],[[7900,7900],"mapped",[7901]],[[7901,7901],"valid"],[[7902,7902],"mapped",[7903]],[[7903,7903],"valid"],[[7904,7904],"mapped",[7905]],[[7905,7905],"valid"],[[7906,7906],"mapped",[7907]],[[7907,7907],"valid"],[[7908,7908],"mapped",[7909]],[[7909,7909],"valid"],[[7910,7910],"mapped",[7911]],[[7911,7911],"valid"],[[7912,7912],"mapped",[7913]],[[7913,7913],"valid"],[[7914,7914],"mapped",[7915]],[[7915,7915],"valid"],[[7916,7916],"mapped",[7917]],[[7917,7917],"valid"],[[7918,7918],"mapped",[7919]],[[7919,7919],"valid"],[[7920,7920],"mapped",[7921]],[[7921,7921],"valid"],[[7922,7922],"mapped",[7923]],[[7923,7923],"valid"],[[7924,7924],"mapped",[7925]],[[7925,7925],"valid"],[[7926,7926],"mapped",[7927]],[[7927,7927],"valid"],[[7928,7928],"mapped",[7929]],[[7929,7929],"valid"],[[7930,7930],"mapped",[7931]],[[7931,7931],"valid"],[[7932,7932],"mapped",[7933]],[[7933,7933],"valid"],[[7934,7934],"mapped",[7935]],[[7935,7935],"valid"],[[7936,7943],"valid"],[[7944,7944],"mapped",[7936]],[[7945,7945],"mapped",[7937]],[[7946,7946],"mapped",[7938]],[[7947,7947],"mapped",[7939]],[[7948,7948],"mapped",[7940]],[[7949,7949],"mapped",[7941]],[[7950,7950],"mapped",[7942]],[[7951,7951],"mapped",[7943]],[[7952,7957],"valid"],[[7958,7959],"disallowed"],[[7960,7960],"mapped",[7952]],[[7961,7961],"mapped",[7953]],[[7962,7962],"mapped",[7954]],[[7963,7963],"mapped",[7955]],[[7964,7964],"mapped",[7956]],[[7965,7965],"mapped",[7957]],[[7966,7967],"disallowed"],[[7968,7975],"valid"],[[7976,7976],"mapped",[7968]],[[7977,7977],"mapped",[7969]],[[7978,7978],"mapped",[7970]],[[7979,7979],"mapped",[7971]],[[7980,7980],"mapped",[7972]],[[7981,7981],"mapped",[7973]],[[7982,7982],"mapped",[7974]],[[7983,7983],"mapped",[7975]],[[7984,7991],"valid"],[[7992,7992],"mapped",[7984]],[[7993,7993],"mapped",[7985]],[[7994,7994],"mapped",[7986]],[[7995,7995],"mapped",[7987]],[[7996,7996],"mapped",[7988]],[[7997,7997],"mapped",[7989]],[[7998,7998],"mapped",[7990]],[[7999,7999],"mapped",[7991]],[[8000,8005],"valid"],[[8006,8007],"disallowed"],[[8008,8008],"mapped",[8000]],[[8009,8009],"mapped",[8001]],[[8010,8010],"mapped",[8002]],[[8011,8011],"mapped",[8003]],[[8012,8012],"mapped",[8004]],[[8013,8013],"mapped",[8005]],[[8014,8015],"disallowed"],[[8016,8023],"valid"],[[8024,8024],"disallowed"],[[8025,8025],"mapped",[8017]],[[8026,8026],"disallowed"],[[8027,8027],"mapped",[8019]],[[8028,8028],"disallowed"],[[8029,8029],"mapped",[8021]],[[8030,8030],"disallowed"],[[8031,8031],"mapped",[8023]],[[8032,8039],"valid"],[[8040,8040],"mapped",[8032]],[[8041,8041],"mapped",[8033]],[[8042,8042],"mapped",[8034]],[[8043,8043],"mapped",[8035]],[[8044,8044],"mapped",[8036]],[[8045,8045],"mapped",[8037]],[[8046,8046],"mapped",[8038]],[[8047,8047],"mapped",[8039]],[[8048,8048],"valid"],[[8049,8049],"mapped",[940]],[[8050,8050],"valid"],[[8051,8051],"mapped",[941]],[[8052,8052],"valid"],[[8053,8053],"mapped",[942]],[[8054,8054],"valid"],[[8055,8055],"mapped",[943]],[[8056,8056],"valid"],[[8057,8057],"mapped",[972]],[[8058,8058],"valid"],[[8059,8059],"mapped",[973]],[[8060,8060],"valid"],[[8061,8061],"mapped",[974]],[[8062,8063],"disallowed"],[[8064,8064],"mapped",[7936,953]],[[8065,8065],"mapped",[7937,953]],[[8066,8066],"mapped",[7938,953]],[[8067,8067],"mapped",[7939,953]],[[8068,8068],"mapped",[7940,953]],[[8069,8069],"mapped",[7941,953]],[[8070,8070],"mapped",[7942,953]],[[8071,8071],"mapped",[7943,953]],[[8072,8072],"mapped",[7936,953]],[[8073,8073],"mapped",[7937,953]],[[8074,8074],"mapped",[7938,953]],[[8075,8075],"mapped",[7939,953]],[[8076,8076],"mapped",[7940,953]],[[8077,8077],"mapped",[7941,953]],[[8078,8078],"mapped",[7942,953]],[[8079,8079],"mapped",[7943,953]],[[8080,8080],"mapped",[7968,953]],[[8081,8081],"mapped",[7969,953]],[[8082,8082],"mapped",[7970,953]],[[8083,8083],"mapped",[7971,953]],[[8084,8084],"mapped",[7972,953]],[[8085,8085],"mapped",[7973,953]],[[8086,8086],"mapped",[7974,953]],[[8087,8087],"mapped",[7975,953]],[[8088,8088],"mapped",[7968,953]],[[8089,8089],"mapped",[7969,953]],[[8090,8090],"mapped",[7970,953]],[[8091,8091],"mapped",[7971,953]],[[8092,8092],"mapped",[7972,953]],[[8093,8093],"mapped",[7973,953]],[[8094,8094],"mapped",[7974,953]],[[8095,8095],"mapped",[7975,953]],[[8096,8096],"mapped",[8032,953]],[[8097,8097],"mapped",[8033,953]],[[8098,8098],"mapped",[8034,953]],[[8099,8099],"mapped",[8035,953]],[[8100,8100],"mapped",[8036,953]],[[8101,8101],"mapped",[8037,953]],[[8102,8102],"mapped",[8038,953]],[[8103,8103],"mapped",[8039,953]],[[8104,8104],"mapped",[8032,953]],[[8105,8105],"mapped",[8033,953]],[[8106,8106],"mapped",[8034,953]],[[8107,8107],"mapped",[8035,953]],[[8108,8108],"mapped",[8036,953]],[[8109,8109],"mapped",[8037,953]],[[8110,8110],"mapped",[8038,953]],[[8111,8111],"mapped",[8039,953]],[[8112,8113],"valid"],[[8114,8114],"mapped",[8048,953]],[[8115,8115],"mapped",[945,953]],[[8116,8116],"mapped",[940,953]],[[8117,8117],"disallowed"],[[8118,8118],"valid"],[[8119,8119],"mapped",[8118,953]],[[8120,8120],"mapped",[8112]],[[8121,8121],"mapped",[8113]],[[8122,8122],"mapped",[8048]],[[8123,8123],"mapped",[940]],[[8124,8124],"mapped",[945,953]],[[8125,8125],"disallowed_STD3_mapped",[32,787]],[[8126,8126],"mapped",[953]],[[8127,8127],"disallowed_STD3_mapped",[32,787]],[[8128,8128],"disallowed_STD3_mapped",[32,834]],[[8129,8129],"disallowed_STD3_mapped",[32,776,834]],[[8130,8130],"mapped",[8052,953]],[[8131,8131],"mapped",[951,953]],[[8132,8132],"mapped",[942,953]],[[8133,8133],"disallowed"],[[8134,8134],"valid"],[[8135,8135],"mapped",[8134,953]],[[8136,8136],"mapped",[8050]],[[8137,8137],"mapped",[941]],[[8138,8138],"mapped",[8052]],[[8139,8139],"mapped",[942]],[[8140,8140],"mapped",[951,953]],[[8141,8141],"disallowed_STD3_mapped",[32,787,768]],[[8142,8142],"disallowed_STD3_mapped",[32,787,769]],[[8143,8143],"disallowed_STD3_mapped",[32,787,834]],[[8144,8146],"valid"],[[8147,8147],"mapped",[912]],[[8148,8149],"disallowed"],[[8150,8151],"valid"],[[8152,8152],"mapped",[8144]],[[8153,8153],"mapped",[8145]],[[8154,8154],"mapped",[8054]],[[8155,8155],"mapped",[943]],[[8156,8156],"disallowed"],[[8157,8157],"disallowed_STD3_mapped",[32,788,768]],[[8158,8158],"disallowed_STD3_mapped",[32,788,769]],[[8159,8159],"disallowed_STD3_mapped",[32,788,834]],[[8160,8162],"valid"],[[8163,8163],"mapped",[944]],[[8164,8167],"valid"],[[8168,8168],"mapped",[8160]],[[8169,8169],"mapped",[8161]],[[8170,8170],"mapped",[8058]],[[8171,8171],"mapped",[973]],[[8172,8172],"mapped",[8165]],[[8173,8173],"disallowed_STD3_mapped",[32,776,768]],[[8174,8174],"disallowed_STD3_mapped",[32,776,769]],[[8175,8175],"disallowed_STD3_mapped",[96]],[[8176,8177],"disallowed"],[[8178,8178],"mapped",[8060,953]],[[8179,8179],"mapped",[969,953]],[[8180,8180],"mapped",[974,953]],[[8181,8181],"disallowed"],[[8182,8182],"valid"],[[8183,8183],"mapped",[8182,953]],[[8184,8184],"mapped",[8056]],[[8185,8185],"mapped",[972]],[[8186,8186],"mapped",[8060]],[[8187,8187],"mapped",[974]],[[8188,8188],"mapped",[969,953]],[[8189,8189],"disallowed_STD3_mapped",[32,769]],[[8190,8190],"disallowed_STD3_mapped",[32,788]],[[8191,8191],"disallowed"],[[8192,8202],"disallowed_STD3_mapped",[32]],[[8203,8203],"ignored"],[[8204,8205],"deviation",[]],[[8206,8207],"disallowed"],[[8208,8208],"valid",[],"NV8"],[[8209,8209],"mapped",[8208]],[[8210,8214],"valid",[],"NV8"],[[8215,8215],"disallowed_STD3_mapped",[32,819]],[[8216,8227],"valid",[],"NV8"],[[8228,8230],"disallowed"],[[8231,8231],"valid",[],"NV8"],[[8232,8238],"disallowed"],[[8239,8239],"disallowed_STD3_mapped",[32]],[[8240,8242],"valid",[],"NV8"],[[8243,8243],"mapped",[8242,8242]],[[8244,8244],"mapped",[8242,8242,8242]],[[8245,8245],"valid",[],"NV8"],[[8246,8246],"mapped",[8245,8245]],[[8247,8247],"mapped",[8245,8245,8245]],[[8248,8251],"valid",[],"NV8"],[[8252,8252],"disallowed_STD3_mapped",[33,33]],[[8253,8253],"valid",[],"NV8"],[[8254,8254],"disallowed_STD3_mapped",[32,773]],[[8255,8262],"valid",[],"NV8"],[[8263,8263],"disallowed_STD3_mapped",[63,63]],[[8264,8264],"disallowed_STD3_mapped",[63,33]],[[8265,8265],"disallowed_STD3_mapped",[33,63]],[[8266,8269],"valid",[],"NV8"],[[8270,8274],"valid",[],"NV8"],[[8275,8276],"valid",[],"NV8"],[[8277,8278],"valid",[],"NV8"],[[8279,8279],"mapped",[8242,8242,8242,8242]],[[8280,8286],"valid",[],"NV8"],[[8287,8287],"disallowed_STD3_mapped",[32]],[[8288,8288],"ignored"],[[8289,8291],"disallowed"],[[8292,8292],"ignored"],[[8293,8293],"disallowed"],[[8294,8297],"disallowed"],[[8298,8303],"disallowed"],[[8304,8304],"mapped",[48]],[[8305,8305],"mapped",[105]],[[8306,8307],"disallowed"],[[8308,8308],"mapped",[52]],[[8309,8309],"mapped",[53]],[[8310,8310],"mapped",[54]],[[8311,8311],"mapped",[55]],[[8312,8312],"mapped",[56]],[[8313,8313],"mapped",[57]],[[8314,8314],"disallowed_STD3_mapped",[43]],[[8315,8315],"mapped",[8722]],[[8316,8316],"disallowed_STD3_mapped",[61]],[[8317,8317],"disallowed_STD3_mapped",[40]],[[8318,8318],"disallowed_STD3_mapped",[41]],[[8319,8319],"mapped",[110]],[[8320,8320],"mapped",[48]],[[8321,8321],"mapped",[49]],[[8322,8322],"mapped",[50]],[[8323,8323],"mapped",[51]],[[8324,8324],"mapped",[52]],[[8325,8325],"mapped",[53]],[[8326,8326],"mapped",[54]],[[8327,8327],"mapped",[55]],[[8328,8328],"mapped",[56]],[[8329,8329],"mapped",[57]],[[8330,8330],"disallowed_STD3_mapped",[43]],[[8331,8331],"mapped",[8722]],[[8332,8332],"disallowed_STD3_mapped",[61]],[[8333,8333],"disallowed_STD3_mapped",[40]],[[8334,8334],"disallowed_STD3_mapped",[41]],[[8335,8335],"disallowed"],[[8336,8336],"mapped",[97]],[[8337,8337],"mapped",[101]],[[8338,8338],"mapped",[111]],[[8339,8339],"mapped",[120]],[[8340,8340],"mapped",[601]],[[8341,8341],"mapped",[104]],[[8342,8342],"mapped",[107]],[[8343,8343],"mapped",[108]],[[8344,8344],"mapped",[109]],[[8345,8345],"mapped",[110]],[[8346,8346],"mapped",[112]],[[8347,8347],"mapped",[115]],[[8348,8348],"mapped",[116]],[[8349,8351],"disallowed"],[[8352,8359],"valid",[],"NV8"],[[8360,8360],"mapped",[114,115]],[[8361,8362],"valid",[],"NV8"],[[8363,8363],"valid",[],"NV8"],[[8364,8364],"valid",[],"NV8"],[[8365,8367],"valid",[],"NV8"],[[8368,8369],"valid",[],"NV8"],[[8370,8373],"valid",[],"NV8"],[[8374,8376],"valid",[],"NV8"],[[8377,8377],"valid",[],"NV8"],[[8378,8378],"valid",[],"NV8"],[[8379,8381],"valid",[],"NV8"],[[8382,8382],"valid",[],"NV8"],[[8383,8399],"disallowed"],[[8400,8417],"valid",[],"NV8"],[[8418,8419],"valid",[],"NV8"],[[8420,8426],"valid",[],"NV8"],[[8427,8427],"valid",[],"NV8"],[[8428,8431],"valid",[],"NV8"],[[8432,8432],"valid",[],"NV8"],[[8433,8447],"disallowed"],[[8448,8448],"disallowed_STD3_mapped",[97,47,99]],[[8449,8449],"disallowed_STD3_mapped",[97,47,115]],[[8450,8450],"mapped",[99]],[[8451,8451],"mapped",[176,99]],[[8452,8452],"valid",[],"NV8"],[[8453,8453],"disallowed_STD3_mapped",[99,47,111]],[[8454,8454],"disallowed_STD3_mapped",[99,47,117]],[[8455,8455],"mapped",[603]],[[8456,8456],"valid",[],"NV8"],[[8457,8457],"mapped",[176,102]],[[8458,8458],"mapped",[103]],[[8459,8462],"mapped",[104]],[[8463,8463],"mapped",[295]],[[8464,8465],"mapped",[105]],[[8466,8467],"mapped",[108]],[[8468,8468],"valid",[],"NV8"],[[8469,8469],"mapped",[110]],[[8470,8470],"mapped",[110,111]],[[8471,8472],"valid",[],"NV8"],[[8473,8473],"mapped",[112]],[[8474,8474],"mapped",[113]],[[8475,8477],"mapped",[114]],[[8478,8479],"valid",[],"NV8"],[[8480,8480],"mapped",[115,109]],[[8481,8481],"mapped",[116,101,108]],[[8482,8482],"mapped",[116,109]],[[8483,8483],"valid",[],"NV8"],[[8484,8484],"mapped",[122]],[[8485,8485],"valid",[],"NV8"],[[8486,8486],"mapped",[969]],[[8487,8487],"valid",[],"NV8"],[[8488,8488],"mapped",[122]],[[8489,8489],"valid",[],"NV8"],[[8490,8490],"mapped",[107]],[[8491,8491],"mapped",[229]],[[8492,8492],"mapped",[98]],[[8493,8493],"mapped",[99]],[[8494,8494],"valid",[],"NV8"],[[8495,8496],"mapped",[101]],[[8497,8497],"mapped",[102]],[[8498,8498],"disallowed"],[[8499,8499],"mapped",[109]],[[8500,8500],"mapped",[111]],[[8501,8501],"mapped",[1488]],[[8502,8502],"mapped",[1489]],[[8503,8503],"mapped",[1490]],[[8504,8504],"mapped",[1491]],[[8505,8505],"mapped",[105]],[[8506,8506],"valid",[],"NV8"],[[8507,8507],"mapped",[102,97,120]],[[8508,8508],"mapped",[960]],[[8509,8510],"mapped",[947]],[[8511,8511],"mapped",[960]],[[8512,8512],"mapped",[8721]],[[8513,8516],"valid",[],"NV8"],[[8517,8518],"mapped",[100]],[[8519,8519],"mapped",[101]],[[8520,8520],"mapped",[105]],[[8521,8521],"mapped",[106]],[[8522,8523],"valid",[],"NV8"],[[8524,8524],"valid",[],"NV8"],[[8525,8525],"valid",[],"NV8"],[[8526,8526],"valid"],[[8527,8527],"valid",[],"NV8"],[[8528,8528],"mapped",[49,8260,55]],[[8529,8529],"mapped",[49,8260,57]],[[8530,8530],"mapped",[49,8260,49,48]],[[8531,8531],"mapped",[49,8260,51]],[[8532,8532],"mapped",[50,8260,51]],[[8533,8533],"mapped",[49,8260,53]],[[8534,8534],"mapped",[50,8260,53]],[[8535,8535],"mapped",[51,8260,53]],[[8536,8536],"mapped",[52,8260,53]],[[8537,8537],"mapped",[49,8260,54]],[[8538,8538],"mapped",[53,8260,54]],[[8539,8539],"mapped",[49,8260,56]],[[8540,8540],"mapped",[51,8260,56]],[[8541,8541],"mapped",[53,8260,56]],[[8542,8542],"mapped",[55,8260,56]],[[8543,8543],"mapped",[49,8260]],[[8544,8544],"mapped",[105]],[[8545,8545],"mapped",[105,105]],[[8546,8546],"mapped",[105,105,105]],[[8547,8547],"mapped",[105,118]],[[8548,8548],"mapped",[118]],[[8549,8549],"mapped",[118,105]],[[8550,8550],"mapped",[118,105,105]],[[8551,8551],"mapped",[118,105,105,105]],[[8552,8552],"mapped",[105,120]],[[8553,8553],"mapped",[120]],[[8554,8554],"mapped",[120,105]],[[8555,8555],"mapped",[120,105,105]],[[8556,8556],"mapped",[108]],[[8557,8557],"mapped",[99]],[[8558,8558],"mapped",[100]],[[8559,8559],"mapped",[109]],[[8560,8560],"mapped",[105]],[[8561,8561],"mapped",[105,105]],[[8562,8562],"mapped",[105,105,105]],[[8563,8563],"mapped",[105,118]],[[8564,8564],"mapped",[118]],[[8565,8565],"mapped",[118,105]],[[8566,8566],"mapped",[118,105,105]],[[8567,8567],"mapped",[118,105,105,105]],[[8568,8568],"mapped",[105,120]],[[8569,8569],"mapped",[120]],[[8570,8570],"mapped",[120,105]],[[8571,8571],"mapped",[120,105,105]],[[8572,8572],"mapped",[108]],[[8573,8573],"mapped",[99]],[[8574,8574],"mapped",[100]],[[8575,8575],"mapped",[109]],[[8576,8578],"valid",[],"NV8"],[[8579,8579],"disallowed"],[[8580,8580],"valid"],[[8581,8584],"valid",[],"NV8"],[[8585,8585],"mapped",[48,8260,51]],[[8586,8587],"valid",[],"NV8"],[[8588,8591],"disallowed"],[[8592,8682],"valid",[],"NV8"],[[8683,8691],"valid",[],"NV8"],[[8692,8703],"valid",[],"NV8"],[[8704,8747],"valid",[],"NV8"],[[8748,8748],"mapped",[8747,8747]],[[8749,8749],"mapped",[8747,8747,8747]],[[8750,8750],"valid",[],"NV8"],[[8751,8751],"mapped",[8750,8750]],[[8752,8752],"mapped",[8750,8750,8750]],[[8753,8799],"valid",[],"NV8"],[[8800,8800],"disallowed_STD3_valid"],[[8801,8813],"valid",[],"NV8"],[[8814,8815],"disallowed_STD3_valid"],[[8816,8945],"valid",[],"NV8"],[[8946,8959],"valid",[],"NV8"],[[8960,8960],"valid",[],"NV8"],[[8961,8961],"valid",[],"NV8"],[[8962,9000],"valid",[],"NV8"],[[9001,9001],"mapped",[12296]],[[9002,9002],"mapped",[12297]],[[9003,9082],"valid",[],"NV8"],[[9083,9083],"valid",[],"NV8"],[[9084,9084],"valid",[],"NV8"],[[9085,9114],"valid",[],"NV8"],[[9115,9166],"valid",[],"NV8"],[[9167,9168],"valid",[],"NV8"],[[9169,9179],"valid",[],"NV8"],[[9180,9191],"valid",[],"NV8"],[[9192,9192],"valid",[],"NV8"],[[9193,9203],"valid",[],"NV8"],[[9204,9210],"valid",[],"NV8"],[[9211,9215],"disallowed"],[[9216,9252],"valid",[],"NV8"],[[9253,9254],"valid",[],"NV8"],[[9255,9279],"disallowed"],[[9280,9290],"valid",[],"NV8"],[[9291,9311],"disallowed"],[[9312,9312],"mapped",[49]],[[9313,9313],"mapped",[50]],[[9314,9314],"mapped",[51]],[[9315,9315],"mapped",[52]],[[9316,9316],"mapped",[53]],[[9317,9317],"mapped",[54]],[[9318,9318],"mapped",[55]],[[9319,9319],"mapped",[56]],[[9320,9320],"mapped",[57]],[[9321,9321],"mapped",[49,48]],[[9322,9322],"mapped",[49,49]],[[9323,9323],"mapped",[49,50]],[[9324,9324],"mapped",[49,51]],[[9325,9325],"mapped",[49,52]],[[9326,9326],"mapped",[49,53]],[[9327,9327],"mapped",[49,54]],[[9328,9328],"mapped",[49,55]],[[9329,9329],"mapped",[49,56]],[[9330,9330],"mapped",[49,57]],[[9331,9331],"mapped",[50,48]],[[9332,9332],"disallowed_STD3_mapped",[40,49,41]],[[9333,9333],"disallowed_STD3_mapped",[40,50,41]],[[9334,9334],"disallowed_STD3_mapped",[40,51,41]],[[9335,9335],"disallowed_STD3_mapped",[40,52,41]],[[9336,9336],"disallowed_STD3_mapped",[40,53,41]],[[9337,9337],"disallowed_STD3_mapped",[40,54,41]],[[9338,9338],"disallowed_STD3_mapped",[40,55,41]],[[9339,9339],"disallowed_STD3_mapped",[40,56,41]],[[9340,9340],"disallowed_STD3_mapped",[40,57,41]],[[9341,9341],"disallowed_STD3_mapped",[40,49,48,41]],[[9342,9342],"disallowed_STD3_mapped",[40,49,49,41]],[[9343,9343],"disallowed_STD3_mapped",[40,49,50,41]],[[9344,9344],"disallowed_STD3_mapped",[40,49,51,41]],[[9345,9345],"disallowed_STD3_mapped",[40,49,52,41]],[[9346,9346],"disallowed_STD3_mapped",[40,49,53,41]],[[9347,9347],"disallowed_STD3_mapped",[40,49,54,41]],[[9348,9348],"disallowed_STD3_mapped",[40,49,55,41]],[[9349,9349],"disallowed_STD3_mapped",[40,49,56,41]],[[9350,9350],"disallowed_STD3_mapped",[40,49,57,41]],[[9351,9351],"disallowed_STD3_mapped",[40,50,48,41]],[[9352,9371],"disallowed"],[[9372,9372],"disallowed_STD3_mapped",[40,97,41]],[[9373,9373],"disallowed_STD3_mapped",[40,98,41]],[[9374,9374],"disallowed_STD3_mapped",[40,99,41]],[[9375,9375],"disallowed_STD3_mapped",[40,100,41]],[[9376,9376],"disallowed_STD3_mapped",[40,101,41]],[[9377,9377],"disallowed_STD3_mapped",[40,102,41]],[[9378,9378],"disallowed_STD3_mapped",[40,103,41]],[[9379,9379],"disallowed_STD3_mapped",[40,104,41]],[[9380,9380],"disallowed_STD3_mapped",[40,105,41]],[[9381,9381],"disallowed_STD3_mapped",[40,106,41]],[[9382,9382],"disallowed_STD3_mapped",[40,107,41]],[[9383,9383],"disallowed_STD3_mapped",[40,108,41]],[[9384,9384],"disallowed_STD3_mapped",[40,109,41]],[[9385,9385],"disallowed_STD3_mapped",[40,110,41]],[[9386,9386],"disallowed_STD3_mapped",[40,111,41]],[[9387,9387],"disallowed_STD3_mapped",[40,112,41]],[[9388,9388],"disallowed_STD3_mapped",[40,113,41]],[[9389,9389],"disallowed_STD3_mapped",[40,114,41]],[[9390,9390],"disallowed_STD3_mapped",[40,115,41]],[[9391,9391],"disallowed_STD3_mapped",[40,116,41]],[[9392,9392],"disallowed_STD3_mapped",[40,117,41]],[[9393,9393],"disallowed_STD3_mapped",[40,118,41]],[[9394,9394],"disallowed_STD3_mapped",[40,119,41]],[[9395,9395],"disallowed_STD3_mapped",[40,120,41]],[[9396,9396],"disallowed_STD3_mapped",[40,121,41]],[[9397,9397],"disallowed_STD3_mapped",[40,122,41]],[[9398,9398],"mapped",[97]],[[9399,9399],"mapped",[98]],[[9400,9400],"mapped",[99]],[[9401,9401],"mapped",[100]],[[9402,9402],"mapped",[101]],[[9403,9403],"mapped",[102]],[[9404,9404],"mapped",[103]],[[9405,9405],"mapped",[104]],[[9406,9406],"mapped",[105]],[[9407,9407],"mapped",[106]],[[9408,9408],"mapped",[107]],[[9409,9409],"mapped",[108]],[[9410,9410],"mapped",[109]],[[9411,9411],"mapped",[110]],[[9412,9412],"mapped",[111]],[[9413,9413],"mapped",[112]],[[9414,9414],"mapped",[113]],[[9415,9415],"mapped",[114]],[[9416,9416],"mapped",[115]],[[9417,9417],"mapped",[116]],[[9418,9418],"mapped",[117]],[[9419,9419],"mapped",[118]],[[9420,9420],"mapped",[119]],[[9421,9421],"mapped",[120]],[[9422,9422],"mapped",[121]],[[9423,9423],"mapped",[122]],[[9424,9424],"mapped",[97]],[[9425,9425],"mapped",[98]],[[9426,9426],"mapped",[99]],[[9427,9427],"mapped",[100]],[[9428,9428],"mapped",[101]],[[9429,9429],"mapped",[102]],[[9430,9430],"mapped",[103]],[[9431,9431],"mapped",[104]],[[9432,9432],"mapped",[105]],[[9433,9433],"mapped",[106]],[[9434,9434],"mapped",[107]],[[9435,9435],"mapped",[108]],[[9436,9436],"mapped",[109]],[[9437,9437],"mapped",[110]],[[9438,9438],"mapped",[111]],[[9439,9439],"mapped",[112]],[[9440,9440],"mapped",[113]],[[9441,9441],"mapped",[114]],[[9442,9442],"mapped",[115]],[[9443,9443],"mapped",[116]],[[9444,9444],"mapped",[117]],[[9445,9445],"mapped",[118]],[[9446,9446],"mapped",[119]],[[9447,9447],"mapped",[120]],[[9448,9448],"mapped",[121]],[[9449,9449],"mapped",[122]],[[9450,9450],"mapped",[48]],[[9451,9470],"valid",[],"NV8"],[[9471,9471],"valid",[],"NV8"],[[9472,9621],"valid",[],"NV8"],[[9622,9631],"valid",[],"NV8"],[[9632,9711],"valid",[],"NV8"],[[9712,9719],"valid",[],"NV8"],[[9720,9727],"valid",[],"NV8"],[[9728,9747],"valid",[],"NV8"],[[9748,9749],"valid",[],"NV8"],[[9750,9751],"valid",[],"NV8"],[[9752,9752],"valid",[],"NV8"],[[9753,9753],"valid",[],"NV8"],[[9754,9839],"valid",[],"NV8"],[[9840,9841],"valid",[],"NV8"],[[9842,9853],"valid",[],"NV8"],[[9854,9855],"valid",[],"NV8"],[[9856,9865],"valid",[],"NV8"],[[9866,9873],"valid",[],"NV8"],[[9874,9884],"valid",[],"NV8"],[[9885,9885],"valid",[],"NV8"],[[9886,9887],"valid",[],"NV8"],[[9888,9889],"valid",[],"NV8"],[[9890,9905],"valid",[],"NV8"],[[9906,9906],"valid",[],"NV8"],[[9907,9916],"valid",[],"NV8"],[[9917,9919],"valid",[],"NV8"],[[9920,9923],"valid",[],"NV8"],[[9924,9933],"valid",[],"NV8"],[[9934,9934],"valid",[],"NV8"],[[9935,9953],"valid",[],"NV8"],[[9954,9954],"valid",[],"NV8"],[[9955,9955],"valid",[],"NV8"],[[9956,9959],"valid",[],"NV8"],[[9960,9983],"valid",[],"NV8"],[[9984,9984],"valid",[],"NV8"],[[9985,9988],"valid",[],"NV8"],[[9989,9989],"valid",[],"NV8"],[[9990,9993],"valid",[],"NV8"],[[9994,9995],"valid",[],"NV8"],[[9996,10023],"valid",[],"NV8"],[[10024,10024],"valid",[],"NV8"],[[10025,10059],"valid",[],"NV8"],[[10060,10060],"valid",[],"NV8"],[[10061,10061],"valid",[],"NV8"],[[10062,10062],"valid",[],"NV8"],[[10063,10066],"valid",[],"NV8"],[[10067,10069],"valid",[],"NV8"],[[10070,10070],"valid",[],"NV8"],[[10071,10071],"valid",[],"NV8"],[[10072,10078],"valid",[],"NV8"],[[10079,10080],"valid",[],"NV8"],[[10081,10087],"valid",[],"NV8"],[[10088,10101],"valid",[],"NV8"],[[10102,10132],"valid",[],"NV8"],[[10133,10135],"valid",[],"NV8"],[[10136,10159],"valid",[],"NV8"],[[10160,10160],"valid",[],"NV8"],[[10161,10174],"valid",[],"NV8"],[[10175,10175],"valid",[],"NV8"],[[10176,10182],"valid",[],"NV8"],[[10183,10186],"valid",[],"NV8"],[[10187,10187],"valid",[],"NV8"],[[10188,10188],"valid",[],"NV8"],[[10189,10189],"valid",[],"NV8"],[[10190,10191],"valid",[],"NV8"],[[10192,10219],"valid",[],"NV8"],[[10220,10223],"valid",[],"NV8"],[[10224,10239],"valid",[],"NV8"],[[10240,10495],"valid",[],"NV8"],[[10496,10763],"valid",[],"NV8"],[[10764,10764],"mapped",[8747,8747,8747,8747]],[[10765,10867],"valid",[],"NV8"],[[10868,10868],"disallowed_STD3_mapped",[58,58,61]],[[10869,10869],"disallowed_STD3_mapped",[61,61]],[[10870,10870],"disallowed_STD3_mapped",[61,61,61]],[[10871,10971],"valid",[],"NV8"],[[10972,10972],"mapped",[10973,824]],[[10973,11007],"valid",[],"NV8"],[[11008,11021],"valid",[],"NV8"],[[11022,11027],"valid",[],"NV8"],[[11028,11034],"valid",[],"NV8"],[[11035,11039],"valid",[],"NV8"],[[11040,11043],"valid",[],"NV8"],[[11044,11084],"valid",[],"NV8"],[[11085,11087],"valid",[],"NV8"],[[11088,11092],"valid",[],"NV8"],[[11093,11097],"valid",[],"NV8"],[[11098,11123],"valid",[],"NV8"],[[11124,11125],"disallowed"],[[11126,11157],"valid",[],"NV8"],[[11158,11159],"disallowed"],[[11160,11193],"valid",[],"NV8"],[[11194,11196],"disallowed"],[[11197,11208],"valid",[],"NV8"],[[11209,11209],"disallowed"],[[11210,11217],"valid",[],"NV8"],[[11218,11243],"disallowed"],[[11244,11247],"valid",[],"NV8"],[[11248,11263],"disallowed"],[[11264,11264],"mapped",[11312]],[[11265,11265],"mapped",[11313]],[[11266,11266],"mapped",[11314]],[[11267,11267],"mapped",[11315]],[[11268,11268],"mapped",[11316]],[[11269,11269],"mapped",[11317]],[[11270,11270],"mapped",[11318]],[[11271,11271],"mapped",[11319]],[[11272,11272],"mapped",[11320]],[[11273,11273],"mapped",[11321]],[[11274,11274],"mapped",[11322]],[[11275,11275],"mapped",[11323]],[[11276,11276],"mapped",[11324]],[[11277,11277],"mapped",[11325]],[[11278,11278],"mapped",[11326]],[[11279,11279],"mapped",[11327]],[[11280,11280],"mapped",[11328]],[[11281,11281],"mapped",[11329]],[[11282,11282],"mapped",[11330]],[[11283,11283],"mapped",[11331]],[[11284,11284],"mapped",[11332]],[[11285,11285],"mapped",[11333]],[[11286,11286],"mapped",[11334]],[[11287,11287],"mapped",[11335]],[[11288,11288],"mapped",[11336]],[[11289,11289],"mapped",[11337]],[[11290,11290],"mapped",[11338]],[[11291,11291],"mapped",[11339]],[[11292,11292],"mapped",[11340]],[[11293,11293],"mapped",[11341]],[[11294,11294],"mapped",[11342]],[[11295,11295],"mapped",[11343]],[[11296,11296],"mapped",[11344]],[[11297,11297],"mapped",[11345]],[[11298,11298],"mapped",[11346]],[[11299,11299],"mapped",[11347]],[[11300,11300],"mapped",[11348]],[[11301,11301],"mapped",[11349]],[[11302,11302],"mapped",[11350]],[[11303,11303],"mapped",[11351]],[[11304,11304],"mapped",[11352]],[[11305,11305],"mapped",[11353]],[[11306,11306],"mapped",[11354]],[[11307,11307],"mapped",[11355]],[[11308,11308],"mapped",[11356]],[[11309,11309],"mapped",[11357]],[[11310,11310],"mapped",[11358]],[[11311,11311],"disallowed"],[[11312,11358],"valid"],[[11359,11359],"disallowed"],[[11360,11360],"mapped",[11361]],[[11361,11361],"valid"],[[11362,11362],"mapped",[619]],[[11363,11363],"mapped",[7549]],[[11364,11364],"mapped",[637]],[[11365,11366],"valid"],[[11367,11367],"mapped",[11368]],[[11368,11368],"valid"],[[11369,11369],"mapped",[11370]],[[11370,11370],"valid"],[[11371,11371],"mapped",[11372]],[[11372,11372],"valid"],[[11373,11373],"mapped",[593]],[[11374,11374],"mapped",[625]],[[11375,11375],"mapped",[592]],[[11376,11376],"mapped",[594]],[[11377,11377],"valid"],[[11378,11378],"mapped",[11379]],[[11379,11379],"valid"],[[11380,11380],"valid"],[[11381,11381],"mapped",[11382]],[[11382,11383],"valid"],[[11384,11387],"valid"],[[11388,11388],"mapped",[106]],[[11389,11389],"mapped",[118]],[[11390,11390],"mapped",[575]],[[11391,11391],"mapped",[576]],[[11392,11392],"mapped",[11393]],[[11393,11393],"valid"],[[11394,11394],"mapped",[11395]],[[11395,11395],"valid"],[[11396,11396],"mapped",[11397]],[[11397,11397],"valid"],[[11398,11398],"mapped",[11399]],[[11399,11399],"valid"],[[11400,11400],"mapped",[11401]],[[11401,11401],"valid"],[[11402,11402],"mapped",[11403]],[[11403,11403],"valid"],[[11404,11404],"mapped",[11405]],[[11405,11405],"valid"],[[11406,11406],"mapped",[11407]],[[11407,11407],"valid"],[[11408,11408],"mapped",[11409]],[[11409,11409],"valid"],[[11410,11410],"mapped",[11411]],[[11411,11411],"valid"],[[11412,11412],"mapped",[11413]],[[11413,11413],"valid"],[[11414,11414],"mapped",[11415]],[[11415,11415],"valid"],[[11416,11416],"mapped",[11417]],[[11417,11417],"valid"],[[11418,11418],"mapped",[11419]],[[11419,11419],"valid"],[[11420,11420],"mapped",[11421]],[[11421,11421],"valid"],[[11422,11422],"mapped",[11423]],[[11423,11423],"valid"],[[11424,11424],"mapped",[11425]],[[11425,11425],"valid"],[[11426,11426],"mapped",[11427]],[[11427,11427],"valid"],[[11428,11428],"mapped",[11429]],[[11429,11429],"valid"],[[11430,11430],"mapped",[11431]],[[11431,11431],"valid"],[[11432,11432],"mapped",[11433]],[[11433,11433],"valid"],[[11434,11434],"mapped",[11435]],[[11435,11435],"valid"],[[11436,11436],"mapped",[11437]],[[11437,11437],"valid"],[[11438,11438],"mapped",[11439]],[[11439,11439],"valid"],[[11440,11440],"mapped",[11441]],[[11441,11441],"valid"],[[11442,11442],"mapped",[11443]],[[11443,11443],"valid"],[[11444,11444],"mapped",[11445]],[[11445,11445],"valid"],[[11446,11446],"mapped",[11447]],[[11447,11447],"valid"],[[11448,11448],"mapped",[11449]],[[11449,11449],"valid"],[[11450,11450],"mapped",[11451]],[[11451,11451],"valid"],[[11452,11452],"mapped",[11453]],[[11453,11453],"valid"],[[11454,11454],"mapped",[11455]],[[11455,11455],"valid"],[[11456,11456],"mapped",[11457]],[[11457,11457],"valid"],[[11458,11458],"mapped",[11459]],[[11459,11459],"valid"],[[11460,11460],"mapped",[11461]],[[11461,11461],"valid"],[[11462,11462],"mapped",[11463]],[[11463,11463],"valid"],[[11464,11464],"mapped",[11465]],[[11465,11465],"valid"],[[11466,11466],"mapped",[11467]],[[11467,11467],"valid"],[[11468,11468],"mapped",[11469]],[[11469,11469],"valid"],[[11470,11470],"mapped",[11471]],[[11471,11471],"valid"],[[11472,11472],"mapped",[11473]],[[11473,11473],"valid"],[[11474,11474],"mapped",[11475]],[[11475,11475],"valid"],[[11476,11476],"mapped",[11477]],[[11477,11477],"valid"],[[11478,11478],"mapped",[11479]],[[11479,11479],"valid"],[[11480,11480],"mapped",[11481]],[[11481,11481],"valid"],[[11482,11482],"mapped",[11483]],[[11483,11483],"valid"],[[11484,11484],"mapped",[11485]],[[11485,11485],"valid"],[[11486,11486],"mapped",[11487]],[[11487,11487],"valid"],[[11488,11488],"mapped",[11489]],[[11489,11489],"valid"],[[11490,11490],"mapped",[11491]],[[11491,11492],"valid"],[[11493,11498],"valid",[],"NV8"],[[11499,11499],"mapped",[11500]],[[11500,11500],"valid"],[[11501,11501],"mapped",[11502]],[[11502,11505],"valid"],[[11506,11506],"mapped",[11507]],[[11507,11507],"valid"],[[11508,11512],"disallowed"],[[11513,11519],"valid",[],"NV8"],[[11520,11557],"valid"],[[11558,11558],"disallowed"],[[11559,11559],"valid"],[[11560,11564],"disallowed"],[[11565,11565],"valid"],[[11566,11567],"disallowed"],[[11568,11621],"valid"],[[11622,11623],"valid"],[[11624,11630],"disallowed"],[[11631,11631],"mapped",[11617]],[[11632,11632],"valid",[],"NV8"],[[11633,11646],"disallowed"],[[11647,11647],"valid"],[[11648,11670],"valid"],[[11671,11679],"disallowed"],[[11680,11686],"valid"],[[11687,11687],"disallowed"],[[11688,11694],"valid"],[[11695,11695],"disallowed"],[[11696,11702],"valid"],[[11703,11703],"disallowed"],[[11704,11710],"valid"],[[11711,11711],"disallowed"],[[11712,11718],"valid"],[[11719,11719],"disallowed"],[[11720,11726],"valid"],[[11727,11727],"disallowed"],[[11728,11734],"valid"],[[11735,11735],"disallowed"],[[11736,11742],"valid"],[[11743,11743],"disallowed"],[[11744,11775],"valid"],[[11776,11799],"valid",[],"NV8"],[[11800,11803],"valid",[],"NV8"],[[11804,11805],"valid",[],"NV8"],[[11806,11822],"valid",[],"NV8"],[[11823,11823],"valid"],[[11824,11824],"valid",[],"NV8"],[[11825,11825],"valid",[],"NV8"],[[11826,11835],"valid",[],"NV8"],[[11836,11842],"valid",[],"NV8"],[[11843,11903],"disallowed"],[[11904,11929],"valid",[],"NV8"],[[11930,11930],"disallowed"],[[11931,11934],"valid",[],"NV8"],[[11935,11935],"mapped",[27597]],[[11936,12018],"valid",[],"NV8"],[[12019,12019],"mapped",[40863]],[[12020,12031],"disallowed"],[[12032,12032],"mapped",[19968]],[[12033,12033],"mapped",[20008]],[[12034,12034],"mapped",[20022]],[[12035,12035],"mapped",[20031]],[[12036,12036],"mapped",[20057]],[[12037,12037],"mapped",[20101]],[[12038,12038],"mapped",[20108]],[[12039,12039],"mapped",[20128]],[[12040,12040],"mapped",[20154]],[[12041,12041],"mapped",[20799]],[[12042,12042],"mapped",[20837]],[[12043,12043],"mapped",[20843]],[[12044,12044],"mapped",[20866]],[[12045,12045],"mapped",[20886]],[[12046,12046],"mapped",[20907]],[[12047,12047],"mapped",[20960]],[[12048,12048],"mapped",[20981]],[[12049,12049],"mapped",[20992]],[[12050,12050],"mapped",[21147]],[[12051,12051],"mapped",[21241]],[[12052,12052],"mapped",[21269]],[[12053,12053],"mapped",[21274]],[[12054,12054],"mapped",[21304]],[[12055,12055],"mapped",[21313]],[[12056,12056],"mapped",[21340]],[[12057,12057],"mapped",[21353]],[[12058,12058],"mapped",[21378]],[[12059,12059],"mapped",[21430]],[[12060,12060],"mapped",[21448]],[[12061,12061],"mapped",[21475]],[[12062,12062],"mapped",[22231]],[[12063,12063],"mapped",[22303]],[[12064,12064],"mapped",[22763]],[[12065,12065],"mapped",[22786]],[[12066,12066],"mapped",[22794]],[[12067,12067],"mapped",[22805]],[[12068,12068],"mapped",[22823]],[[12069,12069],"mapped",[22899]],[[12070,12070],"mapped",[23376]],[[12071,12071],"mapped",[23424]],[[12072,12072],"mapped",[23544]],[[12073,12073],"mapped",[23567]],[[12074,12074],"mapped",[23586]],[[12075,12075],"mapped",[23608]],[[12076,12076],"mapped",[23662]],[[12077,12077],"mapped",[23665]],[[12078,12078],"mapped",[24027]],[[12079,12079],"mapped",[24037]],[[12080,12080],"mapped",[24049]],[[12081,12081],"mapped",[24062]],[[12082,12082],"mapped",[24178]],[[12083,12083],"mapped",[24186]],[[12084,12084],"mapped",[24191]],[[12085,12085],"mapped",[24308]],[[12086,12086],"mapped",[24318]],[[12087,12087],"mapped",[24331]],[[12088,12088],"mapped",[24339]],[[12089,12089],"mapped",[24400]],[[12090,12090],"mapped",[24417]],[[12091,12091],"mapped",[24435]],[[12092,12092],"mapped",[24515]],[[12093,12093],"mapped",[25096]],[[12094,12094],"mapped",[25142]],[[12095,12095],"mapped",[25163]],[[12096,12096],"mapped",[25903]],[[12097,12097],"mapped",[25908]],[[12098,12098],"mapped",[25991]],[[12099,12099],"mapped",[26007]],[[12100,12100],"mapped",[26020]],[[12101,12101],"mapped",[26041]],[[12102,12102],"mapped",[26080]],[[12103,12103],"mapped",[26085]],[[12104,12104],"mapped",[26352]],[[12105,12105],"mapped",[26376]],[[12106,12106],"mapped",[26408]],[[12107,12107],"mapped",[27424]],[[12108,12108],"mapped",[27490]],[[12109,12109],"mapped",[27513]],[[12110,12110],"mapped",[27571]],[[12111,12111],"mapped",[27595]],[[12112,12112],"mapped",[27604]],[[12113,12113],"mapped",[27611]],[[12114,12114],"mapped",[27663]],[[12115,12115],"mapped",[27668]],[[12116,12116],"mapped",[27700]],[[12117,12117],"mapped",[28779]],[[12118,12118],"mapped",[29226]],[[12119,12119],"mapped",[29238]],[[12120,12120],"mapped",[29243]],[[12121,12121],"mapped",[29247]],[[12122,12122],"mapped",[29255]],[[12123,12123],"mapped",[29273]],[[12124,12124],"mapped",[29275]],[[12125,12125],"mapped",[29356]],[[12126,12126],"mapped",[29572]],[[12127,12127],"mapped",[29577]],[[12128,12128],"mapped",[29916]],[[12129,12129],"mapped",[29926]],[[12130,12130],"mapped",[29976]],[[12131,12131],"mapped",[29983]],[[12132,12132],"mapped",[29992]],[[12133,12133],"mapped",[30000]],[[12134,12134],"mapped",[30091]],[[12135,12135],"mapped",[30098]],[[12136,12136],"mapped",[30326]],[[12137,12137],"mapped",[30333]],[[12138,12138],"mapped",[30382]],[[12139,12139],"mapped",[30399]],[[12140,12140],"mapped",[30446]],[[12141,12141],"mapped",[30683]],[[12142,12142],"mapped",[30690]],[[12143,12143],"mapped",[30707]],[[12144,12144],"mapped",[31034]],[[12145,12145],"mapped",[31160]],[[12146,12146],"mapped",[31166]],[[12147,12147],"mapped",[31348]],[[12148,12148],"mapped",[31435]],[[12149,12149],"mapped",[31481]],[[12150,12150],"mapped",[31859]],[[12151,12151],"mapped",[31992]],[[12152,12152],"mapped",[32566]],[[12153,12153],"mapped",[32593]],[[12154,12154],"mapped",[32650]],[[12155,12155],"mapped",[32701]],[[12156,12156],"mapped",[32769]],[[12157,12157],"mapped",[32780]],[[12158,12158],"mapped",[32786]],[[12159,12159],"mapped",[32819]],[[12160,12160],"mapped",[32895]],[[12161,12161],"mapped",[32905]],[[12162,12162],"mapped",[33251]],[[12163,12163],"mapped",[33258]],[[12164,12164],"mapped",[33267]],[[12165,12165],"mapped",[33276]],[[12166,12166],"mapped",[33292]],[[12167,12167],"mapped",[33307]],[[12168,12168],"mapped",[33311]],[[12169,12169],"mapped",[33390]],[[12170,12170],"mapped",[33394]],[[12171,12171],"mapped",[33400]],[[12172,12172],"mapped",[34381]],[[12173,12173],"mapped",[34411]],[[12174,12174],"mapped",[34880]],[[12175,12175],"mapped",[34892]],[[12176,12176],"mapped",[34915]],[[12177,12177],"mapped",[35198]],[[12178,12178],"mapped",[35211]],[[12179,12179],"mapped",[35282]],[[12180,12180],"mapped",[35328]],[[12181,12181],"mapped",[35895]],[[12182,12182],"mapped",[35910]],[[12183,12183],"mapped",[35925]],[[12184,12184],"mapped",[35960]],[[12185,12185],"mapped",[35997]],[[12186,12186],"mapped",[36196]],[[12187,12187],"mapped",[36208]],[[12188,12188],"mapped",[36275]],[[12189,12189],"mapped",[36523]],[[12190,12190],"mapped",[36554]],[[12191,12191],"mapped",[36763]],[[12192,12192],"mapped",[36784]],[[12193,12193],"mapped",[36789]],[[12194,12194],"mapped",[37009]],[[12195,12195],"mapped",[37193]],[[12196,12196],"mapped",[37318]],[[12197,12197],"mapped",[37324]],[[12198,12198],"mapped",[37329]],[[12199,12199],"mapped",[38263]],[[12200,12200],"mapped",[38272]],[[12201,12201],"mapped",[38428]],[[12202,12202],"mapped",[38582]],[[12203,12203],"mapped",[38585]],[[12204,12204],"mapped",[38632]],[[12205,12205],"mapped",[38737]],[[12206,12206],"mapped",[38750]],[[12207,12207],"mapped",[38754]],[[12208,12208],"mapped",[38761]],[[12209,12209],"mapped",[38859]],[[12210,12210],"mapped",[38893]],[[12211,12211],"mapped",[38899]],[[12212,12212],"mapped",[38913]],[[12213,12213],"mapped",[39080]],[[12214,12214],"mapped",[39131]],[[12215,12215],"mapped",[39135]],[[12216,12216],"mapped",[39318]],[[12217,12217],"mapped",[39321]],[[12218,12218],"mapped",[39340]],[[12219,12219],"mapped",[39592]],[[12220,12220],"mapped",[39640]],[[12221,12221],"mapped",[39647]],[[12222,12222],"mapped",[39717]],[[12223,12223],"mapped",[39727]],[[12224,12224],"mapped",[39730]],[[12225,12225],"mapped",[39740]],[[12226,12226],"mapped",[39770]],[[12227,12227],"mapped",[40165]],[[12228,12228],"mapped",[40565]],[[12229,12229],"mapped",[40575]],[[12230,12230],"mapped",[40613]],[[12231,12231],"mapped",[40635]],[[12232,12232],"mapped",[40643]],[[12233,12233],"mapped",[40653]],[[12234,12234],"mapped",[40657]],[[12235,12235],"mapped",[40697]],[[12236,12236],"mapped",[40701]],[[12237,12237],"mapped",[40718]],[[12238,12238],"mapped",[40723]],[[12239,12239],"mapped",[40736]],[[12240,12240],"mapped",[40763]],[[12241,12241],"mapped",[40778]],[[12242,12242],"mapped",[40786]],[[12243,12243],"mapped",[40845]],[[12244,12244],"mapped",[40860]],[[12245,12245],"mapped",[40864]],[[12246,12271],"disallowed"],[[12272,12283],"disallowed"],[[12284,12287],"disallowed"],[[12288,12288],"disallowed_STD3_mapped",[32]],[[12289,12289],"valid",[],"NV8"],[[12290,12290],"mapped",[46]],[[12291,12292],"valid",[],"NV8"],[[12293,12295],"valid"],[[12296,12329],"valid",[],"NV8"],[[12330,12333],"valid"],[[12334,12341],"valid",[],"NV8"],[[12342,12342],"mapped",[12306]],[[12343,12343],"valid",[],"NV8"],[[12344,12344],"mapped",[21313]],[[12345,12345],"mapped",[21316]],[[12346,12346],"mapped",[21317]],[[12347,12347],"valid",[],"NV8"],[[12348,12348],"valid"],[[12349,12349],"valid",[],"NV8"],[[12350,12350],"valid",[],"NV8"],[[12351,12351],"valid",[],"NV8"],[[12352,12352],"disallowed"],[[12353,12436],"valid"],[[12437,12438],"valid"],[[12439,12440],"disallowed"],[[12441,12442],"valid"],[[12443,12443],"disallowed_STD3_mapped",[32,12441]],[[12444,12444],"disallowed_STD3_mapped",[32,12442]],[[12445,12446],"valid"],[[12447,12447],"mapped",[12424,12426]],[[12448,12448],"valid",[],"NV8"],[[12449,12542],"valid"],[[12543,12543],"mapped",[12467,12488]],[[12544,12548],"disallowed"],[[12549,12588],"valid"],[[12589,12589],"valid"],[[12590,12592],"disallowed"],[[12593,12593],"mapped",[4352]],[[12594,12594],"mapped",[4353]],[[12595,12595],"mapped",[4522]],[[12596,12596],"mapped",[4354]],[[12597,12597],"mapped",[4524]],[[12598,12598],"mapped",[4525]],[[12599,12599],"mapped",[4355]],[[12600,12600],"mapped",[4356]],[[12601,12601],"mapped",[4357]],[[12602,12602],"mapped",[4528]],[[12603,12603],"mapped",[4529]],[[12604,12604],"mapped",[4530]],[[12605,12605],"mapped",[4531]],[[12606,12606],"mapped",[4532]],[[12607,12607],"mapped",[4533]],[[12608,12608],"mapped",[4378]],[[12609,12609],"mapped",[4358]],[[12610,12610],"mapped",[4359]],[[12611,12611],"mapped",[4360]],[[12612,12612],"mapped",[4385]],[[12613,12613],"mapped",[4361]],[[12614,12614],"mapped",[4362]],[[12615,12615],"mapped",[4363]],[[12616,12616],"mapped",[4364]],[[12617,12617],"mapped",[4365]],[[12618,12618],"mapped",[4366]],[[12619,12619],"mapped",[4367]],[[12620,12620],"mapped",[4368]],[[12621,12621],"mapped",[4369]],[[12622,12622],"mapped",[4370]],[[12623,12623],"mapped",[4449]],[[12624,12624],"mapped",[4450]],[[12625,12625],"mapped",[4451]],[[12626,12626],"mapped",[4452]],[[12627,12627],"mapped",[4453]],[[12628,12628],"mapped",[4454]],[[12629,12629],"mapped",[4455]],[[12630,12630],"mapped",[4456]],[[12631,12631],"mapped",[4457]],[[12632,12632],"mapped",[4458]],[[12633,12633],"mapped",[4459]],[[12634,12634],"mapped",[4460]],[[12635,12635],"mapped",[4461]],[[12636,12636],"mapped",[4462]],[[12637,12637],"mapped",[4463]],[[12638,12638],"mapped",[4464]],[[12639,12639],"mapped",[4465]],[[12640,12640],"mapped",[4466]],[[12641,12641],"mapped",[4467]],[[12642,12642],"mapped",[4468]],[[12643,12643],"mapped",[4469]],[[12644,12644],"disallowed"],[[12645,12645],"mapped",[4372]],[[12646,12646],"mapped",[4373]],[[12647,12647],"mapped",[4551]],[[12648,12648],"mapped",[4552]],[[12649,12649],"mapped",[4556]],[[12650,12650],"mapped",[4558]],[[12651,12651],"mapped",[4563]],[[12652,12652],"mapped",[4567]],[[12653,12653],"mapped",[4569]],[[12654,12654],"mapped",[4380]],[[12655,12655],"mapped",[4573]],[[12656,12656],"mapped",[4575]],[[12657,12657],"mapped",[4381]],[[12658,12658],"mapped",[4382]],[[12659,12659],"mapped",[4384]],[[12660,12660],"mapped",[4386]],[[12661,12661],"mapped",[4387]],[[12662,12662],"mapped",[4391]],[[12663,12663],"mapped",[4393]],[[12664,12664],"mapped",[4395]],[[12665,12665],"mapped",[4396]],[[12666,12666],"mapped",[4397]],[[12667,12667],"mapped",[4398]],[[12668,12668],"mapped",[4399]],[[12669,12669],"mapped",[4402]],[[12670,12670],"mapped",[4406]],[[12671,12671],"mapped",[4416]],[[12672,12672],"mapped",[4423]],[[12673,12673],"mapped",[4428]],[[12674,12674],"mapped",[4593]],[[12675,12675],"mapped",[4594]],[[12676,12676],"mapped",[4439]],[[12677,12677],"mapped",[4440]],[[12678,12678],"mapped",[4441]],[[12679,12679],"mapped",[4484]],[[12680,12680],"mapped",[4485]],[[12681,12681],"mapped",[4488]],[[12682,12682],"mapped",[4497]],[[12683,12683],"mapped",[4498]],[[12684,12684],"mapped",[4500]],[[12685,12685],"mapped",[4510]],[[12686,12686],"mapped",[4513]],[[12687,12687],"disallowed"],[[12688,12689],"valid",[],"NV8"],[[12690,12690],"mapped",[19968]],[[12691,12691],"mapped",[20108]],[[12692,12692],"mapped",[19977]],[[12693,12693],"mapped",[22235]],[[12694,12694],"mapped",[19978]],[[12695,12695],"mapped",[20013]],[[12696,12696],"mapped",[19979]],[[12697,12697],"mapped",[30002]],[[12698,12698],"mapped",[20057]],[[12699,12699],"mapped",[19993]],[[12700,12700],"mapped",[19969]],[[12701,12701],"mapped",[22825]],[[12702,12702],"mapped",[22320]],[[12703,12703],"mapped",[20154]],[[12704,12727],"valid"],[[12728,12730],"valid"],[[12731,12735],"disallowed"],[[12736,12751],"valid",[],"NV8"],[[12752,12771],"valid",[],"NV8"],[[12772,12783],"disallowed"],[[12784,12799],"valid"],[[12800,12800],"disallowed_STD3_mapped",[40,4352,41]],[[12801,12801],"disallowed_STD3_mapped",[40,4354,41]],[[12802,12802],"disallowed_STD3_mapped",[40,4355,41]],[[12803,12803],"disallowed_STD3_mapped",[40,4357,41]],[[12804,12804],"disallowed_STD3_mapped",[40,4358,41]],[[12805,12805],"disallowed_STD3_mapped",[40,4359,41]],[[12806,12806],"disallowed_STD3_mapped",[40,4361,41]],[[12807,12807],"disallowed_STD3_mapped",[40,4363,41]],[[12808,12808],"disallowed_STD3_mapped",[40,4364,41]],[[12809,12809],"disallowed_STD3_mapped",[40,4366,41]],[[12810,12810],"disallowed_STD3_mapped",[40,4367,41]],[[12811,12811],"disallowed_STD3_mapped",[40,4368,41]],[[12812,12812],"disallowed_STD3_mapped",[40,4369,41]],[[12813,12813],"disallowed_STD3_mapped",[40,4370,41]],[[12814,12814],"disallowed_STD3_mapped",[40,44032,41]],[[12815,12815],"disallowed_STD3_mapped",[40,45208,41]],[[12816,12816],"disallowed_STD3_mapped",[40,45796,41]],[[12817,12817],"disallowed_STD3_mapped",[40,46972,41]],[[12818,12818],"disallowed_STD3_mapped",[40,47560,41]],[[12819,12819],"disallowed_STD3_mapped",[40,48148,41]],[[12820,12820],"disallowed_STD3_mapped",[40,49324,41]],[[12821,12821],"disallowed_STD3_mapped",[40,50500,41]],[[12822,12822],"disallowed_STD3_mapped",[40,51088,41]],[[12823,12823],"disallowed_STD3_mapped",[40,52264,41]],[[12824,12824],"disallowed_STD3_mapped",[40,52852,41]],[[12825,12825],"disallowed_STD3_mapped",[40,53440,41]],[[12826,12826],"disallowed_STD3_mapped",[40,54028,41]],[[12827,12827],"disallowed_STD3_mapped",[40,54616,41]],[[12828,12828],"disallowed_STD3_mapped",[40,51452,41]],[[12829,12829],"disallowed_STD3_mapped",[40,50724,51204,41]],[[12830,12830],"disallowed_STD3_mapped",[40,50724,54980,41]],[[12831,12831],"disallowed"],[[12832,12832],"disallowed_STD3_mapped",[40,19968,41]],[[12833,12833],"disallowed_STD3_mapped",[40,20108,41]],[[12834,12834],"disallowed_STD3_mapped",[40,19977,41]],[[12835,12835],"disallowed_STD3_mapped",[40,22235,41]],[[12836,12836],"disallowed_STD3_mapped",[40,20116,41]],[[12837,12837],"disallowed_STD3_mapped",[40,20845,41]],[[12838,12838],"disallowed_STD3_mapped",[40,19971,41]],[[12839,12839],"disallowed_STD3_mapped",[40,20843,41]],[[12840,12840],"disallowed_STD3_mapped",[40,20061,41]],[[12841,12841],"disallowed_STD3_mapped",[40,21313,41]],[[12842,12842],"disallowed_STD3_mapped",[40,26376,41]],[[12843,12843],"disallowed_STD3_mapped",[40,28779,41]],[[12844,12844],"disallowed_STD3_mapped",[40,27700,41]],[[12845,12845],"disallowed_STD3_mapped",[40,26408,41]],[[12846,12846],"disallowed_STD3_mapped",[40,37329,41]],[[12847,12847],"disallowed_STD3_mapped",[40,22303,41]],[[12848,12848],"disallowed_STD3_mapped",[40,26085,41]],[[12849,12849],"disallowed_STD3_mapped",[40,26666,41]],[[12850,12850],"disallowed_STD3_mapped",[40,26377,41]],[[12851,12851],"disallowed_STD3_mapped",[40,31038,41]],[[12852,12852],"disallowed_STD3_mapped",[40,21517,41]],[[12853,12853],"disallowed_STD3_mapped",[40,29305,41]],[[12854,12854],"disallowed_STD3_mapped",[40,36001,41]],[[12855,12855],"disallowed_STD3_mapped",[40,31069,41]],[[12856,12856],"disallowed_STD3_mapped",[40,21172,41]],[[12857,12857],"disallowed_STD3_mapped",[40,20195,41]],[[12858,12858],"disallowed_STD3_mapped",[40,21628,41]],[[12859,12859],"disallowed_STD3_mapped",[40,23398,41]],[[12860,12860],"disallowed_STD3_mapped",[40,30435,41]],[[12861,12861],"disallowed_STD3_mapped",[40,20225,41]],[[12862,12862],"disallowed_STD3_mapped",[40,36039,41]],[[12863,12863],"disallowed_STD3_mapped",[40,21332,41]],[[12864,12864],"disallowed_STD3_mapped",[40,31085,41]],[[12865,12865],"disallowed_STD3_mapped",[40,20241,41]],[[12866,12866],"disallowed_STD3_mapped",[40,33258,41]],[[12867,12867],"disallowed_STD3_mapped",[40,33267,41]],[[12868,12868],"mapped",[21839]],[[12869,12869],"mapped",[24188]],[[12870,12870],"mapped",[25991]],[[12871,12871],"mapped",[31631]],[[12872,12879],"valid",[],"NV8"],[[12880,12880],"mapped",[112,116,101]],[[12881,12881],"mapped",[50,49]],[[12882,12882],"mapped",[50,50]],[[12883,12883],"mapped",[50,51]],[[12884,12884],"mapped",[50,52]],[[12885,12885],"mapped",[50,53]],[[12886,12886],"mapped",[50,54]],[[12887,12887],"mapped",[50,55]],[[12888,12888],"mapped",[50,56]],[[12889,12889],"mapped",[50,57]],[[12890,12890],"mapped",[51,48]],[[12891,12891],"mapped",[51,49]],[[12892,12892],"mapped",[51,50]],[[12893,12893],"mapped",[51,51]],[[12894,12894],"mapped",[51,52]],[[12895,12895],"mapped",[51,53]],[[12896,12896],"mapped",[4352]],[[12897,12897],"mapped",[4354]],[[12898,12898],"mapped",[4355]],[[12899,12899],"mapped",[4357]],[[12900,12900],"mapped",[4358]],[[12901,12901],"mapped",[4359]],[[12902,12902],"mapped",[4361]],[[12903,12903],"mapped",[4363]],[[12904,12904],"mapped",[4364]],[[12905,12905],"mapped",[4366]],[[12906,12906],"mapped",[4367]],[[12907,12907],"mapped",[4368]],[[12908,12908],"mapped",[4369]],[[12909,12909],"mapped",[4370]],[[12910,12910],"mapped",[44032]],[[12911,12911],"mapped",[45208]],[[12912,12912],"mapped",[45796]],[[12913,12913],"mapped",[46972]],[[12914,12914],"mapped",[47560]],[[12915,12915],"mapped",[48148]],[[12916,12916],"mapped",[49324]],[[12917,12917],"mapped",[50500]],[[12918,12918],"mapped",[51088]],[[12919,12919],"mapped",[52264]],[[12920,12920],"mapped",[52852]],[[12921,12921],"mapped",[53440]],[[12922,12922],"mapped",[54028]],[[12923,12923],"mapped",[54616]],[[12924,12924],"mapped",[52280,44256]],[[12925,12925],"mapped",[51452,51032]],[[12926,12926],"mapped",[50864]],[[12927,12927],"valid",[],"NV8"],[[12928,12928],"mapped",[19968]],[[12929,12929],"mapped",[20108]],[[12930,12930],"mapped",[19977]],[[12931,12931],"mapped",[22235]],[[12932,12932],"mapped",[20116]],[[12933,12933],"mapped",[20845]],[[12934,12934],"mapped",[19971]],[[12935,12935],"mapped",[20843]],[[12936,12936],"mapped",[20061]],[[12937,12937],"mapped",[21313]],[[12938,12938],"mapped",[26376]],[[12939,12939],"mapped",[28779]],[[12940,12940],"mapped",[27700]],[[12941,12941],"mapped",[26408]],[[12942,12942],"mapped",[37329]],[[12943,12943],"mapped",[22303]],[[12944,12944],"mapped",[26085]],[[12945,12945],"mapped",[26666]],[[12946,12946],"mapped",[26377]],[[12947,12947],"mapped",[31038]],[[12948,12948],"mapped",[21517]],[[12949,12949],"mapped",[29305]],[[12950,12950],"mapped",[36001]],[[12951,12951],"mapped",[31069]],[[12952,12952],"mapped",[21172]],[[12953,12953],"mapped",[31192]],[[12954,12954],"mapped",[30007]],[[12955,12955],"mapped",[22899]],[[12956,12956],"mapped",[36969]],[[12957,12957],"mapped",[20778]],[[12958,12958],"mapped",[21360]],[[12959,12959],"mapped",[27880]],[[12960,12960],"mapped",[38917]],[[12961,12961],"mapped",[20241]],[[12962,12962],"mapped",[20889]],[[12963,12963],"mapped",[27491]],[[12964,12964],"mapped",[19978]],[[12965,12965],"mapped",[20013]],[[12966,12966],"mapped",[19979]],[[12967,12967],"mapped",[24038]],[[12968,12968],"mapped",[21491]],[[12969,12969],"mapped",[21307]],[[12970,12970],"mapped",[23447]],[[12971,12971],"mapped",[23398]],[[12972,12972],"mapped",[30435]],[[12973,12973],"mapped",[20225]],[[12974,12974],"mapped",[36039]],[[12975,12975],"mapped",[21332]],[[12976,12976],"mapped",[22812]],[[12977,12977],"mapped",[51,54]],[[12978,12978],"mapped",[51,55]],[[12979,12979],"mapped",[51,56]],[[12980,12980],"mapped",[51,57]],[[12981,12981],"mapped",[52,48]],[[12982,12982],"mapped",[52,49]],[[12983,12983],"mapped",[52,50]],[[12984,12984],"mapped",[52,51]],[[12985,12985],"mapped",[52,52]],[[12986,12986],"mapped",[52,53]],[[12987,12987],"mapped",[52,54]],[[12988,12988],"mapped",[52,55]],[[12989,12989],"mapped",[52,56]],[[12990,12990],"mapped",[52,57]],[[12991,12991],"mapped",[53,48]],[[12992,12992],"mapped",[49,26376]],[[12993,12993],"mapped",[50,26376]],[[12994,12994],"mapped",[51,26376]],[[12995,12995],"mapped",[52,26376]],[[12996,12996],"mapped",[53,26376]],[[12997,12997],"mapped",[54,26376]],[[12998,12998],"mapped",[55,26376]],[[12999,12999],"mapped",[56,26376]],[[13000,13000],"mapped",[57,26376]],[[13001,13001],"mapped",[49,48,26376]],[[13002,13002],"mapped",[49,49,26376]],[[13003,13003],"mapped",[49,50,26376]],[[13004,13004],"mapped",[104,103]],[[13005,13005],"mapped",[101,114,103]],[[13006,13006],"mapped",[101,118]],[[13007,13007],"mapped",[108,116,100]],[[13008,13008],"mapped",[12450]],[[13009,13009],"mapped",[12452]],[[13010,13010],"mapped",[12454]],[[13011,13011],"mapped",[12456]],[[13012,13012],"mapped",[12458]],[[13013,13013],"mapped",[12459]],[[13014,13014],"mapped",[12461]],[[13015,13015],"mapped",[12463]],[[13016,13016],"mapped",[12465]],[[13017,13017],"mapped",[12467]],[[13018,13018],"mapped",[12469]],[[13019,13019],"mapped",[12471]],[[13020,13020],"mapped",[12473]],[[13021,13021],"mapped",[12475]],[[13022,13022],"mapped",[12477]],[[13023,13023],"mapped",[12479]],[[13024,13024],"mapped",[12481]],[[13025,13025],"mapped",[12484]],[[13026,13026],"mapped",[12486]],[[13027,13027],"mapped",[12488]],[[13028,13028],"mapped",[12490]],[[13029,13029],"mapped",[12491]],[[13030,13030],"mapped",[12492]],[[13031,13031],"mapped",[12493]],[[13032,13032],"mapped",[12494]],[[13033,13033],"mapped",[12495]],[[13034,13034],"mapped",[12498]],[[13035,13035],"mapped",[12501]],[[13036,13036],"mapped",[12504]],[[13037,13037],"mapped",[12507]],[[13038,13038],"mapped",[12510]],[[13039,13039],"mapped",[12511]],[[13040,13040],"mapped",[12512]],[[13041,13041],"mapped",[12513]],[[13042,13042],"mapped",[12514]],[[13043,13043],"mapped",[12516]],[[13044,13044],"mapped",[12518]],[[13045,13045],"mapped",[12520]],[[13046,13046],"mapped",[12521]],[[13047,13047],"mapped",[12522]],[[13048,13048],"mapped",[12523]],[[13049,13049],"mapped",[12524]],[[13050,13050],"mapped",[12525]],[[13051,13051],"mapped",[12527]],[[13052,13052],"mapped",[12528]],[[13053,13053],"mapped",[12529]],[[13054,13054],"mapped",[12530]],[[13055,13055],"disallowed"],[[13056,13056],"mapped",[12450,12497,12540,12488]],[[13057,13057],"mapped",[12450,12523,12501,12449]],[[13058,13058],"mapped",[12450,12531,12506,12450]],[[13059,13059],"mapped",[12450,12540,12523]],[[13060,13060],"mapped",[12452,12491,12531,12464]],[[13061,13061],"mapped",[12452,12531,12481]],[[13062,13062],"mapped",[12454,12457,12531]],[[13063,13063],"mapped",[12456,12473,12463,12540,12489]],[[13064,13064],"mapped",[12456,12540,12459,12540]],[[13065,13065],"mapped",[12458,12531,12473]],[[13066,13066],"mapped",[12458,12540,12512]],[[13067,13067],"mapped",[12459,12452,12522]],[[13068,13068],"mapped",[12459,12521,12483,12488]],[[13069,13069],"mapped",[12459,12525,12522,12540]],[[13070,13070],"mapped",[12460,12525,12531]],[[13071,13071],"mapped",[12460,12531,12510]],[[13072,13072],"mapped",[12462,12460]],[[13073,13073],"mapped",[12462,12491,12540]],[[13074,13074],"mapped",[12461,12517,12522,12540]],[[13075,13075],"mapped",[12462,12523,12480,12540]],[[13076,13076],"mapped",[12461,12525]],[[13077,13077],"mapped",[12461,12525,12464,12521,12512]],[[13078,13078],"mapped",[12461,12525,12513,12540,12488,12523]],[[13079,13079],"mapped",[12461,12525,12527,12483,12488]],[[13080,13080],"mapped",[12464,12521,12512]],[[13081,13081],"mapped",[12464,12521,12512,12488,12531]],[[13082,13082],"mapped",[12463,12523,12476,12452,12525]],[[13083,13083],"mapped",[12463,12525,12540,12493]],[[13084,13084],"mapped",[12465,12540,12473]],[[13085,13085],"mapped",[12467,12523,12490]],[[13086,13086],"mapped",[12467,12540,12509]],[[13087,13087],"mapped",[12469,12452,12463,12523]],[[13088,13088],"mapped",[12469,12531,12481,12540,12512]],[[13089,13089],"mapped",[12471,12522,12531,12464]],[[13090,13090],"mapped",[12475,12531,12481]],[[13091,13091],"mapped",[12475,12531,12488]],[[13092,13092],"mapped",[12480,12540,12473]],[[13093,13093],"mapped",[12487,12471]],[[13094,13094],"mapped",[12489,12523]],[[13095,13095],"mapped",[12488,12531]],[[13096,13096],"mapped",[12490,12494]],[[13097,13097],"mapped",[12494,12483,12488]],[[13098,13098],"mapped",[12495,12452,12484]],[[13099,13099],"mapped",[12497,12540,12475,12531,12488]],[[13100,13100],"mapped",[12497,12540,12484]],[[13101,13101],"mapped",[12496,12540,12524,12523]],[[13102,13102],"mapped",[12500,12450,12473,12488,12523]],[[13103,13103],"mapped",[12500,12463,12523]],[[13104,13104],"mapped",[12500,12467]],[[13105,13105],"mapped",[12499,12523]],[[13106,13106],"mapped",[12501,12449,12521,12483,12489]],[[13107,13107],"mapped",[12501,12451,12540,12488]],[[13108,13108],"mapped",[12502,12483,12471,12455,12523]],[[13109,13109],"mapped",[12501,12521,12531]],[[13110,13110],"mapped",[12504,12463,12479,12540,12523]],[[13111,13111],"mapped",[12506,12477]],[[13112,13112],"mapped",[12506,12491,12498]],[[13113,13113],"mapped",[12504,12523,12484]],[[13114,13114],"mapped",[12506,12531,12473]],[[13115,13115],"mapped",[12506,12540,12472]],[[13116,13116],"mapped",[12505,12540,12479]],[[13117,13117],"mapped",[12509,12452,12531,12488]],[[13118,13118],"mapped",[12508,12523,12488]],[[13119,13119],"mapped",[12507,12531]],[[13120,13120],"mapped",[12509,12531,12489]],[[13121,13121],"mapped",[12507,12540,12523]],[[13122,13122],"mapped",[12507,12540,12531]],[[13123,13123],"mapped",[12510,12452,12463,12525]],[[13124,13124],"mapped",[12510,12452,12523]],[[13125,13125],"mapped",[12510,12483,12495]],[[13126,13126],"mapped",[12510,12523,12463]],[[13127,13127],"mapped",[12510,12531,12471,12519,12531]],[[13128,13128],"mapped",[12511,12463,12525,12531]],[[13129,13129],"mapped",[12511,12522]],[[13130,13130],"mapped",[12511,12522,12496,12540,12523]],[[13131,13131],"mapped",[12513,12460]],[[13132,13132],"mapped",[12513,12460,12488,12531]],[[13133,13133],"mapped",[12513,12540,12488,12523]],[[13134,13134],"mapped",[12516,12540,12489]],[[13135,13135],"mapped",[12516,12540,12523]],[[13136,13136],"mapped",[12518,12450,12531]],[[13137,13137],"mapped",[12522,12483,12488,12523]],[[13138,13138],"mapped",[12522,12521]],[[13139,13139],"mapped",[12523,12500,12540]],[[13140,13140],"mapped",[12523,12540,12502,12523]],[[13141,13141],"mapped",[12524,12512]],[[13142,13142],"mapped",[12524,12531,12488,12466,12531]],[[13143,13143],"mapped",[12527,12483,12488]],[[13144,13144],"mapped",[48,28857]],[[13145,13145],"mapped",[49,28857]],[[13146,13146],"mapped",[50,28857]],[[13147,13147],"mapped",[51,28857]],[[13148,13148],"mapped",[52,28857]],[[13149,13149],"mapped",[53,28857]],[[13150,13150],"mapped",[54,28857]],[[13151,13151],"mapped",[55,28857]],[[13152,13152],"mapped",[56,28857]],[[13153,13153],"mapped",[57,28857]],[[13154,13154],"mapped",[49,48,28857]],[[13155,13155],"mapped",[49,49,28857]],[[13156,13156],"mapped",[49,50,28857]],[[13157,13157],"mapped",[49,51,28857]],[[13158,13158],"mapped",[49,52,28857]],[[13159,13159],"mapped",[49,53,28857]],[[13160,13160],"mapped",[49,54,28857]],[[13161,13161],"mapped",[49,55,28857]],[[13162,13162],"mapped",[49,56,28857]],[[13163,13163],"mapped",[49,57,28857]],[[13164,13164],"mapped",[50,48,28857]],[[13165,13165],"mapped",[50,49,28857]],[[13166,13166],"mapped",[50,50,28857]],[[13167,13167],"mapped",[50,51,28857]],[[13168,13168],"mapped",[50,52,28857]],[[13169,13169],"mapped",[104,112,97]],[[13170,13170],"mapped",[100,97]],[[13171,13171],"mapped",[97,117]],[[13172,13172],"mapped",[98,97,114]],[[13173,13173],"mapped",[111,118]],[[13174,13174],"mapped",[112,99]],[[13175,13175],"mapped",[100,109]],[[13176,13176],"mapped",[100,109,50]],[[13177,13177],"mapped",[100,109,51]],[[13178,13178],"mapped",[105,117]],[[13179,13179],"mapped",[24179,25104]],[[13180,13180],"mapped",[26157,21644]],[[13181,13181],"mapped",[22823,27491]],[[13182,13182],"mapped",[26126,27835]],[[13183,13183],"mapped",[26666,24335,20250,31038]],[[13184,13184],"mapped",[112,97]],[[13185,13185],"mapped",[110,97]],[[13186,13186],"mapped",[956,97]],[[13187,13187],"mapped",[109,97]],[[13188,13188],"mapped",[107,97]],[[13189,13189],"mapped",[107,98]],[[13190,13190],"mapped",[109,98]],[[13191,13191],"mapped",[103,98]],[[13192,13192],"mapped",[99,97,108]],[[13193,13193],"mapped",[107,99,97,108]],[[13194,13194],"mapped",[112,102]],[[13195,13195],"mapped",[110,102]],[[13196,13196],"mapped",[956,102]],[[13197,13197],"mapped",[956,103]],[[13198,13198],"mapped",[109,103]],[[13199,13199],"mapped",[107,103]],[[13200,13200],"mapped",[104,122]],[[13201,13201],"mapped",[107,104,122]],[[13202,13202],"mapped",[109,104,122]],[[13203,13203],"mapped",[103,104,122]],[[13204,13204],"mapped",[116,104,122]],[[13205,13205],"mapped",[956,108]],[[13206,13206],"mapped",[109,108]],[[13207,13207],"mapped",[100,108]],[[13208,13208],"mapped",[107,108]],[[13209,13209],"mapped",[102,109]],[[13210,13210],"mapped",[110,109]],[[13211,13211],"mapped",[956,109]],[[13212,13212],"mapped",[109,109]],[[13213,13213],"mapped",[99,109]],[[13214,13214],"mapped",[107,109]],[[13215,13215],"mapped",[109,109,50]],[[13216,13216],"mapped",[99,109,50]],[[13217,13217],"mapped",[109,50]],[[13218,13218],"mapped",[107,109,50]],[[13219,13219],"mapped",[109,109,51]],[[13220,13220],"mapped",[99,109,51]],[[13221,13221],"mapped",[109,51]],[[13222,13222],"mapped",[107,109,51]],[[13223,13223],"mapped",[109,8725,115]],[[13224,13224],"mapped",[109,8725,115,50]],[[13225,13225],"mapped",[112,97]],[[13226,13226],"mapped",[107,112,97]],[[13227,13227],"mapped",[109,112,97]],[[13228,13228],"mapped",[103,112,97]],[[13229,13229],"mapped",[114,97,100]],[[13230,13230],"mapped",[114,97,100,8725,115]],[[13231,13231],"mapped",[114,97,100,8725,115,50]],[[13232,13232],"mapped",[112,115]],[[13233,13233],"mapped",[110,115]],[[13234,13234],"mapped",[956,115]],[[13235,13235],"mapped",[109,115]],[[13236,13236],"mapped",[112,118]],[[13237,13237],"mapped",[110,118]],[[13238,13238],"mapped",[956,118]],[[13239,13239],"mapped",[109,118]],[[13240,13240],"mapped",[107,118]],[[13241,13241],"mapped",[109,118]],[[13242,13242],"mapped",[112,119]],[[13243,13243],"mapped",[110,119]],[[13244,13244],"mapped",[956,119]],[[13245,13245],"mapped",[109,119]],[[13246,13246],"mapped",[107,119]],[[13247,13247],"mapped",[109,119]],[[13248,13248],"mapped",[107,969]],[[13249,13249],"mapped",[109,969]],[[13250,13250],"disallowed"],[[13251,13251],"mapped",[98,113]],[[13252,13252],"mapped",[99,99]],[[13253,13253],"mapped",[99,100]],[[13254,13254],"mapped",[99,8725,107,103]],[[13255,13255],"disallowed"],[[13256,13256],"mapped",[100,98]],[[13257,13257],"mapped",[103,121]],[[13258,13258],"mapped",[104,97]],[[13259,13259],"mapped",[104,112]],[[13260,13260],"mapped",[105,110]],[[13261,13261],"mapped",[107,107]],[[13262,13262],"mapped",[107,109]],[[13263,13263],"mapped",[107,116]],[[13264,13264],"mapped",[108,109]],[[13265,13265],"mapped",[108,110]],[[13266,13266],"mapped",[108,111,103]],[[13267,13267],"mapped",[108,120]],[[13268,13268],"mapped",[109,98]],[[13269,13269],"mapped",[109,105,108]],[[13270,13270],"mapped",[109,111,108]],[[13271,13271],"mapped",[112,104]],[[13272,13272],"disallowed"],[[13273,13273],"mapped",[112,112,109]],[[13274,13274],"mapped",[112,114]],[[13275,13275],"mapped",[115,114]],[[13276,13276],"mapped",[115,118]],[[13277,13277],"mapped",[119,98]],[[13278,13278],"mapped",[118,8725,109]],[[13279,13279],"mapped",[97,8725,109]],[[13280,13280],"mapped",[49,26085]],[[13281,13281],"mapped",[50,26085]],[[13282,13282],"mapped",[51,26085]],[[13283,13283],"mapped",[52,26085]],[[13284,13284],"mapped",[53,26085]],[[13285,13285],"mapped",[54,26085]],[[13286,13286],"mapped",[55,26085]],[[13287,13287],"mapped",[56,26085]],[[13288,13288],"mapped",[57,26085]],[[13289,13289],"mapped",[49,48,26085]],[[13290,13290],"mapped",[49,49,26085]],[[13291,13291],"mapped",[49,50,26085]],[[13292,13292],"mapped",[49,51,26085]],[[13293,13293],"mapped",[49,52,26085]],[[13294,13294],"mapped",[49,53,26085]],[[13295,13295],"mapped",[49,54,26085]],[[13296,13296],"mapped",[49,55,26085]],[[13297,13297],"mapped",[49,56,26085]],[[13298,13298],"mapped",[49,57,26085]],[[13299,13299],"mapped",[50,48,26085]],[[13300,13300],"mapped",[50,49,26085]],[[13301,13301],"mapped",[50,50,26085]],[[13302,13302],"mapped",[50,51,26085]],[[13303,13303],"mapped",[50,52,26085]],[[13304,13304],"mapped",[50,53,26085]],[[13305,13305],"mapped",[50,54,26085]],[[13306,13306],"mapped",[50,55,26085]],[[13307,13307],"mapped",[50,56,26085]],[[13308,13308],"mapped",[50,57,26085]],[[13309,13309],"mapped",[51,48,26085]],[[13310,13310],"mapped",[51,49,26085]],[[13311,13311],"mapped",[103,97,108]],[[13312,19893],"valid"],[[19894,19903],"disallowed"],[[19904,19967],"valid",[],"NV8"],[[19968,40869],"valid"],[[40870,40891],"valid"],[[40892,40899],"valid"],[[40900,40907],"valid"],[[40908,40908],"valid"],[[40909,40917],"valid"],[[40918,40959],"disallowed"],[[40960,42124],"valid"],[[42125,42127],"disallowed"],[[42128,42145],"valid",[],"NV8"],[[42146,42147],"valid",[],"NV8"],[[42148,42163],"valid",[],"NV8"],[[42164,42164],"valid",[],"NV8"],[[42165,42176],"valid",[],"NV8"],[[42177,42177],"valid",[],"NV8"],[[42178,42180],"valid",[],"NV8"],[[42181,42181],"valid",[],"NV8"],[[42182,42182],"valid",[],"NV8"],[[42183,42191],"disallowed"],[[42192,42237],"valid"],[[42238,42239],"valid",[],"NV8"],[[42240,42508],"valid"],[[42509,42511],"valid",[],"NV8"],[[42512,42539],"valid"],[[42540,42559],"disallowed"],[[42560,42560],"mapped",[42561]],[[42561,42561],"valid"],[[42562,42562],"mapped",[42563]],[[42563,42563],"valid"],[[42564,42564],"mapped",[42565]],[[42565,42565],"valid"],[[42566,42566],"mapped",[42567]],[[42567,42567],"valid"],[[42568,42568],"mapped",[42569]],[[42569,42569],"valid"],[[42570,42570],"mapped",[42571]],[[42571,42571],"valid"],[[42572,42572],"mapped",[42573]],[[42573,42573],"valid"],[[42574,42574],"mapped",[42575]],[[42575,42575],"valid"],[[42576,42576],"mapped",[42577]],[[42577,42577],"valid"],[[42578,42578],"mapped",[42579]],[[42579,42579],"valid"],[[42580,42580],"mapped",[42581]],[[42581,42581],"valid"],[[42582,42582],"mapped",[42583]],[[42583,42583],"valid"],[[42584,42584],"mapped",[42585]],[[42585,42585],"valid"],[[42586,42586],"mapped",[42587]],[[42587,42587],"valid"],[[42588,42588],"mapped",[42589]],[[42589,42589],"valid"],[[42590,42590],"mapped",[42591]],[[42591,42591],"valid"],[[42592,42592],"mapped",[42593]],[[42593,42593],"valid"],[[42594,42594],"mapped",[42595]],[[42595,42595],"valid"],[[42596,42596],"mapped",[42597]],[[42597,42597],"valid"],[[42598,42598],"mapped",[42599]],[[42599,42599],"valid"],[[42600,42600],"mapped",[42601]],[[42601,42601],"valid"],[[42602,42602],"mapped",[42603]],[[42603,42603],"valid"],[[42604,42604],"mapped",[42605]],[[42605,42607],"valid"],[[42608,42611],"valid",[],"NV8"],[[42612,42619],"valid"],[[42620,42621],"valid"],[[42622,42622],"valid",[],"NV8"],[[42623,42623],"valid"],[[42624,42624],"mapped",[42625]],[[42625,42625],"valid"],[[42626,42626],"mapped",[42627]],[[42627,42627],"valid"],[[42628,42628],"mapped",[42629]],[[42629,42629],"valid"],[[42630,42630],"mapped",[42631]],[[42631,42631],"valid"],[[42632,42632],"mapped",[42633]],[[42633,42633],"valid"],[[42634,42634],"mapped",[42635]],[[42635,42635],"valid"],[[42636,42636],"mapped",[42637]],[[42637,42637],"valid"],[[42638,42638],"mapped",[42639]],[[42639,42639],"valid"],[[42640,42640],"mapped",[42641]],[[42641,42641],"valid"],[[42642,42642],"mapped",[42643]],[[42643,42643],"valid"],[[42644,42644],"mapped",[42645]],[[42645,42645],"valid"],[[42646,42646],"mapped",[42647]],[[42647,42647],"valid"],[[42648,42648],"mapped",[42649]],[[42649,42649],"valid"],[[42650,42650],"mapped",[42651]],[[42651,42651],"valid"],[[42652,42652],"mapped",[1098]],[[42653,42653],"mapped",[1100]],[[42654,42654],"valid"],[[42655,42655],"valid"],[[42656,42725],"valid"],[[42726,42735],"valid",[],"NV8"],[[42736,42737],"valid"],[[42738,42743],"valid",[],"NV8"],[[42744,42751],"disallowed"],[[42752,42774],"valid",[],"NV8"],[[42775,42778],"valid"],[[42779,42783],"valid"],[[42784,42785],"valid",[],"NV8"],[[42786,42786],"mapped",[42787]],[[42787,42787],"valid"],[[42788,42788],"mapped",[42789]],[[42789,42789],"valid"],[[42790,42790],"mapped",[42791]],[[42791,42791],"valid"],[[42792,42792],"mapped",[42793]],[[42793,42793],"valid"],[[42794,42794],"mapped",[42795]],[[42795,42795],"valid"],[[42796,42796],"mapped",[42797]],[[42797,42797],"valid"],[[42798,42798],"mapped",[42799]],[[42799,42801],"valid"],[[42802,42802],"mapped",[42803]],[[42803,42803],"valid"],[[42804,42804],"mapped",[42805]],[[42805,42805],"valid"],[[42806,42806],"mapped",[42807]],[[42807,42807],"valid"],[[42808,42808],"mapped",[42809]],[[42809,42809],"valid"],[[42810,42810],"mapped",[42811]],[[42811,42811],"valid"],[[42812,42812],"mapped",[42813]],[[42813,42813],"valid"],[[42814,42814],"mapped",[42815]],[[42815,42815],"valid"],[[42816,42816],"mapped",[42817]],[[42817,42817],"valid"],[[42818,42818],"mapped",[42819]],[[42819,42819],"valid"],[[42820,42820],"mapped",[42821]],[[42821,42821],"valid"],[[42822,42822],"mapped",[42823]],[[42823,42823],"valid"],[[42824,42824],"mapped",[42825]],[[42825,42825],"valid"],[[42826,42826],"mapped",[42827]],[[42827,42827],"valid"],[[42828,42828],"mapped",[42829]],[[42829,42829],"valid"],[[42830,42830],"mapped",[42831]],[[42831,42831],"valid"],[[42832,42832],"mapped",[42833]],[[42833,42833],"valid"],[[42834,42834],"mapped",[42835]],[[42835,42835],"valid"],[[42836,42836],"mapped",[42837]],[[42837,42837],"valid"],[[42838,42838],"mapped",[42839]],[[42839,42839],"valid"],[[42840,42840],"mapped",[42841]],[[42841,42841],"valid"],[[42842,42842],"mapped",[42843]],[[42843,42843],"valid"],[[42844,42844],"mapped",[42845]],[[42845,42845],"valid"],[[42846,42846],"mapped",[42847]],[[42847,42847],"valid"],[[42848,42848],"mapped",[42849]],[[42849,42849],"valid"],[[42850,42850],"mapped",[42851]],[[42851,42851],"valid"],[[42852,42852],"mapped",[42853]],[[42853,42853],"valid"],[[42854,42854],"mapped",[42855]],[[42855,42855],"valid"],[[42856,42856],"mapped",[42857]],[[42857,42857],"valid"],[[42858,42858],"mapped",[42859]],[[42859,42859],"valid"],[[42860,42860],"mapped",[42861]],[[42861,42861],"valid"],[[42862,42862],"mapped",[42863]],[[42863,42863],"valid"],[[42864,42864],"mapped",[42863]],[[42865,42872],"valid"],[[42873,42873],"mapped",[42874]],[[42874,42874],"valid"],[[42875,42875],"mapped",[42876]],[[42876,42876],"valid"],[[42877,42877],"mapped",[7545]],[[42878,42878],"mapped",[42879]],[[42879,42879],"valid"],[[42880,42880],"mapped",[42881]],[[42881,42881],"valid"],[[42882,42882],"mapped",[42883]],[[42883,42883],"valid"],[[42884,42884],"mapped",[42885]],[[42885,42885],"valid"],[[42886,42886],"mapped",[42887]],[[42887,42888],"valid"],[[42889,42890],"valid",[],"NV8"],[[42891,42891],"mapped",[42892]],[[42892,42892],"valid"],[[42893,42893],"mapped",[613]],[[42894,42894],"valid"],[[42895,42895],"valid"],[[42896,42896],"mapped",[42897]],[[42897,42897],"valid"],[[42898,42898],"mapped",[42899]],[[42899,42899],"valid"],[[42900,42901],"valid"],[[42902,42902],"mapped",[42903]],[[42903,42903],"valid"],[[42904,42904],"mapped",[42905]],[[42905,42905],"valid"],[[42906,42906],"mapped",[42907]],[[42907,42907],"valid"],[[42908,42908],"mapped",[42909]],[[42909,42909],"valid"],[[42910,42910],"mapped",[42911]],[[42911,42911],"valid"],[[42912,42912],"mapped",[42913]],[[42913,42913],"valid"],[[42914,42914],"mapped",[42915]],[[42915,42915],"valid"],[[42916,42916],"mapped",[42917]],[[42917,42917],"valid"],[[42918,42918],"mapped",[42919]],[[42919,42919],"valid"],[[42920,42920],"mapped",[42921]],[[42921,42921],"valid"],[[42922,42922],"mapped",[614]],[[42923,42923],"mapped",[604]],[[42924,42924],"mapped",[609]],[[42925,42925],"mapped",[620]],[[42926,42927],"disallowed"],[[42928,42928],"mapped",[670]],[[42929,42929],"mapped",[647]],[[42930,42930],"mapped",[669]],[[42931,42931],"mapped",[43859]],[[42932,42932],"mapped",[42933]],[[42933,42933],"valid"],[[42934,42934],"mapped",[42935]],[[42935,42935],"valid"],[[42936,42998],"disallowed"],[[42999,42999],"valid"],[[43000,43000],"mapped",[295]],[[43001,43001],"mapped",[339]],[[43002,43002],"valid"],[[43003,43007],"valid"],[[43008,43047],"valid"],[[43048,43051],"valid",[],"NV8"],[[43052,43055],"disallowed"],[[43056,43065],"valid",[],"NV8"],[[43066,43071],"disallowed"],[[43072,43123],"valid"],[[43124,43127],"valid",[],"NV8"],[[43128,43135],"disallowed"],[[43136,43204],"valid"],[[43205,43213],"disallowed"],[[43214,43215],"valid",[],"NV8"],[[43216,43225],"valid"],[[43226,43231],"disallowed"],[[43232,43255],"valid"],[[43256,43258],"valid",[],"NV8"],[[43259,43259],"valid"],[[43260,43260],"valid",[],"NV8"],[[43261,43261],"valid"],[[43262,43263],"disallowed"],[[43264,43309],"valid"],[[43310,43311],"valid",[],"NV8"],[[43312,43347],"valid"],[[43348,43358],"disallowed"],[[43359,43359],"valid",[],"NV8"],[[43360,43388],"valid",[],"NV8"],[[43389,43391],"disallowed"],[[43392,43456],"valid"],[[43457,43469],"valid",[],"NV8"],[[43470,43470],"disallowed"],[[43471,43481],"valid"],[[43482,43485],"disallowed"],[[43486,43487],"valid",[],"NV8"],[[43488,43518],"valid"],[[43519,43519],"disallowed"],[[43520,43574],"valid"],[[43575,43583],"disallowed"],[[43584,43597],"valid"],[[43598,43599],"disallowed"],[[43600,43609],"valid"],[[43610,43611],"disallowed"],[[43612,43615],"valid",[],"NV8"],[[43616,43638],"valid"],[[43639,43641],"valid",[],"NV8"],[[43642,43643],"valid"],[[43644,43647],"valid"],[[43648,43714],"valid"],[[43715,43738],"disallowed"],[[43739,43741],"valid"],[[43742,43743],"valid",[],"NV8"],[[43744,43759],"valid"],[[43760,43761],"valid",[],"NV8"],[[43762,43766],"valid"],[[43767,43776],"disallowed"],[[43777,43782],"valid"],[[43783,43784],"disallowed"],[[43785,43790],"valid"],[[43791,43792],"disallowed"],[[43793,43798],"valid"],[[43799,43807],"disallowed"],[[43808,43814],"valid"],[[43815,43815],"disallowed"],[[43816,43822],"valid"],[[43823,43823],"disallowed"],[[43824,43866],"valid"],[[43867,43867],"valid",[],"NV8"],[[43868,43868],"mapped",[42791]],[[43869,43869],"mapped",[43831]],[[43870,43870],"mapped",[619]],[[43871,43871],"mapped",[43858]],[[43872,43875],"valid"],[[43876,43877],"valid"],[[43878,43887],"disallowed"],[[43888,43888],"mapped",[5024]],[[43889,43889],"mapped",[5025]],[[43890,43890],"mapped",[5026]],[[43891,43891],"mapped",[5027]],[[43892,43892],"mapped",[5028]],[[43893,43893],"mapped",[5029]],[[43894,43894],"mapped",[5030]],[[43895,43895],"mapped",[5031]],[[43896,43896],"mapped",[5032]],[[43897,43897],"mapped",[5033]],[[43898,43898],"mapped",[5034]],[[43899,43899],"mapped",[5035]],[[43900,43900],"mapped",[5036]],[[43901,43901],"mapped",[5037]],[[43902,43902],"mapped",[5038]],[[43903,43903],"mapped",[5039]],[[43904,43904],"mapped",[5040]],[[43905,43905],"mapped",[5041]],[[43906,43906],"mapped",[5042]],[[43907,43907],"mapped",[5043]],[[43908,43908],"mapped",[5044]],[[43909,43909],"mapped",[5045]],[[43910,43910],"mapped",[5046]],[[43911,43911],"mapped",[5047]],[[43912,43912],"mapped",[5048]],[[43913,43913],"mapped",[5049]],[[43914,43914],"mapped",[5050]],[[43915,43915],"mapped",[5051]],[[43916,43916],"mapped",[5052]],[[43917,43917],"mapped",[5053]],[[43918,43918],"mapped",[5054]],[[43919,43919],"mapped",[5055]],[[43920,43920],"mapped",[5056]],[[43921,43921],"mapped",[5057]],[[43922,43922],"mapped",[5058]],[[43923,43923],"mapped",[5059]],[[43924,43924],"mapped",[5060]],[[43925,43925],"mapped",[5061]],[[43926,43926],"mapped",[5062]],[[43927,43927],"mapped",[5063]],[[43928,43928],"mapped",[5064]],[[43929,43929],"mapped",[5065]],[[43930,43930],"mapped",[5066]],[[43931,43931],"mapped",[5067]],[[43932,43932],"mapped",[5068]],[[43933,43933],"mapped",[5069]],[[43934,43934],"mapped",[5070]],[[43935,43935],"mapped",[5071]],[[43936,43936],"mapped",[5072]],[[43937,43937],"mapped",[5073]],[[43938,43938],"mapped",[5074]],[[43939,43939],"mapped",[5075]],[[43940,43940],"mapped",[5076]],[[43941,43941],"mapped",[5077]],[[43942,43942],"mapped",[5078]],[[43943,43943],"mapped",[5079]],[[43944,43944],"mapped",[5080]],[[43945,43945],"mapped",[5081]],[[43946,43946],"mapped",[5082]],[[43947,43947],"mapped",[5083]],[[43948,43948],"mapped",[5084]],[[43949,43949],"mapped",[5085]],[[43950,43950],"mapped",[5086]],[[43951,43951],"mapped",[5087]],[[43952,43952],"mapped",[5088]],[[43953,43953],"mapped",[5089]],[[43954,43954],"mapped",[5090]],[[43955,43955],"mapped",[5091]],[[43956,43956],"mapped",[5092]],[[43957,43957],"mapped",[5093]],[[43958,43958],"mapped",[5094]],[[43959,43959],"mapped",[5095]],[[43960,43960],"mapped",[5096]],[[43961,43961],"mapped",[5097]],[[43962,43962],"mapped",[5098]],[[43963,43963],"mapped",[5099]],[[43964,43964],"mapped",[5100]],[[43965,43965],"mapped",[5101]],[[43966,43966],"mapped",[5102]],[[43967,43967],"mapped",[5103]],[[43968,44010],"valid"],[[44011,44011],"valid",[],"NV8"],[[44012,44013],"valid"],[[44014,44015],"disallowed"],[[44016,44025],"valid"],[[44026,44031],"disallowed"],[[44032,55203],"valid"],[[55204,55215],"disallowed"],[[55216,55238],"valid",[],"NV8"],[[55239,55242],"disallowed"],[[55243,55291],"valid",[],"NV8"],[[55292,55295],"disallowed"],[[55296,57343],"disallowed"],[[57344,63743],"disallowed"],[[63744,63744],"mapped",[35912]],[[63745,63745],"mapped",[26356]],[[63746,63746],"mapped",[36554]],[[63747,63747],"mapped",[36040]],[[63748,63748],"mapped",[28369]],[[63749,63749],"mapped",[20018]],[[63750,63750],"mapped",[21477]],[[63751,63752],"mapped",[40860]],[[63753,63753],"mapped",[22865]],[[63754,63754],"mapped",[37329]],[[63755,63755],"mapped",[21895]],[[63756,63756],"mapped",[22856]],[[63757,63757],"mapped",[25078]],[[63758,63758],"mapped",[30313]],[[63759,63759],"mapped",[32645]],[[63760,63760],"mapped",[34367]],[[63761,63761],"mapped",[34746]],[[63762,63762],"mapped",[35064]],[[63763,63763],"mapped",[37007]],[[63764,63764],"mapped",[27138]],[[63765,63765],"mapped",[27931]],[[63766,63766],"mapped",[28889]],[[63767,63767],"mapped",[29662]],[[63768,63768],"mapped",[33853]],[[63769,63769],"mapped",[37226]],[[63770,63770],"mapped",[39409]],[[63771,63771],"mapped",[20098]],[[63772,63772],"mapped",[21365]],[[63773,63773],"mapped",[27396]],[[63774,63774],"mapped",[29211]],[[63775,63775],"mapped",[34349]],[[63776,63776],"mapped",[40478]],[[63777,63777],"mapped",[23888]],[[63778,63778],"mapped",[28651]],[[63779,63779],"mapped",[34253]],[[63780,63780],"mapped",[35172]],[[63781,63781],"mapped",[25289]],[[63782,63782],"mapped",[33240]],[[63783,63783],"mapped",[34847]],[[63784,63784],"mapped",[24266]],[[63785,63785],"mapped",[26391]],[[63786,63786],"mapped",[28010]],[[63787,63787],"mapped",[29436]],[[63788,63788],"mapped",[37070]],[[63789,63789],"mapped",[20358]],[[63790,63790],"mapped",[20919]],[[63791,63791],"mapped",[21214]],[[63792,63792],"mapped",[25796]],[[63793,63793],"mapped",[27347]],[[63794,63794],"mapped",[29200]],[[63795,63795],"mapped",[30439]],[[63796,63796],"mapped",[32769]],[[63797,63797],"mapped",[34310]],[[63798,63798],"mapped",[34396]],[[63799,63799],"mapped",[36335]],[[63800,63800],"mapped",[38706]],[[63801,63801],"mapped",[39791]],[[63802,63802],"mapped",[40442]],[[63803,63803],"mapped",[30860]],[[63804,63804],"mapped",[31103]],[[63805,63805],"mapped",[32160]],[[63806,63806],"mapped",[33737]],[[63807,63807],"mapped",[37636]],[[63808,63808],"mapped",[40575]],[[63809,63809],"mapped",[35542]],[[63810,63810],"mapped",[22751]],[[63811,63811],"mapped",[24324]],[[63812,63812],"mapped",[31840]],[[63813,63813],"mapped",[32894]],[[63814,63814],"mapped",[29282]],[[63815,63815],"mapped",[30922]],[[63816,63816],"mapped",[36034]],[[63817,63817],"mapped",[38647]],[[63818,63818],"mapped",[22744]],[[63819,63819],"mapped",[23650]],[[63820,63820],"mapped",[27155]],[[63821,63821],"mapped",[28122]],[[63822,63822],"mapped",[28431]],[[63823,63823],"mapped",[32047]],[[63824,63824],"mapped",[32311]],[[63825,63825],"mapped",[38475]],[[63826,63826],"mapped",[21202]],[[63827,63827],"mapped",[32907]],[[63828,63828],"mapped",[20956]],[[63829,63829],"mapped",[20940]],[[63830,63830],"mapped",[31260]],[[63831,63831],"mapped",[32190]],[[63832,63832],"mapped",[33777]],[[63833,63833],"mapped",[38517]],[[63834,63834],"mapped",[35712]],[[63835,63835],"mapped",[25295]],[[63836,63836],"mapped",[27138]],[[63837,63837],"mapped",[35582]],[[63838,63838],"mapped",[20025]],[[63839,63839],"mapped",[23527]],[[63840,63840],"mapped",[24594]],[[63841,63841],"mapped",[29575]],[[63842,63842],"mapped",[30064]],[[63843,63843],"mapped",[21271]],[[63844,63844],"mapped",[30971]],[[63845,63845],"mapped",[20415]],[[63846,63846],"mapped",[24489]],[[63847,63847],"mapped",[19981]],[[63848,63848],"mapped",[27852]],[[63849,63849],"mapped",[25976]],[[63850,63850],"mapped",[32034]],[[63851,63851],"mapped",[21443]],[[63852,63852],"mapped",[22622]],[[63853,63853],"mapped",[30465]],[[63854,63854],"mapped",[33865]],[[63855,63855],"mapped",[35498]],[[63856,63856],"mapped",[27578]],[[63857,63857],"mapped",[36784]],[[63858,63858],"mapped",[27784]],[[63859,63859],"mapped",[25342]],[[63860,63860],"mapped",[33509]],[[63861,63861],"mapped",[25504]],[[63862,63862],"mapped",[30053]],[[63863,63863],"mapped",[20142]],[[63864,63864],"mapped",[20841]],[[63865,63865],"mapped",[20937]],[[63866,63866],"mapped",[26753]],[[63867,63867],"mapped",[31975]],[[63868,63868],"mapped",[33391]],[[63869,63869],"mapped",[35538]],[[63870,63870],"mapped",[37327]],[[63871,63871],"mapped",[21237]],[[63872,63872],"mapped",[21570]],[[63873,63873],"mapped",[22899]],[[63874,63874],"mapped",[24300]],[[63875,63875],"mapped",[26053]],[[63876,63876],"mapped",[28670]],[[63877,63877],"mapped",[31018]],[[63878,63878],"mapped",[38317]],[[63879,63879],"mapped",[39530]],[[63880,63880],"mapped",[40599]],[[63881,63881],"mapped",[40654]],[[63882,63882],"mapped",[21147]],[[63883,63883],"mapped",[26310]],[[63884,63884],"mapped",[27511]],[[63885,63885],"mapped",[36706]],[[63886,63886],"mapped",[24180]],[[63887,63887],"mapped",[24976]],[[63888,63888],"mapped",[25088]],[[63889,63889],"mapped",[25754]],[[63890,63890],"mapped",[28451]],[[63891,63891],"mapped",[29001]],[[63892,63892],"mapped",[29833]],[[63893,63893],"mapped",[31178]],[[63894,63894],"mapped",[32244]],[[63895,63895],"mapped",[32879]],[[63896,63896],"mapped",[36646]],[[63897,63897],"mapped",[34030]],[[63898,63898],"mapped",[36899]],[[63899,63899],"mapped",[37706]],[[63900,63900],"mapped",[21015]],[[63901,63901],"mapped",[21155]],[[63902,63902],"mapped",[21693]],[[63903,63903],"mapped",[28872]],[[63904,63904],"mapped",[35010]],[[63905,63905],"mapped",[35498]],[[63906,63906],"mapped",[24265]],[[63907,63907],"mapped",[24565]],[[63908,63908],"mapped",[25467]],[[63909,63909],"mapped",[27566]],[[63910,63910],"mapped",[31806]],[[63911,63911],"mapped",[29557]],[[63912,63912],"mapped",[20196]],[[63913,63913],"mapped",[22265]],[[63914,63914],"mapped",[23527]],[[63915,63915],"mapped",[23994]],[[63916,63916],"mapped",[24604]],[[63917,63917],"mapped",[29618]],[[63918,63918],"mapped",[29801]],[[63919,63919],"mapped",[32666]],[[63920,63920],"mapped",[32838]],[[63921,63921],"mapped",[37428]],[[63922,63922],"mapped",[38646]],[[63923,63923],"mapped",[38728]],[[63924,63924],"mapped",[38936]],[[63925,63925],"mapped",[20363]],[[63926,63926],"mapped",[31150]],[[63927,63927],"mapped",[37300]],[[63928,63928],"mapped",[38584]],[[63929,63929],"mapped",[24801]],[[63930,63930],"mapped",[20102]],[[63931,63931],"mapped",[20698]],[[63932,63932],"mapped",[23534]],[[63933,63933],"mapped",[23615]],[[63934,63934],"mapped",[26009]],[[63935,63935],"mapped",[27138]],[[63936,63936],"mapped",[29134]],[[63937,63937],"mapped",[30274]],[[63938,63938],"mapped",[34044]],[[63939,63939],"mapped",[36988]],[[63940,63940],"mapped",[40845]],[[63941,63941],"mapped",[26248]],[[63942,63942],"mapped",[38446]],[[63943,63943],"mapped",[21129]],[[63944,63944],"mapped",[26491]],[[63945,63945],"mapped",[26611]],[[63946,63946],"mapped",[27969]],[[63947,63947],"mapped",[28316]],[[63948,63948],"mapped",[29705]],[[63949,63949],"mapped",[30041]],[[63950,63950],"mapped",[30827]],[[63951,63951],"mapped",[32016]],[[63952,63952],"mapped",[39006]],[[63953,63953],"mapped",[20845]],[[63954,63954],"mapped",[25134]],[[63955,63955],"mapped",[38520]],[[63956,63956],"mapped",[20523]],[[63957,63957],"mapped",[23833]],[[63958,63958],"mapped",[28138]],[[63959,63959],"mapped",[36650]],[[63960,63960],"mapped",[24459]],[[63961,63961],"mapped",[24900]],[[63962,63962],"mapped",[26647]],[[63963,63963],"mapped",[29575]],[[63964,63964],"mapped",[38534]],[[63965,63965],"mapped",[21033]],[[63966,63966],"mapped",[21519]],[[63967,63967],"mapped",[23653]],[[63968,63968],"mapped",[26131]],[[63969,63969],"mapped",[26446]],[[63970,63970],"mapped",[26792]],[[63971,63971],"mapped",[27877]],[[63972,63972],"mapped",[29702]],[[63973,63973],"mapped",[30178]],[[63974,63974],"mapped",[32633]],[[63975,63975],"mapped",[35023]],[[63976,63976],"mapped",[35041]],[[63977,63977],"mapped",[37324]],[[63978,63978],"mapped",[38626]],[[63979,63979],"mapped",[21311]],[[63980,63980],"mapped",[28346]],[[63981,63981],"mapped",[21533]],[[63982,63982],"mapped",[29136]],[[63983,63983],"mapped",[29848]],[[63984,63984],"mapped",[34298]],[[63985,63985],"mapped",[38563]],[[63986,63986],"mapped",[40023]],[[63987,63987],"mapped",[40607]],[[63988,63988],"mapped",[26519]],[[63989,63989],"mapped",[28107]],[[63990,63990],"mapped",[33256]],[[63991,63991],"mapped",[31435]],[[63992,63992],"mapped",[31520]],[[63993,63993],"mapped",[31890]],[[63994,63994],"mapped",[29376]],[[63995,63995],"mapped",[28825]],[[63996,63996],"mapped",[35672]],[[63997,63997],"mapped",[20160]],[[63998,63998],"mapped",[33590]],[[63999,63999],"mapped",[21050]],[[64000,64000],"mapped",[20999]],[[64001,64001],"mapped",[24230]],[[64002,64002],"mapped",[25299]],[[64003,64003],"mapped",[31958]],[[64004,64004],"mapped",[23429]],[[64005,64005],"mapped",[27934]],[[64006,64006],"mapped",[26292]],[[64007,64007],"mapped",[36667]],[[64008,64008],"mapped",[34892]],[[64009,64009],"mapped",[38477]],[[64010,64010],"mapped",[35211]],[[64011,64011],"mapped",[24275]],[[64012,64012],"mapped",[20800]],[[64013,64013],"mapped",[21952]],[[64014,64015],"valid"],[[64016,64016],"mapped",[22618]],[[64017,64017],"valid"],[[64018,64018],"mapped",[26228]],[[64019,64020],"valid"],[[64021,64021],"mapped",[20958]],[[64022,64022],"mapped",[29482]],[[64023,64023],"mapped",[30410]],[[64024,64024],"mapped",[31036]],[[64025,64025],"mapped",[31070]],[[64026,64026],"mapped",[31077]],[[64027,64027],"mapped",[31119]],[[64028,64028],"mapped",[38742]],[[64029,64029],"mapped",[31934]],[[64030,64030],"mapped",[32701]],[[64031,64031],"valid"],[[64032,64032],"mapped",[34322]],[[64033,64033],"valid"],[[64034,64034],"mapped",[35576]],[[64035,64036],"valid"],[[64037,64037],"mapped",[36920]],[[64038,64038],"mapped",[37117]],[[64039,64041],"valid"],[[64042,64042],"mapped",[39151]],[[64043,64043],"mapped",[39164]],[[64044,64044],"mapped",[39208]],[[64045,64045],"mapped",[40372]],[[64046,64046],"mapped",[37086]],[[64047,64047],"mapped",[38583]],[[64048,64048],"mapped",[20398]],[[64049,64049],"mapped",[20711]],[[64050,64050],"mapped",[20813]],[[64051,64051],"mapped",[21193]],[[64052,64052],"mapped",[21220]],[[64053,64053],"mapped",[21329]],[[64054,64054],"mapped",[21917]],[[64055,64055],"mapped",[22022]],[[64056,64056],"mapped",[22120]],[[64057,64057],"mapped",[22592]],[[64058,64058],"mapped",[22696]],[[64059,64059],"mapped",[23652]],[[64060,64060],"mapped",[23662]],[[64061,64061],"mapped",[24724]],[[64062,64062],"mapped",[24936]],[[64063,64063],"mapped",[24974]],[[64064,64064],"mapped",[25074]],[[64065,64065],"mapped",[25935]],[[64066,64066],"mapped",[26082]],[[64067,64067],"mapped",[26257]],[[64068,64068],"mapped",[26757]],[[64069,64069],"mapped",[28023]],[[64070,64070],"mapped",[28186]],[[64071,64071],"mapped",[28450]],[[64072,64072],"mapped",[29038]],[[64073,64073],"mapped",[29227]],[[64074,64074],"mapped",[29730]],[[64075,64075],"mapped",[30865]],[[64076,64076],"mapped",[31038]],[[64077,64077],"mapped",[31049]],[[64078,64078],"mapped",[31048]],[[64079,64079],"mapped",[31056]],[[64080,64080],"mapped",[31062]],[[64081,64081],"mapped",[31069]],[[64082,64082],"mapped",[31117]],[[64083,64083],"mapped",[31118]],[[64084,64084],"mapped",[31296]],[[64085,64085],"mapped",[31361]],[[64086,64086],"mapped",[31680]],[[64087,64087],"mapped",[32244]],[[64088,64088],"mapped",[32265]],[[64089,64089],"mapped",[32321]],[[64090,64090],"mapped",[32626]],[[64091,64091],"mapped",[32773]],[[64092,64092],"mapped",[33261]],[[64093,64094],"mapped",[33401]],[[64095,64095],"mapped",[33879]],[[64096,64096],"mapped",[35088]],[[64097,64097],"mapped",[35222]],[[64098,64098],"mapped",[35585]],[[64099,64099],"mapped",[35641]],[[64100,64100],"mapped",[36051]],[[64101,64101],"mapped",[36104]],[[64102,64102],"mapped",[36790]],[[64103,64103],"mapped",[36920]],[[64104,64104],"mapped",[38627]],[[64105,64105],"mapped",[38911]],[[64106,64106],"mapped",[38971]],[[64107,64107],"mapped",[24693]],[[64108,64108],"mapped",[148206]],[[64109,64109],"mapped",[33304]],[[64110,64111],"disallowed"],[[64112,64112],"mapped",[20006]],[[64113,64113],"mapped",[20917]],[[64114,64114],"mapped",[20840]],[[64115,64115],"mapped",[20352]],[[64116,64116],"mapped",[20805]],[[64117,64117],"mapped",[20864]],[[64118,64118],"mapped",[21191]],[[64119,64119],"mapped",[21242]],[[64120,64120],"mapped",[21917]],[[64121,64121],"mapped",[21845]],[[64122,64122],"mapped",[21913]],[[64123,64123],"mapped",[21986]],[[64124,64124],"mapped",[22618]],[[64125,64125],"mapped",[22707]],[[64126,64126],"mapped",[22852]],[[64127,64127],"mapped",[22868]],[[64128,64128],"mapped",[23138]],[[64129,64129],"mapped",[23336]],[[64130,64130],"mapped",[24274]],[[64131,64131],"mapped",[24281]],[[64132,64132],"mapped",[24425]],[[64133,64133],"mapped",[24493]],[[64134,64134],"mapped",[24792]],[[64135,64135],"mapped",[24910]],[[64136,64136],"mapped",[24840]],[[64137,64137],"mapped",[24974]],[[64138,64138],"mapped",[24928]],[[64139,64139],"mapped",[25074]],[[64140,64140],"mapped",[25140]],[[64141,64141],"mapped",[25540]],[[64142,64142],"mapped",[25628]],[[64143,64143],"mapped",[25682]],[[64144,64144],"mapped",[25942]],[[64145,64145],"mapped",[26228]],[[64146,64146],"mapped",[26391]],[[64147,64147],"mapped",[26395]],[[64148,64148],"mapped",[26454]],[[64149,64149],"mapped",[27513]],[[64150,64150],"mapped",[27578]],[[64151,64151],"mapped",[27969]],[[64152,64152],"mapped",[28379]],[[64153,64153],"mapped",[28363]],[[64154,64154],"mapped",[28450]],[[64155,64155],"mapped",[28702]],[[64156,64156],"mapped",[29038]],[[64157,64157],"mapped",[30631]],[[64158,64158],"mapped",[29237]],[[64159,64159],"mapped",[29359]],[[64160,64160],"mapped",[29482]],[[64161,64161],"mapped",[29809]],[[64162,64162],"mapped",[29958]],[[64163,64163],"mapped",[30011]],[[64164,64164],"mapped",[30237]],[[64165,64165],"mapped",[30239]],[[64166,64166],"mapped",[30410]],[[64167,64167],"mapped",[30427]],[[64168,64168],"mapped",[30452]],[[64169,64169],"mapped",[30538]],[[64170,64170],"mapped",[30528]],[[64171,64171],"mapped",[30924]],[[64172,64172],"mapped",[31409]],[[64173,64173],"mapped",[31680]],[[64174,64174],"mapped",[31867]],[[64175,64175],"mapped",[32091]],[[64176,64176],"mapped",[32244]],[[64177,64177],"mapped",[32574]],[[64178,64178],"mapped",[32773]],[[64179,64179],"mapped",[33618]],[[64180,64180],"mapped",[33775]],[[64181,64181],"mapped",[34681]],[[64182,64182],"mapped",[35137]],[[64183,64183],"mapped",[35206]],[[64184,64184],"mapped",[35222]],[[64185,64185],"mapped",[35519]],[[64186,64186],"mapped",[35576]],[[64187,64187],"mapped",[35531]],[[64188,64188],"mapped",[35585]],[[64189,64189],"mapped",[35582]],[[64190,64190],"mapped",[35565]],[[64191,64191],"mapped",[35641]],[[64192,64192],"mapped",[35722]],[[64193,64193],"mapped",[36104]],[[64194,64194],"mapped",[36664]],[[64195,64195],"mapped",[36978]],[[64196,64196],"mapped",[37273]],[[64197,64197],"mapped",[37494]],[[64198,64198],"mapped",[38524]],[[64199,64199],"mapped",[38627]],[[64200,64200],"mapped",[38742]],[[64201,64201],"mapped",[38875]],[[64202,64202],"mapped",[38911]],[[64203,64203],"mapped",[38923]],[[64204,64204],"mapped",[38971]],[[64205,64205],"mapped",[39698]],[[64206,64206],"mapped",[40860]],[[64207,64207],"mapped",[141386]],[[64208,64208],"mapped",[141380]],[[64209,64209],"mapped",[144341]],[[64210,64210],"mapped",[15261]],[[64211,64211],"mapped",[16408]],[[64212,64212],"mapped",[16441]],[[64213,64213],"mapped",[152137]],[[64214,64214],"mapped",[154832]],[[64215,64215],"mapped",[163539]],[[64216,64216],"mapped",[40771]],[[64217,64217],"mapped",[40846]],[[64218,64255],"disallowed"],[[64256,64256],"mapped",[102,102]],[[64257,64257],"mapped",[102,105]],[[64258,64258],"mapped",[102,108]],[[64259,64259],"mapped",[102,102,105]],[[64260,64260],"mapped",[102,102,108]],[[64261,64262],"mapped",[115,116]],[[64263,64274],"disallowed"],[[64275,64275],"mapped",[1396,1398]],[[64276,64276],"mapped",[1396,1381]],[[64277,64277],"mapped",[1396,1387]],[[64278,64278],"mapped",[1406,1398]],[[64279,64279],"mapped",[1396,1389]],[[64280,64284],"disallowed"],[[64285,64285],"mapped",[1497,1460]],[[64286,64286],"valid"],[[64287,64287],"mapped",[1522,1463]],[[64288,64288],"mapped",[1506]],[[64289,64289],"mapped",[1488]],[[64290,64290],"mapped",[1491]],[[64291,64291],"mapped",[1492]],[[64292,64292],"mapped",[1499]],[[64293,64293],"mapped",[1500]],[[64294,64294],"mapped",[1501]],[[64295,64295],"mapped",[1512]],[[64296,64296],"mapped",[1514]],[[64297,64297],"disallowed_STD3_mapped",[43]],[[64298,64298],"mapped",[1513,1473]],[[64299,64299],"mapped",[1513,1474]],[[64300,64300],"mapped",[1513,1468,1473]],[[64301,64301],"mapped",[1513,1468,1474]],[[64302,64302],"mapped",[1488,1463]],[[64303,64303],"mapped",[1488,1464]],[[64304,64304],"mapped",[1488,1468]],[[64305,64305],"mapped",[1489,1468]],[[64306,64306],"mapped",[1490,1468]],[[64307,64307],"mapped",[1491,1468]],[[64308,64308],"mapped",[1492,1468]],[[64309,64309],"mapped",[1493,1468]],[[64310,64310],"mapped",[1494,1468]],[[64311,64311],"disallowed"],[[64312,64312],"mapped",[1496,1468]],[[64313,64313],"mapped",[1497,1468]],[[64314,64314],"mapped",[1498,1468]],[[64315,64315],"mapped",[1499,1468]],[[64316,64316],"mapped",[1500,1468]],[[64317,64317],"disallowed"],[[64318,64318],"mapped",[1502,1468]],[[64319,64319],"disallowed"],[[64320,64320],"mapped",[1504,1468]],[[64321,64321],"mapped",[1505,1468]],[[64322,64322],"disallowed"],[[64323,64323],"mapped",[1507,1468]],[[64324,64324],"mapped",[1508,1468]],[[64325,64325],"disallowed"],[[64326,64326],"mapped",[1510,1468]],[[64327,64327],"mapped",[1511,1468]],[[64328,64328],"mapped",[1512,1468]],[[64329,64329],"mapped",[1513,1468]],[[64330,64330],"mapped",[1514,1468]],[[64331,64331],"mapped",[1493,1465]],[[64332,64332],"mapped",[1489,1471]],[[64333,64333],"mapped",[1499,1471]],[[64334,64334],"mapped",[1508,1471]],[[64335,64335],"mapped",[1488,1500]],[[64336,64337],"mapped",[1649]],[[64338,64341],"mapped",[1659]],[[64342,64345],"mapped",[1662]],[[64346,64349],"mapped",[1664]],[[64350,64353],"mapped",[1658]],[[64354,64357],"mapped",[1663]],[[64358,64361],"mapped",[1657]],[[64362,64365],"mapped",[1700]],[[64366,64369],"mapped",[1702]],[[64370,64373],"mapped",[1668]],[[64374,64377],"mapped",[1667]],[[64378,64381],"mapped",[1670]],[[64382,64385],"mapped",[1671]],[[64386,64387],"mapped",[1677]],[[64388,64389],"mapped",[1676]],[[64390,64391],"mapped",[1678]],[[64392,64393],"mapped",[1672]],[[64394,64395],"mapped",[1688]],[[64396,64397],"mapped",[1681]],[[64398,64401],"mapped",[1705]],[[64402,64405],"mapped",[1711]],[[64406,64409],"mapped",[1715]],[[64410,64413],"mapped",[1713]],[[64414,64415],"mapped",[1722]],[[64416,64419],"mapped",[1723]],[[64420,64421],"mapped",[1728]],[[64422,64425],"mapped",[1729]],[[64426,64429],"mapped",[1726]],[[64430,64431],"mapped",[1746]],[[64432,64433],"mapped",[1747]],[[64434,64449],"valid",[],"NV8"],[[64450,64466],"disallowed"],[[64467,64470],"mapped",[1709]],[[64471,64472],"mapped",[1735]],[[64473,64474],"mapped",[1734]],[[64475,64476],"mapped",[1736]],[[64477,64477],"mapped",[1735,1652]],[[64478,64479],"mapped",[1739]],[[64480,64481],"mapped",[1733]],[[64482,64483],"mapped",[1737]],[[64484,64487],"mapped",[1744]],[[64488,64489],"mapped",[1609]],[[64490,64491],"mapped",[1574,1575]],[[64492,64493],"mapped",[1574,1749]],[[64494,64495],"mapped",[1574,1608]],[[64496,64497],"mapped",[1574,1735]],[[64498,64499],"mapped",[1574,1734]],[[64500,64501],"mapped",[1574,1736]],[[64502,64504],"mapped",[1574,1744]],[[64505,64507],"mapped",[1574,1609]],[[64508,64511],"mapped",[1740]],[[64512,64512],"mapped",[1574,1580]],[[64513,64513],"mapped",[1574,1581]],[[64514,64514],"mapped",[1574,1605]],[[64515,64515],"mapped",[1574,1609]],[[64516,64516],"mapped",[1574,1610]],[[64517,64517],"mapped",[1576,1580]],[[64518,64518],"mapped",[1576,1581]],[[64519,64519],"mapped",[1576,1582]],[[64520,64520],"mapped",[1576,1605]],[[64521,64521],"mapped",[1576,1609]],[[64522,64522],"mapped",[1576,1610]],[[64523,64523],"mapped",[1578,1580]],[[64524,64524],"mapped",[1578,1581]],[[64525,64525],"mapped",[1578,1582]],[[64526,64526],"mapped",[1578,1605]],[[64527,64527],"mapped",[1578,1609]],[[64528,64528],"mapped",[1578,1610]],[[64529,64529],"mapped",[1579,1580]],[[64530,64530],"mapped",[1579,1605]],[[64531,64531],"mapped",[1579,1609]],[[64532,64532],"mapped",[1579,1610]],[[64533,64533],"mapped",[1580,1581]],[[64534,64534],"mapped",[1580,1605]],[[64535,64535],"mapped",[1581,1580]],[[64536,64536],"mapped",[1581,1605]],[[64537,64537],"mapped",[1582,1580]],[[64538,64538],"mapped",[1582,1581]],[[64539,64539],"mapped",[1582,1605]],[[64540,64540],"mapped",[1587,1580]],[[64541,64541],"mapped",[1587,1581]],[[64542,64542],"mapped",[1587,1582]],[[64543,64543],"mapped",[1587,1605]],[[64544,64544],"mapped",[1589,1581]],[[64545,64545],"mapped",[1589,1605]],[[64546,64546],"mapped",[1590,1580]],[[64547,64547],"mapped",[1590,1581]],[[64548,64548],"mapped",[1590,1582]],[[64549,64549],"mapped",[1590,1605]],[[64550,64550],"mapped",[1591,1581]],[[64551,64551],"mapped",[1591,1605]],[[64552,64552],"mapped",[1592,1605]],[[64553,64553],"mapped",[1593,1580]],[[64554,64554],"mapped",[1593,1605]],[[64555,64555],"mapped",[1594,1580]],[[64556,64556],"mapped",[1594,1605]],[[64557,64557],"mapped",[1601,1580]],[[64558,64558],"mapped",[1601,1581]],[[64559,64559],"mapped",[1601,1582]],[[64560,64560],"mapped",[1601,1605]],[[64561,64561],"mapped",[1601,1609]],[[64562,64562],"mapped",[1601,1610]],[[64563,64563],"mapped",[1602,1581]],[[64564,64564],"mapped",[1602,1605]],[[64565,64565],"mapped",[1602,1609]],[[64566,64566],"mapped",[1602,1610]],[[64567,64567],"mapped",[1603,1575]],[[64568,64568],"mapped",[1603,1580]],[[64569,64569],"mapped",[1603,1581]],[[64570,64570],"mapped",[1603,1582]],[[64571,64571],"mapped",[1603,1604]],[[64572,64572],"mapped",[1603,1605]],[[64573,64573],"mapped",[1603,1609]],[[64574,64574],"mapped",[1603,1610]],[[64575,64575],"mapped",[1604,1580]],[[64576,64576],"mapped",[1604,1581]],[[64577,64577],"mapped",[1604,1582]],[[64578,64578],"mapped",[1604,1605]],[[64579,64579],"mapped",[1604,1609]],[[64580,64580],"mapped",[1604,1610]],[[64581,64581],"mapped",[1605,1580]],[[64582,64582],"mapped",[1605,1581]],[[64583,64583],"mapped",[1605,1582]],[[64584,64584],"mapped",[1605,1605]],[[64585,64585],"mapped",[1605,1609]],[[64586,64586],"mapped",[1605,1610]],[[64587,64587],"mapped",[1606,1580]],[[64588,64588],"mapped",[1606,1581]],[[64589,64589],"mapped",[1606,1582]],[[64590,64590],"mapped",[1606,1605]],[[64591,64591],"mapped",[1606,1609]],[[64592,64592],"mapped",[1606,1610]],[[64593,64593],"mapped",[1607,1580]],[[64594,64594],"mapped",[1607,1605]],[[64595,64595],"mapped",[1607,1609]],[[64596,64596],"mapped",[1607,1610]],[[64597,64597],"mapped",[1610,1580]],[[64598,64598],"mapped",[1610,1581]],[[64599,64599],"mapped",[1610,1582]],[[64600,64600],"mapped",[1610,1605]],[[64601,64601],"mapped",[1610,1609]],[[64602,64602],"mapped",[1610,1610]],[[64603,64603],"mapped",[1584,1648]],[[64604,64604],"mapped",[1585,1648]],[[64605,64605],"mapped",[1609,1648]],[[64606,64606],"disallowed_STD3_mapped",[32,1612,1617]],[[64607,64607],"disallowed_STD3_mapped",[32,1613,1617]],[[64608,64608],"disallowed_STD3_mapped",[32,1614,1617]],[[64609,64609],"disallowed_STD3_mapped",[32,1615,1617]],[[64610,64610],"disallowed_STD3_mapped",[32,1616,1617]],[[64611,64611],"disallowed_STD3_mapped",[32,1617,1648]],[[64612,64612],"mapped",[1574,1585]],[[64613,64613],"mapped",[1574,1586]],[[64614,64614],"mapped",[1574,1605]],[[64615,64615],"mapped",[1574,1606]],[[64616,64616],"mapped",[1574,1609]],[[64617,64617],"mapped",[1574,1610]],[[64618,64618],"mapped",[1576,1585]],[[64619,64619],"mapped",[1576,1586]],[[64620,64620],"mapped",[1576,1605]],[[64621,64621],"mapped",[1576,1606]],[[64622,64622],"mapped",[1576,1609]],[[64623,64623],"mapped",[1576,1610]],[[64624,64624],"mapped",[1578,1585]],[[64625,64625],"mapped",[1578,1586]],[[64626,64626],"mapped",[1578,1605]],[[64627,64627],"mapped",[1578,1606]],[[64628,64628],"mapped",[1578,1609]],[[64629,64629],"mapped",[1578,1610]],[[64630,64630],"mapped",[1579,1585]],[[64631,64631],"mapped",[1579,1586]],[[64632,64632],"mapped",[1579,1605]],[[64633,64633],"mapped",[1579,1606]],[[64634,64634],"mapped",[1579,1609]],[[64635,64635],"mapped",[1579,1610]],[[64636,64636],"mapped",[1601,1609]],[[64637,64637],"mapped",[1601,1610]],[[64638,64638],"mapped",[1602,1609]],[[64639,64639],"mapped",[1602,1610]],[[64640,64640],"mapped",[1603,1575]],[[64641,64641],"mapped",[1603,1604]],[[64642,64642],"mapped",[1603,1605]],[[64643,64643],"mapped",[1603,1609]],[[64644,64644],"mapped",[1603,1610]],[[64645,64645],"mapped",[1604,1605]],[[64646,64646],"mapped",[1604,1609]],[[64647,64647],"mapped",[1604,1610]],[[64648,64648],"mapped",[1605,1575]],[[64649,64649],"mapped",[1605,1605]],[[64650,64650],"mapped",[1606,1585]],[[64651,64651],"mapped",[1606,1586]],[[64652,64652],"mapped",[1606,1605]],[[64653,64653],"mapped",[1606,1606]],[[64654,64654],"mapped",[1606,1609]],[[64655,64655],"mapped",[1606,1610]],[[64656,64656],"mapped",[1609,1648]],[[64657,64657],"mapped",[1610,1585]],[[64658,64658],"mapped",[1610,1586]],[[64659,64659],"mapped",[1610,1605]],[[64660,64660],"mapped",[1610,1606]],[[64661,64661],"mapped",[1610,1609]],[[64662,64662],"mapped",[1610,1610]],[[64663,64663],"mapped",[1574,1580]],[[64664,64664],"mapped",[1574,1581]],[[64665,64665],"mapped",[1574,1582]],[[64666,64666],"mapped",[1574,1605]],[[64667,64667],"mapped",[1574,1607]],[[64668,64668],"mapped",[1576,1580]],[[64669,64669],"mapped",[1576,1581]],[[64670,64670],"mapped",[1576,1582]],[[64671,64671],"mapped",[1576,1605]],[[64672,64672],"mapped",[1576,1607]],[[64673,64673],"mapped",[1578,1580]],[[64674,64674],"mapped",[1578,1581]],[[64675,64675],"mapped",[1578,1582]],[[64676,64676],"mapped",[1578,1605]],[[64677,64677],"mapped",[1578,1607]],[[64678,64678],"mapped",[1579,1605]],[[64679,64679],"mapped",[1580,1581]],[[64680,64680],"mapped",[1580,1605]],[[64681,64681],"mapped",[1581,1580]],[[64682,64682],"mapped",[1581,1605]],[[64683,64683],"mapped",[1582,1580]],[[64684,64684],"mapped",[1582,1605]],[[64685,64685],"mapped",[1587,1580]],[[64686,64686],"mapped",[1587,1581]],[[64687,64687],"mapped",[1587,1582]],[[64688,64688],"mapped",[1587,1605]],[[64689,64689],"mapped",[1589,1581]],[[64690,64690],"mapped",[1589,1582]],[[64691,64691],"mapped",[1589,1605]],[[64692,64692],"mapped",[1590,1580]],[[64693,64693],"mapped",[1590,1581]],[[64694,64694],"mapped",[1590,1582]],[[64695,64695],"mapped",[1590,1605]],[[64696,64696],"mapped",[1591,1581]],[[64697,64697],"mapped",[1592,1605]],[[64698,64698],"mapped",[1593,1580]],[[64699,64699],"mapped",[1593,1605]],[[64700,64700],"mapped",[1594,1580]],[[64701,64701],"mapped",[1594,1605]],[[64702,64702],"mapped",[1601,1580]],[[64703,64703],"mapped",[1601,1581]],[[64704,64704],"mapped",[1601,1582]],[[64705,64705],"mapped",[1601,1605]],[[64706,64706],"mapped",[1602,1581]],[[64707,64707],"mapped",[1602,1605]],[[64708,64708],"mapped",[1603,1580]],[[64709,64709],"mapped",[1603,1581]],[[64710,64710],"mapped",[1603,1582]],[[64711,64711],"mapped",[1603,1604]],[[64712,64712],"mapped",[1603,1605]],[[64713,64713],"mapped",[1604,1580]],[[64714,64714],"mapped",[1604,1581]],[[64715,64715],"mapped",[1604,1582]],[[64716,64716],"mapped",[1604,1605]],[[64717,64717],"mapped",[1604,1607]],[[64718,64718],"mapped",[1605,1580]],[[64719,64719],"mapped",[1605,1581]],[[64720,64720],"mapped",[1605,1582]],[[64721,64721],"mapped",[1605,1605]],[[64722,64722],"mapped",[1606,1580]],[[64723,64723],"mapped",[1606,1581]],[[64724,64724],"mapped",[1606,1582]],[[64725,64725],"mapped",[1606,1605]],[[64726,64726],"mapped",[1606,1607]],[[64727,64727],"mapped",[1607,1580]],[[64728,64728],"mapped",[1607,1605]],[[64729,64729],"mapped",[1607,1648]],[[64730,64730],"mapped",[1610,1580]],[[64731,64731],"mapped",[1610,1581]],[[64732,64732],"mapped",[1610,1582]],[[64733,64733],"mapped",[1610,1605]],[[64734,64734],"mapped",[1610,1607]],[[64735,64735],"mapped",[1574,1605]],[[64736,64736],"mapped",[1574,1607]],[[64737,64737],"mapped",[1576,1605]],[[64738,64738],"mapped",[1576,1607]],[[64739,64739],"mapped",[1578,1605]],[[64740,64740],"mapped",[1578,1607]],[[64741,64741],"mapped",[1579,1605]],[[64742,64742],"mapped",[1579,1607]],[[64743,64743],"mapped",[1587,1605]],[[64744,64744],"mapped",[1587,1607]],[[64745,64745],"mapped",[1588,1605]],[[64746,64746],"mapped",[1588,1607]],[[64747,64747],"mapped",[1603,1604]],[[64748,64748],"mapped",[1603,1605]],[[64749,64749],"mapped",[1604,1605]],[[64750,64750],"mapped",[1606,1605]],[[64751,64751],"mapped",[1606,1607]],[[64752,64752],"mapped",[1610,1605]],[[64753,64753],"mapped",[1610,1607]],[[64754,64754],"mapped",[1600,1614,1617]],[[64755,64755],"mapped",[1600,1615,1617]],[[64756,64756],"mapped",[1600,1616,1617]],[[64757,64757],"mapped",[1591,1609]],[[64758,64758],"mapped",[1591,1610]],[[64759,64759],"mapped",[1593,1609]],[[64760,64760],"mapped",[1593,1610]],[[64761,64761],"mapped",[1594,1609]],[[64762,64762],"mapped",[1594,1610]],[[64763,64763],"mapped",[1587,1609]],[[64764,64764],"mapped",[1587,1610]],[[64765,64765],"mapped",[1588,1609]],[[64766,64766],"mapped",[1588,1610]],[[64767,64767],"mapped",[1581,1609]],[[64768,64768],"mapped",[1581,1610]],[[64769,64769],"mapped",[1580,1609]],[[64770,64770],"mapped",[1580,1610]],[[64771,64771],"mapped",[1582,1609]],[[64772,64772],"mapped",[1582,1610]],[[64773,64773],"mapped",[1589,1609]],[[64774,64774],"mapped",[1589,1610]],[[64775,64775],"mapped",[1590,1609]],[[64776,64776],"mapped",[1590,1610]],[[64777,64777],"mapped",[1588,1580]],[[64778,64778],"mapped",[1588,1581]],[[64779,64779],"mapped",[1588,1582]],[[64780,64780],"mapped",[1588,1605]],[[64781,64781],"mapped",[1588,1585]],[[64782,64782],"mapped",[1587,1585]],[[64783,64783],"mapped",[1589,1585]],[[64784,64784],"mapped",[1590,1585]],[[64785,64785],"mapped",[1591,1609]],[[64786,64786],"mapped",[1591,1610]],[[64787,64787],"mapped",[1593,1609]],[[64788,64788],"mapped",[1593,1610]],[[64789,64789],"mapped",[1594,1609]],[[64790,64790],"mapped",[1594,1610]],[[64791,64791],"mapped",[1587,1609]],[[64792,64792],"mapped",[1587,1610]],[[64793,64793],"mapped",[1588,1609]],[[64794,64794],"mapped",[1588,1610]],[[64795,64795],"mapped",[1581,1609]],[[64796,64796],"mapped",[1581,1610]],[[64797,64797],"mapped",[1580,1609]],[[64798,64798],"mapped",[1580,1610]],[[64799,64799],"mapped",[1582,1609]],[[64800,64800],"mapped",[1582,1610]],[[64801,64801],"mapped",[1589,1609]],[[64802,64802],"mapped",[1589,1610]],[[64803,64803],"mapped",[1590,1609]],[[64804,64804],"mapped",[1590,1610]],[[64805,64805],"mapped",[1588,1580]],[[64806,64806],"mapped",[1588,1581]],[[64807,64807],"mapped",[1588,1582]],[[64808,64808],"mapped",[1588,1605]],[[64809,64809],"mapped",[1588,1585]],[[64810,64810],"mapped",[1587,1585]],[[64811,64811],"mapped",[1589,1585]],[[64812,64812],"mapped",[1590,1585]],[[64813,64813],"mapped",[1588,1580]],[[64814,64814],"mapped",[1588,1581]],[[64815,64815],"mapped",[1588,1582]],[[64816,64816],"mapped",[1588,1605]],[[64817,64817],"mapped",[1587,1607]],[[64818,64818],"mapped",[1588,1607]],[[64819,64819],"mapped",[1591,1605]],[[64820,64820],"mapped",[1587,1580]],[[64821,64821],"mapped",[1587,1581]],[[64822,64822],"mapped",[1587,1582]],[[64823,64823],"mapped",[1588,1580]],[[64824,64824],"mapped",[1588,1581]],[[64825,64825],"mapped",[1588,1582]],[[64826,64826],"mapped",[1591,1605]],[[64827,64827],"mapped",[1592,1605]],[[64828,64829],"mapped",[1575,1611]],[[64830,64831],"valid",[],"NV8"],[[64832,64847],"disallowed"],[[64848,64848],"mapped",[1578,1580,1605]],[[64849,64850],"mapped",[1578,1581,1580]],[[64851,64851],"mapped",[1578,1581,1605]],[[64852,64852],"mapped",[1578,1582,1605]],[[64853,64853],"mapped",[1578,1605,1580]],[[64854,64854],"mapped",[1578,1605,1581]],[[64855,64855],"mapped",[1578,1605,1582]],[[64856,64857],"mapped",[1580,1605,1581]],[[64858,64858],"mapped",[1581,1605,1610]],[[64859,64859],"mapped",[1581,1605,1609]],[[64860,64860],"mapped",[1587,1581,1580]],[[64861,64861],"mapped",[1587,1580,1581]],[[64862,64862],"mapped",[1587,1580,1609]],[[64863,64864],"mapped",[1587,1605,1581]],[[64865,64865],"mapped",[1587,1605,1580]],[[64866,64867],"mapped",[1587,1605,1605]],[[64868,64869],"mapped",[1589,1581,1581]],[[64870,64870],"mapped",[1589,1605,1605]],[[64871,64872],"mapped",[1588,1581,1605]],[[64873,64873],"mapped",[1588,1580,1610]],[[64874,64875],"mapped",[1588,1605,1582]],[[64876,64877],"mapped",[1588,1605,1605]],[[64878,64878],"mapped",[1590,1581,1609]],[[64879,64880],"mapped",[1590,1582,1605]],[[64881,64882],"mapped",[1591,1605,1581]],[[64883,64883],"mapped",[1591,1605,1605]],[[64884,64884],"mapped",[1591,1605,1610]],[[64885,64885],"mapped",[1593,1580,1605]],[[64886,64887],"mapped",[1593,1605,1605]],[[64888,64888],"mapped",[1593,1605,1609]],[[64889,64889],"mapped",[1594,1605,1605]],[[64890,64890],"mapped",[1594,1605,1610]],[[64891,64891],"mapped",[1594,1605,1609]],[[64892,64893],"mapped",[1601,1582,1605]],[[64894,64894],"mapped",[1602,1605,1581]],[[64895,64895],"mapped",[1602,1605,1605]],[[64896,64896],"mapped",[1604,1581,1605]],[[64897,64897],"mapped",[1604,1581,1610]],[[64898,64898],"mapped",[1604,1581,1609]],[[64899,64900],"mapped",[1604,1580,1580]],[[64901,64902],"mapped",[1604,1582,1605]],[[64903,64904],"mapped",[1604,1605,1581]],[[64905,64905],"mapped",[1605,1581,1580]],[[64906,64906],"mapped",[1605,1581,1605]],[[64907,64907],"mapped",[1605,1581,1610]],[[64908,64908],"mapped",[1605,1580,1581]],[[64909,64909],"mapped",[1605,1580,1605]],[[64910,64910],"mapped",[1605,1582,1580]],[[64911,64911],"mapped",[1605,1582,1605]],[[64912,64913],"disallowed"],[[64914,64914],"mapped",[1605,1580,1582]],[[64915,64915],"mapped",[1607,1605,1580]],[[64916,64916],"mapped",[1607,1605,1605]],[[64917,64917],"mapped",[1606,1581,1605]],[[64918,64918],"mapped",[1606,1581,1609]],[[64919,64920],"mapped",[1606,1580,1605]],[[64921,64921],"mapped",[1606,1580,1609]],[[64922,64922],"mapped",[1606,1605,1610]],[[64923,64923],"mapped",[1606,1605,1609]],[[64924,64925],"mapped",[1610,1605,1605]],[[64926,64926],"mapped",[1576,1582,1610]],[[64927,64927],"mapped",[1578,1580,1610]],[[64928,64928],"mapped",[1578,1580,1609]],[[64929,64929],"mapped",[1578,1582,1610]],[[64930,64930],"mapped",[1578,1582,1609]],[[64931,64931],"mapped",[1578,1605,1610]],[[64932,64932],"mapped",[1578,1605,1609]],[[64933,64933],"mapped",[1580,1605,1610]],[[64934,64934],"mapped",[1580,1581,1609]],[[64935,64935],"mapped",[1580,1605,1609]],[[64936,64936],"mapped",[1587,1582,1609]],[[64937,64937],"mapped",[1589,1581,1610]],[[64938,64938],"mapped",[1588,1581,1610]],[[64939,64939],"mapped",[1590,1581,1610]],[[64940,64940],"mapped",[1604,1580,1610]],[[64941,64941],"mapped",[1604,1605,1610]],[[64942,64942],"mapped",[1610,1581,1610]],[[64943,64943],"mapped",[1610,1580,1610]],[[64944,64944],"mapped",[1610,1605,1610]],[[64945,64945],"mapped",[1605,1605,1610]],[[64946,64946],"mapped",[1602,1605,1610]],[[64947,64947],"mapped",[1606,1581,1610]],[[64948,64948],"mapped",[1602,1605,1581]],[[64949,64949],"mapped",[1604,1581,1605]],[[64950,64950],"mapped",[1593,1605,1610]],[[64951,64951],"mapped",[1603,1605,1610]],[[64952,64952],"mapped",[1606,1580,1581]],[[64953,64953],"mapped",[1605,1582,1610]],[[64954,64954],"mapped",[1604,1580,1605]],[[64955,64955],"mapped",[1603,1605,1605]],[[64956,64956],"mapped",[1604,1580,1605]],[[64957,64957],"mapped",[1606,1580,1581]],[[64958,64958],"mapped",[1580,1581,1610]],[[64959,64959],"mapped",[1581,1580,1610]],[[64960,64960],"mapped",[1605,1580,1610]],[[64961,64961],"mapped",[1601,1605,1610]],[[64962,64962],"mapped",[1576,1581,1610]],[[64963,64963],"mapped",[1603,1605,1605]],[[64964,64964],"mapped",[1593,1580,1605]],[[64965,64965],"mapped",[1589,1605,1605]],[[64966,64966],"mapped",[1587,1582,1610]],[[64967,64967],"mapped",[1606,1580,1610]],[[64968,64975],"disallowed"],[[64976,65007],"disallowed"],[[65008,65008],"mapped",[1589,1604,1746]],[[65009,65009],"mapped",[1602,1604,1746]],[[65010,65010],"mapped",[1575,1604,1604,1607]],[[65011,65011],"mapped",[1575,1603,1576,1585]],[[65012,65012],"mapped",[1605,1581,1605,1583]],[[65013,65013],"mapped",[1589,1604,1593,1605]],[[65014,65014],"mapped",[1585,1587,1608,1604]],[[65015,65015],"mapped",[1593,1604,1610,1607]],[[65016,65016],"mapped",[1608,1587,1604,1605]],[[65017,65017],"mapped",[1589,1604,1609]],[[65018,65018],"disallowed_STD3_mapped",[1589,1604,1609,32,1575,1604,1604,1607,32,1593,1604,1610,1607,32,1608,1587,1604,1605]],[[65019,65019],"disallowed_STD3_mapped",[1580,1604,32,1580,1604,1575,1604,1607]],[[65020,65020],"mapped",[1585,1740,1575,1604]],[[65021,65021],"valid",[],"NV8"],[[65022,65023],"disallowed"],[[65024,65039],"ignored"],[[65040,65040],"disallowed_STD3_mapped",[44]],[[65041,65041],"mapped",[12289]],[[65042,65042],"disallowed"],[[65043,65043],"disallowed_STD3_mapped",[58]],[[65044,65044],"disallowed_STD3_mapped",[59]],[[65045,65045],"disallowed_STD3_mapped",[33]],[[65046,65046],"disallowed_STD3_mapped",[63]],[[65047,65047],"mapped",[12310]],[[65048,65048],"mapped",[12311]],[[65049,65049],"disallowed"],[[65050,65055],"disallowed"],[[65056,65059],"valid"],[[65060,65062],"valid"],[[65063,65069],"valid"],[[65070,65071],"valid"],[[65072,65072],"disallowed"],[[65073,65073],"mapped",[8212]],[[65074,65074],"mapped",[8211]],[[65075,65076],"disallowed_STD3_mapped",[95]],[[65077,65077],"disallowed_STD3_mapped",[40]],[[65078,65078],"disallowed_STD3_mapped",[41]],[[65079,65079],"disallowed_STD3_mapped",[123]],[[65080,65080],"disallowed_STD3_mapped",[125]],[[65081,65081],"mapped",[12308]],[[65082,65082],"mapped",[12309]],[[65083,65083],"mapped",[12304]],[[65084,65084],"mapped",[12305]],[[65085,65085],"mapped",[12298]],[[65086,65086],"mapped",[12299]],[[65087,65087],"mapped",[12296]],[[65088,65088],"mapped",[12297]],[[65089,65089],"mapped",[12300]],[[65090,65090],"mapped",[12301]],[[65091,65091],"mapped",[12302]],[[65092,65092],"mapped",[12303]],[[65093,65094],"valid",[],"NV8"],[[65095,65095],"disallowed_STD3_mapped",[91]],[[65096,65096],"disallowed_STD3_mapped",[93]],[[65097,65100],"disallowed_STD3_mapped",[32,773]],[[65101,65103],"disallowed_STD3_mapped",[95]],[[65104,65104],"disallowed_STD3_mapped",[44]],[[65105,65105],"mapped",[12289]],[[65106,65106],"disallowed"],[[65107,65107],"disallowed"],[[65108,65108],"disallowed_STD3_mapped",[59]],[[65109,65109],"disallowed_STD3_mapped",[58]],[[65110,65110],"disallowed_STD3_mapped",[63]],[[65111,65111],"disallowed_STD3_mapped",[33]],[[65112,65112],"mapped",[8212]],[[65113,65113],"disallowed_STD3_mapped",[40]],[[65114,65114],"disallowed_STD3_mapped",[41]],[[65115,65115],"disallowed_STD3_mapped",[123]],[[65116,65116],"disallowed_STD3_mapped",[125]],[[65117,65117],"mapped",[12308]],[[65118,65118],"mapped",[12309]],[[65119,65119],"disallowed_STD3_mapped",[35]],[[65120,65120],"disallowed_STD3_mapped",[38]],[[65121,65121],"disallowed_STD3_mapped",[42]],[[65122,65122],"disallowed_STD3_mapped",[43]],[[65123,65123],"mapped",[45]],[[65124,65124],"disallowed_STD3_mapped",[60]],[[65125,65125],"disallowed_STD3_mapped",[62]],[[65126,65126],"disallowed_STD3_mapped",[61]],[[65127,65127],"disallowed"],[[65128,65128],"disallowed_STD3_mapped",[92]],[[65129,65129],"disallowed_STD3_mapped",[36]],[[65130,65130],"disallowed_STD3_mapped",[37]],[[65131,65131],"disallowed_STD3_mapped",[64]],[[65132,65135],"disallowed"],[[65136,65136],"disallowed_STD3_mapped",[32,1611]],[[65137,65137],"mapped",[1600,1611]],[[65138,65138],"disallowed_STD3_mapped",[32,1612]],[[65139,65139],"valid"],[[65140,65140],"disallowed_STD3_mapped",[32,1613]],[[65141,65141],"disallowed"],[[65142,65142],"disallowed_STD3_mapped",[32,1614]],[[65143,65143],"mapped",[1600,1614]],[[65144,65144],"disallowed_STD3_mapped",[32,1615]],[[65145,65145],"mapped",[1600,1615]],[[65146,65146],"disallowed_STD3_mapped",[32,1616]],[[65147,65147],"mapped",[1600,1616]],[[65148,65148],"disallowed_STD3_mapped",[32,1617]],[[65149,65149],"mapped",[1600,1617]],[[65150,65150],"disallowed_STD3_mapped",[32,1618]],[[65151,65151],"mapped",[1600,1618]],[[65152,65152],"mapped",[1569]],[[65153,65154],"mapped",[1570]],[[65155,65156],"mapped",[1571]],[[65157,65158],"mapped",[1572]],[[65159,65160],"mapped",[1573]],[[65161,65164],"mapped",[1574]],[[65165,65166],"mapped",[1575]],[[65167,65170],"mapped",[1576]],[[65171,65172],"mapped",[1577]],[[65173,65176],"mapped",[1578]],[[65177,65180],"mapped",[1579]],[[65181,65184],"mapped",[1580]],[[65185,65188],"mapped",[1581]],[[65189,65192],"mapped",[1582]],[[65193,65194],"mapped",[1583]],[[65195,65196],"mapped",[1584]],[[65197,65198],"mapped",[1585]],[[65199,65200],"mapped",[1586]],[[65201,65204],"mapped",[1587]],[[65205,65208],"mapped",[1588]],[[65209,65212],"mapped",[1589]],[[65213,65216],"mapped",[1590]],[[65217,65220],"mapped",[1591]],[[65221,65224],"mapped",[1592]],[[65225,65228],"mapped",[1593]],[[65229,65232],"mapped",[1594]],[[65233,65236],"mapped",[1601]],[[65237,65240],"mapped",[1602]],[[65241,65244],"mapped",[1603]],[[65245,65248],"mapped",[1604]],[[65249,65252],"mapped",[1605]],[[65253,65256],"mapped",[1606]],[[65257,65260],"mapped",[1607]],[[65261,65262],"mapped",[1608]],[[65263,65264],"mapped",[1609]],[[65265,65268],"mapped",[1610]],[[65269,65270],"mapped",[1604,1570]],[[65271,65272],"mapped",[1604,1571]],[[65273,65274],"mapped",[1604,1573]],[[65275,65276],"mapped",[1604,1575]],[[65277,65278],"disallowed"],[[65279,65279],"ignored"],[[65280,65280],"disallowed"],[[65281,65281],"disallowed_STD3_mapped",[33]],[[65282,65282],"disallowed_STD3_mapped",[34]],[[65283,65283],"disallowed_STD3_mapped",[35]],[[65284,65284],"disallowed_STD3_mapped",[36]],[[65285,65285],"disallowed_STD3_mapped",[37]],[[65286,65286],"disallowed_STD3_mapped",[38]],[[65287,65287],"disallowed_STD3_mapped",[39]],[[65288,65288],"disallowed_STD3_mapped",[40]],[[65289,65289],"disallowed_STD3_mapped",[41]],[[65290,65290],"disallowed_STD3_mapped",[42]],[[65291,65291],"disallowed_STD3_mapped",[43]],[[65292,65292],"disallowed_STD3_mapped",[44]],[[65293,65293],"mapped",[45]],[[65294,65294],"mapped",[46]],[[65295,65295],"disallowed_STD3_mapped",[47]],[[65296,65296],"mapped",[48]],[[65297,65297],"mapped",[49]],[[65298,65298],"mapped",[50]],[[65299,65299],"mapped",[51]],[[65300,65300],"mapped",[52]],[[65301,65301],"mapped",[53]],[[65302,65302],"mapped",[54]],[[65303,65303],"mapped",[55]],[[65304,65304],"mapped",[56]],[[65305,65305],"mapped",[57]],[[65306,65306],"disallowed_STD3_mapped",[58]],[[65307,65307],"disallowed_STD3_mapped",[59]],[[65308,65308],"disallowed_STD3_mapped",[60]],[[65309,65309],"disallowed_STD3_mapped",[61]],[[65310,65310],"disallowed_STD3_mapped",[62]],[[65311,65311],"disallowed_STD3_mapped",[63]],[[65312,65312],"disallowed_STD3_mapped",[64]],[[65313,65313],"mapped",[97]],[[65314,65314],"mapped",[98]],[[65315,65315],"mapped",[99]],[[65316,65316],"mapped",[100]],[[65317,65317],"mapped",[101]],[[65318,65318],"mapped",[102]],[[65319,65319],"mapped",[103]],[[65320,65320],"mapped",[104]],[[65321,65321],"mapped",[105]],[[65322,65322],"mapped",[106]],[[65323,65323],"mapped",[107]],[[65324,65324],"mapped",[108]],[[65325,65325],"mapped",[109]],[[65326,65326],"mapped",[110]],[[65327,65327],"mapped",[111]],[[65328,65328],"mapped",[112]],[[65329,65329],"mapped",[113]],[[65330,65330],"mapped",[114]],[[65331,65331],"mapped",[115]],[[65332,65332],"mapped",[116]],[[65333,65333],"mapped",[117]],[[65334,65334],"mapped",[118]],[[65335,65335],"mapped",[119]],[[65336,65336],"mapped",[120]],[[65337,65337],"mapped",[121]],[[65338,65338],"mapped",[122]],[[65339,65339],"disallowed_STD3_mapped",[91]],[[65340,65340],"disallowed_STD3_mapped",[92]],[[65341,65341],"disallowed_STD3_mapped",[93]],[[65342,65342],"disallowed_STD3_mapped",[94]],[[65343,65343],"disallowed_STD3_mapped",[95]],[[65344,65344],"disallowed_STD3_mapped",[96]],[[65345,65345],"mapped",[97]],[[65346,65346],"mapped",[98]],[[65347,65347],"mapped",[99]],[[65348,65348],"mapped",[100]],[[65349,65349],"mapped",[101]],[[65350,65350],"mapped",[102]],[[65351,65351],"mapped",[103]],[[65352,65352],"mapped",[104]],[[65353,65353],"mapped",[105]],[[65354,65354],"mapped",[106]],[[65355,65355],"mapped",[107]],[[65356,65356],"mapped",[108]],[[65357,65357],"mapped",[109]],[[65358,65358],"mapped",[110]],[[65359,65359],"mapped",[111]],[[65360,65360],"mapped",[112]],[[65361,65361],"mapped",[113]],[[65362,65362],"mapped",[114]],[[65363,65363],"mapped",[115]],[[65364,65364],"mapped",[116]],[[65365,65365],"mapped",[117]],[[65366,65366],"mapped",[118]],[[65367,65367],"mapped",[119]],[[65368,65368],"mapped",[120]],[[65369,65369],"mapped",[121]],[[65370,65370],"mapped",[122]],[[65371,65371],"disallowed_STD3_mapped",[123]],[[65372,65372],"disallowed_STD3_mapped",[124]],[[65373,65373],"disallowed_STD3_mapped",[125]],[[65374,65374],"disallowed_STD3_mapped",[126]],[[65375,65375],"mapped",[10629]],[[65376,65376],"mapped",[10630]],[[65377,65377],"mapped",[46]],[[65378,65378],"mapped",[12300]],[[65379,65379],"mapped",[12301]],[[65380,65380],"mapped",[12289]],[[65381,65381],"mapped",[12539]],[[65382,65382],"mapped",[12530]],[[65383,65383],"mapped",[12449]],[[65384,65384],"mapped",[12451]],[[65385,65385],"mapped",[12453]],[[65386,65386],"mapped",[12455]],[[65387,65387],"mapped",[12457]],[[65388,65388],"mapped",[12515]],[[65389,65389],"mapped",[12517]],[[65390,65390],"mapped",[12519]],[[65391,65391],"mapped",[12483]],[[65392,65392],"mapped",[12540]],[[65393,65393],"mapped",[12450]],[[65394,65394],"mapped",[12452]],[[65395,65395],"mapped",[12454]],[[65396,65396],"mapped",[12456]],[[65397,65397],"mapped",[12458]],[[65398,65398],"mapped",[12459]],[[65399,65399],"mapped",[12461]],[[65400,65400],"mapped",[12463]],[[65401,65401],"mapped",[12465]],[[65402,65402],"mapped",[12467]],[[65403,65403],"mapped",[12469]],[[65404,65404],"mapped",[12471]],[[65405,65405],"mapped",[12473]],[[65406,65406],"mapped",[12475]],[[65407,65407],"mapped",[12477]],[[65408,65408],"mapped",[12479]],[[65409,65409],"mapped",[12481]],[[65410,65410],"mapped",[12484]],[[65411,65411],"mapped",[12486]],[[65412,65412],"mapped",[12488]],[[65413,65413],"mapped",[12490]],[[65414,65414],"mapped",[12491]],[[65415,65415],"mapped",[12492]],[[65416,65416],"mapped",[12493]],[[65417,65417],"mapped",[12494]],[[65418,65418],"mapped",[12495]],[[65419,65419],"mapped",[12498]],[[65420,65420],"mapped",[12501]],[[65421,65421],"mapped",[12504]],[[65422,65422],"mapped",[12507]],[[65423,65423],"mapped",[12510]],[[65424,65424],"mapped",[12511]],[[65425,65425],"mapped",[12512]],[[65426,65426],"mapped",[12513]],[[65427,65427],"mapped",[12514]],[[65428,65428],"mapped",[12516]],[[65429,65429],"mapped",[12518]],[[65430,65430],"mapped",[12520]],[[65431,65431],"mapped",[12521]],[[65432,65432],"mapped",[12522]],[[65433,65433],"mapped",[12523]],[[65434,65434],"mapped",[12524]],[[65435,65435],"mapped",[12525]],[[65436,65436],"mapped",[12527]],[[65437,65437],"mapped",[12531]],[[65438,65438],"mapped",[12441]],[[65439,65439],"mapped",[12442]],[[65440,65440],"disallowed"],[[65441,65441],"mapped",[4352]],[[65442,65442],"mapped",[4353]],[[65443,65443],"mapped",[4522]],[[65444,65444],"mapped",[4354]],[[65445,65445],"mapped",[4524]],[[65446,65446],"mapped",[4525]],[[65447,65447],"mapped",[4355]],[[65448,65448],"mapped",[4356]],[[65449,65449],"mapped",[4357]],[[65450,65450],"mapped",[4528]],[[65451,65451],"mapped",[4529]],[[65452,65452],"mapped",[4530]],[[65453,65453],"mapped",[4531]],[[65454,65454],"mapped",[4532]],[[65455,65455],"mapped",[4533]],[[65456,65456],"mapped",[4378]],[[65457,65457],"mapped",[4358]],[[65458,65458],"mapped",[4359]],[[65459,65459],"mapped",[4360]],[[65460,65460],"mapped",[4385]],[[65461,65461],"mapped",[4361]],[[65462,65462],"mapped",[4362]],[[65463,65463],"mapped",[4363]],[[65464,65464],"mapped",[4364]],[[65465,65465],"mapped",[4365]],[[65466,65466],"mapped",[4366]],[[65467,65467],"mapped",[4367]],[[65468,65468],"mapped",[4368]],[[65469,65469],"mapped",[4369]],[[65470,65470],"mapped",[4370]],[[65471,65473],"disallowed"],[[65474,65474],"mapped",[4449]],[[65475,65475],"mapped",[4450]],[[65476,65476],"mapped",[4451]],[[65477,65477],"mapped",[4452]],[[65478,65478],"mapped",[4453]],[[65479,65479],"mapped",[4454]],[[65480,65481],"disallowed"],[[65482,65482],"mapped",[4455]],[[65483,65483],"mapped",[4456]],[[65484,65484],"mapped",[4457]],[[65485,65485],"mapped",[4458]],[[65486,65486],"mapped",[4459]],[[65487,65487],"mapped",[4460]],[[65488,65489],"disallowed"],[[65490,65490],"mapped",[4461]],[[65491,65491],"mapped",[4462]],[[65492,65492],"mapped",[4463]],[[65493,65493],"mapped",[4464]],[[65494,65494],"mapped",[4465]],[[65495,65495],"mapped",[4466]],[[65496,65497],"disallowed"],[[65498,65498],"mapped",[4467]],[[65499,65499],"mapped",[4468]],[[65500,65500],"mapped",[4469]],[[65501,65503],"disallowed"],[[65504,65504],"mapped",[162]],[[65505,65505],"mapped",[163]],[[65506,65506],"mapped",[172]],[[65507,65507],"disallowed_STD3_mapped",[32,772]],[[65508,65508],"mapped",[166]],[[65509,65509],"mapped",[165]],[[65510,65510],"mapped",[8361]],[[65511,65511],"disallowed"],[[65512,65512],"mapped",[9474]],[[65513,65513],"mapped",[8592]],[[65514,65514],"mapped",[8593]],[[65515,65515],"mapped",[8594]],[[65516,65516],"mapped",[8595]],[[65517,65517],"mapped",[9632]],[[65518,65518],"mapped",[9675]],[[65519,65528],"disallowed"],[[65529,65531],"disallowed"],[[65532,65532],"disallowed"],[[65533,65533],"disallowed"],[[65534,65535],"disallowed"],[[65536,65547],"valid"],[[65548,65548],"disallowed"],[[65549,65574],"valid"],[[65575,65575],"disallowed"],[[65576,65594],"valid"],[[65595,65595],"disallowed"],[[65596,65597],"valid"],[[65598,65598],"disallowed"],[[65599,65613],"valid"],[[65614,65615],"disallowed"],[[65616,65629],"valid"],[[65630,65663],"disallowed"],[[65664,65786],"valid"],[[65787,65791],"disallowed"],[[65792,65794],"valid",[],"NV8"],[[65795,65798],"disallowed"],[[65799,65843],"valid",[],"NV8"],[[65844,65846],"disallowed"],[[65847,65855],"valid",[],"NV8"],[[65856,65930],"valid",[],"NV8"],[[65931,65932],"valid",[],"NV8"],[[65933,65935],"disallowed"],[[65936,65947],"valid",[],"NV8"],[[65948,65951],"disallowed"],[[65952,65952],"valid",[],"NV8"],[[65953,65999],"disallowed"],[[66000,66044],"valid",[],"NV8"],[[66045,66045],"valid"],[[66046,66175],"disallowed"],[[66176,66204],"valid"],[[66205,66207],"disallowed"],[[66208,66256],"valid"],[[66257,66271],"disallowed"],[[66272,66272],"valid"],[[66273,66299],"valid",[],"NV8"],[[66300,66303],"disallowed"],[[66304,66334],"valid"],[[66335,66335],"valid"],[[66336,66339],"valid",[],"NV8"],[[66340,66351],"disallowed"],[[66352,66368],"valid"],[[66369,66369],"valid",[],"NV8"],[[66370,66377],"valid"],[[66378,66378],"valid",[],"NV8"],[[66379,66383],"disallowed"],[[66384,66426],"valid"],[[66427,66431],"disallowed"],[[66432,66461],"valid"],[[66462,66462],"disallowed"],[[66463,66463],"valid",[],"NV8"],[[66464,66499],"valid"],[[66500,66503],"disallowed"],[[66504,66511],"valid"],[[66512,66517],"valid",[],"NV8"],[[66518,66559],"disallowed"],[[66560,66560],"mapped",[66600]],[[66561,66561],"mapped",[66601]],[[66562,66562],"mapped",[66602]],[[66563,66563],"mapped",[66603]],[[66564,66564],"mapped",[66604]],[[66565,66565],"mapped",[66605]],[[66566,66566],"mapped",[66606]],[[66567,66567],"mapped",[66607]],[[66568,66568],"mapped",[66608]],[[66569,66569],"mapped",[66609]],[[66570,66570],"mapped",[66610]],[[66571,66571],"mapped",[66611]],[[66572,66572],"mapped",[66612]],[[66573,66573],"mapped",[66613]],[[66574,66574],"mapped",[66614]],[[66575,66575],"mapped",[66615]],[[66576,66576],"mapped",[66616]],[[66577,66577],"mapped",[66617]],[[66578,66578],"mapped",[66618]],[[66579,66579],"mapped",[66619]],[[66580,66580],"mapped",[66620]],[[66581,66581],"mapped",[66621]],[[66582,66582],"mapped",[66622]],[[66583,66583],"mapped",[66623]],[[66584,66584],"mapped",[66624]],[[66585,66585],"mapped",[66625]],[[66586,66586],"mapped",[66626]],[[66587,66587],"mapped",[66627]],[[66588,66588],"mapped",[66628]],[[66589,66589],"mapped",[66629]],[[66590,66590],"mapped",[66630]],[[66591,66591],"mapped",[66631]],[[66592,66592],"mapped",[66632]],[[66593,66593],"mapped",[66633]],[[66594,66594],"mapped",[66634]],[[66595,66595],"mapped",[66635]],[[66596,66596],"mapped",[66636]],[[66597,66597],"mapped",[66637]],[[66598,66598],"mapped",[66638]],[[66599,66599],"mapped",[66639]],[[66600,66637],"valid"],[[66638,66717],"valid"],[[66718,66719],"disallowed"],[[66720,66729],"valid"],[[66730,66815],"disallowed"],[[66816,66855],"valid"],[[66856,66863],"disallowed"],[[66864,66915],"valid"],[[66916,66926],"disallowed"],[[66927,66927],"valid",[],"NV8"],[[66928,67071],"disallowed"],[[67072,67382],"valid"],[[67383,67391],"disallowed"],[[67392,67413],"valid"],[[67414,67423],"disallowed"],[[67424,67431],"valid"],[[67432,67583],"disallowed"],[[67584,67589],"valid"],[[67590,67591],"disallowed"],[[67592,67592],"valid"],[[67593,67593],"disallowed"],[[67594,67637],"valid"],[[67638,67638],"disallowed"],[[67639,67640],"valid"],[[67641,67643],"disallowed"],[[67644,67644],"valid"],[[67645,67646],"disallowed"],[[67647,67647],"valid"],[[67648,67669],"valid"],[[67670,67670],"disallowed"],[[67671,67679],"valid",[],"NV8"],[[67680,67702],"valid"],[[67703,67711],"valid",[],"NV8"],[[67712,67742],"valid"],[[67743,67750],"disallowed"],[[67751,67759],"valid",[],"NV8"],[[67760,67807],"disallowed"],[[67808,67826],"valid"],[[67827,67827],"disallowed"],[[67828,67829],"valid"],[[67830,67834],"disallowed"],[[67835,67839],"valid",[],"NV8"],[[67840,67861],"valid"],[[67862,67865],"valid",[],"NV8"],[[67866,67867],"valid",[],"NV8"],[[67868,67870],"disallowed"],[[67871,67871],"valid",[],"NV8"],[[67872,67897],"valid"],[[67898,67902],"disallowed"],[[67903,67903],"valid",[],"NV8"],[[67904,67967],"disallowed"],[[67968,68023],"valid"],[[68024,68027],"disallowed"],[[68028,68029],"valid",[],"NV8"],[[68030,68031],"valid"],[[68032,68047],"valid",[],"NV8"],[[68048,68049],"disallowed"],[[68050,68095],"valid",[],"NV8"],[[68096,68099],"valid"],[[68100,68100],"disallowed"],[[68101,68102],"valid"],[[68103,68107],"disallowed"],[[68108,68115],"valid"],[[68116,68116],"disallowed"],[[68117,68119],"valid"],[[68120,68120],"disallowed"],[[68121,68147],"valid"],[[68148,68151],"disallowed"],[[68152,68154],"valid"],[[68155,68158],"disallowed"],[[68159,68159],"valid"],[[68160,68167],"valid",[],"NV8"],[[68168,68175],"disallowed"],[[68176,68184],"valid",[],"NV8"],[[68185,68191],"disallowed"],[[68192,68220],"valid"],[[68221,68223],"valid",[],"NV8"],[[68224,68252],"valid"],[[68253,68255],"valid",[],"NV8"],[[68256,68287],"disallowed"],[[68288,68295],"valid"],[[68296,68296],"valid",[],"NV8"],[[68297,68326],"valid"],[[68327,68330],"disallowed"],[[68331,68342],"valid",[],"NV8"],[[68343,68351],"disallowed"],[[68352,68405],"valid"],[[68406,68408],"disallowed"],[[68409,68415],"valid",[],"NV8"],[[68416,68437],"valid"],[[68438,68439],"disallowed"],[[68440,68447],"valid",[],"NV8"],[[68448,68466],"valid"],[[68467,68471],"disallowed"],[[68472,68479],"valid",[],"NV8"],[[68480,68497],"valid"],[[68498,68504],"disallowed"],[[68505,68508],"valid",[],"NV8"],[[68509,68520],"disallowed"],[[68521,68527],"valid",[],"NV8"],[[68528,68607],"disallowed"],[[68608,68680],"valid"],[[68681,68735],"disallowed"],[[68736,68736],"mapped",[68800]],[[68737,68737],"mapped",[68801]],[[68738,68738],"mapped",[68802]],[[68739,68739],"mapped",[68803]],[[68740,68740],"mapped",[68804]],[[68741,68741],"mapped",[68805]],[[68742,68742],"mapped",[68806]],[[68743,68743],"mapped",[68807]],[[68744,68744],"mapped",[68808]],[[68745,68745],"mapped",[68809]],[[68746,68746],"mapped",[68810]],[[68747,68747],"mapped",[68811]],[[68748,68748],"mapped",[68812]],[[68749,68749],"mapped",[68813]],[[68750,68750],"mapped",[68814]],[[68751,68751],"mapped",[68815]],[[68752,68752],"mapped",[68816]],[[68753,68753],"mapped",[68817]],[[68754,68754],"mapped",[68818]],[[68755,68755],"mapped",[68819]],[[68756,68756],"mapped",[68820]],[[68757,68757],"mapped",[68821]],[[68758,68758],"mapped",[68822]],[[68759,68759],"mapped",[68823]],[[68760,68760],"mapped",[68824]],[[68761,68761],"mapped",[68825]],[[68762,68762],"mapped",[68826]],[[68763,68763],"mapped",[68827]],[[68764,68764],"mapped",[68828]],[[68765,68765],"mapped",[68829]],[[68766,68766],"mapped",[68830]],[[68767,68767],"mapped",[68831]],[[68768,68768],"mapped",[68832]],[[68769,68769],"mapped",[68833]],[[68770,68770],"mapped",[68834]],[[68771,68771],"mapped",[68835]],[[68772,68772],"mapped",[68836]],[[68773,68773],"mapped",[68837]],[[68774,68774],"mapped",[68838]],[[68775,68775],"mapped",[68839]],[[68776,68776],"mapped",[68840]],[[68777,68777],"mapped",[68841]],[[68778,68778],"mapped",[68842]],[[68779,68779],"mapped",[68843]],[[68780,68780],"mapped",[68844]],[[68781,68781],"mapped",[68845]],[[68782,68782],"mapped",[68846]],[[68783,68783],"mapped",[68847]],[[68784,68784],"mapped",[68848]],[[68785,68785],"mapped",[68849]],[[68786,68786],"mapped",[68850]],[[68787,68799],"disallowed"],[[68800,68850],"valid"],[[68851,68857],"disallowed"],[[68858,68863],"valid",[],"NV8"],[[68864,69215],"disallowed"],[[69216,69246],"valid",[],"NV8"],[[69247,69631],"disallowed"],[[69632,69702],"valid"],[[69703,69709],"valid",[],"NV8"],[[69710,69713],"disallowed"],[[69714,69733],"valid",[],"NV8"],[[69734,69743],"valid"],[[69744,69758],"disallowed"],[[69759,69759],"valid"],[[69760,69818],"valid"],[[69819,69820],"valid",[],"NV8"],[[69821,69821],"disallowed"],[[69822,69825],"valid",[],"NV8"],[[69826,69839],"disallowed"],[[69840,69864],"valid"],[[69865,69871],"disallowed"],[[69872,69881],"valid"],[[69882,69887],"disallowed"],[[69888,69940],"valid"],[[69941,69941],"disallowed"],[[69942,69951],"valid"],[[69952,69955],"valid",[],"NV8"],[[69956,69967],"disallowed"],[[69968,70003],"valid"],[[70004,70005],"valid",[],"NV8"],[[70006,70006],"valid"],[[70007,70015],"disallowed"],[[70016,70084],"valid"],[[70085,70088],"valid",[],"NV8"],[[70089,70089],"valid",[],"NV8"],[[70090,70092],"valid"],[[70093,70093],"valid",[],"NV8"],[[70094,70095],"disallowed"],[[70096,70105],"valid"],[[70106,70106],"valid"],[[70107,70107],"valid",[],"NV8"],[[70108,70108],"valid"],[[70109,70111],"valid",[],"NV8"],[[70112,70112],"disallowed"],[[70113,70132],"valid",[],"NV8"],[[70133,70143],"disallowed"],[[70144,70161],"valid"],[[70162,70162],"disallowed"],[[70163,70199],"valid"],[[70200,70205],"valid",[],"NV8"],[[70206,70271],"disallowed"],[[70272,70278],"valid"],[[70279,70279],"disallowed"],[[70280,70280],"valid"],[[70281,70281],"disallowed"],[[70282,70285],"valid"],[[70286,70286],"disallowed"],[[70287,70301],"valid"],[[70302,70302],"disallowed"],[[70303,70312],"valid"],[[70313,70313],"valid",[],"NV8"],[[70314,70319],"disallowed"],[[70320,70378],"valid"],[[70379,70383],"disallowed"],[[70384,70393],"valid"],[[70394,70399],"disallowed"],[[70400,70400],"valid"],[[70401,70403],"valid"],[[70404,70404],"disallowed"],[[70405,70412],"valid"],[[70413,70414],"disallowed"],[[70415,70416],"valid"],[[70417,70418],"disallowed"],[[70419,70440],"valid"],[[70441,70441],"disallowed"],[[70442,70448],"valid"],[[70449,70449],"disallowed"],[[70450,70451],"valid"],[[70452,70452],"disallowed"],[[70453,70457],"valid"],[[70458,70459],"disallowed"],[[70460,70468],"valid"],[[70469,70470],"disallowed"],[[70471,70472],"valid"],[[70473,70474],"disallowed"],[[70475,70477],"valid"],[[70478,70479],"disallowed"],[[70480,70480],"valid"],[[70481,70486],"disallowed"],[[70487,70487],"valid"],[[70488,70492],"disallowed"],[[70493,70499],"valid"],[[70500,70501],"disallowed"],[[70502,70508],"valid"],[[70509,70511],"disallowed"],[[70512,70516],"valid"],[[70517,70783],"disallowed"],[[70784,70853],"valid"],[[70854,70854],"valid",[],"NV8"],[[70855,70855],"valid"],[[70856,70863],"disallowed"],[[70864,70873],"valid"],[[70874,71039],"disallowed"],[[71040,71093],"valid"],[[71094,71095],"disallowed"],[[71096,71104],"valid"],[[71105,71113],"valid",[],"NV8"],[[71114,71127],"valid",[],"NV8"],[[71128,71133],"valid"],[[71134,71167],"disallowed"],[[71168,71232],"valid"],[[71233,71235],"valid",[],"NV8"],[[71236,71236],"valid"],[[71237,71247],"disallowed"],[[71248,71257],"valid"],[[71258,71295],"disallowed"],[[71296,71351],"valid"],[[71352,71359],"disallowed"],[[71360,71369],"valid"],[[71370,71423],"disallowed"],[[71424,71449],"valid"],[[71450,71452],"disallowed"],[[71453,71467],"valid"],[[71468,71471],"disallowed"],[[71472,71481],"valid"],[[71482,71487],"valid",[],"NV8"],[[71488,71839],"disallowed"],[[71840,71840],"mapped",[71872]],[[71841,71841],"mapped",[71873]],[[71842,71842],"mapped",[71874]],[[71843,71843],"mapped",[71875]],[[71844,71844],"mapped",[71876]],[[71845,71845],"mapped",[71877]],[[71846,71846],"mapped",[71878]],[[71847,71847],"mapped",[71879]],[[71848,71848],"mapped",[71880]],[[71849,71849],"mapped",[71881]],[[71850,71850],"mapped",[71882]],[[71851,71851],"mapped",[71883]],[[71852,71852],"mapped",[71884]],[[71853,71853],"mapped",[71885]],[[71854,71854],"mapped",[71886]],[[71855,71855],"mapped",[71887]],[[71856,71856],"mapped",[71888]],[[71857,71857],"mapped",[71889]],[[71858,71858],"mapped",[71890]],[[71859,71859],"mapped",[71891]],[[71860,71860],"mapped",[71892]],[[71861,71861],"mapped",[71893]],[[71862,71862],"mapped",[71894]],[[71863,71863],"mapped",[71895]],[[71864,71864],"mapped",[71896]],[[71865,71865],"mapped",[71897]],[[71866,71866],"mapped",[71898]],[[71867,71867],"mapped",[71899]],[[71868,71868],"mapped",[71900]],[[71869,71869],"mapped",[71901]],[[71870,71870],"mapped",[71902]],[[71871,71871],"mapped",[71903]],[[71872,71913],"valid"],[[71914,71922],"valid",[],"NV8"],[[71923,71934],"disallowed"],[[71935,71935],"valid"],[[71936,72383],"disallowed"],[[72384,72440],"valid"],[[72441,73727],"disallowed"],[[73728,74606],"valid"],[[74607,74648],"valid"],[[74649,74649],"valid"],[[74650,74751],"disallowed"],[[74752,74850],"valid",[],"NV8"],[[74851,74862],"valid",[],"NV8"],[[74863,74863],"disallowed"],[[74864,74867],"valid",[],"NV8"],[[74868,74868],"valid",[],"NV8"],[[74869,74879],"disallowed"],[[74880,75075],"valid"],[[75076,77823],"disallowed"],[[77824,78894],"valid"],[[78895,82943],"disallowed"],[[82944,83526],"valid"],[[83527,92159],"disallowed"],[[92160,92728],"valid"],[[92729,92735],"disallowed"],[[92736,92766],"valid"],[[92767,92767],"disallowed"],[[92768,92777],"valid"],[[92778,92781],"disallowed"],[[92782,92783],"valid",[],"NV8"],[[92784,92879],"disallowed"],[[92880,92909],"valid"],[[92910,92911],"disallowed"],[[92912,92916],"valid"],[[92917,92917],"valid",[],"NV8"],[[92918,92927],"disallowed"],[[92928,92982],"valid"],[[92983,92991],"valid",[],"NV8"],[[92992,92995],"valid"],[[92996,92997],"valid",[],"NV8"],[[92998,93007],"disallowed"],[[93008,93017],"valid"],[[93018,93018],"disallowed"],[[93019,93025],"valid",[],"NV8"],[[93026,93026],"disallowed"],[[93027,93047],"valid"],[[93048,93052],"disallowed"],[[93053,93071],"valid"],[[93072,93951],"disallowed"],[[93952,94020],"valid"],[[94021,94031],"disallowed"],[[94032,94078],"valid"],[[94079,94094],"disallowed"],[[94095,94111],"valid"],[[94112,110591],"disallowed"],[[110592,110593],"valid"],[[110594,113663],"disallowed"],[[113664,113770],"valid"],[[113771,113775],"disallowed"],[[113776,113788],"valid"],[[113789,113791],"disallowed"],[[113792,113800],"valid"],[[113801,113807],"disallowed"],[[113808,113817],"valid"],[[113818,113819],"disallowed"],[[113820,113820],"valid",[],"NV8"],[[113821,113822],"valid"],[[113823,113823],"valid",[],"NV8"],[[113824,113827],"ignored"],[[113828,118783],"disallowed"],[[118784,119029],"valid",[],"NV8"],[[119030,119039],"disallowed"],[[119040,119078],"valid",[],"NV8"],[[119079,119080],"disallowed"],[[119081,119081],"valid",[],"NV8"],[[119082,119133],"valid",[],"NV8"],[[119134,119134],"mapped",[119127,119141]],[[119135,119135],"mapped",[119128,119141]],[[119136,119136],"mapped",[119128,119141,119150]],[[119137,119137],"mapped",[119128,119141,119151]],[[119138,119138],"mapped",[119128,119141,119152]],[[119139,119139],"mapped",[119128,119141,119153]],[[119140,119140],"mapped",[119128,119141,119154]],[[119141,119154],"valid",[],"NV8"],[[119155,119162],"disallowed"],[[119163,119226],"valid",[],"NV8"],[[119227,119227],"mapped",[119225,119141]],[[119228,119228],"mapped",[119226,119141]],[[119229,119229],"mapped",[119225,119141,119150]],[[119230,119230],"mapped",[119226,119141,119150]],[[119231,119231],"mapped",[119225,119141,119151]],[[119232,119232],"mapped",[119226,119141,119151]],[[119233,119261],"valid",[],"NV8"],[[119262,119272],"valid",[],"NV8"],[[119273,119295],"disallowed"],[[119296,119365],"valid",[],"NV8"],[[119366,119551],"disallowed"],[[119552,119638],"valid",[],"NV8"],[[119639,119647],"disallowed"],[[119648,119665],"valid",[],"NV8"],[[119666,119807],"disallowed"],[[119808,119808],"mapped",[97]],[[119809,119809],"mapped",[98]],[[119810,119810],"mapped",[99]],[[119811,119811],"mapped",[100]],[[119812,119812],"mapped",[101]],[[119813,119813],"mapped",[102]],[[119814,119814],"mapped",[103]],[[119815,119815],"mapped",[104]],[[119816,119816],"mapped",[105]],[[119817,119817],"mapped",[106]],[[119818,119818],"mapped",[107]],[[119819,119819],"mapped",[108]],[[119820,119820],"mapped",[109]],[[119821,119821],"mapped",[110]],[[119822,119822],"mapped",[111]],[[119823,119823],"mapped",[112]],[[119824,119824],"mapped",[113]],[[119825,119825],"mapped",[114]],[[119826,119826],"mapped",[115]],[[119827,119827],"mapped",[116]],[[119828,119828],"mapped",[117]],[[119829,119829],"mapped",[118]],[[119830,119830],"mapped",[119]],[[119831,119831],"mapped",[120]],[[119832,119832],"mapped",[121]],[[119833,119833],"mapped",[122]],[[119834,119834],"mapped",[97]],[[119835,119835],"mapped",[98]],[[119836,119836],"mapped",[99]],[[119837,119837],"mapped",[100]],[[119838,119838],"mapped",[101]],[[119839,119839],"mapped",[102]],[[119840,119840],"mapped",[103]],[[119841,119841],"mapped",[104]],[[119842,119842],"mapped",[105]],[[119843,119843],"mapped",[106]],[[119844,119844],"mapped",[107]],[[119845,119845],"mapped",[108]],[[119846,119846],"mapped",[109]],[[119847,119847],"mapped",[110]],[[119848,119848],"mapped",[111]],[[119849,119849],"mapped",[112]],[[119850,119850],"mapped",[113]],[[119851,119851],"mapped",[114]],[[119852,119852],"mapped",[115]],[[119853,119853],"mapped",[116]],[[119854,119854],"mapped",[117]],[[119855,119855],"mapped",[118]],[[119856,119856],"mapped",[119]],[[119857,119857],"mapped",[120]],[[119858,119858],"mapped",[121]],[[119859,119859],"mapped",[122]],[[119860,119860],"mapped",[97]],[[119861,119861],"mapped",[98]],[[119862,119862],"mapped",[99]],[[119863,119863],"mapped",[100]],[[119864,119864],"mapped",[101]],[[119865,119865],"mapped",[102]],[[119866,119866],"mapped",[103]],[[119867,119867],"mapped",[104]],[[119868,119868],"mapped",[105]],[[119869,119869],"mapped",[106]],[[119870,119870],"mapped",[107]],[[119871,119871],"mapped",[108]],[[119872,119872],"mapped",[109]],[[119873,119873],"mapped",[110]],[[119874,119874],"mapped",[111]],[[119875,119875],"mapped",[112]],[[119876,119876],"mapped",[113]],[[119877,119877],"mapped",[114]],[[119878,119878],"mapped",[115]],[[119879,119879],"mapped",[116]],[[119880,119880],"mapped",[117]],[[119881,119881],"mapped",[118]],[[119882,119882],"mapped",[119]],[[119883,119883],"mapped",[120]],[[119884,119884],"mapped",[121]],[[119885,119885],"mapped",[122]],[[119886,119886],"mapped",[97]],[[119887,119887],"mapped",[98]],[[119888,119888],"mapped",[99]],[[119889,119889],"mapped",[100]],[[119890,119890],"mapped",[101]],[[119891,119891],"mapped",[102]],[[119892,119892],"mapped",[103]],[[119893,119893],"disallowed"],[[119894,119894],"mapped",[105]],[[119895,119895],"mapped",[106]],[[119896,119896],"mapped",[107]],[[119897,119897],"mapped",[108]],[[119898,119898],"mapped",[109]],[[119899,119899],"mapped",[110]],[[119900,119900],"mapped",[111]],[[119901,119901],"mapped",[112]],[[119902,119902],"mapped",[113]],[[119903,119903],"mapped",[114]],[[119904,119904],"mapped",[115]],[[119905,119905],"mapped",[116]],[[119906,119906],"mapped",[117]],[[119907,119907],"mapped",[118]],[[119908,119908],"mapped",[119]],[[119909,119909],"mapped",[120]],[[119910,119910],"mapped",[121]],[[119911,119911],"mapped",[122]],[[119912,119912],"mapped",[97]],[[119913,119913],"mapped",[98]],[[119914,119914],"mapped",[99]],[[119915,119915],"mapped",[100]],[[119916,119916],"mapped",[101]],[[119917,119917],"mapped",[102]],[[119918,119918],"mapped",[103]],[[119919,119919],"mapped",[104]],[[119920,119920],"mapped",[105]],[[119921,119921],"mapped",[106]],[[119922,119922],"mapped",[107]],[[119923,119923],"mapped",[108]],[[119924,119924],"mapped",[109]],[[119925,119925],"mapped",[110]],[[119926,119926],"mapped",[111]],[[119927,119927],"mapped",[112]],[[119928,119928],"mapped",[113]],[[119929,119929],"mapped",[114]],[[119930,119930],"mapped",[115]],[[119931,119931],"mapped",[116]],[[119932,119932],"mapped",[117]],[[119933,119933],"mapped",[118]],[[119934,119934],"mapped",[119]],[[119935,119935],"mapped",[120]],[[119936,119936],"mapped",[121]],[[119937,119937],"mapped",[122]],[[119938,119938],"mapped",[97]],[[119939,119939],"mapped",[98]],[[119940,119940],"mapped",[99]],[[119941,119941],"mapped",[100]],[[119942,119942],"mapped",[101]],[[119943,119943],"mapped",[102]],[[119944,119944],"mapped",[103]],[[119945,119945],"mapped",[104]],[[119946,119946],"mapped",[105]],[[119947,119947],"mapped",[106]],[[119948,119948],"mapped",[107]],[[119949,119949],"mapped",[108]],[[119950,119950],"mapped",[109]],[[119951,119951],"mapped",[110]],[[119952,119952],"mapped",[111]],[[119953,119953],"mapped",[112]],[[119954,119954],"mapped",[113]],[[119955,119955],"mapped",[114]],[[119956,119956],"mapped",[115]],[[119957,119957],"mapped",[116]],[[119958,119958],"mapped",[117]],[[119959,119959],"mapped",[118]],[[119960,119960],"mapped",[119]],[[119961,119961],"mapped",[120]],[[119962,119962],"mapped",[121]],[[119963,119963],"mapped",[122]],[[119964,119964],"mapped",[97]],[[119965,119965],"disallowed"],[[119966,119966],"mapped",[99]],[[119967,119967],"mapped",[100]],[[119968,119969],"disallowed"],[[119970,119970],"mapped",[103]],[[119971,119972],"disallowed"],[[119973,119973],"mapped",[106]],[[119974,119974],"mapped",[107]],[[119975,119976],"disallowed"],[[119977,119977],"mapped",[110]],[[119978,119978],"mapped",[111]],[[119979,119979],"mapped",[112]],[[119980,119980],"mapped",[113]],[[119981,119981],"disallowed"],[[119982,119982],"mapped",[115]],[[119983,119983],"mapped",[116]],[[119984,119984],"mapped",[117]],[[119985,119985],"mapped",[118]],[[119986,119986],"mapped",[119]],[[119987,119987],"mapped",[120]],[[119988,119988],"mapped",[121]],[[119989,119989],"mapped",[122]],[[119990,119990],"mapped",[97]],[[119991,119991],"mapped",[98]],[[119992,119992],"mapped",[99]],[[119993,119993],"mapped",[100]],[[119994,119994],"disallowed"],[[119995,119995],"mapped",[102]],[[119996,119996],"disallowed"],[[119997,119997],"mapped",[104]],[[119998,119998],"mapped",[105]],[[119999,119999],"mapped",[106]],[[120000,120000],"mapped",[107]],[[120001,120001],"mapped",[108]],[[120002,120002],"mapped",[109]],[[120003,120003],"mapped",[110]],[[120004,120004],"disallowed"],[[120005,120005],"mapped",[112]],[[120006,120006],"mapped",[113]],[[120007,120007],"mapped",[114]],[[120008,120008],"mapped",[115]],[[120009,120009],"mapped",[116]],[[120010,120010],"mapped",[117]],[[120011,120011],"mapped",[118]],[[120012,120012],"mapped",[119]],[[120013,120013],"mapped",[120]],[[120014,120014],"mapped",[121]],[[120015,120015],"mapped",[122]],[[120016,120016],"mapped",[97]],[[120017,120017],"mapped",[98]],[[120018,120018],"mapped",[99]],[[120019,120019],"mapped",[100]],[[120020,120020],"mapped",[101]],[[120021,120021],"mapped",[102]],[[120022,120022],"mapped",[103]],[[120023,120023],"mapped",[104]],[[120024,120024],"mapped",[105]],[[120025,120025],"mapped",[106]],[[120026,120026],"mapped",[107]],[[120027,120027],"mapped",[108]],[[120028,120028],"mapped",[109]],[[120029,120029],"mapped",[110]],[[120030,120030],"mapped",[111]],[[120031,120031],"mapped",[112]],[[120032,120032],"mapped",[113]],[[120033,120033],"mapped",[114]],[[120034,120034],"mapped",[115]],[[120035,120035],"mapped",[116]],[[120036,120036],"mapped",[117]],[[120037,120037],"mapped",[118]],[[120038,120038],"mapped",[119]],[[120039,120039],"mapped",[120]],[[120040,120040],"mapped",[121]],[[120041,120041],"mapped",[122]],[[120042,120042],"mapped",[97]],[[120043,120043],"mapped",[98]],[[120044,120044],"mapped",[99]],[[120045,120045],"mapped",[100]],[[120046,120046],"mapped",[101]],[[120047,120047],"mapped",[102]],[[120048,120048],"mapped",[103]],[[120049,120049],"mapped",[104]],[[120050,120050],"mapped",[105]],[[120051,120051],"mapped",[106]],[[120052,120052],"mapped",[107]],[[120053,120053],"mapped",[108]],[[120054,120054],"mapped",[109]],[[120055,120055],"mapped",[110]],[[120056,120056],"mapped",[111]],[[120057,120057],"mapped",[112]],[[120058,120058],"mapped",[113]],[[120059,120059],"mapped",[114]],[[120060,120060],"mapped",[115]],[[120061,120061],"mapped",[116]],[[120062,120062],"mapped",[117]],[[120063,120063],"mapped",[118]],[[120064,120064],"mapped",[119]],[[120065,120065],"mapped",[120]],[[120066,120066],"mapped",[121]],[[120067,120067],"mapped",[122]],[[120068,120068],"mapped",[97]],[[120069,120069],"mapped",[98]],[[120070,120070],"disallowed"],[[120071,120071],"mapped",[100]],[[120072,120072],"mapped",[101]],[[120073,120073],"mapped",[102]],[[120074,120074],"mapped",[103]],[[120075,120076],"disallowed"],[[120077,120077],"mapped",[106]],[[120078,120078],"mapped",[107]],[[120079,120079],"mapped",[108]],[[120080,120080],"mapped",[109]],[[120081,120081],"mapped",[110]],[[120082,120082],"mapped",[111]],[[120083,120083],"mapped",[112]],[[120084,120084],"mapped",[113]],[[120085,120085],"disallowed"],[[120086,120086],"mapped",[115]],[[120087,120087],"mapped",[116]],[[120088,120088],"mapped",[117]],[[120089,120089],"mapped",[118]],[[120090,120090],"mapped",[119]],[[120091,120091],"mapped",[120]],[[120092,120092],"mapped",[121]],[[120093,120093],"disallowed"],[[120094,120094],"mapped",[97]],[[120095,120095],"mapped",[98]],[[120096,120096],"mapped",[99]],[[120097,120097],"mapped",[100]],[[120098,120098],"mapped",[101]],[[120099,120099],"mapped",[102]],[[120100,120100],"mapped",[103]],[[120101,120101],"mapped",[104]],[[120102,120102],"mapped",[105]],[[120103,120103],"mapped",[106]],[[120104,120104],"mapped",[107]],[[120105,120105],"mapped",[108]],[[120106,120106],"mapped",[109]],[[120107,120107],"mapped",[110]],[[120108,120108],"mapped",[111]],[[120109,120109],"mapped",[112]],[[120110,120110],"mapped",[113]],[[120111,120111],"mapped",[114]],[[120112,120112],"mapped",[115]],[[120113,120113],"mapped",[116]],[[120114,120114],"mapped",[117]],[[120115,120115],"mapped",[118]],[[120116,120116],"mapped",[119]],[[120117,120117],"mapped",[120]],[[120118,120118],"mapped",[121]],[[120119,120119],"mapped",[122]],[[120120,120120],"mapped",[97]],[[120121,120121],"mapped",[98]],[[120122,120122],"disallowed"],[[120123,120123],"mapped",[100]],[[120124,120124],"mapped",[101]],[[120125,120125],"mapped",[102]],[[120126,120126],"mapped",[103]],[[120127,120127],"disallowed"],[[120128,120128],"mapped",[105]],[[120129,120129],"mapped",[106]],[[120130,120130],"mapped",[107]],[[120131,120131],"mapped",[108]],[[120132,120132],"mapped",[109]],[[120133,120133],"disallowed"],[[120134,120134],"mapped",[111]],[[120135,120137],"disallowed"],[[120138,120138],"mapped",[115]],[[120139,120139],"mapped",[116]],[[120140,120140],"mapped",[117]],[[120141,120141],"mapped",[118]],[[120142,120142],"mapped",[119]],[[120143,120143],"mapped",[120]],[[120144,120144],"mapped",[121]],[[120145,120145],"disallowed"],[[120146,120146],"mapped",[97]],[[120147,120147],"mapped",[98]],[[120148,120148],"mapped",[99]],[[120149,120149],"mapped",[100]],[[120150,120150],"mapped",[101]],[[120151,120151],"mapped",[102]],[[120152,120152],"mapped",[103]],[[120153,120153],"mapped",[104]],[[120154,120154],"mapped",[105]],[[120155,120155],"mapped",[106]],[[120156,120156],"mapped",[107]],[[120157,120157],"mapped",[108]],[[120158,120158],"mapped",[109]],[[120159,120159],"mapped",[110]],[[120160,120160],"mapped",[111]],[[120161,120161],"mapped",[112]],[[120162,120162],"mapped",[113]],[[120163,120163],"mapped",[114]],[[120164,120164],"mapped",[115]],[[120165,120165],"mapped",[116]],[[120166,120166],"mapped",[117]],[[120167,120167],"mapped",[118]],[[120168,120168],"mapped",[119]],[[120169,120169],"mapped",[120]],[[120170,120170],"mapped",[121]],[[120171,120171],"mapped",[122]],[[120172,120172],"mapped",[97]],[[120173,120173],"mapped",[98]],[[120174,120174],"mapped",[99]],[[120175,120175],"mapped",[100]],[[120176,120176],"mapped",[101]],[[120177,120177],"mapped",[102]],[[120178,120178],"mapped",[103]],[[120179,120179],"mapped",[104]],[[120180,120180],"mapped",[105]],[[120181,120181],"mapped",[106]],[[120182,120182],"mapped",[107]],[[120183,120183],"mapped",[108]],[[120184,120184],"mapped",[109]],[[120185,120185],"mapped",[110]],[[120186,120186],"mapped",[111]],[[120187,120187],"mapped",[112]],[[120188,120188],"mapped",[113]],[[120189,120189],"mapped",[114]],[[120190,120190],"mapped",[115]],[[120191,120191],"mapped",[116]],[[120192,120192],"mapped",[117]],[[120193,120193],"mapped",[118]],[[120194,120194],"mapped",[119]],[[120195,120195],"mapped",[120]],[[120196,120196],"mapped",[121]],[[120197,120197],"mapped",[122]],[[120198,120198],"mapped",[97]],[[120199,120199],"mapped",[98]],[[120200,120200],"mapped",[99]],[[120201,120201],"mapped",[100]],[[120202,120202],"mapped",[101]],[[120203,120203],"mapped",[102]],[[120204,120204],"mapped",[103]],[[120205,120205],"mapped",[104]],[[120206,120206],"mapped",[105]],[[120207,120207],"mapped",[106]],[[120208,120208],"mapped",[107]],[[120209,120209],"mapped",[108]],[[120210,120210],"mapped",[109]],[[120211,120211],"mapped",[110]],[[120212,120212],"mapped",[111]],[[120213,120213],"mapped",[112]],[[120214,120214],"mapped",[113]],[[120215,120215],"mapped",[114]],[[120216,120216],"mapped",[115]],[[120217,120217],"mapped",[116]],[[120218,120218],"mapped",[117]],[[120219,120219],"mapped",[118]],[[120220,120220],"mapped",[119]],[[120221,120221],"mapped",[120]],[[120222,120222],"mapped",[121]],[[120223,120223],"mapped",[122]],[[120224,120224],"mapped",[97]],[[120225,120225],"mapped",[98]],[[120226,120226],"mapped",[99]],[[120227,120227],"mapped",[100]],[[120228,120228],"mapped",[101]],[[120229,120229],"mapped",[102]],[[120230,120230],"mapped",[103]],[[120231,120231],"mapped",[104]],[[120232,120232],"mapped",[105]],[[120233,120233],"mapped",[106]],[[120234,120234],"mapped",[107]],[[120235,120235],"mapped",[108]],[[120236,120236],"mapped",[109]],[[120237,120237],"mapped",[110]],[[120238,120238],"mapped",[111]],[[120239,120239],"mapped",[112]],[[120240,120240],"mapped",[113]],[[120241,120241],"mapped",[114]],[[120242,120242],"mapped",[115]],[[120243,120243],"mapped",[116]],[[120244,120244],"mapped",[117]],[[120245,120245],"mapped",[118]],[[120246,120246],"mapped",[119]],[[120247,120247],"mapped",[120]],[[120248,120248],"mapped",[121]],[[120249,120249],"mapped",[122]],[[120250,120250],"mapped",[97]],[[120251,120251],"mapped",[98]],[[120252,120252],"mapped",[99]],[[120253,120253],"mapped",[100]],[[120254,120254],"mapped",[101]],[[120255,120255],"mapped",[102]],[[120256,120256],"mapped",[103]],[[120257,120257],"mapped",[104]],[[120258,120258],"mapped",[105]],[[120259,120259],"mapped",[106]],[[120260,120260],"mapped",[107]],[[120261,120261],"mapped",[108]],[[120262,120262],"mapped",[109]],[[120263,120263],"mapped",[110]],[[120264,120264],"mapped",[111]],[[120265,120265],"mapped",[112]],[[120266,120266],"mapped",[113]],[[120267,120267],"mapped",[114]],[[120268,120268],"mapped",[115]],[[120269,120269],"mapped",[116]],[[120270,120270],"mapped",[117]],[[120271,120271],"mapped",[118]],[[120272,120272],"mapped",[119]],[[120273,120273],"mapped",[120]],[[120274,120274],"mapped",[121]],[[120275,120275],"mapped",[122]],[[120276,120276],"mapped",[97]],[[120277,120277],"mapped",[98]],[[120278,120278],"mapped",[99]],[[120279,120279],"mapped",[100]],[[120280,120280],"mapped",[101]],[[120281,120281],"mapped",[102]],[[120282,120282],"mapped",[103]],[[120283,120283],"mapped",[104]],[[120284,120284],"mapped",[105]],[[120285,120285],"mapped",[106]],[[120286,120286],"mapped",[107]],[[120287,120287],"mapped",[108]],[[120288,120288],"mapped",[109]],[[120289,120289],"mapped",[110]],[[120290,120290],"mapped",[111]],[[120291,120291],"mapped",[112]],[[120292,120292],"mapped",[113]],[[120293,120293],"mapped",[114]],[[120294,120294],"mapped",[115]],[[120295,120295],"mapped",[116]],[[120296,120296],"mapped",[117]],[[120297,120297],"mapped",[118]],[[120298,120298],"mapped",[119]],[[120299,120299],"mapped",[120]],[[120300,120300],"mapped",[121]],[[120301,120301],"mapped",[122]],[[120302,120302],"mapped",[97]],[[120303,120303],"mapped",[98]],[[120304,120304],"mapped",[99]],[[120305,120305],"mapped",[100]],[[120306,120306],"mapped",[101]],[[120307,120307],"mapped",[102]],[[120308,120308],"mapped",[103]],[[120309,120309],"mapped",[104]],[[120310,120310],"mapped",[105]],[[120311,120311],"mapped",[106]],[[120312,120312],"mapped",[107]],[[120313,120313],"mapped",[108]],[[120314,120314],"mapped",[109]],[[120315,120315],"mapped",[110]],[[120316,120316],"mapped",[111]],[[120317,120317],"mapped",[112]],[[120318,120318],"mapped",[113]],[[120319,120319],"mapped",[114]],[[120320,120320],"mapped",[115]],[[120321,120321],"mapped",[116]],[[120322,120322],"mapped",[117]],[[120323,120323],"mapped",[118]],[[120324,120324],"mapped",[119]],[[120325,120325],"mapped",[120]],[[120326,120326],"mapped",[121]],[[120327,120327],"mapped",[122]],[[120328,120328],"mapped",[97]],[[120329,120329],"mapped",[98]],[[120330,120330],"mapped",[99]],[[120331,120331],"mapped",[100]],[[120332,120332],"mapped",[101]],[[120333,120333],"mapped",[102]],[[120334,120334],"mapped",[103]],[[120335,120335],"mapped",[104]],[[120336,120336],"mapped",[105]],[[120337,120337],"mapped",[106]],[[120338,120338],"mapped",[107]],[[120339,120339],"mapped",[108]],[[120340,120340],"mapped",[109]],[[120341,120341],"mapped",[110]],[[120342,120342],"mapped",[111]],[[120343,120343],"mapped",[112]],[[120344,120344],"mapped",[113]],[[120345,120345],"mapped",[114]],[[120346,120346],"mapped",[115]],[[120347,120347],"mapped",[116]],[[120348,120348],"mapped",[117]],[[120349,120349],"mapped",[118]],[[120350,120350],"mapped",[119]],[[120351,120351],"mapped",[120]],[[120352,120352],"mapped",[121]],[[120353,120353],"mapped",[122]],[[120354,120354],"mapped",[97]],[[120355,120355],"mapped",[98]],[[120356,120356],"mapped",[99]],[[120357,120357],"mapped",[100]],[[120358,120358],"mapped",[101]],[[120359,120359],"mapped",[102]],[[120360,120360],"mapped",[103]],[[120361,120361],"mapped",[104]],[[120362,120362],"mapped",[105]],[[120363,120363],"mapped",[106]],[[120364,120364],"mapped",[107]],[[120365,120365],"mapped",[108]],[[120366,120366],"mapped",[109]],[[120367,120367],"mapped",[110]],[[120368,120368],"mapped",[111]],[[120369,120369],"mapped",[112]],[[120370,120370],"mapped",[113]],[[120371,120371],"mapped",[114]],[[120372,120372],"mapped",[115]],[[120373,120373],"mapped",[116]],[[120374,120374],"mapped",[117]],[[120375,120375],"mapped",[118]],[[120376,120376],"mapped",[119]],[[120377,120377],"mapped",[120]],[[120378,120378],"mapped",[121]],[[120379,120379],"mapped",[122]],[[120380,120380],"mapped",[97]],[[120381,120381],"mapped",[98]],[[120382,120382],"mapped",[99]],[[120383,120383],"mapped",[100]],[[120384,120384],"mapped",[101]],[[120385,120385],"mapped",[102]],[[120386,120386],"mapped",[103]],[[120387,120387],"mapped",[104]],[[120388,120388],"mapped",[105]],[[120389,120389],"mapped",[106]],[[120390,120390],"mapped",[107]],[[120391,120391],"mapped",[108]],[[120392,120392],"mapped",[109]],[[120393,120393],"mapped",[110]],[[120394,120394],"mapped",[111]],[[120395,120395],"mapped",[112]],[[120396,120396],"mapped",[113]],[[120397,120397],"mapped",[114]],[[120398,120398],"mapped",[115]],[[120399,120399],"mapped",[116]],[[120400,120400],"mapped",[117]],[[120401,120401],"mapped",[118]],[[120402,120402],"mapped",[119]],[[120403,120403],"mapped",[120]],[[120404,120404],"mapped",[121]],[[120405,120405],"mapped",[122]],[[120406,120406],"mapped",[97]],[[120407,120407],"mapped",[98]],[[120408,120408],"mapped",[99]],[[120409,120409],"mapped",[100]],[[120410,120410],"mapped",[101]],[[120411,120411],"mapped",[102]],[[120412,120412],"mapped",[103]],[[120413,120413],"mapped",[104]],[[120414,120414],"mapped",[105]],[[120415,120415],"mapped",[106]],[[120416,120416],"mapped",[107]],[[120417,120417],"mapped",[108]],[[120418,120418],"mapped",[109]],[[120419,120419],"mapped",[110]],[[120420,120420],"mapped",[111]],[[120421,120421],"mapped",[112]],[[120422,120422],"mapped",[113]],[[120423,120423],"mapped",[114]],[[120424,120424],"mapped",[115]],[[120425,120425],"mapped",[116]],[[120426,120426],"mapped",[117]],[[120427,120427],"mapped",[118]],[[120428,120428],"mapped",[119]],[[120429,120429],"mapped",[120]],[[120430,120430],"mapped",[121]],[[120431,120431],"mapped",[122]],[[120432,120432],"mapped",[97]],[[120433,120433],"mapped",[98]],[[120434,120434],"mapped",[99]],[[120435,120435],"mapped",[100]],[[120436,120436],"mapped",[101]],[[120437,120437],"mapped",[102]],[[120438,120438],"mapped",[103]],[[120439,120439],"mapped",[104]],[[120440,120440],"mapped",[105]],[[120441,120441],"mapped",[106]],[[120442,120442],"mapped",[107]],[[120443,120443],"mapped",[108]],[[120444,120444],"mapped",[109]],[[120445,120445],"mapped",[110]],[[120446,120446],"mapped",[111]],[[120447,120447],"mapped",[112]],[[120448,120448],"mapped",[113]],[[120449,120449],"mapped",[114]],[[120450,120450],"mapped",[115]],[[120451,120451],"mapped",[116]],[[120452,120452],"mapped",[117]],[[120453,120453],"mapped",[118]],[[120454,120454],"mapped",[119]],[[120455,120455],"mapped",[120]],[[120456,120456],"mapped",[121]],[[120457,120457],"mapped",[122]],[[120458,120458],"mapped",[97]],[[120459,120459],"mapped",[98]],[[120460,120460],"mapped",[99]],[[120461,120461],"mapped",[100]],[[120462,120462],"mapped",[101]],[[120463,120463],"mapped",[102]],[[120464,120464],"mapped",[103]],[[120465,120465],"mapped",[104]],[[120466,120466],"mapped",[105]],[[120467,120467],"mapped",[106]],[[120468,120468],"mapped",[107]],[[120469,120469],"mapped",[108]],[[120470,120470],"mapped",[109]],[[120471,120471],"mapped",[110]],[[120472,120472],"mapped",[111]],[[120473,120473],"mapped",[112]],[[120474,120474],"mapped",[113]],[[120475,120475],"mapped",[114]],[[120476,120476],"mapped",[115]],[[120477,120477],"mapped",[116]],[[120478,120478],"mapped",[117]],[[120479,120479],"mapped",[118]],[[120480,120480],"mapped",[119]],[[120481,120481],"mapped",[120]],[[120482,120482],"mapped",[121]],[[120483,120483],"mapped",[122]],[[120484,120484],"mapped",[305]],[[120485,120485],"mapped",[567]],[[120486,120487],"disallowed"],[[120488,120488],"mapped",[945]],[[120489,120489],"mapped",[946]],[[120490,120490],"mapped",[947]],[[120491,120491],"mapped",[948]],[[120492,120492],"mapped",[949]],[[120493,120493],"mapped",[950]],[[120494,120494],"mapped",[951]],[[120495,120495],"mapped",[952]],[[120496,120496],"mapped",[953]],[[120497,120497],"mapped",[954]],[[120498,120498],"mapped",[955]],[[120499,120499],"mapped",[956]],[[120500,120500],"mapped",[957]],[[120501,120501],"mapped",[958]],[[120502,120502],"mapped",[959]],[[120503,120503],"mapped",[960]],[[120504,120504],"mapped",[961]],[[120505,120505],"mapped",[952]],[[120506,120506],"mapped",[963]],[[120507,120507],"mapped",[964]],[[120508,120508],"mapped",[965]],[[120509,120509],"mapped",[966]],[[120510,120510],"mapped",[967]],[[120511,120511],"mapped",[968]],[[120512,120512],"mapped",[969]],[[120513,120513],"mapped",[8711]],[[120514,120514],"mapped",[945]],[[120515,120515],"mapped",[946]],[[120516,120516],"mapped",[947]],[[120517,120517],"mapped",[948]],[[120518,120518],"mapped",[949]],[[120519,120519],"mapped",[950]],[[120520,120520],"mapped",[951]],[[120521,120521],"mapped",[952]],[[120522,120522],"mapped",[953]],[[120523,120523],"mapped",[954]],[[120524,120524],"mapped",[955]],[[120525,120525],"mapped",[956]],[[120526,120526],"mapped",[957]],[[120527,120527],"mapped",[958]],[[120528,120528],"mapped",[959]],[[120529,120529],"mapped",[960]],[[120530,120530],"mapped",[961]],[[120531,120532],"mapped",[963]],[[120533,120533],"mapped",[964]],[[120534,120534],"mapped",[965]],[[120535,120535],"mapped",[966]],[[120536,120536],"mapped",[967]],[[120537,120537],"mapped",[968]],[[120538,120538],"mapped",[969]],[[120539,120539],"mapped",[8706]],[[120540,120540],"mapped",[949]],[[120541,120541],"mapped",[952]],[[120542,120542],"mapped",[954]],[[120543,120543],"mapped",[966]],[[120544,120544],"mapped",[961]],[[120545,120545],"mapped",[960]],[[120546,120546],"mapped",[945]],[[120547,120547],"mapped",[946]],[[120548,120548],"mapped",[947]],[[120549,120549],"mapped",[948]],[[120550,120550],"mapped",[949]],[[120551,120551],"mapped",[950]],[[120552,120552],"mapped",[951]],[[120553,120553],"mapped",[952]],[[120554,120554],"mapped",[953]],[[120555,120555],"mapped",[954]],[[120556,120556],"mapped",[955]],[[120557,120557],"mapped",[956]],[[120558,120558],"mapped",[957]],[[120559,120559],"mapped",[958]],[[120560,120560],"mapped",[959]],[[120561,120561],"mapped",[960]],[[120562,120562],"mapped",[961]],[[120563,120563],"mapped",[952]],[[120564,120564],"mapped",[963]],[[120565,120565],"mapped",[964]],[[120566,120566],"mapped",[965]],[[120567,120567],"mapped",[966]],[[120568,120568],"mapped",[967]],[[120569,120569],"mapped",[968]],[[120570,120570],"mapped",[969]],[[120571,120571],"mapped",[8711]],[[120572,120572],"mapped",[945]],[[120573,120573],"mapped",[946]],[[120574,120574],"mapped",[947]],[[120575,120575],"mapped",[948]],[[120576,120576],"mapped",[949]],[[120577,120577],"mapped",[950]],[[120578,120578],"mapped",[951]],[[120579,120579],"mapped",[952]],[[120580,120580],"mapped",[953]],[[120581,120581],"mapped",[954]],[[120582,120582],"mapped",[955]],[[120583,120583],"mapped",[956]],[[120584,120584],"mapped",[957]],[[120585,120585],"mapped",[958]],[[120586,120586],"mapped",[959]],[[120587,120587],"mapped",[960]],[[120588,120588],"mapped",[961]],[[120589,120590],"mapped",[963]],[[120591,120591],"mapped",[964]],[[120592,120592],"mapped",[965]],[[120593,120593],"mapped",[966]],[[120594,120594],"mapped",[967]],[[120595,120595],"mapped",[968]],[[120596,120596],"mapped",[969]],[[120597,120597],"mapped",[8706]],[[120598,120598],"mapped",[949]],[[120599,120599],"mapped",[952]],[[120600,120600],"mapped",[954]],[[120601,120601],"mapped",[966]],[[120602,120602],"mapped",[961]],[[120603,120603],"mapped",[960]],[[120604,120604],"mapped",[945]],[[120605,120605],"mapped",[946]],[[120606,120606],"mapped",[947]],[[120607,120607],"mapped",[948]],[[120608,120608],"mapped",[949]],[[120609,120609],"mapped",[950]],[[120610,120610],"mapped",[951]],[[120611,120611],"mapped",[952]],[[120612,120612],"mapped",[953]],[[120613,120613],"mapped",[954]],[[120614,120614],"mapped",[955]],[[120615,120615],"mapped",[956]],[[120616,120616],"mapped",[957]],[[120617,120617],"mapped",[958]],[[120618,120618],"mapped",[959]],[[120619,120619],"mapped",[960]],[[120620,120620],"mapped",[961]],[[120621,120621],"mapped",[952]],[[120622,120622],"mapped",[963]],[[120623,120623],"mapped",[964]],[[120624,120624],"mapped",[965]],[[120625,120625],"mapped",[966]],[[120626,120626],"mapped",[967]],[[120627,120627],"mapped",[968]],[[120628,120628],"mapped",[969]],[[120629,120629],"mapped",[8711]],[[120630,120630],"mapped",[945]],[[120631,120631],"mapped",[946]],[[120632,120632],"mapped",[947]],[[120633,120633],"mapped",[948]],[[120634,120634],"mapped",[949]],[[120635,120635],"mapped",[950]],[[120636,120636],"mapped",[951]],[[120637,120637],"mapped",[952]],[[120638,120638],"mapped",[953]],[[120639,120639],"mapped",[954]],[[120640,120640],"mapped",[955]],[[120641,120641],"mapped",[956]],[[120642,120642],"mapped",[957]],[[120643,120643],"mapped",[958]],[[120644,120644],"mapped",[959]],[[120645,120645],"mapped",[960]],[[120646,120646],"mapped",[961]],[[120647,120648],"mapped",[963]],[[120649,120649],"mapped",[964]],[[120650,120650],"mapped",[965]],[[120651,120651],"mapped",[966]],[[120652,120652],"mapped",[967]],[[120653,120653],"mapped",[968]],[[120654,120654],"mapped",[969]],[[120655,120655],"mapped",[8706]],[[120656,120656],"mapped",[949]],[[120657,120657],"mapped",[952]],[[120658,120658],"mapped",[954]],[[120659,120659],"mapped",[966]],[[120660,120660],"mapped",[961]],[[120661,120661],"mapped",[960]],[[120662,120662],"mapped",[945]],[[120663,120663],"mapped",[946]],[[120664,120664],"mapped",[947]],[[120665,120665],"mapped",[948]],[[120666,120666],"mapped",[949]],[[120667,120667],"mapped",[950]],[[120668,120668],"mapped",[951]],[[120669,120669],"mapped",[952]],[[120670,120670],"mapped",[953]],[[120671,120671],"mapped",[954]],[[120672,120672],"mapped",[955]],[[120673,120673],"mapped",[956]],[[120674,120674],"mapped",[957]],[[120675,120675],"mapped",[958]],[[120676,120676],"mapped",[959]],[[120677,120677],"mapped",[960]],[[120678,120678],"mapped",[961]],[[120679,120679],"mapped",[952]],[[120680,120680],"mapped",[963]],[[120681,120681],"mapped",[964]],[[120682,120682],"mapped",[965]],[[120683,120683],"mapped",[966]],[[120684,120684],"mapped",[967]],[[120685,120685],"mapped",[968]],[[120686,120686],"mapped",[969]],[[120687,120687],"mapped",[8711]],[[120688,120688],"mapped",[945]],[[120689,120689],"mapped",[946]],[[120690,120690],"mapped",[947]],[[120691,120691],"mapped",[948]],[[120692,120692],"mapped",[949]],[[120693,120693],"mapped",[950]],[[120694,120694],"mapped",[951]],[[120695,120695],"mapped",[952]],[[120696,120696],"mapped",[953]],[[120697,120697],"mapped",[954]],[[120698,120698],"mapped",[955]],[[120699,120699],"mapped",[956]],[[120700,120700],"mapped",[957]],[[120701,120701],"mapped",[958]],[[120702,120702],"mapped",[959]],[[120703,120703],"mapped",[960]],[[120704,120704],"mapped",[961]],[[120705,120706],"mapped",[963]],[[120707,120707],"mapped",[964]],[[120708,120708],"mapped",[965]],[[120709,120709],"mapped",[966]],[[120710,120710],"mapped",[967]],[[120711,120711],"mapped",[968]],[[120712,120712],"mapped",[969]],[[120713,120713],"mapped",[8706]],[[120714,120714],"mapped",[949]],[[120715,120715],"mapped",[952]],[[120716,120716],"mapped",[954]],[[120717,120717],"mapped",[966]],[[120718,120718],"mapped",[961]],[[120719,120719],"mapped",[960]],[[120720,120720],"mapped",[945]],[[120721,120721],"mapped",[946]],[[120722,120722],"mapped",[947]],[[120723,120723],"mapped",[948]],[[120724,120724],"mapped",[949]],[[120725,120725],"mapped",[950]],[[120726,120726],"mapped",[951]],[[120727,120727],"mapped",[952]],[[120728,120728],"mapped",[953]],[[120729,120729],"mapped",[954]],[[120730,120730],"mapped",[955]],[[120731,120731],"mapped",[956]],[[120732,120732],"mapped",[957]],[[120733,120733],"mapped",[958]],[[120734,120734],"mapped",[959]],[[120735,120735],"mapped",[960]],[[120736,120736],"mapped",[961]],[[120737,120737],"mapped",[952]],[[120738,120738],"mapped",[963]],[[120739,120739],"mapped",[964]],[[120740,120740],"mapped",[965]],[[120741,120741],"mapped",[966]],[[120742,120742],"mapped",[967]],[[120743,120743],"mapped",[968]],[[120744,120744],"mapped",[969]],[[120745,120745],"mapped",[8711]],[[120746,120746],"mapped",[945]],[[120747,120747],"mapped",[946]],[[120748,120748],"mapped",[947]],[[120749,120749],"mapped",[948]],[[120750,120750],"mapped",[949]],[[120751,120751],"mapped",[950]],[[120752,120752],"mapped",[951]],[[120753,120753],"mapped",[952]],[[120754,120754],"mapped",[953]],[[120755,120755],"mapped",[954]],[[120756,120756],"mapped",[955]],[[120757,120757],"mapped",[956]],[[120758,120758],"mapped",[957]],[[120759,120759],"mapped",[958]],[[120760,120760],"mapped",[959]],[[120761,120761],"mapped",[960]],[[120762,120762],"mapped",[961]],[[120763,120764],"mapped",[963]],[[120765,120765],"mapped",[964]],[[120766,120766],"mapped",[965]],[[120767,120767],"mapped",[966]],[[120768,120768],"mapped",[967]],[[120769,120769],"mapped",[968]],[[120770,120770],"mapped",[969]],[[120771,120771],"mapped",[8706]],[[120772,120772],"mapped",[949]],[[120773,120773],"mapped",[952]],[[120774,120774],"mapped",[954]],[[120775,120775],"mapped",[966]],[[120776,120776],"mapped",[961]],[[120777,120777],"mapped",[960]],[[120778,120779],"mapped",[989]],[[120780,120781],"disallowed"],[[120782,120782],"mapped",[48]],[[120783,120783],"mapped",[49]],[[120784,120784],"mapped",[50]],[[120785,120785],"mapped",[51]],[[120786,120786],"mapped",[52]],[[120787,120787],"mapped",[53]],[[120788,120788],"mapped",[54]],[[120789,120789],"mapped",[55]],[[120790,120790],"mapped",[56]],[[120791,120791],"mapped",[57]],[[120792,120792],"mapped",[48]],[[120793,120793],"mapped",[49]],[[120794,120794],"mapped",[50]],[[120795,120795],"mapped",[51]],[[120796,120796],"mapped",[52]],[[120797,120797],"mapped",[53]],[[120798,120798],"mapped",[54]],[[120799,120799],"mapped",[55]],[[120800,120800],"mapped",[56]],[[120801,120801],"mapped",[57]],[[120802,120802],"mapped",[48]],[[120803,120803],"mapped",[49]],[[120804,120804],"mapped",[50]],[[120805,120805],"mapped",[51]],[[120806,120806],"mapped",[52]],[[120807,120807],"mapped",[53]],[[120808,120808],"mapped",[54]],[[120809,120809],"mapped",[55]],[[120810,120810],"mapped",[56]],[[120811,120811],"mapped",[57]],[[120812,120812],"mapped",[48]],[[120813,120813],"mapped",[49]],[[120814,120814],"mapped",[50]],[[120815,120815],"mapped",[51]],[[120816,120816],"mapped",[52]],[[120817,120817],"mapped",[53]],[[120818,120818],"mapped",[54]],[[120819,120819],"mapped",[55]],[[120820,120820],"mapped",[56]],[[120821,120821],"mapped",[57]],[[120822,120822],"mapped",[48]],[[120823,120823],"mapped",[49]],[[120824,120824],"mapped",[50]],[[120825,120825],"mapped",[51]],[[120826,120826],"mapped",[52]],[[120827,120827],"mapped",[53]],[[120828,120828],"mapped",[54]],[[120829,120829],"mapped",[55]],[[120830,120830],"mapped",[56]],[[120831,120831],"mapped",[57]],[[120832,121343],"valid",[],"NV8"],[[121344,121398],"valid"],[[121399,121402],"valid",[],"NV8"],[[121403,121452],"valid"],[[121453,121460],"valid",[],"NV8"],[[121461,121461],"valid"],[[121462,121475],"valid",[],"NV8"],[[121476,121476],"valid"],[[121477,121483],"valid",[],"NV8"],[[121484,121498],"disallowed"],[[121499,121503],"valid"],[[121504,121504],"disallowed"],[[121505,121519],"valid"],[[121520,124927],"disallowed"],[[124928,125124],"valid"],[[125125,125126],"disallowed"],[[125127,125135],"valid",[],"NV8"],[[125136,125142],"valid"],[[125143,126463],"disallowed"],[[126464,126464],"mapped",[1575]],[[126465,126465],"mapped",[1576]],[[126466,126466],"mapped",[1580]],[[126467,126467],"mapped",[1583]],[[126468,126468],"disallowed"],[[126469,126469],"mapped",[1608]],[[126470,126470],"mapped",[1586]],[[126471,126471],"mapped",[1581]],[[126472,126472],"mapped",[1591]],[[126473,126473],"mapped",[1610]],[[126474,126474],"mapped",[1603]],[[126475,126475],"mapped",[1604]],[[126476,126476],"mapped",[1605]],[[126477,126477],"mapped",[1606]],[[126478,126478],"mapped",[1587]],[[126479,126479],"mapped",[1593]],[[126480,126480],"mapped",[1601]],[[126481,126481],"mapped",[1589]],[[126482,126482],"mapped",[1602]],[[126483,126483],"mapped",[1585]],[[126484,126484],"mapped",[1588]],[[126485,126485],"mapped",[1578]],[[126486,126486],"mapped",[1579]],[[126487,126487],"mapped",[1582]],[[126488,126488],"mapped",[1584]],[[126489,126489],"mapped",[1590]],[[126490,126490],"mapped",[1592]],[[126491,126491],"mapped",[1594]],[[126492,126492],"mapped",[1646]],[[126493,126493],"mapped",[1722]],[[126494,126494],"mapped",[1697]],[[126495,126495],"mapped",[1647]],[[126496,126496],"disallowed"],[[126497,126497],"mapped",[1576]],[[126498,126498],"mapped",[1580]],[[126499,126499],"disallowed"],[[126500,126500],"mapped",[1607]],[[126501,126502],"disallowed"],[[126503,126503],"mapped",[1581]],[[126504,126504],"disallowed"],[[126505,126505],"mapped",[1610]],[[126506,126506],"mapped",[1603]],[[126507,126507],"mapped",[1604]],[[126508,126508],"mapped",[1605]],[[126509,126509],"mapped",[1606]],[[126510,126510],"mapped",[1587]],[[126511,126511],"mapped",[1593]],[[126512,126512],"mapped",[1601]],[[126513,126513],"mapped",[1589]],[[126514,126514],"mapped",[1602]],[[126515,126515],"disallowed"],[[126516,126516],"mapped",[1588]],[[126517,126517],"mapped",[1578]],[[126518,126518],"mapped",[1579]],[[126519,126519],"mapped",[1582]],[[126520,126520],"disallowed"],[[126521,126521],"mapped",[1590]],[[126522,126522],"disallowed"],[[126523,126523],"mapped",[1594]],[[126524,126529],"disallowed"],[[126530,126530],"mapped",[1580]],[[126531,126534],"disallowed"],[[126535,126535],"mapped",[1581]],[[126536,126536],"disallowed"],[[126537,126537],"mapped",[1610]],[[126538,126538],"disallowed"],[[126539,126539],"mapped",[1604]],[[126540,126540],"disallowed"],[[126541,126541],"mapped",[1606]],[[126542,126542],"mapped",[1587]],[[126543,126543],"mapped",[1593]],[[126544,126544],"disallowed"],[[126545,126545],"mapped",[1589]],[[126546,126546],"mapped",[1602]],[[126547,126547],"disallowed"],[[126548,126548],"mapped",[1588]],[[126549,126550],"disallowed"],[[126551,126551],"mapped",[1582]],[[126552,126552],"disallowed"],[[126553,126553],"mapped",[1590]],[[126554,126554],"disallowed"],[[126555,126555],"mapped",[1594]],[[126556,126556],"disallowed"],[[126557,126557],"mapped",[1722]],[[126558,126558],"disallowed"],[[126559,126559],"mapped",[1647]],[[126560,126560],"disallowed"],[[126561,126561],"mapped",[1576]],[[126562,126562],"mapped",[1580]],[[126563,126563],"disallowed"],[[126564,126564],"mapped",[1607]],[[126565,126566],"disallowed"],[[126567,126567],"mapped",[1581]],[[126568,126568],"mapped",[1591]],[[126569,126569],"mapped",[1610]],[[126570,126570],"mapped",[1603]],[[126571,126571],"disallowed"],[[126572,126572],"mapped",[1605]],[[126573,126573],"mapped",[1606]],[[126574,126574],"mapped",[1587]],[[126575,126575],"mapped",[1593]],[[126576,126576],"mapped",[1601]],[[126577,126577],"mapped",[1589]],[[126578,126578],"mapped",[1602]],[[126579,126579],"disallowed"],[[126580,126580],"mapped",[1588]],[[126581,126581],"mapped",[1578]],[[126582,126582],"mapped",[1579]],[[126583,126583],"mapped",[1582]],[[126584,126584],"disallowed"],[[126585,126585],"mapped",[1590]],[[126586,126586],"mapped",[1592]],[[126587,126587],"mapped",[1594]],[[126588,126588],"mapped",[1646]],[[126589,126589],"disallowed"],[[126590,126590],"mapped",[1697]],[[126591,126591],"disallowed"],[[126592,126592],"mapped",[1575]],[[126593,126593],"mapped",[1576]],[[126594,126594],"mapped",[1580]],[[126595,126595],"mapped",[1583]],[[126596,126596],"mapped",[1607]],[[126597,126597],"mapped",[1608]],[[126598,126598],"mapped",[1586]],[[126599,126599],"mapped",[1581]],[[126600,126600],"mapped",[1591]],[[126601,126601],"mapped",[1610]],[[126602,126602],"disallowed"],[[126603,126603],"mapped",[1604]],[[126604,126604],"mapped",[1605]],[[126605,126605],"mapped",[1606]],[[126606,126606],"mapped",[1587]],[[126607,126607],"mapped",[1593]],[[126608,126608],"mapped",[1601]],[[126609,126609],"mapped",[1589]],[[126610,126610],"mapped",[1602]],[[126611,126611],"mapped",[1585]],[[126612,126612],"mapped",[1588]],[[126613,126613],"mapped",[1578]],[[126614,126614],"mapped",[1579]],[[126615,126615],"mapped",[1582]],[[126616,126616],"mapped",[1584]],[[126617,126617],"mapped",[1590]],[[126618,126618],"mapped",[1592]],[[126619,126619],"mapped",[1594]],[[126620,126624],"disallowed"],[[126625,126625],"mapped",[1576]],[[126626,126626],"mapped",[1580]],[[126627,126627],"mapped",[1583]],[[126628,126628],"disallowed"],[[126629,126629],"mapped",[1608]],[[126630,126630],"mapped",[1586]],[[126631,126631],"mapped",[1581]],[[126632,126632],"mapped",[1591]],[[126633,126633],"mapped",[1610]],[[126634,126634],"disallowed"],[[126635,126635],"mapped",[1604]],[[126636,126636],"mapped",[1605]],[[126637,126637],"mapped",[1606]],[[126638,126638],"mapped",[1587]],[[126639,126639],"mapped",[1593]],[[126640,126640],"mapped",[1601]],[[126641,126641],"mapped",[1589]],[[126642,126642],"mapped",[1602]],[[126643,126643],"mapped",[1585]],[[126644,126644],"mapped",[1588]],[[126645,126645],"mapped",[1578]],[[126646,126646],"mapped",[1579]],[[126647,126647],"mapped",[1582]],[[126648,126648],"mapped",[1584]],[[126649,126649],"mapped",[1590]],[[126650,126650],"mapped",[1592]],[[126651,126651],"mapped",[1594]],[[126652,126703],"disallowed"],[[126704,126705],"valid",[],"NV8"],[[126706,126975],"disallowed"],[[126976,127019],"valid",[],"NV8"],[[127020,127023],"disallowed"],[[127024,127123],"valid",[],"NV8"],[[127124,127135],"disallowed"],[[127136,127150],"valid",[],"NV8"],[[127151,127152],"disallowed"],[[127153,127166],"valid",[],"NV8"],[[127167,127167],"valid",[],"NV8"],[[127168,127168],"disallowed"],[[127169,127183],"valid",[],"NV8"],[[127184,127184],"disallowed"],[[127185,127199],"valid",[],"NV8"],[[127200,127221],"valid",[],"NV8"],[[127222,127231],"disallowed"],[[127232,127232],"disallowed"],[[127233,127233],"disallowed_STD3_mapped",[48,44]],[[127234,127234],"disallowed_STD3_mapped",[49,44]],[[127235,127235],"disallowed_STD3_mapped",[50,44]],[[127236,127236],"disallowed_STD3_mapped",[51,44]],[[127237,127237],"disallowed_STD3_mapped",[52,44]],[[127238,127238],"disallowed_STD3_mapped",[53,44]],[[127239,127239],"disallowed_STD3_mapped",[54,44]],[[127240,127240],"disallowed_STD3_mapped",[55,44]],[[127241,127241],"disallowed_STD3_mapped",[56,44]],[[127242,127242],"disallowed_STD3_mapped",[57,44]],[[127243,127244],"valid",[],"NV8"],[[127245,127247],"disallowed"],[[127248,127248],"disallowed_STD3_mapped",[40,97,41]],[[127249,127249],"disallowed_STD3_mapped",[40,98,41]],[[127250,127250],"disallowed_STD3_mapped",[40,99,41]],[[127251,127251],"disallowed_STD3_mapped",[40,100,41]],[[127252,127252],"disallowed_STD3_mapped",[40,101,41]],[[127253,127253],"disallowed_STD3_mapped",[40,102,41]],[[127254,127254],"disallowed_STD3_mapped",[40,103,41]],[[127255,127255],"disallowed_STD3_mapped",[40,104,41]],[[127256,127256],"disallowed_STD3_mapped",[40,105,41]],[[127257,127257],"disallowed_STD3_mapped",[40,106,41]],[[127258,127258],"disallowed_STD3_mapped",[40,107,41]],[[127259,127259],"disallowed_STD3_mapped",[40,108,41]],[[127260,127260],"disallowed_STD3_mapped",[40,109,41]],[[127261,127261],"disallowed_STD3_mapped",[40,110,41]],[[127262,127262],"disallowed_STD3_mapped",[40,111,41]],[[127263,127263],"disallowed_STD3_mapped",[40,112,41]],[[127264,127264],"disallowed_STD3_mapped",[40,113,41]],[[127265,127265],"disallowed_STD3_mapped",[40,114,41]],[[127266,127266],"disallowed_STD3_mapped",[40,115,41]],[[127267,127267],"disallowed_STD3_mapped",[40,116,41]],[[127268,127268],"disallowed_STD3_mapped",[40,117,41]],[[127269,127269],"disallowed_STD3_mapped",[40,118,41]],[[127270,127270],"disallowed_STD3_mapped",[40,119,41]],[[127271,127271],"disallowed_STD3_mapped",[40,120,41]],[[127272,127272],"disallowed_STD3_mapped",[40,121,41]],[[127273,127273],"disallowed_STD3_mapped",[40,122,41]],[[127274,127274],"mapped",[12308,115,12309]],[[127275,127275],"mapped",[99]],[[127276,127276],"mapped",[114]],[[127277,127277],"mapped",[99,100]],[[127278,127278],"mapped",[119,122]],[[127279,127279],"disallowed"],[[127280,127280],"mapped",[97]],[[127281,127281],"mapped",[98]],[[127282,127282],"mapped",[99]],[[127283,127283],"mapped",[100]],[[127284,127284],"mapped",[101]],[[127285,127285],"mapped",[102]],[[127286,127286],"mapped",[103]],[[127287,127287],"mapped",[104]],[[127288,127288],"mapped",[105]],[[127289,127289],"mapped",[106]],[[127290,127290],"mapped",[107]],[[127291,127291],"mapped",[108]],[[127292,127292],"mapped",[109]],[[127293,127293],"mapped",[110]],[[127294,127294],"mapped",[111]],[[127295,127295],"mapped",[112]],[[127296,127296],"mapped",[113]],[[127297,127297],"mapped",[114]],[[127298,127298],"mapped",[115]],[[127299,127299],"mapped",[116]],[[127300,127300],"mapped",[117]],[[127301,127301],"mapped",[118]],[[127302,127302],"mapped",[119]],[[127303,127303],"mapped",[120]],[[127304,127304],"mapped",[121]],[[127305,127305],"mapped",[122]],[[127306,127306],"mapped",[104,118]],[[127307,127307],"mapped",[109,118]],[[127308,127308],"mapped",[115,100]],[[127309,127309],"mapped",[115,115]],[[127310,127310],"mapped",[112,112,118]],[[127311,127311],"mapped",[119,99]],[[127312,127318],"valid",[],"NV8"],[[127319,127319],"valid",[],"NV8"],[[127320,127326],"valid",[],"NV8"],[[127327,127327],"valid",[],"NV8"],[[127328,127337],"valid",[],"NV8"],[[127338,127338],"mapped",[109,99]],[[127339,127339],"mapped",[109,100]],[[127340,127343],"disallowed"],[[127344,127352],"valid",[],"NV8"],[[127353,127353],"valid",[],"NV8"],[[127354,127354],"valid",[],"NV8"],[[127355,127356],"valid",[],"NV8"],[[127357,127358],"valid",[],"NV8"],[[127359,127359],"valid",[],"NV8"],[[127360,127369],"valid",[],"NV8"],[[127370,127373],"valid",[],"NV8"],[[127374,127375],"valid",[],"NV8"],[[127376,127376],"mapped",[100,106]],[[127377,127386],"valid",[],"NV8"],[[127387,127461],"disallowed"],[[127462,127487],"valid",[],"NV8"],[[127488,127488],"mapped",[12411,12363]],[[127489,127489],"mapped",[12467,12467]],[[127490,127490],"mapped",[12469]],[[127491,127503],"disallowed"],[[127504,127504],"mapped",[25163]],[[127505,127505],"mapped",[23383]],[[127506,127506],"mapped",[21452]],[[127507,127507],"mapped",[12487]],[[127508,127508],"mapped",[20108]],[[127509,127509],"mapped",[22810]],[[127510,127510],"mapped",[35299]],[[127511,127511],"mapped",[22825]],[[127512,127512],"mapped",[20132]],[[127513,127513],"mapped",[26144]],[[127514,127514],"mapped",[28961]],[[127515,127515],"mapped",[26009]],[[127516,127516],"mapped",[21069]],[[127517,127517],"mapped",[24460]],[[127518,127518],"mapped",[20877]],[[127519,127519],"mapped",[26032]],[[127520,127520],"mapped",[21021]],[[127521,127521],"mapped",[32066]],[[127522,127522],"mapped",[29983]],[[127523,127523],"mapped",[36009]],[[127524,127524],"mapped",[22768]],[[127525,127525],"mapped",[21561]],[[127526,127526],"mapped",[28436]],[[127527,127527],"mapped",[25237]],[[127528,127528],"mapped",[25429]],[[127529,127529],"mapped",[19968]],[[127530,127530],"mapped",[19977]],[[127531,127531],"mapped",[36938]],[[127532,127532],"mapped",[24038]],[[127533,127533],"mapped",[20013]],[[127534,127534],"mapped",[21491]],[[127535,127535],"mapped",[25351]],[[127536,127536],"mapped",[36208]],[[127537,127537],"mapped",[25171]],[[127538,127538],"mapped",[31105]],[[127539,127539],"mapped",[31354]],[[127540,127540],"mapped",[21512]],[[127541,127541],"mapped",[28288]],[[127542,127542],"mapped",[26377]],[[127543,127543],"mapped",[26376]],[[127544,127544],"mapped",[30003]],[[127545,127545],"mapped",[21106]],[[127546,127546],"mapped",[21942]],[[127547,127551],"disallowed"],[[127552,127552],"mapped",[12308,26412,12309]],[[127553,127553],"mapped",[12308,19977,12309]],[[127554,127554],"mapped",[12308,20108,12309]],[[127555,127555],"mapped",[12308,23433,12309]],[[127556,127556],"mapped",[12308,28857,12309]],[[127557,127557],"mapped",[12308,25171,12309]],[[127558,127558],"mapped",[12308,30423,12309]],[[127559,127559],"mapped",[12308,21213,12309]],[[127560,127560],"mapped",[12308,25943,12309]],[[127561,127567],"disallowed"],[[127568,127568],"mapped",[24471]],[[127569,127569],"mapped",[21487]],[[127570,127743],"disallowed"],[[127744,127776],"valid",[],"NV8"],[[127777,127788],"valid",[],"NV8"],[[127789,127791],"valid",[],"NV8"],[[127792,127797],"valid",[],"NV8"],[[127798,127798],"valid",[],"NV8"],[[127799,127868],"valid",[],"NV8"],[[127869,127869],"valid",[],"NV8"],[[127870,127871],"valid",[],"NV8"],[[127872,127891],"valid",[],"NV8"],[[127892,127903],"valid",[],"NV8"],[[127904,127940],"valid",[],"NV8"],[[127941,127941],"valid",[],"NV8"],[[127942,127946],"valid",[],"NV8"],[[127947,127950],"valid",[],"NV8"],[[127951,127955],"valid",[],"NV8"],[[127956,127967],"valid",[],"NV8"],[[127968,127984],"valid",[],"NV8"],[[127985,127991],"valid",[],"NV8"],[[127992,127999],"valid",[],"NV8"],[[128000,128062],"valid",[],"NV8"],[[128063,128063],"valid",[],"NV8"],[[128064,128064],"valid",[],"NV8"],[[128065,128065],"valid",[],"NV8"],[[128066,128247],"valid",[],"NV8"],[[128248,128248],"valid",[],"NV8"],[[128249,128252],"valid",[],"NV8"],[[128253,128254],"valid",[],"NV8"],[[128255,128255],"valid",[],"NV8"],[[128256,128317],"valid",[],"NV8"],[[128318,128319],"valid",[],"NV8"],[[128320,128323],"valid",[],"NV8"],[[128324,128330],"valid",[],"NV8"],[[128331,128335],"valid",[],"NV8"],[[128336,128359],"valid",[],"NV8"],[[128360,128377],"valid",[],"NV8"],[[128378,128378],"disallowed"],[[128379,128419],"valid",[],"NV8"],[[128420,128420],"disallowed"],[[128421,128506],"valid",[],"NV8"],[[128507,128511],"valid",[],"NV8"],[[128512,128512],"valid",[],"NV8"],[[128513,128528],"valid",[],"NV8"],[[128529,128529],"valid",[],"NV8"],[[128530,128532],"valid",[],"NV8"],[[128533,128533],"valid",[],"NV8"],[[128534,128534],"valid",[],"NV8"],[[128535,128535],"valid",[],"NV8"],[[128536,128536],"valid",[],"NV8"],[[128537,128537],"valid",[],"NV8"],[[128538,128538],"valid",[],"NV8"],[[128539,128539],"valid",[],"NV8"],[[128540,128542],"valid",[],"NV8"],[[128543,128543],"valid",[],"NV8"],[[128544,128549],"valid",[],"NV8"],[[128550,128551],"valid",[],"NV8"],[[128552,128555],"valid",[],"NV8"],[[128556,128556],"valid",[],"NV8"],[[128557,128557],"valid",[],"NV8"],[[128558,128559],"valid",[],"NV8"],[[128560,128563],"valid",[],"NV8"],[[128564,128564],"valid",[],"NV8"],[[128565,128576],"valid",[],"NV8"],[[128577,128578],"valid",[],"NV8"],[[128579,128580],"valid",[],"NV8"],[[128581,128591],"valid",[],"NV8"],[[128592,128639],"valid",[],"NV8"],[[128640,128709],"valid",[],"NV8"],[[128710,128719],"valid",[],"NV8"],[[128720,128720],"valid",[],"NV8"],[[128721,128735],"disallowed"],[[128736,128748],"valid",[],"NV8"],[[128749,128751],"disallowed"],[[128752,128755],"valid",[],"NV8"],[[128756,128767],"disallowed"],[[128768,128883],"valid",[],"NV8"],[[128884,128895],"disallowed"],[[128896,128980],"valid",[],"NV8"],[[128981,129023],"disallowed"],[[129024,129035],"valid",[],"NV8"],[[129036,129039],"disallowed"],[[129040,129095],"valid",[],"NV8"],[[129096,129103],"disallowed"],[[129104,129113],"valid",[],"NV8"],[[129114,129119],"disallowed"],[[129120,129159],"valid",[],"NV8"],[[129160,129167],"disallowed"],[[129168,129197],"valid",[],"NV8"],[[129198,129295],"disallowed"],[[129296,129304],"valid",[],"NV8"],[[129305,129407],"disallowed"],[[129408,129412],"valid",[],"NV8"],[[129413,129471],"disallowed"],[[129472,129472],"valid",[],"NV8"],[[129473,131069],"disallowed"],[[131070,131071],"disallowed"],[[131072,173782],"valid"],[[173783,173823],"disallowed"],[[173824,177972],"valid"],[[177973,177983],"disallowed"],[[177984,178205],"valid"],[[178206,178207],"disallowed"],[[178208,183969],"valid"],[[183970,194559],"disallowed"],[[194560,194560],"mapped",[20029]],[[194561,194561],"mapped",[20024]],[[194562,194562],"mapped",[20033]],[[194563,194563],"mapped",[131362]],[[194564,194564],"mapped",[20320]],[[194565,194565],"mapped",[20398]],[[194566,194566],"mapped",[20411]],[[194567,194567],"mapped",[20482]],[[194568,194568],"mapped",[20602]],[[194569,194569],"mapped",[20633]],[[194570,194570],"mapped",[20711]],[[194571,194571],"mapped",[20687]],[[194572,194572],"mapped",[13470]],[[194573,194573],"mapped",[132666]],[[194574,194574],"mapped",[20813]],[[194575,194575],"mapped",[20820]],[[194576,194576],"mapped",[20836]],[[194577,194577],"mapped",[20855]],[[194578,194578],"mapped",[132380]],[[194579,194579],"mapped",[13497]],[[194580,194580],"mapped",[20839]],[[194581,194581],"mapped",[20877]],[[194582,194582],"mapped",[132427]],[[194583,194583],"mapped",[20887]],[[194584,194584],"mapped",[20900]],[[194585,194585],"mapped",[20172]],[[194586,194586],"mapped",[20908]],[[194587,194587],"mapped",[20917]],[[194588,194588],"mapped",[168415]],[[194589,194589],"mapped",[20981]],[[194590,194590],"mapped",[20995]],[[194591,194591],"mapped",[13535]],[[194592,194592],"mapped",[21051]],[[194593,194593],"mapped",[21062]],[[194594,194594],"mapped",[21106]],[[194595,194595],"mapped",[21111]],[[194596,194596],"mapped",[13589]],[[194597,194597],"mapped",[21191]],[[194598,194598],"mapped",[21193]],[[194599,194599],"mapped",[21220]],[[194600,194600],"mapped",[21242]],[[194601,194601],"mapped",[21253]],[[194602,194602],"mapped",[21254]],[[194603,194603],"mapped",[21271]],[[194604,194604],"mapped",[21321]],[[194605,194605],"mapped",[21329]],[[194606,194606],"mapped",[21338]],[[194607,194607],"mapped",[21363]],[[194608,194608],"mapped",[21373]],[[194609,194611],"mapped",[21375]],[[194612,194612],"mapped",[133676]],[[194613,194613],"mapped",[28784]],[[194614,194614],"mapped",[21450]],[[194615,194615],"mapped",[21471]],[[194616,194616],"mapped",[133987]],[[194617,194617],"mapped",[21483]],[[194618,194618],"mapped",[21489]],[[194619,194619],"mapped",[21510]],[[194620,194620],"mapped",[21662]],[[194621,194621],"mapped",[21560]],[[194622,194622],"mapped",[21576]],[[194623,194623],"mapped",[21608]],[[194624,194624],"mapped",[21666]],[[194625,194625],"mapped",[21750]],[[194626,194626],"mapped",[21776]],[[194627,194627],"mapped",[21843]],[[194628,194628],"mapped",[21859]],[[194629,194630],"mapped",[21892]],[[194631,194631],"mapped",[21913]],[[194632,194632],"mapped",[21931]],[[194633,194633],"mapped",[21939]],[[194634,194634],"mapped",[21954]],[[194635,194635],"mapped",[22294]],[[194636,194636],"mapped",[22022]],[[194637,194637],"mapped",[22295]],[[194638,194638],"mapped",[22097]],[[194639,194639],"mapped",[22132]],[[194640,194640],"mapped",[20999]],[[194641,194641],"mapped",[22766]],[[194642,194642],"mapped",[22478]],[[194643,194643],"mapped",[22516]],[[194644,194644],"mapped",[22541]],[[194645,194645],"mapped",[22411]],[[194646,194646],"mapped",[22578]],[[194647,194647],"mapped",[22577]],[[194648,194648],"mapped",[22700]],[[194649,194649],"mapped",[136420]],[[194650,194650],"mapped",[22770]],[[194651,194651],"mapped",[22775]],[[194652,194652],"mapped",[22790]],[[194653,194653],"mapped",[22810]],[[194654,194654],"mapped",[22818]],[[194655,194655],"mapped",[22882]],[[194656,194656],"mapped",[136872]],[[194657,194657],"mapped",[136938]],[[194658,194658],"mapped",[23020]],[[194659,194659],"mapped",[23067]],[[194660,194660],"mapped",[23079]],[[194661,194661],"mapped",[23000]],[[194662,194662],"mapped",[23142]],[[194663,194663],"mapped",[14062]],[[194664,194664],"disallowed"],[[194665,194665],"mapped",[23304]],[[194666,194667],"mapped",[23358]],[[194668,194668],"mapped",[137672]],[[194669,194669],"mapped",[23491]],[[194670,194670],"mapped",[23512]],[[194671,194671],"mapped",[23527]],[[194672,194672],"mapped",[23539]],[[194673,194673],"mapped",[138008]],[[194674,194674],"mapped",[23551]],[[194675,194675],"mapped",[23558]],[[194676,194676],"disallowed"],[[194677,194677],"mapped",[23586]],[[194678,194678],"mapped",[14209]],[[194679,194679],"mapped",[23648]],[[194680,194680],"mapped",[23662]],[[194681,194681],"mapped",[23744]],[[194682,194682],"mapped",[23693]],[[194683,194683],"mapped",[138724]],[[194684,194684],"mapped",[23875]],[[194685,194685],"mapped",[138726]],[[194686,194686],"mapped",[23918]],[[194687,194687],"mapped",[23915]],[[194688,194688],"mapped",[23932]],[[194689,194689],"mapped",[24033]],[[194690,194690],"mapped",[24034]],[[194691,194691],"mapped",[14383]],[[194692,194692],"mapped",[24061]],[[194693,194693],"mapped",[24104]],[[194694,194694],"mapped",[24125]],[[194695,194695],"mapped",[24169]],[[194696,194696],"mapped",[14434]],[[194697,194697],"mapped",[139651]],[[194698,194698],"mapped",[14460]],[[194699,194699],"mapped",[24240]],[[194700,194700],"mapped",[24243]],[[194701,194701],"mapped",[24246]],[[194702,194702],"mapped",[24266]],[[194703,194703],"mapped",[172946]],[[194704,194704],"mapped",[24318]],[[194705,194706],"mapped",[140081]],[[194707,194707],"mapped",[33281]],[[194708,194709],"mapped",[24354]],[[194710,194710],"mapped",[14535]],[[194711,194711],"mapped",[144056]],[[194712,194712],"mapped",[156122]],[[194713,194713],"mapped",[24418]],[[194714,194714],"mapped",[24427]],[[194715,194715],"mapped",[14563]],[[194716,194716],"mapped",[24474]],[[194717,194717],"mapped",[24525]],[[194718,194718],"mapped",[24535]],[[194719,194719],"mapped",[24569]],[[194720,194720],"mapped",[24705]],[[194721,194721],"mapped",[14650]],[[194722,194722],"mapped",[14620]],[[194723,194723],"mapped",[24724]],[[194724,194724],"mapped",[141012]],[[194725,194725],"mapped",[24775]],[[194726,194726],"mapped",[24904]],[[194727,194727],"mapped",[24908]],[[194728,194728],"mapped",[24910]],[[194729,194729],"mapped",[24908]],[[194730,194730],"mapped",[24954]],[[194731,194731],"mapped",[24974]],[[194732,194732],"mapped",[25010]],[[194733,194733],"mapped",[24996]],[[194734,194734],"mapped",[25007]],[[194735,194735],"mapped",[25054]],[[194736,194736],"mapped",[25074]],[[194737,194737],"mapped",[25078]],[[194738,194738],"mapped",[25104]],[[194739,194739],"mapped",[25115]],[[194740,194740],"mapped",[25181]],[[194741,194741],"mapped",[25265]],[[194742,194742],"mapped",[25300]],[[194743,194743],"mapped",[25424]],[[194744,194744],"mapped",[142092]],[[194745,194745],"mapped",[25405]],[[194746,194746],"mapped",[25340]],[[194747,194747],"mapped",[25448]],[[194748,194748],"mapped",[25475]],[[194749,194749],"mapped",[25572]],[[194750,194750],"mapped",[142321]],[[194751,194751],"mapped",[25634]],[[194752,194752],"mapped",[25541]],[[194753,194753],"mapped",[25513]],[[194754,194754],"mapped",[14894]],[[194755,194755],"mapped",[25705]],[[194756,194756],"mapped",[25726]],[[194757,194757],"mapped",[25757]],[[194758,194758],"mapped",[25719]],[[194759,194759],"mapped",[14956]],[[194760,194760],"mapped",[25935]],[[194761,194761],"mapped",[25964]],[[194762,194762],"mapped",[143370]],[[194763,194763],"mapped",[26083]],[[194764,194764],"mapped",[26360]],[[194765,194765],"mapped",[26185]],[[194766,194766],"mapped",[15129]],[[194767,194767],"mapped",[26257]],[[194768,194768],"mapped",[15112]],[[194769,194769],"mapped",[15076]],[[194770,194770],"mapped",[20882]],[[194771,194771],"mapped",[20885]],[[194772,194772],"mapped",[26368]],[[194773,194773],"mapped",[26268]],[[194774,194774],"mapped",[32941]],[[194775,194775],"mapped",[17369]],[[194776,194776],"mapped",[26391]],[[194777,194777],"mapped",[26395]],[[194778,194778],"mapped",[26401]],[[194779,194779],"mapped",[26462]],[[194780,194780],"mapped",[26451]],[[194781,194781],"mapped",[144323]],[[194782,194782],"mapped",[15177]],[[194783,194783],"mapped",[26618]],[[194784,194784],"mapped",[26501]],[[194785,194785],"mapped",[26706]],[[194786,194786],"mapped",[26757]],[[194787,194787],"mapped",[144493]],[[194788,194788],"mapped",[26766]],[[194789,194789],"mapped",[26655]],[[194790,194790],"mapped",[26900]],[[194791,194791],"mapped",[15261]],[[194792,194792],"mapped",[26946]],[[194793,194793],"mapped",[27043]],[[194794,194794],"mapped",[27114]],[[194795,194795],"mapped",[27304]],[[194796,194796],"mapped",[145059]],[[194797,194797],"mapped",[27355]],[[194798,194798],"mapped",[15384]],[[194799,194799],"mapped",[27425]],[[194800,194800],"mapped",[145575]],[[194801,194801],"mapped",[27476]],[[194802,194802],"mapped",[15438]],[[194803,194803],"mapped",[27506]],[[194804,194804],"mapped",[27551]],[[194805,194805],"mapped",[27578]],[[194806,194806],"mapped",[27579]],[[194807,194807],"mapped",[146061]],[[194808,194808],"mapped",[138507]],[[194809,194809],"mapped",[146170]],[[194810,194810],"mapped",[27726]],[[194811,194811],"mapped",[146620]],[[194812,194812],"mapped",[27839]],[[194813,194813],"mapped",[27853]],[[194814,194814],"mapped",[27751]],[[194815,194815],"mapped",[27926]],[[194816,194816],"mapped",[27966]],[[194817,194817],"mapped",[28023]],[[194818,194818],"mapped",[27969]],[[194819,194819],"mapped",[28009]],[[194820,194820],"mapped",[28024]],[[194821,194821],"mapped",[28037]],[[194822,194822],"mapped",[146718]],[[194823,194823],"mapped",[27956]],[[194824,194824],"mapped",[28207]],[[194825,194825],"mapped",[28270]],[[194826,194826],"mapped",[15667]],[[194827,194827],"mapped",[28363]],[[194828,194828],"mapped",[28359]],[[194829,194829],"mapped",[147153]],[[194830,194830],"mapped",[28153]],[[194831,194831],"mapped",[28526]],[[194832,194832],"mapped",[147294]],[[194833,194833],"mapped",[147342]],[[194834,194834],"mapped",[28614]],[[194835,194835],"mapped",[28729]],[[194836,194836],"mapped",[28702]],[[194837,194837],"mapped",[28699]],[[194838,194838],"mapped",[15766]],[[194839,194839],"mapped",[28746]],[[194840,194840],"mapped",[28797]],[[194841,194841],"mapped",[28791]],[[194842,194842],"mapped",[28845]],[[194843,194843],"mapped",[132389]],[[194844,194844],"mapped",[28997]],[[194845,194845],"mapped",[148067]],[[194846,194846],"mapped",[29084]],[[194847,194847],"disallowed"],[[194848,194848],"mapped",[29224]],[[194849,194849],"mapped",[29237]],[[194850,194850],"mapped",[29264]],[[194851,194851],"mapped",[149000]],[[194852,194852],"mapped",[29312]],[[194853,194853],"mapped",[29333]],[[194854,194854],"mapped",[149301]],[[194855,194855],"mapped",[149524]],[[194856,194856],"mapped",[29562]],[[194857,194857],"mapped",[29579]],[[194858,194858],"mapped",[16044]],[[194859,194859],"mapped",[29605]],[[194860,194861],"mapped",[16056]],[[194862,194862],"mapped",[29767]],[[194863,194863],"mapped",[29788]],[[194864,194864],"mapped",[29809]],[[194865,194865],"mapped",[29829]],[[194866,194866],"mapped",[29898]],[[194867,194867],"mapped",[16155]],[[194868,194868],"mapped",[29988]],[[194869,194869],"mapped",[150582]],[[194870,194870],"mapped",[30014]],[[194871,194871],"mapped",[150674]],[[194872,194872],"mapped",[30064]],[[194873,194873],"mapped",[139679]],[[194874,194874],"mapped",[30224]],[[194875,194875],"mapped",[151457]],[[194876,194876],"mapped",[151480]],[[194877,194877],"mapped",[151620]],[[194878,194878],"mapped",[16380]],[[194879,194879],"mapped",[16392]],[[194880,194880],"mapped",[30452]],[[194881,194881],"mapped",[151795]],[[194882,194882],"mapped",[151794]],[[194883,194883],"mapped",[151833]],[[194884,194884],"mapped",[151859]],[[194885,194885],"mapped",[30494]],[[194886,194887],"mapped",[30495]],[[194888,194888],"mapped",[30538]],[[194889,194889],"mapped",[16441]],[[194890,194890],"mapped",[30603]],[[194891,194891],"mapped",[16454]],[[194892,194892],"mapped",[16534]],[[194893,194893],"mapped",[152605]],[[194894,194894],"mapped",[30798]],[[194895,194895],"mapped",[30860]],[[194896,194896],"mapped",[30924]],[[194897,194897],"mapped",[16611]],[[194898,194898],"mapped",[153126]],[[194899,194899],"mapped",[31062]],[[194900,194900],"mapped",[153242]],[[194901,194901],"mapped",[153285]],[[194902,194902],"mapped",[31119]],[[194903,194903],"mapped",[31211]],[[194904,194904],"mapped",[16687]],[[194905,194905],"mapped",[31296]],[[194906,194906],"mapped",[31306]],[[194907,194907],"mapped",[31311]],[[194908,194908],"mapped",[153980]],[[194909,194910],"mapped",[154279]],[[194911,194911],"disallowed"],[[194912,194912],"mapped",[16898]],[[194913,194913],"mapped",[154539]],[[194914,194914],"mapped",[31686]],[[194915,194915],"mapped",[31689]],[[194916,194916],"mapped",[16935]],[[194917,194917],"mapped",[154752]],[[194918,194918],"mapped",[31954]],[[194919,194919],"mapped",[17056]],[[194920,194920],"mapped",[31976]],[[194921,194921],"mapped",[31971]],[[194922,194922],"mapped",[32000]],[[194923,194923],"mapped",[155526]],[[194924,194924],"mapped",[32099]],[[194925,194925],"mapped",[17153]],[[194926,194926],"mapped",[32199]],[[194927,194927],"mapped",[32258]],[[194928,194928],"mapped",[32325]],[[194929,194929],"mapped",[17204]],[[194930,194930],"mapped",[156200]],[[194931,194931],"mapped",[156231]],[[194932,194932],"mapped",[17241]],[[194933,194933],"mapped",[156377]],[[194934,194934],"mapped",[32634]],[[194935,194935],"mapped",[156478]],[[194936,194936],"mapped",[32661]],[[194937,194937],"mapped",[32762]],[[194938,194938],"mapped",[32773]],[[194939,194939],"mapped",[156890]],[[194940,194940],"mapped",[156963]],[[194941,194941],"mapped",[32864]],[[194942,194942],"mapped",[157096]],[[194943,194943],"mapped",[32880]],[[194944,194944],"mapped",[144223]],[[194945,194945],"mapped",[17365]],[[194946,194946],"mapped",[32946]],[[194947,194947],"mapped",[33027]],[[194948,194948],"mapped",[17419]],[[194949,194949],"mapped",[33086]],[[194950,194950],"mapped",[23221]],[[194951,194951],"mapped",[157607]],[[194952,194952],"mapped",[157621]],[[194953,194953],"mapped",[144275]],[[194954,194954],"mapped",[144284]],[[194955,194955],"mapped",[33281]],[[194956,194956],"mapped",[33284]],[[194957,194957],"mapped",[36766]],[[194958,194958],"mapped",[17515]],[[194959,194959],"mapped",[33425]],[[194960,194960],"mapped",[33419]],[[194961,194961],"mapped",[33437]],[[194962,194962],"mapped",[21171]],[[194963,194963],"mapped",[33457]],[[194964,194964],"mapped",[33459]],[[194965,194965],"mapped",[33469]],[[194966,194966],"mapped",[33510]],[[194967,194967],"mapped",[158524]],[[194968,194968],"mapped",[33509]],[[194969,194969],"mapped",[33565]],[[194970,194970],"mapped",[33635]],[[194971,194971],"mapped",[33709]],[[194972,194972],"mapped",[33571]],[[194973,194973],"mapped",[33725]],[[194974,194974],"mapped",[33767]],[[194975,194975],"mapped",[33879]],[[194976,194976],"mapped",[33619]],[[194977,194977],"mapped",[33738]],[[194978,194978],"mapped",[33740]],[[194979,194979],"mapped",[33756]],[[194980,194980],"mapped",[158774]],[[194981,194981],"mapped",[159083]],[[194982,194982],"mapped",[158933]],[[194983,194983],"mapped",[17707]],[[194984,194984],"mapped",[34033]],[[194985,194985],"mapped",[34035]],[[194986,194986],"mapped",[34070]],[[194987,194987],"mapped",[160714]],[[194988,194988],"mapped",[34148]],[[194989,194989],"mapped",[159532]],[[194990,194990],"mapped",[17757]],[[194991,194991],"mapped",[17761]],[[194992,194992],"mapped",[159665]],[[194993,194993],"mapped",[159954]],[[194994,194994],"mapped",[17771]],[[194995,194995],"mapped",[34384]],[[194996,194996],"mapped",[34396]],[[194997,194997],"mapped",[34407]],[[194998,194998],"mapped",[34409]],[[194999,194999],"mapped",[34473]],[[195000,195000],"mapped",[34440]],[[195001,195001],"mapped",[34574]],[[195002,195002],"mapped",[34530]],[[195003,195003],"mapped",[34681]],[[195004,195004],"mapped",[34600]],[[195005,195005],"mapped",[34667]],[[195006,195006],"mapped",[34694]],[[195007,195007],"disallowed"],[[195008,195008],"mapped",[34785]],[[195009,195009],"mapped",[34817]],[[195010,195010],"mapped",[17913]],[[195011,195011],"mapped",[34912]],[[195012,195012],"mapped",[34915]],[[195013,195013],"mapped",[161383]],[[195014,195014],"mapped",[35031]],[[195015,195015],"mapped",[35038]],[[195016,195016],"mapped",[17973]],[[195017,195017],"mapped",[35066]],[[195018,195018],"mapped",[13499]],[[195019,195019],"mapped",[161966]],[[195020,195020],"mapped",[162150]],[[195021,195021],"mapped",[18110]],[[195022,195022],"mapped",[18119]],[[195023,195023],"mapped",[35488]],[[195024,195024],"mapped",[35565]],[[195025,195025],"mapped",[35722]],[[195026,195026],"mapped",[35925]],[[195027,195027],"mapped",[162984]],[[195028,195028],"mapped",[36011]],[[195029,195029],"mapped",[36033]],[[195030,195030],"mapped",[36123]],[[195031,195031],"mapped",[36215]],[[195032,195032],"mapped",[163631]],[[195033,195033],"mapped",[133124]],[[195034,195034],"mapped",[36299]],[[195035,195035],"mapped",[36284]],[[195036,195036],"mapped",[36336]],[[195037,195037],"mapped",[133342]],[[195038,195038],"mapped",[36564]],[[195039,195039],"mapped",[36664]],[[195040,195040],"mapped",[165330]],[[195041,195041],"mapped",[165357]],[[195042,195042],"mapped",[37012]],[[195043,195043],"mapped",[37105]],[[195044,195044],"mapped",[37137]],[[195045,195045],"mapped",[165678]],[[195046,195046],"mapped",[37147]],[[195047,195047],"mapped",[37432]],[[195048,195048],"mapped",[37591]],[[195049,195049],"mapped",[37592]],[[195050,195050],"mapped",[37500]],[[195051,195051],"mapped",[37881]],[[195052,195052],"mapped",[37909]],[[195053,195053],"mapped",[166906]],[[195054,195054],"mapped",[38283]],[[195055,195055],"mapped",[18837]],[[195056,195056],"mapped",[38327]],[[195057,195057],"mapped",[167287]],[[195058,195058],"mapped",[18918]],[[195059,195059],"mapped",[38595]],[[195060,195060],"mapped",[23986]],[[195061,195061],"mapped",[38691]],[[195062,195062],"mapped",[168261]],[[195063,195063],"mapped",[168474]],[[195064,195064],"mapped",[19054]],[[195065,195065],"mapped",[19062]],[[195066,195066],"mapped",[38880]],[[195067,195067],"mapped",[168970]],[[195068,195068],"mapped",[19122]],[[195069,195069],"mapped",[169110]],[[195070,195071],"mapped",[38923]],[[195072,195072],"mapped",[38953]],[[195073,195073],"mapped",[169398]],[[195074,195074],"mapped",[39138]],[[195075,195075],"mapped",[19251]],[[195076,195076],"mapped",[39209]],[[195077,195077],"mapped",[39335]],[[195078,195078],"mapped",[39362]],[[195079,195079],"mapped",[39422]],[[195080,195080],"mapped",[19406]],[[195081,195081],"mapped",[170800]],[[195082,195082],"mapped",[39698]],[[195083,195083],"mapped",[40000]],[[195084,195084],"mapped",[40189]],[[195085,195085],"mapped",[19662]],[[195086,195086],"mapped",[19693]],[[195087,195087],"mapped",[40295]],[[195088,195088],"mapped",[172238]],[[195089,195089],"mapped",[19704]],[[195090,195090],"mapped",[172293]],[[195091,195091],"mapped",[172558]],[[195092,195092],"mapped",[172689]],[[195093,195093],"mapped",[40635]],[[195094,195094],"mapped",[19798]],[[195095,195095],"mapped",[40697]],[[195096,195096],"mapped",[40702]],[[195097,195097],"mapped",[40709]],[[195098,195098],"mapped",[40719]],[[195099,195099],"mapped",[40726]],[[195100,195100],"mapped",[40763]],[[195101,195101],"mapped",[173568]],[[195102,196605],"disallowed"],[[196606,196607],"disallowed"],[[196608,262141],"disallowed"],[[262142,262143],"disallowed"],[[262144,327677],"disallowed"],[[327678,327679],"disallowed"],[[327680,393213],"disallowed"],[[393214,393215],"disallowed"],[[393216,458749],"disallowed"],[[458750,458751],"disallowed"],[[458752,524285],"disallowed"],[[524286,524287],"disallowed"],[[524288,589821],"disallowed"],[[589822,589823],"disallowed"],[[589824,655357],"disallowed"],[[655358,655359],"disallowed"],[[655360,720893],"disallowed"],[[720894,720895],"disallowed"],[[720896,786429],"disallowed"],[[786430,786431],"disallowed"],[[786432,851965],"disallowed"],[[851966,851967],"disallowed"],[[851968,917501],"disallowed"],[[917502,917503],"disallowed"],[[917504,917504],"disallowed"],[[917505,917505],"disallowed"],[[917506,917535],"disallowed"],[[917536,917631],"disallowed"],[[917632,917759],"disallowed"],[[917760,917999],"ignored"],[[918000,983037],"disallowed"],[[983038,983039],"disallowed"],[[983040,1048573],"disallowed"],[[1048574,1048575],"disallowed"],[[1048576,1114109],"disallowed"],[[1114110,1114111],"disallowed"]]'); -/***/ }) -/******/ }); -/************************************************************************/ -/******/ // The module cache -/******/ var __webpack_module_cache__ = {}; -/******/ -/******/ // The require function -/******/ function __nccwpck_require__(moduleId) { -/******/ // Check if module is in cache -/******/ var cachedModule = __webpack_module_cache__[moduleId]; -/******/ if (cachedModule !== undefined) { -/******/ return cachedModule.exports; -/******/ } -/******/ // Create a new module (and put it into the cache) -/******/ var module = __webpack_module_cache__[moduleId] = { -/******/ // no module.id needed -/******/ // no module.loaded needed -/******/ exports: {} -/******/ }; -/******/ -/******/ // Execute the module function -/******/ var threw = true; -/******/ try { -/******/ __webpack_modules__[moduleId].call(module.exports, module, module.exports, __nccwpck_require__); -/******/ threw = false; -/******/ } finally { -/******/ if(threw) delete __webpack_module_cache__[moduleId]; -/******/ } -/******/ -/******/ // Return the exports of the module -/******/ return module.exports; -/******/ } -/******/ -/************************************************************************/ -/******/ /* webpack/runtime/compat get default export */ -/******/ (() => { -/******/ // getDefaultExport function for compatibility with non-harmony modules -/******/ __nccwpck_require__.n = (module) => { -/******/ var getter = module && module.__esModule ? -/******/ () => (module['default']) : -/******/ () => (module); -/******/ __nccwpck_require__.d(getter, { a: getter }); -/******/ return getter; -/******/ }; -/******/ })(); -/******/ -/******/ /* webpack/runtime/define property getters */ -/******/ (() => { -/******/ // define getter functions for harmony exports -/******/ __nccwpck_require__.d = (exports, definition) => { -/******/ for(var key in definition) { -/******/ if(__nccwpck_require__.o(definition, key) && !__nccwpck_require__.o(exports, key)) { -/******/ Object.defineProperty(exports, key, { enumerable: true, get: definition[key] }); -/******/ } -/******/ } -/******/ }; -/******/ })(); -/******/ -/******/ /* webpack/runtime/hasOwnProperty shorthand */ -/******/ (() => { -/******/ __nccwpck_require__.o = (obj, prop) => (Object.prototype.hasOwnProperty.call(obj, prop)) -/******/ })(); -/******/ -/******/ /* webpack/runtime/compat */ -/******/ -/******/ if (typeof __nccwpck_require__ !== 'undefined') __nccwpck_require__.ab = new URL('.', import.meta.url).pathname.slice(import.meta.url.match(/^file:\/\/\/\w:/) ? 1 : 0, -1) + "/"; -/******/ -/************************************************************************/ -var __webpack_exports__ = {}; -/* harmony export */ __nccwpck_require__.d(__webpack_exports__, { -/* harmony export */ e: () => (/* binding */ deleteCache) -/* harmony export */ }); -/* harmony import */ var _actions_core__WEBPACK_IMPORTED_MODULE_0__ = __nccwpck_require__(7484); -/* harmony import */ var _actions_core__WEBPACK_IMPORTED_MODULE_0___default = /*#__PURE__*/__nccwpck_require__.n(_actions_core__WEBPACK_IMPORTED_MODULE_0__); -/* harmony import */ var node_fetch__WEBPACK_IMPORTED_MODULE_1__ = __nccwpck_require__(6705); -/* harmony import */ var node_fetch__WEBPACK_IMPORTED_MODULE_1___default = /*#__PURE__*/__nccwpck_require__.n(node_fetch__WEBPACK_IMPORTED_MODULE_1__); - - -async function deleteCache(_a) { - var _b, _c, _d; - var { cacheKey, cacheVersion, prefix = false, baseUrl = process.env.BLACKSMITH_CACHE_URL || - (((_b = process.env.PETNAME) === null || _b === void 0 ? void 0 : _b.includes("staging")) - ? "https://stagingapi.blacksmith.sh/cache" - : "https://api.blacksmith.sh/cache"), repoName = (_c = process.env["GITHUB_REPO_NAME"]) !== null && _c !== void 0 ? _c : "", cacheToken = process.env["BLACKSMITH_CACHE_TOKEN"], region = (_d = process.env["BLACKSMITH_REGION"]) !== null && _d !== void 0 ? _d : "eu-central", } = _a; - if (!cacheKey && !prefix) { - throw new Error("Cache key cannot be empty unless prefix is true"); - } - if (cacheVersion && !cacheKey) { - throw new Error("Cannot specify version when using empty key"); - } - if (prefix && cacheVersion) { - throw new Error("Cannot specify version when using prefix"); - } - const resource = cacheVersion ? `${cacheKey}/${cacheVersion}` : cacheKey; - const url = `${baseUrl}/caches/${resource}`; - const response = await node_fetch__WEBPACK_IMPORTED_MODULE_1___default()(prefix ? `${url}?prefix` : url, { - method: "DELETE", - headers: { - Accept: "application/json; version=6.0-preview.1", - "X-GitHub-Repo-Name": repoName, - Authorization: `Bearer ${cacheToken}`, - "X-Cache-Region": region, - }, + + +const execAsync = (0,external_util_.promisify)(external_child_process_.exec); +async function getStickyDisk(stickyDiskKey, options) { + const client = createStickyDiskClient(); + core.debug(`Getting sticky disk for ${stickyDiskKey}`); + const response = await client.getStickyDisk({ + stickyDiskKey: stickyDiskKey, + region: process.env.BLACKSMITH_REGION || 'eu-central', + installationModelId: process.env.BLACKSMITH_INSTALLATION_MODEL_ID || '', + vmId: process.env.VM_ID || '', + stickyDiskType: 'stickydisk', + stickyDiskToken: process.env.BLACKSMITH_STICKYDISK_TOKEN, + repoName: process.env.GITHUB_REPO_NAME || '' + }, { + signal: options === null || options === void 0 ? void 0 : options.signal, }); - if (!response.ok && response.status !== 404) { - throw new Error(`Failed to delete cache: ${response.status} ${response.statusText}`); - } - if (response.status === 404) { - (0,_actions_core__WEBPACK_IMPORTED_MODULE_0__.info)(`Cache not found${cacheKey ? `: ${cacheKey}` : ""}${cacheVersion ? `@${cacheVersion}` : ""}`); + return { + expose_id: response.exposeId, + device: response.diskIdentifier + }; +} +async function maybeFormatBlockDevice(device) { + try { + // Check if device is formatted with ext4 + try { + const { stdout } = await execAsync(`sudo blkid -o value -s TYPE ${device}`); + if (stdout.trim() === 'ext4') { + core.debug(`Device ${device} is already formatted with ext4`); + try { + // Run resize2fs to ensure filesystem uses full block device + await execAsync(`sudo resize2fs -f ${device}`); + core.debug(`Resized ext4 filesystem on ${device}`); + } + catch (error) { + if (error instanceof Error) { + core.warning(`Error resizing ext4 filesystem on ${device}: ${error}`); + } + } + return device; + } + } + catch { + // blkid returns non-zero if no filesystem found, which is fine + core.debug(`No filesystem found on ${device}, will format it`); + } + // Format device with ext4 + core.debug(`Formatting device ${device} with ext4`); + await execAsync(`sudo mkfs.ext4 -m0 -Enodiscard,lazy_itable_init=1,lazy_journal_init=1 -F ${device}`); + core.debug(`Successfully formatted ${device} with ext4`); + return device; } - else { - const data = await response.json(); - (0,_actions_core__WEBPACK_IMPORTED_MODULE_0__.info)(`Successfully deleted ${prefix ? "caches with prefix" : "cache"}${cacheVersion ? " version" : ""}: ${cacheKey}${cacheVersion ? `@${cacheVersion}` : ""}`); - if (data.deleted !== undefined) { - (0,_actions_core__WEBPACK_IMPORTED_MODULE_0__.info)(`Deleted ${data.deleted} cache entries`); + catch (error) { + if (error instanceof Error) { + core.error(`Failed to format device ${device}: ${error}`); } + throw error; } } +async function mountStickyDisk(stickyDiskKey, stickyDiskPath, signal, controller) { + const timeoutId = setTimeout(() => controller.abort(), 15000); + const stickyDiskResponse = await getStickyDisk(stickyDiskKey, { signal }); + const device = stickyDiskResponse.device; + const exposeId = stickyDiskResponse.expose_id; + clearTimeout(timeoutId); + await maybeFormatBlockDevice(device); + await execAsync(`sudo mkdir -p ${stickyDiskPath}`); + await execAsync(`sudo mount ${device} ${stickyDiskPath}`); + core.debug(`${device} has been mounted to ${stickyDiskPath} with expose ID ${exposeId}`); + return { device, exposeId }; +} async function run() { + let stickyDiskError; + let exposeId; + let device = ''; + const stickyDiskKey = (0,core.getInput)("key"); + const stickyDiskPath = (0,core.getInput)("path"); + // Save these values to GitHub Actions state + (0,core.saveState)('STICKYDISK_PATH', stickyDiskPath); + (0,core.saveState)('STICKYDISK_KEY', stickyDiskKey); + core.info(`Mounting sticky disk at ${stickyDiskPath} with key ${stickyDiskKey}`); try { - const cacheKey = (0,_actions_core__WEBPACK_IMPORTED_MODULE_0__.getInput)("key"); - const cacheVersion = (0,_actions_core__WEBPACK_IMPORTED_MODULE_0__.getInput)("version"); - const prefix = (0,_actions_core__WEBPACK_IMPORTED_MODULE_0__.getInput)("prefix") === "true"; - await deleteCache({ cacheKey, cacheVersion, prefix }); + const controller = new AbortController(); + try { + ({ device, exposeId } = await mountStickyDisk(stickyDiskKey, stickyDiskPath, controller.signal, controller)); + (0,core.saveState)('STICKYDISK_EXPOSE_ID', exposeId); + core.debug(`Sticky disk mounted to ${device}, expose ID: ${exposeId}`); + } + catch (error) { + if (error instanceof Error && error.name === 'AbortError') { + core.warning('Request to get sticky disk timed out'); + } + throw error; + } } catch (error) { if (error instanceof Error) { - (0,_actions_core__WEBPACK_IMPORTED_MODULE_0__.setFailed)(error.message); - } - else { - (0,_actions_core__WEBPACK_IMPORTED_MODULE_0__.setFailed)("An unexpected error occurred"); + core.warning(`Error getting sticky disk: ${error}`); + stickyDiskError = error; + (0,core.saveState)('STICKYDISK_ERROR', 'true'); } } + if (stickyDiskError) { + core.setFailed(`Error getting sticky disk: ${stickyDiskError}`); + } } run(); -var __webpack_exports__deleteCache = __webpack_exports__.e; -export { __webpack_exports__deleteCache as deleteCache }; diff --git a/dist/post/index.js b/dist/post/index.js new file mode 100644 index 0000000..bcefe50 --- /dev/null +++ b/dist/post/index.js @@ -0,0 +1,36309 @@ +import { createRequire as __WEBPACK_EXTERNAL_createRequire } from "module"; +/******/ var __webpack_modules__ = ({ + +/***/ 4914: +/***/ (function(__unused_webpack_module, exports, __nccwpck_require__) { + + +var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) { + if (k2 === undefined) k2 = k; + var desc = Object.getOwnPropertyDescriptor(m, k); + if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) { + desc = { enumerable: true, get: function() { return m[k]; } }; + } + Object.defineProperty(o, k2, desc); +}) : (function(o, m, k, k2) { + if (k2 === undefined) k2 = k; + o[k2] = m[k]; +})); +var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) { + Object.defineProperty(o, "default", { enumerable: true, value: v }); +}) : function(o, v) { + o["default"] = v; +}); +var __importStar = (this && this.__importStar) || function (mod) { + if (mod && mod.__esModule) return mod; + var result = {}; + if (mod != null) for (var k in mod) if (k !== "default" && Object.prototype.hasOwnProperty.call(mod, k)) __createBinding(result, mod, k); + __setModuleDefault(result, mod); + return result; +}; +Object.defineProperty(exports, "__esModule", ({ value: true })); +exports.issue = exports.issueCommand = void 0; +const os = __importStar(__nccwpck_require__(857)); +const utils_1 = __nccwpck_require__(302); +/** + * Commands + * + * Command Format: + * ::name key=value,key=value::message + * + * Examples: + * ::warning::This is the message + * ::set-env name=MY_VAR::some value + */ +function issueCommand(command, properties, message) { + const cmd = new Command(command, properties, message); + process.stdout.write(cmd.toString() + os.EOL); +} +exports.issueCommand = issueCommand; +function issue(name, message = '') { + issueCommand(name, {}, message); +} +exports.issue = issue; +const CMD_STRING = '::'; +class Command { + constructor(command, properties, message) { + if (!command) { + command = 'missing.command'; + } + this.command = command; + this.properties = properties; + this.message = message; + } + toString() { + let cmdStr = CMD_STRING + this.command; + if (this.properties && Object.keys(this.properties).length > 0) { + cmdStr += ' '; + let first = true; + for (const key in this.properties) { + if (this.properties.hasOwnProperty(key)) { + const val = this.properties[key]; + if (val) { + if (first) { + first = false; + } + else { + cmdStr += ','; + } + cmdStr += `${key}=${escapeProperty(val)}`; + } + } + } + } + cmdStr += `${CMD_STRING}${escapeData(this.message)}`; + return cmdStr; + } +} +function escapeData(s) { + return (0, utils_1.toCommandValue)(s) + .replace(/%/g, '%25') + .replace(/\r/g, '%0D') + .replace(/\n/g, '%0A'); +} +function escapeProperty(s) { + return (0, utils_1.toCommandValue)(s) + .replace(/%/g, '%25') + .replace(/\r/g, '%0D') + .replace(/\n/g, '%0A') + .replace(/:/g, '%3A') + .replace(/,/g, '%2C'); +} +//# sourceMappingURL=command.js.map + +/***/ }), + +/***/ 7484: +/***/ (function(__unused_webpack_module, exports, __nccwpck_require__) { + + +var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) { + if (k2 === undefined) k2 = k; + var desc = Object.getOwnPropertyDescriptor(m, k); + if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) { + desc = { enumerable: true, get: function() { return m[k]; } }; + } + Object.defineProperty(o, k2, desc); +}) : (function(o, m, k, k2) { + if (k2 === undefined) k2 = k; + o[k2] = m[k]; +})); +var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) { + Object.defineProperty(o, "default", { enumerable: true, value: v }); +}) : function(o, v) { + o["default"] = v; +}); +var __importStar = (this && this.__importStar) || function (mod) { + if (mod && mod.__esModule) return mod; + var result = {}; + if (mod != null) for (var k in mod) if (k !== "default" && Object.prototype.hasOwnProperty.call(mod, k)) __createBinding(result, mod, k); + __setModuleDefault(result, mod); + return result; +}; +var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) { + function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); } + return new (P || (P = Promise))(function (resolve, reject) { + function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } } + function rejected(value) { try { step(generator["throw"](value)); } catch (e) { reject(e); } } + function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); } + step((generator = generator.apply(thisArg, _arguments || [])).next()); + }); +}; +Object.defineProperty(exports, "__esModule", ({ value: true })); +exports.platform = exports.toPlatformPath = exports.toWin32Path = exports.toPosixPath = exports.markdownSummary = exports.summary = exports.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; +const command_1 = __nccwpck_require__(4914); +const file_command_1 = __nccwpck_require__(4753); +const utils_1 = __nccwpck_require__(302); +const os = __importStar(__nccwpck_require__(857)); +const path = __importStar(__nccwpck_require__(6928)); +const oidc_utils_1 = __nccwpck_require__(5306); +/** + * The code to exit an action + */ +var ExitCode; +(function (ExitCode) { + /** + * A code indicating that the action was successful + */ + ExitCode[ExitCode["Success"] = 0] = "Success"; + /** + * A code indicating that the action was a failure + */ + ExitCode[ExitCode["Failure"] = 1] = "Failure"; +})(ExitCode || (exports.ExitCode = ExitCode = {})); +//----------------------------------------------------------------------- +// Variables +//----------------------------------------------------------------------- +/** + * Sets env variable for this action and future actions in the job + * @param name the name of the variable to set + * @param val the value of the variable. Non-string values will be converted to a string via JSON.stringify + */ +// eslint-disable-next-line @typescript-eslint/no-explicit-any +function exportVariable(name, val) { + const convertedVal = (0, utils_1.toCommandValue)(val); + process.env[name] = convertedVal; + const filePath = process.env['GITHUB_ENV'] || ''; + if (filePath) { + return (0, file_command_1.issueFileCommand)('ENV', (0, file_command_1.prepareKeyValueMessage)(name, val)); + } + (0, command_1.issueCommand)('set-env', { name }, convertedVal); +} +exports.exportVariable = exportVariable; +/** + * Registers a secret which will get masked from logs + * @param secret value of the secret + */ +function setSecret(secret) { + (0, command_1.issueCommand)('add-mask', {}, secret); +} +exports.setSecret = setSecret; +/** + * Prepends inputPath to the PATH (for this action and future actions) + * @param inputPath + */ +function addPath(inputPath) { + const filePath = process.env['GITHUB_PATH'] || ''; + if (filePath) { + (0, file_command_1.issueFileCommand)('PATH', inputPath); + } + else { + (0, command_1.issueCommand)('add-path', {}, inputPath); + } + process.env['PATH'] = `${inputPath}${path.delimiter}${process.env['PATH']}`; +} +exports.addPath = addPath; +/** + * Gets the value of an input. + * Unless trimWhitespace is set to false in InputOptions, the value is also trimmed. + * Returns an empty string if the value is not defined. + * + * @param name name of the input to get + * @param options optional. See InputOptions. + * @returns string + */ +function getInput(name, options) { + const val = process.env[`INPUT_${name.replace(/ /g, '_').toUpperCase()}`] || ''; + if (options && options.required && !val) { + throw new Error(`Input required and not supplied: ${name}`); + } + if (options && options.trimWhitespace === false) { + return val; + } + return val.trim(); +} +exports.getInput = getInput; +/** + * Gets the values of an multiline input. Each value is also trimmed. + * + * @param name name of the input to get + * @param options optional. See InputOptions. + * @returns string[] + * + */ +function getMultilineInput(name, options) { + const inputs = getInput(name, options) + .split('\n') + .filter(x => x !== ''); + if (options && options.trimWhitespace === false) { + return inputs; + } + return inputs.map(input => input.trim()); +} +exports.getMultilineInput = getMultilineInput; +/** + * Gets the input value of the boolean type in the YAML 1.2 "core schema" specification. + * Support boolean input list: `true | True | TRUE | false | False | FALSE` . + * The return value is also in boolean type. + * ref: https://yaml.org/spec/1.2/spec.html#id2804923 + * + * @param name name of the input to get + * @param options optional. See InputOptions. + * @returns boolean + */ +function getBooleanInput(name, options) { + const trueValue = ['true', 'True', 'TRUE']; + const falseValue = ['false', 'False', 'FALSE']; + const val = getInput(name, options); + if (trueValue.includes(val)) + return true; + if (falseValue.includes(val)) + return false; + throw new TypeError(`Input does not meet YAML 1.2 "Core Schema" specification: ${name}\n` + + `Support boolean input list: \`true | True | TRUE | false | False | FALSE\``); +} +exports.getBooleanInput = getBooleanInput; +/** + * Sets the value of an output. + * + * @param name name of the output to set + * @param value value to store. Non-string values will be converted to a string via JSON.stringify + */ +// eslint-disable-next-line @typescript-eslint/no-explicit-any +function setOutput(name, value) { + const filePath = process.env['GITHUB_OUTPUT'] || ''; + if (filePath) { + return (0, file_command_1.issueFileCommand)('OUTPUT', (0, file_command_1.prepareKeyValueMessage)(name, value)); + } + process.stdout.write(os.EOL); + (0, command_1.issueCommand)('set-output', { name }, (0, utils_1.toCommandValue)(value)); +} +exports.setOutput = setOutput; +/** + * Enables or disables the echoing of commands into stdout for the rest of the step. + * Echoing is disabled by default if ACTIONS_STEP_DEBUG is not set. + * + */ +function setCommandEcho(enabled) { + (0, command_1.issue)('echo', enabled ? 'on' : 'off'); +} +exports.setCommandEcho = setCommandEcho; +//----------------------------------------------------------------------- +// Results +//----------------------------------------------------------------------- +/** + * Sets the action status to failed. + * When the action exits it will be with an exit code of 1 + * @param message add error issue message + */ +function setFailed(message) { + process.exitCode = ExitCode.Failure; + error(message); +} +exports.setFailed = setFailed; +//----------------------------------------------------------------------- +// Logging Commands +//----------------------------------------------------------------------- +/** + * Gets whether Actions Step Debug is on or not + */ +function isDebug() { + return process.env['RUNNER_DEBUG'] === '1'; +} +exports.isDebug = isDebug; +/** + * Writes debug message to user log + * @param message debug message + */ +function debug(message) { + (0, command_1.issueCommand)('debug', {}, message); +} +exports.debug = debug; +/** + * Adds an error issue + * @param message error issue message. Errors will be converted to string via toString() + * @param properties optional properties to add to the annotation. + */ +function error(message, properties = {}) { + (0, command_1.issueCommand)('error', (0, utils_1.toCommandProperties)(properties), message instanceof Error ? message.toString() : message); +} +exports.error = error; +/** + * Adds a warning issue + * @param message warning issue message. Errors will be converted to string via toString() + * @param properties optional properties to add to the annotation. + */ +function warning(message, properties = {}) { + (0, command_1.issueCommand)('warning', (0, utils_1.toCommandProperties)(properties), message instanceof Error ? message.toString() : message); +} +exports.warning = warning; +/** + * Adds a notice issue + * @param message notice issue message. Errors will be converted to string via toString() + * @param properties optional properties to add to the annotation. + */ +function notice(message, properties = {}) { + (0, command_1.issueCommand)('notice', (0, utils_1.toCommandProperties)(properties), message instanceof Error ? message.toString() : message); +} +exports.notice = notice; +/** + * Writes info to log with console.log. + * @param message info message + */ +function info(message) { + process.stdout.write(message + os.EOL); +} +exports.info = info; +/** + * Begin an output group. + * + * Output until the next `groupEnd` will be foldable in this group + * + * @param name The name of the output group + */ +function startGroup(name) { + (0, command_1.issue)('group', name); +} +exports.startGroup = startGroup; +/** + * End an output group. + */ +function endGroup() { + (0, command_1.issue)('endgroup'); +} +exports.endGroup = endGroup; +/** + * Wrap an asynchronous function call in a group. + * + * Returns the same type as the function itself. + * + * @param name The name of the group + * @param fn The function to wrap in the group + */ +function group(name, fn) { + return __awaiter(this, void 0, void 0, function* () { + startGroup(name); + let result; + try { + result = yield fn(); + } + finally { + endGroup(); + } + return result; + }); +} +exports.group = group; +//----------------------------------------------------------------------- +// Wrapper action state +//----------------------------------------------------------------------- +/** + * Saves state for current action, the state can only be retrieved by this action's post job execution. + * + * @param name name of the state to store + * @param value value to store. Non-string values will be converted to a string via JSON.stringify + */ +// eslint-disable-next-line @typescript-eslint/no-explicit-any +function saveState(name, value) { + const filePath = process.env['GITHUB_STATE'] || ''; + if (filePath) { + return (0, file_command_1.issueFileCommand)('STATE', (0, file_command_1.prepareKeyValueMessage)(name, value)); + } + (0, command_1.issueCommand)('save-state', { name }, (0, utils_1.toCommandValue)(value)); +} +exports.saveState = saveState; +/** + * Gets the value of an state set by this action's main execution. + * + * @param name name of the state to get + * @returns string + */ +function getState(name) { + return process.env[`STATE_${name}`] || ''; +} +exports.getState = getState; +function getIDToken(aud) { + return __awaiter(this, void 0, void 0, function* () { + return yield oidc_utils_1.OidcClient.getIDToken(aud); + }); +} +exports.getIDToken = getIDToken; +/** + * Summary exports + */ +var summary_1 = __nccwpck_require__(1847); +Object.defineProperty(exports, "summary", ({ enumerable: true, get: function () { return summary_1.summary; } })); +/** + * @deprecated use core.summary + */ +var summary_2 = __nccwpck_require__(1847); +Object.defineProperty(exports, "markdownSummary", ({ enumerable: true, get: function () { return summary_2.markdownSummary; } })); +/** + * Path exports + */ +var path_utils_1 = __nccwpck_require__(1976); +Object.defineProperty(exports, "toPosixPath", ({ enumerable: true, get: function () { return path_utils_1.toPosixPath; } })); +Object.defineProperty(exports, "toWin32Path", ({ enumerable: true, get: function () { return path_utils_1.toWin32Path; } })); +Object.defineProperty(exports, "toPlatformPath", ({ enumerable: true, get: function () { return path_utils_1.toPlatformPath; } })); +/** + * Platform utilities exports + */ +exports.platform = __importStar(__nccwpck_require__(8968)); +//# sourceMappingURL=core.js.map + +/***/ }), + +/***/ 4753: +/***/ (function(__unused_webpack_module, exports, __nccwpck_require__) { + + +// For internal use, subject to change. +var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) { + if (k2 === undefined) k2 = k; + var desc = Object.getOwnPropertyDescriptor(m, k); + if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) { + desc = { enumerable: true, get: function() { return m[k]; } }; + } + Object.defineProperty(o, k2, desc); +}) : (function(o, m, k, k2) { + if (k2 === undefined) k2 = k; + o[k2] = m[k]; +})); +var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) { + Object.defineProperty(o, "default", { enumerable: true, value: v }); +}) : function(o, v) { + o["default"] = v; +}); +var __importStar = (this && this.__importStar) || function (mod) { + if (mod && mod.__esModule) return mod; + var result = {}; + if (mod != null) for (var k in mod) if (k !== "default" && Object.prototype.hasOwnProperty.call(mod, k)) __createBinding(result, mod, k); + __setModuleDefault(result, mod); + return result; +}; +Object.defineProperty(exports, "__esModule", ({ value: true })); +exports.prepareKeyValueMessage = exports.issueFileCommand = void 0; +// We use any as a valid input type +/* eslint-disable @typescript-eslint/no-explicit-any */ +const crypto = __importStar(__nccwpck_require__(6982)); +const fs = __importStar(__nccwpck_require__(9896)); +const os = __importStar(__nccwpck_require__(857)); +const utils_1 = __nccwpck_require__(302); +function issueFileCommand(command, message) { + const filePath = process.env[`GITHUB_${command}`]; + if (!filePath) { + throw new Error(`Unable to find environment variable for file command ${command}`); + } + if (!fs.existsSync(filePath)) { + throw new Error(`Missing file at path: ${filePath}`); + } + fs.appendFileSync(filePath, `${(0, utils_1.toCommandValue)(message)}${os.EOL}`, { + encoding: 'utf8' + }); +} +exports.issueFileCommand = issueFileCommand; +function prepareKeyValueMessage(key, value) { + const delimiter = `ghadelimiter_${crypto.randomUUID()}`; + const convertedValue = (0, utils_1.toCommandValue)(value); + // These should realistically never happen, but just in case someone finds a + // way to exploit uuid generation let's not allow keys or values that contain + // the delimiter. + if (key.includes(delimiter)) { + throw new Error(`Unexpected input: name should not contain the delimiter "${delimiter}"`); + } + if (convertedValue.includes(delimiter)) { + throw new Error(`Unexpected input: value should not contain the delimiter "${delimiter}"`); + } + return `${key}<<${delimiter}${os.EOL}${convertedValue}${os.EOL}${delimiter}`; +} +exports.prepareKeyValueMessage = prepareKeyValueMessage; +//# sourceMappingURL=file-command.js.map + +/***/ }), + +/***/ 5306: +/***/ (function(__unused_webpack_module, exports, __nccwpck_require__) { + + +var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) { + function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); } + return new (P || (P = Promise))(function (resolve, reject) { + function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } } + function rejected(value) { try { step(generator["throw"](value)); } catch (e) { reject(e); } } + function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); } + step((generator = generator.apply(thisArg, _arguments || [])).next()); + }); +}; +Object.defineProperty(exports, "__esModule", ({ value: true })); +exports.OidcClient = void 0; +const http_client_1 = __nccwpck_require__(4844); +const auth_1 = __nccwpck_require__(4552); +const core_1 = __nccwpck_require__(7484); +class OidcClient { + static createHttpClient(allowRetry = true, maxRetry = 10) { + const requestOptions = { + allowRetries: allowRetry, + maxRetries: maxRetry + }; + return new http_client_1.HttpClient('actions/oidc-client', [new auth_1.BearerCredentialHandler(OidcClient.getRequestToken())], requestOptions); + } + static getRequestToken() { + const token = process.env['ACTIONS_ID_TOKEN_REQUEST_TOKEN']; + if (!token) { + throw new Error('Unable to get ACTIONS_ID_TOKEN_REQUEST_TOKEN env variable'); + } + return token; + } + static getIDTokenUrl() { + const runtimeUrl = process.env['ACTIONS_ID_TOKEN_REQUEST_URL']; + if (!runtimeUrl) { + throw new Error('Unable to get ACTIONS_ID_TOKEN_REQUEST_URL env variable'); + } + return runtimeUrl; + } + static getCall(id_token_url) { + var _a; + return __awaiter(this, void 0, void 0, function* () { + const httpclient = OidcClient.createHttpClient(); + const res = yield httpclient + .getJson(id_token_url) + .catch(error => { + throw new Error(`Failed to get ID Token. \n + Error Code : ${error.statusCode}\n + Error Message: ${error.message}`); + }); + const id_token = (_a = res.result) === null || _a === void 0 ? void 0 : _a.value; + if (!id_token) { + throw new Error('Response json body do not have ID Token field'); + } + return id_token; + }); + } + static getIDToken(audience) { + return __awaiter(this, void 0, void 0, function* () { + try { + // New ID Token is requested from action service + let id_token_url = OidcClient.getIDTokenUrl(); + if (audience) { + const encodedAudience = encodeURIComponent(audience); + id_token_url = `${id_token_url}&audience=${encodedAudience}`; + } + (0, core_1.debug)(`ID token url is ${id_token_url}`); + const id_token = yield OidcClient.getCall(id_token_url); + (0, core_1.setSecret)(id_token); + return id_token; + } + catch (error) { + throw new Error(`Error message: ${error.message}`); + } + }); + } +} +exports.OidcClient = OidcClient; +//# sourceMappingURL=oidc-utils.js.map + +/***/ }), + +/***/ 1976: +/***/ (function(__unused_webpack_module, exports, __nccwpck_require__) { + + +var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) { + if (k2 === undefined) k2 = k; + var desc = Object.getOwnPropertyDescriptor(m, k); + if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) { + desc = { enumerable: true, get: function() { return m[k]; } }; + } + Object.defineProperty(o, k2, desc); +}) : (function(o, m, k, k2) { + if (k2 === undefined) k2 = k; + o[k2] = m[k]; +})); +var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) { + Object.defineProperty(o, "default", { enumerable: true, value: v }); +}) : function(o, v) { + o["default"] = v; +}); +var __importStar = (this && this.__importStar) || function (mod) { + if (mod && mod.__esModule) return mod; + var result = {}; + if (mod != null) for (var k in mod) if (k !== "default" && Object.prototype.hasOwnProperty.call(mod, k)) __createBinding(result, mod, k); + __setModuleDefault(result, mod); + return result; +}; +Object.defineProperty(exports, "__esModule", ({ value: true })); +exports.toPlatformPath = exports.toWin32Path = exports.toPosixPath = void 0; +const path = __importStar(__nccwpck_require__(6928)); +/** + * toPosixPath converts the given path to the posix form. On Windows, \\ will be + * replaced with /. + * + * @param pth. Path to transform. + * @return string Posix path. + */ +function toPosixPath(pth) { + return pth.replace(/[\\]/g, '/'); +} +exports.toPosixPath = toPosixPath; +/** + * toWin32Path converts the given path to the win32 form. On Linux, / will be + * replaced with \\. + * + * @param pth. Path to transform. + * @return string Win32 path. + */ +function toWin32Path(pth) { + return pth.replace(/[/]/g, '\\'); +} +exports.toWin32Path = toWin32Path; +/** + * toPlatformPath converts the given path to a platform-specific path. It does + * this by replacing instances of / and \ with the platform-specific path + * separator. + * + * @param pth The path to platformize. + * @return string The platform-specific path. + */ +function toPlatformPath(pth) { + return pth.replace(/[/\\]/g, path.sep); +} +exports.toPlatformPath = toPlatformPath; +//# sourceMappingURL=path-utils.js.map + +/***/ }), + +/***/ 8968: +/***/ (function(__unused_webpack_module, exports, __nccwpck_require__) { + + +var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) { + if (k2 === undefined) k2 = k; + var desc = Object.getOwnPropertyDescriptor(m, k); + if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) { + desc = { enumerable: true, get: function() { return m[k]; } }; + } + Object.defineProperty(o, k2, desc); +}) : (function(o, m, k, k2) { + if (k2 === undefined) k2 = k; + o[k2] = m[k]; +})); +var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) { + Object.defineProperty(o, "default", { enumerable: true, value: v }); +}) : function(o, v) { + o["default"] = v; +}); +var __importStar = (this && this.__importStar) || function (mod) { + if (mod && mod.__esModule) return mod; + var result = {}; + if (mod != null) for (var k in mod) if (k !== "default" && Object.prototype.hasOwnProperty.call(mod, k)) __createBinding(result, mod, k); + __setModuleDefault(result, mod); + return result; +}; +var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) { + function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); } + return new (P || (P = Promise))(function (resolve, reject) { + function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } } + function rejected(value) { try { step(generator["throw"](value)); } catch (e) { reject(e); } } + function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); } + step((generator = generator.apply(thisArg, _arguments || [])).next()); + }); +}; +var __importDefault = (this && this.__importDefault) || function (mod) { + return (mod && mod.__esModule) ? mod : { "default": mod }; +}; +Object.defineProperty(exports, "__esModule", ({ value: true })); +exports.getDetails = exports.isLinux = exports.isMacOS = exports.isWindows = exports.arch = exports.platform = void 0; +const os_1 = __importDefault(__nccwpck_require__(857)); +const exec = __importStar(__nccwpck_require__(5236)); +const getWindowsInfo = () => __awaiter(void 0, void 0, void 0, function* () { + const { stdout: version } = yield exec.getExecOutput('powershell -command "(Get-CimInstance -ClassName Win32_OperatingSystem).Version"', undefined, { + silent: true + }); + const { stdout: name } = yield exec.getExecOutput('powershell -command "(Get-CimInstance -ClassName Win32_OperatingSystem).Caption"', undefined, { + silent: true + }); + return { + name: name.trim(), + version: version.trim() + }; +}); +const getMacOsInfo = () => __awaiter(void 0, void 0, void 0, function* () { + var _a, _b, _c, _d; + const { stdout } = yield exec.getExecOutput('sw_vers', undefined, { + silent: true + }); + const version = (_b = (_a = stdout.match(/ProductVersion:\s*(.+)/)) === null || _a === void 0 ? void 0 : _a[1]) !== null && _b !== void 0 ? _b : ''; + const name = (_d = (_c = stdout.match(/ProductName:\s*(.+)/)) === null || _c === void 0 ? void 0 : _c[1]) !== null && _d !== void 0 ? _d : ''; + return { + name, + version + }; +}); +const getLinuxInfo = () => __awaiter(void 0, void 0, void 0, function* () { + const { stdout } = yield exec.getExecOutput('lsb_release', ['-i', '-r', '-s'], { + silent: true + }); + const [name, version] = stdout.trim().split('\n'); + return { + name, + version + }; +}); +exports.platform = os_1.default.platform(); +exports.arch = os_1.default.arch(); +exports.isWindows = exports.platform === 'win32'; +exports.isMacOS = exports.platform === 'darwin'; +exports.isLinux = exports.platform === 'linux'; +function getDetails() { + return __awaiter(this, void 0, void 0, function* () { + return Object.assign(Object.assign({}, (yield (exports.isWindows + ? getWindowsInfo() + : exports.isMacOS + ? getMacOsInfo() + : getLinuxInfo()))), { platform: exports.platform, + arch: exports.arch, + isWindows: exports.isWindows, + isMacOS: exports.isMacOS, + isLinux: exports.isLinux }); + }); +} +exports.getDetails = getDetails; +//# sourceMappingURL=platform.js.map + +/***/ }), + +/***/ 1847: +/***/ (function(__unused_webpack_module, exports, __nccwpck_require__) { + + +var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) { + function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); } + return new (P || (P = Promise))(function (resolve, reject) { + function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } } + function rejected(value) { try { step(generator["throw"](value)); } catch (e) { reject(e); } } + function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); } + step((generator = generator.apply(thisArg, _arguments || [])).next()); + }); +}; +Object.defineProperty(exports, "__esModule", ({ value: true })); +exports.summary = exports.markdownSummary = exports.SUMMARY_DOCS_URL = exports.SUMMARY_ENV_VAR = void 0; +const os_1 = __nccwpck_require__(857); +const fs_1 = __nccwpck_require__(9896); +const { access, appendFile, writeFile } = fs_1.promises; +exports.SUMMARY_ENV_VAR = 'GITHUB_STEP_SUMMARY'; +exports.SUMMARY_DOCS_URL = 'https://docs.github.com/actions/using-workflows/workflow-commands-for-github-actions#adding-a-job-summary'; +class Summary { + constructor() { + this._buffer = ''; + } + /** + * Finds the summary file path from the environment, rejects if env var is not found or file does not exist + * Also checks r/w permissions. + * + * @returns step summary file path + */ + filePath() { + return __awaiter(this, void 0, void 0, function* () { + if (this._filePath) { + return this._filePath; + } + const pathFromEnv = process.env[exports.SUMMARY_ENV_VAR]; + if (!pathFromEnv) { + throw new Error(`Unable to find environment variable for $${exports.SUMMARY_ENV_VAR}. Check if your runtime environment supports job summaries.`); + } + try { + yield access(pathFromEnv, fs_1.constants.R_OK | fs_1.constants.W_OK); + } + catch (_a) { + throw new Error(`Unable to access summary file: '${pathFromEnv}'. Check if the file has correct read/write permissions.`); + } + this._filePath = pathFromEnv; + return this._filePath; + }); + } + /** + * Wraps content in an HTML tag, adding any HTML attributes + * + * @param {string} tag HTML tag to wrap + * @param {string | null} content content within the tag + * @param {[attribute: string]: string} attrs key-value list of HTML attributes to add + * + * @returns {string} content wrapped in HTML element + */ + wrap(tag, content, attrs = {}) { + const htmlAttrs = Object.entries(attrs) + .map(([key, value]) => ` ${key}="${value}"`) + .join(''); + if (!content) { + return `<${tag}${htmlAttrs}>`; + } + return `<${tag}${htmlAttrs}>${content}`; + } + /** + * Writes text in the buffer to the summary buffer file and empties buffer. Will append by default. + * + * @param {SummaryWriteOptions} [options] (optional) options for write operation + * + * @returns {Promise} summary instance + */ + write(options) { + return __awaiter(this, void 0, void 0, function* () { + const overwrite = !!(options === null || options === void 0 ? void 0 : options.overwrite); + const filePath = yield this.filePath(); + const writeFunc = overwrite ? writeFile : appendFile; + yield writeFunc(filePath, this._buffer, { encoding: 'utf8' }); + return this.emptyBuffer(); + }); + } + /** + * Clears the summary buffer and wipes the summary file + * + * @returns {Summary} summary instance + */ + clear() { + return __awaiter(this, void 0, void 0, function* () { + return this.emptyBuffer().write({ overwrite: true }); + }); + } + /** + * Returns the current summary buffer as a string + * + * @returns {string} string of summary buffer + */ + stringify() { + return this._buffer; + } + /** + * If the summary buffer is empty + * + * @returns {boolen} true if the buffer is empty + */ + isEmptyBuffer() { + return this._buffer.length === 0; + } + /** + * Resets the summary buffer without writing to summary file + * + * @returns {Summary} summary instance + */ + emptyBuffer() { + this._buffer = ''; + return this; + } + /** + * Adds raw text to the summary buffer + * + * @param {string} text content to add + * @param {boolean} [addEOL=false] (optional) append an EOL to the raw text (default: false) + * + * @returns {Summary} summary instance + */ + addRaw(text, addEOL = false) { + this._buffer += text; + return addEOL ? this.addEOL() : this; + } + /** + * Adds the operating system-specific end-of-line marker to the buffer + * + * @returns {Summary} summary instance + */ + addEOL() { + return this.addRaw(os_1.EOL); + } + /** + * Adds an HTML codeblock to the summary buffer + * + * @param {string} code content to render within fenced code block + * @param {string} lang (optional) language to syntax highlight code + * + * @returns {Summary} summary instance + */ + addCodeBlock(code, lang) { + const attrs = Object.assign({}, (lang && { lang })); + const element = this.wrap('pre', this.wrap('code', code), attrs); + return this.addRaw(element).addEOL(); + } + /** + * Adds an HTML list to the summary buffer + * + * @param {string[]} items list of items to render + * @param {boolean} [ordered=false] (optional) if the rendered list should be ordered or not (default: false) + * + * @returns {Summary} summary instance + */ + addList(items, ordered = false) { + const tag = ordered ? 'ol' : 'ul'; + const listItems = items.map(item => this.wrap('li', item)).join(''); + const element = this.wrap(tag, listItems); + return this.addRaw(element).addEOL(); + } + /** + * Adds an HTML table to the summary buffer + * + * @param {SummaryTableCell[]} rows table rows + * + * @returns {Summary} summary instance + */ + addTable(rows) { + const tableBody = rows + .map(row => { + const cells = row + .map(cell => { + if (typeof cell === 'string') { + return this.wrap('td', cell); + } + const { header, data, colspan, rowspan } = cell; + const tag = header ? 'th' : 'td'; + const attrs = Object.assign(Object.assign({}, (colspan && { colspan })), (rowspan && { rowspan })); + return this.wrap(tag, data, attrs); + }) + .join(''); + return this.wrap('tr', cells); + }) + .join(''); + const element = this.wrap('table', tableBody); + return this.addRaw(element).addEOL(); + } + /** + * Adds a collapsable HTML details element to the summary buffer + * + * @param {string} label text for the closed state + * @param {string} content collapsable content + * + * @returns {Summary} summary instance + */ + addDetails(label, content) { + const element = this.wrap('details', this.wrap('summary', label) + content); + return this.addRaw(element).addEOL(); + } + /** + * Adds an HTML image tag to the summary buffer + * + * @param {string} src path to the image you to embed + * @param {string} alt text description of the image + * @param {SummaryImageOptions} options (optional) addition image attributes + * + * @returns {Summary} summary instance + */ + addImage(src, alt, options) { + const { width, height } = options || {}; + const attrs = Object.assign(Object.assign({}, (width && { width })), (height && { height })); + const element = this.wrap('img', null, Object.assign({ src, alt }, attrs)); + return this.addRaw(element).addEOL(); + } + /** + * Adds an HTML section heading element + * + * @param {string} text heading text + * @param {number | string} [level=1] (optional) the heading level, default: 1 + * + * @returns {Summary} summary instance + */ + addHeading(text, level) { + const tag = `h${level}`; + const allowedTag = ['h1', 'h2', 'h3', 'h4', 'h5', 'h6'].includes(tag) + ? tag + : 'h1'; + const element = this.wrap(allowedTag, text); + return this.addRaw(element).addEOL(); + } + /** + * Adds an HTML thematic break (
) to the summary buffer + * + * @returns {Summary} summary instance + */ + addSeparator() { + const element = this.wrap('hr', null); + return this.addRaw(element).addEOL(); + } + /** + * Adds an HTML line break (
) to the summary buffer + * + * @returns {Summary} summary instance + */ + addBreak() { + const element = this.wrap('br', null); + return this.addRaw(element).addEOL(); + } + /** + * Adds an HTML blockquote to the summary buffer + * + * @param {string} text quote text + * @param {string} cite (optional) citation url + * + * @returns {Summary} summary instance + */ + addQuote(text, cite) { + const attrs = Object.assign({}, (cite && { cite })); + const element = this.wrap('blockquote', text, attrs); + return this.addRaw(element).addEOL(); + } + /** + * Adds an HTML anchor tag to the summary buffer + * + * @param {string} text link text/content + * @param {string} href hyperlink + * + * @returns {Summary} summary instance + */ + addLink(text, href) { + const element = this.wrap('a', text, { href }); + return this.addRaw(element).addEOL(); + } +} +const _summary = new Summary(); +/** + * @deprecated use `core.summary` + */ +exports.markdownSummary = _summary; +exports.summary = _summary; +//# sourceMappingURL=summary.js.map + +/***/ }), + +/***/ 302: +/***/ ((__unused_webpack_module, exports) => { + + +// We use any as a valid input type +/* eslint-disable @typescript-eslint/no-explicit-any */ +Object.defineProperty(exports, "__esModule", ({ value: true })); +exports.toCommandProperties = exports.toCommandValue = void 0; +/** + * Sanitizes an input into a string so it can be passed into issueCommand safely + * @param input input to sanitize into a string + */ +function toCommandValue(input) { + if (input === null || input === undefined) { + return ''; + } + else if (typeof input === 'string' || input instanceof String) { + return input; + } + return JSON.stringify(input); +} +exports.toCommandValue = toCommandValue; +/** + * + * @param annotationProperties + * @returns The command properties to send with the actual annotation command + * See IssueCommandProperties: https://github.com/actions/runner/blob/main/src/Runner.Worker/ActionCommandManager.cs#L646 + */ +function toCommandProperties(annotationProperties) { + if (!Object.keys(annotationProperties).length) { + return {}; + } + return { + title: annotationProperties.title, + file: annotationProperties.file, + line: annotationProperties.startLine, + endLine: annotationProperties.endLine, + col: annotationProperties.startColumn, + endColumn: annotationProperties.endColumn + }; +} +exports.toCommandProperties = toCommandProperties; +//# sourceMappingURL=utils.js.map + +/***/ }), + +/***/ 5236: +/***/ (function(__unused_webpack_module, exports, __nccwpck_require__) { + + +var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) { + if (k2 === undefined) k2 = k; + Object.defineProperty(o, k2, { enumerable: true, get: function() { return m[k]; } }); +}) : (function(o, m, k, k2) { + if (k2 === undefined) k2 = k; + o[k2] = m[k]; +})); +var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) { + Object.defineProperty(o, "default", { enumerable: true, value: v }); +}) : function(o, v) { + o["default"] = v; +}); +var __importStar = (this && this.__importStar) || function (mod) { + if (mod && mod.__esModule) return mod; + var result = {}; + if (mod != null) for (var k in mod) if (k !== "default" && Object.hasOwnProperty.call(mod, k)) __createBinding(result, mod, k); + __setModuleDefault(result, mod); + return result; +}; +var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) { + function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); } + return new (P || (P = Promise))(function (resolve, reject) { + function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } } + function rejected(value) { try { step(generator["throw"](value)); } catch (e) { reject(e); } } + function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); } + step((generator = generator.apply(thisArg, _arguments || [])).next()); + }); +}; +Object.defineProperty(exports, "__esModule", ({ value: true })); +exports.getExecOutput = exports.exec = void 0; +const string_decoder_1 = __nccwpck_require__(3193); +const tr = __importStar(__nccwpck_require__(6665)); +/** + * Exec a command. + * Output will be streamed to the live console. + * Returns promise with return code + * + * @param commandLine command to execute (can include additional args). Must be correctly escaped. + * @param args optional arguments for tool. Escaping is handled by the lib. + * @param options optional exec options. See ExecOptions + * @returns Promise exit code + */ +function exec(commandLine, args, options) { + return __awaiter(this, void 0, void 0, function* () { + const commandArgs = tr.argStringToArray(commandLine); + if (commandArgs.length === 0) { + throw new Error(`Parameter 'commandLine' cannot be null or empty.`); + } + // Path to tool to execute should be first arg + const toolPath = commandArgs[0]; + args = commandArgs.slice(1).concat(args || []); + const runner = new tr.ToolRunner(toolPath, args, options); + return runner.exec(); + }); +} +exports.exec = exec; +/** + * Exec a command and get the output. + * Output will be streamed to the live console. + * Returns promise with the exit code and collected stdout and stderr + * + * @param commandLine command to execute (can include additional args). Must be correctly escaped. + * @param args optional arguments for tool. Escaping is handled by the lib. + * @param options optional exec options. See ExecOptions + * @returns Promise exit code, stdout, and stderr + */ +function getExecOutput(commandLine, args, options) { + var _a, _b; + return __awaiter(this, void 0, void 0, function* () { + let stdout = ''; + let stderr = ''; + //Using string decoder covers the case where a mult-byte character is split + const stdoutDecoder = new string_decoder_1.StringDecoder('utf8'); + const stderrDecoder = new string_decoder_1.StringDecoder('utf8'); + const originalStdoutListener = (_a = options === null || options === void 0 ? void 0 : options.listeners) === null || _a === void 0 ? void 0 : _a.stdout; + const originalStdErrListener = (_b = options === null || options === void 0 ? void 0 : options.listeners) === null || _b === void 0 ? void 0 : _b.stderr; + const stdErrListener = (data) => { + stderr += stderrDecoder.write(data); + if (originalStdErrListener) { + originalStdErrListener(data); + } + }; + const stdOutListener = (data) => { + stdout += stdoutDecoder.write(data); + if (originalStdoutListener) { + originalStdoutListener(data); + } + }; + const listeners = Object.assign(Object.assign({}, options === null || options === void 0 ? void 0 : options.listeners), { stdout: stdOutListener, stderr: stdErrListener }); + const exitCode = yield exec(commandLine, args, Object.assign(Object.assign({}, options), { listeners })); + //flush any remaining characters + stdout += stdoutDecoder.end(); + stderr += stderrDecoder.end(); + return { + exitCode, + stdout, + stderr + }; + }); +} +exports.getExecOutput = getExecOutput; +//# sourceMappingURL=exec.js.map + +/***/ }), + +/***/ 6665: +/***/ (function(__unused_webpack_module, exports, __nccwpck_require__) { + + +var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) { + if (k2 === undefined) k2 = k; + Object.defineProperty(o, k2, { enumerable: true, get: function() { return m[k]; } }); +}) : (function(o, m, k, k2) { + if (k2 === undefined) k2 = k; + o[k2] = m[k]; +})); +var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) { + Object.defineProperty(o, "default", { enumerable: true, value: v }); +}) : function(o, v) { + o["default"] = v; +}); +var __importStar = (this && this.__importStar) || function (mod) { + if (mod && mod.__esModule) return mod; + var result = {}; + if (mod != null) for (var k in mod) if (k !== "default" && Object.hasOwnProperty.call(mod, k)) __createBinding(result, mod, k); + __setModuleDefault(result, mod); + return result; +}; +var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) { + function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); } + return new (P || (P = Promise))(function (resolve, reject) { + function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } } + function rejected(value) { try { step(generator["throw"](value)); } catch (e) { reject(e); } } + function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); } + step((generator = generator.apply(thisArg, _arguments || [])).next()); + }); +}; +Object.defineProperty(exports, "__esModule", ({ value: true })); +exports.argStringToArray = exports.ToolRunner = void 0; +const os = __importStar(__nccwpck_require__(857)); +const events = __importStar(__nccwpck_require__(4434)); +const child = __importStar(__nccwpck_require__(5317)); +const path = __importStar(__nccwpck_require__(6928)); +const io = __importStar(__nccwpck_require__(4994)); +const ioUtil = __importStar(__nccwpck_require__(5207)); +const timers_1 = __nccwpck_require__(3557); +/* eslint-disable @typescript-eslint/unbound-method */ +const IS_WINDOWS = process.platform === 'win32'; +/* + * Class for running command line tools. Handles quoting and arg parsing in a platform agnostic way. + */ +class ToolRunner extends events.EventEmitter { + constructor(toolPath, args, options) { + super(); + if (!toolPath) { + throw new Error("Parameter 'toolPath' cannot be null or empty."); + } + this.toolPath = toolPath; + this.args = args || []; + this.options = options || {}; + } + _debug(message) { + if (this.options.listeners && this.options.listeners.debug) { + this.options.listeners.debug(message); + } + } + _getCommandString(options, noPrefix) { + const toolPath = this._getSpawnFileName(); + const args = this._getSpawnArgs(options); + let cmd = noPrefix ? '' : '[command]'; // omit prefix when piped to a second tool + if (IS_WINDOWS) { + // Windows + cmd file + if (this._isCmdFile()) { + cmd += toolPath; + for (const a of args) { + cmd += ` ${a}`; + } + } + // Windows + verbatim + else if (options.windowsVerbatimArguments) { + cmd += `"${toolPath}"`; + for (const a of args) { + cmd += ` ${a}`; + } + } + // Windows (regular) + else { + cmd += this._windowsQuoteCmdArg(toolPath); + for (const a of args) { + cmd += ` ${this._windowsQuoteCmdArg(a)}`; + } + } + } + else { + // OSX/Linux - this can likely be improved with some form of quoting. + // creating processes on Unix is fundamentally different than Windows. + // on Unix, execvp() takes an arg array. + cmd += toolPath; + for (const a of args) { + cmd += ` ${a}`; + } + } + return cmd; + } + _processLineBuffer(data, strBuffer, onLine) { + try { + let s = strBuffer + data.toString(); + let n = s.indexOf(os.EOL); + while (n > -1) { + const line = s.substring(0, n); + onLine(line); + // the rest of the string ... + s = s.substring(n + os.EOL.length); + n = s.indexOf(os.EOL); + } + return s; + } + catch (err) { + // streaming lines to console is best effort. Don't fail a build. + this._debug(`error processing line. Failed with error ${err}`); + return ''; + } + } + _getSpawnFileName() { + if (IS_WINDOWS) { + if (this._isCmdFile()) { + return process.env['COMSPEC'] || 'cmd.exe'; + } + } + return this.toolPath; + } + _getSpawnArgs(options) { + if (IS_WINDOWS) { + if (this._isCmdFile()) { + let argline = `/D /S /C "${this._windowsQuoteCmdArg(this.toolPath)}`; + for (const a of this.args) { + argline += ' '; + argline += options.windowsVerbatimArguments + ? a + : this._windowsQuoteCmdArg(a); + } + argline += '"'; + return [argline]; + } + } + return this.args; + } + _endsWith(str, end) { + return str.endsWith(end); + } + _isCmdFile() { + const upperToolPath = this.toolPath.toUpperCase(); + return (this._endsWith(upperToolPath, '.CMD') || + this._endsWith(upperToolPath, '.BAT')); + } + _windowsQuoteCmdArg(arg) { + // for .exe, apply the normal quoting rules that libuv applies + if (!this._isCmdFile()) { + return this._uvQuoteCmdArg(arg); + } + // otherwise apply quoting rules specific to the cmd.exe command line parser. + // the libuv rules are generic and are not designed specifically for cmd.exe + // command line parser. + // + // for a detailed description of the cmd.exe command line parser, refer to + // http://stackoverflow.com/questions/4094699/how-does-the-windows-command-interpreter-cmd-exe-parse-scripts/7970912#7970912 + // need quotes for empty arg + if (!arg) { + return '""'; + } + // determine whether the arg needs to be quoted + const cmdSpecialChars = [ + ' ', + '\t', + '&', + '(', + ')', + '[', + ']', + '{', + '}', + '^', + '=', + ';', + '!', + "'", + '+', + ',', + '`', + '~', + '|', + '<', + '>', + '"' + ]; + let needsQuotes = false; + for (const char of arg) { + if (cmdSpecialChars.some(x => x === char)) { + needsQuotes = true; + break; + } + } + // short-circuit if quotes not needed + if (!needsQuotes) { + return arg; + } + // the following quoting rules are very similar to the rules that by libuv applies. + // + // 1) wrap the string in quotes + // + // 2) double-up quotes - i.e. " => "" + // + // this is different from the libuv quoting rules. libuv replaces " with \", which unfortunately + // doesn't work well with a cmd.exe command line. + // + // note, replacing " with "" also works well if the arg is passed to a downstream .NET console app. + // for example, the command line: + // foo.exe "myarg:""my val""" + // is parsed by a .NET console app into an arg array: + // [ "myarg:\"my val\"" ] + // which is the same end result when applying libuv quoting rules. although the actual + // command line from libuv quoting rules would look like: + // foo.exe "myarg:\"my val\"" + // + // 3) double-up slashes that precede a quote, + // e.g. hello \world => "hello \world" + // hello\"world => "hello\\""world" + // hello\\"world => "hello\\\\""world" + // hello world\ => "hello world\\" + // + // technically this is not required for a cmd.exe command line, or the batch argument parser. + // the reasons for including this as a .cmd quoting rule are: + // + // a) this is optimized for the scenario where the argument is passed from the .cmd file to an + // external program. many programs (e.g. .NET console apps) rely on the slash-doubling rule. + // + // b) it's what we've been doing previously (by deferring to node default behavior) and we + // haven't heard any complaints about that aspect. + // + // note, a weakness of the quoting rules chosen here, is that % is not escaped. in fact, % cannot be + // escaped when used on the command line directly - even though within a .cmd file % can be escaped + // by using %%. + // + // the saving grace is, on the command line, %var% is left as-is if var is not defined. this contrasts + // the line parsing rules within a .cmd file, where if var is not defined it is replaced with nothing. + // + // one option that was explored was replacing % with ^% - i.e. %var% => ^%var^%. this hack would + // often work, since it is unlikely that var^ would exist, and the ^ character is removed when the + // variable is used. the problem, however, is that ^ is not removed when %* is used to pass the args + // to an external program. + // + // an unexplored potential solution for the % escaping problem, is to create a wrapper .cmd file. + // % can be escaped within a .cmd file. + let reverse = '"'; + let quoteHit = true; + for (let i = arg.length; i > 0; i--) { + // walk the string in reverse + reverse += arg[i - 1]; + if (quoteHit && arg[i - 1] === '\\') { + reverse += '\\'; // double the slash + } + else if (arg[i - 1] === '"') { + quoteHit = true; + reverse += '"'; // double the quote + } + else { + quoteHit = false; + } + } + reverse += '"'; + return reverse + .split('') + .reverse() + .join(''); + } + _uvQuoteCmdArg(arg) { + // Tool runner wraps child_process.spawn() and needs to apply the same quoting as + // Node in certain cases where the undocumented spawn option windowsVerbatimArguments + // is used. + // + // Since this function is a port of quote_cmd_arg from Node 4.x (technically, lib UV, + // see https://github.com/nodejs/node/blob/v4.x/deps/uv/src/win/process.c for details), + // pasting copyright notice from Node within this function: + // + // Copyright Joyent, Inc. and other Node contributors. All rights reserved. + // + // Permission is hereby granted, free of charge, to any person obtaining a copy + // of this software and associated documentation files (the "Software"), to + // deal in the Software without restriction, including without limitation the + // rights to use, copy, modify, merge, publish, distribute, sublicense, and/or + // sell copies of the Software, and to permit persons to whom the Software is + // furnished to do so, subject to the following conditions: + // + // The above copyright notice and this permission notice shall be included in + // all copies or substantial portions of the Software. + // + // THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR + // IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, + // FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE + // AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER + // LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING + // FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS + // IN THE SOFTWARE. + if (!arg) { + // Need double quotation for empty argument + return '""'; + } + if (!arg.includes(' ') && !arg.includes('\t') && !arg.includes('"')) { + // No quotation needed + return arg; + } + if (!arg.includes('"') && !arg.includes('\\')) { + // No embedded double quotes or backslashes, so I can just wrap + // quote marks around the whole thing. + return `"${arg}"`; + } + // Expected input/output: + // input : hello"world + // output: "hello\"world" + // input : hello""world + // output: "hello\"\"world" + // input : hello\world + // output: hello\world + // input : hello\\world + // output: hello\\world + // input : hello\"world + // output: "hello\\\"world" + // input : hello\\"world + // output: "hello\\\\\"world" + // input : hello world\ + // output: "hello world\\" - note the comment in libuv actually reads "hello world\" + // but it appears the comment is wrong, it should be "hello world\\" + let reverse = '"'; + let quoteHit = true; + for (let i = arg.length; i > 0; i--) { + // walk the string in reverse + reverse += arg[i - 1]; + if (quoteHit && arg[i - 1] === '\\') { + reverse += '\\'; + } + else if (arg[i - 1] === '"') { + quoteHit = true; + reverse += '\\'; + } + else { + quoteHit = false; + } + } + reverse += '"'; + return reverse + .split('') + .reverse() + .join(''); + } + _cloneExecOptions(options) { + options = options || {}; + const result = { + cwd: options.cwd || process.cwd(), + env: options.env || process.env, + silent: options.silent || false, + windowsVerbatimArguments: options.windowsVerbatimArguments || false, + failOnStdErr: options.failOnStdErr || false, + ignoreReturnCode: options.ignoreReturnCode || false, + delay: options.delay || 10000 + }; + result.outStream = options.outStream || process.stdout; + result.errStream = options.errStream || process.stderr; + return result; + } + _getSpawnOptions(options, toolPath) { + options = options || {}; + const result = {}; + result.cwd = options.cwd; + result.env = options.env; + result['windowsVerbatimArguments'] = + options.windowsVerbatimArguments || this._isCmdFile(); + if (options.windowsVerbatimArguments) { + result.argv0 = `"${toolPath}"`; + } + return result; + } + /** + * Exec a tool. + * Output will be streamed to the live console. + * Returns promise with return code + * + * @param tool path to tool to exec + * @param options optional exec options. See ExecOptions + * @returns number + */ + exec() { + return __awaiter(this, void 0, void 0, function* () { + // root the tool path if it is unrooted and contains relative pathing + if (!ioUtil.isRooted(this.toolPath) && + (this.toolPath.includes('/') || + (IS_WINDOWS && this.toolPath.includes('\\')))) { + // prefer options.cwd if it is specified, however options.cwd may also need to be rooted + this.toolPath = path.resolve(process.cwd(), this.options.cwd || process.cwd(), this.toolPath); + } + // if the tool is only a file name, then resolve it from the PATH + // otherwise verify it exists (add extension on Windows if necessary) + this.toolPath = yield io.which(this.toolPath, true); + return new Promise((resolve, reject) => __awaiter(this, void 0, void 0, function* () { + this._debug(`exec tool: ${this.toolPath}`); + this._debug('arguments:'); + for (const arg of this.args) { + this._debug(` ${arg}`); + } + const optionsNonNull = this._cloneExecOptions(this.options); + if (!optionsNonNull.silent && optionsNonNull.outStream) { + optionsNonNull.outStream.write(this._getCommandString(optionsNonNull) + os.EOL); + } + const state = new ExecState(optionsNonNull, this.toolPath); + state.on('debug', (message) => { + this._debug(message); + }); + if (this.options.cwd && !(yield ioUtil.exists(this.options.cwd))) { + return reject(new Error(`The cwd: ${this.options.cwd} does not exist!`)); + } + const fileName = this._getSpawnFileName(); + const cp = child.spawn(fileName, this._getSpawnArgs(optionsNonNull), this._getSpawnOptions(this.options, fileName)); + let stdbuffer = ''; + if (cp.stdout) { + cp.stdout.on('data', (data) => { + if (this.options.listeners && this.options.listeners.stdout) { + this.options.listeners.stdout(data); + } + if (!optionsNonNull.silent && optionsNonNull.outStream) { + optionsNonNull.outStream.write(data); + } + stdbuffer = this._processLineBuffer(data, stdbuffer, (line) => { + if (this.options.listeners && this.options.listeners.stdline) { + this.options.listeners.stdline(line); + } + }); + }); + } + let errbuffer = ''; + if (cp.stderr) { + cp.stderr.on('data', (data) => { + state.processStderr = true; + if (this.options.listeners && this.options.listeners.stderr) { + this.options.listeners.stderr(data); + } + if (!optionsNonNull.silent && + optionsNonNull.errStream && + optionsNonNull.outStream) { + const s = optionsNonNull.failOnStdErr + ? optionsNonNull.errStream + : optionsNonNull.outStream; + s.write(data); + } + errbuffer = this._processLineBuffer(data, errbuffer, (line) => { + if (this.options.listeners && this.options.listeners.errline) { + this.options.listeners.errline(line); + } + }); + }); + } + cp.on('error', (err) => { + state.processError = err.message; + state.processExited = true; + state.processClosed = true; + state.CheckComplete(); + }); + cp.on('exit', (code) => { + state.processExitCode = code; + state.processExited = true; + this._debug(`Exit code ${code} received from tool '${this.toolPath}'`); + state.CheckComplete(); + }); + cp.on('close', (code) => { + state.processExitCode = code; + state.processExited = true; + state.processClosed = true; + this._debug(`STDIO streams have closed for tool '${this.toolPath}'`); + state.CheckComplete(); + }); + state.on('done', (error, exitCode) => { + if (stdbuffer.length > 0) { + this.emit('stdline', stdbuffer); + } + if (errbuffer.length > 0) { + this.emit('errline', errbuffer); + } + cp.removeAllListeners(); + if (error) { + reject(error); + } + else { + resolve(exitCode); + } + }); + if (this.options.input) { + if (!cp.stdin) { + throw new Error('child process missing stdin'); + } + cp.stdin.end(this.options.input); + } + })); + }); + } +} +exports.ToolRunner = ToolRunner; +/** + * Convert an arg string to an array of args. Handles escaping + * + * @param argString string of arguments + * @returns string[] array of arguments + */ +function argStringToArray(argString) { + const args = []; + let inQuotes = false; + let escaped = false; + let arg = ''; + function append(c) { + // we only escape double quotes. + if (escaped && c !== '"') { + arg += '\\'; + } + arg += c; + escaped = false; + } + for (let i = 0; i < argString.length; i++) { + const c = argString.charAt(i); + if (c === '"') { + if (!escaped) { + inQuotes = !inQuotes; + } + else { + append(c); + } + continue; + } + if (c === '\\' && escaped) { + append(c); + continue; + } + if (c === '\\' && inQuotes) { + escaped = true; + continue; + } + if (c === ' ' && !inQuotes) { + if (arg.length > 0) { + args.push(arg); + arg = ''; + } + continue; + } + append(c); + } + if (arg.length > 0) { + args.push(arg.trim()); + } + return args; +} +exports.argStringToArray = argStringToArray; +class ExecState extends events.EventEmitter { + constructor(options, toolPath) { + super(); + this.processClosed = false; // tracks whether the process has exited and stdio is closed + this.processError = ''; + this.processExitCode = 0; + this.processExited = false; // tracks whether the process has exited + this.processStderr = false; // tracks whether stderr was written to + this.delay = 10000; // 10 seconds + this.done = false; + this.timeout = null; + if (!toolPath) { + throw new Error('toolPath must not be empty'); + } + this.options = options; + this.toolPath = toolPath; + if (options.delay) { + this.delay = options.delay; + } + } + CheckComplete() { + if (this.done) { + return; + } + if (this.processClosed) { + this._setResult(); + } + else if (this.processExited) { + this.timeout = timers_1.setTimeout(ExecState.HandleTimeout, this.delay, this); + } + } + _debug(message) { + this.emit('debug', message); + } + _setResult() { + // determine whether there is an error + let error; + if (this.processExited) { + if (this.processError) { + error = new Error(`There was an error when attempting to execute the process '${this.toolPath}'. This may indicate the process failed to start. Error: ${this.processError}`); + } + else if (this.processExitCode !== 0 && !this.options.ignoreReturnCode) { + error = new Error(`The process '${this.toolPath}' failed with exit code ${this.processExitCode}`); + } + else if (this.processStderr && this.options.failOnStdErr) { + error = new Error(`The process '${this.toolPath}' failed because one or more lines were written to the STDERR stream`); + } + } + // clear the timeout + if (this.timeout) { + clearTimeout(this.timeout); + this.timeout = null; + } + this.done = true; + this.emit('done', error, this.processExitCode); + } + static HandleTimeout(state) { + if (state.done) { + return; + } + if (!state.processClosed && state.processExited) { + const message = `The STDIO streams did not close within ${state.delay / + 1000} seconds of the exit event from process '${state.toolPath}'. This may indicate a child process inherited the STDIO streams and has not yet exited.`; + state._debug(message); + } + state._setResult(); + } +} +//# sourceMappingURL=toolrunner.js.map + +/***/ }), + +/***/ 4552: +/***/ (function(__unused_webpack_module, exports) { + + +var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) { + function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); } + return new (P || (P = Promise))(function (resolve, reject) { + function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } } + function rejected(value) { try { step(generator["throw"](value)); } catch (e) { reject(e); } } + function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); } + step((generator = generator.apply(thisArg, _arguments || [])).next()); + }); +}; +Object.defineProperty(exports, "__esModule", ({ value: true })); +exports.PersonalAccessTokenCredentialHandler = exports.BearerCredentialHandler = exports.BasicCredentialHandler = void 0; +class BasicCredentialHandler { + constructor(username, password) { + this.username = username; + this.password = password; + } + prepareRequest(options) { + if (!options.headers) { + throw Error('The request has no headers'); + } + options.headers['Authorization'] = `Basic ${Buffer.from(`${this.username}:${this.password}`).toString('base64')}`; + } + // This handler cannot handle 401 + canHandleAuthentication() { + return false; + } + handleAuthentication() { + return __awaiter(this, void 0, void 0, function* () { + throw new Error('not implemented'); + }); + } +} +exports.BasicCredentialHandler = BasicCredentialHandler; +class BearerCredentialHandler { + constructor(token) { + this.token = token; + } + // currently implements pre-authorization + // TODO: support preAuth = false where it hooks on 401 + prepareRequest(options) { + if (!options.headers) { + throw Error('The request has no headers'); + } + options.headers['Authorization'] = `Bearer ${this.token}`; + } + // This handler cannot handle 401 + canHandleAuthentication() { + return false; + } + handleAuthentication() { + return __awaiter(this, void 0, void 0, function* () { + throw new Error('not implemented'); + }); + } +} +exports.BearerCredentialHandler = BearerCredentialHandler; +class PersonalAccessTokenCredentialHandler { + constructor(token) { + this.token = token; + } + // currently implements pre-authorization + // TODO: support preAuth = false where it hooks on 401 + prepareRequest(options) { + if (!options.headers) { + throw Error('The request has no headers'); + } + options.headers['Authorization'] = `Basic ${Buffer.from(`PAT:${this.token}`).toString('base64')}`; + } + // This handler cannot handle 401 + canHandleAuthentication() { + return false; + } + handleAuthentication() { + return __awaiter(this, void 0, void 0, function* () { + throw new Error('not implemented'); + }); + } +} +exports.PersonalAccessTokenCredentialHandler = PersonalAccessTokenCredentialHandler; +//# sourceMappingURL=auth.js.map + +/***/ }), + +/***/ 4844: +/***/ (function(__unused_webpack_module, exports, __nccwpck_require__) { + + +/* eslint-disable @typescript-eslint/no-explicit-any */ +var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) { + if (k2 === undefined) k2 = k; + var desc = Object.getOwnPropertyDescriptor(m, k); + if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) { + desc = { enumerable: true, get: function() { return m[k]; } }; + } + Object.defineProperty(o, k2, desc); +}) : (function(o, m, k, k2) { + if (k2 === undefined) k2 = k; + o[k2] = m[k]; +})); +var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) { + Object.defineProperty(o, "default", { enumerable: true, value: v }); +}) : function(o, v) { + o["default"] = v; +}); +var __importStar = (this && this.__importStar) || function (mod) { + if (mod && mod.__esModule) return mod; + var result = {}; + if (mod != null) for (var k in mod) if (k !== "default" && Object.prototype.hasOwnProperty.call(mod, k)) __createBinding(result, mod, k); + __setModuleDefault(result, mod); + return result; +}; +var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) { + function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); } + return new (P || (P = Promise))(function (resolve, reject) { + function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } } + function rejected(value) { try { step(generator["throw"](value)); } catch (e) { reject(e); } } + function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); } + step((generator = generator.apply(thisArg, _arguments || [])).next()); + }); +}; +Object.defineProperty(exports, "__esModule", ({ value: true })); +exports.HttpClient = exports.isHttps = exports.HttpClientResponse = exports.HttpClientError = exports.getProxyUrl = exports.MediaTypes = exports.Headers = exports.HttpCodes = void 0; +const http = __importStar(__nccwpck_require__(8611)); +const https = __importStar(__nccwpck_require__(5692)); +const pm = __importStar(__nccwpck_require__(4988)); +const tunnel = __importStar(__nccwpck_require__(770)); +const undici_1 = __nccwpck_require__(6752); +var HttpCodes; +(function (HttpCodes) { + HttpCodes[HttpCodes["OK"] = 200] = "OK"; + HttpCodes[HttpCodes["MultipleChoices"] = 300] = "MultipleChoices"; + HttpCodes[HttpCodes["MovedPermanently"] = 301] = "MovedPermanently"; + HttpCodes[HttpCodes["ResourceMoved"] = 302] = "ResourceMoved"; + HttpCodes[HttpCodes["SeeOther"] = 303] = "SeeOther"; + HttpCodes[HttpCodes["NotModified"] = 304] = "NotModified"; + HttpCodes[HttpCodes["UseProxy"] = 305] = "UseProxy"; + HttpCodes[HttpCodes["SwitchProxy"] = 306] = "SwitchProxy"; + HttpCodes[HttpCodes["TemporaryRedirect"] = 307] = "TemporaryRedirect"; + HttpCodes[HttpCodes["PermanentRedirect"] = 308] = "PermanentRedirect"; + HttpCodes[HttpCodes["BadRequest"] = 400] = "BadRequest"; + HttpCodes[HttpCodes["Unauthorized"] = 401] = "Unauthorized"; + HttpCodes[HttpCodes["PaymentRequired"] = 402] = "PaymentRequired"; + HttpCodes[HttpCodes["Forbidden"] = 403] = "Forbidden"; + HttpCodes[HttpCodes["NotFound"] = 404] = "NotFound"; + HttpCodes[HttpCodes["MethodNotAllowed"] = 405] = "MethodNotAllowed"; + HttpCodes[HttpCodes["NotAcceptable"] = 406] = "NotAcceptable"; + HttpCodes[HttpCodes["ProxyAuthenticationRequired"] = 407] = "ProxyAuthenticationRequired"; + HttpCodes[HttpCodes["RequestTimeout"] = 408] = "RequestTimeout"; + HttpCodes[HttpCodes["Conflict"] = 409] = "Conflict"; + HttpCodes[HttpCodes["Gone"] = 410] = "Gone"; + HttpCodes[HttpCodes["TooManyRequests"] = 429] = "TooManyRequests"; + HttpCodes[HttpCodes["InternalServerError"] = 500] = "InternalServerError"; + HttpCodes[HttpCodes["NotImplemented"] = 501] = "NotImplemented"; + HttpCodes[HttpCodes["BadGateway"] = 502] = "BadGateway"; + HttpCodes[HttpCodes["ServiceUnavailable"] = 503] = "ServiceUnavailable"; + HttpCodes[HttpCodes["GatewayTimeout"] = 504] = "GatewayTimeout"; +})(HttpCodes || (exports.HttpCodes = HttpCodes = {})); +var Headers; +(function (Headers) { + Headers["Accept"] = "accept"; + Headers["ContentType"] = "content-type"; +})(Headers || (exports.Headers = Headers = {})); +var MediaTypes; +(function (MediaTypes) { + MediaTypes["ApplicationJson"] = "application/json"; +})(MediaTypes || (exports.MediaTypes = MediaTypes = {})); +/** + * Returns the proxy URL, depending upon the supplied url and proxy environment variables. + * @param serverUrl The server URL where the request will be sent. For example, https://api.github.com + */ +function getProxyUrl(serverUrl) { + const proxyUrl = pm.getProxyUrl(new URL(serverUrl)); + return proxyUrl ? proxyUrl.href : ''; +} +exports.getProxyUrl = getProxyUrl; +const HttpRedirectCodes = [ + HttpCodes.MovedPermanently, + HttpCodes.ResourceMoved, + HttpCodes.SeeOther, + HttpCodes.TemporaryRedirect, + HttpCodes.PermanentRedirect +]; +const HttpResponseRetryCodes = [ + HttpCodes.BadGateway, + HttpCodes.ServiceUnavailable, + HttpCodes.GatewayTimeout +]; +const RetryableHttpVerbs = ['OPTIONS', 'GET', 'DELETE', 'HEAD']; +const ExponentialBackoffCeiling = 10; +const ExponentialBackoffTimeSlice = 5; +class HttpClientError extends Error { + constructor(message, statusCode) { + super(message); + this.name = 'HttpClientError'; + this.statusCode = statusCode; + Object.setPrototypeOf(this, HttpClientError.prototype); + } +} +exports.HttpClientError = HttpClientError; +class HttpClientResponse { + constructor(message) { + this.message = message; + } + readBody() { + return __awaiter(this, void 0, void 0, function* () { + return new Promise((resolve) => __awaiter(this, void 0, void 0, function* () { + let output = Buffer.alloc(0); + this.message.on('data', (chunk) => { + output = Buffer.concat([output, chunk]); + }); + this.message.on('end', () => { + resolve(output.toString()); + }); + })); + }); + } + readBodyBuffer() { + return __awaiter(this, void 0, void 0, function* () { + return new Promise((resolve) => __awaiter(this, void 0, void 0, function* () { + const chunks = []; + this.message.on('data', (chunk) => { + chunks.push(chunk); + }); + this.message.on('end', () => { + resolve(Buffer.concat(chunks)); + }); + })); + }); + } +} +exports.HttpClientResponse = HttpClientResponse; +function isHttps(requestUrl) { + const parsedUrl = new URL(requestUrl); + return parsedUrl.protocol === 'https:'; +} +exports.isHttps = isHttps; +class HttpClient { + constructor(userAgent, handlers, requestOptions) { + this._ignoreSslError = false; + this._allowRedirects = true; + this._allowRedirectDowngrade = false; + this._maxRedirects = 50; + this._allowRetries = false; + this._maxRetries = 1; + this._keepAlive = false; + this._disposed = false; + this.userAgent = userAgent; + this.handlers = handlers || []; + this.requestOptions = requestOptions; + if (requestOptions) { + if (requestOptions.ignoreSslError != null) { + this._ignoreSslError = requestOptions.ignoreSslError; + } + this._socketTimeout = requestOptions.socketTimeout; + if (requestOptions.allowRedirects != null) { + this._allowRedirects = requestOptions.allowRedirects; + } + if (requestOptions.allowRedirectDowngrade != null) { + this._allowRedirectDowngrade = requestOptions.allowRedirectDowngrade; + } + if (requestOptions.maxRedirects != null) { + this._maxRedirects = Math.max(requestOptions.maxRedirects, 0); + } + if (requestOptions.keepAlive != null) { + this._keepAlive = requestOptions.keepAlive; + } + if (requestOptions.allowRetries != null) { + this._allowRetries = requestOptions.allowRetries; + } + if (requestOptions.maxRetries != null) { + this._maxRetries = requestOptions.maxRetries; + } + } + } + options(requestUrl, additionalHeaders) { + return __awaiter(this, void 0, void 0, function* () { + return this.request('OPTIONS', requestUrl, null, additionalHeaders || {}); + }); + } + get(requestUrl, additionalHeaders) { + return __awaiter(this, void 0, void 0, function* () { + return this.request('GET', requestUrl, null, additionalHeaders || {}); + }); + } + del(requestUrl, additionalHeaders) { + return __awaiter(this, void 0, void 0, function* () { + return this.request('DELETE', requestUrl, null, additionalHeaders || {}); + }); + } + post(requestUrl, data, additionalHeaders) { + return __awaiter(this, void 0, void 0, function* () { + return this.request('POST', requestUrl, data, additionalHeaders || {}); + }); + } + patch(requestUrl, data, additionalHeaders) { + return __awaiter(this, void 0, void 0, function* () { + return this.request('PATCH', requestUrl, data, additionalHeaders || {}); + }); + } + put(requestUrl, data, additionalHeaders) { + return __awaiter(this, void 0, void 0, function* () { + return this.request('PUT', requestUrl, data, additionalHeaders || {}); + }); + } + head(requestUrl, additionalHeaders) { + return __awaiter(this, void 0, void 0, function* () { + return this.request('HEAD', requestUrl, null, additionalHeaders || {}); + }); + } + sendStream(verb, requestUrl, stream, additionalHeaders) { + return __awaiter(this, void 0, void 0, function* () { + return this.request(verb, requestUrl, stream, additionalHeaders); + }); + } + /** + * Gets a typed object from an endpoint + * Be aware that not found returns a null. Other errors (4xx, 5xx) reject the promise + */ + getJson(requestUrl, additionalHeaders = {}) { + return __awaiter(this, void 0, void 0, function* () { + additionalHeaders[Headers.Accept] = this._getExistingOrDefaultHeader(additionalHeaders, Headers.Accept, MediaTypes.ApplicationJson); + const res = yield this.get(requestUrl, additionalHeaders); + return this._processResponse(res, this.requestOptions); + }); + } + postJson(requestUrl, obj, additionalHeaders = {}) { + return __awaiter(this, void 0, void 0, function* () { + const data = JSON.stringify(obj, null, 2); + additionalHeaders[Headers.Accept] = this._getExistingOrDefaultHeader(additionalHeaders, Headers.Accept, MediaTypes.ApplicationJson); + additionalHeaders[Headers.ContentType] = this._getExistingOrDefaultHeader(additionalHeaders, Headers.ContentType, MediaTypes.ApplicationJson); + const res = yield this.post(requestUrl, data, additionalHeaders); + return this._processResponse(res, this.requestOptions); + }); + } + putJson(requestUrl, obj, additionalHeaders = {}) { + return __awaiter(this, void 0, void 0, function* () { + const data = JSON.stringify(obj, null, 2); + additionalHeaders[Headers.Accept] = this._getExistingOrDefaultHeader(additionalHeaders, Headers.Accept, MediaTypes.ApplicationJson); + additionalHeaders[Headers.ContentType] = this._getExistingOrDefaultHeader(additionalHeaders, Headers.ContentType, MediaTypes.ApplicationJson); + const res = yield this.put(requestUrl, data, additionalHeaders); + return this._processResponse(res, this.requestOptions); + }); + } + patchJson(requestUrl, obj, additionalHeaders = {}) { + return __awaiter(this, void 0, void 0, function* () { + const data = JSON.stringify(obj, null, 2); + additionalHeaders[Headers.Accept] = this._getExistingOrDefaultHeader(additionalHeaders, Headers.Accept, MediaTypes.ApplicationJson); + additionalHeaders[Headers.ContentType] = this._getExistingOrDefaultHeader(additionalHeaders, Headers.ContentType, MediaTypes.ApplicationJson); + const res = yield this.patch(requestUrl, data, additionalHeaders); + return this._processResponse(res, this.requestOptions); + }); + } + /** + * Makes a raw http request. + * All other methods such as get, post, patch, and request ultimately call this. + * Prefer get, del, post and patch + */ + request(verb, requestUrl, data, headers) { + return __awaiter(this, void 0, void 0, function* () { + if (this._disposed) { + throw new Error('Client has already been disposed.'); + } + const parsedUrl = new URL(requestUrl); + let info = this._prepareRequest(verb, parsedUrl, headers); + // Only perform retries on reads since writes may not be idempotent. + const maxTries = this._allowRetries && RetryableHttpVerbs.includes(verb) + ? this._maxRetries + 1 + : 1; + let numTries = 0; + let response; + do { + response = yield this.requestRaw(info, data); + // Check if it's an authentication challenge + if (response && + response.message && + response.message.statusCode === HttpCodes.Unauthorized) { + let authenticationHandler; + for (const handler of this.handlers) { + if (handler.canHandleAuthentication(response)) { + authenticationHandler = handler; + break; + } + } + if (authenticationHandler) { + return authenticationHandler.handleAuthentication(this, info, data); + } + else { + // We have received an unauthorized response but have no handlers to handle it. + // Let the response return to the caller. + return response; + } + } + let redirectsRemaining = this._maxRedirects; + while (response.message.statusCode && + HttpRedirectCodes.includes(response.message.statusCode) && + this._allowRedirects && + redirectsRemaining > 0) { + const redirectUrl = response.message.headers['location']; + if (!redirectUrl) { + // if there's no location to redirect to, we won't + break; + } + const parsedRedirectUrl = new URL(redirectUrl); + if (parsedUrl.protocol === 'https:' && + parsedUrl.protocol !== parsedRedirectUrl.protocol && + !this._allowRedirectDowngrade) { + 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.'); + } + // we need to finish reading the response before reassigning response + // which will leak the open socket. + yield response.readBody(); + // strip authorization header if redirected to a different hostname + if (parsedRedirectUrl.hostname !== parsedUrl.hostname) { + for (const header in headers) { + // header names are case insensitive + if (header.toLowerCase() === 'authorization') { + delete headers[header]; + } + } + } + // let's make the request with the new redirectUrl + info = this._prepareRequest(verb, parsedRedirectUrl, headers); + response = yield this.requestRaw(info, data); + redirectsRemaining--; + } + if (!response.message.statusCode || + !HttpResponseRetryCodes.includes(response.message.statusCode)) { + // If not a retry code, return immediately instead of retrying + return response; + } + numTries += 1; + if (numTries < maxTries) { + yield response.readBody(); + yield this._performExponentialBackoff(numTries); + } + } while (numTries < maxTries); + return response; + }); + } + /** + * Needs to be called if keepAlive is set to true in request options. + */ + dispose() { + if (this._agent) { + this._agent.destroy(); + } + this._disposed = true; + } + /** + * Raw request. + * @param info + * @param data + */ + requestRaw(info, data) { + return __awaiter(this, void 0, void 0, function* () { + return new Promise((resolve, reject) => { + function callbackForResult(err, res) { + if (err) { + reject(err); + } + else if (!res) { + // If `err` is not passed, then `res` must be passed. + reject(new Error('Unknown error')); + } + else { + resolve(res); + } + } + this.requestRawWithCallback(info, data, callbackForResult); + }); + }); + } + /** + * Raw request with callback. + * @param info + * @param data + * @param onResult + */ + requestRawWithCallback(info, data, onResult) { + if (typeof data === 'string') { + if (!info.options.headers) { + info.options.headers = {}; + } + info.options.headers['Content-Length'] = Buffer.byteLength(data, 'utf8'); + } + let callbackCalled = false; + function handleResult(err, res) { + if (!callbackCalled) { + callbackCalled = true; + onResult(err, res); + } + } + const req = info.httpModule.request(info.options, (msg) => { + const res = new HttpClientResponse(msg); + handleResult(undefined, res); + }); + let socket; + req.on('socket', sock => { + socket = sock; + }); + // If we ever get disconnected, we want the socket to timeout eventually + req.setTimeout(this._socketTimeout || 3 * 60000, () => { + if (socket) { + socket.end(); + } + handleResult(new Error(`Request timeout: ${info.options.path}`)); + }); + req.on('error', function (err) { + // err has statusCode property + // res should have headers + handleResult(err); + }); + if (data && typeof data === 'string') { + req.write(data, 'utf8'); + } + if (data && typeof data !== 'string') { + data.on('close', function () { + req.end(); + }); + data.pipe(req); + } + else { + req.end(); + } + } + /** + * Gets an http agent. This function is useful when you need an http agent that handles + * routing through a proxy server - depending upon the url and proxy environment variables. + * @param serverUrl The server URL where the request will be sent. For example, https://api.github.com + */ + getAgent(serverUrl) { + const parsedUrl = new URL(serverUrl); + return this._getAgent(parsedUrl); + } + getAgentDispatcher(serverUrl) { + const parsedUrl = new URL(serverUrl); + const proxyUrl = pm.getProxyUrl(parsedUrl); + const useProxy = proxyUrl && proxyUrl.hostname; + if (!useProxy) { + return; + } + return this._getProxyAgentDispatcher(parsedUrl, proxyUrl); + } + _prepareRequest(method, requestUrl, headers) { + const info = {}; + info.parsedUrl = requestUrl; + const usingSsl = info.parsedUrl.protocol === 'https:'; + info.httpModule = usingSsl ? https : http; + const defaultPort = usingSsl ? 443 : 80; + info.options = {}; + info.options.host = info.parsedUrl.hostname; + info.options.port = info.parsedUrl.port + ? parseInt(info.parsedUrl.port) + : defaultPort; + info.options.path = + (info.parsedUrl.pathname || '') + (info.parsedUrl.search || ''); + info.options.method = method; + info.options.headers = this._mergeHeaders(headers); + if (this.userAgent != null) { + info.options.headers['user-agent'] = this.userAgent; + } + info.options.agent = this._getAgent(info.parsedUrl); + // gives handlers an opportunity to participate + if (this.handlers) { + for (const handler of this.handlers) { + handler.prepareRequest(info.options); + } + } + return info; + } + _mergeHeaders(headers) { + if (this.requestOptions && this.requestOptions.headers) { + return Object.assign({}, lowercaseKeys(this.requestOptions.headers), lowercaseKeys(headers || {})); + } + return lowercaseKeys(headers || {}); + } + _getExistingOrDefaultHeader(additionalHeaders, header, _default) { + let clientHeader; + if (this.requestOptions && this.requestOptions.headers) { + clientHeader = lowercaseKeys(this.requestOptions.headers)[header]; + } + return additionalHeaders[header] || clientHeader || _default; + } + _getAgent(parsedUrl) { + let agent; + const proxyUrl = pm.getProxyUrl(parsedUrl); + const useProxy = proxyUrl && proxyUrl.hostname; + if (this._keepAlive && useProxy) { + agent = this._proxyAgent; + } + if (!useProxy) { + agent = this._agent; + } + // if agent is already assigned use that agent. + if (agent) { + return agent; + } + const usingSsl = parsedUrl.protocol === 'https:'; + let maxSockets = 100; + if (this.requestOptions) { + maxSockets = this.requestOptions.maxSockets || http.globalAgent.maxSockets; + } + // This is `useProxy` again, but we need to check `proxyURl` directly for TypeScripts's flow analysis. + if (proxyUrl && proxyUrl.hostname) { + const agentOptions = { + maxSockets, + keepAlive: this._keepAlive, + proxy: Object.assign(Object.assign({}, ((proxyUrl.username || proxyUrl.password) && { + proxyAuth: `${proxyUrl.username}:${proxyUrl.password}` + })), { host: proxyUrl.hostname, port: proxyUrl.port }) + }; + let tunnelAgent; + const overHttps = proxyUrl.protocol === 'https:'; + if (usingSsl) { + tunnelAgent = overHttps ? tunnel.httpsOverHttps : tunnel.httpsOverHttp; + } + else { + tunnelAgent = overHttps ? tunnel.httpOverHttps : tunnel.httpOverHttp; + } + agent = tunnelAgent(agentOptions); + this._proxyAgent = agent; + } + // if tunneling agent isn't assigned create a new agent + if (!agent) { + const options = { keepAlive: this._keepAlive, maxSockets }; + agent = usingSsl ? new https.Agent(options) : new http.Agent(options); + this._agent = agent; + } + if (usingSsl && this._ignoreSslError) { + // we don't want to set NODE_TLS_REJECT_UNAUTHORIZED=0 since that will affect request for entire process + // http.RequestOptions doesn't expose a way to modify RequestOptions.agent.options + // we have to cast it to any and change it directly + agent.options = Object.assign(agent.options || {}, { + rejectUnauthorized: false + }); + } + return agent; + } + _getProxyAgentDispatcher(parsedUrl, proxyUrl) { + let proxyAgent; + if (this._keepAlive) { + proxyAgent = this._proxyAgentDispatcher; + } + // if agent is already assigned use that agent. + if (proxyAgent) { + return proxyAgent; + } + const usingSsl = parsedUrl.protocol === 'https:'; + proxyAgent = new undici_1.ProxyAgent(Object.assign({ uri: proxyUrl.href, pipelining: !this._keepAlive ? 0 : 1 }, ((proxyUrl.username || proxyUrl.password) && { + token: `Basic ${Buffer.from(`${proxyUrl.username}:${proxyUrl.password}`).toString('base64')}` + }))); + this._proxyAgentDispatcher = proxyAgent; + if (usingSsl && this._ignoreSslError) { + // we don't want to set NODE_TLS_REJECT_UNAUTHORIZED=0 since that will affect request for entire process + // http.RequestOptions doesn't expose a way to modify RequestOptions.agent.options + // we have to cast it to any and change it directly + proxyAgent.options = Object.assign(proxyAgent.options.requestTls || {}, { + rejectUnauthorized: false + }); + } + return proxyAgent; + } + _performExponentialBackoff(retryNumber) { + return __awaiter(this, void 0, void 0, function* () { + retryNumber = Math.min(ExponentialBackoffCeiling, retryNumber); + const ms = ExponentialBackoffTimeSlice * Math.pow(2, retryNumber); + return new Promise(resolve => setTimeout(() => resolve(), ms)); + }); + } + _processResponse(res, options) { + return __awaiter(this, void 0, void 0, function* () { + return new Promise((resolve, reject) => __awaiter(this, void 0, void 0, function* () { + const statusCode = res.message.statusCode || 0; + const response = { + statusCode, + result: null, + headers: {} + }; + // not found leads to null obj returned + if (statusCode === HttpCodes.NotFound) { + resolve(response); + } + // get the result from the body + function dateTimeDeserializer(key, value) { + if (typeof value === 'string') { + const a = new Date(value); + if (!isNaN(a.valueOf())) { + return a; + } + } + return value; + } + let obj; + let contents; + try { + contents = yield res.readBody(); + if (contents && contents.length > 0) { + if (options && options.deserializeDates) { + obj = JSON.parse(contents, dateTimeDeserializer); + } + else { + obj = JSON.parse(contents); + } + response.result = obj; + } + response.headers = res.message.headers; + } + catch (err) { + // Invalid resource (contents not json); leaving result obj null + } + // note that 3xx redirects are handled by the http layer. + if (statusCode > 299) { + let msg; + // if exception/error in body, attempt to get better error + if (obj && obj.message) { + msg = obj.message; + } + else if (contents && contents.length > 0) { + // it may be the case that the exception is in the body message as string + msg = contents; + } + else { + msg = `Failed request: (${statusCode})`; + } + const err = new HttpClientError(msg, statusCode); + err.result = response.result; + reject(err); + } + else { + resolve(response); + } + })); + }); + } +} +exports.HttpClient = HttpClient; +const lowercaseKeys = (obj) => Object.keys(obj).reduce((c, k) => ((c[k.toLowerCase()] = obj[k]), c), {}); +//# sourceMappingURL=index.js.map + +/***/ }), + +/***/ 4988: +/***/ ((__unused_webpack_module, exports) => { + + +Object.defineProperty(exports, "__esModule", ({ value: true })); +exports.checkBypass = exports.getProxyUrl = void 0; +function getProxyUrl(reqUrl) { + const usingSsl = reqUrl.protocol === 'https:'; + if (checkBypass(reqUrl)) { + return undefined; + } + const proxyVar = (() => { + if (usingSsl) { + return process.env['https_proxy'] || process.env['HTTPS_PROXY']; + } + else { + return process.env['http_proxy'] || process.env['HTTP_PROXY']; + } + })(); + if (proxyVar) { + try { + return new DecodedURL(proxyVar); + } + catch (_a) { + if (!proxyVar.startsWith('http://') && !proxyVar.startsWith('https://')) + return new DecodedURL(`http://${proxyVar}`); + } + } + else { + return undefined; + } +} +exports.getProxyUrl = getProxyUrl; +function checkBypass(reqUrl) { + if (!reqUrl.hostname) { + return false; + } + const reqHost = reqUrl.hostname; + if (isLoopbackAddress(reqHost)) { + return true; + } + const noProxy = process.env['no_proxy'] || process.env['NO_PROXY'] || ''; + if (!noProxy) { + return false; + } + // Determine the request port + let reqPort; + if (reqUrl.port) { + reqPort = Number(reqUrl.port); + } + else if (reqUrl.protocol === 'http:') { + reqPort = 80; + } + else if (reqUrl.protocol === 'https:') { + reqPort = 443; + } + // Format the request hostname and hostname with port + const upperReqHosts = [reqUrl.hostname.toUpperCase()]; + if (typeof reqPort === 'number') { + upperReqHosts.push(`${upperReqHosts[0]}:${reqPort}`); + } + // Compare request host against noproxy + for (const upperNoProxyItem of noProxy + .split(',') + .map(x => x.trim().toUpperCase()) + .filter(x => x)) { + if (upperNoProxyItem === '*' || + upperReqHosts.some(x => x === upperNoProxyItem || + x.endsWith(`.${upperNoProxyItem}`) || + (upperNoProxyItem.startsWith('.') && + x.endsWith(`${upperNoProxyItem}`)))) { + return true; + } + } + return false; +} +exports.checkBypass = checkBypass; +function isLoopbackAddress(host) { + const hostLower = host.toLowerCase(); + return (hostLower === 'localhost' || + hostLower.startsWith('127.') || + hostLower.startsWith('[::1]') || + hostLower.startsWith('[0:0:0:0:0:0:0:1]')); +} +class DecodedURL extends URL { + constructor(url, base) { + super(url, base); + this._decodedUsername = decodeURIComponent(super.username); + this._decodedPassword = decodeURIComponent(super.password); + } + get username() { + return this._decodedUsername; + } + get password() { + return this._decodedPassword; + } +} +//# sourceMappingURL=proxy.js.map + +/***/ }), + +/***/ 5207: +/***/ (function(__unused_webpack_module, exports, __nccwpck_require__) { + + +var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) { + if (k2 === undefined) k2 = k; + Object.defineProperty(o, k2, { enumerable: true, get: function() { return m[k]; } }); +}) : (function(o, m, k, k2) { + if (k2 === undefined) k2 = k; + o[k2] = m[k]; +})); +var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) { + Object.defineProperty(o, "default", { enumerable: true, value: v }); +}) : function(o, v) { + o["default"] = v; +}); +var __importStar = (this && this.__importStar) || function (mod) { + if (mod && mod.__esModule) return mod; + var result = {}; + if (mod != null) for (var k in mod) if (k !== "default" && Object.hasOwnProperty.call(mod, k)) __createBinding(result, mod, k); + __setModuleDefault(result, mod); + return result; +}; +var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) { + function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); } + return new (P || (P = Promise))(function (resolve, reject) { + function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } } + function rejected(value) { try { step(generator["throw"](value)); } catch (e) { reject(e); } } + function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); } + step((generator = generator.apply(thisArg, _arguments || [])).next()); + }); +}; +var _a; +Object.defineProperty(exports, "__esModule", ({ value: true })); +exports.getCmdPath = exports.tryGetExecutablePath = exports.isRooted = exports.isDirectory = exports.exists = exports.READONLY = exports.UV_FS_O_EXLOCK = exports.IS_WINDOWS = exports.unlink = exports.symlink = exports.stat = exports.rmdir = exports.rm = exports.rename = exports.readlink = exports.readdir = exports.open = exports.mkdir = exports.lstat = exports.copyFile = exports.chmod = void 0; +const fs = __importStar(__nccwpck_require__(9896)); +const path = __importStar(__nccwpck_require__(6928)); +_a = fs.promises +// export const {open} = 'fs' +, exports.chmod = _a.chmod, exports.copyFile = _a.copyFile, exports.lstat = _a.lstat, exports.mkdir = _a.mkdir, exports.open = _a.open, exports.readdir = _a.readdir, exports.readlink = _a.readlink, exports.rename = _a.rename, exports.rm = _a.rm, exports.rmdir = _a.rmdir, exports.stat = _a.stat, exports.symlink = _a.symlink, exports.unlink = _a.unlink; +// export const {open} = 'fs' +exports.IS_WINDOWS = process.platform === 'win32'; +// See https://github.com/nodejs/node/blob/d0153aee367422d0858105abec186da4dff0a0c5/deps/uv/include/uv/win.h#L691 +exports.UV_FS_O_EXLOCK = 0x10000000; +exports.READONLY = fs.constants.O_RDONLY; +function exists(fsPath) { + return __awaiter(this, void 0, void 0, function* () { + try { + yield exports.stat(fsPath); + } + catch (err) { + if (err.code === 'ENOENT') { + return false; + } + throw err; + } + return true; + }); +} +exports.exists = exists; +function isDirectory(fsPath, useStat = false) { + return __awaiter(this, void 0, void 0, function* () { + const stats = useStat ? yield exports.stat(fsPath) : yield exports.lstat(fsPath); + return stats.isDirectory(); + }); +} +exports.isDirectory = isDirectory; +/** + * On OSX/Linux, true if path starts with '/'. On Windows, true for paths like: + * \, \hello, \\hello\share, C:, and C:\hello (and corresponding alternate separator cases). + */ +function isRooted(p) { + p = normalizeSeparators(p); + if (!p) { + throw new Error('isRooted() parameter "p" cannot be empty'); + } + if (exports.IS_WINDOWS) { + return (p.startsWith('\\') || /^[A-Z]:/i.test(p) // e.g. \ or \hello or \\hello + ); // e.g. C: or C:\hello + } + return p.startsWith('/'); +} +exports.isRooted = isRooted; +/** + * Best effort attempt to determine whether a file exists and is executable. + * @param filePath file path to check + * @param extensions additional file extensions to try + * @return if file exists and is executable, returns the file path. otherwise empty string. + */ +function tryGetExecutablePath(filePath, extensions) { + return __awaiter(this, void 0, void 0, function* () { + let stats = undefined; + try { + // test file exists + stats = yield exports.stat(filePath); + } + catch (err) { + if (err.code !== 'ENOENT') { + // eslint-disable-next-line no-console + console.log(`Unexpected error attempting to determine if executable file exists '${filePath}': ${err}`); + } + } + if (stats && stats.isFile()) { + if (exports.IS_WINDOWS) { + // on Windows, test for valid extension + const upperExt = path.extname(filePath).toUpperCase(); + if (extensions.some(validExt => validExt.toUpperCase() === upperExt)) { + return filePath; + } + } + else { + if (isUnixExecutable(stats)) { + return filePath; + } + } + } + // try each extension + const originalFilePath = filePath; + for (const extension of extensions) { + filePath = originalFilePath + extension; + stats = undefined; + try { + stats = yield exports.stat(filePath); + } + catch (err) { + if (err.code !== 'ENOENT') { + // eslint-disable-next-line no-console + console.log(`Unexpected error attempting to determine if executable file exists '${filePath}': ${err}`); + } + } + if (stats && stats.isFile()) { + if (exports.IS_WINDOWS) { + // preserve the case of the actual file (since an extension was appended) + try { + const directory = path.dirname(filePath); + const upperName = path.basename(filePath).toUpperCase(); + for (const actualName of yield exports.readdir(directory)) { + if (upperName === actualName.toUpperCase()) { + filePath = path.join(directory, actualName); + break; + } + } + } + catch (err) { + // eslint-disable-next-line no-console + console.log(`Unexpected error attempting to determine the actual case of the file '${filePath}': ${err}`); + } + return filePath; + } + else { + if (isUnixExecutable(stats)) { + return filePath; + } + } + } + } + return ''; + }); +} +exports.tryGetExecutablePath = tryGetExecutablePath; +function normalizeSeparators(p) { + p = p || ''; + if (exports.IS_WINDOWS) { + // convert slashes on Windows + p = p.replace(/\//g, '\\'); + // remove redundant slashes + return p.replace(/\\\\+/g, '\\'); + } + // remove redundant slashes + return p.replace(/\/\/+/g, '/'); +} +// on Mac/Linux, test the execute bit +// R W X R W X R W X +// 256 128 64 32 16 8 4 2 1 +function isUnixExecutable(stats) { + return ((stats.mode & 1) > 0 || + ((stats.mode & 8) > 0 && stats.gid === process.getgid()) || + ((stats.mode & 64) > 0 && stats.uid === process.getuid())); +} +// Get the path of cmd.exe in windows +function getCmdPath() { + var _a; + return (_a = process.env['COMSPEC']) !== null && _a !== void 0 ? _a : `cmd.exe`; +} +exports.getCmdPath = getCmdPath; +//# sourceMappingURL=io-util.js.map + +/***/ }), + +/***/ 4994: +/***/ (function(__unused_webpack_module, exports, __nccwpck_require__) { + + +var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) { + if (k2 === undefined) k2 = k; + Object.defineProperty(o, k2, { enumerable: true, get: function() { return m[k]; } }); +}) : (function(o, m, k, k2) { + if (k2 === undefined) k2 = k; + o[k2] = m[k]; +})); +var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) { + Object.defineProperty(o, "default", { enumerable: true, value: v }); +}) : function(o, v) { + o["default"] = v; +}); +var __importStar = (this && this.__importStar) || function (mod) { + if (mod && mod.__esModule) return mod; + var result = {}; + if (mod != null) for (var k in mod) if (k !== "default" && Object.hasOwnProperty.call(mod, k)) __createBinding(result, mod, k); + __setModuleDefault(result, mod); + return result; +}; +var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) { + function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); } + return new (P || (P = Promise))(function (resolve, reject) { + function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } } + function rejected(value) { try { step(generator["throw"](value)); } catch (e) { reject(e); } } + function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); } + step((generator = generator.apply(thisArg, _arguments || [])).next()); + }); +}; +Object.defineProperty(exports, "__esModule", ({ value: true })); +exports.findInPath = exports.which = exports.mkdirP = exports.rmRF = exports.mv = exports.cp = void 0; +const assert_1 = __nccwpck_require__(2613); +const path = __importStar(__nccwpck_require__(6928)); +const ioUtil = __importStar(__nccwpck_require__(5207)); +/** + * Copies a file or folder. + * Based off of shelljs - https://github.com/shelljs/shelljs/blob/9237f66c52e5daa40458f94f9565e18e8132f5a6/src/cp.js + * + * @param source source path + * @param dest destination path + * @param options optional. See CopyOptions. + */ +function cp(source, dest, options = {}) { + return __awaiter(this, void 0, void 0, function* () { + const { force, recursive, copySourceDirectory } = readCopyOptions(options); + const destStat = (yield ioUtil.exists(dest)) ? yield ioUtil.stat(dest) : null; + // Dest is an existing file, but not forcing + if (destStat && destStat.isFile() && !force) { + return; + } + // If dest is an existing directory, should copy inside. + const newDest = destStat && destStat.isDirectory() && copySourceDirectory + ? path.join(dest, path.basename(source)) + : dest; + if (!(yield ioUtil.exists(source))) { + throw new Error(`no such file or directory: ${source}`); + } + const sourceStat = yield ioUtil.stat(source); + if (sourceStat.isDirectory()) { + if (!recursive) { + throw new Error(`Failed to copy. ${source} is a directory, but tried to copy without recursive flag.`); + } + else { + yield cpDirRecursive(source, newDest, 0, force); + } + } + else { + if (path.relative(source, newDest) === '') { + // a file cannot be copied to itself + throw new Error(`'${newDest}' and '${source}' are the same file`); + } + yield copyFile(source, newDest, force); + } + }); +} +exports.cp = cp; +/** + * Moves a path. + * + * @param source source path + * @param dest destination path + * @param options optional. See MoveOptions. + */ +function mv(source, dest, options = {}) { + return __awaiter(this, void 0, void 0, function* () { + if (yield ioUtil.exists(dest)) { + let destExists = true; + if (yield ioUtil.isDirectory(dest)) { + // If dest is directory copy src into dest + dest = path.join(dest, path.basename(source)); + destExists = yield ioUtil.exists(dest); + } + if (destExists) { + if (options.force == null || options.force) { + yield rmRF(dest); + } + else { + throw new Error('Destination already exists'); + } + } + } + yield mkdirP(path.dirname(dest)); + yield ioUtil.rename(source, dest); + }); +} +exports.mv = mv; +/** + * Remove a path recursively with force + * + * @param inputPath path to remove + */ +function rmRF(inputPath) { + return __awaiter(this, void 0, void 0, function* () { + if (ioUtil.IS_WINDOWS) { + // Check for invalid characters + // https://docs.microsoft.com/en-us/windows/win32/fileio/naming-a-file + if (/[*"<>|]/.test(inputPath)) { + throw new Error('File path must not contain `*`, `"`, `<`, `>` or `|` on Windows'); + } + } + try { + // note if path does not exist, error is silent + yield ioUtil.rm(inputPath, { + force: true, + maxRetries: 3, + recursive: true, + retryDelay: 300 + }); + } + catch (err) { + throw new Error(`File was unable to be removed ${err}`); + } + }); +} +exports.rmRF = rmRF; +/** + * Make a directory. Creates the full path with folders in between + * Will throw if it fails + * + * @param fsPath path to create + * @returns Promise + */ +function mkdirP(fsPath) { + return __awaiter(this, void 0, void 0, function* () { + assert_1.ok(fsPath, 'a path argument must be provided'); + yield ioUtil.mkdir(fsPath, { recursive: true }); + }); +} +exports.mkdirP = mkdirP; +/** + * Returns path of a tool had the tool actually been invoked. Resolves via paths. + * If you check and the tool does not exist, it will throw. + * + * @param tool name of the tool + * @param check whether to check if tool exists + * @returns Promise path to tool + */ +function which(tool, check) { + return __awaiter(this, void 0, void 0, function* () { + if (!tool) { + throw new Error("parameter 'tool' is required"); + } + // recursive when check=true + if (check) { + const result = yield which(tool, false); + if (!result) { + if (ioUtil.IS_WINDOWS) { + throw new Error(`Unable to locate executable file: ${tool}. Please verify either the file path exists or the file can be found within a directory specified by the PATH environment variable. Also verify the file has a valid extension for an executable file.`); + } + else { + throw new Error(`Unable to locate executable file: ${tool}. Please verify either the file path exists or the file can be found within a directory specified by the PATH environment variable. Also check the file mode to verify the file is executable.`); + } + } + return result; + } + const matches = yield findInPath(tool); + if (matches && matches.length > 0) { + return matches[0]; + } + return ''; + }); +} +exports.which = which; +/** + * Returns a list of all occurrences of the given tool on the system path. + * + * @returns Promise the paths of the tool + */ +function findInPath(tool) { + return __awaiter(this, void 0, void 0, function* () { + if (!tool) { + throw new Error("parameter 'tool' is required"); + } + // build the list of extensions to try + const extensions = []; + if (ioUtil.IS_WINDOWS && process.env['PATHEXT']) { + for (const extension of process.env['PATHEXT'].split(path.delimiter)) { + if (extension) { + extensions.push(extension); + } + } + } + // if it's rooted, return it if exists. otherwise return empty. + if (ioUtil.isRooted(tool)) { + const filePath = yield ioUtil.tryGetExecutablePath(tool, extensions); + if (filePath) { + return [filePath]; + } + return []; + } + // if any path separators, return empty + if (tool.includes(path.sep)) { + return []; + } + // build the list of directories + // + // Note, technically "where" checks the current directory on Windows. From a toolkit perspective, + // it feels like we should not do this. Checking the current directory seems like more of a use + // case of a shell, and the which() function exposed by the toolkit should strive for consistency + // across platforms. + const directories = []; + if (process.env.PATH) { + for (const p of process.env.PATH.split(path.delimiter)) { + if (p) { + directories.push(p); + } + } + } + // find all matches + const matches = []; + for (const directory of directories) { + const filePath = yield ioUtil.tryGetExecutablePath(path.join(directory, tool), extensions); + if (filePath) { + matches.push(filePath); + } + } + return matches; + }); +} +exports.findInPath = findInPath; +function readCopyOptions(options) { + const force = options.force == null ? true : options.force; + const recursive = Boolean(options.recursive); + const copySourceDirectory = options.copySourceDirectory == null + ? true + : Boolean(options.copySourceDirectory); + return { force, recursive, copySourceDirectory }; +} +function cpDirRecursive(sourceDir, destDir, currentDepth, force) { + return __awaiter(this, void 0, void 0, function* () { + // Ensure there is not a run away recursive copy + if (currentDepth >= 255) + return; + currentDepth++; + yield mkdirP(destDir); + const files = yield ioUtil.readdir(sourceDir); + for (const fileName of files) { + const srcFile = `${sourceDir}/${fileName}`; + const destFile = `${destDir}/${fileName}`; + const srcFileStat = yield ioUtil.lstat(srcFile); + if (srcFileStat.isDirectory()) { + // Recurse + yield cpDirRecursive(srcFile, destFile, currentDepth, force); + } + else { + yield copyFile(srcFile, destFile, force); + } + } + // Change the mode for the newly created directory + yield ioUtil.chmod(destDir, (yield ioUtil.stat(sourceDir)).mode); + }); +} +// Buffered file copy +function copyFile(srcFile, destFile, force) { + return __awaiter(this, void 0, void 0, function* () { + if ((yield ioUtil.lstat(srcFile)).isSymbolicLink()) { + // unlink/re-link it + try { + yield ioUtil.lstat(destFile); + yield ioUtil.unlink(destFile); + } + catch (e) { + // Try to override file permission + if (e.code === 'EPERM') { + yield ioUtil.chmod(destFile, '0666'); + yield ioUtil.unlink(destFile); + } + // other errors = it doesn't exist, no work to do + } + // Copy over symlink + const symlinkFull = yield ioUtil.readlink(srcFile); + yield ioUtil.symlink(symlinkFull, destFile, ioUtil.IS_WINDOWS ? 'junction' : null); + } + else if (!(yield ioUtil.exists(destFile)) || force) { + yield ioUtil.copyFile(srcFile, destFile); + } + }); +} +//# sourceMappingURL=io.js.map + +/***/ }), + +/***/ 770: +/***/ ((module, __unused_webpack_exports, __nccwpck_require__) => { + +module.exports = __nccwpck_require__(218); + + +/***/ }), + +/***/ 218: +/***/ ((__unused_webpack_module, exports, __nccwpck_require__) => { + + + +var net = __nccwpck_require__(9278); +var tls = __nccwpck_require__(4756); +var http = __nccwpck_require__(8611); +var https = __nccwpck_require__(5692); +var events = __nccwpck_require__(4434); +var assert = __nccwpck_require__(2613); +var util = __nccwpck_require__(9023); + + +exports.httpOverHttp = httpOverHttp; +exports.httpsOverHttp = httpsOverHttp; +exports.httpOverHttps = httpOverHttps; +exports.httpsOverHttps = httpsOverHttps; + + +function httpOverHttp(options) { + var agent = new TunnelingAgent(options); + agent.request = http.request; + return agent; +} + +function httpsOverHttp(options) { + var agent = new TunnelingAgent(options); + agent.request = http.request; + agent.createSocket = createSecureSocket; + agent.defaultPort = 443; + return agent; +} + +function httpOverHttps(options) { + var agent = new TunnelingAgent(options); + agent.request = https.request; + return agent; +} + +function httpsOverHttps(options) { + var agent = new TunnelingAgent(options); + agent.request = https.request; + agent.createSocket = createSecureSocket; + agent.defaultPort = 443; + return agent; +} + + +function TunnelingAgent(options) { + var self = this; + self.options = options || {}; + self.proxyOptions = self.options.proxy || {}; + self.maxSockets = self.options.maxSockets || http.Agent.defaultMaxSockets; + self.requests = []; + self.sockets = []; + + self.on('free', function onFree(socket, host, port, localAddress) { + var options = toOptions(host, port, localAddress); + for (var i = 0, len = self.requests.length; i < len; ++i) { + var pending = self.requests[i]; + if (pending.host === options.host && pending.port === options.port) { + // Detect the request to connect same origin server, + // reuse the connection. + self.requests.splice(i, 1); + pending.request.onSocket(socket); + return; + } + } + socket.destroy(); + self.removeSocket(socket); + }); +} +util.inherits(TunnelingAgent, events.EventEmitter); + +TunnelingAgent.prototype.addRequest = function addRequest(req, host, port, localAddress) { + var self = this; + var options = mergeOptions({request: req}, self.options, toOptions(host, port, localAddress)); + + if (self.sockets.length >= this.maxSockets) { + // We are over limit so we'll add it to the queue. + self.requests.push(options); + return; + } + + // If we are under maxSockets create a new one. + self.createSocket(options, function(socket) { + socket.on('free', onFree); + socket.on('close', onCloseOrRemove); + socket.on('agentRemove', onCloseOrRemove); + req.onSocket(socket); + + function onFree() { + self.emit('free', socket, options); + } + + function onCloseOrRemove(err) { + self.removeSocket(socket); + socket.removeListener('free', onFree); + socket.removeListener('close', onCloseOrRemove); + socket.removeListener('agentRemove', onCloseOrRemove); + } + }); +}; + +TunnelingAgent.prototype.createSocket = function createSocket(options, cb) { + var self = this; + var placeholder = {}; + self.sockets.push(placeholder); + + var connectOptions = mergeOptions({}, self.proxyOptions, { + method: 'CONNECT', + path: options.host + ':' + options.port, + agent: false, + headers: { + host: options.host + ':' + options.port + } + }); + if (options.localAddress) { + connectOptions.localAddress = options.localAddress; + } + if (connectOptions.proxyAuth) { + connectOptions.headers = connectOptions.headers || {}; + connectOptions.headers['Proxy-Authorization'] = 'Basic ' + + new Buffer(connectOptions.proxyAuth).toString('base64'); + } + + debug('making CONNECT request'); + var connectReq = self.request(connectOptions); + connectReq.useChunkedEncodingByDefault = false; // for v0.6 + connectReq.once('response', onResponse); // for v0.6 + connectReq.once('upgrade', onUpgrade); // for v0.6 + connectReq.once('connect', onConnect); // for v0.7 or later + connectReq.once('error', onError); + connectReq.end(); + + function onResponse(res) { + // Very hacky. This is necessary to avoid http-parser leaks. + res.upgrade = true; + } + + function onUpgrade(res, socket, head) { + // Hacky. + process.nextTick(function() { + onConnect(res, socket, head); + }); + } + + function onConnect(res, socket, head) { + connectReq.removeAllListeners(); + socket.removeAllListeners(); + + if (res.statusCode !== 200) { + debug('tunneling socket could not be established, statusCode=%d', + res.statusCode); + socket.destroy(); + var error = new Error('tunneling socket could not be established, ' + + 'statusCode=' + res.statusCode); + error.code = 'ECONNRESET'; + options.request.emit('error', error); + self.removeSocket(placeholder); + return; + } + if (head.length > 0) { + debug('got illegal response body from proxy'); + socket.destroy(); + var error = new Error('got illegal response body from proxy'); + error.code = 'ECONNRESET'; + options.request.emit('error', error); + self.removeSocket(placeholder); + return; + } + debug('tunneling connection has established'); + self.sockets[self.sockets.indexOf(placeholder)] = socket; + return cb(socket); + } + + function onError(cause) { + connectReq.removeAllListeners(); + + debug('tunneling socket could not be established, cause=%s\n', + cause.message, cause.stack); + var error = new Error('tunneling socket could not be established, ' + + 'cause=' + cause.message); + error.code = 'ECONNRESET'; + options.request.emit('error', error); + self.removeSocket(placeholder); + } +}; + +TunnelingAgent.prototype.removeSocket = function removeSocket(socket) { + var pos = this.sockets.indexOf(socket) + if (pos === -1) { + return; + } + this.sockets.splice(pos, 1); + + var pending = this.requests.shift(); + if (pending) { + // If we have pending requests and a socket gets closed a new one + // needs to be created to take over in the pool for the one that closed. + this.createSocket(pending, function(socket) { + pending.request.onSocket(socket); + }); + } +}; + +function createSecureSocket(options, cb) { + var self = this; + TunnelingAgent.prototype.createSocket.call(self, options, function(socket) { + var hostHeader = options.request.getHeader('host'); + var tlsOptions = mergeOptions({}, self.options, { + socket: socket, + servername: hostHeader ? hostHeader.replace(/:.*$/, '') : options.host + }); + + // 0 is dummy port for v0.6 + var secureSocket = tls.connect(0, tlsOptions); + self.sockets[self.sockets.indexOf(socket)] = secureSocket; + cb(secureSocket); + }); +} + + +function toOptions(host, port, localAddress) { + if (typeof host === 'string') { // since v0.10 + return { + host: host, + port: port, + localAddress: localAddress + }; + } + return host; // for v0.11 or later +} + +function mergeOptions(target) { + for (var i = 1, len = arguments.length; i < len; ++i) { + var overrides = arguments[i]; + if (typeof overrides === 'object') { + var keys = Object.keys(overrides); + for (var j = 0, keyLen = keys.length; j < keyLen; ++j) { + var k = keys[j]; + if (overrides[k] !== undefined) { + target[k] = overrides[k]; + } + } + } + } + return target; +} + + +var debug; +if (process.env.NODE_DEBUG && /\btunnel\b/.test(process.env.NODE_DEBUG)) { + debug = function() { + var args = Array.prototype.slice.call(arguments); + if (typeof args[0] === 'string') { + args[0] = 'TUNNEL: ' + args[0]; + } else { + args.unshift('TUNNEL:'); + } + console.error.apply(console, args); + } +} else { + debug = function() {}; +} +exports.debug = debug; // for test + + +/***/ }), + +/***/ 6752: +/***/ ((module, __unused_webpack_exports, __nccwpck_require__) => { + + + +const Client = __nccwpck_require__(6197) +const Dispatcher = __nccwpck_require__(992) +const errors = __nccwpck_require__(8707) +const Pool = __nccwpck_require__(5076) +const BalancedPool = __nccwpck_require__(1093) +const Agent = __nccwpck_require__(9965) +const util = __nccwpck_require__(3440) +const { InvalidArgumentError } = errors +const api = __nccwpck_require__(6615) +const buildConnector = __nccwpck_require__(9136) +const MockClient = __nccwpck_require__(7365) +const MockAgent = __nccwpck_require__(7501) +const MockPool = __nccwpck_require__(4004) +const mockErrors = __nccwpck_require__(2429) +const ProxyAgent = __nccwpck_require__(2720) +const RetryHandler = __nccwpck_require__(3573) +const { getGlobalDispatcher, setGlobalDispatcher } = __nccwpck_require__(2581) +const DecoratorHandler = __nccwpck_require__(8840) +const RedirectHandler = __nccwpck_require__(8299) +const createRedirectInterceptor = __nccwpck_require__(4415) + +let hasCrypto +try { + __nccwpck_require__(6982) + hasCrypto = true +} catch { + hasCrypto = false +} + +Object.assign(Dispatcher.prototype, api) + +module.exports.Dispatcher = Dispatcher +module.exports.Client = Client +module.exports.Pool = Pool +module.exports.BalancedPool = BalancedPool +module.exports.Agent = Agent +module.exports.ProxyAgent = ProxyAgent +module.exports.RetryHandler = RetryHandler + +module.exports.DecoratorHandler = DecoratorHandler +module.exports.RedirectHandler = RedirectHandler +module.exports.createRedirectInterceptor = createRedirectInterceptor + +module.exports.buildConnector = buildConnector +module.exports.errors = errors + +function makeDispatcher (fn) { + return (url, opts, handler) => { + if (typeof opts === 'function') { + handler = opts + opts = null + } + + if (!url || (typeof url !== 'string' && typeof url !== 'object' && !(url instanceof URL))) { + throw new InvalidArgumentError('invalid url') + } + + if (opts != null && typeof opts !== 'object') { + throw new InvalidArgumentError('invalid opts') + } + + if (opts && opts.path != null) { + if (typeof opts.path !== 'string') { + throw new InvalidArgumentError('invalid opts.path') + } + + let path = opts.path + if (!opts.path.startsWith('/')) { + path = `/${path}` + } + + url = new URL(util.parseOrigin(url).origin + path) + } else { + if (!opts) { + opts = typeof url === 'object' ? url : {} + } + + url = util.parseURL(url) + } + + const { agent, dispatcher = getGlobalDispatcher() } = opts + + if (agent) { + throw new InvalidArgumentError('unsupported opts.agent. Did you mean opts.client?') + } + + return fn.call(dispatcher, { + ...opts, + origin: url.origin, + path: url.search ? `${url.pathname}${url.search}` : url.pathname, + method: opts.method || (opts.body ? 'PUT' : 'GET') + }, handler) + } +} + +module.exports.setGlobalDispatcher = setGlobalDispatcher +module.exports.getGlobalDispatcher = getGlobalDispatcher + +if (util.nodeMajor > 16 || (util.nodeMajor === 16 && util.nodeMinor >= 8)) { + let fetchImpl = null + module.exports.fetch = async function fetch (resource) { + if (!fetchImpl) { + fetchImpl = (__nccwpck_require__(2315).fetch) + } + + try { + return await fetchImpl(...arguments) + } catch (err) { + if (typeof err === 'object') { + Error.captureStackTrace(err, this) + } + + throw err + } + } + module.exports.Headers = __nccwpck_require__(6349).Headers + module.exports.Response = __nccwpck_require__(8676).Response + module.exports.Request = __nccwpck_require__(5194).Request + module.exports.FormData = __nccwpck_require__(3073).FormData + module.exports.File = __nccwpck_require__(3041).File + module.exports.FileReader = __nccwpck_require__(2160).FileReader + + const { setGlobalOrigin, getGlobalOrigin } = __nccwpck_require__(5628) + + module.exports.setGlobalOrigin = setGlobalOrigin + module.exports.getGlobalOrigin = getGlobalOrigin + + const { CacheStorage } = __nccwpck_require__(4738) + const { kConstruct } = __nccwpck_require__(296) + + // Cache & CacheStorage are tightly coupled with fetch. Even if it may run + // in an older version of Node, it doesn't have any use without fetch. + module.exports.caches = new CacheStorage(kConstruct) +} + +if (util.nodeMajor >= 16) { + const { deleteCookie, getCookies, getSetCookies, setCookie } = __nccwpck_require__(3168) + + module.exports.deleteCookie = deleteCookie + module.exports.getCookies = getCookies + module.exports.getSetCookies = getSetCookies + module.exports.setCookie = setCookie + + const { parseMIMEType, serializeAMimeType } = __nccwpck_require__(4322) + + module.exports.parseMIMEType = parseMIMEType + module.exports.serializeAMimeType = serializeAMimeType +} + +if (util.nodeMajor >= 18 && hasCrypto) { + const { WebSocket } = __nccwpck_require__(5171) + + module.exports.WebSocket = WebSocket +} + +module.exports.request = makeDispatcher(api.request) +module.exports.stream = makeDispatcher(api.stream) +module.exports.pipeline = makeDispatcher(api.pipeline) +module.exports.connect = makeDispatcher(api.connect) +module.exports.upgrade = makeDispatcher(api.upgrade) + +module.exports.MockClient = MockClient +module.exports.MockPool = MockPool +module.exports.MockAgent = MockAgent +module.exports.mockErrors = mockErrors + + +/***/ }), + +/***/ 9965: +/***/ ((module, __unused_webpack_exports, __nccwpck_require__) => { + + + +const { InvalidArgumentError } = __nccwpck_require__(8707) +const { kClients, kRunning, kClose, kDestroy, kDispatch, kInterceptors } = __nccwpck_require__(6443) +const DispatcherBase = __nccwpck_require__(1) +const Pool = __nccwpck_require__(5076) +const Client = __nccwpck_require__(6197) +const util = __nccwpck_require__(3440) +const createRedirectInterceptor = __nccwpck_require__(4415) +const { WeakRef, FinalizationRegistry } = __nccwpck_require__(3194)() + +const kOnConnect = Symbol('onConnect') +const kOnDisconnect = Symbol('onDisconnect') +const kOnConnectionError = Symbol('onConnectionError') +const kMaxRedirections = Symbol('maxRedirections') +const kOnDrain = Symbol('onDrain') +const kFactory = Symbol('factory') +const kFinalizer = Symbol('finalizer') +const kOptions = Symbol('options') + +function defaultFactory (origin, opts) { + return opts && opts.connections === 1 + ? new Client(origin, opts) + : new Pool(origin, opts) +} + +class Agent extends DispatcherBase { + constructor ({ factory = defaultFactory, maxRedirections = 0, connect, ...options } = {}) { + super() + + if (typeof factory !== 'function') { + throw new InvalidArgumentError('factory must be a function.') + } + + if (connect != null && typeof connect !== 'function' && typeof connect !== 'object') { + throw new InvalidArgumentError('connect must be a function or an object') + } + + if (!Number.isInteger(maxRedirections) || maxRedirections < 0) { + throw new InvalidArgumentError('maxRedirections must be a positive number') + } + + if (connect && typeof connect !== 'function') { + connect = { ...connect } + } + + this[kInterceptors] = options.interceptors && options.interceptors.Agent && Array.isArray(options.interceptors.Agent) + ? options.interceptors.Agent + : [createRedirectInterceptor({ maxRedirections })] + + this[kOptions] = { ...util.deepClone(options), connect } + this[kOptions].interceptors = options.interceptors + ? { ...options.interceptors } + : undefined + this[kMaxRedirections] = maxRedirections + this[kFactory] = factory + this[kClients] = new Map() + this[kFinalizer] = new FinalizationRegistry(/* istanbul ignore next: gc is undeterministic */ key => { + const ref = this[kClients].get(key) + if (ref !== undefined && ref.deref() === undefined) { + this[kClients].delete(key) + } + }) + + const agent = this + + this[kOnDrain] = (origin, targets) => { + agent.emit('drain', origin, [agent, ...targets]) + } + + this[kOnConnect] = (origin, targets) => { + agent.emit('connect', origin, [agent, ...targets]) + } + + this[kOnDisconnect] = (origin, targets, err) => { + agent.emit('disconnect', origin, [agent, ...targets], err) + } + + this[kOnConnectionError] = (origin, targets, err) => { + agent.emit('connectionError', origin, [agent, ...targets], err) + } + } + + get [kRunning] () { + let ret = 0 + for (const ref of this[kClients].values()) { + const client = ref.deref() + /* istanbul ignore next: gc is undeterministic */ + if (client) { + ret += client[kRunning] + } + } + return ret + } + + [kDispatch] (opts, handler) { + let key + if (opts.origin && (typeof opts.origin === 'string' || opts.origin instanceof URL)) { + key = String(opts.origin) + } else { + throw new InvalidArgumentError('opts.origin must be a non-empty string or URL.') + } + + const ref = this[kClients].get(key) + + let dispatcher = ref ? ref.deref() : null + if (!dispatcher) { + dispatcher = this[kFactory](opts.origin, this[kOptions]) + .on('drain', this[kOnDrain]) + .on('connect', this[kOnConnect]) + .on('disconnect', this[kOnDisconnect]) + .on('connectionError', this[kOnConnectionError]) + + this[kClients].set(key, new WeakRef(dispatcher)) + this[kFinalizer].register(dispatcher, key) + } + + return dispatcher.dispatch(opts, handler) + } + + async [kClose] () { + const closePromises = [] + for (const ref of this[kClients].values()) { + const client = ref.deref() + /* istanbul ignore else: gc is undeterministic */ + if (client) { + closePromises.push(client.close()) + } + } + + await Promise.all(closePromises) + } + + async [kDestroy] (err) { + const destroyPromises = [] + for (const ref of this[kClients].values()) { + const client = ref.deref() + /* istanbul ignore else: gc is undeterministic */ + if (client) { + destroyPromises.push(client.destroy(err)) + } + } + + await Promise.all(destroyPromises) + } +} + +module.exports = Agent + + +/***/ }), + +/***/ 158: +/***/ ((module, __unused_webpack_exports, __nccwpck_require__) => { + +const { addAbortListener } = __nccwpck_require__(3440) +const { RequestAbortedError } = __nccwpck_require__(8707) + +const kListener = Symbol('kListener') +const kSignal = Symbol('kSignal') + +function abort (self) { + if (self.abort) { + self.abort() + } else { + self.onError(new RequestAbortedError()) + } +} + +function addSignal (self, signal) { + self[kSignal] = null + self[kListener] = null + + if (!signal) { + return + } + + if (signal.aborted) { + abort(self) + return + } + + self[kSignal] = signal + self[kListener] = () => { + abort(self) + } + + addAbortListener(self[kSignal], self[kListener]) +} + +function removeSignal (self) { + if (!self[kSignal]) { + return + } + + if ('removeEventListener' in self[kSignal]) { + self[kSignal].removeEventListener('abort', self[kListener]) + } else { + self[kSignal].removeListener('abort', self[kListener]) + } + + self[kSignal] = null + self[kListener] = null +} + +module.exports = { + addSignal, + removeSignal +} + + +/***/ }), + +/***/ 4660: +/***/ ((module, __unused_webpack_exports, __nccwpck_require__) => { + + + +const { AsyncResource } = __nccwpck_require__(290) +const { InvalidArgumentError, RequestAbortedError, SocketError } = __nccwpck_require__(8707) +const util = __nccwpck_require__(3440) +const { addSignal, removeSignal } = __nccwpck_require__(158) + +class ConnectHandler extends AsyncResource { + constructor (opts, callback) { + if (!opts || typeof opts !== 'object') { + throw new InvalidArgumentError('invalid opts') + } + + if (typeof callback !== 'function') { + throw new InvalidArgumentError('invalid callback') + } + + const { signal, opaque, responseHeaders } = opts + + if (signal && typeof signal.on !== 'function' && typeof signal.addEventListener !== 'function') { + throw new InvalidArgumentError('signal must be an EventEmitter or EventTarget') + } + + super('UNDICI_CONNECT') + + this.opaque = opaque || null + this.responseHeaders = responseHeaders || null + this.callback = callback + this.abort = null + + addSignal(this, signal) + } + + onConnect (abort, context) { + if (!this.callback) { + throw new RequestAbortedError() + } + + this.abort = abort + this.context = context + } + + onHeaders () { + throw new SocketError('bad connect', null) + } + + onUpgrade (statusCode, rawHeaders, socket) { + const { callback, opaque, context } = this + + removeSignal(this) + + this.callback = null + + let headers = rawHeaders + // Indicates is an HTTP2Session + if (headers != null) { + headers = this.responseHeaders === 'raw' ? util.parseRawHeaders(rawHeaders) : util.parseHeaders(rawHeaders) + } + + this.runInAsyncScope(callback, null, null, { + statusCode, + headers, + socket, + opaque, + context + }) + } + + onError (err) { + const { callback, opaque } = this + + removeSignal(this) + + if (callback) { + this.callback = null + queueMicrotask(() => { + this.runInAsyncScope(callback, null, err, { opaque }) + }) + } + } +} + +function connect (opts, callback) { + if (callback === undefined) { + return new Promise((resolve, reject) => { + connect.call(this, opts, (err, data) => { + return err ? reject(err) : resolve(data) + }) + }) + } + + try { + const connectHandler = new ConnectHandler(opts, callback) + this.dispatch({ ...opts, method: 'CONNECT' }, connectHandler) + } catch (err) { + if (typeof callback !== 'function') { + throw err + } + const opaque = opts && opts.opaque + queueMicrotask(() => callback(err, { opaque })) + } +} + +module.exports = connect + + +/***/ }), + +/***/ 6862: +/***/ ((module, __unused_webpack_exports, __nccwpck_require__) => { + + + +const { + Readable, + Duplex, + PassThrough +} = __nccwpck_require__(2203) +const { + InvalidArgumentError, + InvalidReturnValueError, + RequestAbortedError +} = __nccwpck_require__(8707) +const util = __nccwpck_require__(3440) +const { AsyncResource } = __nccwpck_require__(290) +const { addSignal, removeSignal } = __nccwpck_require__(158) +const assert = __nccwpck_require__(2613) + +const kResume = Symbol('resume') + +class PipelineRequest extends Readable { + constructor () { + super({ autoDestroy: true }) + + this[kResume] = null + } + + _read () { + const { [kResume]: resume } = this + + if (resume) { + this[kResume] = null + resume() + } + } + + _destroy (err, callback) { + this._read() + + callback(err) + } +} + +class PipelineResponse extends Readable { + constructor (resume) { + super({ autoDestroy: true }) + this[kResume] = resume + } + + _read () { + this[kResume]() + } + + _destroy (err, callback) { + if (!err && !this._readableState.endEmitted) { + err = new RequestAbortedError() + } + + callback(err) + } +} + +class PipelineHandler extends AsyncResource { + constructor (opts, handler) { + if (!opts || typeof opts !== 'object') { + throw new InvalidArgumentError('invalid opts') + } + + if (typeof handler !== 'function') { + throw new InvalidArgumentError('invalid handler') + } + + const { signal, method, opaque, onInfo, responseHeaders } = opts + + if (signal && typeof signal.on !== 'function' && typeof signal.addEventListener !== 'function') { + throw new InvalidArgumentError('signal must be an EventEmitter or EventTarget') + } + + if (method === 'CONNECT') { + throw new InvalidArgumentError('invalid method') + } + + if (onInfo && typeof onInfo !== 'function') { + throw new InvalidArgumentError('invalid onInfo callback') + } + + super('UNDICI_PIPELINE') + + this.opaque = opaque || null + this.responseHeaders = responseHeaders || null + this.handler = handler + this.abort = null + this.context = null + this.onInfo = onInfo || null + + this.req = new PipelineRequest().on('error', util.nop) + + this.ret = new Duplex({ + readableObjectMode: opts.objectMode, + autoDestroy: true, + read: () => { + const { body } = this + + if (body && body.resume) { + body.resume() + } + }, + write: (chunk, encoding, callback) => { + const { req } = this + + if (req.push(chunk, encoding) || req._readableState.destroyed) { + callback() + } else { + req[kResume] = callback + } + }, + destroy: (err, callback) => { + const { body, req, res, ret, abort } = this + + if (!err && !ret._readableState.endEmitted) { + err = new RequestAbortedError() + } + + if (abort && err) { + abort() + } + + util.destroy(body, err) + util.destroy(req, err) + util.destroy(res, err) + + removeSignal(this) + + callback(err) + } + }).on('prefinish', () => { + const { req } = this + + // Node < 15 does not call _final in same tick. + req.push(null) + }) + + this.res = null + + addSignal(this, signal) + } + + onConnect (abort, context) { + const { ret, res } = this + + assert(!res, 'pipeline cannot be retried') + + if (ret.destroyed) { + throw new RequestAbortedError() + } + + this.abort = abort + this.context = context + } + + onHeaders (statusCode, rawHeaders, resume) { + const { opaque, handler, context } = this + + if (statusCode < 200) { + if (this.onInfo) { + const headers = this.responseHeaders === 'raw' ? util.parseRawHeaders(rawHeaders) : util.parseHeaders(rawHeaders) + this.onInfo({ statusCode, headers }) + } + return + } + + this.res = new PipelineResponse(resume) + + let body + try { + this.handler = null + const headers = this.responseHeaders === 'raw' ? util.parseRawHeaders(rawHeaders) : util.parseHeaders(rawHeaders) + body = this.runInAsyncScope(handler, null, { + statusCode, + headers, + opaque, + body: this.res, + context + }) + } catch (err) { + this.res.on('error', util.nop) + throw err + } + + if (!body || typeof body.on !== 'function') { + throw new InvalidReturnValueError('expected Readable') + } + + body + .on('data', (chunk) => { + const { ret, body } = this + + if (!ret.push(chunk) && body.pause) { + body.pause() + } + }) + .on('error', (err) => { + const { ret } = this + + util.destroy(ret, err) + }) + .on('end', () => { + const { ret } = this + + ret.push(null) + }) + .on('close', () => { + const { ret } = this + + if (!ret._readableState.ended) { + util.destroy(ret, new RequestAbortedError()) + } + }) + + this.body = body + } + + onData (chunk) { + const { res } = this + return res.push(chunk) + } + + onComplete (trailers) { + const { res } = this + res.push(null) + } + + onError (err) { + const { ret } = this + this.handler = null + util.destroy(ret, err) + } +} + +function pipeline (opts, handler) { + try { + const pipelineHandler = new PipelineHandler(opts, handler) + this.dispatch({ ...opts, body: pipelineHandler.req }, pipelineHandler) + return pipelineHandler.ret + } catch (err) { + return new PassThrough().destroy(err) + } +} + +module.exports = pipeline + + +/***/ }), + +/***/ 4043: +/***/ ((module, __unused_webpack_exports, __nccwpck_require__) => { + + + +const Readable = __nccwpck_require__(9927) +const { + InvalidArgumentError, + RequestAbortedError +} = __nccwpck_require__(8707) +const util = __nccwpck_require__(3440) +const { getResolveErrorBodyCallback } = __nccwpck_require__(7655) +const { AsyncResource } = __nccwpck_require__(290) +const { addSignal, removeSignal } = __nccwpck_require__(158) + +class RequestHandler extends AsyncResource { + constructor (opts, callback) { + if (!opts || typeof opts !== 'object') { + throw new InvalidArgumentError('invalid opts') + } + + const { signal, method, opaque, body, onInfo, responseHeaders, throwOnError, highWaterMark } = opts + + try { + if (typeof callback !== 'function') { + throw new InvalidArgumentError('invalid callback') + } + + if (highWaterMark && (typeof highWaterMark !== 'number' || highWaterMark < 0)) { + throw new InvalidArgumentError('invalid highWaterMark') + } + + if (signal && typeof signal.on !== 'function' && typeof signal.addEventListener !== 'function') { + throw new InvalidArgumentError('signal must be an EventEmitter or EventTarget') + } + + if (method === 'CONNECT') { + throw new InvalidArgumentError('invalid method') + } + + if (onInfo && typeof onInfo !== 'function') { + throw new InvalidArgumentError('invalid onInfo callback') + } + + super('UNDICI_REQUEST') + } catch (err) { + if (util.isStream(body)) { + util.destroy(body.on('error', util.nop), err) + } + throw err + } + + this.responseHeaders = responseHeaders || null + this.opaque = opaque || null + this.callback = callback + this.res = null + this.abort = null + this.body = body + this.trailers = {} + this.context = null + this.onInfo = onInfo || null + this.throwOnError = throwOnError + this.highWaterMark = highWaterMark + + if (util.isStream(body)) { + body.on('error', (err) => { + this.onError(err) + }) + } + + addSignal(this, signal) + } + + onConnect (abort, context) { + if (!this.callback) { + throw new RequestAbortedError() + } + + this.abort = abort + this.context = context + } + + onHeaders (statusCode, rawHeaders, resume, statusMessage) { + const { callback, opaque, abort, context, responseHeaders, highWaterMark } = this + + const headers = responseHeaders === 'raw' ? util.parseRawHeaders(rawHeaders) : util.parseHeaders(rawHeaders) + + if (statusCode < 200) { + if (this.onInfo) { + this.onInfo({ statusCode, headers }) + } + return + } + + const parsedHeaders = responseHeaders === 'raw' ? util.parseHeaders(rawHeaders) : headers + const contentType = parsedHeaders['content-type'] + const body = new Readable({ resume, abort, contentType, highWaterMark }) + + this.callback = null + this.res = body + if (callback !== null) { + if (this.throwOnError && statusCode >= 400) { + this.runInAsyncScope(getResolveErrorBodyCallback, null, + { callback, body, contentType, statusCode, statusMessage, headers } + ) + } else { + this.runInAsyncScope(callback, null, null, { + statusCode, + headers, + trailers: this.trailers, + opaque, + body, + context + }) + } + } + } + + onData (chunk) { + const { res } = this + return res.push(chunk) + } + + onComplete (trailers) { + const { res } = this + + removeSignal(this) + + util.parseHeaders(trailers, this.trailers) + + res.push(null) + } + + onError (err) { + const { res, callback, body, opaque } = this + + removeSignal(this) + + if (callback) { + // TODO: Does this need queueMicrotask? + this.callback = null + queueMicrotask(() => { + this.runInAsyncScope(callback, null, err, { opaque }) + }) + } + + if (res) { + this.res = null + // Ensure all queued handlers are invoked before destroying res. + queueMicrotask(() => { + util.destroy(res, err) + }) + } + + if (body) { + this.body = null + util.destroy(body, err) + } + } +} + +function request (opts, callback) { + if (callback === undefined) { + return new Promise((resolve, reject) => { + request.call(this, opts, (err, data) => { + return err ? reject(err) : resolve(data) + }) + }) + } + + try { + this.dispatch(opts, new RequestHandler(opts, callback)) + } catch (err) { + if (typeof callback !== 'function') { + throw err + } + const opaque = opts && opts.opaque + queueMicrotask(() => callback(err, { opaque })) + } +} + +module.exports = request +module.exports.RequestHandler = RequestHandler + + +/***/ }), + +/***/ 3560: +/***/ ((module, __unused_webpack_exports, __nccwpck_require__) => { + + + +const { finished, PassThrough } = __nccwpck_require__(2203) +const { + InvalidArgumentError, + InvalidReturnValueError, + RequestAbortedError +} = __nccwpck_require__(8707) +const util = __nccwpck_require__(3440) +const { getResolveErrorBodyCallback } = __nccwpck_require__(7655) +const { AsyncResource } = __nccwpck_require__(290) +const { addSignal, removeSignal } = __nccwpck_require__(158) + +class StreamHandler extends AsyncResource { + constructor (opts, factory, callback) { + if (!opts || typeof opts !== 'object') { + throw new InvalidArgumentError('invalid opts') + } + + const { signal, method, opaque, body, onInfo, responseHeaders, throwOnError } = opts + + try { + if (typeof callback !== 'function') { + throw new InvalidArgumentError('invalid callback') + } + + if (typeof factory !== 'function') { + throw new InvalidArgumentError('invalid factory') + } + + if (signal && typeof signal.on !== 'function' && typeof signal.addEventListener !== 'function') { + throw new InvalidArgumentError('signal must be an EventEmitter or EventTarget') + } + + if (method === 'CONNECT') { + throw new InvalidArgumentError('invalid method') + } + + if (onInfo && typeof onInfo !== 'function') { + throw new InvalidArgumentError('invalid onInfo callback') + } + + super('UNDICI_STREAM') + } catch (err) { + if (util.isStream(body)) { + util.destroy(body.on('error', util.nop), err) + } + throw err + } + + this.responseHeaders = responseHeaders || null + this.opaque = opaque || null + this.factory = factory + this.callback = callback + this.res = null + this.abort = null + this.context = null + this.trailers = null + this.body = body + this.onInfo = onInfo || null + this.throwOnError = throwOnError || false + + if (util.isStream(body)) { + body.on('error', (err) => { + this.onError(err) + }) + } + + addSignal(this, signal) + } + + onConnect (abort, context) { + if (!this.callback) { + throw new RequestAbortedError() + } + + this.abort = abort + this.context = context + } + + onHeaders (statusCode, rawHeaders, resume, statusMessage) { + const { factory, opaque, context, callback, responseHeaders } = this + + const headers = responseHeaders === 'raw' ? util.parseRawHeaders(rawHeaders) : util.parseHeaders(rawHeaders) + + if (statusCode < 200) { + if (this.onInfo) { + this.onInfo({ statusCode, headers }) + } + return + } + + this.factory = null + + let res + + if (this.throwOnError && statusCode >= 400) { + const parsedHeaders = responseHeaders === 'raw' ? util.parseHeaders(rawHeaders) : headers + const contentType = parsedHeaders['content-type'] + res = new PassThrough() + + this.callback = null + this.runInAsyncScope(getResolveErrorBodyCallback, null, + { callback, body: res, contentType, statusCode, statusMessage, headers } + ) + } else { + if (factory === null) { + return + } + + res = this.runInAsyncScope(factory, null, { + statusCode, + headers, + opaque, + context + }) + + if ( + !res || + typeof res.write !== 'function' || + typeof res.end !== 'function' || + typeof res.on !== 'function' + ) { + throw new InvalidReturnValueError('expected Writable') + } + + // TODO: Avoid finished. It registers an unnecessary amount of listeners. + finished(res, { readable: false }, (err) => { + const { callback, res, opaque, trailers, abort } = this + + this.res = null + if (err || !res.readable) { + util.destroy(res, err) + } + + this.callback = null + this.runInAsyncScope(callback, null, err || null, { opaque, trailers }) + + if (err) { + abort() + } + }) + } + + res.on('drain', resume) + + this.res = res + + const needDrain = res.writableNeedDrain !== undefined + ? res.writableNeedDrain + : res._writableState && res._writableState.needDrain + + return needDrain !== true + } + + onData (chunk) { + const { res } = this + + return res ? res.write(chunk) : true + } + + onComplete (trailers) { + const { res } = this + + removeSignal(this) + + if (!res) { + return + } + + this.trailers = util.parseHeaders(trailers) + + res.end() + } + + onError (err) { + const { res, callback, opaque, body } = this + + removeSignal(this) + + this.factory = null + + if (res) { + this.res = null + util.destroy(res, err) + } else if (callback) { + this.callback = null + queueMicrotask(() => { + this.runInAsyncScope(callback, null, err, { opaque }) + }) + } + + if (body) { + this.body = null + util.destroy(body, err) + } + } +} + +function stream (opts, factory, callback) { + if (callback === undefined) { + return new Promise((resolve, reject) => { + stream.call(this, opts, factory, (err, data) => { + return err ? reject(err) : resolve(data) + }) + }) + } + + try { + this.dispatch(opts, new StreamHandler(opts, factory, callback)) + } catch (err) { + if (typeof callback !== 'function') { + throw err + } + const opaque = opts && opts.opaque + queueMicrotask(() => callback(err, { opaque })) + } +} + +module.exports = stream + + +/***/ }), + +/***/ 1882: +/***/ ((module, __unused_webpack_exports, __nccwpck_require__) => { + + + +const { InvalidArgumentError, RequestAbortedError, SocketError } = __nccwpck_require__(8707) +const { AsyncResource } = __nccwpck_require__(290) +const util = __nccwpck_require__(3440) +const { addSignal, removeSignal } = __nccwpck_require__(158) +const assert = __nccwpck_require__(2613) + +class UpgradeHandler extends AsyncResource { + constructor (opts, callback) { + if (!opts || typeof opts !== 'object') { + throw new InvalidArgumentError('invalid opts') + } + + if (typeof callback !== 'function') { + throw new InvalidArgumentError('invalid callback') + } + + const { signal, opaque, responseHeaders } = opts + + if (signal && typeof signal.on !== 'function' && typeof signal.addEventListener !== 'function') { + throw new InvalidArgumentError('signal must be an EventEmitter or EventTarget') + } + + super('UNDICI_UPGRADE') + + this.responseHeaders = responseHeaders || null + this.opaque = opaque || null + this.callback = callback + this.abort = null + this.context = null + + addSignal(this, signal) + } + + onConnect (abort, context) { + if (!this.callback) { + throw new RequestAbortedError() + } + + this.abort = abort + this.context = null + } + + onHeaders () { + throw new SocketError('bad upgrade', null) + } + + onUpgrade (statusCode, rawHeaders, socket) { + const { callback, opaque, context } = this + + assert.strictEqual(statusCode, 101) + + removeSignal(this) + + this.callback = null + const headers = this.responseHeaders === 'raw' ? util.parseRawHeaders(rawHeaders) : util.parseHeaders(rawHeaders) + this.runInAsyncScope(callback, null, null, { + headers, + socket, + opaque, + context + }) + } + + onError (err) { + const { callback, opaque } = this + + removeSignal(this) + + if (callback) { + this.callback = null + queueMicrotask(() => { + this.runInAsyncScope(callback, null, err, { opaque }) + }) + } + } +} + +function upgrade (opts, callback) { + if (callback === undefined) { + return new Promise((resolve, reject) => { + upgrade.call(this, opts, (err, data) => { + return err ? reject(err) : resolve(data) + }) + }) + } + + try { + const upgradeHandler = new UpgradeHandler(opts, callback) + this.dispatch({ + ...opts, + method: opts.method || 'GET', + upgrade: opts.protocol || 'Websocket' + }, upgradeHandler) + } catch (err) { + if (typeof callback !== 'function') { + throw err + } + const opaque = opts && opts.opaque + queueMicrotask(() => callback(err, { opaque })) + } +} + +module.exports = upgrade + + +/***/ }), + +/***/ 6615: +/***/ ((module, __unused_webpack_exports, __nccwpck_require__) => { + + + +module.exports.request = __nccwpck_require__(4043) +module.exports.stream = __nccwpck_require__(3560) +module.exports.pipeline = __nccwpck_require__(6862) +module.exports.upgrade = __nccwpck_require__(1882) +module.exports.connect = __nccwpck_require__(4660) + + +/***/ }), + +/***/ 9927: +/***/ ((module, __unused_webpack_exports, __nccwpck_require__) => { + +// Ported from https://github.com/nodejs/undici/pull/907 + + + +const assert = __nccwpck_require__(2613) +const { Readable } = __nccwpck_require__(2203) +const { RequestAbortedError, NotSupportedError, InvalidArgumentError } = __nccwpck_require__(8707) +const util = __nccwpck_require__(3440) +const { ReadableStreamFrom, toUSVString } = __nccwpck_require__(3440) + +let Blob + +const kConsume = Symbol('kConsume') +const kReading = Symbol('kReading') +const kBody = Symbol('kBody') +const kAbort = Symbol('abort') +const kContentType = Symbol('kContentType') + +const noop = () => {} + +module.exports = class BodyReadable extends Readable { + constructor ({ + resume, + abort, + contentType = '', + highWaterMark = 64 * 1024 // Same as nodejs fs streams. + }) { + super({ + autoDestroy: true, + read: resume, + highWaterMark + }) + + this._readableState.dataEmitted = false + + this[kAbort] = abort + this[kConsume] = null + this[kBody] = null + this[kContentType] = contentType + + // Is stream being consumed through Readable API? + // This is an optimization so that we avoid checking + // for 'data' and 'readable' listeners in the hot path + // inside push(). + this[kReading] = false + } + + destroy (err) { + if (this.destroyed) { + // Node < 16 + return this + } + + if (!err && !this._readableState.endEmitted) { + err = new RequestAbortedError() + } + + if (err) { + this[kAbort]() + } + + return super.destroy(err) + } + + emit (ev, ...args) { + if (ev === 'data') { + // Node < 16.7 + this._readableState.dataEmitted = true + } else if (ev === 'error') { + // Node < 16 + this._readableState.errorEmitted = true + } + return super.emit(ev, ...args) + } + + on (ev, ...args) { + if (ev === 'data' || ev === 'readable') { + this[kReading] = true + } + return super.on(ev, ...args) + } + + addListener (ev, ...args) { + return this.on(ev, ...args) + } + + off (ev, ...args) { + const ret = super.off(ev, ...args) + if (ev === 'data' || ev === 'readable') { + this[kReading] = ( + this.listenerCount('data') > 0 || + this.listenerCount('readable') > 0 + ) + } + return ret + } + + removeListener (ev, ...args) { + return this.off(ev, ...args) + } + + push (chunk) { + if (this[kConsume] && chunk !== null && this.readableLength === 0) { + consumePush(this[kConsume], chunk) + return this[kReading] ? super.push(chunk) : true + } + return super.push(chunk) + } + + // https://fetch.spec.whatwg.org/#dom-body-text + async text () { + return consume(this, 'text') + } + + // https://fetch.spec.whatwg.org/#dom-body-json + async json () { + return consume(this, 'json') + } + + // https://fetch.spec.whatwg.org/#dom-body-blob + async blob () { + return consume(this, 'blob') + } + + // https://fetch.spec.whatwg.org/#dom-body-arraybuffer + async arrayBuffer () { + return consume(this, 'arrayBuffer') + } + + // https://fetch.spec.whatwg.org/#dom-body-formdata + async formData () { + // TODO: Implement. + throw new NotSupportedError() + } + + // https://fetch.spec.whatwg.org/#dom-body-bodyused + get bodyUsed () { + return util.isDisturbed(this) + } + + // https://fetch.spec.whatwg.org/#dom-body-body + get body () { + if (!this[kBody]) { + this[kBody] = ReadableStreamFrom(this) + if (this[kConsume]) { + // TODO: Is this the best way to force a lock? + this[kBody].getReader() // Ensure stream is locked. + assert(this[kBody].locked) + } + } + return this[kBody] + } + + dump (opts) { + let limit = opts && Number.isFinite(opts.limit) ? opts.limit : 262144 + const signal = opts && opts.signal + + if (signal) { + try { + if (typeof signal !== 'object' || !('aborted' in signal)) { + throw new InvalidArgumentError('signal must be an AbortSignal') + } + util.throwIfAborted(signal) + } catch (err) { + return Promise.reject(err) + } + } + + if (this.closed) { + return Promise.resolve(null) + } + + return new Promise((resolve, reject) => { + const signalListenerCleanup = signal + ? util.addAbortListener(signal, () => { + this.destroy() + }) + : noop + + this + .on('close', function () { + signalListenerCleanup() + if (signal && signal.aborted) { + reject(signal.reason || Object.assign(new Error('The operation was aborted'), { name: 'AbortError' })) + } else { + resolve(null) + } + }) + .on('error', noop) + .on('data', function (chunk) { + limit -= chunk.length + if (limit <= 0) { + this.destroy() + } + }) + .resume() + }) + } +} + +// https://streams.spec.whatwg.org/#readablestream-locked +function isLocked (self) { + // Consume is an implicit lock. + return (self[kBody] && self[kBody].locked === true) || self[kConsume] +} + +// https://fetch.spec.whatwg.org/#body-unusable +function isUnusable (self) { + return util.isDisturbed(self) || isLocked(self) +} + +async function consume (stream, type) { + if (isUnusable(stream)) { + throw new TypeError('unusable') + } + + assert(!stream[kConsume]) + + return new Promise((resolve, reject) => { + stream[kConsume] = { + type, + stream, + resolve, + reject, + length: 0, + body: [] + } + + stream + .on('error', function (err) { + consumeFinish(this[kConsume], err) + }) + .on('close', function () { + if (this[kConsume].body !== null) { + consumeFinish(this[kConsume], new RequestAbortedError()) + } + }) + + process.nextTick(consumeStart, stream[kConsume]) + }) +} + +function consumeStart (consume) { + if (consume.body === null) { + return + } + + const { _readableState: state } = consume.stream + + for (const chunk of state.buffer) { + consumePush(consume, chunk) + } + + if (state.endEmitted) { + consumeEnd(this[kConsume]) + } else { + consume.stream.on('end', function () { + consumeEnd(this[kConsume]) + }) + } + + consume.stream.resume() + + while (consume.stream.read() != null) { + // Loop + } +} + +function consumeEnd (consume) { + const { type, body, resolve, stream, length } = consume + + try { + if (type === 'text') { + resolve(toUSVString(Buffer.concat(body))) + } else if (type === 'json') { + resolve(JSON.parse(Buffer.concat(body))) + } else if (type === 'arrayBuffer') { + const dst = new Uint8Array(length) + + let pos = 0 + for (const buf of body) { + dst.set(buf, pos) + pos += buf.byteLength + } + + resolve(dst.buffer) + } else if (type === 'blob') { + if (!Blob) { + Blob = (__nccwpck_require__(181).Blob) + } + resolve(new Blob(body, { type: stream[kContentType] })) + } + + consumeFinish(consume) + } catch (err) { + stream.destroy(err) + } +} + +function consumePush (consume, chunk) { + consume.length += chunk.length + consume.body.push(chunk) +} + +function consumeFinish (consume, err) { + if (consume.body === null) { + return + } + + if (err) { + consume.reject(err) + } else { + consume.resolve() + } + + consume.type = null + consume.stream = null + consume.resolve = null + consume.reject = null + consume.length = 0 + consume.body = null +} + + +/***/ }), + +/***/ 7655: +/***/ ((module, __unused_webpack_exports, __nccwpck_require__) => { + +const assert = __nccwpck_require__(2613) +const { + ResponseStatusCodeError +} = __nccwpck_require__(8707) +const { toUSVString } = __nccwpck_require__(3440) + +async function getResolveErrorBodyCallback ({ callback, body, contentType, statusCode, statusMessage, headers }) { + assert(body) + + let chunks = [] + let limit = 0 + + for await (const chunk of body) { + chunks.push(chunk) + limit += chunk.length + if (limit > 128 * 1024) { + chunks = null + break + } + } + + if (statusCode === 204 || !contentType || !chunks) { + process.nextTick(callback, new ResponseStatusCodeError(`Response status code ${statusCode}${statusMessage ? `: ${statusMessage}` : ''}`, statusCode, headers)) + return + } + + try { + if (contentType.startsWith('application/json')) { + const payload = JSON.parse(toUSVString(Buffer.concat(chunks))) + process.nextTick(callback, new ResponseStatusCodeError(`Response status code ${statusCode}${statusMessage ? `: ${statusMessage}` : ''}`, statusCode, headers, payload)) + return + } + + if (contentType.startsWith('text/')) { + const payload = toUSVString(Buffer.concat(chunks)) + process.nextTick(callback, new ResponseStatusCodeError(`Response status code ${statusCode}${statusMessage ? `: ${statusMessage}` : ''}`, statusCode, headers, payload)) + return + } + } catch (err) { + // Process in a fallback if error + } + + process.nextTick(callback, new ResponseStatusCodeError(`Response status code ${statusCode}${statusMessage ? `: ${statusMessage}` : ''}`, statusCode, headers)) +} + +module.exports = { getResolveErrorBodyCallback } + + +/***/ }), + +/***/ 1093: +/***/ ((module, __unused_webpack_exports, __nccwpck_require__) => { + + + +const { + BalancedPoolMissingUpstreamError, + InvalidArgumentError +} = __nccwpck_require__(8707) +const { + PoolBase, + kClients, + kNeedDrain, + kAddClient, + kRemoveClient, + kGetDispatcher +} = __nccwpck_require__(8640) +const Pool = __nccwpck_require__(5076) +const { kUrl, kInterceptors } = __nccwpck_require__(6443) +const { parseOrigin } = __nccwpck_require__(3440) +const kFactory = Symbol('factory') + +const kOptions = Symbol('options') +const kGreatestCommonDivisor = Symbol('kGreatestCommonDivisor') +const kCurrentWeight = Symbol('kCurrentWeight') +const kIndex = Symbol('kIndex') +const kWeight = Symbol('kWeight') +const kMaxWeightPerServer = Symbol('kMaxWeightPerServer') +const kErrorPenalty = Symbol('kErrorPenalty') + +function getGreatestCommonDivisor (a, b) { + if (b === 0) return a + return getGreatestCommonDivisor(b, a % b) +} + +function defaultFactory (origin, opts) { + return new Pool(origin, opts) +} + +class BalancedPool extends PoolBase { + constructor (upstreams = [], { factory = defaultFactory, ...opts } = {}) { + super() + + this[kOptions] = opts + this[kIndex] = -1 + this[kCurrentWeight] = 0 + + this[kMaxWeightPerServer] = this[kOptions].maxWeightPerServer || 100 + this[kErrorPenalty] = this[kOptions].errorPenalty || 15 + + if (!Array.isArray(upstreams)) { + upstreams = [upstreams] + } + + if (typeof factory !== 'function') { + throw new InvalidArgumentError('factory must be a function.') + } + + this[kInterceptors] = opts.interceptors && opts.interceptors.BalancedPool && Array.isArray(opts.interceptors.BalancedPool) + ? opts.interceptors.BalancedPool + : [] + this[kFactory] = factory + + for (const upstream of upstreams) { + this.addUpstream(upstream) + } + this._updateBalancedPoolStats() + } + + addUpstream (upstream) { + const upstreamOrigin = parseOrigin(upstream).origin + + if (this[kClients].find((pool) => ( + pool[kUrl].origin === upstreamOrigin && + pool.closed !== true && + pool.destroyed !== true + ))) { + return this + } + const pool = this[kFactory](upstreamOrigin, Object.assign({}, this[kOptions])) + + this[kAddClient](pool) + pool.on('connect', () => { + pool[kWeight] = Math.min(this[kMaxWeightPerServer], pool[kWeight] + this[kErrorPenalty]) + }) + + pool.on('connectionError', () => { + pool[kWeight] = Math.max(1, pool[kWeight] - this[kErrorPenalty]) + this._updateBalancedPoolStats() + }) + + pool.on('disconnect', (...args) => { + const err = args[2] + if (err && err.code === 'UND_ERR_SOCKET') { + // decrease the weight of the pool. + pool[kWeight] = Math.max(1, pool[kWeight] - this[kErrorPenalty]) + this._updateBalancedPoolStats() + } + }) + + for (const client of this[kClients]) { + client[kWeight] = this[kMaxWeightPerServer] + } + + this._updateBalancedPoolStats() + + return this + } + + _updateBalancedPoolStats () { + this[kGreatestCommonDivisor] = this[kClients].map(p => p[kWeight]).reduce(getGreatestCommonDivisor, 0) + } + + removeUpstream (upstream) { + const upstreamOrigin = parseOrigin(upstream).origin + + const pool = this[kClients].find((pool) => ( + pool[kUrl].origin === upstreamOrigin && + pool.closed !== true && + pool.destroyed !== true + )) + + if (pool) { + this[kRemoveClient](pool) + } + + return this + } + + get upstreams () { + return this[kClients] + .filter(dispatcher => dispatcher.closed !== true && dispatcher.destroyed !== true) + .map((p) => p[kUrl].origin) + } + + [kGetDispatcher] () { + // We validate that pools is greater than 0, + // otherwise we would have to wait until an upstream + // is added, which might never happen. + if (this[kClients].length === 0) { + throw new BalancedPoolMissingUpstreamError() + } + + const dispatcher = this[kClients].find(dispatcher => ( + !dispatcher[kNeedDrain] && + dispatcher.closed !== true && + dispatcher.destroyed !== true + )) + + if (!dispatcher) { + return + } + + const allClientsBusy = this[kClients].map(pool => pool[kNeedDrain]).reduce((a, b) => a && b, true) + + if (allClientsBusy) { + return + } + + let counter = 0 + + let maxWeightIndex = this[kClients].findIndex(pool => !pool[kNeedDrain]) + + while (counter++ < this[kClients].length) { + this[kIndex] = (this[kIndex] + 1) % this[kClients].length + const pool = this[kClients][this[kIndex]] + + // find pool index with the largest weight + if (pool[kWeight] > this[kClients][maxWeightIndex][kWeight] && !pool[kNeedDrain]) { + maxWeightIndex = this[kIndex] + } + + // decrease the current weight every `this[kClients].length`. + if (this[kIndex] === 0) { + // Set the current weight to the next lower weight. + this[kCurrentWeight] = this[kCurrentWeight] - this[kGreatestCommonDivisor] + + if (this[kCurrentWeight] <= 0) { + this[kCurrentWeight] = this[kMaxWeightPerServer] + } + } + if (pool[kWeight] >= this[kCurrentWeight] && (!pool[kNeedDrain])) { + return pool + } + } + + this[kCurrentWeight] = this[kClients][maxWeightIndex][kWeight] + this[kIndex] = maxWeightIndex + return this[kClients][maxWeightIndex] + } +} + +module.exports = BalancedPool + + +/***/ }), + +/***/ 479: +/***/ ((module, __unused_webpack_exports, __nccwpck_require__) => { + + + +const { kConstruct } = __nccwpck_require__(296) +const { urlEquals, fieldValues: getFieldValues } = __nccwpck_require__(3993) +const { kEnumerableProperty, isDisturbed } = __nccwpck_require__(3440) +const { kHeadersList } = __nccwpck_require__(6443) +const { webidl } = __nccwpck_require__(4222) +const { Response, cloneResponse } = __nccwpck_require__(8676) +const { Request } = __nccwpck_require__(5194) +const { kState, kHeaders, kGuard, kRealm } = __nccwpck_require__(9710) +const { fetching } = __nccwpck_require__(2315) +const { urlIsHttpHttpsScheme, createDeferredPromise, readAllBytes } = __nccwpck_require__(5523) +const assert = __nccwpck_require__(2613) +const { getGlobalDispatcher } = __nccwpck_require__(2581) + +/** + * @see https://w3c.github.io/ServiceWorker/#dfn-cache-batch-operation + * @typedef {Object} CacheBatchOperation + * @property {'delete' | 'put'} type + * @property {any} request + * @property {any} response + * @property {import('../../types/cache').CacheQueryOptions} options + */ + +/** + * @see https://w3c.github.io/ServiceWorker/#dfn-request-response-list + * @typedef {[any, any][]} requestResponseList + */ + +class Cache { + /** + * @see https://w3c.github.io/ServiceWorker/#dfn-relevant-request-response-list + * @type {requestResponseList} + */ + #relevantRequestResponseList + + constructor () { + if (arguments[0] !== kConstruct) { + webidl.illegalConstructor() + } + + this.#relevantRequestResponseList = arguments[1] + } + + async match (request, options = {}) { + webidl.brandCheck(this, Cache) + webidl.argumentLengthCheck(arguments, 1, { header: 'Cache.match' }) + + request = webidl.converters.RequestInfo(request) + options = webidl.converters.CacheQueryOptions(options) + + const p = await this.matchAll(request, options) + + if (p.length === 0) { + return + } + + return p[0] + } + + async matchAll (request = undefined, options = {}) { + webidl.brandCheck(this, Cache) + + if (request !== undefined) request = webidl.converters.RequestInfo(request) + options = webidl.converters.CacheQueryOptions(options) + + // 1. + let r = null + + // 2. + if (request !== undefined) { + if (request instanceof Request) { + // 2.1.1 + r = request[kState] + + // 2.1.2 + if (r.method !== 'GET' && !options.ignoreMethod) { + return [] + } + } else if (typeof request === 'string') { + // 2.2.1 + r = new Request(request)[kState] + } + } + + // 5. + // 5.1 + const responses = [] + + // 5.2 + if (request === undefined) { + // 5.2.1 + for (const requestResponse of this.#relevantRequestResponseList) { + responses.push(requestResponse[1]) + } + } else { // 5.3 + // 5.3.1 + const requestResponses = this.#queryCache(r, options) + + // 5.3.2 + for (const requestResponse of requestResponses) { + responses.push(requestResponse[1]) + } + } + + // 5.4 + // We don't implement CORs so we don't need to loop over the responses, yay! + + // 5.5.1 + const responseList = [] + + // 5.5.2 + for (const response of responses) { + // 5.5.2.1 + const responseObject = new Response(response.body?.source ?? null) + const body = responseObject[kState].body + responseObject[kState] = response + responseObject[kState].body = body + responseObject[kHeaders][kHeadersList] = response.headersList + responseObject[kHeaders][kGuard] = 'immutable' + + responseList.push(responseObject) + } + + // 6. + return Object.freeze(responseList) + } + + async add (request) { + webidl.brandCheck(this, Cache) + webidl.argumentLengthCheck(arguments, 1, { header: 'Cache.add' }) + + request = webidl.converters.RequestInfo(request) + + // 1. + const requests = [request] + + // 2. + const responseArrayPromise = this.addAll(requests) + + // 3. + return await responseArrayPromise + } + + async addAll (requests) { + webidl.brandCheck(this, Cache) + webidl.argumentLengthCheck(arguments, 1, { header: 'Cache.addAll' }) + + requests = webidl.converters['sequence'](requests) + + // 1. + const responsePromises = [] + + // 2. + const requestList = [] + + // 3. + for (const request of requests) { + if (typeof request === 'string') { + continue + } + + // 3.1 + const r = request[kState] + + // 3.2 + if (!urlIsHttpHttpsScheme(r.url) || r.method !== 'GET') { + throw webidl.errors.exception({ + header: 'Cache.addAll', + message: 'Expected http/s scheme when method is not GET.' + }) + } + } + + // 4. + /** @type {ReturnType[]} */ + const fetchControllers = [] + + // 5. + for (const request of requests) { + // 5.1 + const r = new Request(request)[kState] + + // 5.2 + if (!urlIsHttpHttpsScheme(r.url)) { + throw webidl.errors.exception({ + header: 'Cache.addAll', + message: 'Expected http/s scheme.' + }) + } + + // 5.4 + r.initiator = 'fetch' + r.destination = 'subresource' + + // 5.5 + requestList.push(r) + + // 5.6 + const responsePromise = createDeferredPromise() + + // 5.7 + fetchControllers.push(fetching({ + request: r, + dispatcher: getGlobalDispatcher(), + processResponse (response) { + // 1. + if (response.type === 'error' || response.status === 206 || response.status < 200 || response.status > 299) { + responsePromise.reject(webidl.errors.exception({ + header: 'Cache.addAll', + message: 'Received an invalid status code or the request failed.' + })) + } else if (response.headersList.contains('vary')) { // 2. + // 2.1 + const fieldValues = getFieldValues(response.headersList.get('vary')) + + // 2.2 + for (const fieldValue of fieldValues) { + // 2.2.1 + if (fieldValue === '*') { + responsePromise.reject(webidl.errors.exception({ + header: 'Cache.addAll', + message: 'invalid vary field value' + })) + + for (const controller of fetchControllers) { + controller.abort() + } + + return + } + } + } + }, + processResponseEndOfBody (response) { + // 1. + if (response.aborted) { + responsePromise.reject(new DOMException('aborted', 'AbortError')) + return + } + + // 2. + responsePromise.resolve(response) + } + })) + + // 5.8 + responsePromises.push(responsePromise.promise) + } + + // 6. + const p = Promise.all(responsePromises) + + // 7. + const responses = await p + + // 7.1 + const operations = [] + + // 7.2 + let index = 0 + + // 7.3 + for (const response of responses) { + // 7.3.1 + /** @type {CacheBatchOperation} */ + const operation = { + type: 'put', // 7.3.2 + request: requestList[index], // 7.3.3 + response // 7.3.4 + } + + operations.push(operation) // 7.3.5 + + index++ // 7.3.6 + } + + // 7.5 + const cacheJobPromise = createDeferredPromise() + + // 7.6.1 + let errorData = null + + // 7.6.2 + try { + this.#batchCacheOperations(operations) + } catch (e) { + errorData = e + } + + // 7.6.3 + queueMicrotask(() => { + // 7.6.3.1 + if (errorData === null) { + cacheJobPromise.resolve(undefined) + } else { + // 7.6.3.2 + cacheJobPromise.reject(errorData) + } + }) + + // 7.7 + return cacheJobPromise.promise + } + + async put (request, response) { + webidl.brandCheck(this, Cache) + webidl.argumentLengthCheck(arguments, 2, { header: 'Cache.put' }) + + request = webidl.converters.RequestInfo(request) + response = webidl.converters.Response(response) + + // 1. + let innerRequest = null + + // 2. + if (request instanceof Request) { + innerRequest = request[kState] + } else { // 3. + innerRequest = new Request(request)[kState] + } + + // 4. + if (!urlIsHttpHttpsScheme(innerRequest.url) || innerRequest.method !== 'GET') { + throw webidl.errors.exception({ + header: 'Cache.put', + message: 'Expected an http/s scheme when method is not GET' + }) + } + + // 5. + const innerResponse = response[kState] + + // 6. + if (innerResponse.status === 206) { + throw webidl.errors.exception({ + header: 'Cache.put', + message: 'Got 206 status' + }) + } + + // 7. + if (innerResponse.headersList.contains('vary')) { + // 7.1. + const fieldValues = getFieldValues(innerResponse.headersList.get('vary')) + + // 7.2. + for (const fieldValue of fieldValues) { + // 7.2.1 + if (fieldValue === '*') { + throw webidl.errors.exception({ + header: 'Cache.put', + message: 'Got * vary field value' + }) + } + } + } + + // 8. + if (innerResponse.body && (isDisturbed(innerResponse.body.stream) || innerResponse.body.stream.locked)) { + throw webidl.errors.exception({ + header: 'Cache.put', + message: 'Response body is locked or disturbed' + }) + } + + // 9. + const clonedResponse = cloneResponse(innerResponse) + + // 10. + const bodyReadPromise = createDeferredPromise() + + // 11. + if (innerResponse.body != null) { + // 11.1 + const stream = innerResponse.body.stream + + // 11.2 + const reader = stream.getReader() + + // 11.3 + readAllBytes(reader).then(bodyReadPromise.resolve, bodyReadPromise.reject) + } else { + bodyReadPromise.resolve(undefined) + } + + // 12. + /** @type {CacheBatchOperation[]} */ + const operations = [] + + // 13. + /** @type {CacheBatchOperation} */ + const operation = { + type: 'put', // 14. + request: innerRequest, // 15. + response: clonedResponse // 16. + } + + // 17. + operations.push(operation) + + // 19. + const bytes = await bodyReadPromise.promise + + if (clonedResponse.body != null) { + clonedResponse.body.source = bytes + } + + // 19.1 + const cacheJobPromise = createDeferredPromise() + + // 19.2.1 + let errorData = null + + // 19.2.2 + try { + this.#batchCacheOperations(operations) + } catch (e) { + errorData = e + } + + // 19.2.3 + queueMicrotask(() => { + // 19.2.3.1 + if (errorData === null) { + cacheJobPromise.resolve() + } else { // 19.2.3.2 + cacheJobPromise.reject(errorData) + } + }) + + return cacheJobPromise.promise + } + + async delete (request, options = {}) { + webidl.brandCheck(this, Cache) + webidl.argumentLengthCheck(arguments, 1, { header: 'Cache.delete' }) + + request = webidl.converters.RequestInfo(request) + options = webidl.converters.CacheQueryOptions(options) + + /** + * @type {Request} + */ + let r = null + + if (request instanceof Request) { + r = request[kState] + + if (r.method !== 'GET' && !options.ignoreMethod) { + return false + } + } else { + assert(typeof request === 'string') + + r = new Request(request)[kState] + } + + /** @type {CacheBatchOperation[]} */ + const operations = [] + + /** @type {CacheBatchOperation} */ + const operation = { + type: 'delete', + request: r, + options + } + + operations.push(operation) + + const cacheJobPromise = createDeferredPromise() + + let errorData = null + let requestResponses + + try { + requestResponses = this.#batchCacheOperations(operations) + } catch (e) { + errorData = e + } + + queueMicrotask(() => { + if (errorData === null) { + cacheJobPromise.resolve(!!requestResponses?.length) + } else { + cacheJobPromise.reject(errorData) + } + }) + + return cacheJobPromise.promise + } + + /** + * @see https://w3c.github.io/ServiceWorker/#dom-cache-keys + * @param {any} request + * @param {import('../../types/cache').CacheQueryOptions} options + * @returns {readonly Request[]} + */ + async keys (request = undefined, options = {}) { + webidl.brandCheck(this, Cache) + + if (request !== undefined) request = webidl.converters.RequestInfo(request) + options = webidl.converters.CacheQueryOptions(options) + + // 1. + let r = null + + // 2. + if (request !== undefined) { + // 2.1 + if (request instanceof Request) { + // 2.1.1 + r = request[kState] + + // 2.1.2 + if (r.method !== 'GET' && !options.ignoreMethod) { + return [] + } + } else if (typeof request === 'string') { // 2.2 + r = new Request(request)[kState] + } + } + + // 4. + const promise = createDeferredPromise() + + // 5. + // 5.1 + const requests = [] + + // 5.2 + if (request === undefined) { + // 5.2.1 + for (const requestResponse of this.#relevantRequestResponseList) { + // 5.2.1.1 + requests.push(requestResponse[0]) + } + } else { // 5.3 + // 5.3.1 + const requestResponses = this.#queryCache(r, options) + + // 5.3.2 + for (const requestResponse of requestResponses) { + // 5.3.2.1 + requests.push(requestResponse[0]) + } + } + + // 5.4 + queueMicrotask(() => { + // 5.4.1 + const requestList = [] + + // 5.4.2 + for (const request of requests) { + const requestObject = new Request('https://a') + requestObject[kState] = request + requestObject[kHeaders][kHeadersList] = request.headersList + requestObject[kHeaders][kGuard] = 'immutable' + requestObject[kRealm] = request.client + + // 5.4.2.1 + requestList.push(requestObject) + } + + // 5.4.3 + promise.resolve(Object.freeze(requestList)) + }) + + return promise.promise + } + + /** + * @see https://w3c.github.io/ServiceWorker/#batch-cache-operations-algorithm + * @param {CacheBatchOperation[]} operations + * @returns {requestResponseList} + */ + #batchCacheOperations (operations) { + // 1. + const cache = this.#relevantRequestResponseList + + // 2. + const backupCache = [...cache] + + // 3. + const addedItems = [] + + // 4.1 + const resultList = [] + + try { + // 4.2 + for (const operation of operations) { + // 4.2.1 + if (operation.type !== 'delete' && operation.type !== 'put') { + throw webidl.errors.exception({ + header: 'Cache.#batchCacheOperations', + message: 'operation type does not match "delete" or "put"' + }) + } + + // 4.2.2 + if (operation.type === 'delete' && operation.response != null) { + throw webidl.errors.exception({ + header: 'Cache.#batchCacheOperations', + message: 'delete operation should not have an associated response' + }) + } + + // 4.2.3 + if (this.#queryCache(operation.request, operation.options, addedItems).length) { + throw new DOMException('???', 'InvalidStateError') + } + + // 4.2.4 + let requestResponses + + // 4.2.5 + if (operation.type === 'delete') { + // 4.2.5.1 + requestResponses = this.#queryCache(operation.request, operation.options) + + // TODO: the spec is wrong, this is needed to pass WPTs + if (requestResponses.length === 0) { + return [] + } + + // 4.2.5.2 + for (const requestResponse of requestResponses) { + const idx = cache.indexOf(requestResponse) + assert(idx !== -1) + + // 4.2.5.2.1 + cache.splice(idx, 1) + } + } else if (operation.type === 'put') { // 4.2.6 + // 4.2.6.1 + if (operation.response == null) { + throw webidl.errors.exception({ + header: 'Cache.#batchCacheOperations', + message: 'put operation should have an associated response' + }) + } + + // 4.2.6.2 + const r = operation.request + + // 4.2.6.3 + if (!urlIsHttpHttpsScheme(r.url)) { + throw webidl.errors.exception({ + header: 'Cache.#batchCacheOperations', + message: 'expected http or https scheme' + }) + } + + // 4.2.6.4 + if (r.method !== 'GET') { + throw webidl.errors.exception({ + header: 'Cache.#batchCacheOperations', + message: 'not get method' + }) + } + + // 4.2.6.5 + if (operation.options != null) { + throw webidl.errors.exception({ + header: 'Cache.#batchCacheOperations', + message: 'options must not be defined' + }) + } + + // 4.2.6.6 + requestResponses = this.#queryCache(operation.request) + + // 4.2.6.7 + for (const requestResponse of requestResponses) { + const idx = cache.indexOf(requestResponse) + assert(idx !== -1) + + // 4.2.6.7.1 + cache.splice(idx, 1) + } + + // 4.2.6.8 + cache.push([operation.request, operation.response]) + + // 4.2.6.10 + addedItems.push([operation.request, operation.response]) + } + + // 4.2.7 + resultList.push([operation.request, operation.response]) + } + + // 4.3 + return resultList + } catch (e) { // 5. + // 5.1 + this.#relevantRequestResponseList.length = 0 + + // 5.2 + this.#relevantRequestResponseList = backupCache + + // 5.3 + throw e + } + } + + /** + * @see https://w3c.github.io/ServiceWorker/#query-cache + * @param {any} requestQuery + * @param {import('../../types/cache').CacheQueryOptions} options + * @param {requestResponseList} targetStorage + * @returns {requestResponseList} + */ + #queryCache (requestQuery, options, targetStorage) { + /** @type {requestResponseList} */ + const resultList = [] + + const storage = targetStorage ?? this.#relevantRequestResponseList + + for (const requestResponse of storage) { + const [cachedRequest, cachedResponse] = requestResponse + if (this.#requestMatchesCachedItem(requestQuery, cachedRequest, cachedResponse, options)) { + resultList.push(requestResponse) + } + } + + return resultList + } + + /** + * @see https://w3c.github.io/ServiceWorker/#request-matches-cached-item-algorithm + * @param {any} requestQuery + * @param {any} request + * @param {any | null} response + * @param {import('../../types/cache').CacheQueryOptions | undefined} options + * @returns {boolean} + */ + #requestMatchesCachedItem (requestQuery, request, response = null, options) { + // if (options?.ignoreMethod === false && request.method === 'GET') { + // return false + // } + + const queryURL = new URL(requestQuery.url) + + const cachedURL = new URL(request.url) + + if (options?.ignoreSearch) { + cachedURL.search = '' + + queryURL.search = '' + } + + if (!urlEquals(queryURL, cachedURL, true)) { + return false + } + + if ( + response == null || + options?.ignoreVary || + !response.headersList.contains('vary') + ) { + return true + } + + const fieldValues = getFieldValues(response.headersList.get('vary')) + + for (const fieldValue of fieldValues) { + if (fieldValue === '*') { + return false + } + + const requestValue = request.headersList.get(fieldValue) + const queryValue = requestQuery.headersList.get(fieldValue) + + // If one has the header and the other doesn't, or one has + // a different value than the other, return false + if (requestValue !== queryValue) { + return false + } + } + + return true + } +} + +Object.defineProperties(Cache.prototype, { + [Symbol.toStringTag]: { + value: 'Cache', + configurable: true + }, + match: kEnumerableProperty, + matchAll: kEnumerableProperty, + add: kEnumerableProperty, + addAll: kEnumerableProperty, + put: kEnumerableProperty, + delete: kEnumerableProperty, + keys: kEnumerableProperty +}) + +const cacheQueryOptionConverters = [ + { + key: 'ignoreSearch', + converter: webidl.converters.boolean, + defaultValue: false + }, + { + key: 'ignoreMethod', + converter: webidl.converters.boolean, + defaultValue: false + }, + { + key: 'ignoreVary', + converter: webidl.converters.boolean, + defaultValue: false + } +] + +webidl.converters.CacheQueryOptions = webidl.dictionaryConverter(cacheQueryOptionConverters) + +webidl.converters.MultiCacheQueryOptions = webidl.dictionaryConverter([ + ...cacheQueryOptionConverters, + { + key: 'cacheName', + converter: webidl.converters.DOMString + } +]) + +webidl.converters.Response = webidl.interfaceConverter(Response) + +webidl.converters['sequence'] = webidl.sequenceConverter( + webidl.converters.RequestInfo +) + +module.exports = { + Cache +} + + +/***/ }), + +/***/ 4738: +/***/ ((module, __unused_webpack_exports, __nccwpck_require__) => { + + + +const { kConstruct } = __nccwpck_require__(296) +const { Cache } = __nccwpck_require__(479) +const { webidl } = __nccwpck_require__(4222) +const { kEnumerableProperty } = __nccwpck_require__(3440) + +class CacheStorage { + /** + * @see https://w3c.github.io/ServiceWorker/#dfn-relevant-name-to-cache-map + * @type {Map} + */ + async has (cacheName) { + webidl.brandCheck(this, CacheStorage) + webidl.argumentLengthCheck(arguments, 1, { header: 'CacheStorage.has' }) + + cacheName = webidl.converters.DOMString(cacheName) + + // 2.1.1 + // 2.2 + return this.#caches.has(cacheName) + } + + /** + * @see https://w3c.github.io/ServiceWorker/#dom-cachestorage-open + * @param {string} cacheName + * @returns {Promise} + */ + async open (cacheName) { + webidl.brandCheck(this, CacheStorage) + webidl.argumentLengthCheck(arguments, 1, { header: 'CacheStorage.open' }) + + cacheName = webidl.converters.DOMString(cacheName) + + // 2.1 + if (this.#caches.has(cacheName)) { + // await caches.open('v1') !== await caches.open('v1') + + // 2.1.1 + const cache = this.#caches.get(cacheName) + + // 2.1.1.1 + return new Cache(kConstruct, cache) + } + + // 2.2 + const cache = [] + + // 2.3 + this.#caches.set(cacheName, cache) + + // 2.4 + return new Cache(kConstruct, cache) + } + + /** + * @see https://w3c.github.io/ServiceWorker/#cache-storage-delete + * @param {string} cacheName + * @returns {Promise} + */ + async delete (cacheName) { + webidl.brandCheck(this, CacheStorage) + webidl.argumentLengthCheck(arguments, 1, { header: 'CacheStorage.delete' }) + + cacheName = webidl.converters.DOMString(cacheName) + + return this.#caches.delete(cacheName) + } + + /** + * @see https://w3c.github.io/ServiceWorker/#cache-storage-keys + * @returns {string[]} + */ + async keys () { + webidl.brandCheck(this, CacheStorage) + + // 2.1 + const keys = this.#caches.keys() + + // 2.2 + return [...keys] + } +} + +Object.defineProperties(CacheStorage.prototype, { + [Symbol.toStringTag]: { + value: 'CacheStorage', + configurable: true + }, + match: kEnumerableProperty, + has: kEnumerableProperty, + open: kEnumerableProperty, + delete: kEnumerableProperty, + keys: kEnumerableProperty +}) + +module.exports = { + CacheStorage +} + + +/***/ }), + +/***/ 296: +/***/ ((module, __unused_webpack_exports, __nccwpck_require__) => { + + + +module.exports = { + kConstruct: (__nccwpck_require__(6443).kConstruct) +} + + +/***/ }), + +/***/ 3993: +/***/ ((module, __unused_webpack_exports, __nccwpck_require__) => { + + + +const assert = __nccwpck_require__(2613) +const { URLSerializer } = __nccwpck_require__(4322) +const { isValidHeaderName } = __nccwpck_require__(5523) + +/** + * @see https://url.spec.whatwg.org/#concept-url-equals + * @param {URL} A + * @param {URL} B + * @param {boolean | undefined} excludeFragment + * @returns {boolean} + */ +function urlEquals (A, B, excludeFragment = false) { + const serializedA = URLSerializer(A, excludeFragment) + + const serializedB = URLSerializer(B, excludeFragment) + + return serializedA === serializedB +} + +/** + * @see https://github.com/chromium/chromium/blob/694d20d134cb553d8d89e5500b9148012b1ba299/content/browser/cache_storage/cache_storage_cache.cc#L260-L262 + * @param {string} header + */ +function fieldValues (header) { + assert(header !== null) + + const values = [] + + for (let value of header.split(',')) { + value = value.trim() + + if (!value.length) { + continue + } else if (!isValidHeaderName(value)) { + continue + } + + values.push(value) + } + + return values +} + +module.exports = { + urlEquals, + fieldValues +} + + +/***/ }), + +/***/ 6197: +/***/ ((module, __unused_webpack_exports, __nccwpck_require__) => { + +// @ts-check + + + +/* global WebAssembly */ + +const assert = __nccwpck_require__(2613) +const net = __nccwpck_require__(9278) +const http = __nccwpck_require__(8611) +const { pipeline } = __nccwpck_require__(2203) +const util = __nccwpck_require__(3440) +const timers = __nccwpck_require__(8804) +const Request = __nccwpck_require__(4655) +const DispatcherBase = __nccwpck_require__(1) +const { + RequestContentLengthMismatchError, + ResponseContentLengthMismatchError, + InvalidArgumentError, + RequestAbortedError, + HeadersTimeoutError, + HeadersOverflowError, + SocketError, + InformationalError, + BodyTimeoutError, + HTTPParserError, + ResponseExceededMaxSizeError, + ClientDestroyedError +} = __nccwpck_require__(8707) +const buildConnector = __nccwpck_require__(9136) +const { + kUrl, + kReset, + kServerName, + kClient, + kBusy, + kParser, + kConnect, + kBlocking, + kResuming, + kRunning, + kPending, + kSize, + kWriting, + kQueue, + kConnected, + kConnecting, + kNeedDrain, + kNoRef, + kKeepAliveDefaultTimeout, + kHostHeader, + kPendingIdx, + kRunningIdx, + kError, + kPipelining, + kSocket, + kKeepAliveTimeoutValue, + kMaxHeadersSize, + kKeepAliveMaxTimeout, + kKeepAliveTimeoutThreshold, + kHeadersTimeout, + kBodyTimeout, + kStrictContentLength, + kConnector, + kMaxRedirections, + kMaxRequests, + kCounter, + kClose, + kDestroy, + kDispatch, + kInterceptors, + kLocalAddress, + kMaxResponseSize, + kHTTPConnVersion, + // HTTP2 + kHost, + kHTTP2Session, + kHTTP2SessionState, + kHTTP2BuildRequest, + kHTTP2CopyHeaders, + kHTTP1BuildRequest +} = __nccwpck_require__(6443) + +/** @type {import('http2')} */ +let http2 +try { + http2 = __nccwpck_require__(5675) +} catch { + // @ts-ignore + http2 = { constants: {} } +} + +const { + constants: { + HTTP2_HEADER_AUTHORITY, + HTTP2_HEADER_METHOD, + HTTP2_HEADER_PATH, + HTTP2_HEADER_SCHEME, + HTTP2_HEADER_CONTENT_LENGTH, + HTTP2_HEADER_EXPECT, + HTTP2_HEADER_STATUS + } +} = http2 + +// Experimental +let h2ExperimentalWarned = false + +const FastBuffer = Buffer[Symbol.species] + +const kClosedResolve = Symbol('kClosedResolve') + +const channels = {} + +try { + const diagnosticsChannel = __nccwpck_require__(1637) + channels.sendHeaders = diagnosticsChannel.channel('undici:client:sendHeaders') + channels.beforeConnect = diagnosticsChannel.channel('undici:client:beforeConnect') + channels.connectError = diagnosticsChannel.channel('undici:client:connectError') + channels.connected = diagnosticsChannel.channel('undici:client:connected') +} catch { + channels.sendHeaders = { hasSubscribers: false } + channels.beforeConnect = { hasSubscribers: false } + channels.connectError = { hasSubscribers: false } + channels.connected = { hasSubscribers: false } +} + +/** + * @type {import('../types/client').default} + */ +class Client extends DispatcherBase { + /** + * + * @param {string|URL} url + * @param {import('../types/client').Client.Options} options + */ + constructor (url, { + interceptors, + maxHeaderSize, + headersTimeout, + socketTimeout, + requestTimeout, + connectTimeout, + bodyTimeout, + idleTimeout, + keepAlive, + keepAliveTimeout, + maxKeepAliveTimeout, + keepAliveMaxTimeout, + keepAliveTimeoutThreshold, + socketPath, + pipelining, + tls, + strictContentLength, + maxCachedSessions, + maxRedirections, + connect, + maxRequestsPerClient, + localAddress, + maxResponseSize, + autoSelectFamily, + autoSelectFamilyAttemptTimeout, + // h2 + allowH2, + maxConcurrentStreams + } = {}) { + super() + + if (keepAlive !== undefined) { + throw new InvalidArgumentError('unsupported keepAlive, use pipelining=0 instead') + } + + if (socketTimeout !== undefined) { + throw new InvalidArgumentError('unsupported socketTimeout, use headersTimeout & bodyTimeout instead') + } + + if (requestTimeout !== undefined) { + throw new InvalidArgumentError('unsupported requestTimeout, use headersTimeout & bodyTimeout instead') + } + + if (idleTimeout !== undefined) { + throw new InvalidArgumentError('unsupported idleTimeout, use keepAliveTimeout instead') + } + + if (maxKeepAliveTimeout !== undefined) { + throw new InvalidArgumentError('unsupported maxKeepAliveTimeout, use keepAliveMaxTimeout instead') + } + + if (maxHeaderSize != null && !Number.isFinite(maxHeaderSize)) { + throw new InvalidArgumentError('invalid maxHeaderSize') + } + + if (socketPath != null && typeof socketPath !== 'string') { + throw new InvalidArgumentError('invalid socketPath') + } + + if (connectTimeout != null && (!Number.isFinite(connectTimeout) || connectTimeout < 0)) { + throw new InvalidArgumentError('invalid connectTimeout') + } + + if (keepAliveTimeout != null && (!Number.isFinite(keepAliveTimeout) || keepAliveTimeout <= 0)) { + throw new InvalidArgumentError('invalid keepAliveTimeout') + } + + if (keepAliveMaxTimeout != null && (!Number.isFinite(keepAliveMaxTimeout) || keepAliveMaxTimeout <= 0)) { + throw new InvalidArgumentError('invalid keepAliveMaxTimeout') + } + + if (keepAliveTimeoutThreshold != null && !Number.isFinite(keepAliveTimeoutThreshold)) { + throw new InvalidArgumentError('invalid keepAliveTimeoutThreshold') + } + + if (headersTimeout != null && (!Number.isInteger(headersTimeout) || headersTimeout < 0)) { + throw new InvalidArgumentError('headersTimeout must be a positive integer or zero') + } + + if (bodyTimeout != null && (!Number.isInteger(bodyTimeout) || bodyTimeout < 0)) { + throw new InvalidArgumentError('bodyTimeout must be a positive integer or zero') + } + + if (connect != null && typeof connect !== 'function' && typeof connect !== 'object') { + throw new InvalidArgumentError('connect must be a function or an object') + } + + if (maxRedirections != null && (!Number.isInteger(maxRedirections) || maxRedirections < 0)) { + throw new InvalidArgumentError('maxRedirections must be a positive number') + } + + if (maxRequestsPerClient != null && (!Number.isInteger(maxRequestsPerClient) || maxRequestsPerClient < 0)) { + throw new InvalidArgumentError('maxRequestsPerClient must be a positive number') + } + + if (localAddress != null && (typeof localAddress !== 'string' || net.isIP(localAddress) === 0)) { + throw new InvalidArgumentError('localAddress must be valid string IP address') + } + + if (maxResponseSize != null && (!Number.isInteger(maxResponseSize) || maxResponseSize < -1)) { + throw new InvalidArgumentError('maxResponseSize must be a positive number') + } + + if ( + autoSelectFamilyAttemptTimeout != null && + (!Number.isInteger(autoSelectFamilyAttemptTimeout) || autoSelectFamilyAttemptTimeout < -1) + ) { + throw new InvalidArgumentError('autoSelectFamilyAttemptTimeout must be a positive number') + } + + // h2 + if (allowH2 != null && typeof allowH2 !== 'boolean') { + throw new InvalidArgumentError('allowH2 must be a valid boolean value') + } + + if (maxConcurrentStreams != null && (typeof maxConcurrentStreams !== 'number' || maxConcurrentStreams < 1)) { + throw new InvalidArgumentError('maxConcurrentStreams must be a possitive integer, greater than 0') + } + + if (typeof connect !== 'function') { + connect = buildConnector({ + ...tls, + maxCachedSessions, + allowH2, + socketPath, + timeout: connectTimeout, + ...(util.nodeHasAutoSelectFamily && autoSelectFamily ? { autoSelectFamily, autoSelectFamilyAttemptTimeout } : undefined), + ...connect + }) + } + + this[kInterceptors] = interceptors && interceptors.Client && Array.isArray(interceptors.Client) + ? interceptors.Client + : [createRedirectInterceptor({ maxRedirections })] + this[kUrl] = util.parseOrigin(url) + this[kConnector] = connect + this[kSocket] = null + this[kPipelining] = pipelining != null ? pipelining : 1 + this[kMaxHeadersSize] = maxHeaderSize || http.maxHeaderSize + this[kKeepAliveDefaultTimeout] = keepAliveTimeout == null ? 4e3 : keepAliveTimeout + this[kKeepAliveMaxTimeout] = keepAliveMaxTimeout == null ? 600e3 : keepAliveMaxTimeout + this[kKeepAliveTimeoutThreshold] = keepAliveTimeoutThreshold == null ? 1e3 : keepAliveTimeoutThreshold + this[kKeepAliveTimeoutValue] = this[kKeepAliveDefaultTimeout] + this[kServerName] = null + this[kLocalAddress] = localAddress != null ? localAddress : null + this[kResuming] = 0 // 0, idle, 1, scheduled, 2 resuming + this[kNeedDrain] = 0 // 0, idle, 1, scheduled, 2 resuming + this[kHostHeader] = `host: ${this[kUrl].hostname}${this[kUrl].port ? `:${this[kUrl].port}` : ''}\r\n` + this[kBodyTimeout] = bodyTimeout != null ? bodyTimeout : 300e3 + this[kHeadersTimeout] = headersTimeout != null ? headersTimeout : 300e3 + this[kStrictContentLength] = strictContentLength == null ? true : strictContentLength + this[kMaxRedirections] = maxRedirections + this[kMaxRequests] = maxRequestsPerClient + this[kClosedResolve] = null + this[kMaxResponseSize] = maxResponseSize > -1 ? maxResponseSize : -1 + this[kHTTPConnVersion] = 'h1' + + // HTTP/2 + this[kHTTP2Session] = null + this[kHTTP2SessionState] = !allowH2 + ? null + : { + // streams: null, // Fixed queue of streams - For future support of `push` + openStreams: 0, // Keep track of them to decide wether or not unref the session + maxConcurrentStreams: maxConcurrentStreams != null ? maxConcurrentStreams : 100 // Max peerConcurrentStreams for a Node h2 server + } + this[kHost] = `${this[kUrl].hostname}${this[kUrl].port ? `:${this[kUrl].port}` : ''}` + + // kQueue is built up of 3 sections separated by + // the kRunningIdx and kPendingIdx indices. + // | complete | running | pending | + // ^ kRunningIdx ^ kPendingIdx ^ kQueue.length + // kRunningIdx points to the first running element. + // kPendingIdx points to the first pending element. + // This implements a fast queue with an amortized + // time of O(1). + + this[kQueue] = [] + this[kRunningIdx] = 0 + this[kPendingIdx] = 0 + } + + get pipelining () { + return this[kPipelining] + } + + set pipelining (value) { + this[kPipelining] = value + resume(this, true) + } + + get [kPending] () { + return this[kQueue].length - this[kPendingIdx] + } + + get [kRunning] () { + return this[kPendingIdx] - this[kRunningIdx] + } + + get [kSize] () { + return this[kQueue].length - this[kRunningIdx] + } + + get [kConnected] () { + return !!this[kSocket] && !this[kConnecting] && !this[kSocket].destroyed + } + + get [kBusy] () { + const socket = this[kSocket] + return ( + (socket && (socket[kReset] || socket[kWriting] || socket[kBlocking])) || + (this[kSize] >= (this[kPipelining] || 1)) || + this[kPending] > 0 + ) + } + + /* istanbul ignore: only used for test */ + [kConnect] (cb) { + connect(this) + this.once('connect', cb) + } + + [kDispatch] (opts, handler) { + const origin = opts.origin || this[kUrl].origin + + const request = this[kHTTPConnVersion] === 'h2' + ? Request[kHTTP2BuildRequest](origin, opts, handler) + : Request[kHTTP1BuildRequest](origin, opts, handler) + + this[kQueue].push(request) + if (this[kResuming]) { + // Do nothing. + } else if (util.bodyLength(request.body) == null && util.isIterable(request.body)) { + // Wait a tick in case stream/iterator is ended in the same tick. + this[kResuming] = 1 + process.nextTick(resume, this) + } else { + resume(this, true) + } + + if (this[kResuming] && this[kNeedDrain] !== 2 && this[kBusy]) { + this[kNeedDrain] = 2 + } + + return this[kNeedDrain] < 2 + } + + async [kClose] () { + // TODO: for H2 we need to gracefully flush the remaining enqueued + // request and close each stream. + return new Promise((resolve) => { + if (!this[kSize]) { + resolve(null) + } else { + this[kClosedResolve] = resolve + } + }) + } + + async [kDestroy] (err) { + return new Promise((resolve) => { + const requests = this[kQueue].splice(this[kPendingIdx]) + for (let i = 0; i < requests.length; i++) { + const request = requests[i] + errorRequest(this, request, err) + } + + const callback = () => { + if (this[kClosedResolve]) { + // TODO (fix): Should we error here with ClientDestroyedError? + this[kClosedResolve]() + this[kClosedResolve] = null + } + resolve() + } + + if (this[kHTTP2Session] != null) { + util.destroy(this[kHTTP2Session], err) + this[kHTTP2Session] = null + this[kHTTP2SessionState] = null + } + + if (!this[kSocket]) { + queueMicrotask(callback) + } else { + util.destroy(this[kSocket].on('close', callback), err) + } + + resume(this) + }) + } +} + +function onHttp2SessionError (err) { + assert(err.code !== 'ERR_TLS_CERT_ALTNAME_INVALID') + + this[kSocket][kError] = err + + onError(this[kClient], err) +} + +function onHttp2FrameError (type, code, id) { + const err = new InformationalError(`HTTP/2: "frameError" received - type ${type}, code ${code}`) + + if (id === 0) { + this[kSocket][kError] = err + onError(this[kClient], err) + } +} + +function onHttp2SessionEnd () { + util.destroy(this, new SocketError('other side closed')) + util.destroy(this[kSocket], new SocketError('other side closed')) +} + +function onHTTP2GoAway (code) { + const client = this[kClient] + const err = new InformationalError(`HTTP/2: "GOAWAY" frame received with code ${code}`) + client[kSocket] = null + client[kHTTP2Session] = null + + if (client.destroyed) { + assert(this[kPending] === 0) + + // Fail entire queue. + const requests = client[kQueue].splice(client[kRunningIdx]) + for (let i = 0; i < requests.length; i++) { + const request = requests[i] + errorRequest(this, request, err) + } + } else if (client[kRunning] > 0) { + // Fail head of pipeline. + const request = client[kQueue][client[kRunningIdx]] + client[kQueue][client[kRunningIdx]++] = null + + errorRequest(client, request, err) + } + + client[kPendingIdx] = client[kRunningIdx] + + assert(client[kRunning] === 0) + + client.emit('disconnect', + client[kUrl], + [client], + err + ) + + resume(client) +} + +const constants = __nccwpck_require__(2824) +const createRedirectInterceptor = __nccwpck_require__(4415) +const EMPTY_BUF = Buffer.alloc(0) + +async function lazyllhttp () { + const llhttpWasmData = process.env.JEST_WORKER_ID ? __nccwpck_require__(3870) : undefined + + let mod + try { + mod = await WebAssembly.compile(Buffer.from(__nccwpck_require__(3434), 'base64')) + } catch (e) { + /* istanbul ignore next */ + + // We could check if the error was caused by the simd option not + // being enabled, but the occurring of this other error + // * https://github.com/emscripten-core/emscripten/issues/11495 + // got me to remove that check to avoid breaking Node 12. + mod = await WebAssembly.compile(Buffer.from(llhttpWasmData || __nccwpck_require__(3870), 'base64')) + } + + return await WebAssembly.instantiate(mod, { + env: { + /* eslint-disable camelcase */ + + wasm_on_url: (p, at, len) => { + /* istanbul ignore next */ + return 0 + }, + wasm_on_status: (p, at, len) => { + assert.strictEqual(currentParser.ptr, p) + const start = at - currentBufferPtr + currentBufferRef.byteOffset + return currentParser.onStatus(new FastBuffer(currentBufferRef.buffer, start, len)) || 0 + }, + wasm_on_message_begin: (p) => { + assert.strictEqual(currentParser.ptr, p) + return currentParser.onMessageBegin() || 0 + }, + wasm_on_header_field: (p, at, len) => { + assert.strictEqual(currentParser.ptr, p) + const start = at - currentBufferPtr + currentBufferRef.byteOffset + return currentParser.onHeaderField(new FastBuffer(currentBufferRef.buffer, start, len)) || 0 + }, + wasm_on_header_value: (p, at, len) => { + assert.strictEqual(currentParser.ptr, p) + const start = at - currentBufferPtr + currentBufferRef.byteOffset + return currentParser.onHeaderValue(new FastBuffer(currentBufferRef.buffer, start, len)) || 0 + }, + wasm_on_headers_complete: (p, statusCode, upgrade, shouldKeepAlive) => { + assert.strictEqual(currentParser.ptr, p) + return currentParser.onHeadersComplete(statusCode, Boolean(upgrade), Boolean(shouldKeepAlive)) || 0 + }, + wasm_on_body: (p, at, len) => { + assert.strictEqual(currentParser.ptr, p) + const start = at - currentBufferPtr + currentBufferRef.byteOffset + return currentParser.onBody(new FastBuffer(currentBufferRef.buffer, start, len)) || 0 + }, + wasm_on_message_complete: (p) => { + assert.strictEqual(currentParser.ptr, p) + return currentParser.onMessageComplete() || 0 + } + + /* eslint-enable camelcase */ + } + }) +} + +let llhttpInstance = null +let llhttpPromise = lazyllhttp() +llhttpPromise.catch() + +let currentParser = null +let currentBufferRef = null +let currentBufferSize = 0 +let currentBufferPtr = null + +const TIMEOUT_HEADERS = 1 +const TIMEOUT_BODY = 2 +const TIMEOUT_IDLE = 3 + +class Parser { + constructor (client, socket, { exports }) { + assert(Number.isFinite(client[kMaxHeadersSize]) && client[kMaxHeadersSize] > 0) + + this.llhttp = exports + this.ptr = this.llhttp.llhttp_alloc(constants.TYPE.RESPONSE) + this.client = client + this.socket = socket + this.timeout = null + this.timeoutValue = null + this.timeoutType = null + this.statusCode = null + this.statusText = '' + this.upgrade = false + this.headers = [] + this.headersSize = 0 + this.headersMaxSize = client[kMaxHeadersSize] + this.shouldKeepAlive = false + this.paused = false + this.resume = this.resume.bind(this) + + this.bytesRead = 0 + + this.keepAlive = '' + this.contentLength = '' + this.connection = '' + this.maxResponseSize = client[kMaxResponseSize] + } + + setTimeout (value, type) { + this.timeoutType = type + if (value !== this.timeoutValue) { + timers.clearTimeout(this.timeout) + if (value) { + this.timeout = timers.setTimeout(onParserTimeout, value, this) + // istanbul ignore else: only for jest + if (this.timeout.unref) { + this.timeout.unref() + } + } else { + this.timeout = null + } + this.timeoutValue = value + } else if (this.timeout) { + // istanbul ignore else: only for jest + if (this.timeout.refresh) { + this.timeout.refresh() + } + } + } + + resume () { + if (this.socket.destroyed || !this.paused) { + return + } + + assert(this.ptr != null) + assert(currentParser == null) + + this.llhttp.llhttp_resume(this.ptr) + + assert(this.timeoutType === TIMEOUT_BODY) + if (this.timeout) { + // istanbul ignore else: only for jest + if (this.timeout.refresh) { + this.timeout.refresh() + } + } + + this.paused = false + this.execute(this.socket.read() || EMPTY_BUF) // Flush parser. + this.readMore() + } + + readMore () { + while (!this.paused && this.ptr) { + const chunk = this.socket.read() + if (chunk === null) { + break + } + this.execute(chunk) + } + } + + execute (data) { + assert(this.ptr != null) + assert(currentParser == null) + assert(!this.paused) + + const { socket, llhttp } = this + + if (data.length > currentBufferSize) { + if (currentBufferPtr) { + llhttp.free(currentBufferPtr) + } + currentBufferSize = Math.ceil(data.length / 4096) * 4096 + currentBufferPtr = llhttp.malloc(currentBufferSize) + } + + new Uint8Array(llhttp.memory.buffer, currentBufferPtr, currentBufferSize).set(data) + + // Call `execute` on the wasm parser. + // We pass the `llhttp_parser` pointer address, the pointer address of buffer view data, + // and finally the length of bytes to parse. + // The return value is an error code or `constants.ERROR.OK`. + try { + let ret + + try { + currentBufferRef = data + currentParser = this + ret = llhttp.llhttp_execute(this.ptr, currentBufferPtr, data.length) + /* eslint-disable-next-line no-useless-catch */ + } catch (err) { + /* istanbul ignore next: difficult to make a test case for */ + throw err + } finally { + currentParser = null + currentBufferRef = null + } + + const offset = llhttp.llhttp_get_error_pos(this.ptr) - currentBufferPtr + + if (ret === constants.ERROR.PAUSED_UPGRADE) { + this.onUpgrade(data.slice(offset)) + } else if (ret === constants.ERROR.PAUSED) { + this.paused = true + socket.unshift(data.slice(offset)) + } else if (ret !== constants.ERROR.OK) { + const ptr = llhttp.llhttp_get_error_reason(this.ptr) + let message = '' + /* istanbul ignore else: difficult to make a test case for */ + if (ptr) { + const len = new Uint8Array(llhttp.memory.buffer, ptr).indexOf(0) + message = + 'Response does not match the HTTP/1.1 protocol (' + + Buffer.from(llhttp.memory.buffer, ptr, len).toString() + + ')' + } + throw new HTTPParserError(message, constants.ERROR[ret], data.slice(offset)) + } + } catch (err) { + util.destroy(socket, err) + } + } + + destroy () { + assert(this.ptr != null) + assert(currentParser == null) + + this.llhttp.llhttp_free(this.ptr) + this.ptr = null + + timers.clearTimeout(this.timeout) + this.timeout = null + this.timeoutValue = null + this.timeoutType = null + + this.paused = false + } + + onStatus (buf) { + this.statusText = buf.toString() + } + + onMessageBegin () { + const { socket, client } = this + + /* istanbul ignore next: difficult to make a test case for */ + if (socket.destroyed) { + return -1 + } + + const request = client[kQueue][client[kRunningIdx]] + if (!request) { + return -1 + } + } + + onHeaderField (buf) { + const len = this.headers.length + + if ((len & 1) === 0) { + this.headers.push(buf) + } else { + this.headers[len - 1] = Buffer.concat([this.headers[len - 1], buf]) + } + + this.trackHeader(buf.length) + } + + onHeaderValue (buf) { + let len = this.headers.length + + if ((len & 1) === 1) { + this.headers.push(buf) + len += 1 + } else { + this.headers[len - 1] = Buffer.concat([this.headers[len - 1], buf]) + } + + const key = this.headers[len - 2] + if (key.length === 10 && key.toString().toLowerCase() === 'keep-alive') { + this.keepAlive += buf.toString() + } else if (key.length === 10 && key.toString().toLowerCase() === 'connection') { + this.connection += buf.toString() + } else if (key.length === 14 && key.toString().toLowerCase() === 'content-length') { + this.contentLength += buf.toString() + } + + this.trackHeader(buf.length) + } + + trackHeader (len) { + this.headersSize += len + if (this.headersSize >= this.headersMaxSize) { + util.destroy(this.socket, new HeadersOverflowError()) + } + } + + onUpgrade (head) { + const { upgrade, client, socket, headers, statusCode } = this + + assert(upgrade) + + const request = client[kQueue][client[kRunningIdx]] + assert(request) + + assert(!socket.destroyed) + assert(socket === client[kSocket]) + assert(!this.paused) + assert(request.upgrade || request.method === 'CONNECT') + + this.statusCode = null + this.statusText = '' + this.shouldKeepAlive = null + + assert(this.headers.length % 2 === 0) + this.headers = [] + this.headersSize = 0 + + socket.unshift(head) + + socket[kParser].destroy() + socket[kParser] = null + + socket[kClient] = null + socket[kError] = null + socket + .removeListener('error', onSocketError) + .removeListener('readable', onSocketReadable) + .removeListener('end', onSocketEnd) + .removeListener('close', onSocketClose) + + client[kSocket] = null + client[kQueue][client[kRunningIdx]++] = null + client.emit('disconnect', client[kUrl], [client], new InformationalError('upgrade')) + + try { + request.onUpgrade(statusCode, headers, socket) + } catch (err) { + util.destroy(socket, err) + } + + resume(client) + } + + onHeadersComplete (statusCode, upgrade, shouldKeepAlive) { + const { client, socket, headers, statusText } = this + + /* istanbul ignore next: difficult to make a test case for */ + if (socket.destroyed) { + return -1 + } + + const request = client[kQueue][client[kRunningIdx]] + + /* istanbul ignore next: difficult to make a test case for */ + if (!request) { + return -1 + } + + assert(!this.upgrade) + assert(this.statusCode < 200) + + if (statusCode === 100) { + util.destroy(socket, new SocketError('bad response', util.getSocketInfo(socket))) + return -1 + } + + /* this can only happen if server is misbehaving */ + if (upgrade && !request.upgrade) { + util.destroy(socket, new SocketError('bad upgrade', util.getSocketInfo(socket))) + return -1 + } + + assert.strictEqual(this.timeoutType, TIMEOUT_HEADERS) + + this.statusCode = statusCode + this.shouldKeepAlive = ( + shouldKeepAlive || + // Override llhttp value which does not allow keepAlive for HEAD. + (request.method === 'HEAD' && !socket[kReset] && this.connection.toLowerCase() === 'keep-alive') + ) + + if (this.statusCode >= 200) { + const bodyTimeout = request.bodyTimeout != null + ? request.bodyTimeout + : client[kBodyTimeout] + this.setTimeout(bodyTimeout, TIMEOUT_BODY) + } else if (this.timeout) { + // istanbul ignore else: only for jest + if (this.timeout.refresh) { + this.timeout.refresh() + } + } + + if (request.method === 'CONNECT') { + assert(client[kRunning] === 1) + this.upgrade = true + return 2 + } + + if (upgrade) { + assert(client[kRunning] === 1) + this.upgrade = true + return 2 + } + + assert(this.headers.length % 2 === 0) + this.headers = [] + this.headersSize = 0 + + if (this.shouldKeepAlive && client[kPipelining]) { + const keepAliveTimeout = this.keepAlive ? util.parseKeepAliveTimeout(this.keepAlive) : null + + if (keepAliveTimeout != null) { + const timeout = Math.min( + keepAliveTimeout - client[kKeepAliveTimeoutThreshold], + client[kKeepAliveMaxTimeout] + ) + if (timeout <= 0) { + socket[kReset] = true + } else { + client[kKeepAliveTimeoutValue] = timeout + } + } else { + client[kKeepAliveTimeoutValue] = client[kKeepAliveDefaultTimeout] + } + } else { + // Stop more requests from being dispatched. + socket[kReset] = true + } + + const pause = request.onHeaders(statusCode, headers, this.resume, statusText) === false + + if (request.aborted) { + return -1 + } + + if (request.method === 'HEAD') { + return 1 + } + + if (statusCode < 200) { + return 1 + } + + if (socket[kBlocking]) { + socket[kBlocking] = false + resume(client) + } + + return pause ? constants.ERROR.PAUSED : 0 + } + + onBody (buf) { + const { client, socket, statusCode, maxResponseSize } = this + + if (socket.destroyed) { + return -1 + } + + const request = client[kQueue][client[kRunningIdx]] + assert(request) + + assert.strictEqual(this.timeoutType, TIMEOUT_BODY) + if (this.timeout) { + // istanbul ignore else: only for jest + if (this.timeout.refresh) { + this.timeout.refresh() + } + } + + assert(statusCode >= 200) + + if (maxResponseSize > -1 && this.bytesRead + buf.length > maxResponseSize) { + util.destroy(socket, new ResponseExceededMaxSizeError()) + return -1 + } + + this.bytesRead += buf.length + + if (request.onData(buf) === false) { + return constants.ERROR.PAUSED + } + } + + onMessageComplete () { + const { client, socket, statusCode, upgrade, headers, contentLength, bytesRead, shouldKeepAlive } = this + + if (socket.destroyed && (!statusCode || shouldKeepAlive)) { + return -1 + } + + if (upgrade) { + return + } + + const request = client[kQueue][client[kRunningIdx]] + assert(request) + + assert(statusCode >= 100) + + this.statusCode = null + this.statusText = '' + this.bytesRead = 0 + this.contentLength = '' + this.keepAlive = '' + this.connection = '' + + assert(this.headers.length % 2 === 0) + this.headers = [] + this.headersSize = 0 + + if (statusCode < 200) { + return + } + + /* istanbul ignore next: should be handled by llhttp? */ + if (request.method !== 'HEAD' && contentLength && bytesRead !== parseInt(contentLength, 10)) { + util.destroy(socket, new ResponseContentLengthMismatchError()) + return -1 + } + + request.onComplete(headers) + + client[kQueue][client[kRunningIdx]++] = null + + if (socket[kWriting]) { + assert.strictEqual(client[kRunning], 0) + // Response completed before request. + util.destroy(socket, new InformationalError('reset')) + return constants.ERROR.PAUSED + } else if (!shouldKeepAlive) { + util.destroy(socket, new InformationalError('reset')) + return constants.ERROR.PAUSED + } else if (socket[kReset] && client[kRunning] === 0) { + // Destroy socket once all requests have completed. + // The request at the tail of the pipeline is the one + // that requested reset and no further requests should + // have been queued since then. + util.destroy(socket, new InformationalError('reset')) + return constants.ERROR.PAUSED + } else if (client[kPipelining] === 1) { + // We must wait a full event loop cycle to reuse this socket to make sure + // that non-spec compliant servers are not closing the connection even if they + // said they won't. + setImmediate(resume, client) + } else { + resume(client) + } + } +} + +function onParserTimeout (parser) { + const { socket, timeoutType, client } = parser + + /* istanbul ignore else */ + if (timeoutType === TIMEOUT_HEADERS) { + if (!socket[kWriting] || socket.writableNeedDrain || client[kRunning] > 1) { + assert(!parser.paused, 'cannot be paused while waiting for headers') + util.destroy(socket, new HeadersTimeoutError()) + } + } else if (timeoutType === TIMEOUT_BODY) { + if (!parser.paused) { + util.destroy(socket, new BodyTimeoutError()) + } + } else if (timeoutType === TIMEOUT_IDLE) { + assert(client[kRunning] === 0 && client[kKeepAliveTimeoutValue]) + util.destroy(socket, new InformationalError('socket idle timeout')) + } +} + +function onSocketReadable () { + const { [kParser]: parser } = this + if (parser) { + parser.readMore() + } +} + +function onSocketError (err) { + const { [kClient]: client, [kParser]: parser } = this + + assert(err.code !== 'ERR_TLS_CERT_ALTNAME_INVALID') + + if (client[kHTTPConnVersion] !== 'h2') { + // On Mac OS, we get an ECONNRESET even if there is a full body to be forwarded + // to the user. + if (err.code === 'ECONNRESET' && parser.statusCode && !parser.shouldKeepAlive) { + // We treat all incoming data so for as a valid response. + parser.onMessageComplete() + return + } + } + + this[kError] = err + + onError(this[kClient], err) +} + +function onError (client, err) { + if ( + client[kRunning] === 0 && + err.code !== 'UND_ERR_INFO' && + err.code !== 'UND_ERR_SOCKET' + ) { + // Error is not caused by running request and not a recoverable + // socket error. + + assert(client[kPendingIdx] === client[kRunningIdx]) + + const requests = client[kQueue].splice(client[kRunningIdx]) + for (let i = 0; i < requests.length; i++) { + const request = requests[i] + errorRequest(client, request, err) + } + assert(client[kSize] === 0) + } +} + +function onSocketEnd () { + const { [kParser]: parser, [kClient]: client } = this + + if (client[kHTTPConnVersion] !== 'h2') { + if (parser.statusCode && !parser.shouldKeepAlive) { + // We treat all incoming data so far as a valid response. + parser.onMessageComplete() + return + } + } + + util.destroy(this, new SocketError('other side closed', util.getSocketInfo(this))) +} + +function onSocketClose () { + const { [kClient]: client, [kParser]: parser } = this + + if (client[kHTTPConnVersion] === 'h1' && parser) { + if (!this[kError] && parser.statusCode && !parser.shouldKeepAlive) { + // We treat all incoming data so far as a valid response. + parser.onMessageComplete() + } + + this[kParser].destroy() + this[kParser] = null + } + + const err = this[kError] || new SocketError('closed', util.getSocketInfo(this)) + + client[kSocket] = null + + if (client.destroyed) { + assert(client[kPending] === 0) + + // Fail entire queue. + const requests = client[kQueue].splice(client[kRunningIdx]) + for (let i = 0; i < requests.length; i++) { + const request = requests[i] + errorRequest(client, request, err) + } + } else if (client[kRunning] > 0 && err.code !== 'UND_ERR_INFO') { + // Fail head of pipeline. + const request = client[kQueue][client[kRunningIdx]] + client[kQueue][client[kRunningIdx]++] = null + + errorRequest(client, request, err) + } + + client[kPendingIdx] = client[kRunningIdx] + + assert(client[kRunning] === 0) + + client.emit('disconnect', client[kUrl], [client], err) + + resume(client) +} + +async function connect (client) { + assert(!client[kConnecting]) + assert(!client[kSocket]) + + let { host, hostname, protocol, port } = client[kUrl] + + // Resolve ipv6 + if (hostname[0] === '[') { + const idx = hostname.indexOf(']') + + assert(idx !== -1) + const ip = hostname.substring(1, idx) + + assert(net.isIP(ip)) + hostname = ip + } + + client[kConnecting] = true + + if (channels.beforeConnect.hasSubscribers) { + channels.beforeConnect.publish({ + connectParams: { + host, + hostname, + protocol, + port, + servername: client[kServerName], + localAddress: client[kLocalAddress] + }, + connector: client[kConnector] + }) + } + + try { + const socket = await new Promise((resolve, reject) => { + client[kConnector]({ + host, + hostname, + protocol, + port, + servername: client[kServerName], + localAddress: client[kLocalAddress] + }, (err, socket) => { + if (err) { + reject(err) + } else { + resolve(socket) + } + }) + }) + + if (client.destroyed) { + util.destroy(socket.on('error', () => {}), new ClientDestroyedError()) + return + } + + client[kConnecting] = false + + assert(socket) + + const isH2 = socket.alpnProtocol === 'h2' + if (isH2) { + if (!h2ExperimentalWarned) { + h2ExperimentalWarned = true + process.emitWarning('H2 support is experimental, expect them to change at any time.', { + code: 'UNDICI-H2' + }) + } + + const session = http2.connect(client[kUrl], { + createConnection: () => socket, + peerMaxConcurrentStreams: client[kHTTP2SessionState].maxConcurrentStreams + }) + + client[kHTTPConnVersion] = 'h2' + session[kClient] = client + session[kSocket] = socket + session.on('error', onHttp2SessionError) + session.on('frameError', onHttp2FrameError) + session.on('end', onHttp2SessionEnd) + session.on('goaway', onHTTP2GoAway) + session.on('close', onSocketClose) + session.unref() + + client[kHTTP2Session] = session + socket[kHTTP2Session] = session + } else { + if (!llhttpInstance) { + llhttpInstance = await llhttpPromise + llhttpPromise = null + } + + socket[kNoRef] = false + socket[kWriting] = false + socket[kReset] = false + socket[kBlocking] = false + socket[kParser] = new Parser(client, socket, llhttpInstance) + } + + socket[kCounter] = 0 + socket[kMaxRequests] = client[kMaxRequests] + socket[kClient] = client + socket[kError] = null + + socket + .on('error', onSocketError) + .on('readable', onSocketReadable) + .on('end', onSocketEnd) + .on('close', onSocketClose) + + client[kSocket] = socket + + if (channels.connected.hasSubscribers) { + channels.connected.publish({ + connectParams: { + host, + hostname, + protocol, + port, + servername: client[kServerName], + localAddress: client[kLocalAddress] + }, + connector: client[kConnector], + socket + }) + } + client.emit('connect', client[kUrl], [client]) + } catch (err) { + if (client.destroyed) { + return + } + + client[kConnecting] = false + + if (channels.connectError.hasSubscribers) { + channels.connectError.publish({ + connectParams: { + host, + hostname, + protocol, + port, + servername: client[kServerName], + localAddress: client[kLocalAddress] + }, + connector: client[kConnector], + error: err + }) + } + + if (err.code === 'ERR_TLS_CERT_ALTNAME_INVALID') { + assert(client[kRunning] === 0) + while (client[kPending] > 0 && client[kQueue][client[kPendingIdx]].servername === client[kServerName]) { + const request = client[kQueue][client[kPendingIdx]++] + errorRequest(client, request, err) + } + } else { + onError(client, err) + } + + client.emit('connectionError', client[kUrl], [client], err) + } + + resume(client) +} + +function emitDrain (client) { + client[kNeedDrain] = 0 + client.emit('drain', client[kUrl], [client]) +} + +function resume (client, sync) { + if (client[kResuming] === 2) { + return + } + + client[kResuming] = 2 + + _resume(client, sync) + client[kResuming] = 0 + + if (client[kRunningIdx] > 256) { + client[kQueue].splice(0, client[kRunningIdx]) + client[kPendingIdx] -= client[kRunningIdx] + client[kRunningIdx] = 0 + } +} + +function _resume (client, sync) { + while (true) { + if (client.destroyed) { + assert(client[kPending] === 0) + return + } + + if (client[kClosedResolve] && !client[kSize]) { + client[kClosedResolve]() + client[kClosedResolve] = null + return + } + + const socket = client[kSocket] + + if (socket && !socket.destroyed && socket.alpnProtocol !== 'h2') { + if (client[kSize] === 0) { + if (!socket[kNoRef] && socket.unref) { + socket.unref() + socket[kNoRef] = true + } + } else if (socket[kNoRef] && socket.ref) { + socket.ref() + socket[kNoRef] = false + } + + if (client[kSize] === 0) { + if (socket[kParser].timeoutType !== TIMEOUT_IDLE) { + socket[kParser].setTimeout(client[kKeepAliveTimeoutValue], TIMEOUT_IDLE) + } + } else if (client[kRunning] > 0 && socket[kParser].statusCode < 200) { + if (socket[kParser].timeoutType !== TIMEOUT_HEADERS) { + const request = client[kQueue][client[kRunningIdx]] + const headersTimeout = request.headersTimeout != null + ? request.headersTimeout + : client[kHeadersTimeout] + socket[kParser].setTimeout(headersTimeout, TIMEOUT_HEADERS) + } + } + } + + if (client[kBusy]) { + client[kNeedDrain] = 2 + } else if (client[kNeedDrain] === 2) { + if (sync) { + client[kNeedDrain] = 1 + process.nextTick(emitDrain, client) + } else { + emitDrain(client) + } + continue + } + + if (client[kPending] === 0) { + return + } + + if (client[kRunning] >= (client[kPipelining] || 1)) { + return + } + + const request = client[kQueue][client[kPendingIdx]] + + if (client[kUrl].protocol === 'https:' && client[kServerName] !== request.servername) { + if (client[kRunning] > 0) { + return + } + + client[kServerName] = request.servername + + if (socket && socket.servername !== request.servername) { + util.destroy(socket, new InformationalError('servername changed')) + return + } + } + + if (client[kConnecting]) { + return + } + + if (!socket && !client[kHTTP2Session]) { + connect(client) + return + } + + if (socket.destroyed || socket[kWriting] || socket[kReset] || socket[kBlocking]) { + return + } + + if (client[kRunning] > 0 && !request.idempotent) { + // Non-idempotent request cannot be retried. + // Ensure that no other requests are inflight and + // could cause failure. + return + } + + if (client[kRunning] > 0 && (request.upgrade || request.method === 'CONNECT')) { + // Don't dispatch an upgrade until all preceding requests have completed. + // A misbehaving server might upgrade the connection before all pipelined + // request has completed. + return + } + + if (client[kRunning] > 0 && util.bodyLength(request.body) !== 0 && + (util.isStream(request.body) || util.isAsyncIterable(request.body))) { + // Request with stream or iterator body can error while other requests + // are inflight and indirectly error those as well. + // Ensure this doesn't happen by waiting for inflight + // to complete before dispatching. + + // Request with stream or iterator body cannot be retried. + // Ensure that no other requests are inflight and + // could cause failure. + return + } + + if (!request.aborted && write(client, request)) { + client[kPendingIdx]++ + } else { + client[kQueue].splice(client[kPendingIdx], 1) + } + } +} + +// https://www.rfc-editor.org/rfc/rfc7230#section-3.3.2 +function shouldSendContentLength (method) { + return method !== 'GET' && method !== 'HEAD' && method !== 'OPTIONS' && method !== 'TRACE' && method !== 'CONNECT' +} + +function write (client, request) { + if (client[kHTTPConnVersion] === 'h2') { + writeH2(client, client[kHTTP2Session], request) + return + } + + const { body, method, path, host, upgrade, headers, blocking, reset } = request + + // https://tools.ietf.org/html/rfc7231#section-4.3.1 + // https://tools.ietf.org/html/rfc7231#section-4.3.2 + // https://tools.ietf.org/html/rfc7231#section-4.3.5 + + // Sending a payload body on a request that does not + // expect it can cause undefined behavior on some + // servers and corrupt connection state. Do not + // re-use the connection for further requests. + + const expectsPayload = ( + method === 'PUT' || + method === 'POST' || + method === 'PATCH' + ) + + if (body && typeof body.read === 'function') { + // Try to read EOF in order to get length. + body.read(0) + } + + const bodyLength = util.bodyLength(body) + + let contentLength = bodyLength + + if (contentLength === null) { + contentLength = request.contentLength + } + + if (contentLength === 0 && !expectsPayload) { + // https://tools.ietf.org/html/rfc7230#section-3.3.2 + // A user agent SHOULD NOT send a Content-Length header field when + // the request message does not contain a payload body and the method + // semantics do not anticipate such a body. + + contentLength = null + } + + // https://github.com/nodejs/undici/issues/2046 + // A user agent may send a Content-Length header with 0 value, this should be allowed. + if (shouldSendContentLength(method) && contentLength > 0 && request.contentLength !== null && request.contentLength !== contentLength) { + if (client[kStrictContentLength]) { + errorRequest(client, request, new RequestContentLengthMismatchError()) + return false + } + + process.emitWarning(new RequestContentLengthMismatchError()) + } + + const socket = client[kSocket] + + try { + request.onConnect((err) => { + if (request.aborted || request.completed) { + return + } + + errorRequest(client, request, err || new RequestAbortedError()) + + util.destroy(socket, new InformationalError('aborted')) + }) + } catch (err) { + errorRequest(client, request, err) + } + + if (request.aborted) { + return false + } + + if (method === 'HEAD') { + // https://github.com/mcollina/undici/issues/258 + // Close after a HEAD request to interop with misbehaving servers + // that may send a body in the response. + + socket[kReset] = true + } + + if (upgrade || method === 'CONNECT') { + // On CONNECT or upgrade, block pipeline from dispatching further + // requests on this connection. + + socket[kReset] = true + } + + if (reset != null) { + socket[kReset] = reset + } + + if (client[kMaxRequests] && socket[kCounter]++ >= client[kMaxRequests]) { + socket[kReset] = true + } + + if (blocking) { + socket[kBlocking] = true + } + + let header = `${method} ${path} HTTP/1.1\r\n` + + if (typeof host === 'string') { + header += `host: ${host}\r\n` + } else { + header += client[kHostHeader] + } + + if (upgrade) { + header += `connection: upgrade\r\nupgrade: ${upgrade}\r\n` + } else if (client[kPipelining] && !socket[kReset]) { + header += 'connection: keep-alive\r\n' + } else { + header += 'connection: close\r\n' + } + + if (headers) { + header += headers + } + + if (channels.sendHeaders.hasSubscribers) { + channels.sendHeaders.publish({ request, headers: header, socket }) + } + + /* istanbul ignore else: assertion */ + if (!body || bodyLength === 0) { + if (contentLength === 0) { + socket.write(`${header}content-length: 0\r\n\r\n`, 'latin1') + } else { + assert(contentLength === null, 'no body must not have content length') + socket.write(`${header}\r\n`, 'latin1') + } + request.onRequestSent() + } else if (util.isBuffer(body)) { + assert(contentLength === body.byteLength, 'buffer body must have content length') + + socket.cork() + socket.write(`${header}content-length: ${contentLength}\r\n\r\n`, 'latin1') + socket.write(body) + socket.uncork() + request.onBodySent(body) + request.onRequestSent() + if (!expectsPayload) { + socket[kReset] = true + } + } else if (util.isBlobLike(body)) { + if (typeof body.stream === 'function') { + writeIterable({ body: body.stream(), client, request, socket, contentLength, header, expectsPayload }) + } else { + writeBlob({ body, client, request, socket, contentLength, header, expectsPayload }) + } + } else if (util.isStream(body)) { + writeStream({ body, client, request, socket, contentLength, header, expectsPayload }) + } else if (util.isIterable(body)) { + writeIterable({ body, client, request, socket, contentLength, header, expectsPayload }) + } else { + assert(false) + } + + return true +} + +function writeH2 (client, session, request) { + const { body, method, path, host, upgrade, expectContinue, signal, headers: reqHeaders } = request + + let headers + if (typeof reqHeaders === 'string') headers = Request[kHTTP2CopyHeaders](reqHeaders.trim()) + else headers = reqHeaders + + if (upgrade) { + errorRequest(client, request, new Error('Upgrade not supported for H2')) + return false + } + + try { + // TODO(HTTP/2): Should we call onConnect immediately or on stream ready event? + request.onConnect((err) => { + if (request.aborted || request.completed) { + return + } + + errorRequest(client, request, err || new RequestAbortedError()) + }) + } catch (err) { + errorRequest(client, request, err) + } + + if (request.aborted) { + return false + } + + /** @type {import('node:http2').ClientHttp2Stream} */ + let stream + const h2State = client[kHTTP2SessionState] + + headers[HTTP2_HEADER_AUTHORITY] = host || client[kHost] + headers[HTTP2_HEADER_METHOD] = method + + if (method === 'CONNECT') { + session.ref() + // we are already connected, streams are pending, first request + // will create a new stream. We trigger a request to create the stream and wait until + // `ready` event is triggered + // We disabled endStream to allow the user to write to the stream + stream = session.request(headers, { endStream: false, signal }) + + if (stream.id && !stream.pending) { + request.onUpgrade(null, null, stream) + ++h2State.openStreams + } else { + stream.once('ready', () => { + request.onUpgrade(null, null, stream) + ++h2State.openStreams + }) + } + + stream.once('close', () => { + h2State.openStreams -= 1 + // TODO(HTTP/2): unref only if current streams count is 0 + if (h2State.openStreams === 0) session.unref() + }) + + return true + } + + // https://tools.ietf.org/html/rfc7540#section-8.3 + // :path and :scheme headers must be omited when sending CONNECT + + headers[HTTP2_HEADER_PATH] = path + headers[HTTP2_HEADER_SCHEME] = 'https' + + // https://tools.ietf.org/html/rfc7231#section-4.3.1 + // https://tools.ietf.org/html/rfc7231#section-4.3.2 + // https://tools.ietf.org/html/rfc7231#section-4.3.5 + + // Sending a payload body on a request that does not + // expect it can cause undefined behavior on some + // servers and corrupt connection state. Do not + // re-use the connection for further requests. + + const expectsPayload = ( + method === 'PUT' || + method === 'POST' || + method === 'PATCH' + ) + + if (body && typeof body.read === 'function') { + // Try to read EOF in order to get length. + body.read(0) + } + + let contentLength = util.bodyLength(body) + + if (contentLength == null) { + contentLength = request.contentLength + } + + if (contentLength === 0 || !expectsPayload) { + // https://tools.ietf.org/html/rfc7230#section-3.3.2 + // A user agent SHOULD NOT send a Content-Length header field when + // the request message does not contain a payload body and the method + // semantics do not anticipate such a body. + + contentLength = null + } + + // https://github.com/nodejs/undici/issues/2046 + // A user agent may send a Content-Length header with 0 value, this should be allowed. + if (shouldSendContentLength(method) && contentLength > 0 && request.contentLength != null && request.contentLength !== contentLength) { + if (client[kStrictContentLength]) { + errorRequest(client, request, new RequestContentLengthMismatchError()) + return false + } + + process.emitWarning(new RequestContentLengthMismatchError()) + } + + if (contentLength != null) { + assert(body, 'no body must not have content length') + headers[HTTP2_HEADER_CONTENT_LENGTH] = `${contentLength}` + } + + session.ref() + + const shouldEndStream = method === 'GET' || method === 'HEAD' + if (expectContinue) { + headers[HTTP2_HEADER_EXPECT] = '100-continue' + stream = session.request(headers, { endStream: shouldEndStream, signal }) + + stream.once('continue', writeBodyH2) + } else { + stream = session.request(headers, { + endStream: shouldEndStream, + signal + }) + writeBodyH2() + } + + // Increment counter as we have new several streams open + ++h2State.openStreams + + stream.once('response', headers => { + const { [HTTP2_HEADER_STATUS]: statusCode, ...realHeaders } = headers + + if (request.onHeaders(Number(statusCode), realHeaders, stream.resume.bind(stream), '') === false) { + stream.pause() + } + }) + + stream.once('end', () => { + request.onComplete([]) + }) + + stream.on('data', (chunk) => { + if (request.onData(chunk) === false) { + stream.pause() + } + }) + + stream.once('close', () => { + h2State.openStreams -= 1 + // TODO(HTTP/2): unref only if current streams count is 0 + if (h2State.openStreams === 0) { + session.unref() + } + }) + + stream.once('error', function (err) { + if (client[kHTTP2Session] && !client[kHTTP2Session].destroyed && !this.closed && !this.destroyed) { + h2State.streams -= 1 + util.destroy(stream, err) + } + }) + + stream.once('frameError', (type, code) => { + const err = new InformationalError(`HTTP/2: "frameError" received - type ${type}, code ${code}`) + errorRequest(client, request, err) + + if (client[kHTTP2Session] && !client[kHTTP2Session].destroyed && !this.closed && !this.destroyed) { + h2State.streams -= 1 + util.destroy(stream, err) + } + }) + + // stream.on('aborted', () => { + // // TODO(HTTP/2): Support aborted + // }) + + // stream.on('timeout', () => { + // // TODO(HTTP/2): Support timeout + // }) + + // stream.on('push', headers => { + // // TODO(HTTP/2): Suppor push + // }) + + // stream.on('trailers', headers => { + // // TODO(HTTP/2): Support trailers + // }) + + return true + + function writeBodyH2 () { + /* istanbul ignore else: assertion */ + if (!body) { + request.onRequestSent() + } else if (util.isBuffer(body)) { + assert(contentLength === body.byteLength, 'buffer body must have content length') + stream.cork() + stream.write(body) + stream.uncork() + stream.end() + request.onBodySent(body) + request.onRequestSent() + } else if (util.isBlobLike(body)) { + if (typeof body.stream === 'function') { + writeIterable({ + client, + request, + contentLength, + h2stream: stream, + expectsPayload, + body: body.stream(), + socket: client[kSocket], + header: '' + }) + } else { + writeBlob({ + body, + client, + request, + contentLength, + expectsPayload, + h2stream: stream, + header: '', + socket: client[kSocket] + }) + } + } else if (util.isStream(body)) { + writeStream({ + body, + client, + request, + contentLength, + expectsPayload, + socket: client[kSocket], + h2stream: stream, + header: '' + }) + } else if (util.isIterable(body)) { + writeIterable({ + body, + client, + request, + contentLength, + expectsPayload, + header: '', + h2stream: stream, + socket: client[kSocket] + }) + } else { + assert(false) + } + } +} + +function writeStream ({ h2stream, body, client, request, socket, contentLength, header, expectsPayload }) { + assert(contentLength !== 0 || client[kRunning] === 0, 'stream body cannot be pipelined') + + if (client[kHTTPConnVersion] === 'h2') { + // For HTTP/2, is enough to pipe the stream + const pipe = pipeline( + body, + h2stream, + (err) => { + if (err) { + util.destroy(body, err) + util.destroy(h2stream, err) + } else { + request.onRequestSent() + } + } + ) + + pipe.on('data', onPipeData) + pipe.once('end', () => { + pipe.removeListener('data', onPipeData) + util.destroy(pipe) + }) + + function onPipeData (chunk) { + request.onBodySent(chunk) + } + + return + } + + let finished = false + + const writer = new AsyncWriter({ socket, request, contentLength, client, expectsPayload, header }) + + const onData = function (chunk) { + if (finished) { + return + } + + try { + if (!writer.write(chunk) && this.pause) { + this.pause() + } + } catch (err) { + util.destroy(this, err) + } + } + const onDrain = function () { + if (finished) { + return + } + + if (body.resume) { + body.resume() + } + } + const onAbort = function () { + if (finished) { + return + } + const err = new RequestAbortedError() + queueMicrotask(() => onFinished(err)) + } + const onFinished = function (err) { + if (finished) { + return + } + + finished = true + + assert(socket.destroyed || (socket[kWriting] && client[kRunning] <= 1)) + + socket + .off('drain', onDrain) + .off('error', onFinished) + + body + .removeListener('data', onData) + .removeListener('end', onFinished) + .removeListener('error', onFinished) + .removeListener('close', onAbort) + + if (!err) { + try { + writer.end() + } catch (er) { + err = er + } + } + + writer.destroy(err) + + if (err && (err.code !== 'UND_ERR_INFO' || err.message !== 'reset')) { + util.destroy(body, err) + } else { + util.destroy(body) + } + } + + body + .on('data', onData) + .on('end', onFinished) + .on('error', onFinished) + .on('close', onAbort) + + if (body.resume) { + body.resume() + } + + socket + .on('drain', onDrain) + .on('error', onFinished) +} + +async function writeBlob ({ h2stream, body, client, request, socket, contentLength, header, expectsPayload }) { + assert(contentLength === body.size, 'blob body must have content length') + + const isH2 = client[kHTTPConnVersion] === 'h2' + try { + if (contentLength != null && contentLength !== body.size) { + throw new RequestContentLengthMismatchError() + } + + const buffer = Buffer.from(await body.arrayBuffer()) + + if (isH2) { + h2stream.cork() + h2stream.write(buffer) + h2stream.uncork() + } else { + socket.cork() + socket.write(`${header}content-length: ${contentLength}\r\n\r\n`, 'latin1') + socket.write(buffer) + socket.uncork() + } + + request.onBodySent(buffer) + request.onRequestSent() + + if (!expectsPayload) { + socket[kReset] = true + } + + resume(client) + } catch (err) { + util.destroy(isH2 ? h2stream : socket, err) + } +} + +async function writeIterable ({ h2stream, body, client, request, socket, contentLength, header, expectsPayload }) { + assert(contentLength !== 0 || client[kRunning] === 0, 'iterator body cannot be pipelined') + + let callback = null + function onDrain () { + if (callback) { + const cb = callback + callback = null + cb() + } + } + + const waitForDrain = () => new Promise((resolve, reject) => { + assert(callback === null) + + if (socket[kError]) { + reject(socket[kError]) + } else { + callback = resolve + } + }) + + if (client[kHTTPConnVersion] === 'h2') { + h2stream + .on('close', onDrain) + .on('drain', onDrain) + + try { + // It's up to the user to somehow abort the async iterable. + for await (const chunk of body) { + if (socket[kError]) { + throw socket[kError] + } + + const res = h2stream.write(chunk) + request.onBodySent(chunk) + if (!res) { + await waitForDrain() + } + } + } catch (err) { + h2stream.destroy(err) + } finally { + request.onRequestSent() + h2stream.end() + h2stream + .off('close', onDrain) + .off('drain', onDrain) + } + + return + } + + socket + .on('close', onDrain) + .on('drain', onDrain) + + const writer = new AsyncWriter({ socket, request, contentLength, client, expectsPayload, header }) + try { + // It's up to the user to somehow abort the async iterable. + for await (const chunk of body) { + if (socket[kError]) { + throw socket[kError] + } + + if (!writer.write(chunk)) { + await waitForDrain() + } + } + + writer.end() + } catch (err) { + writer.destroy(err) + } finally { + socket + .off('close', onDrain) + .off('drain', onDrain) + } +} + +class AsyncWriter { + constructor ({ socket, request, contentLength, client, expectsPayload, header }) { + this.socket = socket + this.request = request + this.contentLength = contentLength + this.client = client + this.bytesWritten = 0 + this.expectsPayload = expectsPayload + this.header = header + + socket[kWriting] = true + } + + write (chunk) { + const { socket, request, contentLength, client, bytesWritten, expectsPayload, header } = this + + if (socket[kError]) { + throw socket[kError] + } + + if (socket.destroyed) { + return false + } + + const len = Buffer.byteLength(chunk) + if (!len) { + return true + } + + // We should defer writing chunks. + if (contentLength !== null && bytesWritten + len > contentLength) { + if (client[kStrictContentLength]) { + throw new RequestContentLengthMismatchError() + } + + process.emitWarning(new RequestContentLengthMismatchError()) + } + + socket.cork() + + if (bytesWritten === 0) { + if (!expectsPayload) { + socket[kReset] = true + } + + if (contentLength === null) { + socket.write(`${header}transfer-encoding: chunked\r\n`, 'latin1') + } else { + socket.write(`${header}content-length: ${contentLength}\r\n\r\n`, 'latin1') + } + } + + if (contentLength === null) { + socket.write(`\r\n${len.toString(16)}\r\n`, 'latin1') + } + + this.bytesWritten += len + + const ret = socket.write(chunk) + + socket.uncork() + + request.onBodySent(chunk) + + if (!ret) { + if (socket[kParser].timeout && socket[kParser].timeoutType === TIMEOUT_HEADERS) { + // istanbul ignore else: only for jest + if (socket[kParser].timeout.refresh) { + socket[kParser].timeout.refresh() + } + } + } + + return ret + } + + end () { + const { socket, contentLength, client, bytesWritten, expectsPayload, header, request } = this + request.onRequestSent() + + socket[kWriting] = false + + if (socket[kError]) { + throw socket[kError] + } + + if (socket.destroyed) { + return + } + + if (bytesWritten === 0) { + if (expectsPayload) { + // https://tools.ietf.org/html/rfc7230#section-3.3.2 + // A user agent SHOULD send a Content-Length in a request message when + // no Transfer-Encoding is sent and the request method defines a meaning + // for an enclosed payload body. + + socket.write(`${header}content-length: 0\r\n\r\n`, 'latin1') + } else { + socket.write(`${header}\r\n`, 'latin1') + } + } else if (contentLength === null) { + socket.write('\r\n0\r\n\r\n', 'latin1') + } + + if (contentLength !== null && bytesWritten !== contentLength) { + if (client[kStrictContentLength]) { + throw new RequestContentLengthMismatchError() + } else { + process.emitWarning(new RequestContentLengthMismatchError()) + } + } + + if (socket[kParser].timeout && socket[kParser].timeoutType === TIMEOUT_HEADERS) { + // istanbul ignore else: only for jest + if (socket[kParser].timeout.refresh) { + socket[kParser].timeout.refresh() + } + } + + resume(client) + } + + destroy (err) { + const { socket, client } = this + + socket[kWriting] = false + + if (err) { + assert(client[kRunning] <= 1, 'pipeline should only contain this request') + util.destroy(socket, err) + } + } +} + +function errorRequest (client, request, err) { + try { + request.onError(err) + assert(request.aborted) + } catch (err) { + client.emit('error', err) + } +} + +module.exports = Client + + +/***/ }), + +/***/ 3194: +/***/ ((module, __unused_webpack_exports, __nccwpck_require__) => { + + + +/* istanbul ignore file: only for Node 12 */ + +const { kConnected, kSize } = __nccwpck_require__(6443) + +class CompatWeakRef { + constructor (value) { + this.value = value + } + + deref () { + return this.value[kConnected] === 0 && this.value[kSize] === 0 + ? undefined + : this.value + } +} + +class CompatFinalizer { + constructor (finalizer) { + this.finalizer = finalizer + } + + register (dispatcher, key) { + if (dispatcher.on) { + dispatcher.on('disconnect', () => { + if (dispatcher[kConnected] === 0 && dispatcher[kSize] === 0) { + this.finalizer(key) + } + }) + } + } +} + +module.exports = function () { + // FIXME: remove workaround when the Node bug is fixed + // https://github.com/nodejs/node/issues/49344#issuecomment-1741776308 + if (process.env.NODE_V8_COVERAGE) { + return { + WeakRef: CompatWeakRef, + FinalizationRegistry: CompatFinalizer + } + } + return { + WeakRef: global.WeakRef || CompatWeakRef, + FinalizationRegistry: global.FinalizationRegistry || CompatFinalizer + } +} + + +/***/ }), + +/***/ 9237: +/***/ ((module) => { + + + +// https://wicg.github.io/cookie-store/#cookie-maximum-attribute-value-size +const maxAttributeValueSize = 1024 + +// https://wicg.github.io/cookie-store/#cookie-maximum-name-value-pair-size +const maxNameValuePairSize = 4096 + +module.exports = { + maxAttributeValueSize, + maxNameValuePairSize +} + + +/***/ }), + +/***/ 3168: +/***/ ((module, __unused_webpack_exports, __nccwpck_require__) => { + + + +const { parseSetCookie } = __nccwpck_require__(8915) +const { stringify, getHeadersList } = __nccwpck_require__(3834) +const { webidl } = __nccwpck_require__(4222) +const { Headers } = __nccwpck_require__(6349) + +/** + * @typedef {Object} Cookie + * @property {string} name + * @property {string} value + * @property {Date|number|undefined} expires + * @property {number|undefined} maxAge + * @property {string|undefined} domain + * @property {string|undefined} path + * @property {boolean|undefined} secure + * @property {boolean|undefined} httpOnly + * @property {'Strict'|'Lax'|'None'} sameSite + * @property {string[]} unparsed + */ + +/** + * @param {Headers} headers + * @returns {Record} + */ +function getCookies (headers) { + webidl.argumentLengthCheck(arguments, 1, { header: 'getCookies' }) + + webidl.brandCheck(headers, Headers, { strict: false }) + + const cookie = headers.get('cookie') + const out = {} + + if (!cookie) { + return out + } + + for (const piece of cookie.split(';')) { + const [name, ...value] = piece.split('=') + + out[name.trim()] = value.join('=') + } + + return out +} + +/** + * @param {Headers} headers + * @param {string} name + * @param {{ path?: string, domain?: string }|undefined} attributes + * @returns {void} + */ +function deleteCookie (headers, name, attributes) { + webidl.argumentLengthCheck(arguments, 2, { header: 'deleteCookie' }) + + webidl.brandCheck(headers, Headers, { strict: false }) + + name = webidl.converters.DOMString(name) + attributes = webidl.converters.DeleteCookieAttributes(attributes) + + // Matches behavior of + // https://github.com/denoland/deno_std/blob/63827b16330b82489a04614027c33b7904e08be5/http/cookie.ts#L278 + setCookie(headers, { + name, + value: '', + expires: new Date(0), + ...attributes + }) +} + +/** + * @param {Headers} headers + * @returns {Cookie[]} + */ +function getSetCookies (headers) { + webidl.argumentLengthCheck(arguments, 1, { header: 'getSetCookies' }) + + webidl.brandCheck(headers, Headers, { strict: false }) + + const cookies = getHeadersList(headers).cookies + + if (!cookies) { + return [] + } + + // In older versions of undici, cookies is a list of name:value. + return cookies.map((pair) => parseSetCookie(Array.isArray(pair) ? pair[1] : pair)) +} + +/** + * @param {Headers} headers + * @param {Cookie} cookie + * @returns {void} + */ +function setCookie (headers, cookie) { + webidl.argumentLengthCheck(arguments, 2, { header: 'setCookie' }) + + webidl.brandCheck(headers, Headers, { strict: false }) + + cookie = webidl.converters.Cookie(cookie) + + const str = stringify(cookie) + + if (str) { + headers.append('Set-Cookie', stringify(cookie)) + } +} + +webidl.converters.DeleteCookieAttributes = webidl.dictionaryConverter([ + { + converter: webidl.nullableConverter(webidl.converters.DOMString), + key: 'path', + defaultValue: null + }, + { + converter: webidl.nullableConverter(webidl.converters.DOMString), + key: 'domain', + defaultValue: null + } +]) + +webidl.converters.Cookie = webidl.dictionaryConverter([ + { + converter: webidl.converters.DOMString, + key: 'name' + }, + { + converter: webidl.converters.DOMString, + key: 'value' + }, + { + converter: webidl.nullableConverter((value) => { + if (typeof value === 'number') { + return webidl.converters['unsigned long long'](value) + } + + return new Date(value) + }), + key: 'expires', + defaultValue: null + }, + { + converter: webidl.nullableConverter(webidl.converters['long long']), + key: 'maxAge', + defaultValue: null + }, + { + converter: webidl.nullableConverter(webidl.converters.DOMString), + key: 'domain', + defaultValue: null + }, + { + converter: webidl.nullableConverter(webidl.converters.DOMString), + key: 'path', + defaultValue: null + }, + { + converter: webidl.nullableConverter(webidl.converters.boolean), + key: 'secure', + defaultValue: null + }, + { + converter: webidl.nullableConverter(webidl.converters.boolean), + key: 'httpOnly', + defaultValue: null + }, + { + converter: webidl.converters.USVString, + key: 'sameSite', + allowedValues: ['Strict', 'Lax', 'None'] + }, + { + converter: webidl.sequenceConverter(webidl.converters.DOMString), + key: 'unparsed', + defaultValue: [] + } +]) + +module.exports = { + getCookies, + deleteCookie, + getSetCookies, + setCookie +} + + +/***/ }), + +/***/ 8915: +/***/ ((module, __unused_webpack_exports, __nccwpck_require__) => { + + + +const { maxNameValuePairSize, maxAttributeValueSize } = __nccwpck_require__(9237) +const { isCTLExcludingHtab } = __nccwpck_require__(3834) +const { collectASequenceOfCodePointsFast } = __nccwpck_require__(4322) +const assert = __nccwpck_require__(2613) + +/** + * @description Parses the field-value attributes of a set-cookie header string. + * @see https://datatracker.ietf.org/doc/html/draft-ietf-httpbis-rfc6265bis#section-5.4 + * @param {string} header + * @returns if the header is invalid, null will be returned + */ +function parseSetCookie (header) { + // 1. If the set-cookie-string contains a %x00-08 / %x0A-1F / %x7F + // character (CTL characters excluding HTAB): Abort these steps and + // ignore the set-cookie-string entirely. + if (isCTLExcludingHtab(header)) { + return null + } + + let nameValuePair = '' + let unparsedAttributes = '' + let name = '' + let value = '' + + // 2. If the set-cookie-string contains a %x3B (";") character: + if (header.includes(';')) { + // 1. The name-value-pair string consists of the characters up to, + // but not including, the first %x3B (";"), and the unparsed- + // attributes consist of the remainder of the set-cookie-string + // (including the %x3B (";") in question). + const position = { position: 0 } + + nameValuePair = collectASequenceOfCodePointsFast(';', header, position) + unparsedAttributes = header.slice(position.position) + } else { + // Otherwise: + + // 1. The name-value-pair string consists of all the characters + // contained in the set-cookie-string, and the unparsed- + // attributes is the empty string. + nameValuePair = header + } + + // 3. If the name-value-pair string lacks a %x3D ("=") character, then + // the name string is empty, and the value string is the value of + // name-value-pair. + if (!nameValuePair.includes('=')) { + value = nameValuePair + } else { + // Otherwise, the name string consists of the characters up to, but + // not including, the first %x3D ("=") character, and the (possibly + // empty) value string consists of the characters after the first + // %x3D ("=") character. + const position = { position: 0 } + name = collectASequenceOfCodePointsFast( + '=', + nameValuePair, + position + ) + value = nameValuePair.slice(position.position + 1) + } + + // 4. Remove any leading or trailing WSP characters from the name + // string and the value string. + name = name.trim() + value = value.trim() + + // 5. If the sum of the lengths of the name string and the value string + // is more than 4096 octets, abort these steps and ignore the set- + // cookie-string entirely. + if (name.length + value.length > maxNameValuePairSize) { + return null + } + + // 6. The cookie-name is the name string, and the cookie-value is the + // value string. + return { + name, value, ...parseUnparsedAttributes(unparsedAttributes) + } +} + +/** + * Parses the remaining attributes of a set-cookie header + * @see https://datatracker.ietf.org/doc/html/draft-ietf-httpbis-rfc6265bis#section-5.4 + * @param {string} unparsedAttributes + * @param {[Object.]={}} cookieAttributeList + */ +function parseUnparsedAttributes (unparsedAttributes, cookieAttributeList = {}) { + // 1. If the unparsed-attributes string is empty, skip the rest of + // these steps. + if (unparsedAttributes.length === 0) { + return cookieAttributeList + } + + // 2. Discard the first character of the unparsed-attributes (which + // will be a %x3B (";") character). + assert(unparsedAttributes[0] === ';') + unparsedAttributes = unparsedAttributes.slice(1) + + let cookieAv = '' + + // 3. If the remaining unparsed-attributes contains a %x3B (";") + // character: + if (unparsedAttributes.includes(';')) { + // 1. Consume the characters of the unparsed-attributes up to, but + // not including, the first %x3B (";") character. + cookieAv = collectASequenceOfCodePointsFast( + ';', + unparsedAttributes, + { position: 0 } + ) + unparsedAttributes = unparsedAttributes.slice(cookieAv.length) + } else { + // Otherwise: + + // 1. Consume the remainder of the unparsed-attributes. + cookieAv = unparsedAttributes + unparsedAttributes = '' + } + + // Let the cookie-av string be the characters consumed in this step. + + let attributeName = '' + let attributeValue = '' + + // 4. If the cookie-av string contains a %x3D ("=") character: + if (cookieAv.includes('=')) { + // 1. The (possibly empty) attribute-name string consists of the + // characters up to, but not including, the first %x3D ("=") + // character, and the (possibly empty) attribute-value string + // consists of the characters after the first %x3D ("=") + // character. + const position = { position: 0 } + + attributeName = collectASequenceOfCodePointsFast( + '=', + cookieAv, + position + ) + attributeValue = cookieAv.slice(position.position + 1) + } else { + // Otherwise: + + // 1. The attribute-name string consists of the entire cookie-av + // string, and the attribute-value string is empty. + attributeName = cookieAv + } + + // 5. Remove any leading or trailing WSP characters from the attribute- + // name string and the attribute-value string. + attributeName = attributeName.trim() + attributeValue = attributeValue.trim() + + // 6. If the attribute-value is longer than 1024 octets, ignore the + // cookie-av string and return to Step 1 of this algorithm. + if (attributeValue.length > maxAttributeValueSize) { + return parseUnparsedAttributes(unparsedAttributes, cookieAttributeList) + } + + // 7. Process the attribute-name and attribute-value according to the + // requirements in the following subsections. (Notice that + // attributes with unrecognized attribute-names are ignored.) + const attributeNameLowercase = attributeName.toLowerCase() + + // https://datatracker.ietf.org/doc/html/draft-ietf-httpbis-rfc6265bis#section-5.4.1 + // If the attribute-name case-insensitively matches the string + // "Expires", the user agent MUST process the cookie-av as follows. + if (attributeNameLowercase === 'expires') { + // 1. Let the expiry-time be the result of parsing the attribute-value + // as cookie-date (see Section 5.1.1). + const expiryTime = new Date(attributeValue) + + // 2. If the attribute-value failed to parse as a cookie date, ignore + // the cookie-av. + + cookieAttributeList.expires = expiryTime + } else if (attributeNameLowercase === 'max-age') { + // https://datatracker.ietf.org/doc/html/draft-ietf-httpbis-rfc6265bis#section-5.4.2 + // If the attribute-name case-insensitively matches the string "Max- + // Age", the user agent MUST process the cookie-av as follows. + + // 1. If the first character of the attribute-value is not a DIGIT or a + // "-" character, ignore the cookie-av. + const charCode = attributeValue.charCodeAt(0) + + if ((charCode < 48 || charCode > 57) && attributeValue[0] !== '-') { + return parseUnparsedAttributes(unparsedAttributes, cookieAttributeList) + } + + // 2. If the remainder of attribute-value contains a non-DIGIT + // character, ignore the cookie-av. + if (!/^\d+$/.test(attributeValue)) { + return parseUnparsedAttributes(unparsedAttributes, cookieAttributeList) + } + + // 3. Let delta-seconds be the attribute-value converted to an integer. + const deltaSeconds = Number(attributeValue) + + // 4. Let cookie-age-limit be the maximum age of the cookie (which + // SHOULD be 400 days or less, see Section 4.1.2.2). + + // 5. Set delta-seconds to the smaller of its present value and cookie- + // age-limit. + // deltaSeconds = Math.min(deltaSeconds * 1000, maxExpiresMs) + + // 6. If delta-seconds is less than or equal to zero (0), let expiry- + // time be the earliest representable date and time. Otherwise, let + // the expiry-time be the current date and time plus delta-seconds + // seconds. + // const expiryTime = deltaSeconds <= 0 ? Date.now() : Date.now() + deltaSeconds + + // 7. Append an attribute to the cookie-attribute-list with an + // attribute-name of Max-Age and an attribute-value of expiry-time. + cookieAttributeList.maxAge = deltaSeconds + } else if (attributeNameLowercase === 'domain') { + // https://datatracker.ietf.org/doc/html/draft-ietf-httpbis-rfc6265bis#section-5.4.3 + // If the attribute-name case-insensitively matches the string "Domain", + // the user agent MUST process the cookie-av as follows. + + // 1. Let cookie-domain be the attribute-value. + let cookieDomain = attributeValue + + // 2. If cookie-domain starts with %x2E ("."), let cookie-domain be + // cookie-domain without its leading %x2E ("."). + if (cookieDomain[0] === '.') { + cookieDomain = cookieDomain.slice(1) + } + + // 3. Convert the cookie-domain to lower case. + cookieDomain = cookieDomain.toLowerCase() + + // 4. Append an attribute to the cookie-attribute-list with an + // attribute-name of Domain and an attribute-value of cookie-domain. + cookieAttributeList.domain = cookieDomain + } else if (attributeNameLowercase === 'path') { + // https://datatracker.ietf.org/doc/html/draft-ietf-httpbis-rfc6265bis#section-5.4.4 + // If the attribute-name case-insensitively matches the string "Path", + // the user agent MUST process the cookie-av as follows. + + // 1. If the attribute-value is empty or if the first character of the + // attribute-value is not %x2F ("/"): + let cookiePath = '' + if (attributeValue.length === 0 || attributeValue[0] !== '/') { + // 1. Let cookie-path be the default-path. + cookiePath = '/' + } else { + // Otherwise: + + // 1. Let cookie-path be the attribute-value. + cookiePath = attributeValue + } + + // 2. Append an attribute to the cookie-attribute-list with an + // attribute-name of Path and an attribute-value of cookie-path. + cookieAttributeList.path = cookiePath + } else if (attributeNameLowercase === 'secure') { + // https://datatracker.ietf.org/doc/html/draft-ietf-httpbis-rfc6265bis#section-5.4.5 + // If the attribute-name case-insensitively matches the string "Secure", + // the user agent MUST append an attribute to the cookie-attribute-list + // with an attribute-name of Secure and an empty attribute-value. + + cookieAttributeList.secure = true + } else if (attributeNameLowercase === 'httponly') { + // https://datatracker.ietf.org/doc/html/draft-ietf-httpbis-rfc6265bis#section-5.4.6 + // If the attribute-name case-insensitively matches the string + // "HttpOnly", the user agent MUST append an attribute to the cookie- + // attribute-list with an attribute-name of HttpOnly and an empty + // attribute-value. + + cookieAttributeList.httpOnly = true + } else if (attributeNameLowercase === 'samesite') { + // https://datatracker.ietf.org/doc/html/draft-ietf-httpbis-rfc6265bis#section-5.4.7 + // If the attribute-name case-insensitively matches the string + // "SameSite", the user agent MUST process the cookie-av as follows: + + // 1. Let enforcement be "Default". + let enforcement = 'Default' + + const attributeValueLowercase = attributeValue.toLowerCase() + // 2. If cookie-av's attribute-value is a case-insensitive match for + // "None", set enforcement to "None". + if (attributeValueLowercase.includes('none')) { + enforcement = 'None' + } + + // 3. If cookie-av's attribute-value is a case-insensitive match for + // "Strict", set enforcement to "Strict". + if (attributeValueLowercase.includes('strict')) { + enforcement = 'Strict' + } + + // 4. If cookie-av's attribute-value is a case-insensitive match for + // "Lax", set enforcement to "Lax". + if (attributeValueLowercase.includes('lax')) { + enforcement = 'Lax' + } + + // 5. Append an attribute to the cookie-attribute-list with an + // attribute-name of "SameSite" and an attribute-value of + // enforcement. + cookieAttributeList.sameSite = enforcement + } else { + cookieAttributeList.unparsed ??= [] + + cookieAttributeList.unparsed.push(`${attributeName}=${attributeValue}`) + } + + // 8. Return to Step 1 of this algorithm. + return parseUnparsedAttributes(unparsedAttributes, cookieAttributeList) +} + +module.exports = { + parseSetCookie, + parseUnparsedAttributes +} + + +/***/ }), + +/***/ 3834: +/***/ ((module, __unused_webpack_exports, __nccwpck_require__) => { + + + +const assert = __nccwpck_require__(2613) +const { kHeadersList } = __nccwpck_require__(6443) + +function isCTLExcludingHtab (value) { + if (value.length === 0) { + return false + } + + for (const char of value) { + const code = char.charCodeAt(0) + + if ( + (code >= 0x00 || code <= 0x08) || + (code >= 0x0A || code <= 0x1F) || + code === 0x7F + ) { + return false + } + } +} + +/** + CHAR = + token = 1* + separators = "(" | ")" | "<" | ">" | "@" + | "," | ";" | ":" | "\" | <"> + | "/" | "[" | "]" | "?" | "=" + | "{" | "}" | SP | HT + * @param {string} name + */ +function validateCookieName (name) { + for (const char of name) { + const code = char.charCodeAt(0) + + if ( + (code <= 0x20 || code > 0x7F) || + char === '(' || + char === ')' || + char === '>' || + char === '<' || + char === '@' || + char === ',' || + char === ';' || + char === ':' || + char === '\\' || + char === '"' || + char === '/' || + char === '[' || + char === ']' || + char === '?' || + char === '=' || + char === '{' || + char === '}' + ) { + throw new Error('Invalid cookie name') + } + } +} + +/** + cookie-value = *cookie-octet / ( DQUOTE *cookie-octet DQUOTE ) + cookie-octet = %x21 / %x23-2B / %x2D-3A / %x3C-5B / %x5D-7E + ; US-ASCII characters excluding CTLs, + ; whitespace DQUOTE, comma, semicolon, + ; and backslash + * @param {string} value + */ +function validateCookieValue (value) { + for (const char of value) { + const code = char.charCodeAt(0) + + if ( + code < 0x21 || // exclude CTLs (0-31) + code === 0x22 || + code === 0x2C || + code === 0x3B || + code === 0x5C || + code > 0x7E // non-ascii + ) { + throw new Error('Invalid header value') + } + } +} + +/** + * path-value = + * @param {string} path + */ +function validateCookiePath (path) { + for (const char of path) { + const code = char.charCodeAt(0) + + if (code < 0x21 || char === ';') { + throw new Error('Invalid cookie path') + } + } +} + +/** + * I have no idea why these values aren't allowed to be honest, + * but Deno tests these. - Khafra + * @param {string} domain + */ +function validateCookieDomain (domain) { + if ( + domain.startsWith('-') || + domain.endsWith('.') || + domain.endsWith('-') + ) { + throw new Error('Invalid cookie domain') + } +} + +/** + * @see https://www.rfc-editor.org/rfc/rfc7231#section-7.1.1.1 + * @param {number|Date} date + IMF-fixdate = day-name "," SP date1 SP time-of-day SP GMT + ; fixed length/zone/capitalization subset of the format + ; see Section 3.3 of [RFC5322] + + day-name = %x4D.6F.6E ; "Mon", case-sensitive + / %x54.75.65 ; "Tue", case-sensitive + / %x57.65.64 ; "Wed", case-sensitive + / %x54.68.75 ; "Thu", case-sensitive + / %x46.72.69 ; "Fri", case-sensitive + / %x53.61.74 ; "Sat", case-sensitive + / %x53.75.6E ; "Sun", case-sensitive + date1 = day SP month SP year + ; e.g., 02 Jun 1982 + + day = 2DIGIT + month = %x4A.61.6E ; "Jan", case-sensitive + / %x46.65.62 ; "Feb", case-sensitive + / %x4D.61.72 ; "Mar", case-sensitive + / %x41.70.72 ; "Apr", case-sensitive + / %x4D.61.79 ; "May", case-sensitive + / %x4A.75.6E ; "Jun", case-sensitive + / %x4A.75.6C ; "Jul", case-sensitive + / %x41.75.67 ; "Aug", case-sensitive + / %x53.65.70 ; "Sep", case-sensitive + / %x4F.63.74 ; "Oct", case-sensitive + / %x4E.6F.76 ; "Nov", case-sensitive + / %x44.65.63 ; "Dec", case-sensitive + year = 4DIGIT + + GMT = %x47.4D.54 ; "GMT", case-sensitive + + time-of-day = hour ":" minute ":" second + ; 00:00:00 - 23:59:60 (leap second) + + hour = 2DIGIT + minute = 2DIGIT + second = 2DIGIT + */ +function toIMFDate (date) { + if (typeof date === 'number') { + date = new Date(date) + } + + const days = [ + 'Sun', 'Mon', 'Tue', 'Wed', + 'Thu', 'Fri', 'Sat' + ] + + const months = [ + 'Jan', 'Feb', 'Mar', 'Apr', 'May', 'Jun', + 'Jul', 'Aug', 'Sep', 'Oct', 'Nov', 'Dec' + ] + + const dayName = days[date.getUTCDay()] + const day = date.getUTCDate().toString().padStart(2, '0') + const month = months[date.getUTCMonth()] + const year = date.getUTCFullYear() + const hour = date.getUTCHours().toString().padStart(2, '0') + const minute = date.getUTCMinutes().toString().padStart(2, '0') + const second = date.getUTCSeconds().toString().padStart(2, '0') + + return `${dayName}, ${day} ${month} ${year} ${hour}:${minute}:${second} GMT` +} + +/** + max-age-av = "Max-Age=" non-zero-digit *DIGIT + ; In practice, both expires-av and max-age-av + ; are limited to dates representable by the + ; user agent. + * @param {number} maxAge + */ +function validateCookieMaxAge (maxAge) { + if (maxAge < 0) { + throw new Error('Invalid cookie max-age') + } +} + +/** + * @see https://www.rfc-editor.org/rfc/rfc6265#section-4.1.1 + * @param {import('./index').Cookie} cookie + */ +function stringify (cookie) { + if (cookie.name.length === 0) { + return null + } + + validateCookieName(cookie.name) + validateCookieValue(cookie.value) + + const out = [`${cookie.name}=${cookie.value}`] + + // https://datatracker.ietf.org/doc/html/draft-ietf-httpbis-cookie-prefixes-00#section-3.1 + // https://datatracker.ietf.org/doc/html/draft-ietf-httpbis-cookie-prefixes-00#section-3.2 + if (cookie.name.startsWith('__Secure-')) { + cookie.secure = true + } + + if (cookie.name.startsWith('__Host-')) { + cookie.secure = true + cookie.domain = null + cookie.path = '/' + } + + if (cookie.secure) { + out.push('Secure') + } + + if (cookie.httpOnly) { + out.push('HttpOnly') + } + + if (typeof cookie.maxAge === 'number') { + validateCookieMaxAge(cookie.maxAge) + out.push(`Max-Age=${cookie.maxAge}`) + } + + if (cookie.domain) { + validateCookieDomain(cookie.domain) + out.push(`Domain=${cookie.domain}`) + } + + if (cookie.path) { + validateCookiePath(cookie.path) + out.push(`Path=${cookie.path}`) + } + + if (cookie.expires && cookie.expires.toString() !== 'Invalid Date') { + out.push(`Expires=${toIMFDate(cookie.expires)}`) + } + + if (cookie.sameSite) { + out.push(`SameSite=${cookie.sameSite}`) + } + + for (const part of cookie.unparsed) { + if (!part.includes('=')) { + throw new Error('Invalid unparsed') + } + + const [key, ...value] = part.split('=') + + out.push(`${key.trim()}=${value.join('=')}`) + } + + return out.join('; ') +} + +let kHeadersListNode + +function getHeadersList (headers) { + if (headers[kHeadersList]) { + return headers[kHeadersList] + } + + if (!kHeadersListNode) { + kHeadersListNode = Object.getOwnPropertySymbols(headers).find( + (symbol) => symbol.description === 'headers list' + ) + + assert(kHeadersListNode, 'Headers cannot be parsed') + } + + const headersList = headers[kHeadersListNode] + assert(headersList) + + return headersList +} + +module.exports = { + isCTLExcludingHtab, + stringify, + getHeadersList +} + + +/***/ }), + +/***/ 9136: +/***/ ((module, __unused_webpack_exports, __nccwpck_require__) => { + + + +const net = __nccwpck_require__(9278) +const assert = __nccwpck_require__(2613) +const util = __nccwpck_require__(3440) +const { InvalidArgumentError, ConnectTimeoutError } = __nccwpck_require__(8707) + +let tls // include tls conditionally since it is not always available + +// TODO: session re-use does not wait for the first +// connection to resolve the session and might therefore +// resolve the same servername multiple times even when +// re-use is enabled. + +let SessionCache +// FIXME: remove workaround when the Node bug is fixed +// https://github.com/nodejs/node/issues/49344#issuecomment-1741776308 +if (global.FinalizationRegistry && !process.env.NODE_V8_COVERAGE) { + SessionCache = class WeakSessionCache { + constructor (maxCachedSessions) { + this._maxCachedSessions = maxCachedSessions + this._sessionCache = new Map() + this._sessionRegistry = new global.FinalizationRegistry((key) => { + if (this._sessionCache.size < this._maxCachedSessions) { + return + } + + const ref = this._sessionCache.get(key) + if (ref !== undefined && ref.deref() === undefined) { + this._sessionCache.delete(key) + } + }) + } + + get (sessionKey) { + const ref = this._sessionCache.get(sessionKey) + return ref ? ref.deref() : null + } + + set (sessionKey, session) { + if (this._maxCachedSessions === 0) { + return + } + + this._sessionCache.set(sessionKey, new WeakRef(session)) + this._sessionRegistry.register(session, sessionKey) + } + } +} else { + SessionCache = class SimpleSessionCache { + constructor (maxCachedSessions) { + this._maxCachedSessions = maxCachedSessions + this._sessionCache = new Map() + } + + get (sessionKey) { + return this._sessionCache.get(sessionKey) + } + + set (sessionKey, session) { + if (this._maxCachedSessions === 0) { + return + } + + if (this._sessionCache.size >= this._maxCachedSessions) { + // remove the oldest session + const { value: oldestKey } = this._sessionCache.keys().next() + this._sessionCache.delete(oldestKey) + } + + this._sessionCache.set(sessionKey, session) + } + } +} + +function buildConnector ({ allowH2, maxCachedSessions, socketPath, timeout, ...opts }) { + if (maxCachedSessions != null && (!Number.isInteger(maxCachedSessions) || maxCachedSessions < 0)) { + throw new InvalidArgumentError('maxCachedSessions must be a positive integer or zero') + } + + const options = { path: socketPath, ...opts } + const sessionCache = new SessionCache(maxCachedSessions == null ? 100 : maxCachedSessions) + timeout = timeout == null ? 10e3 : timeout + allowH2 = allowH2 != null ? allowH2 : false + return function connect ({ hostname, host, protocol, port, servername, localAddress, httpSocket }, callback) { + let socket + if (protocol === 'https:') { + if (!tls) { + tls = __nccwpck_require__(4756) + } + servername = servername || options.servername || util.getServerName(host) || null + + const sessionKey = servername || hostname + const session = sessionCache.get(sessionKey) || null + + assert(sessionKey) + + socket = tls.connect({ + highWaterMark: 16384, // TLS in node can't have bigger HWM anyway... + ...options, + servername, + session, + localAddress, + // TODO(HTTP/2): Add support for h2c + ALPNProtocols: allowH2 ? ['http/1.1', 'h2'] : ['http/1.1'], + socket: httpSocket, // upgrade socket connection + port: port || 443, + host: hostname + }) + + socket + .on('session', function (session) { + // TODO (fix): Can a session become invalid once established? Don't think so? + sessionCache.set(sessionKey, session) + }) + } else { + assert(!httpSocket, 'httpSocket can only be sent on TLS update') + socket = net.connect({ + highWaterMark: 64 * 1024, // Same as nodejs fs streams. + ...options, + localAddress, + port: port || 80, + host: hostname + }) + } + + // Set TCP keep alive options on the socket here instead of in connect() for the case of assigning the socket + if (options.keepAlive == null || options.keepAlive) { + const keepAliveInitialDelay = options.keepAliveInitialDelay === undefined ? 60e3 : options.keepAliveInitialDelay + socket.setKeepAlive(true, keepAliveInitialDelay) + } + + const cancelTimeout = setupTimeout(() => onConnectTimeout(socket), timeout) + + socket + .setNoDelay(true) + .once(protocol === 'https:' ? 'secureConnect' : 'connect', function () { + cancelTimeout() + + if (callback) { + const cb = callback + callback = null + cb(null, this) + } + }) + .on('error', function (err) { + cancelTimeout() + + if (callback) { + const cb = callback + callback = null + cb(err) + } + }) + + return socket + } +} + +function setupTimeout (onConnectTimeout, timeout) { + if (!timeout) { + return () => {} + } + + let s1 = null + let s2 = null + const timeoutId = setTimeout(() => { + // setImmediate is added to make sure that we priotorise socket error events over timeouts + s1 = setImmediate(() => { + if (process.platform === 'win32') { + // Windows needs an extra setImmediate probably due to implementation differences in the socket logic + s2 = setImmediate(() => onConnectTimeout()) + } else { + onConnectTimeout() + } + }) + }, timeout) + return () => { + clearTimeout(timeoutId) + clearImmediate(s1) + clearImmediate(s2) + } +} + +function onConnectTimeout (socket) { + util.destroy(socket, new ConnectTimeoutError()) +} + +module.exports = buildConnector + + +/***/ }), + +/***/ 735: +/***/ ((module) => { + + + +/** @type {Record} */ +const headerNameLowerCasedRecord = {} + +// https://developer.mozilla.org/docs/Web/HTTP/Headers +const wellknownHeaderNames = [ + 'Accept', + 'Accept-Encoding', + 'Accept-Language', + 'Accept-Ranges', + 'Access-Control-Allow-Credentials', + 'Access-Control-Allow-Headers', + 'Access-Control-Allow-Methods', + 'Access-Control-Allow-Origin', + 'Access-Control-Expose-Headers', + 'Access-Control-Max-Age', + 'Access-Control-Request-Headers', + 'Access-Control-Request-Method', + 'Age', + 'Allow', + 'Alt-Svc', + 'Alt-Used', + 'Authorization', + 'Cache-Control', + 'Clear-Site-Data', + 'Connection', + 'Content-Disposition', + 'Content-Encoding', + 'Content-Language', + 'Content-Length', + 'Content-Location', + 'Content-Range', + 'Content-Security-Policy', + 'Content-Security-Policy-Report-Only', + 'Content-Type', + 'Cookie', + 'Cross-Origin-Embedder-Policy', + 'Cross-Origin-Opener-Policy', + 'Cross-Origin-Resource-Policy', + 'Date', + 'Device-Memory', + 'Downlink', + 'ECT', + 'ETag', + 'Expect', + 'Expect-CT', + 'Expires', + 'Forwarded', + 'From', + 'Host', + 'If-Match', + 'If-Modified-Since', + 'If-None-Match', + 'If-Range', + 'If-Unmodified-Since', + 'Keep-Alive', + 'Last-Modified', + 'Link', + 'Location', + 'Max-Forwards', + 'Origin', + 'Permissions-Policy', + 'Pragma', + 'Proxy-Authenticate', + 'Proxy-Authorization', + 'RTT', + 'Range', + 'Referer', + 'Referrer-Policy', + 'Refresh', + 'Retry-After', + 'Sec-WebSocket-Accept', + 'Sec-WebSocket-Extensions', + 'Sec-WebSocket-Key', + 'Sec-WebSocket-Protocol', + 'Sec-WebSocket-Version', + 'Server', + 'Server-Timing', + 'Service-Worker-Allowed', + 'Service-Worker-Navigation-Preload', + 'Set-Cookie', + 'SourceMap', + 'Strict-Transport-Security', + 'Supports-Loading-Mode', + 'TE', + 'Timing-Allow-Origin', + 'Trailer', + 'Transfer-Encoding', + 'Upgrade', + 'Upgrade-Insecure-Requests', + 'User-Agent', + 'Vary', + 'Via', + 'WWW-Authenticate', + 'X-Content-Type-Options', + 'X-DNS-Prefetch-Control', + 'X-Frame-Options', + 'X-Permitted-Cross-Domain-Policies', + 'X-Powered-By', + 'X-Requested-With', + 'X-XSS-Protection' +] + +for (let i = 0; i < wellknownHeaderNames.length; ++i) { + const key = wellknownHeaderNames[i] + const lowerCasedKey = key.toLowerCase() + headerNameLowerCasedRecord[key] = headerNameLowerCasedRecord[lowerCasedKey] = + lowerCasedKey +} + +// Note: object prototypes should not be able to be referenced. e.g. `Object#hasOwnProperty`. +Object.setPrototypeOf(headerNameLowerCasedRecord, null) + +module.exports = { + wellknownHeaderNames, + headerNameLowerCasedRecord +} + + +/***/ }), + +/***/ 8707: +/***/ ((module) => { + + + +class UndiciError extends Error { + constructor (message) { + super(message) + this.name = 'UndiciError' + this.code = 'UND_ERR' + } +} + +class ConnectTimeoutError extends UndiciError { + constructor (message) { + super(message) + Error.captureStackTrace(this, ConnectTimeoutError) + this.name = 'ConnectTimeoutError' + this.message = message || 'Connect Timeout Error' + this.code = 'UND_ERR_CONNECT_TIMEOUT' + } +} + +class HeadersTimeoutError extends UndiciError { + constructor (message) { + super(message) + Error.captureStackTrace(this, HeadersTimeoutError) + this.name = 'HeadersTimeoutError' + this.message = message || 'Headers Timeout Error' + this.code = 'UND_ERR_HEADERS_TIMEOUT' + } +} + +class HeadersOverflowError extends UndiciError { + constructor (message) { + super(message) + Error.captureStackTrace(this, HeadersOverflowError) + this.name = 'HeadersOverflowError' + this.message = message || 'Headers Overflow Error' + this.code = 'UND_ERR_HEADERS_OVERFLOW' + } +} + +class BodyTimeoutError extends UndiciError { + constructor (message) { + super(message) + Error.captureStackTrace(this, BodyTimeoutError) + this.name = 'BodyTimeoutError' + this.message = message || 'Body Timeout Error' + this.code = 'UND_ERR_BODY_TIMEOUT' + } +} + +class ResponseStatusCodeError extends UndiciError { + constructor (message, statusCode, headers, body) { + super(message) + Error.captureStackTrace(this, ResponseStatusCodeError) + this.name = 'ResponseStatusCodeError' + this.message = message || 'Response Status Code Error' + this.code = 'UND_ERR_RESPONSE_STATUS_CODE' + this.body = body + this.status = statusCode + this.statusCode = statusCode + this.headers = headers + } +} + +class InvalidArgumentError extends UndiciError { + constructor (message) { + super(message) + Error.captureStackTrace(this, InvalidArgumentError) + this.name = 'InvalidArgumentError' + this.message = message || 'Invalid Argument Error' + this.code = 'UND_ERR_INVALID_ARG' + } +} + +class InvalidReturnValueError extends UndiciError { + constructor (message) { + super(message) + Error.captureStackTrace(this, InvalidReturnValueError) + this.name = 'InvalidReturnValueError' + this.message = message || 'Invalid Return Value Error' + this.code = 'UND_ERR_INVALID_RETURN_VALUE' + } +} + +class RequestAbortedError extends UndiciError { + constructor (message) { + super(message) + Error.captureStackTrace(this, RequestAbortedError) + this.name = 'AbortError' + this.message = message || 'Request aborted' + this.code = 'UND_ERR_ABORTED' + } +} + +class InformationalError extends UndiciError { + constructor (message) { + super(message) + Error.captureStackTrace(this, InformationalError) + this.name = 'InformationalError' + this.message = message || 'Request information' + this.code = 'UND_ERR_INFO' + } +} + +class RequestContentLengthMismatchError extends UndiciError { + constructor (message) { + super(message) + Error.captureStackTrace(this, RequestContentLengthMismatchError) + this.name = 'RequestContentLengthMismatchError' + this.message = message || 'Request body length does not match content-length header' + this.code = 'UND_ERR_REQ_CONTENT_LENGTH_MISMATCH' + } +} + +class ResponseContentLengthMismatchError extends UndiciError { + constructor (message) { + super(message) + Error.captureStackTrace(this, ResponseContentLengthMismatchError) + this.name = 'ResponseContentLengthMismatchError' + this.message = message || 'Response body length does not match content-length header' + this.code = 'UND_ERR_RES_CONTENT_LENGTH_MISMATCH' + } +} + +class ClientDestroyedError extends UndiciError { + constructor (message) { + super(message) + Error.captureStackTrace(this, ClientDestroyedError) + this.name = 'ClientDestroyedError' + this.message = message || 'The client is destroyed' + this.code = 'UND_ERR_DESTROYED' + } +} + +class ClientClosedError extends UndiciError { + constructor (message) { + super(message) + Error.captureStackTrace(this, ClientClosedError) + this.name = 'ClientClosedError' + this.message = message || 'The client is closed' + this.code = 'UND_ERR_CLOSED' + } +} + +class SocketError extends UndiciError { + constructor (message, socket) { + super(message) + Error.captureStackTrace(this, SocketError) + this.name = 'SocketError' + this.message = message || 'Socket error' + this.code = 'UND_ERR_SOCKET' + this.socket = socket + } +} + +class NotSupportedError extends UndiciError { + constructor (message) { + super(message) + Error.captureStackTrace(this, NotSupportedError) + this.name = 'NotSupportedError' + this.message = message || 'Not supported error' + this.code = 'UND_ERR_NOT_SUPPORTED' + } +} + +class BalancedPoolMissingUpstreamError extends UndiciError { + constructor (message) { + super(message) + Error.captureStackTrace(this, NotSupportedError) + this.name = 'MissingUpstreamError' + this.message = message || 'No upstream has been added to the BalancedPool' + this.code = 'UND_ERR_BPL_MISSING_UPSTREAM' + } +} + +class HTTPParserError extends Error { + constructor (message, code, data) { + super(message) + Error.captureStackTrace(this, HTTPParserError) + this.name = 'HTTPParserError' + this.code = code ? `HPE_${code}` : undefined + this.data = data ? data.toString() : undefined + } +} + +class ResponseExceededMaxSizeError extends UndiciError { + constructor (message) { + super(message) + Error.captureStackTrace(this, ResponseExceededMaxSizeError) + this.name = 'ResponseExceededMaxSizeError' + this.message = message || 'Response content exceeded max size' + this.code = 'UND_ERR_RES_EXCEEDED_MAX_SIZE' + } +} + +class RequestRetryError extends UndiciError { + constructor (message, code, { headers, data }) { + super(message) + Error.captureStackTrace(this, RequestRetryError) + this.name = 'RequestRetryError' + this.message = message || 'Request retry error' + this.code = 'UND_ERR_REQ_RETRY' + this.statusCode = code + this.data = data + this.headers = headers + } +} + +module.exports = { + HTTPParserError, + UndiciError, + HeadersTimeoutError, + HeadersOverflowError, + BodyTimeoutError, + RequestContentLengthMismatchError, + ConnectTimeoutError, + ResponseStatusCodeError, + InvalidArgumentError, + InvalidReturnValueError, + RequestAbortedError, + ClientDestroyedError, + ClientClosedError, + InformationalError, + SocketError, + NotSupportedError, + ResponseContentLengthMismatchError, + BalancedPoolMissingUpstreamError, + ResponseExceededMaxSizeError, + RequestRetryError +} + + +/***/ }), + +/***/ 4655: +/***/ ((module, __unused_webpack_exports, __nccwpck_require__) => { + + + +const { + InvalidArgumentError, + NotSupportedError +} = __nccwpck_require__(8707) +const assert = __nccwpck_require__(2613) +const { kHTTP2BuildRequest, kHTTP2CopyHeaders, kHTTP1BuildRequest } = __nccwpck_require__(6443) +const util = __nccwpck_require__(3440) + +// tokenRegExp and headerCharRegex have been lifted from +// https://github.com/nodejs/node/blob/main/lib/_http_common.js + +/** + * Verifies that the given val is a valid HTTP token + * per the rules defined in RFC 7230 + * See https://tools.ietf.org/html/rfc7230#section-3.2.6 + */ +const tokenRegExp = /^[\^_`a-zA-Z\-0-9!#$%&'*+.|~]+$/ + +/** + * Matches if val contains an invalid field-vchar + * field-value = *( field-content / obs-fold ) + * field-content = field-vchar [ 1*( SP / HTAB ) field-vchar ] + * field-vchar = VCHAR / obs-text + */ +const headerCharRegex = /[^\t\x20-\x7e\x80-\xff]/ + +// Verifies that a given path is valid does not contain control chars \x00 to \x20 +const invalidPathRegex = /[^\u0021-\u00ff]/ + +const kHandler = Symbol('handler') + +const channels = {} + +let extractBody + +try { + const diagnosticsChannel = __nccwpck_require__(1637) + channels.create = diagnosticsChannel.channel('undici:request:create') + channels.bodySent = diagnosticsChannel.channel('undici:request:bodySent') + channels.headers = diagnosticsChannel.channel('undici:request:headers') + channels.trailers = diagnosticsChannel.channel('undici:request:trailers') + channels.error = diagnosticsChannel.channel('undici:request:error') +} catch { + channels.create = { hasSubscribers: false } + channels.bodySent = { hasSubscribers: false } + channels.headers = { hasSubscribers: false } + channels.trailers = { hasSubscribers: false } + channels.error = { hasSubscribers: false } +} + +class Request { + constructor (origin, { + path, + method, + body, + headers, + query, + idempotent, + blocking, + upgrade, + headersTimeout, + bodyTimeout, + reset, + throwOnError, + expectContinue + }, handler) { + if (typeof path !== 'string') { + throw new InvalidArgumentError('path must be a string') + } else if ( + path[0] !== '/' && + !(path.startsWith('http://') || path.startsWith('https://')) && + method !== 'CONNECT' + ) { + throw new InvalidArgumentError('path must be an absolute URL or start with a slash') + } else if (invalidPathRegex.exec(path) !== null) { + throw new InvalidArgumentError('invalid request path') + } + + if (typeof method !== 'string') { + throw new InvalidArgumentError('method must be a string') + } else if (tokenRegExp.exec(method) === null) { + throw new InvalidArgumentError('invalid request method') + } + + if (upgrade && typeof upgrade !== 'string') { + throw new InvalidArgumentError('upgrade must be a string') + } + + if (headersTimeout != null && (!Number.isFinite(headersTimeout) || headersTimeout < 0)) { + throw new InvalidArgumentError('invalid headersTimeout') + } + + if (bodyTimeout != null && (!Number.isFinite(bodyTimeout) || bodyTimeout < 0)) { + throw new InvalidArgumentError('invalid bodyTimeout') + } + + if (reset != null && typeof reset !== 'boolean') { + throw new InvalidArgumentError('invalid reset') + } + + if (expectContinue != null && typeof expectContinue !== 'boolean') { + throw new InvalidArgumentError('invalid expectContinue') + } + + this.headersTimeout = headersTimeout + + this.bodyTimeout = bodyTimeout + + this.throwOnError = throwOnError === true + + this.method = method + + this.abort = null + + if (body == null) { + this.body = null + } else if (util.isStream(body)) { + this.body = body + + const rState = this.body._readableState + if (!rState || !rState.autoDestroy) { + this.endHandler = function autoDestroy () { + util.destroy(this) + } + this.body.on('end', this.endHandler) + } + + this.errorHandler = err => { + if (this.abort) { + this.abort(err) + } else { + this.error = err + } + } + this.body.on('error', this.errorHandler) + } else if (util.isBuffer(body)) { + this.body = body.byteLength ? body : null + } else if (ArrayBuffer.isView(body)) { + this.body = body.buffer.byteLength ? Buffer.from(body.buffer, body.byteOffset, body.byteLength) : null + } else if (body instanceof ArrayBuffer) { + this.body = body.byteLength ? Buffer.from(body) : null + } else if (typeof body === 'string') { + this.body = body.length ? Buffer.from(body) : null + } else if (util.isFormDataLike(body) || util.isIterable(body) || util.isBlobLike(body)) { + this.body = body + } else { + throw new InvalidArgumentError('body must be a string, a Buffer, a Readable stream, an iterable, or an async iterable') + } + + this.completed = false + + this.aborted = false + + this.upgrade = upgrade || null + + this.path = query ? util.buildURL(path, query) : path + + this.origin = origin + + this.idempotent = idempotent == null + ? method === 'HEAD' || method === 'GET' + : idempotent + + this.blocking = blocking == null ? false : blocking + + this.reset = reset == null ? null : reset + + this.host = null + + this.contentLength = null + + this.contentType = null + + this.headers = '' + + // Only for H2 + this.expectContinue = expectContinue != null ? expectContinue : false + + if (Array.isArray(headers)) { + if (headers.length % 2 !== 0) { + throw new InvalidArgumentError('headers array must be even') + } + for (let i = 0; i < headers.length; i += 2) { + processHeader(this, headers[i], headers[i + 1]) + } + } else if (headers && typeof headers === 'object') { + const keys = Object.keys(headers) + for (let i = 0; i < keys.length; i++) { + const key = keys[i] + processHeader(this, key, headers[key]) + } + } else if (headers != null) { + throw new InvalidArgumentError('headers must be an object or an array') + } + + if (util.isFormDataLike(this.body)) { + if (util.nodeMajor < 16 || (util.nodeMajor === 16 && util.nodeMinor < 8)) { + throw new InvalidArgumentError('Form-Data bodies are only supported in node v16.8 and newer.') + } + + if (!extractBody) { + extractBody = (__nccwpck_require__(8923).extractBody) + } + + const [bodyStream, contentType] = extractBody(body) + if (this.contentType == null) { + this.contentType = contentType + this.headers += `content-type: ${contentType}\r\n` + } + this.body = bodyStream.stream + this.contentLength = bodyStream.length + } else if (util.isBlobLike(body) && this.contentType == null && body.type) { + this.contentType = body.type + this.headers += `content-type: ${body.type}\r\n` + } + + util.validateHandler(handler, method, upgrade) + + this.servername = util.getServerName(this.host) + + this[kHandler] = handler + + if (channels.create.hasSubscribers) { + channels.create.publish({ request: this }) + } + } + + onBodySent (chunk) { + if (this[kHandler].onBodySent) { + try { + return this[kHandler].onBodySent(chunk) + } catch (err) { + this.abort(err) + } + } + } + + onRequestSent () { + if (channels.bodySent.hasSubscribers) { + channels.bodySent.publish({ request: this }) + } + + if (this[kHandler].onRequestSent) { + try { + return this[kHandler].onRequestSent() + } catch (err) { + this.abort(err) + } + } + } + + onConnect (abort) { + assert(!this.aborted) + assert(!this.completed) + + if (this.error) { + abort(this.error) + } else { + this.abort = abort + return this[kHandler].onConnect(abort) + } + } + + onHeaders (statusCode, headers, resume, statusText) { + assert(!this.aborted) + assert(!this.completed) + + if (channels.headers.hasSubscribers) { + channels.headers.publish({ request: this, response: { statusCode, headers, statusText } }) + } + + try { + return this[kHandler].onHeaders(statusCode, headers, resume, statusText) + } catch (err) { + this.abort(err) + } + } + + onData (chunk) { + assert(!this.aborted) + assert(!this.completed) + + try { + return this[kHandler].onData(chunk) + } catch (err) { + this.abort(err) + return false + } + } + + onUpgrade (statusCode, headers, socket) { + assert(!this.aborted) + assert(!this.completed) + + return this[kHandler].onUpgrade(statusCode, headers, socket) + } + + onComplete (trailers) { + this.onFinally() + + assert(!this.aborted) + + this.completed = true + if (channels.trailers.hasSubscribers) { + channels.trailers.publish({ request: this, trailers }) + } + + try { + return this[kHandler].onComplete(trailers) + } catch (err) { + // TODO (fix): This might be a bad idea? + this.onError(err) + } + } + + onError (error) { + this.onFinally() + + if (channels.error.hasSubscribers) { + channels.error.publish({ request: this, error }) + } + + if (this.aborted) { + return + } + this.aborted = true + + return this[kHandler].onError(error) + } + + onFinally () { + if (this.errorHandler) { + this.body.off('error', this.errorHandler) + this.errorHandler = null + } + + if (this.endHandler) { + this.body.off('end', this.endHandler) + this.endHandler = null + } + } + + // TODO: adjust to support H2 + addHeader (key, value) { + processHeader(this, key, value) + return this + } + + static [kHTTP1BuildRequest] (origin, opts, handler) { + // TODO: Migrate header parsing here, to make Requests + // HTTP agnostic + return new Request(origin, opts, handler) + } + + static [kHTTP2BuildRequest] (origin, opts, handler) { + const headers = opts.headers + opts = { ...opts, headers: null } + + const request = new Request(origin, opts, handler) + + request.headers = {} + + if (Array.isArray(headers)) { + if (headers.length % 2 !== 0) { + throw new InvalidArgumentError('headers array must be even') + } + for (let i = 0; i < headers.length; i += 2) { + processHeader(request, headers[i], headers[i + 1], true) + } + } else if (headers && typeof headers === 'object') { + const keys = Object.keys(headers) + for (let i = 0; i < keys.length; i++) { + const key = keys[i] + processHeader(request, key, headers[key], true) + } + } else if (headers != null) { + throw new InvalidArgumentError('headers must be an object or an array') + } + + return request + } + + static [kHTTP2CopyHeaders] (raw) { + const rawHeaders = raw.split('\r\n') + const headers = {} + + for (const header of rawHeaders) { + const [key, value] = header.split(': ') + + if (value == null || value.length === 0) continue + + if (headers[key]) headers[key] += `,${value}` + else headers[key] = value + } + + return headers + } +} + +function processHeaderValue (key, val, skipAppend) { + if (val && typeof val === 'object') { + throw new InvalidArgumentError(`invalid ${key} header`) + } + + val = val != null ? `${val}` : '' + + if (headerCharRegex.exec(val) !== null) { + throw new InvalidArgumentError(`invalid ${key} header`) + } + + return skipAppend ? val : `${key}: ${val}\r\n` +} + +function processHeader (request, key, val, skipAppend = false) { + if (val && (typeof val === 'object' && !Array.isArray(val))) { + throw new InvalidArgumentError(`invalid ${key} header`) + } else if (val === undefined) { + return + } + + if ( + request.host === null && + key.length === 4 && + key.toLowerCase() === 'host' + ) { + if (headerCharRegex.exec(val) !== null) { + throw new InvalidArgumentError(`invalid ${key} header`) + } + // Consumed by Client + request.host = val + } else if ( + request.contentLength === null && + key.length === 14 && + key.toLowerCase() === 'content-length' + ) { + request.contentLength = parseInt(val, 10) + if (!Number.isFinite(request.contentLength)) { + throw new InvalidArgumentError('invalid content-length header') + } + } else if ( + request.contentType === null && + key.length === 12 && + key.toLowerCase() === 'content-type' + ) { + request.contentType = val + if (skipAppend) request.headers[key] = processHeaderValue(key, val, skipAppend) + else request.headers += processHeaderValue(key, val) + } else if ( + key.length === 17 && + key.toLowerCase() === 'transfer-encoding' + ) { + throw new InvalidArgumentError('invalid transfer-encoding header') + } else if ( + key.length === 10 && + key.toLowerCase() === 'connection' + ) { + const value = typeof val === 'string' ? val.toLowerCase() : null + if (value !== 'close' && value !== 'keep-alive') { + throw new InvalidArgumentError('invalid connection header') + } else if (value === 'close') { + request.reset = true + } + } else if ( + key.length === 10 && + key.toLowerCase() === 'keep-alive' + ) { + throw new InvalidArgumentError('invalid keep-alive header') + } else if ( + key.length === 7 && + key.toLowerCase() === 'upgrade' + ) { + throw new InvalidArgumentError('invalid upgrade header') + } else if ( + key.length === 6 && + key.toLowerCase() === 'expect' + ) { + throw new NotSupportedError('expect header not supported') + } else if (tokenRegExp.exec(key) === null) { + throw new InvalidArgumentError('invalid header key') + } else { + if (Array.isArray(val)) { + for (let i = 0; i < val.length; i++) { + if (skipAppend) { + if (request.headers[key]) request.headers[key] += `,${processHeaderValue(key, val[i], skipAppend)}` + else request.headers[key] = processHeaderValue(key, val[i], skipAppend) + } else { + request.headers += processHeaderValue(key, val[i]) + } + } + } else { + if (skipAppend) request.headers[key] = processHeaderValue(key, val, skipAppend) + else request.headers += processHeaderValue(key, val) + } + } +} + +module.exports = Request + + +/***/ }), + +/***/ 6443: +/***/ ((module) => { + +module.exports = { + kClose: Symbol('close'), + kDestroy: Symbol('destroy'), + kDispatch: Symbol('dispatch'), + kUrl: Symbol('url'), + kWriting: Symbol('writing'), + kResuming: Symbol('resuming'), + kQueue: Symbol('queue'), + kConnect: Symbol('connect'), + kConnecting: Symbol('connecting'), + kHeadersList: Symbol('headers list'), + kKeepAliveDefaultTimeout: Symbol('default keep alive timeout'), + kKeepAliveMaxTimeout: Symbol('max keep alive timeout'), + kKeepAliveTimeoutThreshold: Symbol('keep alive timeout threshold'), + kKeepAliveTimeoutValue: Symbol('keep alive timeout'), + kKeepAlive: Symbol('keep alive'), + kHeadersTimeout: Symbol('headers timeout'), + kBodyTimeout: Symbol('body timeout'), + kServerName: Symbol('server name'), + kLocalAddress: Symbol('local address'), + kHost: Symbol('host'), + kNoRef: Symbol('no ref'), + kBodyUsed: Symbol('used'), + kRunning: Symbol('running'), + kBlocking: Symbol('blocking'), + kPending: Symbol('pending'), + kSize: Symbol('size'), + kBusy: Symbol('busy'), + kQueued: Symbol('queued'), + kFree: Symbol('free'), + kConnected: Symbol('connected'), + kClosed: Symbol('closed'), + kNeedDrain: Symbol('need drain'), + kReset: Symbol('reset'), + kDestroyed: Symbol.for('nodejs.stream.destroyed'), + kMaxHeadersSize: Symbol('max headers size'), + kRunningIdx: Symbol('running index'), + kPendingIdx: Symbol('pending index'), + kError: Symbol('error'), + kClients: Symbol('clients'), + kClient: Symbol('client'), + kParser: Symbol('parser'), + kOnDestroyed: Symbol('destroy callbacks'), + kPipelining: Symbol('pipelining'), + kSocket: Symbol('socket'), + kHostHeader: Symbol('host header'), + kConnector: Symbol('connector'), + kStrictContentLength: Symbol('strict content length'), + kMaxRedirections: Symbol('maxRedirections'), + kMaxRequests: Symbol('maxRequestsPerClient'), + kProxy: Symbol('proxy agent options'), + kCounter: Symbol('socket request counter'), + kInterceptors: Symbol('dispatch interceptors'), + kMaxResponseSize: Symbol('max response size'), + kHTTP2Session: Symbol('http2Session'), + kHTTP2SessionState: Symbol('http2Session state'), + kHTTP2BuildRequest: Symbol('http2 build request'), + kHTTP1BuildRequest: Symbol('http1 build request'), + kHTTP2CopyHeaders: Symbol('http2 copy headers'), + kHTTPConnVersion: Symbol('http connection version'), + kRetryHandlerDefaultRetry: Symbol('retry agent default retry'), + kConstruct: Symbol('constructable') +} + + +/***/ }), + +/***/ 3440: +/***/ ((module, __unused_webpack_exports, __nccwpck_require__) => { + + + +const assert = __nccwpck_require__(2613) +const { kDestroyed, kBodyUsed } = __nccwpck_require__(6443) +const { IncomingMessage } = __nccwpck_require__(8611) +const stream = __nccwpck_require__(2203) +const net = __nccwpck_require__(9278) +const { InvalidArgumentError } = __nccwpck_require__(8707) +const { Blob } = __nccwpck_require__(181) +const nodeUtil = __nccwpck_require__(9023) +const { stringify } = __nccwpck_require__(3480) +const { headerNameLowerCasedRecord } = __nccwpck_require__(735) + +const [nodeMajor, nodeMinor] = process.versions.node.split('.').map(v => Number(v)) + +function nop () {} + +function isStream (obj) { + return obj && typeof obj === 'object' && typeof obj.pipe === 'function' && typeof obj.on === 'function' +} + +// based on https://github.com/node-fetch/fetch-blob/blob/8ab587d34080de94140b54f07168451e7d0b655e/index.js#L229-L241 (MIT License) +function isBlobLike (object) { + return (Blob && object instanceof Blob) || ( + object && + typeof object === 'object' && + (typeof object.stream === 'function' || + typeof object.arrayBuffer === 'function') && + /^(Blob|File)$/.test(object[Symbol.toStringTag]) + ) +} + +function buildURL (url, queryParams) { + if (url.includes('?') || url.includes('#')) { + throw new Error('Query params cannot be passed when url already contains "?" or "#".') + } + + const stringified = stringify(queryParams) + + if (stringified) { + url += '?' + stringified + } + + return url +} + +function parseURL (url) { + if (typeof url === 'string') { + url = new URL(url) + + if (!/^https?:/.test(url.origin || url.protocol)) { + throw new InvalidArgumentError('Invalid URL protocol: the URL must start with `http:` or `https:`.') + } + + return url + } + + if (!url || typeof url !== 'object') { + throw new InvalidArgumentError('Invalid URL: The URL argument must be a non-null object.') + } + + if (!/^https?:/.test(url.origin || url.protocol)) { + throw new InvalidArgumentError('Invalid URL protocol: the URL must start with `http:` or `https:`.') + } + + if (!(url instanceof URL)) { + if (url.port != null && url.port !== '' && !Number.isFinite(parseInt(url.port))) { + throw new InvalidArgumentError('Invalid URL: port must be a valid integer or a string representation of an integer.') + } + + if (url.path != null && typeof url.path !== 'string') { + throw new InvalidArgumentError('Invalid URL path: the path must be a string or null/undefined.') + } + + if (url.pathname != null && typeof url.pathname !== 'string') { + throw new InvalidArgumentError('Invalid URL pathname: the pathname must be a string or null/undefined.') + } + + if (url.hostname != null && typeof url.hostname !== 'string') { + throw new InvalidArgumentError('Invalid URL hostname: the hostname must be a string or null/undefined.') + } + + if (url.origin != null && typeof url.origin !== 'string') { + throw new InvalidArgumentError('Invalid URL origin: the origin must be a string or null/undefined.') + } + + const port = url.port != null + ? url.port + : (url.protocol === 'https:' ? 443 : 80) + let origin = url.origin != null + ? url.origin + : `${url.protocol}//${url.hostname}:${port}` + let path = url.path != null + ? url.path + : `${url.pathname || ''}${url.search || ''}` + + if (origin.endsWith('/')) { + origin = origin.substring(0, origin.length - 1) + } + + if (path && !path.startsWith('/')) { + path = `/${path}` + } + // new URL(path, origin) is unsafe when `path` contains an absolute URL + // From https://developer.mozilla.org/en-US/docs/Web/API/URL/URL: + // If first parameter is a relative URL, second param is required, and will be used as the base URL. + // If first parameter is an absolute URL, a given second param will be ignored. + url = new URL(origin + path) + } + + return url +} + +function parseOrigin (url) { + url = parseURL(url) + + if (url.pathname !== '/' || url.search || url.hash) { + throw new InvalidArgumentError('invalid url') + } + + return url +} + +function getHostname (host) { + if (host[0] === '[') { + const idx = host.indexOf(']') + + assert(idx !== -1) + return host.substring(1, idx) + } + + const idx = host.indexOf(':') + if (idx === -1) return host + + return host.substring(0, idx) +} + +// IP addresses are not valid server names per RFC6066 +// > Currently, the only server names supported are DNS hostnames +function getServerName (host) { + if (!host) { + return null + } + + assert.strictEqual(typeof host, 'string') + + const servername = getHostname(host) + if (net.isIP(servername)) { + return '' + } + + return servername +} + +function deepClone (obj) { + return JSON.parse(JSON.stringify(obj)) +} + +function isAsyncIterable (obj) { + return !!(obj != null && typeof obj[Symbol.asyncIterator] === 'function') +} + +function isIterable (obj) { + return !!(obj != null && (typeof obj[Symbol.iterator] === 'function' || typeof obj[Symbol.asyncIterator] === 'function')) +} + +function bodyLength (body) { + if (body == null) { + return 0 + } else if (isStream(body)) { + const state = body._readableState + return state && state.objectMode === false && state.ended === true && Number.isFinite(state.length) + ? state.length + : null + } else if (isBlobLike(body)) { + return body.size != null ? body.size : null + } else if (isBuffer(body)) { + return body.byteLength + } + + return null +} + +function isDestroyed (stream) { + return !stream || !!(stream.destroyed || stream[kDestroyed]) +} + +function isReadableAborted (stream) { + const state = stream && stream._readableState + return isDestroyed(stream) && state && !state.endEmitted +} + +function destroy (stream, err) { + if (stream == null || !isStream(stream) || isDestroyed(stream)) { + return + } + + if (typeof stream.destroy === 'function') { + if (Object.getPrototypeOf(stream).constructor === IncomingMessage) { + // See: https://github.com/nodejs/node/pull/38505/files + stream.socket = null + } + + stream.destroy(err) + } else if (err) { + process.nextTick((stream, err) => { + stream.emit('error', err) + }, stream, err) + } + + if (stream.destroyed !== true) { + stream[kDestroyed] = true + } +} + +const KEEPALIVE_TIMEOUT_EXPR = /timeout=(\d+)/ +function parseKeepAliveTimeout (val) { + const m = val.toString().match(KEEPALIVE_TIMEOUT_EXPR) + return m ? parseInt(m[1], 10) * 1000 : null +} + +/** + * Retrieves a header name and returns its lowercase value. + * @param {string | Buffer} value Header name + * @returns {string} + */ +function headerNameToString (value) { + return headerNameLowerCasedRecord[value] || value.toLowerCase() +} + +function parseHeaders (headers, obj = {}) { + // For H2 support + if (!Array.isArray(headers)) return headers + + for (let i = 0; i < headers.length; i += 2) { + const key = headers[i].toString().toLowerCase() + let val = obj[key] + + if (!val) { + if (Array.isArray(headers[i + 1])) { + obj[key] = headers[i + 1].map(x => x.toString('utf8')) + } else { + obj[key] = headers[i + 1].toString('utf8') + } + } else { + if (!Array.isArray(val)) { + val = [val] + obj[key] = val + } + val.push(headers[i + 1].toString('utf8')) + } + } + + // See https://github.com/nodejs/node/pull/46528 + if ('content-length' in obj && 'content-disposition' in obj) { + obj['content-disposition'] = Buffer.from(obj['content-disposition']).toString('latin1') + } + + return obj +} + +function parseRawHeaders (headers) { + const ret = [] + let hasContentLength = false + let contentDispositionIdx = -1 + + for (let n = 0; n < headers.length; n += 2) { + const key = headers[n + 0].toString() + const val = headers[n + 1].toString('utf8') + + if (key.length === 14 && (key === 'content-length' || key.toLowerCase() === 'content-length')) { + ret.push(key, val) + hasContentLength = true + } else if (key.length === 19 && (key === 'content-disposition' || key.toLowerCase() === 'content-disposition')) { + contentDispositionIdx = ret.push(key, val) - 1 + } else { + ret.push(key, val) + } + } + + // See https://github.com/nodejs/node/pull/46528 + if (hasContentLength && contentDispositionIdx !== -1) { + ret[contentDispositionIdx] = Buffer.from(ret[contentDispositionIdx]).toString('latin1') + } + + return ret +} + +function isBuffer (buffer) { + // See, https://github.com/mcollina/undici/pull/319 + return buffer instanceof Uint8Array || Buffer.isBuffer(buffer) +} + +function validateHandler (handler, method, upgrade) { + if (!handler || typeof handler !== 'object') { + throw new InvalidArgumentError('handler must be an object') + } + + if (typeof handler.onConnect !== 'function') { + throw new InvalidArgumentError('invalid onConnect method') + } + + if (typeof handler.onError !== 'function') { + throw new InvalidArgumentError('invalid onError method') + } + + if (typeof handler.onBodySent !== 'function' && handler.onBodySent !== undefined) { + throw new InvalidArgumentError('invalid onBodySent method') + } + + if (upgrade || method === 'CONNECT') { + if (typeof handler.onUpgrade !== 'function') { + throw new InvalidArgumentError('invalid onUpgrade method') + } + } else { + if (typeof handler.onHeaders !== 'function') { + throw new InvalidArgumentError('invalid onHeaders method') + } + + if (typeof handler.onData !== 'function') { + throw new InvalidArgumentError('invalid onData method') + } + + if (typeof handler.onComplete !== 'function') { + throw new InvalidArgumentError('invalid onComplete method') + } + } +} + +// A body is disturbed if it has been read from and it cannot +// be re-used without losing state or data. +function isDisturbed (body) { + return !!(body && ( + stream.isDisturbed + ? stream.isDisturbed(body) || body[kBodyUsed] // TODO (fix): Why is body[kBodyUsed] needed? + : body[kBodyUsed] || + body.readableDidRead || + (body._readableState && body._readableState.dataEmitted) || + isReadableAborted(body) + )) +} + +function isErrored (body) { + return !!(body && ( + stream.isErrored + ? stream.isErrored(body) + : /state: 'errored'/.test(nodeUtil.inspect(body) + ))) +} + +function isReadable (body) { + return !!(body && ( + stream.isReadable + ? stream.isReadable(body) + : /state: 'readable'/.test(nodeUtil.inspect(body) + ))) +} + +function getSocketInfo (socket) { + return { + localAddress: socket.localAddress, + localPort: socket.localPort, + remoteAddress: socket.remoteAddress, + remotePort: socket.remotePort, + remoteFamily: socket.remoteFamily, + timeout: socket.timeout, + bytesWritten: socket.bytesWritten, + bytesRead: socket.bytesRead + } +} + +async function * convertIterableToBuffer (iterable) { + for await (const chunk of iterable) { + yield Buffer.isBuffer(chunk) ? chunk : Buffer.from(chunk) + } +} + +let ReadableStream +function ReadableStreamFrom (iterable) { + if (!ReadableStream) { + ReadableStream = (__nccwpck_require__(3774).ReadableStream) + } + + if (ReadableStream.from) { + return ReadableStream.from(convertIterableToBuffer(iterable)) + } + + let iterator + return new ReadableStream( + { + async start () { + iterator = iterable[Symbol.asyncIterator]() + }, + async pull (controller) { + const { done, value } = await iterator.next() + if (done) { + queueMicrotask(() => { + controller.close() + }) + } else { + const buf = Buffer.isBuffer(value) ? value : Buffer.from(value) + controller.enqueue(new Uint8Array(buf)) + } + return controller.desiredSize > 0 + }, + async cancel (reason) { + await iterator.return() + } + }, + 0 + ) +} + +// The chunk should be a FormData instance and contains +// all the required methods. +function isFormDataLike (object) { + return ( + object && + typeof object === 'object' && + typeof object.append === 'function' && + typeof object.delete === 'function' && + typeof object.get === 'function' && + typeof object.getAll === 'function' && + typeof object.has === 'function' && + typeof object.set === 'function' && + object[Symbol.toStringTag] === 'FormData' + ) +} + +function throwIfAborted (signal) { + if (!signal) { return } + if (typeof signal.throwIfAborted === 'function') { + signal.throwIfAborted() + } else { + if (signal.aborted) { + // DOMException not available < v17.0.0 + const err = new Error('The operation was aborted') + err.name = 'AbortError' + throw err + } + } +} + +function addAbortListener (signal, listener) { + if ('addEventListener' in signal) { + signal.addEventListener('abort', listener, { once: true }) + return () => signal.removeEventListener('abort', listener) + } + signal.addListener('abort', listener) + return () => signal.removeListener('abort', listener) +} + +const hasToWellFormed = !!String.prototype.toWellFormed + +/** + * @param {string} val + */ +function toUSVString (val) { + if (hasToWellFormed) { + return `${val}`.toWellFormed() + } else if (nodeUtil.toUSVString) { + return nodeUtil.toUSVString(val) + } + + return `${val}` +} + +// Parsed accordingly to RFC 9110 +// https://www.rfc-editor.org/rfc/rfc9110#field.content-range +function parseRangeHeader (range) { + if (range == null || range === '') return { start: 0, end: null, size: null } + + const m = range ? range.match(/^bytes (\d+)-(\d+)\/(\d+)?$/) : null + return m + ? { + start: parseInt(m[1]), + end: m[2] ? parseInt(m[2]) : null, + size: m[3] ? parseInt(m[3]) : null + } + : null +} + +const kEnumerableProperty = Object.create(null) +kEnumerableProperty.enumerable = true + +module.exports = { + kEnumerableProperty, + nop, + isDisturbed, + isErrored, + isReadable, + toUSVString, + isReadableAborted, + isBlobLike, + parseOrigin, + parseURL, + getServerName, + isStream, + isIterable, + isAsyncIterable, + isDestroyed, + headerNameToString, + parseRawHeaders, + parseHeaders, + parseKeepAliveTimeout, + destroy, + bodyLength, + deepClone, + ReadableStreamFrom, + isBuffer, + validateHandler, + getSocketInfo, + isFormDataLike, + buildURL, + throwIfAborted, + addAbortListener, + parseRangeHeader, + nodeMajor, + nodeMinor, + nodeHasAutoSelectFamily: nodeMajor > 18 || (nodeMajor === 18 && nodeMinor >= 13), + safeHTTPMethods: ['GET', 'HEAD', 'OPTIONS', 'TRACE'] +} + + +/***/ }), + +/***/ 1: +/***/ ((module, __unused_webpack_exports, __nccwpck_require__) => { + + + +const Dispatcher = __nccwpck_require__(992) +const { + ClientDestroyedError, + ClientClosedError, + InvalidArgumentError +} = __nccwpck_require__(8707) +const { kDestroy, kClose, kDispatch, kInterceptors } = __nccwpck_require__(6443) + +const kDestroyed = Symbol('destroyed') +const kClosed = Symbol('closed') +const kOnDestroyed = Symbol('onDestroyed') +const kOnClosed = Symbol('onClosed') +const kInterceptedDispatch = Symbol('Intercepted Dispatch') + +class DispatcherBase extends Dispatcher { + constructor () { + super() + + this[kDestroyed] = false + this[kOnDestroyed] = null + this[kClosed] = false + this[kOnClosed] = [] + } + + get destroyed () { + return this[kDestroyed] + } + + get closed () { + return this[kClosed] + } + + get interceptors () { + return this[kInterceptors] + } + + set interceptors (newInterceptors) { + if (newInterceptors) { + for (let i = newInterceptors.length - 1; i >= 0; i--) { + const interceptor = this[kInterceptors][i] + if (typeof interceptor !== 'function') { + throw new InvalidArgumentError('interceptor must be an function') + } + } + } + + this[kInterceptors] = newInterceptors + } + + close (callback) { + if (callback === undefined) { + return new Promise((resolve, reject) => { + this.close((err, data) => { + return err ? reject(err) : resolve(data) + }) + }) + } + + if (typeof callback !== 'function') { + throw new InvalidArgumentError('invalid callback') + } + + if (this[kDestroyed]) { + queueMicrotask(() => callback(new ClientDestroyedError(), null)) + return + } + + if (this[kClosed]) { + if (this[kOnClosed]) { + this[kOnClosed].push(callback) + } else { + queueMicrotask(() => callback(null, null)) + } + return + } + + this[kClosed] = true + this[kOnClosed].push(callback) + + const onClosed = () => { + const callbacks = this[kOnClosed] + this[kOnClosed] = null + for (let i = 0; i < callbacks.length; i++) { + callbacks[i](null, null) + } + } + + // Should not error. + this[kClose]() + .then(() => this.destroy()) + .then(() => { + queueMicrotask(onClosed) + }) + } + + destroy (err, callback) { + if (typeof err === 'function') { + callback = err + err = null + } + + if (callback === undefined) { + return new Promise((resolve, reject) => { + this.destroy(err, (err, data) => { + return err ? /* istanbul ignore next: should never error */ reject(err) : resolve(data) + }) + }) + } + + if (typeof callback !== 'function') { + throw new InvalidArgumentError('invalid callback') + } + + if (this[kDestroyed]) { + if (this[kOnDestroyed]) { + this[kOnDestroyed].push(callback) + } else { + queueMicrotask(() => callback(null, null)) + } + return + } + + if (!err) { + err = new ClientDestroyedError() + } + + this[kDestroyed] = true + this[kOnDestroyed] = this[kOnDestroyed] || [] + this[kOnDestroyed].push(callback) + + const onDestroyed = () => { + const callbacks = this[kOnDestroyed] + this[kOnDestroyed] = null + for (let i = 0; i < callbacks.length; i++) { + callbacks[i](null, null) + } + } + + // Should not error. + this[kDestroy](err).then(() => { + queueMicrotask(onDestroyed) + }) + } + + [kInterceptedDispatch] (opts, handler) { + if (!this[kInterceptors] || this[kInterceptors].length === 0) { + this[kInterceptedDispatch] = this[kDispatch] + return this[kDispatch](opts, handler) + } + + let dispatch = this[kDispatch].bind(this) + for (let i = this[kInterceptors].length - 1; i >= 0; i--) { + dispatch = this[kInterceptors][i](dispatch) + } + this[kInterceptedDispatch] = dispatch + return dispatch(opts, handler) + } + + dispatch (opts, handler) { + if (!handler || typeof handler !== 'object') { + throw new InvalidArgumentError('handler must be an object') + } + + try { + if (!opts || typeof opts !== 'object') { + throw new InvalidArgumentError('opts must be an object.') + } + + if (this[kDestroyed] || this[kOnDestroyed]) { + throw new ClientDestroyedError() + } + + if (this[kClosed]) { + throw new ClientClosedError() + } + + return this[kInterceptedDispatch](opts, handler) + } catch (err) { + if (typeof handler.onError !== 'function') { + throw new InvalidArgumentError('invalid onError method') + } + + handler.onError(err) + + return false + } + } +} + +module.exports = DispatcherBase + + +/***/ }), + +/***/ 992: +/***/ ((module, __unused_webpack_exports, __nccwpck_require__) => { + + + +const EventEmitter = __nccwpck_require__(4434) + +class Dispatcher extends EventEmitter { + dispatch () { + throw new Error('not implemented') + } + + close () { + throw new Error('not implemented') + } + + destroy () { + throw new Error('not implemented') + } +} + +module.exports = Dispatcher + + +/***/ }), + +/***/ 8923: +/***/ ((module, __unused_webpack_exports, __nccwpck_require__) => { + + + +const Busboy = __nccwpck_require__(9581) +const util = __nccwpck_require__(3440) +const { + ReadableStreamFrom, + isBlobLike, + isReadableStreamLike, + readableStreamClose, + createDeferredPromise, + fullyReadBody +} = __nccwpck_require__(5523) +const { FormData } = __nccwpck_require__(3073) +const { kState } = __nccwpck_require__(9710) +const { webidl } = __nccwpck_require__(4222) +const { DOMException, structuredClone } = __nccwpck_require__(7326) +const { Blob, File: NativeFile } = __nccwpck_require__(181) +const { kBodyUsed } = __nccwpck_require__(6443) +const assert = __nccwpck_require__(2613) +const { isErrored } = __nccwpck_require__(3440) +const { isUint8Array, isArrayBuffer } = __nccwpck_require__(8253) +const { File: UndiciFile } = __nccwpck_require__(3041) +const { parseMIMEType, serializeAMimeType } = __nccwpck_require__(4322) + +let ReadableStream = globalThis.ReadableStream + +/** @type {globalThis['File']} */ +const File = NativeFile ?? UndiciFile +const textEncoder = new TextEncoder() +const textDecoder = new TextDecoder() + +// https://fetch.spec.whatwg.org/#concept-bodyinit-extract +function extractBody (object, keepalive = false) { + if (!ReadableStream) { + ReadableStream = (__nccwpck_require__(3774).ReadableStream) + } + + // 1. Let stream be null. + let stream = null + + // 2. If object is a ReadableStream object, then set stream to object. + if (object instanceof ReadableStream) { + stream = object + } else if (isBlobLike(object)) { + // 3. Otherwise, if object is a Blob object, set stream to the + // result of running object’s get stream. + stream = object.stream() + } else { + // 4. Otherwise, set stream to a new ReadableStream object, and set + // up stream. + stream = new ReadableStream({ + async pull (controller) { + controller.enqueue( + typeof source === 'string' ? textEncoder.encode(source) : source + ) + queueMicrotask(() => readableStreamClose(controller)) + }, + start () {}, + type: undefined + }) + } + + // 5. Assert: stream is a ReadableStream object. + assert(isReadableStreamLike(stream)) + + // 6. Let action be null. + let action = null + + // 7. Let source be null. + let source = null + + // 8. Let length be null. + let length = null + + // 9. Let type be null. + let type = null + + // 10. Switch on object: + if (typeof object === 'string') { + // Set source to the UTF-8 encoding of object. + // Note: setting source to a Uint8Array here breaks some mocking assumptions. + source = object + + // Set type to `text/plain;charset=UTF-8`. + type = 'text/plain;charset=UTF-8' + } else if (object instanceof URLSearchParams) { + // URLSearchParams + + // spec says to run application/x-www-form-urlencoded on body.list + // this is implemented in Node.js as apart of an URLSearchParams instance toString method + // See: https://github.com/nodejs/node/blob/e46c680bf2b211bbd52cf959ca17ee98c7f657f5/lib/internal/url.js#L490 + // and https://github.com/nodejs/node/blob/e46c680bf2b211bbd52cf959ca17ee98c7f657f5/lib/internal/url.js#L1100 + + // Set source to the result of running the application/x-www-form-urlencoded serializer with object’s list. + source = object.toString() + + // Set type to `application/x-www-form-urlencoded;charset=UTF-8`. + type = 'application/x-www-form-urlencoded;charset=UTF-8' + } else if (isArrayBuffer(object)) { + // BufferSource/ArrayBuffer + + // Set source to a copy of the bytes held by object. + source = new Uint8Array(object.slice()) + } else if (ArrayBuffer.isView(object)) { + // BufferSource/ArrayBufferView + + // Set source to a copy of the bytes held by object. + source = new Uint8Array(object.buffer.slice(object.byteOffset, object.byteOffset + object.byteLength)) + } else if (util.isFormDataLike(object)) { + const boundary = `----formdata-undici-0${`${Math.floor(Math.random() * 1e11)}`.padStart(11, '0')}` + const prefix = `--${boundary}\r\nContent-Disposition: form-data` + + /*! formdata-polyfill. MIT License. Jimmy Wärting */ + const escape = (str) => + str.replace(/\n/g, '%0A').replace(/\r/g, '%0D').replace(/"/g, '%22') + const normalizeLinefeeds = (value) => value.replace(/\r?\n|\r/g, '\r\n') + + // Set action to this step: run the multipart/form-data + // encoding algorithm, with object’s entry list and UTF-8. + // - This ensures that the body is immutable and can't be changed afterwords + // - That the content-length is calculated in advance. + // - And that all parts are pre-encoded and ready to be sent. + + const blobParts = [] + const rn = new Uint8Array([13, 10]) // '\r\n' + length = 0 + let hasUnknownSizeValue = false + + for (const [name, value] of object) { + if (typeof value === 'string') { + const chunk = textEncoder.encode(prefix + + `; name="${escape(normalizeLinefeeds(name))}"` + + `\r\n\r\n${normalizeLinefeeds(value)}\r\n`) + blobParts.push(chunk) + length += chunk.byteLength + } else { + const chunk = textEncoder.encode(`${prefix}; name="${escape(normalizeLinefeeds(name))}"` + + (value.name ? `; filename="${escape(value.name)}"` : '') + '\r\n' + + `Content-Type: ${ + value.type || 'application/octet-stream' + }\r\n\r\n`) + blobParts.push(chunk, value, rn) + if (typeof value.size === 'number') { + length += chunk.byteLength + value.size + rn.byteLength + } else { + hasUnknownSizeValue = true + } + } + } + + const chunk = textEncoder.encode(`--${boundary}--`) + blobParts.push(chunk) + length += chunk.byteLength + if (hasUnknownSizeValue) { + length = null + } + + // Set source to object. + source = object + + action = async function * () { + for (const part of blobParts) { + if (part.stream) { + yield * part.stream() + } else { + yield part + } + } + } + + // Set type to `multipart/form-data; boundary=`, + // followed by the multipart/form-data boundary string generated + // by the multipart/form-data encoding algorithm. + type = 'multipart/form-data; boundary=' + boundary + } else if (isBlobLike(object)) { + // Blob + + // Set source to object. + source = object + + // Set length to object’s size. + length = object.size + + // If object’s type attribute is not the empty byte sequence, set + // type to its value. + if (object.type) { + type = object.type + } + } else if (typeof object[Symbol.asyncIterator] === 'function') { + // If keepalive is true, then throw a TypeError. + if (keepalive) { + throw new TypeError('keepalive') + } + + // If object is disturbed or locked, then throw a TypeError. + if (util.isDisturbed(object) || object.locked) { + throw new TypeError( + 'Response body object should not be disturbed or locked' + ) + } + + stream = + object instanceof ReadableStream ? object : ReadableStreamFrom(object) + } + + // 11. If source is a byte sequence, then set action to a + // step that returns source and length to source’s length. + if (typeof source === 'string' || util.isBuffer(source)) { + length = Buffer.byteLength(source) + } + + // 12. If action is non-null, then run these steps in in parallel: + if (action != null) { + // Run action. + let iterator + stream = new ReadableStream({ + async start () { + iterator = action(object)[Symbol.asyncIterator]() + }, + async pull (controller) { + const { value, done } = await iterator.next() + if (done) { + // When running action is done, close stream. + queueMicrotask(() => { + controller.close() + }) + } else { + // Whenever one or more bytes are available and stream is not errored, + // enqueue a Uint8Array wrapping an ArrayBuffer containing the available + // bytes into stream. + if (!isErrored(stream)) { + controller.enqueue(new Uint8Array(value)) + } + } + return controller.desiredSize > 0 + }, + async cancel (reason) { + await iterator.return() + }, + type: undefined + }) + } + + // 13. Let body be a body whose stream is stream, source is source, + // and length is length. + const body = { stream, source, length } + + // 14. Return (body, type). + return [body, type] +} + +// https://fetch.spec.whatwg.org/#bodyinit-safely-extract +function safelyExtractBody (object, keepalive = false) { + if (!ReadableStream) { + // istanbul ignore next + ReadableStream = (__nccwpck_require__(3774).ReadableStream) + } + + // To safely extract a body and a `Content-Type` value from + // a byte sequence or BodyInit object object, run these steps: + + // 1. If object is a ReadableStream object, then: + if (object instanceof ReadableStream) { + // Assert: object is neither disturbed nor locked. + // istanbul ignore next + assert(!util.isDisturbed(object), 'The body has already been consumed.') + // istanbul ignore next + assert(!object.locked, 'The stream is locked.') + } + + // 2. Return the results of extracting object. + return extractBody(object, keepalive) +} + +function cloneBody (body) { + // To clone a body body, run these steps: + + // https://fetch.spec.whatwg.org/#concept-body-clone + + // 1. Let « out1, out2 » be the result of teeing body’s stream. + const [out1, out2] = body.stream.tee() + const out2Clone = structuredClone(out2, { transfer: [out2] }) + // This, for whatever reasons, unrefs out2Clone which allows + // the process to exit by itself. + const [, finalClone] = out2Clone.tee() + + // 2. Set body’s stream to out1. + body.stream = out1 + + // 3. Return a body whose stream is out2 and other members are copied from body. + return { + stream: finalClone, + length: body.length, + source: body.source + } +} + +async function * consumeBody (body) { + if (body) { + if (isUint8Array(body)) { + yield body + } else { + const stream = body.stream + + if (util.isDisturbed(stream)) { + throw new TypeError('The body has already been consumed.') + } + + if (stream.locked) { + throw new TypeError('The stream is locked.') + } + + // Compat. + stream[kBodyUsed] = true + + yield * stream + } + } +} + +function throwIfAborted (state) { + if (state.aborted) { + throw new DOMException('The operation was aborted.', 'AbortError') + } +} + +function bodyMixinMethods (instance) { + const methods = { + blob () { + // The blob() method steps are to return the result of + // running consume body with this and the following step + // given a byte sequence bytes: return a Blob whose + // contents are bytes and whose type attribute is this’s + // MIME type. + return specConsumeBody(this, (bytes) => { + let mimeType = bodyMimeType(this) + + if (mimeType === 'failure') { + mimeType = '' + } else if (mimeType) { + mimeType = serializeAMimeType(mimeType) + } + + // Return a Blob whose contents are bytes and type attribute + // is mimeType. + return new Blob([bytes], { type: mimeType }) + }, instance) + }, + + arrayBuffer () { + // The arrayBuffer() method steps are to return the result + // of running consume body with this and the following step + // given a byte sequence bytes: return a new ArrayBuffer + // whose contents are bytes. + return specConsumeBody(this, (bytes) => { + return new Uint8Array(bytes).buffer + }, instance) + }, + + text () { + // The text() method steps are to return the result of running + // consume body with this and UTF-8 decode. + return specConsumeBody(this, utf8DecodeBytes, instance) + }, + + json () { + // The json() method steps are to return the result of running + // consume body with this and parse JSON from bytes. + return specConsumeBody(this, parseJSONFromBytes, instance) + }, + + async formData () { + webidl.brandCheck(this, instance) + + throwIfAborted(this[kState]) + + const contentType = this.headers.get('Content-Type') + + // If mimeType’s essence is "multipart/form-data", then: + if (/multipart\/form-data/.test(contentType)) { + const headers = {} + for (const [key, value] of this.headers) headers[key.toLowerCase()] = value + + const responseFormData = new FormData() + + let busboy + + try { + busboy = new Busboy({ + headers, + preservePath: true + }) + } catch (err) { + throw new DOMException(`${err}`, 'AbortError') + } + + busboy.on('field', (name, value) => { + responseFormData.append(name, value) + }) + busboy.on('file', (name, value, filename, encoding, mimeType) => { + const chunks = [] + + if (encoding === 'base64' || encoding.toLowerCase() === 'base64') { + let base64chunk = '' + + value.on('data', (chunk) => { + base64chunk += chunk.toString().replace(/[\r\n]/gm, '') + + const end = base64chunk.length - base64chunk.length % 4 + chunks.push(Buffer.from(base64chunk.slice(0, end), 'base64')) + + base64chunk = base64chunk.slice(end) + }) + value.on('end', () => { + chunks.push(Buffer.from(base64chunk, 'base64')) + responseFormData.append(name, new File(chunks, filename, { type: mimeType })) + }) + } else { + value.on('data', (chunk) => { + chunks.push(chunk) + }) + value.on('end', () => { + responseFormData.append(name, new File(chunks, filename, { type: mimeType })) + }) + } + }) + + const busboyResolve = new Promise((resolve, reject) => { + busboy.on('finish', resolve) + busboy.on('error', (err) => reject(new TypeError(err))) + }) + + if (this.body !== null) for await (const chunk of consumeBody(this[kState].body)) busboy.write(chunk) + busboy.end() + await busboyResolve + + return responseFormData + } else if (/application\/x-www-form-urlencoded/.test(contentType)) { + // Otherwise, if mimeType’s essence is "application/x-www-form-urlencoded", then: + + // 1. Let entries be the result of parsing bytes. + let entries + try { + let text = '' + // application/x-www-form-urlencoded parser will keep the BOM. + // https://url.spec.whatwg.org/#concept-urlencoded-parser + // Note that streaming decoder is stateful and cannot be reused + const streamingDecoder = new TextDecoder('utf-8', { ignoreBOM: true }) + + for await (const chunk of consumeBody(this[kState].body)) { + if (!isUint8Array(chunk)) { + throw new TypeError('Expected Uint8Array chunk') + } + text += streamingDecoder.decode(chunk, { stream: true }) + } + text += streamingDecoder.decode() + entries = new URLSearchParams(text) + } catch (err) { + // istanbul ignore next: Unclear when new URLSearchParams can fail on a string. + // 2. If entries is failure, then throw a TypeError. + throw Object.assign(new TypeError(), { cause: err }) + } + + // 3. Return a new FormData object whose entries are entries. + const formData = new FormData() + for (const [name, value] of entries) { + formData.append(name, value) + } + return formData + } else { + // Wait a tick before checking if the request has been aborted. + // Otherwise, a TypeError can be thrown when an AbortError should. + await Promise.resolve() + + throwIfAborted(this[kState]) + + // Otherwise, throw a TypeError. + throw webidl.errors.exception({ + header: `${instance.name}.formData`, + message: 'Could not parse content as FormData.' + }) + } + } + } + + return methods +} + +function mixinBody (prototype) { + Object.assign(prototype.prototype, bodyMixinMethods(prototype)) +} + +/** + * @see https://fetch.spec.whatwg.org/#concept-body-consume-body + * @param {Response|Request} object + * @param {(value: unknown) => unknown} convertBytesToJSValue + * @param {Response|Request} instance + */ +async function specConsumeBody (object, convertBytesToJSValue, instance) { + webidl.brandCheck(object, instance) + + throwIfAborted(object[kState]) + + // 1. If object is unusable, then return a promise rejected + // with a TypeError. + if (bodyUnusable(object[kState].body)) { + throw new TypeError('Body is unusable') + } + + // 2. Let promise be a new promise. + const promise = createDeferredPromise() + + // 3. Let errorSteps given error be to reject promise with error. + const errorSteps = (error) => promise.reject(error) + + // 4. Let successSteps given a byte sequence data be to resolve + // promise with the result of running convertBytesToJSValue + // with data. If that threw an exception, then run errorSteps + // with that exception. + const successSteps = (data) => { + try { + promise.resolve(convertBytesToJSValue(data)) + } catch (e) { + errorSteps(e) + } + } + + // 5. If object’s body is null, then run successSteps with an + // empty byte sequence. + if (object[kState].body == null) { + successSteps(new Uint8Array()) + return promise.promise + } + + // 6. Otherwise, fully read object’s body given successSteps, + // errorSteps, and object’s relevant global object. + await fullyReadBody(object[kState].body, successSteps, errorSteps) + + // 7. Return promise. + return promise.promise +} + +// https://fetch.spec.whatwg.org/#body-unusable +function bodyUnusable (body) { + // An object including the Body interface mixin is + // said to be unusable if its body is non-null and + // its body’s stream is disturbed or locked. + return body != null && (body.stream.locked || util.isDisturbed(body.stream)) +} + +/** + * @see https://encoding.spec.whatwg.org/#utf-8-decode + * @param {Buffer} buffer + */ +function utf8DecodeBytes (buffer) { + if (buffer.length === 0) { + return '' + } + + // 1. Let buffer be the result of peeking three bytes from + // ioQueue, converted to a byte sequence. + + // 2. If buffer is 0xEF 0xBB 0xBF, then read three + // bytes from ioQueue. (Do nothing with those bytes.) + if (buffer[0] === 0xEF && buffer[1] === 0xBB && buffer[2] === 0xBF) { + buffer = buffer.subarray(3) + } + + // 3. Process a queue with an instance of UTF-8’s + // decoder, ioQueue, output, and "replacement". + const output = textDecoder.decode(buffer) + + // 4. Return output. + return output +} + +/** + * @see https://infra.spec.whatwg.org/#parse-json-bytes-to-a-javascript-value + * @param {Uint8Array} bytes + */ +function parseJSONFromBytes (bytes) { + return JSON.parse(utf8DecodeBytes(bytes)) +} + +/** + * @see https://fetch.spec.whatwg.org/#concept-body-mime-type + * @param {import('./response').Response|import('./request').Request} object + */ +function bodyMimeType (object) { + const { headersList } = object[kState] + const contentType = headersList.get('content-type') + + if (contentType === null) { + return 'failure' + } + + return parseMIMEType(contentType) +} + +module.exports = { + extractBody, + safelyExtractBody, + cloneBody, + mixinBody +} + + +/***/ }), + +/***/ 7326: +/***/ ((module, __unused_webpack_exports, __nccwpck_require__) => { + + + +const { MessageChannel, receiveMessageOnPort } = __nccwpck_require__(8167) + +const corsSafeListedMethods = ['GET', 'HEAD', 'POST'] +const corsSafeListedMethodsSet = new Set(corsSafeListedMethods) + +const nullBodyStatus = [101, 204, 205, 304] + +const redirectStatus = [301, 302, 303, 307, 308] +const redirectStatusSet = new Set(redirectStatus) + +// https://fetch.spec.whatwg.org/#block-bad-port +const badPorts = [ + '1', '7', '9', '11', '13', '15', '17', '19', '20', '21', '22', '23', '25', '37', '42', '43', '53', '69', '77', '79', + '87', '95', '101', '102', '103', '104', '109', '110', '111', '113', '115', '117', '119', '123', '135', '137', + '139', '143', '161', '179', '389', '427', '465', '512', '513', '514', '515', '526', '530', '531', '532', + '540', '548', '554', '556', '563', '587', '601', '636', '989', '990', '993', '995', '1719', '1720', '1723', + '2049', '3659', '4045', '5060', '5061', '6000', '6566', '6665', '6666', '6667', '6668', '6669', '6697', + '10080' +] + +const badPortsSet = new Set(badPorts) + +// https://w3c.github.io/webappsec-referrer-policy/#referrer-policies +const referrerPolicy = [ + '', + 'no-referrer', + 'no-referrer-when-downgrade', + 'same-origin', + 'origin', + 'strict-origin', + 'origin-when-cross-origin', + 'strict-origin-when-cross-origin', + 'unsafe-url' +] +const referrerPolicySet = new Set(referrerPolicy) + +const requestRedirect = ['follow', 'manual', 'error'] + +const safeMethods = ['GET', 'HEAD', 'OPTIONS', 'TRACE'] +const safeMethodsSet = new Set(safeMethods) + +const requestMode = ['navigate', 'same-origin', 'no-cors', 'cors'] + +const requestCredentials = ['omit', 'same-origin', 'include'] + +const requestCache = [ + 'default', + 'no-store', + 'reload', + 'no-cache', + 'force-cache', + 'only-if-cached' +] + +// https://fetch.spec.whatwg.org/#request-body-header-name +const requestBodyHeader = [ + 'content-encoding', + 'content-language', + 'content-location', + 'content-type', + // See https://github.com/nodejs/undici/issues/2021 + // 'Content-Length' is a forbidden header name, which is typically + // removed in the Headers implementation. However, undici doesn't + // filter out headers, so we add it here. + 'content-length' +] + +// https://fetch.spec.whatwg.org/#enumdef-requestduplex +const requestDuplex = [ + 'half' +] + +// http://fetch.spec.whatwg.org/#forbidden-method +const forbiddenMethods = ['CONNECT', 'TRACE', 'TRACK'] +const forbiddenMethodsSet = new Set(forbiddenMethods) + +const subresource = [ + 'audio', + 'audioworklet', + 'font', + 'image', + 'manifest', + 'paintworklet', + 'script', + 'style', + 'track', + 'video', + 'xslt', + '' +] +const subresourceSet = new Set(subresource) + +/** @type {globalThis['DOMException']} */ +const DOMException = globalThis.DOMException ?? (() => { + // DOMException was only made a global in Node v17.0.0, + // but fetch supports >= v16.8. + try { + atob('~') + } catch (err) { + return Object.getPrototypeOf(err).constructor + } +})() + +let channel + +/** @type {globalThis['structuredClone']} */ +const structuredClone = + globalThis.structuredClone ?? + // https://github.com/nodejs/node/blob/b27ae24dcc4251bad726d9d84baf678d1f707fed/lib/internal/structured_clone.js + // structuredClone was added in v17.0.0, but fetch supports v16.8 + function structuredClone (value, options = undefined) { + if (arguments.length === 0) { + throw new TypeError('missing argument') + } + + if (!channel) { + channel = new MessageChannel() + } + channel.port1.unref() + channel.port2.unref() + channel.port1.postMessage(value, options?.transfer) + return receiveMessageOnPort(channel.port2).message + } + +module.exports = { + DOMException, + structuredClone, + subresource, + forbiddenMethods, + requestBodyHeader, + referrerPolicy, + requestRedirect, + requestMode, + requestCredentials, + requestCache, + redirectStatus, + corsSafeListedMethods, + nullBodyStatus, + safeMethods, + badPorts, + requestDuplex, + subresourceSet, + badPortsSet, + redirectStatusSet, + corsSafeListedMethodsSet, + safeMethodsSet, + forbiddenMethodsSet, + referrerPolicySet +} + + +/***/ }), + +/***/ 4322: +/***/ ((module, __unused_webpack_exports, __nccwpck_require__) => { + +const assert = __nccwpck_require__(2613) +const { atob } = __nccwpck_require__(181) +const { isomorphicDecode } = __nccwpck_require__(5523) + +const encoder = new TextEncoder() + +/** + * @see https://mimesniff.spec.whatwg.org/#http-token-code-point + */ +const HTTP_TOKEN_CODEPOINTS = /^[!#$%&'*+-.^_|~A-Za-z0-9]+$/ +const HTTP_WHITESPACE_REGEX = /(\u000A|\u000D|\u0009|\u0020)/ // eslint-disable-line +/** + * @see https://mimesniff.spec.whatwg.org/#http-quoted-string-token-code-point + */ +const HTTP_QUOTED_STRING_TOKENS = /[\u0009|\u0020-\u007E|\u0080-\u00FF]/ // eslint-disable-line + +// https://fetch.spec.whatwg.org/#data-url-processor +/** @param {URL} dataURL */ +function dataURLProcessor (dataURL) { + // 1. Assert: dataURL’s scheme is "data". + assert(dataURL.protocol === 'data:') + + // 2. Let input be the result of running the URL + // serializer on dataURL with exclude fragment + // set to true. + let input = URLSerializer(dataURL, true) + + // 3. Remove the leading "data:" string from input. + input = input.slice(5) + + // 4. Let position point at the start of input. + const position = { position: 0 } + + // 5. Let mimeType be the result of collecting a + // sequence of code points that are not equal + // to U+002C (,), given position. + let mimeType = collectASequenceOfCodePointsFast( + ',', + input, + position + ) + + // 6. Strip leading and trailing ASCII whitespace + // from mimeType. + // Undici implementation note: we need to store the + // length because if the mimetype has spaces removed, + // the wrong amount will be sliced from the input in + // step #9 + const mimeTypeLength = mimeType.length + mimeType = removeASCIIWhitespace(mimeType, true, true) + + // 7. If position is past the end of input, then + // return failure + if (position.position >= input.length) { + return 'failure' + } + + // 8. Advance position by 1. + position.position++ + + // 9. Let encodedBody be the remainder of input. + const encodedBody = input.slice(mimeTypeLength + 1) + + // 10. Let body be the percent-decoding of encodedBody. + let body = stringPercentDecode(encodedBody) + + // 11. If mimeType ends with U+003B (;), followed by + // zero or more U+0020 SPACE, followed by an ASCII + // case-insensitive match for "base64", then: + if (/;(\u0020){0,}base64$/i.test(mimeType)) { + // 1. Let stringBody be the isomorphic decode of body. + const stringBody = isomorphicDecode(body) + + // 2. Set body to the forgiving-base64 decode of + // stringBody. + body = forgivingBase64(stringBody) + + // 3. If body is failure, then return failure. + if (body === 'failure') { + return 'failure' + } + + // 4. Remove the last 6 code points from mimeType. + mimeType = mimeType.slice(0, -6) + + // 5. Remove trailing U+0020 SPACE code points from mimeType, + // if any. + mimeType = mimeType.replace(/(\u0020)+$/, '') + + // 6. Remove the last U+003B (;) code point from mimeType. + mimeType = mimeType.slice(0, -1) + } + + // 12. If mimeType starts with U+003B (;), then prepend + // "text/plain" to mimeType. + if (mimeType.startsWith(';')) { + mimeType = 'text/plain' + mimeType + } + + // 13. Let mimeTypeRecord be the result of parsing + // mimeType. + let mimeTypeRecord = parseMIMEType(mimeType) + + // 14. If mimeTypeRecord is failure, then set + // mimeTypeRecord to text/plain;charset=US-ASCII. + if (mimeTypeRecord === 'failure') { + mimeTypeRecord = parseMIMEType('text/plain;charset=US-ASCII') + } + + // 15. Return a new data: URL struct whose MIME + // type is mimeTypeRecord and body is body. + // https://fetch.spec.whatwg.org/#data-url-struct + return { mimeType: mimeTypeRecord, body } +} + +// https://url.spec.whatwg.org/#concept-url-serializer +/** + * @param {URL} url + * @param {boolean} excludeFragment + */ +function URLSerializer (url, excludeFragment = false) { + if (!excludeFragment) { + return url.href + } + + const href = url.href + const hashLength = url.hash.length + + return hashLength === 0 ? href : href.substring(0, href.length - hashLength) +} + +// https://infra.spec.whatwg.org/#collect-a-sequence-of-code-points +/** + * @param {(char: string) => boolean} condition + * @param {string} input + * @param {{ position: number }} position + */ +function collectASequenceOfCodePoints (condition, input, position) { + // 1. Let result be the empty string. + let result = '' + + // 2. While position doesn’t point past the end of input and the + // code point at position within input meets the condition condition: + while (position.position < input.length && condition(input[position.position])) { + // 1. Append that code point to the end of result. + result += input[position.position] + + // 2. Advance position by 1. + position.position++ + } + + // 3. Return result. + return result +} + +/** + * A faster collectASequenceOfCodePoints that only works when comparing a single character. + * @param {string} char + * @param {string} input + * @param {{ position: number }} position + */ +function collectASequenceOfCodePointsFast (char, input, position) { + const idx = input.indexOf(char, position.position) + const start = position.position + + if (idx === -1) { + position.position = input.length + return input.slice(start) + } + + position.position = idx + return input.slice(start, position.position) +} + +// https://url.spec.whatwg.org/#string-percent-decode +/** @param {string} input */ +function stringPercentDecode (input) { + // 1. Let bytes be the UTF-8 encoding of input. + const bytes = encoder.encode(input) + + // 2. Return the percent-decoding of bytes. + return percentDecode(bytes) +} + +// https://url.spec.whatwg.org/#percent-decode +/** @param {Uint8Array} input */ +function percentDecode (input) { + // 1. Let output be an empty byte sequence. + /** @type {number[]} */ + const output = [] + + // 2. For each byte byte in input: + for (let i = 0; i < input.length; i++) { + const byte = input[i] + + // 1. If byte is not 0x25 (%), then append byte to output. + if (byte !== 0x25) { + output.push(byte) + + // 2. Otherwise, if byte is 0x25 (%) and the next two bytes + // after byte in input are not in the ranges + // 0x30 (0) to 0x39 (9), 0x41 (A) to 0x46 (F), + // and 0x61 (a) to 0x66 (f), all inclusive, append byte + // to output. + } else if ( + byte === 0x25 && + !/^[0-9A-Fa-f]{2}$/i.test(String.fromCharCode(input[i + 1], input[i + 2])) + ) { + output.push(0x25) + + // 3. Otherwise: + } else { + // 1. Let bytePoint be the two bytes after byte in input, + // decoded, and then interpreted as hexadecimal number. + const nextTwoBytes = String.fromCharCode(input[i + 1], input[i + 2]) + const bytePoint = Number.parseInt(nextTwoBytes, 16) + + // 2. Append a byte whose value is bytePoint to output. + output.push(bytePoint) + + // 3. Skip the next two bytes in input. + i += 2 + } + } + + // 3. Return output. + return Uint8Array.from(output) +} + +// https://mimesniff.spec.whatwg.org/#parse-a-mime-type +/** @param {string} input */ +function parseMIMEType (input) { + // 1. Remove any leading and trailing HTTP whitespace + // from input. + input = removeHTTPWhitespace(input, true, true) + + // 2. Let position be a position variable for input, + // initially pointing at the start of input. + const position = { position: 0 } + + // 3. Let type be the result of collecting a sequence + // of code points that are not U+002F (/) from + // input, given position. + const type = collectASequenceOfCodePointsFast( + '/', + input, + position + ) + + // 4. If type is the empty string or does not solely + // contain HTTP token code points, then return failure. + // https://mimesniff.spec.whatwg.org/#http-token-code-point + if (type.length === 0 || !HTTP_TOKEN_CODEPOINTS.test(type)) { + return 'failure' + } + + // 5. If position is past the end of input, then return + // failure + if (position.position > input.length) { + return 'failure' + } + + // 6. Advance position by 1. (This skips past U+002F (/).) + position.position++ + + // 7. Let subtype be the result of collecting a sequence of + // code points that are not U+003B (;) from input, given + // position. + let subtype = collectASequenceOfCodePointsFast( + ';', + input, + position + ) + + // 8. Remove any trailing HTTP whitespace from subtype. + subtype = removeHTTPWhitespace(subtype, false, true) + + // 9. If subtype is the empty string or does not solely + // contain HTTP token code points, then return failure. + if (subtype.length === 0 || !HTTP_TOKEN_CODEPOINTS.test(subtype)) { + return 'failure' + } + + const typeLowercase = type.toLowerCase() + const subtypeLowercase = subtype.toLowerCase() + + // 10. Let mimeType be a new MIME type record whose type + // is type, in ASCII lowercase, and subtype is subtype, + // in ASCII lowercase. + // https://mimesniff.spec.whatwg.org/#mime-type + const mimeType = { + type: typeLowercase, + subtype: subtypeLowercase, + /** @type {Map} */ + parameters: new Map(), + // https://mimesniff.spec.whatwg.org/#mime-type-essence + essence: `${typeLowercase}/${subtypeLowercase}` + } + + // 11. While position is not past the end of input: + while (position.position < input.length) { + // 1. Advance position by 1. (This skips past U+003B (;).) + position.position++ + + // 2. Collect a sequence of code points that are HTTP + // whitespace from input given position. + collectASequenceOfCodePoints( + // https://fetch.spec.whatwg.org/#http-whitespace + char => HTTP_WHITESPACE_REGEX.test(char), + input, + position + ) + + // 3. Let parameterName be the result of collecting a + // sequence of code points that are not U+003B (;) + // or U+003D (=) from input, given position. + let parameterName = collectASequenceOfCodePoints( + (char) => char !== ';' && char !== '=', + input, + position + ) + + // 4. Set parameterName to parameterName, in ASCII + // lowercase. + parameterName = parameterName.toLowerCase() + + // 5. If position is not past the end of input, then: + if (position.position < input.length) { + // 1. If the code point at position within input is + // U+003B (;), then continue. + if (input[position.position] === ';') { + continue + } + + // 2. Advance position by 1. (This skips past U+003D (=).) + position.position++ + } + + // 6. If position is past the end of input, then break. + if (position.position > input.length) { + break + } + + // 7. Let parameterValue be null. + let parameterValue = null + + // 8. If the code point at position within input is + // U+0022 ("), then: + if (input[position.position] === '"') { + // 1. Set parameterValue to the result of collecting + // an HTTP quoted string from input, given position + // and the extract-value flag. + parameterValue = collectAnHTTPQuotedString(input, position, true) + + // 2. Collect a sequence of code points that are not + // U+003B (;) from input, given position. + collectASequenceOfCodePointsFast( + ';', + input, + position + ) + + // 9. Otherwise: + } else { + // 1. Set parameterValue to the result of collecting + // a sequence of code points that are not U+003B (;) + // from input, given position. + parameterValue = collectASequenceOfCodePointsFast( + ';', + input, + position + ) + + // 2. Remove any trailing HTTP whitespace from parameterValue. + parameterValue = removeHTTPWhitespace(parameterValue, false, true) + + // 3. If parameterValue is the empty string, then continue. + if (parameterValue.length === 0) { + continue + } + } + + // 10. If all of the following are true + // - parameterName is not the empty string + // - parameterName solely contains HTTP token code points + // - parameterValue solely contains HTTP quoted-string token code points + // - mimeType’s parameters[parameterName] does not exist + // then set mimeType’s parameters[parameterName] to parameterValue. + if ( + parameterName.length !== 0 && + HTTP_TOKEN_CODEPOINTS.test(parameterName) && + (parameterValue.length === 0 || HTTP_QUOTED_STRING_TOKENS.test(parameterValue)) && + !mimeType.parameters.has(parameterName) + ) { + mimeType.parameters.set(parameterName, parameterValue) + } + } + + // 12. Return mimeType. + return mimeType +} + +// https://infra.spec.whatwg.org/#forgiving-base64-decode +/** @param {string} data */ +function forgivingBase64 (data) { + // 1. Remove all ASCII whitespace from data. + data = data.replace(/[\u0009\u000A\u000C\u000D\u0020]/g, '') // eslint-disable-line + + // 2. If data’s code point length divides by 4 leaving + // no remainder, then: + if (data.length % 4 === 0) { + // 1. If data ends with one or two U+003D (=) code points, + // then remove them from data. + data = data.replace(/=?=$/, '') + } + + // 3. If data’s code point length divides by 4 leaving + // a remainder of 1, then return failure. + if (data.length % 4 === 1) { + return 'failure' + } + + // 4. If data contains a code point that is not one of + // U+002B (+) + // U+002F (/) + // ASCII alphanumeric + // then return failure. + if (/[^+/0-9A-Za-z]/.test(data)) { + return 'failure' + } + + const binary = atob(data) + const bytes = new Uint8Array(binary.length) + + for (let byte = 0; byte < binary.length; byte++) { + bytes[byte] = binary.charCodeAt(byte) + } + + return bytes +} + +// https://fetch.spec.whatwg.org/#collect-an-http-quoted-string +// tests: https://fetch.spec.whatwg.org/#example-http-quoted-string +/** + * @param {string} input + * @param {{ position: number }} position + * @param {boolean?} extractValue + */ +function collectAnHTTPQuotedString (input, position, extractValue) { + // 1. Let positionStart be position. + const positionStart = position.position + + // 2. Let value be the empty string. + let value = '' + + // 3. Assert: the code point at position within input + // is U+0022 ("). + assert(input[position.position] === '"') + + // 4. Advance position by 1. + position.position++ + + // 5. While true: + while (true) { + // 1. Append the result of collecting a sequence of code points + // that are not U+0022 (") or U+005C (\) from input, given + // position, to value. + value += collectASequenceOfCodePoints( + (char) => char !== '"' && char !== '\\', + input, + position + ) + + // 2. If position is past the end of input, then break. + if (position.position >= input.length) { + break + } + + // 3. Let quoteOrBackslash be the code point at position within + // input. + const quoteOrBackslash = input[position.position] + + // 4. Advance position by 1. + position.position++ + + // 5. If quoteOrBackslash is U+005C (\), then: + if (quoteOrBackslash === '\\') { + // 1. If position is past the end of input, then append + // U+005C (\) to value and break. + if (position.position >= input.length) { + value += '\\' + break + } + + // 2. Append the code point at position within input to value. + value += input[position.position] + + // 3. Advance position by 1. + position.position++ + + // 6. Otherwise: + } else { + // 1. Assert: quoteOrBackslash is U+0022 ("). + assert(quoteOrBackslash === '"') + + // 2. Break. + break + } + } + + // 6. If the extract-value flag is set, then return value. + if (extractValue) { + return value + } + + // 7. Return the code points from positionStart to position, + // inclusive, within input. + return input.slice(positionStart, position.position) +} + +/** + * @see https://mimesniff.spec.whatwg.org/#serialize-a-mime-type + */ +function serializeAMimeType (mimeType) { + assert(mimeType !== 'failure') + const { parameters, essence } = mimeType + + // 1. Let serialization be the concatenation of mimeType’s + // type, U+002F (/), and mimeType’s subtype. + let serialization = essence + + // 2. For each name → value of mimeType’s parameters: + for (let [name, value] of parameters.entries()) { + // 1. Append U+003B (;) to serialization. + serialization += ';' + + // 2. Append name to serialization. + serialization += name + + // 3. Append U+003D (=) to serialization. + serialization += '=' + + // 4. If value does not solely contain HTTP token code + // points or value is the empty string, then: + if (!HTTP_TOKEN_CODEPOINTS.test(value)) { + // 1. Precede each occurence of U+0022 (") or + // U+005C (\) in value with U+005C (\). + value = value.replace(/(\\|")/g, '\\$1') + + // 2. Prepend U+0022 (") to value. + value = '"' + value + + // 3. Append U+0022 (") to value. + value += '"' + } + + // 5. Append value to serialization. + serialization += value + } + + // 3. Return serialization. + return serialization +} + +/** + * @see https://fetch.spec.whatwg.org/#http-whitespace + * @param {string} char + */ +function isHTTPWhiteSpace (char) { + return char === '\r' || char === '\n' || char === '\t' || char === ' ' +} + +/** + * @see https://fetch.spec.whatwg.org/#http-whitespace + * @param {string} str + */ +function removeHTTPWhitespace (str, leading = true, trailing = true) { + let lead = 0 + let trail = str.length - 1 + + if (leading) { + for (; lead < str.length && isHTTPWhiteSpace(str[lead]); lead++); + } + + if (trailing) { + for (; trail > 0 && isHTTPWhiteSpace(str[trail]); trail--); + } + + return str.slice(lead, trail + 1) +} + +/** + * @see https://infra.spec.whatwg.org/#ascii-whitespace + * @param {string} char + */ +function isASCIIWhitespace (char) { + return char === '\r' || char === '\n' || char === '\t' || char === '\f' || char === ' ' +} + +/** + * @see https://infra.spec.whatwg.org/#strip-leading-and-trailing-ascii-whitespace + */ +function removeASCIIWhitespace (str, leading = true, trailing = true) { + let lead = 0 + let trail = str.length - 1 + + if (leading) { + for (; lead < str.length && isASCIIWhitespace(str[lead]); lead++); + } + + if (trailing) { + for (; trail > 0 && isASCIIWhitespace(str[trail]); trail--); + } + + return str.slice(lead, trail + 1) +} + +module.exports = { + dataURLProcessor, + URLSerializer, + collectASequenceOfCodePoints, + collectASequenceOfCodePointsFast, + stringPercentDecode, + parseMIMEType, + collectAnHTTPQuotedString, + serializeAMimeType +} + + +/***/ }), + +/***/ 3041: +/***/ ((module, __unused_webpack_exports, __nccwpck_require__) => { + + + +const { Blob, File: NativeFile } = __nccwpck_require__(181) +const { types } = __nccwpck_require__(9023) +const { kState } = __nccwpck_require__(9710) +const { isBlobLike } = __nccwpck_require__(5523) +const { webidl } = __nccwpck_require__(4222) +const { parseMIMEType, serializeAMimeType } = __nccwpck_require__(4322) +const { kEnumerableProperty } = __nccwpck_require__(3440) +const encoder = new TextEncoder() + +class File extends Blob { + constructor (fileBits, fileName, options = {}) { + // The File constructor is invoked with two or three parameters, depending + // on whether the optional dictionary parameter is used. When the File() + // constructor is invoked, user agents must run the following steps: + webidl.argumentLengthCheck(arguments, 2, { header: 'File constructor' }) + + fileBits = webidl.converters['sequence'](fileBits) + fileName = webidl.converters.USVString(fileName) + options = webidl.converters.FilePropertyBag(options) + + // 1. Let bytes be the result of processing blob parts given fileBits and + // options. + // Note: Blob handles this for us + + // 2. Let n be the fileName argument to the constructor. + const n = fileName + + // 3. Process FilePropertyBag dictionary argument by running the following + // substeps: + + // 1. If the type member is provided and is not the empty string, let t + // be set to the type dictionary member. If t contains any characters + // outside the range U+0020 to U+007E, then set t to the empty string + // and return from these substeps. + // 2. Convert every character in t to ASCII lowercase. + let t = options.type + let d + + // eslint-disable-next-line no-labels + substep: { + if (t) { + t = parseMIMEType(t) + + if (t === 'failure') { + t = '' + // eslint-disable-next-line no-labels + break substep + } + + t = serializeAMimeType(t).toLowerCase() + } + + // 3. If the lastModified member is provided, let d be set to the + // lastModified dictionary member. If it is not provided, set d to the + // current date and time represented as the number of milliseconds since + // the Unix Epoch (which is the equivalent of Date.now() [ECMA-262]). + d = options.lastModified + } + + // 4. Return a new File object F such that: + // F refers to the bytes byte sequence. + // F.size is set to the number of total bytes in bytes. + // F.name is set to n. + // F.type is set to t. + // F.lastModified is set to d. + + super(processBlobParts(fileBits, options), { type: t }) + this[kState] = { + name: n, + lastModified: d, + type: t + } + } + + get name () { + webidl.brandCheck(this, File) + + return this[kState].name + } + + get lastModified () { + webidl.brandCheck(this, File) + + return this[kState].lastModified + } + + get type () { + webidl.brandCheck(this, File) + + return this[kState].type + } +} + +class FileLike { + constructor (blobLike, fileName, options = {}) { + // TODO: argument idl type check + + // The File constructor is invoked with two or three parameters, depending + // on whether the optional dictionary parameter is used. When the File() + // constructor is invoked, user agents must run the following steps: + + // 1. Let bytes be the result of processing blob parts given fileBits and + // options. + + // 2. Let n be the fileName argument to the constructor. + const n = fileName + + // 3. Process FilePropertyBag dictionary argument by running the following + // substeps: + + // 1. If the type member is provided and is not the empty string, let t + // be set to the type dictionary member. If t contains any characters + // outside the range U+0020 to U+007E, then set t to the empty string + // and return from these substeps. + // TODO + const t = options.type + + // 2. Convert every character in t to ASCII lowercase. + // TODO + + // 3. If the lastModified member is provided, let d be set to the + // lastModified dictionary member. If it is not provided, set d to the + // current date and time represented as the number of milliseconds since + // the Unix Epoch (which is the equivalent of Date.now() [ECMA-262]). + const d = options.lastModified ?? Date.now() + + // 4. Return a new File object F such that: + // F refers to the bytes byte sequence. + // F.size is set to the number of total bytes in bytes. + // F.name is set to n. + // F.type is set to t. + // F.lastModified is set to d. + + this[kState] = { + blobLike, + name: n, + type: t, + lastModified: d + } + } + + stream (...args) { + webidl.brandCheck(this, FileLike) + + return this[kState].blobLike.stream(...args) + } + + arrayBuffer (...args) { + webidl.brandCheck(this, FileLike) + + return this[kState].blobLike.arrayBuffer(...args) + } + + slice (...args) { + webidl.brandCheck(this, FileLike) + + return this[kState].blobLike.slice(...args) + } + + text (...args) { + webidl.brandCheck(this, FileLike) + + return this[kState].blobLike.text(...args) + } + + get size () { + webidl.brandCheck(this, FileLike) + + return this[kState].blobLike.size + } + + get type () { + webidl.brandCheck(this, FileLike) + + return this[kState].blobLike.type + } + + get name () { + webidl.brandCheck(this, FileLike) + + return this[kState].name + } + + get lastModified () { + webidl.brandCheck(this, FileLike) + + return this[kState].lastModified + } + + get [Symbol.toStringTag] () { + return 'File' + } +} + +Object.defineProperties(File.prototype, { + [Symbol.toStringTag]: { + value: 'File', + configurable: true + }, + name: kEnumerableProperty, + lastModified: kEnumerableProperty +}) + +webidl.converters.Blob = webidl.interfaceConverter(Blob) + +webidl.converters.BlobPart = function (V, opts) { + if (webidl.util.Type(V) === 'Object') { + if (isBlobLike(V)) { + return webidl.converters.Blob(V, { strict: false }) + } + + if ( + ArrayBuffer.isView(V) || + types.isAnyArrayBuffer(V) + ) { + return webidl.converters.BufferSource(V, opts) + } + } + + return webidl.converters.USVString(V, opts) +} + +webidl.converters['sequence'] = webidl.sequenceConverter( + webidl.converters.BlobPart +) + +// https://www.w3.org/TR/FileAPI/#dfn-FilePropertyBag +webidl.converters.FilePropertyBag = webidl.dictionaryConverter([ + { + key: 'lastModified', + converter: webidl.converters['long long'], + get defaultValue () { + return Date.now() + } + }, + { + key: 'type', + converter: webidl.converters.DOMString, + defaultValue: '' + }, + { + key: 'endings', + converter: (value) => { + value = webidl.converters.DOMString(value) + value = value.toLowerCase() + + if (value !== 'native') { + value = 'transparent' + } + + return value + }, + defaultValue: 'transparent' + } +]) + +/** + * @see https://www.w3.org/TR/FileAPI/#process-blob-parts + * @param {(NodeJS.TypedArray|Blob|string)[]} parts + * @param {{ type: string, endings: string }} options + */ +function processBlobParts (parts, options) { + // 1. Let bytes be an empty sequence of bytes. + /** @type {NodeJS.TypedArray[]} */ + const bytes = [] + + // 2. For each element in parts: + for (const element of parts) { + // 1. If element is a USVString, run the following substeps: + if (typeof element === 'string') { + // 1. Let s be element. + let s = element + + // 2. If the endings member of options is "native", set s + // to the result of converting line endings to native + // of element. + if (options.endings === 'native') { + s = convertLineEndingsNative(s) + } + + // 3. Append the result of UTF-8 encoding s to bytes. + bytes.push(encoder.encode(s)) + } else if ( + types.isAnyArrayBuffer(element) || + types.isTypedArray(element) + ) { + // 2. If element is a BufferSource, get a copy of the + // bytes held by the buffer source, and append those + // bytes to bytes. + if (!element.buffer) { // ArrayBuffer + bytes.push(new Uint8Array(element)) + } else { + bytes.push( + new Uint8Array(element.buffer, element.byteOffset, element.byteLength) + ) + } + } else if (isBlobLike(element)) { + // 3. If element is a Blob, append the bytes it represents + // to bytes. + bytes.push(element) + } + } + + // 3. Return bytes. + return bytes +} + +/** + * @see https://www.w3.org/TR/FileAPI/#convert-line-endings-to-native + * @param {string} s + */ +function convertLineEndingsNative (s) { + // 1. Let native line ending be be the code point U+000A LF. + let nativeLineEnding = '\n' + + // 2. If the underlying platform’s conventions are to + // represent newlines as a carriage return and line feed + // sequence, set native line ending to the code point + // U+000D CR followed by the code point U+000A LF. + if (process.platform === 'win32') { + nativeLineEnding = '\r\n' + } + + return s.replace(/\r?\n/g, nativeLineEnding) +} + +// If this function is moved to ./util.js, some tools (such as +// rollup) will warn about circular dependencies. See: +// https://github.com/nodejs/undici/issues/1629 +function isFileLike (object) { + return ( + (NativeFile && object instanceof NativeFile) || + object instanceof File || ( + object && + (typeof object.stream === 'function' || + typeof object.arrayBuffer === 'function') && + object[Symbol.toStringTag] === 'File' + ) + ) +} + +module.exports = { File, FileLike, isFileLike } + + +/***/ }), + +/***/ 3073: +/***/ ((module, __unused_webpack_exports, __nccwpck_require__) => { + + + +const { isBlobLike, toUSVString, makeIterator } = __nccwpck_require__(5523) +const { kState } = __nccwpck_require__(9710) +const { File: UndiciFile, FileLike, isFileLike } = __nccwpck_require__(3041) +const { webidl } = __nccwpck_require__(4222) +const { Blob, File: NativeFile } = __nccwpck_require__(181) + +/** @type {globalThis['File']} */ +const File = NativeFile ?? UndiciFile + +// https://xhr.spec.whatwg.org/#formdata +class FormData { + constructor (form) { + if (form !== undefined) { + throw webidl.errors.conversionFailed({ + prefix: 'FormData constructor', + argument: 'Argument 1', + types: ['undefined'] + }) + } + + this[kState] = [] + } + + append (name, value, filename = undefined) { + webidl.brandCheck(this, FormData) + + webidl.argumentLengthCheck(arguments, 2, { header: 'FormData.append' }) + + if (arguments.length === 3 && !isBlobLike(value)) { + throw new TypeError( + "Failed to execute 'append' on 'FormData': parameter 2 is not of type 'Blob'" + ) + } + + // 1. Let value be value if given; otherwise blobValue. + + name = webidl.converters.USVString(name) + value = isBlobLike(value) + ? webidl.converters.Blob(value, { strict: false }) + : webidl.converters.USVString(value) + filename = arguments.length === 3 + ? webidl.converters.USVString(filename) + : undefined + + // 2. Let entry be the result of creating an entry with + // name, value, and filename if given. + const entry = makeEntry(name, value, filename) + + // 3. Append entry to this’s entry list. + this[kState].push(entry) + } + + delete (name) { + webidl.brandCheck(this, FormData) + + webidl.argumentLengthCheck(arguments, 1, { header: 'FormData.delete' }) + + name = webidl.converters.USVString(name) + + // The delete(name) method steps are to remove all entries whose name + // is name from this’s entry list. + this[kState] = this[kState].filter(entry => entry.name !== name) + } + + get (name) { + webidl.brandCheck(this, FormData) + + webidl.argumentLengthCheck(arguments, 1, { header: 'FormData.get' }) + + name = webidl.converters.USVString(name) + + // 1. If there is no entry whose name is name in this’s entry list, + // then return null. + const idx = this[kState].findIndex((entry) => entry.name === name) + if (idx === -1) { + return null + } + + // 2. Return the value of the first entry whose name is name from + // this’s entry list. + return this[kState][idx].value + } + + getAll (name) { + webidl.brandCheck(this, FormData) + + webidl.argumentLengthCheck(arguments, 1, { header: 'FormData.getAll' }) + + name = webidl.converters.USVString(name) + + // 1. If there is no entry whose name is name in this’s entry list, + // then return the empty list. + // 2. Return the values of all entries whose name is name, in order, + // from this’s entry list. + return this[kState] + .filter((entry) => entry.name === name) + .map((entry) => entry.value) + } + + has (name) { + webidl.brandCheck(this, FormData) + + webidl.argumentLengthCheck(arguments, 1, { header: 'FormData.has' }) + + name = webidl.converters.USVString(name) + + // The has(name) method steps are to return true if there is an entry + // whose name is name in this’s entry list; otherwise false. + return this[kState].findIndex((entry) => entry.name === name) !== -1 + } + + set (name, value, filename = undefined) { + webidl.brandCheck(this, FormData) + + webidl.argumentLengthCheck(arguments, 2, { header: 'FormData.set' }) + + if (arguments.length === 3 && !isBlobLike(value)) { + throw new TypeError( + "Failed to execute 'set' on 'FormData': parameter 2 is not of type 'Blob'" + ) + } + + // The set(name, value) and set(name, blobValue, filename) method steps + // are: + + // 1. Let value be value if given; otherwise blobValue. + + name = webidl.converters.USVString(name) + value = isBlobLike(value) + ? webidl.converters.Blob(value, { strict: false }) + : webidl.converters.USVString(value) + filename = arguments.length === 3 + ? toUSVString(filename) + : undefined + + // 2. Let entry be the result of creating an entry with name, value, and + // filename if given. + const entry = makeEntry(name, value, filename) + + // 3. If there are entries in this’s entry list whose name is name, then + // replace the first such entry with entry and remove the others. + const idx = this[kState].findIndex((entry) => entry.name === name) + if (idx !== -1) { + this[kState] = [ + ...this[kState].slice(0, idx), + entry, + ...this[kState].slice(idx + 1).filter((entry) => entry.name !== name) + ] + } else { + // 4. Otherwise, append entry to this’s entry list. + this[kState].push(entry) + } + } + + entries () { + webidl.brandCheck(this, FormData) + + return makeIterator( + () => this[kState].map(pair => [pair.name, pair.value]), + 'FormData', + 'key+value' + ) + } + + keys () { + webidl.brandCheck(this, FormData) + + return makeIterator( + () => this[kState].map(pair => [pair.name, pair.value]), + 'FormData', + 'key' + ) + } + + values () { + webidl.brandCheck(this, FormData) + + return makeIterator( + () => this[kState].map(pair => [pair.name, pair.value]), + 'FormData', + 'value' + ) + } + + /** + * @param {(value: string, key: string, self: FormData) => void} callbackFn + * @param {unknown} thisArg + */ + forEach (callbackFn, thisArg = globalThis) { + webidl.brandCheck(this, FormData) + + webidl.argumentLengthCheck(arguments, 1, { header: 'FormData.forEach' }) + + if (typeof callbackFn !== 'function') { + throw new TypeError( + "Failed to execute 'forEach' on 'FormData': parameter 1 is not of type 'Function'." + ) + } + + for (const [key, value] of this) { + callbackFn.apply(thisArg, [value, key, this]) + } + } +} + +FormData.prototype[Symbol.iterator] = FormData.prototype.entries + +Object.defineProperties(FormData.prototype, { + [Symbol.toStringTag]: { + value: 'FormData', + configurable: true + } +}) + +/** + * @see https://html.spec.whatwg.org/multipage/form-control-infrastructure.html#create-an-entry + * @param {string} name + * @param {string|Blob} value + * @param {?string} filename + * @returns + */ +function makeEntry (name, value, filename) { + // 1. Set name to the result of converting name into a scalar value string. + // "To convert a string into a scalar value string, replace any surrogates + // with U+FFFD." + // see: https://nodejs.org/dist/latest-v18.x/docs/api/buffer.html#buftostringencoding-start-end + name = Buffer.from(name).toString('utf8') + + // 2. If value is a string, then set value to the result of converting + // value into a scalar value string. + if (typeof value === 'string') { + value = Buffer.from(value).toString('utf8') + } else { + // 3. Otherwise: + + // 1. If value is not a File object, then set value to a new File object, + // representing the same bytes, whose name attribute value is "blob" + if (!isFileLike(value)) { + value = value instanceof Blob + ? new File([value], 'blob', { type: value.type }) + : new FileLike(value, 'blob', { type: value.type }) + } + + // 2. If filename is given, then set value to a new File object, + // representing the same bytes, whose name attribute is filename. + if (filename !== undefined) { + /** @type {FilePropertyBag} */ + const options = { + type: value.type, + lastModified: value.lastModified + } + + value = (NativeFile && value instanceof NativeFile) || value instanceof UndiciFile + ? new File([value], filename, options) + : new FileLike(value, filename, options) + } + } + + // 4. Return an entry whose name is name and whose value is value. + return { name, value } +} + +module.exports = { FormData } + + +/***/ }), + +/***/ 5628: +/***/ ((module) => { + + + +// In case of breaking changes, increase the version +// number to avoid conflicts. +const globalOrigin = Symbol.for('undici.globalOrigin.1') + +function getGlobalOrigin () { + return globalThis[globalOrigin] +} + +function setGlobalOrigin (newOrigin) { + if (newOrigin === undefined) { + Object.defineProperty(globalThis, globalOrigin, { + value: undefined, + writable: true, + enumerable: false, + configurable: false + }) + + return + } + + const parsedURL = new URL(newOrigin) + + if (parsedURL.protocol !== 'http:' && parsedURL.protocol !== 'https:') { + throw new TypeError(`Only http & https urls are allowed, received ${parsedURL.protocol}`) + } + + Object.defineProperty(globalThis, globalOrigin, { + value: parsedURL, + writable: true, + enumerable: false, + configurable: false + }) +} + +module.exports = { + getGlobalOrigin, + setGlobalOrigin +} + + +/***/ }), + +/***/ 6349: +/***/ ((module, __unused_webpack_exports, __nccwpck_require__) => { + +// https://github.com/Ethan-Arrowood/undici-fetch + + + +const { kHeadersList, kConstruct } = __nccwpck_require__(6443) +const { kGuard } = __nccwpck_require__(9710) +const { kEnumerableProperty } = __nccwpck_require__(3440) +const { + makeIterator, + isValidHeaderName, + isValidHeaderValue +} = __nccwpck_require__(5523) +const { webidl } = __nccwpck_require__(4222) +const assert = __nccwpck_require__(2613) + +const kHeadersMap = Symbol('headers map') +const kHeadersSortedMap = Symbol('headers map sorted') + +/** + * @param {number} code + */ +function isHTTPWhiteSpaceCharCode (code) { + return code === 0x00a || code === 0x00d || code === 0x009 || code === 0x020 +} + +/** + * @see https://fetch.spec.whatwg.org/#concept-header-value-normalize + * @param {string} potentialValue + */ +function headerValueNormalize (potentialValue) { + // To normalize a byte sequence potentialValue, remove + // any leading and trailing HTTP whitespace bytes from + // potentialValue. + let i = 0; let j = potentialValue.length + + while (j > i && isHTTPWhiteSpaceCharCode(potentialValue.charCodeAt(j - 1))) --j + while (j > i && isHTTPWhiteSpaceCharCode(potentialValue.charCodeAt(i))) ++i + + return i === 0 && j === potentialValue.length ? potentialValue : potentialValue.substring(i, j) +} + +function fill (headers, object) { + // To fill a Headers object headers with a given object object, run these steps: + + // 1. If object is a sequence, then for each header in object: + // Note: webidl conversion to array has already been done. + if (Array.isArray(object)) { + for (let i = 0; i < object.length; ++i) { + const header = object[i] + // 1. If header does not contain exactly two items, then throw a TypeError. + if (header.length !== 2) { + throw webidl.errors.exception({ + header: 'Headers constructor', + message: `expected name/value pair to be length 2, found ${header.length}.` + }) + } + + // 2. Append (header’s first item, header’s second item) to headers. + appendHeader(headers, header[0], header[1]) + } + } else if (typeof object === 'object' && object !== null) { + // Note: null should throw + + // 2. Otherwise, object is a record, then for each key → value in object, + // append (key, value) to headers + const keys = Object.keys(object) + for (let i = 0; i < keys.length; ++i) { + appendHeader(headers, keys[i], object[keys[i]]) + } + } else { + throw webidl.errors.conversionFailed({ + prefix: 'Headers constructor', + argument: 'Argument 1', + types: ['sequence>', 'record'] + }) + } +} + +/** + * @see https://fetch.spec.whatwg.org/#concept-headers-append + */ +function appendHeader (headers, name, value) { + // 1. Normalize value. + value = headerValueNormalize(value) + + // 2. If name is not a header name or value is not a + // header value, then throw a TypeError. + if (!isValidHeaderName(name)) { + throw webidl.errors.invalidArgument({ + prefix: 'Headers.append', + value: name, + type: 'header name' + }) + } else if (!isValidHeaderValue(value)) { + throw webidl.errors.invalidArgument({ + prefix: 'Headers.append', + value, + type: 'header value' + }) + } + + // 3. If headers’s guard is "immutable", then throw a TypeError. + // 4. Otherwise, if headers’s guard is "request" and name is a + // forbidden header name, return. + // Note: undici does not implement forbidden header names + if (headers[kGuard] === 'immutable') { + throw new TypeError('immutable') + } else if (headers[kGuard] === 'request-no-cors') { + // 5. Otherwise, if headers’s guard is "request-no-cors": + // TODO + } + + // 6. Otherwise, if headers’s guard is "response" and name is a + // forbidden response-header name, return. + + // 7. Append (name, value) to headers’s header list. + return headers[kHeadersList].append(name, value) + + // 8. If headers’s guard is "request-no-cors", then remove + // privileged no-CORS request headers from headers +} + +class HeadersList { + /** @type {[string, string][]|null} */ + cookies = null + + constructor (init) { + if (init instanceof HeadersList) { + this[kHeadersMap] = new Map(init[kHeadersMap]) + this[kHeadersSortedMap] = init[kHeadersSortedMap] + this.cookies = init.cookies === null ? null : [...init.cookies] + } else { + this[kHeadersMap] = new Map(init) + this[kHeadersSortedMap] = null + } + } + + // https://fetch.spec.whatwg.org/#header-list-contains + contains (name) { + // A header list list contains a header name name if list + // contains a header whose name is a byte-case-insensitive + // match for name. + name = name.toLowerCase() + + return this[kHeadersMap].has(name) + } + + clear () { + this[kHeadersMap].clear() + this[kHeadersSortedMap] = null + this.cookies = null + } + + // https://fetch.spec.whatwg.org/#concept-header-list-append + append (name, value) { + this[kHeadersSortedMap] = null + + // 1. If list contains name, then set name to the first such + // header’s name. + const lowercaseName = name.toLowerCase() + const exists = this[kHeadersMap].get(lowercaseName) + + // 2. Append (name, value) to list. + if (exists) { + const delimiter = lowercaseName === 'cookie' ? '; ' : ', ' + this[kHeadersMap].set(lowercaseName, { + name: exists.name, + value: `${exists.value}${delimiter}${value}` + }) + } else { + this[kHeadersMap].set(lowercaseName, { name, value }) + } + + if (lowercaseName === 'set-cookie') { + this.cookies ??= [] + this.cookies.push(value) + } + } + + // https://fetch.spec.whatwg.org/#concept-header-list-set + set (name, value) { + this[kHeadersSortedMap] = null + const lowercaseName = name.toLowerCase() + + if (lowercaseName === 'set-cookie') { + this.cookies = [value] + } + + // 1. If list contains name, then set the value of + // the first such header to value and remove the + // others. + // 2. Otherwise, append header (name, value) to list. + this[kHeadersMap].set(lowercaseName, { name, value }) + } + + // https://fetch.spec.whatwg.org/#concept-header-list-delete + delete (name) { + this[kHeadersSortedMap] = null + + name = name.toLowerCase() + + if (name === 'set-cookie') { + this.cookies = null + } + + this[kHeadersMap].delete(name) + } + + // https://fetch.spec.whatwg.org/#concept-header-list-get + get (name) { + const value = this[kHeadersMap].get(name.toLowerCase()) + + // 1. If list does not contain name, then return null. + // 2. Return the values of all headers in list whose name + // is a byte-case-insensitive match for name, + // separated from each other by 0x2C 0x20, in order. + return value === undefined ? null : value.value + } + + * [Symbol.iterator] () { + // use the lowercased name + for (const [name, { value }] of this[kHeadersMap]) { + yield [name, value] + } + } + + get entries () { + const headers = {} + + if (this[kHeadersMap].size) { + for (const { name, value } of this[kHeadersMap].values()) { + headers[name] = value + } + } + + return headers + } +} + +// https://fetch.spec.whatwg.org/#headers-class +class Headers { + constructor (init = undefined) { + if (init === kConstruct) { + return + } + this[kHeadersList] = new HeadersList() + + // The new Headers(init) constructor steps are: + + // 1. Set this’s guard to "none". + this[kGuard] = 'none' + + // 2. If init is given, then fill this with init. + if (init !== undefined) { + init = webidl.converters.HeadersInit(init) + fill(this, init) + } + } + + // https://fetch.spec.whatwg.org/#dom-headers-append + append (name, value) { + webidl.brandCheck(this, Headers) + + webidl.argumentLengthCheck(arguments, 2, { header: 'Headers.append' }) + + name = webidl.converters.ByteString(name) + value = webidl.converters.ByteString(value) + + return appendHeader(this, name, value) + } + + // https://fetch.spec.whatwg.org/#dom-headers-delete + delete (name) { + webidl.brandCheck(this, Headers) + + webidl.argumentLengthCheck(arguments, 1, { header: 'Headers.delete' }) + + name = webidl.converters.ByteString(name) + + // 1. If name is not a header name, then throw a TypeError. + if (!isValidHeaderName(name)) { + throw webidl.errors.invalidArgument({ + prefix: 'Headers.delete', + value: name, + type: 'header name' + }) + } + + // 2. If this’s guard is "immutable", then throw a TypeError. + // 3. Otherwise, if this’s guard is "request" and name is a + // forbidden header name, return. + // 4. Otherwise, if this’s guard is "request-no-cors", name + // is not a no-CORS-safelisted request-header name, and + // name is not a privileged no-CORS request-header name, + // return. + // 5. Otherwise, if this’s guard is "response" and name is + // a forbidden response-header name, return. + // Note: undici does not implement forbidden header names + if (this[kGuard] === 'immutable') { + throw new TypeError('immutable') + } else if (this[kGuard] === 'request-no-cors') { + // TODO + } + + // 6. If this’s header list does not contain name, then + // return. + if (!this[kHeadersList].contains(name)) { + return + } + + // 7. Delete name from this’s header list. + // 8. If this’s guard is "request-no-cors", then remove + // privileged no-CORS request headers from this. + this[kHeadersList].delete(name) + } + + // https://fetch.spec.whatwg.org/#dom-headers-get + get (name) { + webidl.brandCheck(this, Headers) + + webidl.argumentLengthCheck(arguments, 1, { header: 'Headers.get' }) + + name = webidl.converters.ByteString(name) + + // 1. If name is not a header name, then throw a TypeError. + if (!isValidHeaderName(name)) { + throw webidl.errors.invalidArgument({ + prefix: 'Headers.get', + value: name, + type: 'header name' + }) + } + + // 2. Return the result of getting name from this’s header + // list. + return this[kHeadersList].get(name) + } + + // https://fetch.spec.whatwg.org/#dom-headers-has + has (name) { + webidl.brandCheck(this, Headers) + + webidl.argumentLengthCheck(arguments, 1, { header: 'Headers.has' }) + + name = webidl.converters.ByteString(name) + + // 1. If name is not a header name, then throw a TypeError. + if (!isValidHeaderName(name)) { + throw webidl.errors.invalidArgument({ + prefix: 'Headers.has', + value: name, + type: 'header name' + }) + } + + // 2. Return true if this’s header list contains name; + // otherwise false. + return this[kHeadersList].contains(name) + } + + // https://fetch.spec.whatwg.org/#dom-headers-set + set (name, value) { + webidl.brandCheck(this, Headers) + + webidl.argumentLengthCheck(arguments, 2, { header: 'Headers.set' }) + + name = webidl.converters.ByteString(name) + value = webidl.converters.ByteString(value) + + // 1. Normalize value. + value = headerValueNormalize(value) + + // 2. If name is not a header name or value is not a + // header value, then throw a TypeError. + if (!isValidHeaderName(name)) { + throw webidl.errors.invalidArgument({ + prefix: 'Headers.set', + value: name, + type: 'header name' + }) + } else if (!isValidHeaderValue(value)) { + throw webidl.errors.invalidArgument({ + prefix: 'Headers.set', + value, + type: 'header value' + }) + } + + // 3. If this’s guard is "immutable", then throw a TypeError. + // 4. Otherwise, if this’s guard is "request" and name is a + // forbidden header name, return. + // 5. Otherwise, if this’s guard is "request-no-cors" and + // name/value is not a no-CORS-safelisted request-header, + // return. + // 6. Otherwise, if this’s guard is "response" and name is a + // forbidden response-header name, return. + // Note: undici does not implement forbidden header names + if (this[kGuard] === 'immutable') { + throw new TypeError('immutable') + } else if (this[kGuard] === 'request-no-cors') { + // TODO + } + + // 7. Set (name, value) in this’s header list. + // 8. If this’s guard is "request-no-cors", then remove + // privileged no-CORS request headers from this + this[kHeadersList].set(name, value) + } + + // https://fetch.spec.whatwg.org/#dom-headers-getsetcookie + getSetCookie () { + webidl.brandCheck(this, Headers) + + // 1. If this’s header list does not contain `Set-Cookie`, then return « ». + // 2. Return the values of all headers in this’s header list whose name is + // a byte-case-insensitive match for `Set-Cookie`, in order. + + const list = this[kHeadersList].cookies + + if (list) { + return [...list] + } + + return [] + } + + // https://fetch.spec.whatwg.org/#concept-header-list-sort-and-combine + get [kHeadersSortedMap] () { + if (this[kHeadersList][kHeadersSortedMap]) { + return this[kHeadersList][kHeadersSortedMap] + } + + // 1. Let headers be an empty list of headers with the key being the name + // and value the value. + const headers = [] + + // 2. Let names be the result of convert header names to a sorted-lowercase + // set with all the names of the headers in list. + const names = [...this[kHeadersList]].sort((a, b) => a[0] < b[0] ? -1 : 1) + const cookies = this[kHeadersList].cookies + + // 3. For each name of names: + for (let i = 0; i < names.length; ++i) { + const [name, value] = names[i] + // 1. If name is `set-cookie`, then: + if (name === 'set-cookie') { + // 1. Let values be a list of all values of headers in list whose name + // is a byte-case-insensitive match for name, in order. + + // 2. For each value of values: + // 1. Append (name, value) to headers. + for (let j = 0; j < cookies.length; ++j) { + headers.push([name, cookies[j]]) + } + } else { + // 2. Otherwise: + + // 1. Let value be the result of getting name from list. + + // 2. Assert: value is non-null. + assert(value !== null) + + // 3. Append (name, value) to headers. + headers.push([name, value]) + } + } + + this[kHeadersList][kHeadersSortedMap] = headers + + // 4. Return headers. + return headers + } + + keys () { + webidl.brandCheck(this, Headers) + + if (this[kGuard] === 'immutable') { + const value = this[kHeadersSortedMap] + return makeIterator(() => value, 'Headers', + 'key') + } + + return makeIterator( + () => [...this[kHeadersSortedMap].values()], + 'Headers', + 'key' + ) + } + + values () { + webidl.brandCheck(this, Headers) + + if (this[kGuard] === 'immutable') { + const value = this[kHeadersSortedMap] + return makeIterator(() => value, 'Headers', + 'value') + } + + return makeIterator( + () => [...this[kHeadersSortedMap].values()], + 'Headers', + 'value' + ) + } + + entries () { + webidl.brandCheck(this, Headers) + + if (this[kGuard] === 'immutable') { + const value = this[kHeadersSortedMap] + return makeIterator(() => value, 'Headers', + 'key+value') + } + + return makeIterator( + () => [...this[kHeadersSortedMap].values()], + 'Headers', + 'key+value' + ) + } + + /** + * @param {(value: string, key: string, self: Headers) => void} callbackFn + * @param {unknown} thisArg + */ + forEach (callbackFn, thisArg = globalThis) { + webidl.brandCheck(this, Headers) + + webidl.argumentLengthCheck(arguments, 1, { header: 'Headers.forEach' }) + + if (typeof callbackFn !== 'function') { + throw new TypeError( + "Failed to execute 'forEach' on 'Headers': parameter 1 is not of type 'Function'." + ) + } + + for (const [key, value] of this) { + callbackFn.apply(thisArg, [value, key, this]) + } + } + + [Symbol.for('nodejs.util.inspect.custom')] () { + webidl.brandCheck(this, Headers) + + return this[kHeadersList] + } +} + +Headers.prototype[Symbol.iterator] = Headers.prototype.entries + +Object.defineProperties(Headers.prototype, { + append: kEnumerableProperty, + delete: kEnumerableProperty, + get: kEnumerableProperty, + has: kEnumerableProperty, + set: kEnumerableProperty, + getSetCookie: kEnumerableProperty, + keys: kEnumerableProperty, + values: kEnumerableProperty, + entries: kEnumerableProperty, + forEach: kEnumerableProperty, + [Symbol.iterator]: { enumerable: false }, + [Symbol.toStringTag]: { + value: 'Headers', + configurable: true + } +}) + +webidl.converters.HeadersInit = function (V) { + if (webidl.util.Type(V) === 'Object') { + if (V[Symbol.iterator]) { + return webidl.converters['sequence>'](V) + } + + return webidl.converters['record'](V) + } + + throw webidl.errors.conversionFailed({ + prefix: 'Headers constructor', + argument: 'Argument 1', + types: ['sequence>', 'record'] + }) +} + +module.exports = { + fill, + Headers, + HeadersList +} + + +/***/ }), + +/***/ 2315: +/***/ ((module, __unused_webpack_exports, __nccwpck_require__) => { + +// https://github.com/Ethan-Arrowood/undici-fetch + + + +const { + Response, + makeNetworkError, + makeAppropriateNetworkError, + filterResponse, + makeResponse +} = __nccwpck_require__(8676) +const { Headers } = __nccwpck_require__(6349) +const { Request, makeRequest } = __nccwpck_require__(5194) +const zlib = __nccwpck_require__(3106) +const { + bytesMatch, + makePolicyContainer, + clonePolicyContainer, + requestBadPort, + TAOCheck, + appendRequestOriginHeader, + responseLocationURL, + requestCurrentURL, + setRequestReferrerPolicyOnRedirect, + tryUpgradeRequestToAPotentiallyTrustworthyURL, + createOpaqueTimingInfo, + appendFetchMetadata, + corsCheck, + crossOriginResourcePolicyCheck, + determineRequestsReferrer, + coarsenedSharedCurrentTime, + createDeferredPromise, + isBlobLike, + sameOrigin, + isCancelled, + isAborted, + isErrorLike, + fullyReadBody, + readableStreamClose, + isomorphicEncode, + urlIsLocal, + urlIsHttpHttpsScheme, + urlHasHttpsScheme +} = __nccwpck_require__(5523) +const { kState, kHeaders, kGuard, kRealm } = __nccwpck_require__(9710) +const assert = __nccwpck_require__(2613) +const { safelyExtractBody } = __nccwpck_require__(8923) +const { + redirectStatusSet, + nullBodyStatus, + safeMethodsSet, + requestBodyHeader, + subresourceSet, + DOMException +} = __nccwpck_require__(7326) +const { kHeadersList } = __nccwpck_require__(6443) +const EE = __nccwpck_require__(4434) +const { Readable, pipeline } = __nccwpck_require__(2203) +const { addAbortListener, isErrored, isReadable, nodeMajor, nodeMinor } = __nccwpck_require__(3440) +const { dataURLProcessor, serializeAMimeType } = __nccwpck_require__(4322) +const { TransformStream } = __nccwpck_require__(3774) +const { getGlobalDispatcher } = __nccwpck_require__(2581) +const { webidl } = __nccwpck_require__(4222) +const { STATUS_CODES } = __nccwpck_require__(8611) +const GET_OR_HEAD = ['GET', 'HEAD'] + +/** @type {import('buffer').resolveObjectURL} */ +let resolveObjectURL +let ReadableStream = globalThis.ReadableStream + +class Fetch extends EE { + constructor (dispatcher) { + super() + + this.dispatcher = dispatcher + this.connection = null + this.dump = false + this.state = 'ongoing' + // 2 terminated listeners get added per request, + // but only 1 gets removed. If there are 20 redirects, + // 21 listeners will be added. + // See https://github.com/nodejs/undici/issues/1711 + // TODO (fix): Find and fix root cause for leaked listener. + this.setMaxListeners(21) + } + + terminate (reason) { + if (this.state !== 'ongoing') { + return + } + + this.state = 'terminated' + this.connection?.destroy(reason) + this.emit('terminated', reason) + } + + // https://fetch.spec.whatwg.org/#fetch-controller-abort + abort (error) { + if (this.state !== 'ongoing') { + return + } + + // 1. Set controller’s state to "aborted". + this.state = 'aborted' + + // 2. Let fallbackError be an "AbortError" DOMException. + // 3. Set error to fallbackError if it is not given. + if (!error) { + error = new DOMException('The operation was aborted.', 'AbortError') + } + + // 4. Let serializedError be StructuredSerialize(error). + // If that threw an exception, catch it, and let + // serializedError be StructuredSerialize(fallbackError). + + // 5. Set controller’s serialized abort reason to serializedError. + this.serializedAbortReason = error + + this.connection?.destroy(error) + this.emit('terminated', error) + } +} + +// https://fetch.spec.whatwg.org/#fetch-method +function fetch (input, init = {}) { + webidl.argumentLengthCheck(arguments, 1, { header: 'globalThis.fetch' }) + + // 1. Let p be a new promise. + const p = createDeferredPromise() + + // 2. Let requestObject be the result of invoking the initial value of + // Request as constructor with input and init as arguments. If this throws + // an exception, reject p with it and return p. + let requestObject + + try { + requestObject = new Request(input, init) + } catch (e) { + p.reject(e) + return p.promise + } + + // 3. Let request be requestObject’s request. + const request = requestObject[kState] + + // 4. If requestObject’s signal’s aborted flag is set, then: + if (requestObject.signal.aborted) { + // 1. Abort the fetch() call with p, request, null, and + // requestObject’s signal’s abort reason. + abortFetch(p, request, null, requestObject.signal.reason) + + // 2. Return p. + return p.promise + } + + // 5. Let globalObject be request’s client’s global object. + const globalObject = request.client.globalObject + + // 6. If globalObject is a ServiceWorkerGlobalScope object, then set + // request’s service-workers mode to "none". + if (globalObject?.constructor?.name === 'ServiceWorkerGlobalScope') { + request.serviceWorkers = 'none' + } + + // 7. Let responseObject be null. + let responseObject = null + + // 8. Let relevantRealm be this’s relevant Realm. + const relevantRealm = null + + // 9. Let locallyAborted be false. + let locallyAborted = false + + // 10. Let controller be null. + let controller = null + + // 11. Add the following abort steps to requestObject’s signal: + addAbortListener( + requestObject.signal, + () => { + // 1. Set locallyAborted to true. + locallyAborted = true + + // 2. Assert: controller is non-null. + assert(controller != null) + + // 3. Abort controller with requestObject’s signal’s abort reason. + controller.abort(requestObject.signal.reason) + + // 4. Abort the fetch() call with p, request, responseObject, + // and requestObject’s signal’s abort reason. + abortFetch(p, request, responseObject, requestObject.signal.reason) + } + ) + + // 12. Let handleFetchDone given response response be to finalize and + // report timing with response, globalObject, and "fetch". + const handleFetchDone = (response) => + finalizeAndReportTiming(response, 'fetch') + + // 13. Set controller to the result of calling fetch given request, + // with processResponseEndOfBody set to handleFetchDone, and processResponse + // given response being these substeps: + + const processResponse = (response) => { + // 1. If locallyAborted is true, terminate these substeps. + if (locallyAborted) { + return Promise.resolve() + } + + // 2. If response’s aborted flag is set, then: + if (response.aborted) { + // 1. Let deserializedError be the result of deserialize a serialized + // abort reason given controller’s serialized abort reason and + // relevantRealm. + + // 2. Abort the fetch() call with p, request, responseObject, and + // deserializedError. + + abortFetch(p, request, responseObject, controller.serializedAbortReason) + return Promise.resolve() + } + + // 3. If response is a network error, then reject p with a TypeError + // and terminate these substeps. + if (response.type === 'error') { + p.reject( + Object.assign(new TypeError('fetch failed'), { cause: response.error }) + ) + return Promise.resolve() + } + + // 4. Set responseObject to the result of creating a Response object, + // given response, "immutable", and relevantRealm. + responseObject = new Response() + responseObject[kState] = response + responseObject[kRealm] = relevantRealm + responseObject[kHeaders][kHeadersList] = response.headersList + responseObject[kHeaders][kGuard] = 'immutable' + responseObject[kHeaders][kRealm] = relevantRealm + + // 5. Resolve p with responseObject. + p.resolve(responseObject) + } + + controller = fetching({ + request, + processResponseEndOfBody: handleFetchDone, + processResponse, + dispatcher: init.dispatcher ?? getGlobalDispatcher() // undici + }) + + // 14. Return p. + return p.promise +} + +// https://fetch.spec.whatwg.org/#finalize-and-report-timing +function finalizeAndReportTiming (response, initiatorType = 'other') { + // 1. If response is an aborted network error, then return. + if (response.type === 'error' && response.aborted) { + return + } + + // 2. If response’s URL list is null or empty, then return. + if (!response.urlList?.length) { + return + } + + // 3. Let originalURL be response’s URL list[0]. + const originalURL = response.urlList[0] + + // 4. Let timingInfo be response’s timing info. + let timingInfo = response.timingInfo + + // 5. Let cacheState be response’s cache state. + let cacheState = response.cacheState + + // 6. If originalURL’s scheme is not an HTTP(S) scheme, then return. + if (!urlIsHttpHttpsScheme(originalURL)) { + return + } + + // 7. If timingInfo is null, then return. + if (timingInfo === null) { + return + } + + // 8. If response’s timing allow passed flag is not set, then: + if (!response.timingAllowPassed) { + // 1. Set timingInfo to a the result of creating an opaque timing info for timingInfo. + timingInfo = createOpaqueTimingInfo({ + startTime: timingInfo.startTime + }) + + // 2. Set cacheState to the empty string. + cacheState = '' + } + + // 9. Set timingInfo’s end time to the coarsened shared current time + // given global’s relevant settings object’s cross-origin isolated + // capability. + // TODO: given global’s relevant settings object’s cross-origin isolated + // capability? + timingInfo.endTime = coarsenedSharedCurrentTime() + + // 10. Set response’s timing info to timingInfo. + response.timingInfo = timingInfo + + // 11. Mark resource timing for timingInfo, originalURL, initiatorType, + // global, and cacheState. + markResourceTiming( + timingInfo, + originalURL, + initiatorType, + globalThis, + cacheState + ) +} + +// https://w3c.github.io/resource-timing/#dfn-mark-resource-timing +function markResourceTiming (timingInfo, originalURL, initiatorType, globalThis, cacheState) { + if (nodeMajor > 18 || (nodeMajor === 18 && nodeMinor >= 2)) { + performance.markResourceTiming(timingInfo, originalURL.href, initiatorType, globalThis, cacheState) + } +} + +// https://fetch.spec.whatwg.org/#abort-fetch +function abortFetch (p, request, responseObject, error) { + // Note: AbortSignal.reason was added in node v17.2.0 + // which would give us an undefined error to reject with. + // Remove this once node v16 is no longer supported. + if (!error) { + error = new DOMException('The operation was aborted.', 'AbortError') + } + + // 1. Reject promise with error. + p.reject(error) + + // 2. If request’s body is not null and is readable, then cancel request’s + // body with error. + if (request.body != null && isReadable(request.body?.stream)) { + request.body.stream.cancel(error).catch((err) => { + if (err.code === 'ERR_INVALID_STATE') { + // Node bug? + return + } + throw err + }) + } + + // 3. If responseObject is null, then return. + if (responseObject == null) { + return + } + + // 4. Let response be responseObject’s response. + const response = responseObject[kState] + + // 5. If response’s body is not null and is readable, then error response’s + // body with error. + if (response.body != null && isReadable(response.body?.stream)) { + response.body.stream.cancel(error).catch((err) => { + if (err.code === 'ERR_INVALID_STATE') { + // Node bug? + return + } + throw err + }) + } +} + +// https://fetch.spec.whatwg.org/#fetching +function fetching ({ + request, + processRequestBodyChunkLength, + processRequestEndOfBody, + processResponse, + processResponseEndOfBody, + processResponseConsumeBody, + useParallelQueue = false, + dispatcher // undici +}) { + // 1. Let taskDestination be null. + let taskDestination = null + + // 2. Let crossOriginIsolatedCapability be false. + let crossOriginIsolatedCapability = false + + // 3. If request’s client is non-null, then: + if (request.client != null) { + // 1. Set taskDestination to request’s client’s global object. + taskDestination = request.client.globalObject + + // 2. Set crossOriginIsolatedCapability to request’s client’s cross-origin + // isolated capability. + crossOriginIsolatedCapability = + request.client.crossOriginIsolatedCapability + } + + // 4. If useParallelQueue is true, then set taskDestination to the result of + // starting a new parallel queue. + // TODO + + // 5. Let timingInfo be a new fetch timing info whose start time and + // post-redirect start time are the coarsened shared current time given + // crossOriginIsolatedCapability. + const currenTime = coarsenedSharedCurrentTime(crossOriginIsolatedCapability) + const timingInfo = createOpaqueTimingInfo({ + startTime: currenTime + }) + + // 6. Let fetchParams be a new fetch params whose + // request is request, + // timing info is timingInfo, + // process request body chunk length is processRequestBodyChunkLength, + // process request end-of-body is processRequestEndOfBody, + // process response is processResponse, + // process response consume body is processResponseConsumeBody, + // process response end-of-body is processResponseEndOfBody, + // task destination is taskDestination, + // and cross-origin isolated capability is crossOriginIsolatedCapability. + const fetchParams = { + controller: new Fetch(dispatcher), + request, + timingInfo, + processRequestBodyChunkLength, + processRequestEndOfBody, + processResponse, + processResponseConsumeBody, + processResponseEndOfBody, + taskDestination, + crossOriginIsolatedCapability + } + + // 7. If request’s body is a byte sequence, then set request’s body to + // request’s body as a body. + // NOTE: Since fetching is only called from fetch, body should already be + // extracted. + assert(!request.body || request.body.stream) + + // 8. If request’s window is "client", then set request’s window to request’s + // client, if request’s client’s global object is a Window object; otherwise + // "no-window". + if (request.window === 'client') { + // TODO: What if request.client is null? + request.window = + request.client?.globalObject?.constructor?.name === 'Window' + ? request.client + : 'no-window' + } + + // 9. If request’s origin is "client", then set request’s origin to request’s + // client’s origin. + if (request.origin === 'client') { + // TODO: What if request.client is null? + request.origin = request.client?.origin + } + + // 10. If all of the following conditions are true: + // TODO + + // 11. If request’s policy container is "client", then: + if (request.policyContainer === 'client') { + // 1. If request’s client is non-null, then set request’s policy + // container to a clone of request’s client’s policy container. [HTML] + if (request.client != null) { + request.policyContainer = clonePolicyContainer( + request.client.policyContainer + ) + } else { + // 2. Otherwise, set request’s policy container to a new policy + // container. + request.policyContainer = makePolicyContainer() + } + } + + // 12. If request’s header list does not contain `Accept`, then: + if (!request.headersList.contains('accept')) { + // 1. Let value be `*/*`. + const value = '*/*' + + // 2. A user agent should set value to the first matching statement, if + // any, switching on request’s destination: + // "document" + // "frame" + // "iframe" + // `text/html,application/xhtml+xml,application/xml;q=0.9,*/*;q=0.8` + // "image" + // `image/png,image/svg+xml,image/*;q=0.8,*/*;q=0.5` + // "style" + // `text/css,*/*;q=0.1` + // TODO + + // 3. Append `Accept`/value to request’s header list. + request.headersList.append('accept', value) + } + + // 13. If request’s header list does not contain `Accept-Language`, then + // user agents should append `Accept-Language`/an appropriate value to + // request’s header list. + if (!request.headersList.contains('accept-language')) { + request.headersList.append('accept-language', '*') + } + + // 14. If request’s priority is null, then use request’s initiator and + // destination appropriately in setting request’s priority to a + // user-agent-defined object. + if (request.priority === null) { + // TODO + } + + // 15. If request is a subresource request, then: + if (subresourceSet.has(request.destination)) { + // TODO + } + + // 16. Run main fetch given fetchParams. + mainFetch(fetchParams) + .catch(err => { + fetchParams.controller.terminate(err) + }) + + // 17. Return fetchParam's controller + return fetchParams.controller +} + +// https://fetch.spec.whatwg.org/#concept-main-fetch +async function mainFetch (fetchParams, recursive = false) { + // 1. Let request be fetchParams’s request. + const request = fetchParams.request + + // 2. Let response be null. + let response = null + + // 3. If request’s local-URLs-only flag is set and request’s current URL is + // not local, then set response to a network error. + if (request.localURLsOnly && !urlIsLocal(requestCurrentURL(request))) { + response = makeNetworkError('local URLs only') + } + + // 4. Run report Content Security Policy violations for request. + // TODO + + // 5. Upgrade request to a potentially trustworthy URL, if appropriate. + tryUpgradeRequestToAPotentiallyTrustworthyURL(request) + + // 6. If should request be blocked due to a bad port, should fetching request + // be blocked as mixed content, or should request be blocked by Content + // Security Policy returns blocked, then set response to a network error. + if (requestBadPort(request) === 'blocked') { + response = makeNetworkError('bad port') + } + // TODO: should fetching request be blocked as mixed content? + // TODO: should request be blocked by Content Security Policy? + + // 7. If request’s referrer policy is the empty string, then set request’s + // referrer policy to request’s policy container’s referrer policy. + if (request.referrerPolicy === '') { + request.referrerPolicy = request.policyContainer.referrerPolicy + } + + // 8. If request’s referrer is not "no-referrer", then set request’s + // referrer to the result of invoking determine request’s referrer. + if (request.referrer !== 'no-referrer') { + request.referrer = determineRequestsReferrer(request) + } + + // 9. Set request’s current URL’s scheme to "https" if all of the following + // conditions are true: + // - request’s current URL’s scheme is "http" + // - request’s current URL’s host is a domain + // - Matching request’s current URL’s host per Known HSTS Host Domain Name + // Matching results in either a superdomain match with an asserted + // includeSubDomains directive or a congruent match (with or without an + // asserted includeSubDomains directive). [HSTS] + // TODO + + // 10. If recursive is false, then run the remaining steps in parallel. + // TODO + + // 11. If response is null, then set response to the result of running + // the steps corresponding to the first matching statement: + if (response === null) { + response = await (async () => { + const currentURL = requestCurrentURL(request) + + if ( + // - request’s current URL’s origin is same origin with request’s origin, + // and request’s response tainting is "basic" + (sameOrigin(currentURL, request.url) && request.responseTainting === 'basic') || + // request’s current URL’s scheme is "data" + (currentURL.protocol === 'data:') || + // - request’s mode is "navigate" or "websocket" + (request.mode === 'navigate' || request.mode === 'websocket') + ) { + // 1. Set request’s response tainting to "basic". + request.responseTainting = 'basic' + + // 2. Return the result of running scheme fetch given fetchParams. + return await schemeFetch(fetchParams) + } + + // request’s mode is "same-origin" + if (request.mode === 'same-origin') { + // 1. Return a network error. + return makeNetworkError('request mode cannot be "same-origin"') + } + + // request’s mode is "no-cors" + if (request.mode === 'no-cors') { + // 1. If request’s redirect mode is not "follow", then return a network + // error. + if (request.redirect !== 'follow') { + return makeNetworkError( + 'redirect mode cannot be "follow" for "no-cors" request' + ) + } + + // 2. Set request’s response tainting to "opaque". + request.responseTainting = 'opaque' + + // 3. Return the result of running scheme fetch given fetchParams. + return await schemeFetch(fetchParams) + } + + // request’s current URL’s scheme is not an HTTP(S) scheme + if (!urlIsHttpHttpsScheme(requestCurrentURL(request))) { + // Return a network error. + return makeNetworkError('URL scheme must be a HTTP(S) scheme') + } + + // - request’s use-CORS-preflight flag is set + // - request’s unsafe-request flag is set and either request’s method is + // not a CORS-safelisted method or CORS-unsafe request-header names with + // request’s header list is not empty + // 1. Set request’s response tainting to "cors". + // 2. Let corsWithPreflightResponse be the result of running HTTP fetch + // given fetchParams and true. + // 3. If corsWithPreflightResponse is a network error, then clear cache + // entries using request. + // 4. Return corsWithPreflightResponse. + // TODO + + // Otherwise + // 1. Set request’s response tainting to "cors". + request.responseTainting = 'cors' + + // 2. Return the result of running HTTP fetch given fetchParams. + return await httpFetch(fetchParams) + })() + } + + // 12. If recursive is true, then return response. + if (recursive) { + return response + } + + // 13. If response is not a network error and response is not a filtered + // response, then: + if (response.status !== 0 && !response.internalResponse) { + // If request’s response tainting is "cors", then: + if (request.responseTainting === 'cors') { + // 1. Let headerNames be the result of extracting header list values + // given `Access-Control-Expose-Headers` and response’s header list. + // TODO + // 2. If request’s credentials mode is not "include" and headerNames + // contains `*`, then set response’s CORS-exposed header-name list to + // all unique header names in response’s header list. + // TODO + // 3. Otherwise, if headerNames is not null or failure, then set + // response’s CORS-exposed header-name list to headerNames. + // TODO + } + + // Set response to the following filtered response with response as its + // internal response, depending on request’s response tainting: + if (request.responseTainting === 'basic') { + response = filterResponse(response, 'basic') + } else if (request.responseTainting === 'cors') { + response = filterResponse(response, 'cors') + } else if (request.responseTainting === 'opaque') { + response = filterResponse(response, 'opaque') + } else { + assert(false) + } + } + + // 14. Let internalResponse be response, if response is a network error, + // and response’s internal response otherwise. + let internalResponse = + response.status === 0 ? response : response.internalResponse + + // 15. If internalResponse’s URL list is empty, then set it to a clone of + // request’s URL list. + if (internalResponse.urlList.length === 0) { + internalResponse.urlList.push(...request.urlList) + } + + // 16. If request’s timing allow failed flag is unset, then set + // internalResponse’s timing allow passed flag. + if (!request.timingAllowFailed) { + response.timingAllowPassed = true + } + + // 17. If response is not a network error and any of the following returns + // blocked + // - should internalResponse to request be blocked as mixed content + // - should internalResponse to request be blocked by Content Security Policy + // - should internalResponse to request be blocked due to its MIME type + // - should internalResponse to request be blocked due to nosniff + // TODO + + // 18. If response’s type is "opaque", internalResponse’s status is 206, + // internalResponse’s range-requested flag is set, and request’s header + // list does not contain `Range`, then set response and internalResponse + // to a network error. + if ( + response.type === 'opaque' && + internalResponse.status === 206 && + internalResponse.rangeRequested && + !request.headers.contains('range') + ) { + response = internalResponse = makeNetworkError() + } + + // 19. If response is not a network error and either request’s method is + // `HEAD` or `CONNECT`, or internalResponse’s status is a null body status, + // set internalResponse’s body to null and disregard any enqueuing toward + // it (if any). + if ( + response.status !== 0 && + (request.method === 'HEAD' || + request.method === 'CONNECT' || + nullBodyStatus.includes(internalResponse.status)) + ) { + internalResponse.body = null + fetchParams.controller.dump = true + } + + // 20. If request’s integrity metadata is not the empty string, then: + if (request.integrity) { + // 1. Let processBodyError be this step: run fetch finale given fetchParams + // and a network error. + const processBodyError = (reason) => + fetchFinale(fetchParams, makeNetworkError(reason)) + + // 2. If request’s response tainting is "opaque", or response’s body is null, + // then run processBodyError and abort these steps. + if (request.responseTainting === 'opaque' || response.body == null) { + processBodyError(response.error) + return + } + + // 3. Let processBody given bytes be these steps: + const processBody = (bytes) => { + // 1. If bytes do not match request’s integrity metadata, + // then run processBodyError and abort these steps. [SRI] + if (!bytesMatch(bytes, request.integrity)) { + processBodyError('integrity mismatch') + return + } + + // 2. Set response’s body to bytes as a body. + response.body = safelyExtractBody(bytes)[0] + + // 3. Run fetch finale given fetchParams and response. + fetchFinale(fetchParams, response) + } + + // 4. Fully read response’s body given processBody and processBodyError. + await fullyReadBody(response.body, processBody, processBodyError) + } else { + // 21. Otherwise, run fetch finale given fetchParams and response. + fetchFinale(fetchParams, response) + } +} + +// https://fetch.spec.whatwg.org/#concept-scheme-fetch +// given a fetch params fetchParams +function schemeFetch (fetchParams) { + // Note: since the connection is destroyed on redirect, which sets fetchParams to a + // cancelled state, we do not want this condition to trigger *unless* there have been + // no redirects. See https://github.com/nodejs/undici/issues/1776 + // 1. If fetchParams is canceled, then return the appropriate network error for fetchParams. + if (isCancelled(fetchParams) && fetchParams.request.redirectCount === 0) { + return Promise.resolve(makeAppropriateNetworkError(fetchParams)) + } + + // 2. Let request be fetchParams’s request. + const { request } = fetchParams + + const { protocol: scheme } = requestCurrentURL(request) + + // 3. Switch on request’s current URL’s scheme and run the associated steps: + switch (scheme) { + case 'about:': { + // If request’s current URL’s path is the string "blank", then return a new response + // whose status message is `OK`, header list is « (`Content-Type`, `text/html;charset=utf-8`) », + // and body is the empty byte sequence as a body. + + // Otherwise, return a network error. + return Promise.resolve(makeNetworkError('about scheme is not supported')) + } + case 'blob:': { + if (!resolveObjectURL) { + resolveObjectURL = (__nccwpck_require__(181).resolveObjectURL) + } + + // 1. Let blobURLEntry be request’s current URL’s blob URL entry. + const blobURLEntry = requestCurrentURL(request) + + // https://github.com/web-platform-tests/wpt/blob/7b0ebaccc62b566a1965396e5be7bb2bc06f841f/FileAPI/url/resources/fetch-tests.js#L52-L56 + // Buffer.resolveObjectURL does not ignore URL queries. + if (blobURLEntry.search.length !== 0) { + return Promise.resolve(makeNetworkError('NetworkError when attempting to fetch resource.')) + } + + const blobURLEntryObject = resolveObjectURL(blobURLEntry.toString()) + + // 2. If request’s method is not `GET`, blobURLEntry is null, or blobURLEntry’s + // object is not a Blob object, then return a network error. + if (request.method !== 'GET' || !isBlobLike(blobURLEntryObject)) { + return Promise.resolve(makeNetworkError('invalid method')) + } + + // 3. Let bodyWithType be the result of safely extracting blobURLEntry’s object. + const bodyWithType = safelyExtractBody(blobURLEntryObject) + + // 4. Let body be bodyWithType’s body. + const body = bodyWithType[0] + + // 5. Let length be body’s length, serialized and isomorphic encoded. + const length = isomorphicEncode(`${body.length}`) + + // 6. Let type be bodyWithType’s type if it is non-null; otherwise the empty byte sequence. + const type = bodyWithType[1] ?? '' + + // 7. Return a new response whose status message is `OK`, header list is + // « (`Content-Length`, length), (`Content-Type`, type) », and body is body. + const response = makeResponse({ + statusText: 'OK', + headersList: [ + ['content-length', { name: 'Content-Length', value: length }], + ['content-type', { name: 'Content-Type', value: type }] + ] + }) + + response.body = body + + return Promise.resolve(response) + } + case 'data:': { + // 1. Let dataURLStruct be the result of running the + // data: URL processor on request’s current URL. + const currentURL = requestCurrentURL(request) + const dataURLStruct = dataURLProcessor(currentURL) + + // 2. If dataURLStruct is failure, then return a + // network error. + if (dataURLStruct === 'failure') { + return Promise.resolve(makeNetworkError('failed to fetch the data URL')) + } + + // 3. Let mimeType be dataURLStruct’s MIME type, serialized. + const mimeType = serializeAMimeType(dataURLStruct.mimeType) + + // 4. Return a response whose status message is `OK`, + // header list is « (`Content-Type`, mimeType) », + // and body is dataURLStruct’s body as a body. + return Promise.resolve(makeResponse({ + statusText: 'OK', + headersList: [ + ['content-type', { name: 'Content-Type', value: mimeType }] + ], + body: safelyExtractBody(dataURLStruct.body)[0] + })) + } + case 'file:': { + // For now, unfortunate as it is, file URLs are left as an exercise for the reader. + // When in doubt, return a network error. + return Promise.resolve(makeNetworkError('not implemented... yet...')) + } + case 'http:': + case 'https:': { + // Return the result of running HTTP fetch given fetchParams. + + return httpFetch(fetchParams) + .catch((err) => makeNetworkError(err)) + } + default: { + return Promise.resolve(makeNetworkError('unknown scheme')) + } + } +} + +// https://fetch.spec.whatwg.org/#finalize-response +function finalizeResponse (fetchParams, response) { + // 1. Set fetchParams’s request’s done flag. + fetchParams.request.done = true + + // 2, If fetchParams’s process response done is not null, then queue a fetch + // task to run fetchParams’s process response done given response, with + // fetchParams’s task destination. + if (fetchParams.processResponseDone != null) { + queueMicrotask(() => fetchParams.processResponseDone(response)) + } +} + +// https://fetch.spec.whatwg.org/#fetch-finale +function fetchFinale (fetchParams, response) { + // 1. If response is a network error, then: + if (response.type === 'error') { + // 1. Set response’s URL list to « fetchParams’s request’s URL list[0] ». + response.urlList = [fetchParams.request.urlList[0]] + + // 2. Set response’s timing info to the result of creating an opaque timing + // info for fetchParams’s timing info. + response.timingInfo = createOpaqueTimingInfo({ + startTime: fetchParams.timingInfo.startTime + }) + } + + // 2. Let processResponseEndOfBody be the following steps: + const processResponseEndOfBody = () => { + // 1. Set fetchParams’s request’s done flag. + fetchParams.request.done = true + + // If fetchParams’s process response end-of-body is not null, + // then queue a fetch task to run fetchParams’s process response + // end-of-body given response with fetchParams’s task destination. + if (fetchParams.processResponseEndOfBody != null) { + queueMicrotask(() => fetchParams.processResponseEndOfBody(response)) + } + } + + // 3. If fetchParams’s process response is non-null, then queue a fetch task + // to run fetchParams’s process response given response, with fetchParams’s + // task destination. + if (fetchParams.processResponse != null) { + queueMicrotask(() => fetchParams.processResponse(response)) + } + + // 4. If response’s body is null, then run processResponseEndOfBody. + if (response.body == null) { + processResponseEndOfBody() + } else { + // 5. Otherwise: + + // 1. Let transformStream be a new a TransformStream. + + // 2. Let identityTransformAlgorithm be an algorithm which, given chunk, + // enqueues chunk in transformStream. + const identityTransformAlgorithm = (chunk, controller) => { + controller.enqueue(chunk) + } + + // 3. Set up transformStream with transformAlgorithm set to identityTransformAlgorithm + // and flushAlgorithm set to processResponseEndOfBody. + const transformStream = new TransformStream({ + start () {}, + transform: identityTransformAlgorithm, + flush: processResponseEndOfBody + }, { + size () { + return 1 + } + }, { + size () { + return 1 + } + }) + + // 4. Set response’s body to the result of piping response’s body through transformStream. + response.body = { stream: response.body.stream.pipeThrough(transformStream) } + } + + // 6. If fetchParams’s process response consume body is non-null, then: + if (fetchParams.processResponseConsumeBody != null) { + // 1. Let processBody given nullOrBytes be this step: run fetchParams’s + // process response consume body given response and nullOrBytes. + const processBody = (nullOrBytes) => fetchParams.processResponseConsumeBody(response, nullOrBytes) + + // 2. Let processBodyError be this step: run fetchParams’s process + // response consume body given response and failure. + const processBodyError = (failure) => fetchParams.processResponseConsumeBody(response, failure) + + // 3. If response’s body is null, then queue a fetch task to run processBody + // given null, with fetchParams’s task destination. + if (response.body == null) { + queueMicrotask(() => processBody(null)) + } else { + // 4. Otherwise, fully read response’s body given processBody, processBodyError, + // and fetchParams’s task destination. + return fullyReadBody(response.body, processBody, processBodyError) + } + return Promise.resolve() + } +} + +// https://fetch.spec.whatwg.org/#http-fetch +async function httpFetch (fetchParams) { + // 1. Let request be fetchParams’s request. + const request = fetchParams.request + + // 2. Let response be null. + let response = null + + // 3. Let actualResponse be null. + let actualResponse = null + + // 4. Let timingInfo be fetchParams’s timing info. + const timingInfo = fetchParams.timingInfo + + // 5. If request’s service-workers mode is "all", then: + if (request.serviceWorkers === 'all') { + // TODO + } + + // 6. If response is null, then: + if (response === null) { + // 1. If makeCORSPreflight is true and one of these conditions is true: + // TODO + + // 2. If request’s redirect mode is "follow", then set request’s + // service-workers mode to "none". + if (request.redirect === 'follow') { + request.serviceWorkers = 'none' + } + + // 3. Set response and actualResponse to the result of running + // HTTP-network-or-cache fetch given fetchParams. + actualResponse = response = await httpNetworkOrCacheFetch(fetchParams) + + // 4. If request’s response tainting is "cors" and a CORS check + // for request and response returns failure, then return a network error. + if ( + request.responseTainting === 'cors' && + corsCheck(request, response) === 'failure' + ) { + return makeNetworkError('cors failure') + } + + // 5. If the TAO check for request and response returns failure, then set + // request’s timing allow failed flag. + if (TAOCheck(request, response) === 'failure') { + request.timingAllowFailed = true + } + } + + // 7. If either request’s response tainting or response’s type + // is "opaque", and the cross-origin resource policy check with + // request’s origin, request’s client, request’s destination, + // and actualResponse returns blocked, then return a network error. + if ( + (request.responseTainting === 'opaque' || response.type === 'opaque') && + crossOriginResourcePolicyCheck( + request.origin, + request.client, + request.destination, + actualResponse + ) === 'blocked' + ) { + return makeNetworkError('blocked') + } + + // 8. If actualResponse’s status is a redirect status, then: + if (redirectStatusSet.has(actualResponse.status)) { + // 1. If actualResponse’s status is not 303, request’s body is not null, + // and the connection uses HTTP/2, then user agents may, and are even + // encouraged to, transmit an RST_STREAM frame. + // See, https://github.com/whatwg/fetch/issues/1288 + if (request.redirect !== 'manual') { + fetchParams.controller.connection.destroy() + } + + // 2. Switch on request’s redirect mode: + if (request.redirect === 'error') { + // Set response to a network error. + response = makeNetworkError('unexpected redirect') + } else if (request.redirect === 'manual') { + // Set response to an opaque-redirect filtered response whose internal + // response is actualResponse. + // NOTE(spec): On the web this would return an `opaqueredirect` response, + // but that doesn't make sense server side. + // See https://github.com/nodejs/undici/issues/1193. + response = actualResponse + } else if (request.redirect === 'follow') { + // Set response to the result of running HTTP-redirect fetch given + // fetchParams and response. + response = await httpRedirectFetch(fetchParams, response) + } else { + assert(false) + } + } + + // 9. Set response’s timing info to timingInfo. + response.timingInfo = timingInfo + + // 10. Return response. + return response +} + +// https://fetch.spec.whatwg.org/#http-redirect-fetch +function httpRedirectFetch (fetchParams, response) { + // 1. Let request be fetchParams’s request. + const request = fetchParams.request + + // 2. Let actualResponse be response, if response is not a filtered response, + // and response’s internal response otherwise. + const actualResponse = response.internalResponse + ? response.internalResponse + : response + + // 3. Let locationURL be actualResponse’s location URL given request’s current + // URL’s fragment. + let locationURL + + try { + locationURL = responseLocationURL( + actualResponse, + requestCurrentURL(request).hash + ) + + // 4. If locationURL is null, then return response. + if (locationURL == null) { + return response + } + } catch (err) { + // 5. If locationURL is failure, then return a network error. + return Promise.resolve(makeNetworkError(err)) + } + + // 6. If locationURL’s scheme is not an HTTP(S) scheme, then return a network + // error. + if (!urlIsHttpHttpsScheme(locationURL)) { + return Promise.resolve(makeNetworkError('URL scheme must be a HTTP(S) scheme')) + } + + // 7. If request’s redirect count is 20, then return a network error. + if (request.redirectCount === 20) { + return Promise.resolve(makeNetworkError('redirect count exceeded')) + } + + // 8. Increase request’s redirect count by 1. + request.redirectCount += 1 + + // 9. If request’s mode is "cors", locationURL includes credentials, and + // request’s origin is not same origin with locationURL’s origin, then return + // a network error. + if ( + request.mode === 'cors' && + (locationURL.username || locationURL.password) && + !sameOrigin(request, locationURL) + ) { + return Promise.resolve(makeNetworkError('cross origin not allowed for request mode "cors"')) + } + + // 10. If request’s response tainting is "cors" and locationURL includes + // credentials, then return a network error. + if ( + request.responseTainting === 'cors' && + (locationURL.username || locationURL.password) + ) { + return Promise.resolve(makeNetworkError( + 'URL cannot contain credentials for request mode "cors"' + )) + } + + // 11. If actualResponse’s status is not 303, request’s body is non-null, + // and request’s body’s source is null, then return a network error. + if ( + actualResponse.status !== 303 && + request.body != null && + request.body.source == null + ) { + return Promise.resolve(makeNetworkError()) + } + + // 12. If one of the following is true + // - actualResponse’s status is 301 or 302 and request’s method is `POST` + // - actualResponse’s status is 303 and request’s method is not `GET` or `HEAD` + if ( + ([301, 302].includes(actualResponse.status) && request.method === 'POST') || + (actualResponse.status === 303 && + !GET_OR_HEAD.includes(request.method)) + ) { + // then: + // 1. Set request’s method to `GET` and request’s body to null. + request.method = 'GET' + request.body = null + + // 2. For each headerName of request-body-header name, delete headerName from + // request’s header list. + for (const headerName of requestBodyHeader) { + request.headersList.delete(headerName) + } + } + + // 13. If request’s current URL’s origin is not same origin with locationURL’s + // origin, then for each headerName of CORS non-wildcard request-header name, + // delete headerName from request’s header list. + if (!sameOrigin(requestCurrentURL(request), locationURL)) { + // https://fetch.spec.whatwg.org/#cors-non-wildcard-request-header-name + request.headersList.delete('authorization') + + // https://fetch.spec.whatwg.org/#authentication-entries + request.headersList.delete('proxy-authorization', true) + + // "Cookie" and "Host" are forbidden request-headers, which undici doesn't implement. + request.headersList.delete('cookie') + request.headersList.delete('host') + } + + // 14. If request’s body is non-null, then set request’s body to the first return + // value of safely extracting request’s body’s source. + if (request.body != null) { + assert(request.body.source != null) + request.body = safelyExtractBody(request.body.source)[0] + } + + // 15. Let timingInfo be fetchParams’s timing info. + const timingInfo = fetchParams.timingInfo + + // 16. Set timingInfo’s redirect end time and post-redirect start time to the + // coarsened shared current time given fetchParams’s cross-origin isolated + // capability. + timingInfo.redirectEndTime = timingInfo.postRedirectStartTime = + coarsenedSharedCurrentTime(fetchParams.crossOriginIsolatedCapability) + + // 17. If timingInfo’s redirect start time is 0, then set timingInfo’s + // redirect start time to timingInfo’s start time. + if (timingInfo.redirectStartTime === 0) { + timingInfo.redirectStartTime = timingInfo.startTime + } + + // 18. Append locationURL to request’s URL list. + request.urlList.push(locationURL) + + // 19. Invoke set request’s referrer policy on redirect on request and + // actualResponse. + setRequestReferrerPolicyOnRedirect(request, actualResponse) + + // 20. Return the result of running main fetch given fetchParams and true. + return mainFetch(fetchParams, true) +} + +// https://fetch.spec.whatwg.org/#http-network-or-cache-fetch +async function httpNetworkOrCacheFetch ( + fetchParams, + isAuthenticationFetch = false, + isNewConnectionFetch = false +) { + // 1. Let request be fetchParams’s request. + const request = fetchParams.request + + // 2. Let httpFetchParams be null. + let httpFetchParams = null + + // 3. Let httpRequest be null. + let httpRequest = null + + // 4. Let response be null. + let response = null + + // 5. Let storedResponse be null. + // TODO: cache + + // 6. Let httpCache be null. + const httpCache = null + + // 7. Let the revalidatingFlag be unset. + const revalidatingFlag = false + + // 8. Run these steps, but abort when the ongoing fetch is terminated: + + // 1. If request’s window is "no-window" and request’s redirect mode is + // "error", then set httpFetchParams to fetchParams and httpRequest to + // request. + if (request.window === 'no-window' && request.redirect === 'error') { + httpFetchParams = fetchParams + httpRequest = request + } else { + // Otherwise: + + // 1. Set httpRequest to a clone of request. + httpRequest = makeRequest(request) + + // 2. Set httpFetchParams to a copy of fetchParams. + httpFetchParams = { ...fetchParams } + + // 3. Set httpFetchParams’s request to httpRequest. + httpFetchParams.request = httpRequest + } + + // 3. Let includeCredentials be true if one of + const includeCredentials = + request.credentials === 'include' || + (request.credentials === 'same-origin' && + request.responseTainting === 'basic') + + // 4. Let contentLength be httpRequest’s body’s length, if httpRequest’s + // body is non-null; otherwise null. + const contentLength = httpRequest.body ? httpRequest.body.length : null + + // 5. Let contentLengthHeaderValue be null. + let contentLengthHeaderValue = null + + // 6. If httpRequest’s body is null and httpRequest’s method is `POST` or + // `PUT`, then set contentLengthHeaderValue to `0`. + if ( + httpRequest.body == null && + ['POST', 'PUT'].includes(httpRequest.method) + ) { + contentLengthHeaderValue = '0' + } + + // 7. If contentLength is non-null, then set contentLengthHeaderValue to + // contentLength, serialized and isomorphic encoded. + if (contentLength != null) { + contentLengthHeaderValue = isomorphicEncode(`${contentLength}`) + } + + // 8. If contentLengthHeaderValue is non-null, then append + // `Content-Length`/contentLengthHeaderValue to httpRequest’s header + // list. + if (contentLengthHeaderValue != null) { + httpRequest.headersList.append('content-length', contentLengthHeaderValue) + } + + // 9. If contentLengthHeaderValue is non-null, then append (`Content-Length`, + // contentLengthHeaderValue) to httpRequest’s header list. + + // 10. If contentLength is non-null and httpRequest’s keepalive is true, + // then: + if (contentLength != null && httpRequest.keepalive) { + // NOTE: keepalive is a noop outside of browser context. + } + + // 11. If httpRequest’s referrer is a URL, then append + // `Referer`/httpRequest’s referrer, serialized and isomorphic encoded, + // to httpRequest’s header list. + if (httpRequest.referrer instanceof URL) { + httpRequest.headersList.append('referer', isomorphicEncode(httpRequest.referrer.href)) + } + + // 12. Append a request `Origin` header for httpRequest. + appendRequestOriginHeader(httpRequest) + + // 13. Append the Fetch metadata headers for httpRequest. [FETCH-METADATA] + appendFetchMetadata(httpRequest) + + // 14. If httpRequest’s header list does not contain `User-Agent`, then + // user agents should append `User-Agent`/default `User-Agent` value to + // httpRequest’s header list. + if (!httpRequest.headersList.contains('user-agent')) { + httpRequest.headersList.append('user-agent', typeof esbuildDetection === 'undefined' ? 'undici' : 'node') + } + + // 15. If httpRequest’s cache mode is "default" and httpRequest’s header + // list contains `If-Modified-Since`, `If-None-Match`, + // `If-Unmodified-Since`, `If-Match`, or `If-Range`, then set + // httpRequest’s cache mode to "no-store". + if ( + httpRequest.cache === 'default' && + (httpRequest.headersList.contains('if-modified-since') || + httpRequest.headersList.contains('if-none-match') || + httpRequest.headersList.contains('if-unmodified-since') || + httpRequest.headersList.contains('if-match') || + httpRequest.headersList.contains('if-range')) + ) { + httpRequest.cache = 'no-store' + } + + // 16. If httpRequest’s cache mode is "no-cache", httpRequest’s prevent + // no-cache cache-control header modification flag is unset, and + // httpRequest’s header list does not contain `Cache-Control`, then append + // `Cache-Control`/`max-age=0` to httpRequest’s header list. + if ( + httpRequest.cache === 'no-cache' && + !httpRequest.preventNoCacheCacheControlHeaderModification && + !httpRequest.headersList.contains('cache-control') + ) { + httpRequest.headersList.append('cache-control', 'max-age=0') + } + + // 17. If httpRequest’s cache mode is "no-store" or "reload", then: + if (httpRequest.cache === 'no-store' || httpRequest.cache === 'reload') { + // 1. If httpRequest’s header list does not contain `Pragma`, then append + // `Pragma`/`no-cache` to httpRequest’s header list. + if (!httpRequest.headersList.contains('pragma')) { + httpRequest.headersList.append('pragma', 'no-cache') + } + + // 2. If httpRequest’s header list does not contain `Cache-Control`, + // then append `Cache-Control`/`no-cache` to httpRequest’s header list. + if (!httpRequest.headersList.contains('cache-control')) { + httpRequest.headersList.append('cache-control', 'no-cache') + } + } + + // 18. If httpRequest’s header list contains `Range`, then append + // `Accept-Encoding`/`identity` to httpRequest’s header list. + if (httpRequest.headersList.contains('range')) { + httpRequest.headersList.append('accept-encoding', 'identity') + } + + // 19. Modify httpRequest’s header list per HTTP. Do not append a given + // header if httpRequest’s header list contains that header’s name. + // TODO: https://github.com/whatwg/fetch/issues/1285#issuecomment-896560129 + if (!httpRequest.headersList.contains('accept-encoding')) { + if (urlHasHttpsScheme(requestCurrentURL(httpRequest))) { + httpRequest.headersList.append('accept-encoding', 'br, gzip, deflate') + } else { + httpRequest.headersList.append('accept-encoding', 'gzip, deflate') + } + } + + httpRequest.headersList.delete('host') + + // 20. If includeCredentials is true, then: + if (includeCredentials) { + // 1. If the user agent is not configured to block cookies for httpRequest + // (see section 7 of [COOKIES]), then: + // TODO: credentials + // 2. If httpRequest’s header list does not contain `Authorization`, then: + // TODO: credentials + } + + // 21. If there’s a proxy-authentication entry, use it as appropriate. + // TODO: proxy-authentication + + // 22. Set httpCache to the result of determining the HTTP cache + // partition, given httpRequest. + // TODO: cache + + // 23. If httpCache is null, then set httpRequest’s cache mode to + // "no-store". + if (httpCache == null) { + httpRequest.cache = 'no-store' + } + + // 24. If httpRequest’s cache mode is neither "no-store" nor "reload", + // then: + if (httpRequest.mode !== 'no-store' && httpRequest.mode !== 'reload') { + // TODO: cache + } + + // 9. If aborted, then return the appropriate network error for fetchParams. + // TODO + + // 10. If response is null, then: + if (response == null) { + // 1. If httpRequest’s cache mode is "only-if-cached", then return a + // network error. + if (httpRequest.mode === 'only-if-cached') { + return makeNetworkError('only if cached') + } + + // 2. Let forwardResponse be the result of running HTTP-network fetch + // given httpFetchParams, includeCredentials, and isNewConnectionFetch. + const forwardResponse = await httpNetworkFetch( + httpFetchParams, + includeCredentials, + isNewConnectionFetch + ) + + // 3. If httpRequest’s method is unsafe and forwardResponse’s status is + // in the range 200 to 399, inclusive, invalidate appropriate stored + // responses in httpCache, as per the "Invalidation" chapter of HTTP + // Caching, and set storedResponse to null. [HTTP-CACHING] + if ( + !safeMethodsSet.has(httpRequest.method) && + forwardResponse.status >= 200 && + forwardResponse.status <= 399 + ) { + // TODO: cache + } + + // 4. If the revalidatingFlag is set and forwardResponse’s status is 304, + // then: + if (revalidatingFlag && forwardResponse.status === 304) { + // TODO: cache + } + + // 5. If response is null, then: + if (response == null) { + // 1. Set response to forwardResponse. + response = forwardResponse + + // 2. Store httpRequest and forwardResponse in httpCache, as per the + // "Storing Responses in Caches" chapter of HTTP Caching. [HTTP-CACHING] + // TODO: cache + } + } + + // 11. Set response’s URL list to a clone of httpRequest’s URL list. + response.urlList = [...httpRequest.urlList] + + // 12. If httpRequest’s header list contains `Range`, then set response’s + // range-requested flag. + if (httpRequest.headersList.contains('range')) { + response.rangeRequested = true + } + + // 13. Set response’s request-includes-credentials to includeCredentials. + response.requestIncludesCredentials = includeCredentials + + // 14. If response’s status is 401, httpRequest’s response tainting is not + // "cors", includeCredentials is true, and request’s window is an environment + // settings object, then: + // TODO + + // 15. If response’s status is 407, then: + if (response.status === 407) { + // 1. If request’s window is "no-window", then return a network error. + if (request.window === 'no-window') { + return makeNetworkError() + } + + // 2. ??? + + // 3. If fetchParams is canceled, then return the appropriate network error for fetchParams. + if (isCancelled(fetchParams)) { + return makeAppropriateNetworkError(fetchParams) + } + + // 4. Prompt the end user as appropriate in request’s window and store + // the result as a proxy-authentication entry. [HTTP-AUTH] + // TODO: Invoke some kind of callback? + + // 5. Set response to the result of running HTTP-network-or-cache fetch given + // fetchParams. + // TODO + return makeNetworkError('proxy authentication required') + } + + // 16. If all of the following are true + if ( + // response’s status is 421 + response.status === 421 && + // isNewConnectionFetch is false + !isNewConnectionFetch && + // request’s body is null, or request’s body is non-null and request’s body’s source is non-null + (request.body == null || request.body.source != null) + ) { + // then: + + // 1. If fetchParams is canceled, then return the appropriate network error for fetchParams. + if (isCancelled(fetchParams)) { + return makeAppropriateNetworkError(fetchParams) + } + + // 2. Set response to the result of running HTTP-network-or-cache + // fetch given fetchParams, isAuthenticationFetch, and true. + + // TODO (spec): The spec doesn't specify this but we need to cancel + // the active response before we can start a new one. + // https://github.com/whatwg/fetch/issues/1293 + fetchParams.controller.connection.destroy() + + response = await httpNetworkOrCacheFetch( + fetchParams, + isAuthenticationFetch, + true + ) + } + + // 17. If isAuthenticationFetch is true, then create an authentication entry + if (isAuthenticationFetch) { + // TODO + } + + // 18. Return response. + return response +} + +// https://fetch.spec.whatwg.org/#http-network-fetch +async function httpNetworkFetch ( + fetchParams, + includeCredentials = false, + forceNewConnection = false +) { + assert(!fetchParams.controller.connection || fetchParams.controller.connection.destroyed) + + fetchParams.controller.connection = { + abort: null, + destroyed: false, + destroy (err) { + if (!this.destroyed) { + this.destroyed = true + this.abort?.(err ?? new DOMException('The operation was aborted.', 'AbortError')) + } + } + } + + // 1. Let request be fetchParams’s request. + const request = fetchParams.request + + // 2. Let response be null. + let response = null + + // 3. Let timingInfo be fetchParams’s timing info. + const timingInfo = fetchParams.timingInfo + + // 4. Let httpCache be the result of determining the HTTP cache partition, + // given request. + // TODO: cache + const httpCache = null + + // 5. If httpCache is null, then set request’s cache mode to "no-store". + if (httpCache == null) { + request.cache = 'no-store' + } + + // 6. Let networkPartitionKey be the result of determining the network + // partition key given request. + // TODO + + // 7. Let newConnection be "yes" if forceNewConnection is true; otherwise + // "no". + const newConnection = forceNewConnection ? 'yes' : 'no' // eslint-disable-line no-unused-vars + + // 8. Switch on request’s mode: + if (request.mode === 'websocket') { + // Let connection be the result of obtaining a WebSocket connection, + // given request’s current URL. + // TODO + } else { + // Let connection be the result of obtaining a connection, given + // networkPartitionKey, request’s current URL’s origin, + // includeCredentials, and forceNewConnection. + // TODO + } + + // 9. Run these steps, but abort when the ongoing fetch is terminated: + + // 1. If connection is failure, then return a network error. + + // 2. Set timingInfo’s final connection timing info to the result of + // calling clamp and coarsen connection timing info with connection’s + // timing info, timingInfo’s post-redirect start time, and fetchParams’s + // cross-origin isolated capability. + + // 3. If connection is not an HTTP/2 connection, request’s body is non-null, + // and request’s body’s source is null, then append (`Transfer-Encoding`, + // `chunked`) to request’s header list. + + // 4. Set timingInfo’s final network-request start time to the coarsened + // shared current time given fetchParams’s cross-origin isolated + // capability. + + // 5. Set response to the result of making an HTTP request over connection + // using request with the following caveats: + + // - Follow the relevant requirements from HTTP. [HTTP] [HTTP-SEMANTICS] + // [HTTP-COND] [HTTP-CACHING] [HTTP-AUTH] + + // - If request’s body is non-null, and request’s body’s source is null, + // then the user agent may have a buffer of up to 64 kibibytes and store + // a part of request’s body in that buffer. If the user agent reads from + // request’s body beyond that buffer’s size and the user agent needs to + // resend request, then instead return a network error. + + // - Set timingInfo’s final network-response start time to the coarsened + // shared current time given fetchParams’s cross-origin isolated capability, + // immediately after the user agent’s HTTP parser receives the first byte + // of the response (e.g., frame header bytes for HTTP/2 or response status + // line for HTTP/1.x). + + // - Wait until all the headers are transmitted. + + // - Any responses whose status is in the range 100 to 199, inclusive, + // and is not 101, are to be ignored, except for the purposes of setting + // timingInfo’s final network-response start time above. + + // - If request’s header list contains `Transfer-Encoding`/`chunked` and + // response is transferred via HTTP/1.0 or older, then return a network + // error. + + // - If the HTTP request results in a TLS client certificate dialog, then: + + // 1. If request’s window is an environment settings object, make the + // dialog available in request’s window. + + // 2. Otherwise, return a network error. + + // To transmit request’s body body, run these steps: + let requestBody = null + // 1. If body is null and fetchParams’s process request end-of-body is + // non-null, then queue a fetch task given fetchParams’s process request + // end-of-body and fetchParams’s task destination. + if (request.body == null && fetchParams.processRequestEndOfBody) { + queueMicrotask(() => fetchParams.processRequestEndOfBody()) + } else if (request.body != null) { + // 2. Otherwise, if body is non-null: + + // 1. Let processBodyChunk given bytes be these steps: + const processBodyChunk = async function * (bytes) { + // 1. If the ongoing fetch is terminated, then abort these steps. + if (isCancelled(fetchParams)) { + return + } + + // 2. Run this step in parallel: transmit bytes. + yield bytes + + // 3. If fetchParams’s process request body is non-null, then run + // fetchParams’s process request body given bytes’s length. + fetchParams.processRequestBodyChunkLength?.(bytes.byteLength) + } + + // 2. Let processEndOfBody be these steps: + const processEndOfBody = () => { + // 1. If fetchParams is canceled, then abort these steps. + if (isCancelled(fetchParams)) { + return + } + + // 2. If fetchParams’s process request end-of-body is non-null, + // then run fetchParams’s process request end-of-body. + if (fetchParams.processRequestEndOfBody) { + fetchParams.processRequestEndOfBody() + } + } + + // 3. Let processBodyError given e be these steps: + const processBodyError = (e) => { + // 1. If fetchParams is canceled, then abort these steps. + if (isCancelled(fetchParams)) { + return + } + + // 2. If e is an "AbortError" DOMException, then abort fetchParams’s controller. + if (e.name === 'AbortError') { + fetchParams.controller.abort() + } else { + fetchParams.controller.terminate(e) + } + } + + // 4. Incrementally read request’s body given processBodyChunk, processEndOfBody, + // processBodyError, and fetchParams’s task destination. + requestBody = (async function * () { + try { + for await (const bytes of request.body.stream) { + yield * processBodyChunk(bytes) + } + processEndOfBody() + } catch (err) { + processBodyError(err) + } + })() + } + + try { + // socket is only provided for websockets + const { body, status, statusText, headersList, socket } = await dispatch({ body: requestBody }) + + if (socket) { + response = makeResponse({ status, statusText, headersList, socket }) + } else { + const iterator = body[Symbol.asyncIterator]() + fetchParams.controller.next = () => iterator.next() + + response = makeResponse({ status, statusText, headersList }) + } + } catch (err) { + // 10. If aborted, then: + if (err.name === 'AbortError') { + // 1. If connection uses HTTP/2, then transmit an RST_STREAM frame. + fetchParams.controller.connection.destroy() + + // 2. Return the appropriate network error for fetchParams. + return makeAppropriateNetworkError(fetchParams, err) + } + + return makeNetworkError(err) + } + + // 11. Let pullAlgorithm be an action that resumes the ongoing fetch + // if it is suspended. + const pullAlgorithm = () => { + fetchParams.controller.resume() + } + + // 12. Let cancelAlgorithm be an algorithm that aborts fetchParams’s + // controller with reason, given reason. + const cancelAlgorithm = (reason) => { + fetchParams.controller.abort(reason) + } + + // 13. Let highWaterMark be a non-negative, non-NaN number, chosen by + // the user agent. + // TODO + + // 14. Let sizeAlgorithm be an algorithm that accepts a chunk object + // and returns a non-negative, non-NaN, non-infinite number, chosen by the user agent. + // TODO + + // 15. Let stream be a new ReadableStream. + // 16. Set up stream with pullAlgorithm set to pullAlgorithm, + // cancelAlgorithm set to cancelAlgorithm, highWaterMark set to + // highWaterMark, and sizeAlgorithm set to sizeAlgorithm. + if (!ReadableStream) { + ReadableStream = (__nccwpck_require__(3774).ReadableStream) + } + + const stream = new ReadableStream( + { + async start (controller) { + fetchParams.controller.controller = controller + }, + async pull (controller) { + await pullAlgorithm(controller) + }, + async cancel (reason) { + await cancelAlgorithm(reason) + } + }, + { + highWaterMark: 0, + size () { + return 1 + } + } + ) + + // 17. Run these steps, but abort when the ongoing fetch is terminated: + + // 1. Set response’s body to a new body whose stream is stream. + response.body = { stream } + + // 2. If response is not a network error and request’s cache mode is + // not "no-store", then update response in httpCache for request. + // TODO + + // 3. If includeCredentials is true and the user agent is not configured + // to block cookies for request (see section 7 of [COOKIES]), then run the + // "set-cookie-string" parsing algorithm (see section 5.2 of [COOKIES]) on + // the value of each header whose name is a byte-case-insensitive match for + // `Set-Cookie` in response’s header list, if any, and request’s current URL. + // TODO + + // 18. If aborted, then: + // TODO + + // 19. Run these steps in parallel: + + // 1. Run these steps, but abort when fetchParams is canceled: + fetchParams.controller.on('terminated', onAborted) + fetchParams.controller.resume = async () => { + // 1. While true + while (true) { + // 1-3. See onData... + + // 4. Set bytes to the result of handling content codings given + // codings and bytes. + let bytes + let isFailure + try { + const { done, value } = await fetchParams.controller.next() + + if (isAborted(fetchParams)) { + break + } + + bytes = done ? undefined : value + } catch (err) { + if (fetchParams.controller.ended && !timingInfo.encodedBodySize) { + // zlib doesn't like empty streams. + bytes = undefined + } else { + bytes = err + + // err may be propagated from the result of calling readablestream.cancel, + // which might not be an error. https://github.com/nodejs/undici/issues/2009 + isFailure = true + } + } + + if (bytes === undefined) { + // 2. Otherwise, if the bytes transmission for response’s message + // body is done normally and stream is readable, then close + // stream, finalize response for fetchParams and response, and + // abort these in-parallel steps. + readableStreamClose(fetchParams.controller.controller) + + finalizeResponse(fetchParams, response) + + return + } + + // 5. Increase timingInfo’s decoded body size by bytes’s length. + timingInfo.decodedBodySize += bytes?.byteLength ?? 0 + + // 6. If bytes is failure, then terminate fetchParams’s controller. + if (isFailure) { + fetchParams.controller.terminate(bytes) + return + } + + // 7. Enqueue a Uint8Array wrapping an ArrayBuffer containing bytes + // into stream. + fetchParams.controller.controller.enqueue(new Uint8Array(bytes)) + + // 8. If stream is errored, then terminate the ongoing fetch. + if (isErrored(stream)) { + fetchParams.controller.terminate() + return + } + + // 9. If stream doesn’t need more data ask the user agent to suspend + // the ongoing fetch. + if (!fetchParams.controller.controller.desiredSize) { + return + } + } + } + + // 2. If aborted, then: + function onAborted (reason) { + // 2. If fetchParams is aborted, then: + if (isAborted(fetchParams)) { + // 1. Set response’s aborted flag. + response.aborted = true + + // 2. If stream is readable, then error stream with the result of + // deserialize a serialized abort reason given fetchParams’s + // controller’s serialized abort reason and an + // implementation-defined realm. + if (isReadable(stream)) { + fetchParams.controller.controller.error( + fetchParams.controller.serializedAbortReason + ) + } + } else { + // 3. Otherwise, if stream is readable, error stream with a TypeError. + if (isReadable(stream)) { + fetchParams.controller.controller.error(new TypeError('terminated', { + cause: isErrorLike(reason) ? reason : undefined + })) + } + } + + // 4. If connection uses HTTP/2, then transmit an RST_STREAM frame. + // 5. Otherwise, the user agent should close connection unless it would be bad for performance to do so. + fetchParams.controller.connection.destroy() + } + + // 20. Return response. + return response + + async function dispatch ({ body }) { + const url = requestCurrentURL(request) + /** @type {import('../..').Agent} */ + const agent = fetchParams.controller.dispatcher + + return new Promise((resolve, reject) => agent.dispatch( + { + path: url.pathname + url.search, + origin: url.origin, + method: request.method, + body: fetchParams.controller.dispatcher.isMockActive ? request.body && (request.body.source || request.body.stream) : body, + headers: request.headersList.entries, + maxRedirections: 0, + upgrade: request.mode === 'websocket' ? 'websocket' : undefined + }, + { + body: null, + abort: null, + + onConnect (abort) { + // TODO (fix): Do we need connection here? + const { connection } = fetchParams.controller + + if (connection.destroyed) { + abort(new DOMException('The operation was aborted.', 'AbortError')) + } else { + fetchParams.controller.on('terminated', abort) + this.abort = connection.abort = abort + } + }, + + onHeaders (status, headersList, resume, statusText) { + if (status < 200) { + return + } + + let codings = [] + let location = '' + + const headers = new Headers() + + // For H2, the headers are a plain JS object + // We distinguish between them and iterate accordingly + if (Array.isArray(headersList)) { + for (let n = 0; n < headersList.length; n += 2) { + const key = headersList[n + 0].toString('latin1') + const val = headersList[n + 1].toString('latin1') + if (key.toLowerCase() === 'content-encoding') { + // https://www.rfc-editor.org/rfc/rfc7231#section-3.1.2.1 + // "All content-coding values are case-insensitive..." + codings = val.toLowerCase().split(',').map((x) => x.trim()) + } else if (key.toLowerCase() === 'location') { + location = val + } + + headers[kHeadersList].append(key, val) + } + } else { + const keys = Object.keys(headersList) + for (const key of keys) { + const val = headersList[key] + if (key.toLowerCase() === 'content-encoding') { + // https://www.rfc-editor.org/rfc/rfc7231#section-3.1.2.1 + // "All content-coding values are case-insensitive..." + codings = val.toLowerCase().split(',').map((x) => x.trim()).reverse() + } else if (key.toLowerCase() === 'location') { + location = val + } + + headers[kHeadersList].append(key, val) + } + } + + this.body = new Readable({ read: resume }) + + const decoders = [] + + const willFollow = request.redirect === 'follow' && + location && + redirectStatusSet.has(status) + + // https://developer.mozilla.org/en-US/docs/Web/HTTP/Headers/Content-Encoding + if (request.method !== 'HEAD' && request.method !== 'CONNECT' && !nullBodyStatus.includes(status) && !willFollow) { + for (const coding of codings) { + // https://www.rfc-editor.org/rfc/rfc9112.html#section-7.2 + if (coding === 'x-gzip' || coding === 'gzip') { + decoders.push(zlib.createGunzip({ + // Be less strict when decoding compressed responses, since sometimes + // servers send slightly invalid responses that are still accepted + // by common browsers. + // Always using Z_SYNC_FLUSH is what cURL does. + flush: zlib.constants.Z_SYNC_FLUSH, + finishFlush: zlib.constants.Z_SYNC_FLUSH + })) + } else if (coding === 'deflate') { + decoders.push(zlib.createInflate()) + } else if (coding === 'br') { + decoders.push(zlib.createBrotliDecompress()) + } else { + decoders.length = 0 + break + } + } + } + + resolve({ + status, + statusText, + headersList: headers[kHeadersList], + body: decoders.length + ? pipeline(this.body, ...decoders, () => { }) + : this.body.on('error', () => {}) + }) + + return true + }, + + onData (chunk) { + if (fetchParams.controller.dump) { + return + } + + // 1. If one or more bytes have been transmitted from response’s + // message body, then: + + // 1. Let bytes be the transmitted bytes. + const bytes = chunk + + // 2. Let codings be the result of extracting header list values + // given `Content-Encoding` and response’s header list. + // See pullAlgorithm. + + // 3. Increase timingInfo’s encoded body size by bytes’s length. + timingInfo.encodedBodySize += bytes.byteLength + + // 4. See pullAlgorithm... + + return this.body.push(bytes) + }, + + onComplete () { + if (this.abort) { + fetchParams.controller.off('terminated', this.abort) + } + + fetchParams.controller.ended = true + + this.body.push(null) + }, + + onError (error) { + if (this.abort) { + fetchParams.controller.off('terminated', this.abort) + } + + this.body?.destroy(error) + + fetchParams.controller.terminate(error) + + reject(error) + }, + + onUpgrade (status, headersList, socket) { + if (status !== 101) { + return + } + + const headers = new Headers() + + for (let n = 0; n < headersList.length; n += 2) { + const key = headersList[n + 0].toString('latin1') + const val = headersList[n + 1].toString('latin1') + + headers[kHeadersList].append(key, val) + } + + resolve({ + status, + statusText: STATUS_CODES[status], + headersList: headers[kHeadersList], + socket + }) + + return true + } + } + )) + } +} + +module.exports = { + fetch, + Fetch, + fetching, + finalizeAndReportTiming +} + + +/***/ }), + +/***/ 5194: +/***/ ((module, __unused_webpack_exports, __nccwpck_require__) => { + +/* globals AbortController */ + + + +const { extractBody, mixinBody, cloneBody } = __nccwpck_require__(8923) +const { Headers, fill: fillHeaders, HeadersList } = __nccwpck_require__(6349) +const { FinalizationRegistry } = __nccwpck_require__(3194)() +const util = __nccwpck_require__(3440) +const { + isValidHTTPToken, + sameOrigin, + normalizeMethod, + makePolicyContainer, + normalizeMethodRecord +} = __nccwpck_require__(5523) +const { + forbiddenMethodsSet, + corsSafeListedMethodsSet, + referrerPolicy, + requestRedirect, + requestMode, + requestCredentials, + requestCache, + requestDuplex +} = __nccwpck_require__(7326) +const { kEnumerableProperty } = util +const { kHeaders, kSignal, kState, kGuard, kRealm } = __nccwpck_require__(9710) +const { webidl } = __nccwpck_require__(4222) +const { getGlobalOrigin } = __nccwpck_require__(5628) +const { URLSerializer } = __nccwpck_require__(4322) +const { kHeadersList, kConstruct } = __nccwpck_require__(6443) +const assert = __nccwpck_require__(2613) +const { getMaxListeners, setMaxListeners, getEventListeners, defaultMaxListeners } = __nccwpck_require__(4434) + +let TransformStream = globalThis.TransformStream + +const kAbortController = Symbol('abortController') + +const requestFinalizer = new FinalizationRegistry(({ signal, abort }) => { + signal.removeEventListener('abort', abort) +}) + +// https://fetch.spec.whatwg.org/#request-class +class Request { + // https://fetch.spec.whatwg.org/#dom-request + constructor (input, init = {}) { + if (input === kConstruct) { + return + } + + webidl.argumentLengthCheck(arguments, 1, { header: 'Request constructor' }) + + input = webidl.converters.RequestInfo(input) + init = webidl.converters.RequestInit(init) + + // https://html.spec.whatwg.org/multipage/webappapis.html#environment-settings-object + this[kRealm] = { + settingsObject: { + baseUrl: getGlobalOrigin(), + get origin () { + return this.baseUrl?.origin + }, + policyContainer: makePolicyContainer() + } + } + + // 1. Let request be null. + let request = null + + // 2. Let fallbackMode be null. + let fallbackMode = null + + // 3. Let baseURL be this’s relevant settings object’s API base URL. + const baseUrl = this[kRealm].settingsObject.baseUrl + + // 4. Let signal be null. + let signal = null + + // 5. If input is a string, then: + if (typeof input === 'string') { + // 1. Let parsedURL be the result of parsing input with baseURL. + // 2. If parsedURL is failure, then throw a TypeError. + let parsedURL + try { + parsedURL = new URL(input, baseUrl) + } catch (err) { + throw new TypeError('Failed to parse URL from ' + input, { cause: err }) + } + + // 3. If parsedURL includes credentials, then throw a TypeError. + if (parsedURL.username || parsedURL.password) { + throw new TypeError( + 'Request cannot be constructed from a URL that includes credentials: ' + + input + ) + } + + // 4. Set request to a new request whose URL is parsedURL. + request = makeRequest({ urlList: [parsedURL] }) + + // 5. Set fallbackMode to "cors". + fallbackMode = 'cors' + } else { + // 6. Otherwise: + + // 7. Assert: input is a Request object. + assert(input instanceof Request) + + // 8. Set request to input’s request. + request = input[kState] + + // 9. Set signal to input’s signal. + signal = input[kSignal] + } + + // 7. Let origin be this’s relevant settings object’s origin. + const origin = this[kRealm].settingsObject.origin + + // 8. Let window be "client". + let window = 'client' + + // 9. If request’s window is an environment settings object and its origin + // is same origin with origin, then set window to request’s window. + if ( + request.window?.constructor?.name === 'EnvironmentSettingsObject' && + sameOrigin(request.window, origin) + ) { + window = request.window + } + + // 10. If init["window"] exists and is non-null, then throw a TypeError. + if (init.window != null) { + throw new TypeError(`'window' option '${window}' must be null`) + } + + // 11. If init["window"] exists, then set window to "no-window". + if ('window' in init) { + window = 'no-window' + } + + // 12. Set request to a new request with the following properties: + request = makeRequest({ + // URL request’s URL. + // undici implementation note: this is set as the first item in request's urlList in makeRequest + // method request’s method. + method: request.method, + // header list A copy of request’s header list. + // undici implementation note: headersList is cloned in makeRequest + headersList: request.headersList, + // unsafe-request flag Set. + unsafeRequest: request.unsafeRequest, + // client This’s relevant settings object. + client: this[kRealm].settingsObject, + // window window. + window, + // priority request’s priority. + priority: request.priority, + // origin request’s origin. The propagation of the origin is only significant for navigation requests + // being handled by a service worker. In this scenario a request can have an origin that is different + // from the current client. + origin: request.origin, + // referrer request’s referrer. + referrer: request.referrer, + // referrer policy request’s referrer policy. + referrerPolicy: request.referrerPolicy, + // mode request’s mode. + mode: request.mode, + // credentials mode request’s credentials mode. + credentials: request.credentials, + // cache mode request’s cache mode. + cache: request.cache, + // redirect mode request’s redirect mode. + redirect: request.redirect, + // integrity metadata request’s integrity metadata. + integrity: request.integrity, + // keepalive request’s keepalive. + keepalive: request.keepalive, + // reload-navigation flag request’s reload-navigation flag. + reloadNavigation: request.reloadNavigation, + // history-navigation flag request’s history-navigation flag. + historyNavigation: request.historyNavigation, + // URL list A clone of request’s URL list. + urlList: [...request.urlList] + }) + + const initHasKey = Object.keys(init).length !== 0 + + // 13. If init is not empty, then: + if (initHasKey) { + // 1. If request’s mode is "navigate", then set it to "same-origin". + if (request.mode === 'navigate') { + request.mode = 'same-origin' + } + + // 2. Unset request’s reload-navigation flag. + request.reloadNavigation = false + + // 3. Unset request’s history-navigation flag. + request.historyNavigation = false + + // 4. Set request’s origin to "client". + request.origin = 'client' + + // 5. Set request’s referrer to "client" + request.referrer = 'client' + + // 6. Set request’s referrer policy to the empty string. + request.referrerPolicy = '' + + // 7. Set request’s URL to request’s current URL. + request.url = request.urlList[request.urlList.length - 1] + + // 8. Set request’s URL list to « request’s URL ». + request.urlList = [request.url] + } + + // 14. If init["referrer"] exists, then: + if (init.referrer !== undefined) { + // 1. Let referrer be init["referrer"]. + const referrer = init.referrer + + // 2. If referrer is the empty string, then set request’s referrer to "no-referrer". + if (referrer === '') { + request.referrer = 'no-referrer' + } else { + // 1. Let parsedReferrer be the result of parsing referrer with + // baseURL. + // 2. If parsedReferrer is failure, then throw a TypeError. + let parsedReferrer + try { + parsedReferrer = new URL(referrer, baseUrl) + } catch (err) { + throw new TypeError(`Referrer "${referrer}" is not a valid URL.`, { cause: err }) + } + + // 3. If one of the following is true + // - parsedReferrer’s scheme is "about" and path is the string "client" + // - parsedReferrer’s origin is not same origin with origin + // then set request’s referrer to "client". + if ( + (parsedReferrer.protocol === 'about:' && parsedReferrer.hostname === 'client') || + (origin && !sameOrigin(parsedReferrer, this[kRealm].settingsObject.baseUrl)) + ) { + request.referrer = 'client' + } else { + // 4. Otherwise, set request’s referrer to parsedReferrer. + request.referrer = parsedReferrer + } + } + } + + // 15. If init["referrerPolicy"] exists, then set request’s referrer policy + // to it. + if (init.referrerPolicy !== undefined) { + request.referrerPolicy = init.referrerPolicy + } + + // 16. Let mode be init["mode"] if it exists, and fallbackMode otherwise. + let mode + if (init.mode !== undefined) { + mode = init.mode + } else { + mode = fallbackMode + } + + // 17. If mode is "navigate", then throw a TypeError. + if (mode === 'navigate') { + throw webidl.errors.exception({ + header: 'Request constructor', + message: 'invalid request mode navigate.' + }) + } + + // 18. If mode is non-null, set request’s mode to mode. + if (mode != null) { + request.mode = mode + } + + // 19. If init["credentials"] exists, then set request’s credentials mode + // to it. + if (init.credentials !== undefined) { + request.credentials = init.credentials + } + + // 18. If init["cache"] exists, then set request’s cache mode to it. + if (init.cache !== undefined) { + request.cache = init.cache + } + + // 21. If request’s cache mode is "only-if-cached" and request’s mode is + // not "same-origin", then throw a TypeError. + if (request.cache === 'only-if-cached' && request.mode !== 'same-origin') { + throw new TypeError( + "'only-if-cached' can be set only with 'same-origin' mode" + ) + } + + // 22. If init["redirect"] exists, then set request’s redirect mode to it. + if (init.redirect !== undefined) { + request.redirect = init.redirect + } + + // 23. If init["integrity"] exists, then set request’s integrity metadata to it. + if (init.integrity != null) { + request.integrity = String(init.integrity) + } + + // 24. If init["keepalive"] exists, then set request’s keepalive to it. + if (init.keepalive !== undefined) { + request.keepalive = Boolean(init.keepalive) + } + + // 25. If init["method"] exists, then: + if (init.method !== undefined) { + // 1. Let method be init["method"]. + let method = init.method + + // 2. If method is not a method or method is a forbidden method, then + // throw a TypeError. + if (!isValidHTTPToken(method)) { + throw new TypeError(`'${method}' is not a valid HTTP method.`) + } + + if (forbiddenMethodsSet.has(method.toUpperCase())) { + throw new TypeError(`'${method}' HTTP method is unsupported.`) + } + + // 3. Normalize method. + method = normalizeMethodRecord[method] ?? normalizeMethod(method) + + // 4. Set request’s method to method. + request.method = method + } + + // 26. If init["signal"] exists, then set signal to it. + if (init.signal !== undefined) { + signal = init.signal + } + + // 27. Set this’s request to request. + this[kState] = request + + // 28. Set this’s signal to a new AbortSignal object with this’s relevant + // Realm. + // TODO: could this be simplified with AbortSignal.any + // (https://dom.spec.whatwg.org/#dom-abortsignal-any) + const ac = new AbortController() + this[kSignal] = ac.signal + this[kSignal][kRealm] = this[kRealm] + + // 29. If signal is not null, then make this’s signal follow signal. + if (signal != null) { + if ( + !signal || + typeof signal.aborted !== 'boolean' || + typeof signal.addEventListener !== 'function' + ) { + throw new TypeError( + "Failed to construct 'Request': member signal is not of type AbortSignal." + ) + } + + if (signal.aborted) { + ac.abort(signal.reason) + } else { + // Keep a strong ref to ac while request object + // is alive. This is needed to prevent AbortController + // from being prematurely garbage collected. + // See, https://github.com/nodejs/undici/issues/1926. + this[kAbortController] = ac + + const acRef = new WeakRef(ac) + const abort = function () { + const ac = acRef.deref() + if (ac !== undefined) { + ac.abort(this.reason) + } + } + + // Third-party AbortControllers may not work with these. + // See, https://github.com/nodejs/undici/pull/1910#issuecomment-1464495619. + try { + // If the max amount of listeners is equal to the default, increase it + // This is only available in node >= v19.9.0 + if (typeof getMaxListeners === 'function' && getMaxListeners(signal) === defaultMaxListeners) { + setMaxListeners(100, signal) + } else if (getEventListeners(signal, 'abort').length >= defaultMaxListeners) { + setMaxListeners(100, signal) + } + } catch {} + + util.addAbortListener(signal, abort) + requestFinalizer.register(ac, { signal, abort }) + } + } + + // 30. Set this’s headers to a new Headers object with this’s relevant + // Realm, whose header list is request’s header list and guard is + // "request". + this[kHeaders] = new Headers(kConstruct) + this[kHeaders][kHeadersList] = request.headersList + this[kHeaders][kGuard] = 'request' + this[kHeaders][kRealm] = this[kRealm] + + // 31. If this’s request’s mode is "no-cors", then: + if (mode === 'no-cors') { + // 1. If this’s request’s method is not a CORS-safelisted method, + // then throw a TypeError. + if (!corsSafeListedMethodsSet.has(request.method)) { + throw new TypeError( + `'${request.method} is unsupported in no-cors mode.` + ) + } + + // 2. Set this’s headers’s guard to "request-no-cors". + this[kHeaders][kGuard] = 'request-no-cors' + } + + // 32. If init is not empty, then: + if (initHasKey) { + /** @type {HeadersList} */ + const headersList = this[kHeaders][kHeadersList] + // 1. Let headers be a copy of this’s headers and its associated header + // list. + // 2. If init["headers"] exists, then set headers to init["headers"]. + const headers = init.headers !== undefined ? init.headers : new HeadersList(headersList) + + // 3. Empty this’s headers’s header list. + headersList.clear() + + // 4. If headers is a Headers object, then for each header in its header + // list, append header’s name/header’s value to this’s headers. + if (headers instanceof HeadersList) { + for (const [key, val] of headers) { + headersList.append(key, val) + } + // Note: Copy the `set-cookie` meta-data. + headersList.cookies = headers.cookies + } else { + // 5. Otherwise, fill this’s headers with headers. + fillHeaders(this[kHeaders], headers) + } + } + + // 33. Let inputBody be input’s request’s body if input is a Request + // object; otherwise null. + const inputBody = input instanceof Request ? input[kState].body : null + + // 34. If either init["body"] exists and is non-null or inputBody is + // non-null, and request’s method is `GET` or `HEAD`, then throw a + // TypeError. + if ( + (init.body != null || inputBody != null) && + (request.method === 'GET' || request.method === 'HEAD') + ) { + throw new TypeError('Request with GET/HEAD method cannot have body.') + } + + // 35. Let initBody be null. + let initBody = null + + // 36. If init["body"] exists and is non-null, then: + if (init.body != null) { + // 1. Let Content-Type be null. + // 2. Set initBody and Content-Type to the result of extracting + // init["body"], with keepalive set to request’s keepalive. + const [extractedBody, contentType] = extractBody( + init.body, + request.keepalive + ) + initBody = extractedBody + + // 3, If Content-Type is non-null and this’s headers’s header list does + // not contain `Content-Type`, then append `Content-Type`/Content-Type to + // this’s headers. + if (contentType && !this[kHeaders][kHeadersList].contains('content-type')) { + this[kHeaders].append('content-type', contentType) + } + } + + // 37. Let inputOrInitBody be initBody if it is non-null; otherwise + // inputBody. + const inputOrInitBody = initBody ?? inputBody + + // 38. If inputOrInitBody is non-null and inputOrInitBody’s source is + // null, then: + if (inputOrInitBody != null && inputOrInitBody.source == null) { + // 1. If initBody is non-null and init["duplex"] does not exist, + // then throw a TypeError. + if (initBody != null && init.duplex == null) { + throw new TypeError('RequestInit: duplex option is required when sending a body.') + } + + // 2. If this’s request’s mode is neither "same-origin" nor "cors", + // then throw a TypeError. + if (request.mode !== 'same-origin' && request.mode !== 'cors') { + throw new TypeError( + 'If request is made from ReadableStream, mode should be "same-origin" or "cors"' + ) + } + + // 3. Set this’s request’s use-CORS-preflight flag. + request.useCORSPreflightFlag = true + } + + // 39. Let finalBody be inputOrInitBody. + let finalBody = inputOrInitBody + + // 40. If initBody is null and inputBody is non-null, then: + if (initBody == null && inputBody != null) { + // 1. If input is unusable, then throw a TypeError. + if (util.isDisturbed(inputBody.stream) || inputBody.stream.locked) { + throw new TypeError( + 'Cannot construct a Request with a Request object that has already been used.' + ) + } + + // 2. Set finalBody to the result of creating a proxy for inputBody. + if (!TransformStream) { + TransformStream = (__nccwpck_require__(3774).TransformStream) + } + + // https://streams.spec.whatwg.org/#readablestream-create-a-proxy + const identityTransform = new TransformStream() + inputBody.stream.pipeThrough(identityTransform) + finalBody = { + source: inputBody.source, + length: inputBody.length, + stream: identityTransform.readable + } + } + + // 41. Set this’s request’s body to finalBody. + this[kState].body = finalBody + } + + // Returns request’s HTTP method, which is "GET" by default. + get method () { + webidl.brandCheck(this, Request) + + // The method getter steps are to return this’s request’s method. + return this[kState].method + } + + // Returns the URL of request as a string. + get url () { + webidl.brandCheck(this, Request) + + // The url getter steps are to return this’s request’s URL, serialized. + return URLSerializer(this[kState].url) + } + + // Returns a Headers object consisting of the headers associated with request. + // Note that headers added in the network layer by the user agent will not + // be accounted for in this object, e.g., the "Host" header. + get headers () { + webidl.brandCheck(this, Request) + + // The headers getter steps are to return this’s headers. + return this[kHeaders] + } + + // Returns the kind of resource requested by request, e.g., "document" + // or "script". + get destination () { + webidl.brandCheck(this, Request) + + // The destination getter are to return this’s request’s destination. + return this[kState].destination + } + + // Returns the referrer of request. Its value can be a same-origin URL if + // explicitly set in init, the empty string to indicate no referrer, and + // "about:client" when defaulting to the global’s default. This is used + // during fetching to determine the value of the `Referer` header of the + // request being made. + get referrer () { + webidl.brandCheck(this, Request) + + // 1. If this’s request’s referrer is "no-referrer", then return the + // empty string. + if (this[kState].referrer === 'no-referrer') { + return '' + } + + // 2. If this’s request’s referrer is "client", then return + // "about:client". + if (this[kState].referrer === 'client') { + return 'about:client' + } + + // Return this’s request’s referrer, serialized. + return this[kState].referrer.toString() + } + + // Returns the referrer policy associated with request. + // This is used during fetching to compute the value of the request’s + // referrer. + get referrerPolicy () { + webidl.brandCheck(this, Request) + + // The referrerPolicy getter steps are to return this’s request’s referrer policy. + return this[kState].referrerPolicy + } + + // Returns the mode associated with request, which is a string indicating + // whether the request will use CORS, or will be restricted to same-origin + // URLs. + get mode () { + webidl.brandCheck(this, Request) + + // The mode getter steps are to return this’s request’s mode. + return this[kState].mode + } + + // Returns the credentials mode associated with request, + // which is a string indicating whether credentials will be sent with the + // request always, never, or only when sent to a same-origin URL. + get credentials () { + // The credentials getter steps are to return this’s request’s credentials mode. + return this[kState].credentials + } + + // Returns the cache mode associated with request, + // which is a string indicating how the request will + // interact with the browser’s cache when fetching. + get cache () { + webidl.brandCheck(this, Request) + + // The cache getter steps are to return this’s request’s cache mode. + return this[kState].cache + } + + // Returns the redirect mode associated with request, + // which is a string indicating how redirects for the + // request will be handled during fetching. A request + // will follow redirects by default. + get redirect () { + webidl.brandCheck(this, Request) + + // The redirect getter steps are to return this’s request’s redirect mode. + return this[kState].redirect + } + + // Returns request’s subresource integrity metadata, which is a + // cryptographic hash of the resource being fetched. Its value + // consists of multiple hashes separated by whitespace. [SRI] + get integrity () { + webidl.brandCheck(this, Request) + + // The integrity getter steps are to return this’s request’s integrity + // metadata. + return this[kState].integrity + } + + // Returns a boolean indicating whether or not request can outlive the + // global in which it was created. + get keepalive () { + webidl.brandCheck(this, Request) + + // The keepalive getter steps are to return this’s request’s keepalive. + return this[kState].keepalive + } + + // Returns a boolean indicating whether or not request is for a reload + // navigation. + get isReloadNavigation () { + webidl.brandCheck(this, Request) + + // The isReloadNavigation getter steps are to return true if this’s + // request’s reload-navigation flag is set; otherwise false. + return this[kState].reloadNavigation + } + + // Returns a boolean indicating whether or not request is for a history + // navigation (a.k.a. back-foward navigation). + get isHistoryNavigation () { + webidl.brandCheck(this, Request) + + // The isHistoryNavigation getter steps are to return true if this’s request’s + // history-navigation flag is set; otherwise false. + return this[kState].historyNavigation + } + + // Returns the signal associated with request, which is an AbortSignal + // object indicating whether or not request has been aborted, and its + // abort event handler. + get signal () { + webidl.brandCheck(this, Request) + + // The signal getter steps are to return this’s signal. + return this[kSignal] + } + + get body () { + webidl.brandCheck(this, Request) + + return this[kState].body ? this[kState].body.stream : null + } + + get bodyUsed () { + webidl.brandCheck(this, Request) + + return !!this[kState].body && util.isDisturbed(this[kState].body.stream) + } + + get duplex () { + webidl.brandCheck(this, Request) + + return 'half' + } + + // Returns a clone of request. + clone () { + webidl.brandCheck(this, Request) + + // 1. If this is unusable, then throw a TypeError. + if (this.bodyUsed || this.body?.locked) { + throw new TypeError('unusable') + } + + // 2. Let clonedRequest be the result of cloning this’s request. + const clonedRequest = cloneRequest(this[kState]) + + // 3. Let clonedRequestObject be the result of creating a Request object, + // given clonedRequest, this’s headers’s guard, and this’s relevant Realm. + const clonedRequestObject = new Request(kConstruct) + clonedRequestObject[kState] = clonedRequest + clonedRequestObject[kRealm] = this[kRealm] + clonedRequestObject[kHeaders] = new Headers(kConstruct) + clonedRequestObject[kHeaders][kHeadersList] = clonedRequest.headersList + clonedRequestObject[kHeaders][kGuard] = this[kHeaders][kGuard] + clonedRequestObject[kHeaders][kRealm] = this[kHeaders][kRealm] + + // 4. Make clonedRequestObject’s signal follow this’s signal. + const ac = new AbortController() + if (this.signal.aborted) { + ac.abort(this.signal.reason) + } else { + util.addAbortListener( + this.signal, + () => { + ac.abort(this.signal.reason) + } + ) + } + clonedRequestObject[kSignal] = ac.signal + + // 4. Return clonedRequestObject. + return clonedRequestObject + } +} + +mixinBody(Request) + +function makeRequest (init) { + // https://fetch.spec.whatwg.org/#requests + const request = { + method: 'GET', + localURLsOnly: false, + unsafeRequest: false, + body: null, + client: null, + reservedClient: null, + replacesClientId: '', + window: 'client', + keepalive: false, + serviceWorkers: 'all', + initiator: '', + destination: '', + priority: null, + origin: 'client', + policyContainer: 'client', + referrer: 'client', + referrerPolicy: '', + mode: 'no-cors', + useCORSPreflightFlag: false, + credentials: 'same-origin', + useCredentials: false, + cache: 'default', + redirect: 'follow', + integrity: '', + cryptoGraphicsNonceMetadata: '', + parserMetadata: '', + reloadNavigation: false, + historyNavigation: false, + userActivation: false, + taintedOrigin: false, + redirectCount: 0, + responseTainting: 'basic', + preventNoCacheCacheControlHeaderModification: false, + done: false, + timingAllowFailed: false, + ...init, + headersList: init.headersList + ? new HeadersList(init.headersList) + : new HeadersList() + } + request.url = request.urlList[0] + return request +} + +// https://fetch.spec.whatwg.org/#concept-request-clone +function cloneRequest (request) { + // To clone a request request, run these steps: + + // 1. Let newRequest be a copy of request, except for its body. + const newRequest = makeRequest({ ...request, body: null }) + + // 2. If request’s body is non-null, set newRequest’s body to the + // result of cloning request’s body. + if (request.body != null) { + newRequest.body = cloneBody(request.body) + } + + // 3. Return newRequest. + return newRequest +} + +Object.defineProperties(Request.prototype, { + method: kEnumerableProperty, + url: kEnumerableProperty, + headers: kEnumerableProperty, + redirect: kEnumerableProperty, + clone: kEnumerableProperty, + signal: kEnumerableProperty, + duplex: kEnumerableProperty, + destination: kEnumerableProperty, + body: kEnumerableProperty, + bodyUsed: kEnumerableProperty, + isHistoryNavigation: kEnumerableProperty, + isReloadNavigation: kEnumerableProperty, + keepalive: kEnumerableProperty, + integrity: kEnumerableProperty, + cache: kEnumerableProperty, + credentials: kEnumerableProperty, + attribute: kEnumerableProperty, + referrerPolicy: kEnumerableProperty, + referrer: kEnumerableProperty, + mode: kEnumerableProperty, + [Symbol.toStringTag]: { + value: 'Request', + configurable: true + } +}) + +webidl.converters.Request = webidl.interfaceConverter( + Request +) + +// https://fetch.spec.whatwg.org/#requestinfo +webidl.converters.RequestInfo = function (V) { + if (typeof V === 'string') { + return webidl.converters.USVString(V) + } + + if (V instanceof Request) { + return webidl.converters.Request(V) + } + + return webidl.converters.USVString(V) +} + +webidl.converters.AbortSignal = webidl.interfaceConverter( + AbortSignal +) + +// https://fetch.spec.whatwg.org/#requestinit +webidl.converters.RequestInit = webidl.dictionaryConverter([ + { + key: 'method', + converter: webidl.converters.ByteString + }, + { + key: 'headers', + converter: webidl.converters.HeadersInit + }, + { + key: 'body', + converter: webidl.nullableConverter( + webidl.converters.BodyInit + ) + }, + { + key: 'referrer', + converter: webidl.converters.USVString + }, + { + key: 'referrerPolicy', + converter: webidl.converters.DOMString, + // https://w3c.github.io/webappsec-referrer-policy/#referrer-policy + allowedValues: referrerPolicy + }, + { + key: 'mode', + converter: webidl.converters.DOMString, + // https://fetch.spec.whatwg.org/#concept-request-mode + allowedValues: requestMode + }, + { + key: 'credentials', + converter: webidl.converters.DOMString, + // https://fetch.spec.whatwg.org/#requestcredentials + allowedValues: requestCredentials + }, + { + key: 'cache', + converter: webidl.converters.DOMString, + // https://fetch.spec.whatwg.org/#requestcache + allowedValues: requestCache + }, + { + key: 'redirect', + converter: webidl.converters.DOMString, + // https://fetch.spec.whatwg.org/#requestredirect + allowedValues: requestRedirect + }, + { + key: 'integrity', + converter: webidl.converters.DOMString + }, + { + key: 'keepalive', + converter: webidl.converters.boolean + }, + { + key: 'signal', + converter: webidl.nullableConverter( + (signal) => webidl.converters.AbortSignal( + signal, + { strict: false } + ) + ) + }, + { + key: 'window', + converter: webidl.converters.any + }, + { + key: 'duplex', + converter: webidl.converters.DOMString, + allowedValues: requestDuplex + } +]) + +module.exports = { Request, makeRequest } + + +/***/ }), + +/***/ 8676: +/***/ ((module, __unused_webpack_exports, __nccwpck_require__) => { + + + +const { Headers, HeadersList, fill } = __nccwpck_require__(6349) +const { extractBody, cloneBody, mixinBody } = __nccwpck_require__(8923) +const util = __nccwpck_require__(3440) +const { kEnumerableProperty } = util +const { + isValidReasonPhrase, + isCancelled, + isAborted, + isBlobLike, + serializeJavascriptValueToJSONString, + isErrorLike, + isomorphicEncode +} = __nccwpck_require__(5523) +const { + redirectStatusSet, + nullBodyStatus, + DOMException +} = __nccwpck_require__(7326) +const { kState, kHeaders, kGuard, kRealm } = __nccwpck_require__(9710) +const { webidl } = __nccwpck_require__(4222) +const { FormData } = __nccwpck_require__(3073) +const { getGlobalOrigin } = __nccwpck_require__(5628) +const { URLSerializer } = __nccwpck_require__(4322) +const { kHeadersList, kConstruct } = __nccwpck_require__(6443) +const assert = __nccwpck_require__(2613) +const { types } = __nccwpck_require__(9023) + +const ReadableStream = globalThis.ReadableStream || (__nccwpck_require__(3774).ReadableStream) +const textEncoder = new TextEncoder('utf-8') + +// https://fetch.spec.whatwg.org/#response-class +class Response { + // Creates network error Response. + static error () { + // TODO + const relevantRealm = { settingsObject: {} } + + // The static error() method steps are to return the result of creating a + // Response object, given a new network error, "immutable", and this’s + // relevant Realm. + const responseObject = new Response() + responseObject[kState] = makeNetworkError() + responseObject[kRealm] = relevantRealm + responseObject[kHeaders][kHeadersList] = responseObject[kState].headersList + responseObject[kHeaders][kGuard] = 'immutable' + responseObject[kHeaders][kRealm] = relevantRealm + return responseObject + } + + // https://fetch.spec.whatwg.org/#dom-response-json + static json (data, init = {}) { + webidl.argumentLengthCheck(arguments, 1, { header: 'Response.json' }) + + if (init !== null) { + init = webidl.converters.ResponseInit(init) + } + + // 1. Let bytes the result of running serialize a JavaScript value to JSON bytes on data. + const bytes = textEncoder.encode( + serializeJavascriptValueToJSONString(data) + ) + + // 2. Let body be the result of extracting bytes. + const body = extractBody(bytes) + + // 3. Let responseObject be the result of creating a Response object, given a new response, + // "response", and this’s relevant Realm. + const relevantRealm = { settingsObject: {} } + const responseObject = new Response() + responseObject[kRealm] = relevantRealm + responseObject[kHeaders][kGuard] = 'response' + responseObject[kHeaders][kRealm] = relevantRealm + + // 4. Perform initialize a response given responseObject, init, and (body, "application/json"). + initializeResponse(responseObject, init, { body: body[0], type: 'application/json' }) + + // 5. Return responseObject. + return responseObject + } + + // Creates a redirect Response that redirects to url with status status. + static redirect (url, status = 302) { + const relevantRealm = { settingsObject: {} } + + webidl.argumentLengthCheck(arguments, 1, { header: 'Response.redirect' }) + + url = webidl.converters.USVString(url) + status = webidl.converters['unsigned short'](status) + + // 1. Let parsedURL be the result of parsing url with current settings + // object’s API base URL. + // 2. If parsedURL is failure, then throw a TypeError. + // TODO: base-URL? + let parsedURL + try { + parsedURL = new URL(url, getGlobalOrigin()) + } catch (err) { + throw Object.assign(new TypeError('Failed to parse URL from ' + url), { + cause: err + }) + } + + // 3. If status is not a redirect status, then throw a RangeError. + if (!redirectStatusSet.has(status)) { + throw new RangeError('Invalid status code ' + status) + } + + // 4. Let responseObject be the result of creating a Response object, + // given a new response, "immutable", and this’s relevant Realm. + const responseObject = new Response() + responseObject[kRealm] = relevantRealm + responseObject[kHeaders][kGuard] = 'immutable' + responseObject[kHeaders][kRealm] = relevantRealm + + // 5. Set responseObject’s response’s status to status. + responseObject[kState].status = status + + // 6. Let value be parsedURL, serialized and isomorphic encoded. + const value = isomorphicEncode(URLSerializer(parsedURL)) + + // 7. Append `Location`/value to responseObject’s response’s header list. + responseObject[kState].headersList.append('location', value) + + // 8. Return responseObject. + return responseObject + } + + // https://fetch.spec.whatwg.org/#dom-response + constructor (body = null, init = {}) { + if (body !== null) { + body = webidl.converters.BodyInit(body) + } + + init = webidl.converters.ResponseInit(init) + + // TODO + this[kRealm] = { settingsObject: {} } + + // 1. Set this’s response to a new response. + this[kState] = makeResponse({}) + + // 2. Set this’s headers to a new Headers object with this’s relevant + // Realm, whose header list is this’s response’s header list and guard + // is "response". + this[kHeaders] = new Headers(kConstruct) + this[kHeaders][kGuard] = 'response' + this[kHeaders][kHeadersList] = this[kState].headersList + this[kHeaders][kRealm] = this[kRealm] + + // 3. Let bodyWithType be null. + let bodyWithType = null + + // 4. If body is non-null, then set bodyWithType to the result of extracting body. + if (body != null) { + const [extractedBody, type] = extractBody(body) + bodyWithType = { body: extractedBody, type } + } + + // 5. Perform initialize a response given this, init, and bodyWithType. + initializeResponse(this, init, bodyWithType) + } + + // Returns response’s type, e.g., "cors". + get type () { + webidl.brandCheck(this, Response) + + // The type getter steps are to return this’s response’s type. + return this[kState].type + } + + // Returns response’s URL, if it has one; otherwise the empty string. + get url () { + webidl.brandCheck(this, Response) + + const urlList = this[kState].urlList + + // The url getter steps are to return the empty string if this’s + // response’s URL is null; otherwise this’s response’s URL, + // serialized with exclude fragment set to true. + const url = urlList[urlList.length - 1] ?? null + + if (url === null) { + return '' + } + + return URLSerializer(url, true) + } + + // Returns whether response was obtained through a redirect. + get redirected () { + webidl.brandCheck(this, Response) + + // The redirected getter steps are to return true if this’s response’s URL + // list has more than one item; otherwise false. + return this[kState].urlList.length > 1 + } + + // Returns response’s status. + get status () { + webidl.brandCheck(this, Response) + + // The status getter steps are to return this’s response’s status. + return this[kState].status + } + + // Returns whether response’s status is an ok status. + get ok () { + webidl.brandCheck(this, Response) + + // The ok getter steps are to return true if this’s response’s status is an + // ok status; otherwise false. + return this[kState].status >= 200 && this[kState].status <= 299 + } + + // Returns response’s status message. + get statusText () { + webidl.brandCheck(this, Response) + + // The statusText getter steps are to return this’s response’s status + // message. + return this[kState].statusText + } + + // Returns response’s headers as Headers. + get headers () { + webidl.brandCheck(this, Response) + + // The headers getter steps are to return this’s headers. + return this[kHeaders] + } + + get body () { + webidl.brandCheck(this, Response) + + return this[kState].body ? this[kState].body.stream : null + } + + get bodyUsed () { + webidl.brandCheck(this, Response) + + return !!this[kState].body && util.isDisturbed(this[kState].body.stream) + } + + // Returns a clone of response. + clone () { + webidl.brandCheck(this, Response) + + // 1. If this is unusable, then throw a TypeError. + if (this.bodyUsed || (this.body && this.body.locked)) { + throw webidl.errors.exception({ + header: 'Response.clone', + message: 'Body has already been consumed.' + }) + } + + // 2. Let clonedResponse be the result of cloning this’s response. + const clonedResponse = cloneResponse(this[kState]) + + // 3. Return the result of creating a Response object, given + // clonedResponse, this’s headers’s guard, and this’s relevant Realm. + const clonedResponseObject = new Response() + clonedResponseObject[kState] = clonedResponse + clonedResponseObject[kRealm] = this[kRealm] + clonedResponseObject[kHeaders][kHeadersList] = clonedResponse.headersList + clonedResponseObject[kHeaders][kGuard] = this[kHeaders][kGuard] + clonedResponseObject[kHeaders][kRealm] = this[kHeaders][kRealm] + + return clonedResponseObject + } +} + +mixinBody(Response) + +Object.defineProperties(Response.prototype, { + type: kEnumerableProperty, + url: kEnumerableProperty, + status: kEnumerableProperty, + ok: kEnumerableProperty, + redirected: kEnumerableProperty, + statusText: kEnumerableProperty, + headers: kEnumerableProperty, + clone: kEnumerableProperty, + body: kEnumerableProperty, + bodyUsed: kEnumerableProperty, + [Symbol.toStringTag]: { + value: 'Response', + configurable: true + } +}) + +Object.defineProperties(Response, { + json: kEnumerableProperty, + redirect: kEnumerableProperty, + error: kEnumerableProperty +}) + +// https://fetch.spec.whatwg.org/#concept-response-clone +function cloneResponse (response) { + // To clone a response response, run these steps: + + // 1. If response is a filtered response, then return a new identical + // filtered response whose internal response is a clone of response’s + // internal response. + if (response.internalResponse) { + return filterResponse( + cloneResponse(response.internalResponse), + response.type + ) + } + + // 2. Let newResponse be a copy of response, except for its body. + const newResponse = makeResponse({ ...response, body: null }) + + // 3. If response’s body is non-null, then set newResponse’s body to the + // result of cloning response’s body. + if (response.body != null) { + newResponse.body = cloneBody(response.body) + } + + // 4. Return newResponse. + return newResponse +} + +function makeResponse (init) { + return { + aborted: false, + rangeRequested: false, + timingAllowPassed: false, + requestIncludesCredentials: false, + type: 'default', + status: 200, + timingInfo: null, + cacheState: '', + statusText: '', + ...init, + headersList: init.headersList + ? new HeadersList(init.headersList) + : new HeadersList(), + urlList: init.urlList ? [...init.urlList] : [] + } +} + +function makeNetworkError (reason) { + const isError = isErrorLike(reason) + return makeResponse({ + type: 'error', + status: 0, + error: isError + ? reason + : new Error(reason ? String(reason) : reason), + aborted: reason && reason.name === 'AbortError' + }) +} + +function makeFilteredResponse (response, state) { + state = { + internalResponse: response, + ...state + } + + return new Proxy(response, { + get (target, p) { + return p in state ? state[p] : target[p] + }, + set (target, p, value) { + assert(!(p in state)) + target[p] = value + return true + } + }) +} + +// https://fetch.spec.whatwg.org/#concept-filtered-response +function filterResponse (response, type) { + // Set response to the following filtered response with response as its + // internal response, depending on request’s response tainting: + if (type === 'basic') { + // A basic filtered response is a filtered response whose type is "basic" + // and header list excludes any headers in internal response’s header list + // whose name is a forbidden response-header name. + + // Note: undici does not implement forbidden response-header names + return makeFilteredResponse(response, { + type: 'basic', + headersList: response.headersList + }) + } else if (type === 'cors') { + // A CORS filtered response is a filtered response whose type is "cors" + // and header list excludes any headers in internal response’s header + // list whose name is not a CORS-safelisted response-header name, given + // internal response’s CORS-exposed header-name list. + + // Note: undici does not implement CORS-safelisted response-header names + return makeFilteredResponse(response, { + type: 'cors', + headersList: response.headersList + }) + } else if (type === 'opaque') { + // An opaque filtered response is a filtered response whose type is + // "opaque", URL list is the empty list, status is 0, status message + // is the empty byte sequence, header list is empty, and body is null. + + return makeFilteredResponse(response, { + type: 'opaque', + urlList: Object.freeze([]), + status: 0, + statusText: '', + body: null + }) + } else if (type === 'opaqueredirect') { + // An opaque-redirect filtered response is a filtered response whose type + // is "opaqueredirect", status is 0, status message is the empty byte + // sequence, header list is empty, and body is null. + + return makeFilteredResponse(response, { + type: 'opaqueredirect', + status: 0, + statusText: '', + headersList: [], + body: null + }) + } else { + assert(false) + } +} + +// https://fetch.spec.whatwg.org/#appropriate-network-error +function makeAppropriateNetworkError (fetchParams, err = null) { + // 1. Assert: fetchParams is canceled. + assert(isCancelled(fetchParams)) + + // 2. Return an aborted network error if fetchParams is aborted; + // otherwise return a network error. + return isAborted(fetchParams) + ? makeNetworkError(Object.assign(new DOMException('The operation was aborted.', 'AbortError'), { cause: err })) + : makeNetworkError(Object.assign(new DOMException('Request was cancelled.'), { cause: err })) +} + +// https://whatpr.org/fetch/1392.html#initialize-a-response +function initializeResponse (response, init, body) { + // 1. If init["status"] is not in the range 200 to 599, inclusive, then + // throw a RangeError. + if (init.status !== null && (init.status < 200 || init.status > 599)) { + throw new RangeError('init["status"] must be in the range of 200 to 599, inclusive.') + } + + // 2. If init["statusText"] does not match the reason-phrase token production, + // then throw a TypeError. + if ('statusText' in init && init.statusText != null) { + // See, https://datatracker.ietf.org/doc/html/rfc7230#section-3.1.2: + // reason-phrase = *( HTAB / SP / VCHAR / obs-text ) + if (!isValidReasonPhrase(String(init.statusText))) { + throw new TypeError('Invalid statusText') + } + } + + // 3. Set response’s response’s status to init["status"]. + if ('status' in init && init.status != null) { + response[kState].status = init.status + } + + // 4. Set response’s response’s status message to init["statusText"]. + if ('statusText' in init && init.statusText != null) { + response[kState].statusText = init.statusText + } + + // 5. If init["headers"] exists, then fill response’s headers with init["headers"]. + if ('headers' in init && init.headers != null) { + fill(response[kHeaders], init.headers) + } + + // 6. If body was given, then: + if (body) { + // 1. If response's status is a null body status, then throw a TypeError. + if (nullBodyStatus.includes(response.status)) { + throw webidl.errors.exception({ + header: 'Response constructor', + message: 'Invalid response status code ' + response.status + }) + } + + // 2. Set response's body to body's body. + response[kState].body = body.body + + // 3. If body's type is non-null and response's header list does not contain + // `Content-Type`, then append (`Content-Type`, body's type) to response's header list. + if (body.type != null && !response[kState].headersList.contains('Content-Type')) { + response[kState].headersList.append('content-type', body.type) + } + } +} + +webidl.converters.ReadableStream = webidl.interfaceConverter( + ReadableStream +) + +webidl.converters.FormData = webidl.interfaceConverter( + FormData +) + +webidl.converters.URLSearchParams = webidl.interfaceConverter( + URLSearchParams +) + +// https://fetch.spec.whatwg.org/#typedefdef-xmlhttprequestbodyinit +webidl.converters.XMLHttpRequestBodyInit = function (V) { + if (typeof V === 'string') { + return webidl.converters.USVString(V) + } + + if (isBlobLike(V)) { + return webidl.converters.Blob(V, { strict: false }) + } + + if (types.isArrayBuffer(V) || types.isTypedArray(V) || types.isDataView(V)) { + return webidl.converters.BufferSource(V) + } + + if (util.isFormDataLike(V)) { + return webidl.converters.FormData(V, { strict: false }) + } + + if (V instanceof URLSearchParams) { + return webidl.converters.URLSearchParams(V) + } + + return webidl.converters.DOMString(V) +} + +// https://fetch.spec.whatwg.org/#bodyinit +webidl.converters.BodyInit = function (V) { + if (V instanceof ReadableStream) { + return webidl.converters.ReadableStream(V) + } + + // Note: the spec doesn't include async iterables, + // this is an undici extension. + if (V?.[Symbol.asyncIterator]) { + return V + } + + return webidl.converters.XMLHttpRequestBodyInit(V) +} + +webidl.converters.ResponseInit = webidl.dictionaryConverter([ + { + key: 'status', + converter: webidl.converters['unsigned short'], + defaultValue: 200 + }, + { + key: 'statusText', + converter: webidl.converters.ByteString, + defaultValue: '' + }, + { + key: 'headers', + converter: webidl.converters.HeadersInit + } +]) + +module.exports = { + makeNetworkError, + makeResponse, + makeAppropriateNetworkError, + filterResponse, + Response, + cloneResponse +} + + +/***/ }), + +/***/ 9710: +/***/ ((module) => { + + + +module.exports = { + kUrl: Symbol('url'), + kHeaders: Symbol('headers'), + kSignal: Symbol('signal'), + kState: Symbol('state'), + kGuard: Symbol('guard'), + kRealm: Symbol('realm') +} + + +/***/ }), + +/***/ 5523: +/***/ ((module, __unused_webpack_exports, __nccwpck_require__) => { + + + +const { redirectStatusSet, referrerPolicySet: referrerPolicyTokens, badPortsSet } = __nccwpck_require__(7326) +const { getGlobalOrigin } = __nccwpck_require__(5628) +const { performance } = __nccwpck_require__(2987) +const { isBlobLike, toUSVString, ReadableStreamFrom } = __nccwpck_require__(3440) +const assert = __nccwpck_require__(2613) +const { isUint8Array } = __nccwpck_require__(8253) + +let supportedHashes = [] + +// https://nodejs.org/api/crypto.html#determining-if-crypto-support-is-unavailable +/** @type {import('crypto')|undefined} */ +let crypto + +try { + crypto = __nccwpck_require__(6982) + const possibleRelevantHashes = ['sha256', 'sha384', 'sha512'] + supportedHashes = crypto.getHashes().filter((hash) => possibleRelevantHashes.includes(hash)) +/* c8 ignore next 3 */ +} catch { +} + +function responseURL (response) { + // https://fetch.spec.whatwg.org/#responses + // A response has an associated URL. It is a pointer to the last URL + // in response’s URL list and null if response’s URL list is empty. + const urlList = response.urlList + const length = urlList.length + return length === 0 ? null : urlList[length - 1].toString() +} + +// https://fetch.spec.whatwg.org/#concept-response-location-url +function responseLocationURL (response, requestFragment) { + // 1. If response’s status is not a redirect status, then return null. + if (!redirectStatusSet.has(response.status)) { + return null + } + + // 2. Let location be the result of extracting header list values given + // `Location` and response’s header list. + let location = response.headersList.get('location') + + // 3. If location is a header value, then set location to the result of + // parsing location with response’s URL. + if (location !== null && isValidHeaderValue(location)) { + location = new URL(location, responseURL(response)) + } + + // 4. If location is a URL whose fragment is null, then set location’s + // fragment to requestFragment. + if (location && !location.hash) { + location.hash = requestFragment + } + + // 5. Return location. + return location +} + +/** @returns {URL} */ +function requestCurrentURL (request) { + return request.urlList[request.urlList.length - 1] +} + +function requestBadPort (request) { + // 1. Let url be request’s current URL. + const url = requestCurrentURL(request) + + // 2. If url’s scheme is an HTTP(S) scheme and url’s port is a bad port, + // then return blocked. + if (urlIsHttpHttpsScheme(url) && badPortsSet.has(url.port)) { + return 'blocked' + } + + // 3. Return allowed. + return 'allowed' +} + +function isErrorLike (object) { + return object instanceof Error || ( + object?.constructor?.name === 'Error' || + object?.constructor?.name === 'DOMException' + ) +} + +// Check whether |statusText| is a ByteString and +// matches the Reason-Phrase token production. +// RFC 2616: https://tools.ietf.org/html/rfc2616 +// RFC 7230: https://tools.ietf.org/html/rfc7230 +// "reason-phrase = *( HTAB / SP / VCHAR / obs-text )" +// https://github.com/chromium/chromium/blob/94.0.4604.1/third_party/blink/renderer/core/fetch/response.cc#L116 +function isValidReasonPhrase (statusText) { + for (let i = 0; i < statusText.length; ++i) { + const c = statusText.charCodeAt(i) + if ( + !( + ( + c === 0x09 || // HTAB + (c >= 0x20 && c <= 0x7e) || // SP / VCHAR + (c >= 0x80 && c <= 0xff) + ) // obs-text + ) + ) { + return false + } + } + return true +} + +/** + * @see https://tools.ietf.org/html/rfc7230#section-3.2.6 + * @param {number} c + */ +function isTokenCharCode (c) { + switch (c) { + case 0x22: + case 0x28: + case 0x29: + case 0x2c: + case 0x2f: + case 0x3a: + case 0x3b: + case 0x3c: + case 0x3d: + case 0x3e: + case 0x3f: + case 0x40: + case 0x5b: + case 0x5c: + case 0x5d: + case 0x7b: + case 0x7d: + // DQUOTE and "(),/:;<=>?@[\]{}" + return false + default: + // VCHAR %x21-7E + return c >= 0x21 && c <= 0x7e + } +} + +/** + * @param {string} characters + */ +function isValidHTTPToken (characters) { + if (characters.length === 0) { + return false + } + for (let i = 0; i < characters.length; ++i) { + if (!isTokenCharCode(characters.charCodeAt(i))) { + return false + } + } + return true +} + +/** + * @see https://fetch.spec.whatwg.org/#header-name + * @param {string} potentialValue + */ +function isValidHeaderName (potentialValue) { + return isValidHTTPToken(potentialValue) +} + +/** + * @see https://fetch.spec.whatwg.org/#header-value + * @param {string} potentialValue + */ +function isValidHeaderValue (potentialValue) { + // - Has no leading or trailing HTTP tab or space bytes. + // - Contains no 0x00 (NUL) or HTTP newline bytes. + if ( + potentialValue.startsWith('\t') || + potentialValue.startsWith(' ') || + potentialValue.endsWith('\t') || + potentialValue.endsWith(' ') + ) { + return false + } + + if ( + potentialValue.includes('\0') || + potentialValue.includes('\r') || + potentialValue.includes('\n') + ) { + return false + } + + return true +} + +// https://w3c.github.io/webappsec-referrer-policy/#set-requests-referrer-policy-on-redirect +function setRequestReferrerPolicyOnRedirect (request, actualResponse) { + // Given a request request and a response actualResponse, this algorithm + // updates request’s referrer policy according to the Referrer-Policy + // header (if any) in actualResponse. + + // 1. Let policy be the result of executing § 8.1 Parse a referrer policy + // from a Referrer-Policy header on actualResponse. + + // 8.1 Parse a referrer policy from a Referrer-Policy header + // 1. Let policy-tokens be the result of extracting header list values given `Referrer-Policy` and response’s header list. + const { headersList } = actualResponse + // 2. Let policy be the empty string. + // 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. + // 4. Return policy. + const policyHeader = (headersList.get('referrer-policy') ?? '').split(',') + + // Note: As the referrer-policy can contain multiple policies + // separated by comma, we need to loop through all of them + // and pick the first valid one. + // Ref: https://developer.mozilla.org/en-US/docs/Web/HTTP/Headers/Referrer-Policy#specify_a_fallback_policy + let policy = '' + if (policyHeader.length > 0) { + // The right-most policy takes precedence. + // The left-most policy is the fallback. + for (let i = policyHeader.length; i !== 0; i--) { + const token = policyHeader[i - 1].trim() + if (referrerPolicyTokens.has(token)) { + policy = token + break + } + } + } + + // 2. If policy is not the empty string, then set request’s referrer policy to policy. + if (policy !== '') { + request.referrerPolicy = policy + } +} + +// https://fetch.spec.whatwg.org/#cross-origin-resource-policy-check +function crossOriginResourcePolicyCheck () { + // TODO + return 'allowed' +} + +// https://fetch.spec.whatwg.org/#concept-cors-check +function corsCheck () { + // TODO + return 'success' +} + +// https://fetch.spec.whatwg.org/#concept-tao-check +function TAOCheck () { + // TODO + return 'success' +} + +function appendFetchMetadata (httpRequest) { + // https://w3c.github.io/webappsec-fetch-metadata/#sec-fetch-dest-header + // TODO + + // https://w3c.github.io/webappsec-fetch-metadata/#sec-fetch-mode-header + + // 1. Assert: r’s url is a potentially trustworthy URL. + // TODO + + // 2. Let header be a Structured Header whose value is a token. + let header = null + + // 3. Set header’s value to r’s mode. + header = httpRequest.mode + + // 4. Set a structured field value `Sec-Fetch-Mode`/header in r’s header list. + httpRequest.headersList.set('sec-fetch-mode', header) + + // https://w3c.github.io/webappsec-fetch-metadata/#sec-fetch-site-header + // TODO + + // https://w3c.github.io/webappsec-fetch-metadata/#sec-fetch-user-header + // TODO +} + +// https://fetch.spec.whatwg.org/#append-a-request-origin-header +function appendRequestOriginHeader (request) { + // 1. Let serializedOrigin be the result of byte-serializing a request origin with request. + let serializedOrigin = request.origin + + // 2. If request’s response tainting is "cors" or request’s mode is "websocket", then append (`Origin`, serializedOrigin) to request’s header list. + if (request.responseTainting === 'cors' || request.mode === 'websocket') { + if (serializedOrigin) { + request.headersList.append('origin', serializedOrigin) + } + + // 3. Otherwise, if request’s method is neither `GET` nor `HEAD`, then: + } else if (request.method !== 'GET' && request.method !== 'HEAD') { + // 1. Switch on request’s referrer policy: + switch (request.referrerPolicy) { + case 'no-referrer': + // Set serializedOrigin to `null`. + serializedOrigin = null + break + case 'no-referrer-when-downgrade': + case 'strict-origin': + case 'strict-origin-when-cross-origin': + // 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`. + if (request.origin && urlHasHttpsScheme(request.origin) && !urlHasHttpsScheme(requestCurrentURL(request))) { + serializedOrigin = null + } + break + case 'same-origin': + // If request’s origin is not same origin with request’s current URL’s origin, then set serializedOrigin to `null`. + if (!sameOrigin(request, requestCurrentURL(request))) { + serializedOrigin = null + } + break + default: + // Do nothing. + } + + if (serializedOrigin) { + // 2. Append (`Origin`, serializedOrigin) to request’s header list. + request.headersList.append('origin', serializedOrigin) + } + } +} + +function coarsenedSharedCurrentTime (crossOriginIsolatedCapability) { + // TODO + return performance.now() +} + +// https://fetch.spec.whatwg.org/#create-an-opaque-timing-info +function createOpaqueTimingInfo (timingInfo) { + return { + startTime: timingInfo.startTime ?? 0, + redirectStartTime: 0, + redirectEndTime: 0, + postRedirectStartTime: timingInfo.startTime ?? 0, + finalServiceWorkerStartTime: 0, + finalNetworkResponseStartTime: 0, + finalNetworkRequestStartTime: 0, + endTime: 0, + encodedBodySize: 0, + decodedBodySize: 0, + finalConnectionTimingInfo: null + } +} + +// https://html.spec.whatwg.org/multipage/origin.html#policy-container +function makePolicyContainer () { + // Note: the fetch spec doesn't make use of embedder policy or CSP list + return { + referrerPolicy: 'strict-origin-when-cross-origin' + } +} + +// https://html.spec.whatwg.org/multipage/origin.html#clone-a-policy-container +function clonePolicyContainer (policyContainer) { + return { + referrerPolicy: policyContainer.referrerPolicy + } +} + +// https://w3c.github.io/webappsec-referrer-policy/#determine-requests-referrer +function determineRequestsReferrer (request) { + // 1. Let policy be request's referrer policy. + const policy = request.referrerPolicy + + // Note: policy cannot (shouldn't) be null or an empty string. + assert(policy) + + // 2. Let environment be request’s client. + + let referrerSource = null + + // 3. Switch on request’s referrer: + if (request.referrer === 'client') { + // Note: node isn't a browser and doesn't implement document/iframes, + // so we bypass this step and replace it with our own. + + const globalOrigin = getGlobalOrigin() + + if (!globalOrigin || globalOrigin.origin === 'null') { + return 'no-referrer' + } + + // note: we need to clone it as it's mutated + referrerSource = new URL(globalOrigin) + } else if (request.referrer instanceof URL) { + // Let referrerSource be request’s referrer. + referrerSource = request.referrer + } + + // 4. Let request’s referrerURL be the result of stripping referrerSource for + // use as a referrer. + let referrerURL = stripURLForReferrer(referrerSource) + + // 5. Let referrerOrigin be the result of stripping referrerSource for use as + // a referrer, with the origin-only flag set to true. + const referrerOrigin = stripURLForReferrer(referrerSource, true) + + // 6. If the result of serializing referrerURL is a string whose length is + // greater than 4096, set referrerURL to referrerOrigin. + if (referrerURL.toString().length > 4096) { + referrerURL = referrerOrigin + } + + const areSameOrigin = sameOrigin(request, referrerURL) + const isNonPotentiallyTrustWorthy = isURLPotentiallyTrustworthy(referrerURL) && + !isURLPotentiallyTrustworthy(request.url) + + // 8. Execute the switch statements corresponding to the value of policy: + switch (policy) { + case 'origin': return referrerOrigin != null ? referrerOrigin : stripURLForReferrer(referrerSource, true) + case 'unsafe-url': return referrerURL + case 'same-origin': + return areSameOrigin ? referrerOrigin : 'no-referrer' + case 'origin-when-cross-origin': + return areSameOrigin ? referrerURL : referrerOrigin + case 'strict-origin-when-cross-origin': { + const currentURL = requestCurrentURL(request) + + // 1. If the origin of referrerURL and the origin of request’s current + // URL are the same, then return referrerURL. + if (sameOrigin(referrerURL, currentURL)) { + return referrerURL + } + + // 2. If referrerURL is a potentially trustworthy URL and request’s + // current URL is not a potentially trustworthy URL, then return no + // referrer. + if (isURLPotentiallyTrustworthy(referrerURL) && !isURLPotentiallyTrustworthy(currentURL)) { + return 'no-referrer' + } + + // 3. Return referrerOrigin. + return referrerOrigin + } + case 'strict-origin': // eslint-disable-line + /** + * 1. If referrerURL is a potentially trustworthy URL and + * request’s current URL is not a potentially trustworthy URL, + * then return no referrer. + * 2. Return referrerOrigin + */ + case 'no-referrer-when-downgrade': // eslint-disable-line + /** + * 1. If referrerURL is a potentially trustworthy URL and + * request’s current URL is not a potentially trustworthy URL, + * then return no referrer. + * 2. Return referrerOrigin + */ + + default: // eslint-disable-line + return isNonPotentiallyTrustWorthy ? 'no-referrer' : referrerOrigin + } +} + +/** + * @see https://w3c.github.io/webappsec-referrer-policy/#strip-url + * @param {URL} url + * @param {boolean|undefined} originOnly + */ +function stripURLForReferrer (url, originOnly) { + // 1. Assert: url is a URL. + assert(url instanceof URL) + + // 2. If url’s scheme is a local scheme, then return no referrer. + if (url.protocol === 'file:' || url.protocol === 'about:' || url.protocol === 'blank:') { + return 'no-referrer' + } + + // 3. Set url’s username to the empty string. + url.username = '' + + // 4. Set url’s password to the empty string. + url.password = '' + + // 5. Set url’s fragment to null. + url.hash = '' + + // 6. If the origin-only flag is true, then: + if (originOnly) { + // 1. Set url’s path to « the empty string ». + url.pathname = '' + + // 2. Set url’s query to null. + url.search = '' + } + + // 7. Return url. + return url +} + +function isURLPotentiallyTrustworthy (url) { + if (!(url instanceof URL)) { + return false + } + + // If child of about, return true + if (url.href === 'about:blank' || url.href === 'about:srcdoc') { + return true + } + + // If scheme is data, return true + if (url.protocol === 'data:') return true + + // If file, return true + if (url.protocol === 'file:') return true + + return isOriginPotentiallyTrustworthy(url.origin) + + function isOriginPotentiallyTrustworthy (origin) { + // If origin is explicitly null, return false + if (origin == null || origin === 'null') return false + + const originAsURL = new URL(origin) + + // If secure, return true + if (originAsURL.protocol === 'https:' || originAsURL.protocol === 'wss:') { + return true + } + + // If localhost or variants, return true + if (/^127(?:\.[0-9]+){0,2}\.[0-9]+$|^\[(?:0*:)*?:?0*1\]$/.test(originAsURL.hostname) || + (originAsURL.hostname === 'localhost' || originAsURL.hostname.includes('localhost.')) || + (originAsURL.hostname.endsWith('.localhost'))) { + return true + } + + // If any other, return false + return false + } +} + +/** + * @see https://w3c.github.io/webappsec-subresource-integrity/#does-response-match-metadatalist + * @param {Uint8Array} bytes + * @param {string} metadataList + */ +function bytesMatch (bytes, metadataList) { + // If node is not built with OpenSSL support, we cannot check + // a request's integrity, so allow it by default (the spec will + // allow requests if an invalid hash is given, as precedence). + /* istanbul ignore if: only if node is built with --without-ssl */ + if (crypto === undefined) { + return true + } + + // 1. Let parsedMetadata be the result of parsing metadataList. + const parsedMetadata = parseMetadata(metadataList) + + // 2. If parsedMetadata is no metadata, return true. + if (parsedMetadata === 'no metadata') { + return true + } + + // 3. If response is not eligible for integrity validation, return false. + // TODO + + // 4. If parsedMetadata is the empty set, return true. + if (parsedMetadata.length === 0) { + return true + } + + // 5. Let metadata be the result of getting the strongest + // metadata from parsedMetadata. + const strongest = getStrongestMetadata(parsedMetadata) + const metadata = filterMetadataListByAlgorithm(parsedMetadata, strongest) + + // 6. For each item in metadata: + for (const item of metadata) { + // 1. Let algorithm be the alg component of item. + const algorithm = item.algo + + // 2. Let expectedValue be the val component of item. + const expectedValue = item.hash + + // See https://github.com/web-platform-tests/wpt/commit/e4c5cc7a5e48093220528dfdd1c4012dc3837a0e + // "be liberal with padding". This is annoying, and it's not even in the spec. + + // 3. Let actualValue be the result of applying algorithm to bytes. + let actualValue = crypto.createHash(algorithm).update(bytes).digest('base64') + + if (actualValue[actualValue.length - 1] === '=') { + if (actualValue[actualValue.length - 2] === '=') { + actualValue = actualValue.slice(0, -2) + } else { + actualValue = actualValue.slice(0, -1) + } + } + + // 4. If actualValue is a case-sensitive match for expectedValue, + // return true. + if (compareBase64Mixed(actualValue, expectedValue)) { + return true + } + } + + // 7. Return false. + return false +} + +// https://w3c.github.io/webappsec-subresource-integrity/#grammardef-hash-with-options +// https://www.w3.org/TR/CSP2/#source-list-syntax +// https://www.rfc-editor.org/rfc/rfc5234#appendix-B.1 +const parseHashWithOptions = /(?sha256|sha384|sha512)-((?[A-Za-z0-9+/]+|[A-Za-z0-9_-]+)={0,2}(?:\s|$)( +[!-~]*)?)?/i + +/** + * @see https://w3c.github.io/webappsec-subresource-integrity/#parse-metadata + * @param {string} metadata + */ +function parseMetadata (metadata) { + // 1. Let result be the empty set. + /** @type {{ algo: string, hash: string }[]} */ + const result = [] + + // 2. Let empty be equal to true. + let empty = true + + // 3. For each token returned by splitting metadata on spaces: + for (const token of metadata.split(' ')) { + // 1. Set empty to false. + empty = false + + // 2. Parse token as a hash-with-options. + const parsedToken = parseHashWithOptions.exec(token) + + // 3. If token does not parse, continue to the next token. + if ( + parsedToken === null || + parsedToken.groups === undefined || + parsedToken.groups.algo === undefined + ) { + // Note: Chromium blocks the request at this point, but Firefox + // gives a warning that an invalid integrity was given. The + // correct behavior is to ignore these, and subsequently not + // check the integrity of the resource. + continue + } + + // 4. Let algorithm be the hash-algo component of token. + const algorithm = parsedToken.groups.algo.toLowerCase() + + // 5. If algorithm is a hash function recognized by the user + // agent, add the parsed token to result. + if (supportedHashes.includes(algorithm)) { + result.push(parsedToken.groups) + } + } + + // 4. Return no metadata if empty is true, otherwise return result. + if (empty === true) { + return 'no metadata' + } + + return result +} + +/** + * @param {{ algo: 'sha256' | 'sha384' | 'sha512' }[]} metadataList + */ +function getStrongestMetadata (metadataList) { + // Let algorithm be the algo component of the first item in metadataList. + // Can be sha256 + let algorithm = metadataList[0].algo + // If the algorithm is sha512, then it is the strongest + // and we can return immediately + if (algorithm[3] === '5') { + return algorithm + } + + for (let i = 1; i < metadataList.length; ++i) { + const metadata = metadataList[i] + // If the algorithm is sha512, then it is the strongest + // and we can break the loop immediately + if (metadata.algo[3] === '5') { + algorithm = 'sha512' + break + // If the algorithm is sha384, then a potential sha256 or sha384 is ignored + } else if (algorithm[3] === '3') { + continue + // algorithm is sha256, check if algorithm is sha384 and if so, set it as + // the strongest + } else if (metadata.algo[3] === '3') { + algorithm = 'sha384' + } + } + return algorithm +} + +function filterMetadataListByAlgorithm (metadataList, algorithm) { + if (metadataList.length === 1) { + return metadataList + } + + let pos = 0 + for (let i = 0; i < metadataList.length; ++i) { + if (metadataList[i].algo === algorithm) { + metadataList[pos++] = metadataList[i] + } + } + + metadataList.length = pos + + return metadataList +} + +/** + * Compares two base64 strings, allowing for base64url + * in the second string. + * +* @param {string} actualValue always base64 + * @param {string} expectedValue base64 or base64url + * @returns {boolean} + */ +function compareBase64Mixed (actualValue, expectedValue) { + if (actualValue.length !== expectedValue.length) { + return false + } + for (let i = 0; i < actualValue.length; ++i) { + if (actualValue[i] !== expectedValue[i]) { + if ( + (actualValue[i] === '+' && expectedValue[i] === '-') || + (actualValue[i] === '/' && expectedValue[i] === '_') + ) { + continue + } + return false + } + } + + return true +} + +// https://w3c.github.io/webappsec-upgrade-insecure-requests/#upgrade-request +function tryUpgradeRequestToAPotentiallyTrustworthyURL (request) { + // TODO +} + +/** + * @link {https://html.spec.whatwg.org/multipage/origin.html#same-origin} + * @param {URL} A + * @param {URL} B + */ +function sameOrigin (A, B) { + // 1. If A and B are the same opaque origin, then return true. + if (A.origin === B.origin && A.origin === 'null') { + return true + } + + // 2. If A and B are both tuple origins and their schemes, + // hosts, and port are identical, then return true. + if (A.protocol === B.protocol && A.hostname === B.hostname && A.port === B.port) { + return true + } + + // 3. Return false. + return false +} + +function createDeferredPromise () { + let res + let rej + const promise = new Promise((resolve, reject) => { + res = resolve + rej = reject + }) + + return { promise, resolve: res, reject: rej } +} + +function isAborted (fetchParams) { + return fetchParams.controller.state === 'aborted' +} + +function isCancelled (fetchParams) { + return fetchParams.controller.state === 'aborted' || + fetchParams.controller.state === 'terminated' +} + +const normalizeMethodRecord = { + delete: 'DELETE', + DELETE: 'DELETE', + get: 'GET', + GET: 'GET', + head: 'HEAD', + HEAD: 'HEAD', + options: 'OPTIONS', + OPTIONS: 'OPTIONS', + post: 'POST', + POST: 'POST', + put: 'PUT', + PUT: 'PUT' +} + +// Note: object prototypes should not be able to be referenced. e.g. `Object#hasOwnProperty`. +Object.setPrototypeOf(normalizeMethodRecord, null) + +/** + * @see https://fetch.spec.whatwg.org/#concept-method-normalize + * @param {string} method + */ +function normalizeMethod (method) { + return normalizeMethodRecord[method.toLowerCase()] ?? method +} + +// https://infra.spec.whatwg.org/#serialize-a-javascript-value-to-a-json-string +function serializeJavascriptValueToJSONString (value) { + // 1. Let result be ? Call(%JSON.stringify%, undefined, « value »). + const result = JSON.stringify(value) + + // 2. If result is undefined, then throw a TypeError. + if (result === undefined) { + throw new TypeError('Value is not JSON serializable') + } + + // 3. Assert: result is a string. + assert(typeof result === 'string') + + // 4. Return result. + return result +} + +// https://tc39.es/ecma262/#sec-%25iteratorprototype%25-object +const esIteratorPrototype = Object.getPrototypeOf(Object.getPrototypeOf([][Symbol.iterator]())) + +/** + * @see https://webidl.spec.whatwg.org/#dfn-iterator-prototype-object + * @param {() => unknown[]} iterator + * @param {string} name name of the instance + * @param {'key'|'value'|'key+value'} kind + */ +function makeIterator (iterator, name, kind) { + const object = { + index: 0, + kind, + target: iterator + } + + const i = { + next () { + // 1. Let interface be the interface for which the iterator prototype object exists. + + // 2. Let thisValue be the this value. + + // 3. Let object be ? ToObject(thisValue). + + // 4. If object is a platform object, then perform a security + // check, passing: + + // 5. If object is not a default iterator object for interface, + // then throw a TypeError. + if (Object.getPrototypeOf(this) !== i) { + throw new TypeError( + `'next' called on an object that does not implement interface ${name} Iterator.` + ) + } + + // 6. Let index be object’s index. + // 7. Let kind be object’s kind. + // 8. Let values be object’s target's value pairs to iterate over. + const { index, kind, target } = object + const values = target() + + // 9. Let len be the length of values. + const len = values.length + + // 10. If index is greater than or equal to len, then return + // CreateIterResultObject(undefined, true). + if (index >= len) { + return { value: undefined, done: true } + } + + // 11. Let pair be the entry in values at index index. + const pair = values[index] + + // 12. Set object’s index to index + 1. + object.index = index + 1 + + // 13. Return the iterator result for pair and kind. + return iteratorResult(pair, kind) + }, + // The class string of an iterator prototype object for a given interface is the + // result of concatenating the identifier of the interface and the string " Iterator". + [Symbol.toStringTag]: `${name} Iterator` + } + + // The [[Prototype]] internal slot of an iterator prototype object must be %IteratorPrototype%. + Object.setPrototypeOf(i, esIteratorPrototype) + // esIteratorPrototype needs to be the prototype of i + // which is the prototype of an empty object. Yes, it's confusing. + return Object.setPrototypeOf({}, i) +} + +// https://webidl.spec.whatwg.org/#iterator-result +function iteratorResult (pair, kind) { + let result + + // 1. Let result be a value determined by the value of kind: + switch (kind) { + case 'key': { + // 1. Let idlKey be pair’s key. + // 2. Let key be the result of converting idlKey to an + // ECMAScript value. + // 3. result is key. + result = pair[0] + break + } + case 'value': { + // 1. Let idlValue be pair’s value. + // 2. Let value be the result of converting idlValue to + // an ECMAScript value. + // 3. result is value. + result = pair[1] + break + } + case 'key+value': { + // 1. Let idlKey be pair’s key. + // 2. Let idlValue be pair’s value. + // 3. Let key be the result of converting idlKey to an + // ECMAScript value. + // 4. Let value be the result of converting idlValue to + // an ECMAScript value. + // 5. Let array be ! ArrayCreate(2). + // 6. Call ! CreateDataProperty(array, "0", key). + // 7. Call ! CreateDataProperty(array, "1", value). + // 8. result is array. + result = pair + break + } + } + + // 2. Return CreateIterResultObject(result, false). + return { value: result, done: false } +} + +/** + * @see https://fetch.spec.whatwg.org/#body-fully-read + */ +async function fullyReadBody (body, processBody, processBodyError) { + // 1. If taskDestination is null, then set taskDestination to + // the result of starting a new parallel queue. + + // 2. Let successSteps given a byte sequence bytes be to queue a + // fetch task to run processBody given bytes, with taskDestination. + const successSteps = processBody + + // 3. Let errorSteps be to queue a fetch task to run processBodyError, + // with taskDestination. + const errorSteps = processBodyError + + // 4. Let reader be the result of getting a reader for body’s stream. + // If that threw an exception, then run errorSteps with that + // exception and return. + let reader + + try { + reader = body.stream.getReader() + } catch (e) { + errorSteps(e) + return + } + + // 5. Read all bytes from reader, given successSteps and errorSteps. + try { + const result = await readAllBytes(reader) + successSteps(result) + } catch (e) { + errorSteps(e) + } +} + +/** @type {ReadableStream} */ +let ReadableStream = globalThis.ReadableStream + +function isReadableStreamLike (stream) { + if (!ReadableStream) { + ReadableStream = (__nccwpck_require__(3774).ReadableStream) + } + + return stream instanceof ReadableStream || ( + stream[Symbol.toStringTag] === 'ReadableStream' && + typeof stream.tee === 'function' + ) +} + +const MAXIMUM_ARGUMENT_LENGTH = 65535 + +/** + * @see https://infra.spec.whatwg.org/#isomorphic-decode + * @param {number[]|Uint8Array} input + */ +function isomorphicDecode (input) { + // 1. To isomorphic decode a byte sequence input, return a string whose code point + // length is equal to input’s length and whose code points have the same values + // as the values of input’s bytes, in the same order. + + if (input.length < MAXIMUM_ARGUMENT_LENGTH) { + return String.fromCharCode(...input) + } + + return input.reduce((previous, current) => previous + String.fromCharCode(current), '') +} + +/** + * @param {ReadableStreamController} controller + */ +function readableStreamClose (controller) { + try { + controller.close() + } catch (err) { + // TODO: add comment explaining why this error occurs. + if (!err.message.includes('Controller is already closed')) { + throw err + } + } +} + +/** + * @see https://infra.spec.whatwg.org/#isomorphic-encode + * @param {string} input + */ +function isomorphicEncode (input) { + // 1. Assert: input contains no code points greater than U+00FF. + for (let i = 0; i < input.length; i++) { + assert(input.charCodeAt(i) <= 0xFF) + } + + // 2. Return a byte sequence whose length is equal to input’s code + // point length and whose bytes have the same values as the + // values of input’s code points, in the same order + return input +} + +/** + * @see https://streams.spec.whatwg.org/#readablestreamdefaultreader-read-all-bytes + * @see https://streams.spec.whatwg.org/#read-loop + * @param {ReadableStreamDefaultReader} reader + */ +async function readAllBytes (reader) { + const bytes = [] + let byteLength = 0 + + while (true) { + const { done, value: chunk } = await reader.read() + + if (done) { + // 1. Call successSteps with bytes. + return Buffer.concat(bytes, byteLength) + } + + // 1. If chunk is not a Uint8Array object, call failureSteps + // with a TypeError and abort these steps. + if (!isUint8Array(chunk)) { + throw new TypeError('Received non-Uint8Array chunk') + } + + // 2. Append the bytes represented by chunk to bytes. + bytes.push(chunk) + byteLength += chunk.length + + // 3. Read-loop given reader, bytes, successSteps, and failureSteps. + } +} + +/** + * @see https://fetch.spec.whatwg.org/#is-local + * @param {URL} url + */ +function urlIsLocal (url) { + assert('protocol' in url) // ensure it's a url object + + const protocol = url.protocol + + return protocol === 'about:' || protocol === 'blob:' || protocol === 'data:' +} + +/** + * @param {string|URL} url + */ +function urlHasHttpsScheme (url) { + if (typeof url === 'string') { + return url.startsWith('https:') + } + + return url.protocol === 'https:' +} + +/** + * @see https://fetch.spec.whatwg.org/#http-scheme + * @param {URL} url + */ +function urlIsHttpHttpsScheme (url) { + assert('protocol' in url) // ensure it's a url object + + const protocol = url.protocol + + return protocol === 'http:' || protocol === 'https:' +} + +/** + * Fetch supports node >= 16.8.0, but Object.hasOwn was added in v16.9.0. + */ +const hasOwn = Object.hasOwn || ((dict, key) => Object.prototype.hasOwnProperty.call(dict, key)) + +module.exports = { + isAborted, + isCancelled, + createDeferredPromise, + ReadableStreamFrom, + toUSVString, + tryUpgradeRequestToAPotentiallyTrustworthyURL, + coarsenedSharedCurrentTime, + determineRequestsReferrer, + makePolicyContainer, + clonePolicyContainer, + appendFetchMetadata, + appendRequestOriginHeader, + TAOCheck, + corsCheck, + crossOriginResourcePolicyCheck, + createOpaqueTimingInfo, + setRequestReferrerPolicyOnRedirect, + isValidHTTPToken, + requestBadPort, + requestCurrentURL, + responseURL, + responseLocationURL, + isBlobLike, + isURLPotentiallyTrustworthy, + isValidReasonPhrase, + sameOrigin, + normalizeMethod, + serializeJavascriptValueToJSONString, + makeIterator, + isValidHeaderName, + isValidHeaderValue, + hasOwn, + isErrorLike, + fullyReadBody, + bytesMatch, + isReadableStreamLike, + readableStreamClose, + isomorphicEncode, + isomorphicDecode, + urlIsLocal, + urlHasHttpsScheme, + urlIsHttpHttpsScheme, + readAllBytes, + normalizeMethodRecord, + parseMetadata +} + + +/***/ }), + +/***/ 4222: +/***/ ((module, __unused_webpack_exports, __nccwpck_require__) => { + + + +const { types } = __nccwpck_require__(9023) +const { hasOwn, toUSVString } = __nccwpck_require__(5523) + +/** @type {import('../../types/webidl').Webidl} */ +const webidl = {} +webidl.converters = {} +webidl.util = {} +webidl.errors = {} + +webidl.errors.exception = function (message) { + return new TypeError(`${message.header}: ${message.message}`) +} + +webidl.errors.conversionFailed = function (context) { + const plural = context.types.length === 1 ? '' : ' one of' + const message = + `${context.argument} could not be converted to` + + `${plural}: ${context.types.join(', ')}.` + + return webidl.errors.exception({ + header: context.prefix, + message + }) +} + +webidl.errors.invalidArgument = function (context) { + return webidl.errors.exception({ + header: context.prefix, + message: `"${context.value}" is an invalid ${context.type}.` + }) +} + +// https://webidl.spec.whatwg.org/#implements +webidl.brandCheck = function (V, I, opts = undefined) { + if (opts?.strict !== false && !(V instanceof I)) { + throw new TypeError('Illegal invocation') + } else { + return V?.[Symbol.toStringTag] === I.prototype[Symbol.toStringTag] + } +} + +webidl.argumentLengthCheck = function ({ length }, min, ctx) { + if (length < min) { + throw webidl.errors.exception({ + message: `${min} argument${min !== 1 ? 's' : ''} required, ` + + `but${length ? ' only' : ''} ${length} found.`, + ...ctx + }) + } +} + +webidl.illegalConstructor = function () { + throw webidl.errors.exception({ + header: 'TypeError', + message: 'Illegal constructor' + }) +} + +// https://tc39.es/ecma262/#sec-ecmascript-data-types-and-values +webidl.util.Type = function (V) { + switch (typeof V) { + case 'undefined': return 'Undefined' + case 'boolean': return 'Boolean' + case 'string': return 'String' + case 'symbol': return 'Symbol' + case 'number': return 'Number' + case 'bigint': return 'BigInt' + case 'function': + case 'object': { + if (V === null) { + return 'Null' + } + + return 'Object' + } + } +} + +// https://webidl.spec.whatwg.org/#abstract-opdef-converttoint +webidl.util.ConvertToInt = function (V, bitLength, signedness, opts = {}) { + let upperBound + let lowerBound + + // 1. If bitLength is 64, then: + if (bitLength === 64) { + // 1. Let upperBound be 2^53 − 1. + upperBound = Math.pow(2, 53) - 1 + + // 2. If signedness is "unsigned", then let lowerBound be 0. + if (signedness === 'unsigned') { + lowerBound = 0 + } else { + // 3. Otherwise let lowerBound be −2^53 + 1. + lowerBound = Math.pow(-2, 53) + 1 + } + } else if (signedness === 'unsigned') { + // 2. Otherwise, if signedness is "unsigned", then: + + // 1. Let lowerBound be 0. + lowerBound = 0 + + // 2. Let upperBound be 2^bitLength − 1. + upperBound = Math.pow(2, bitLength) - 1 + } else { + // 3. Otherwise: + + // 1. Let lowerBound be -2^bitLength − 1. + lowerBound = Math.pow(-2, bitLength) - 1 + + // 2. Let upperBound be 2^bitLength − 1 − 1. + upperBound = Math.pow(2, bitLength - 1) - 1 + } + + // 4. Let x be ? ToNumber(V). + let x = Number(V) + + // 5. If x is −0, then set x to +0. + if (x === 0) { + x = 0 + } + + // 6. If the conversion is to an IDL type associated + // with the [EnforceRange] extended attribute, then: + if (opts.enforceRange === true) { + // 1. If x is NaN, +∞, or −∞, then throw a TypeError. + if ( + Number.isNaN(x) || + x === Number.POSITIVE_INFINITY || + x === Number.NEGATIVE_INFINITY + ) { + throw webidl.errors.exception({ + header: 'Integer conversion', + message: `Could not convert ${V} to an integer.` + }) + } + + // 2. Set x to IntegerPart(x). + x = webidl.util.IntegerPart(x) + + // 3. If x < lowerBound or x > upperBound, then + // throw a TypeError. + if (x < lowerBound || x > upperBound) { + throw webidl.errors.exception({ + header: 'Integer conversion', + message: `Value must be between ${lowerBound}-${upperBound}, got ${x}.` + }) + } + + // 4. Return x. + return x + } + + // 7. If x is not NaN and the conversion is to an IDL + // type associated with the [Clamp] extended + // attribute, then: + if (!Number.isNaN(x) && opts.clamp === true) { + // 1. Set x to min(max(x, lowerBound), upperBound). + x = Math.min(Math.max(x, lowerBound), upperBound) + + // 2. Round x to the nearest integer, choosing the + // even integer if it lies halfway between two, + // and choosing +0 rather than −0. + if (Math.floor(x) % 2 === 0) { + x = Math.floor(x) + } else { + x = Math.ceil(x) + } + + // 3. Return x. + return x + } + + // 8. If x is NaN, +0, +∞, or −∞, then return +0. + if ( + Number.isNaN(x) || + (x === 0 && Object.is(0, x)) || + x === Number.POSITIVE_INFINITY || + x === Number.NEGATIVE_INFINITY + ) { + return 0 + } + + // 9. Set x to IntegerPart(x). + x = webidl.util.IntegerPart(x) + + // 10. Set x to x modulo 2^bitLength. + x = x % Math.pow(2, bitLength) + + // 11. If signedness is "signed" and x ≥ 2^bitLength − 1, + // then return x − 2^bitLength. + if (signedness === 'signed' && x >= Math.pow(2, bitLength) - 1) { + return x - Math.pow(2, bitLength) + } + + // 12. Otherwise, return x. + return x +} + +// https://webidl.spec.whatwg.org/#abstract-opdef-integerpart +webidl.util.IntegerPart = function (n) { + // 1. Let r be floor(abs(n)). + const r = Math.floor(Math.abs(n)) + + // 2. If n < 0, then return -1 × r. + if (n < 0) { + return -1 * r + } + + // 3. Otherwise, return r. + return r +} + +// https://webidl.spec.whatwg.org/#es-sequence +webidl.sequenceConverter = function (converter) { + return (V) => { + // 1. If Type(V) is not Object, throw a TypeError. + if (webidl.util.Type(V) !== 'Object') { + throw webidl.errors.exception({ + header: 'Sequence', + message: `Value of type ${webidl.util.Type(V)} is not an Object.` + }) + } + + // 2. Let method be ? GetMethod(V, @@iterator). + /** @type {Generator} */ + const method = V?.[Symbol.iterator]?.() + const seq = [] + + // 3. If method is undefined, throw a TypeError. + if ( + method === undefined || + typeof method.next !== 'function' + ) { + throw webidl.errors.exception({ + header: 'Sequence', + message: 'Object is not an iterator.' + }) + } + + // https://webidl.spec.whatwg.org/#create-sequence-from-iterable + while (true) { + const { done, value } = method.next() + + if (done) { + break + } + + seq.push(converter(value)) + } + + return seq + } +} + +// https://webidl.spec.whatwg.org/#es-to-record +webidl.recordConverter = function (keyConverter, valueConverter) { + return (O) => { + // 1. If Type(O) is not Object, throw a TypeError. + if (webidl.util.Type(O) !== 'Object') { + throw webidl.errors.exception({ + header: 'Record', + message: `Value of type ${webidl.util.Type(O)} is not an Object.` + }) + } + + // 2. Let result be a new empty instance of record. + const result = {} + + if (!types.isProxy(O)) { + // Object.keys only returns enumerable properties + const keys = Object.keys(O) + + for (const key of keys) { + // 1. Let typedKey be key converted to an IDL value of type K. + const typedKey = keyConverter(key) + + // 2. Let value be ? Get(O, key). + // 3. Let typedValue be value converted to an IDL value of type V. + const typedValue = valueConverter(O[key]) + + // 4. Set result[typedKey] to typedValue. + result[typedKey] = typedValue + } + + // 5. Return result. + return result + } + + // 3. Let keys be ? O.[[OwnPropertyKeys]](). + const keys = Reflect.ownKeys(O) + + // 4. For each key of keys. + for (const key of keys) { + // 1. Let desc be ? O.[[GetOwnProperty]](key). + const desc = Reflect.getOwnPropertyDescriptor(O, key) + + // 2. If desc is not undefined and desc.[[Enumerable]] is true: + if (desc?.enumerable) { + // 1. Let typedKey be key converted to an IDL value of type K. + const typedKey = keyConverter(key) + + // 2. Let value be ? Get(O, key). + // 3. Let typedValue be value converted to an IDL value of type V. + const typedValue = valueConverter(O[key]) + + // 4. Set result[typedKey] to typedValue. + result[typedKey] = typedValue + } + } + + // 5. Return result. + return result + } +} + +webidl.interfaceConverter = function (i) { + return (V, opts = {}) => { + if (opts.strict !== false && !(V instanceof i)) { + throw webidl.errors.exception({ + header: i.name, + message: `Expected ${V} to be an instance of ${i.name}.` + }) + } + + return V + } +} + +webidl.dictionaryConverter = function (converters) { + return (dictionary) => { + const type = webidl.util.Type(dictionary) + const dict = {} + + if (type === 'Null' || type === 'Undefined') { + return dict + } else if (type !== 'Object') { + throw webidl.errors.exception({ + header: 'Dictionary', + message: `Expected ${dictionary} to be one of: Null, Undefined, Object.` + }) + } + + for (const options of converters) { + const { key, defaultValue, required, converter } = options + + if (required === true) { + if (!hasOwn(dictionary, key)) { + throw webidl.errors.exception({ + header: 'Dictionary', + message: `Missing required key "${key}".` + }) + } + } + + let value = dictionary[key] + const hasDefault = hasOwn(options, 'defaultValue') + + // Only use defaultValue if value is undefined and + // a defaultValue options was provided. + if (hasDefault && value !== null) { + value = value ?? defaultValue + } + + // A key can be optional and have no default value. + // When this happens, do not perform a conversion, + // and do not assign the key a value. + if (required || hasDefault || value !== undefined) { + value = converter(value) + + if ( + options.allowedValues && + !options.allowedValues.includes(value) + ) { + throw webidl.errors.exception({ + header: 'Dictionary', + message: `${value} is not an accepted type. Expected one of ${options.allowedValues.join(', ')}.` + }) + } + + dict[key] = value + } + } + + return dict + } +} + +webidl.nullableConverter = function (converter) { + return (V) => { + if (V === null) { + return V + } + + return converter(V) + } +} + +// https://webidl.spec.whatwg.org/#es-DOMString +webidl.converters.DOMString = function (V, opts = {}) { + // 1. If V is null and the conversion is to an IDL type + // associated with the [LegacyNullToEmptyString] + // extended attribute, then return the DOMString value + // that represents the empty string. + if (V === null && opts.legacyNullToEmptyString) { + return '' + } + + // 2. Let x be ? ToString(V). + if (typeof V === 'symbol') { + throw new TypeError('Could not convert argument of type symbol to string.') + } + + // 3. Return the IDL DOMString value that represents the + // same sequence of code units as the one the + // ECMAScript String value x represents. + return String(V) +} + +// https://webidl.spec.whatwg.org/#es-ByteString +webidl.converters.ByteString = function (V) { + // 1. Let x be ? ToString(V). + // Note: DOMString converter perform ? ToString(V) + const x = webidl.converters.DOMString(V) + + // 2. If the value of any element of x is greater than + // 255, then throw a TypeError. + for (let index = 0; index < x.length; index++) { + if (x.charCodeAt(index) > 255) { + throw new TypeError( + 'Cannot convert argument to a ByteString because the character at ' + + `index ${index} has a value of ${x.charCodeAt(index)} which is greater than 255.` + ) + } + } + + // 3. Return an IDL ByteString value whose length is the + // length of x, and where the value of each element is + // the value of the corresponding element of x. + return x +} + +// https://webidl.spec.whatwg.org/#es-USVString +webidl.converters.USVString = toUSVString + +// https://webidl.spec.whatwg.org/#es-boolean +webidl.converters.boolean = function (V) { + // 1. Let x be the result of computing ToBoolean(V). + const x = Boolean(V) + + // 2. Return the IDL boolean value that is the one that represents + // the same truth value as the ECMAScript Boolean value x. + return x +} + +// https://webidl.spec.whatwg.org/#es-any +webidl.converters.any = function (V) { + return V +} + +// https://webidl.spec.whatwg.org/#es-long-long +webidl.converters['long long'] = function (V) { + // 1. Let x be ? ConvertToInt(V, 64, "signed"). + const x = webidl.util.ConvertToInt(V, 64, 'signed') + + // 2. Return the IDL long long value that represents + // the same numeric value as x. + return x +} + +// https://webidl.spec.whatwg.org/#es-unsigned-long-long +webidl.converters['unsigned long long'] = function (V) { + // 1. Let x be ? ConvertToInt(V, 64, "unsigned"). + const x = webidl.util.ConvertToInt(V, 64, 'unsigned') + + // 2. Return the IDL unsigned long long value that + // represents the same numeric value as x. + return x +} + +// https://webidl.spec.whatwg.org/#es-unsigned-long +webidl.converters['unsigned long'] = function (V) { + // 1. Let x be ? ConvertToInt(V, 32, "unsigned"). + const x = webidl.util.ConvertToInt(V, 32, 'unsigned') + + // 2. Return the IDL unsigned long value that + // represents the same numeric value as x. + return x +} + +// https://webidl.spec.whatwg.org/#es-unsigned-short +webidl.converters['unsigned short'] = function (V, opts) { + // 1. Let x be ? ConvertToInt(V, 16, "unsigned"). + const x = webidl.util.ConvertToInt(V, 16, 'unsigned', opts) + + // 2. Return the IDL unsigned short value that represents + // the same numeric value as x. + return x +} + +// https://webidl.spec.whatwg.org/#idl-ArrayBuffer +webidl.converters.ArrayBuffer = function (V, opts = {}) { + // 1. If Type(V) is not Object, or V does not have an + // [[ArrayBufferData]] internal slot, then throw a + // TypeError. + // see: https://tc39.es/ecma262/#sec-properties-of-the-arraybuffer-instances + // see: https://tc39.es/ecma262/#sec-properties-of-the-sharedarraybuffer-instances + if ( + webidl.util.Type(V) !== 'Object' || + !types.isAnyArrayBuffer(V) + ) { + throw webidl.errors.conversionFailed({ + prefix: `${V}`, + argument: `${V}`, + types: ['ArrayBuffer'] + }) + } + + // 2. If the conversion is not to an IDL type associated + // with the [AllowShared] extended attribute, and + // IsSharedArrayBuffer(V) is true, then throw a + // TypeError. + if (opts.allowShared === false && types.isSharedArrayBuffer(V)) { + throw webidl.errors.exception({ + header: 'ArrayBuffer', + message: 'SharedArrayBuffer is not allowed.' + }) + } + + // 3. If the conversion is not to an IDL type associated + // with the [AllowResizable] extended attribute, and + // IsResizableArrayBuffer(V) is true, then throw a + // TypeError. + // Note: resizable ArrayBuffers are currently a proposal. + + // 4. Return the IDL ArrayBuffer value that is a + // reference to the same object as V. + return V +} + +webidl.converters.TypedArray = function (V, T, opts = {}) { + // 1. Let T be the IDL type V is being converted to. + + // 2. If Type(V) is not Object, or V does not have a + // [[TypedArrayName]] internal slot with a value + // equal to T’s name, then throw a TypeError. + if ( + webidl.util.Type(V) !== 'Object' || + !types.isTypedArray(V) || + V.constructor.name !== T.name + ) { + throw webidl.errors.conversionFailed({ + prefix: `${T.name}`, + argument: `${V}`, + types: [T.name] + }) + } + + // 3. If the conversion is not to an IDL type associated + // with the [AllowShared] extended attribute, and + // IsSharedArrayBuffer(V.[[ViewedArrayBuffer]]) is + // true, then throw a TypeError. + if (opts.allowShared === false && types.isSharedArrayBuffer(V.buffer)) { + throw webidl.errors.exception({ + header: 'ArrayBuffer', + message: 'SharedArrayBuffer is not allowed.' + }) + } + + // 4. If the conversion is not to an IDL type associated + // with the [AllowResizable] extended attribute, and + // IsResizableArrayBuffer(V.[[ViewedArrayBuffer]]) is + // true, then throw a TypeError. + // Note: resizable array buffers are currently a proposal + + // 5. Return the IDL value of type T that is a reference + // to the same object as V. + return V +} + +webidl.converters.DataView = function (V, opts = {}) { + // 1. If Type(V) is not Object, or V does not have a + // [[DataView]] internal slot, then throw a TypeError. + if (webidl.util.Type(V) !== 'Object' || !types.isDataView(V)) { + throw webidl.errors.exception({ + header: 'DataView', + message: 'Object is not a DataView.' + }) + } + + // 2. If the conversion is not to an IDL type associated + // with the [AllowShared] extended attribute, and + // IsSharedArrayBuffer(V.[[ViewedArrayBuffer]]) is true, + // then throw a TypeError. + if (opts.allowShared === false && types.isSharedArrayBuffer(V.buffer)) { + throw webidl.errors.exception({ + header: 'ArrayBuffer', + message: 'SharedArrayBuffer is not allowed.' + }) + } + + // 3. If the conversion is not to an IDL type associated + // with the [AllowResizable] extended attribute, and + // IsResizableArrayBuffer(V.[[ViewedArrayBuffer]]) is + // true, then throw a TypeError. + // Note: resizable ArrayBuffers are currently a proposal + + // 4. Return the IDL DataView value that is a reference + // to the same object as V. + return V +} + +// https://webidl.spec.whatwg.org/#BufferSource +webidl.converters.BufferSource = function (V, opts = {}) { + if (types.isAnyArrayBuffer(V)) { + return webidl.converters.ArrayBuffer(V, opts) + } + + if (types.isTypedArray(V)) { + return webidl.converters.TypedArray(V, V.constructor) + } + + if (types.isDataView(V)) { + return webidl.converters.DataView(V, opts) + } + + throw new TypeError(`Could not convert ${V} to a BufferSource.`) +} + +webidl.converters['sequence'] = webidl.sequenceConverter( + webidl.converters.ByteString +) + +webidl.converters['sequence>'] = webidl.sequenceConverter( + webidl.converters['sequence'] +) + +webidl.converters['record'] = webidl.recordConverter( + webidl.converters.ByteString, + webidl.converters.ByteString +) + +module.exports = { + webidl +} + + +/***/ }), + +/***/ 396: +/***/ ((module) => { + + + +/** + * @see https://encoding.spec.whatwg.org/#concept-encoding-get + * @param {string|undefined} label + */ +function getEncoding (label) { + if (!label) { + return 'failure' + } + + // 1. Remove any leading and trailing ASCII whitespace from label. + // 2. If label is an ASCII case-insensitive match for any of the + // labels listed in the table below, then return the + // corresponding encoding; otherwise return failure. + switch (label.trim().toLowerCase()) { + case 'unicode-1-1-utf-8': + case 'unicode11utf8': + case 'unicode20utf8': + case 'utf-8': + case 'utf8': + case 'x-unicode20utf8': + return 'UTF-8' + case '866': + case 'cp866': + case 'csibm866': + case 'ibm866': + return 'IBM866' + case 'csisolatin2': + case 'iso-8859-2': + case 'iso-ir-101': + case 'iso8859-2': + case 'iso88592': + case 'iso_8859-2': + case 'iso_8859-2:1987': + case 'l2': + case 'latin2': + return 'ISO-8859-2' + case 'csisolatin3': + case 'iso-8859-3': + case 'iso-ir-109': + case 'iso8859-3': + case 'iso88593': + case 'iso_8859-3': + case 'iso_8859-3:1988': + case 'l3': + case 'latin3': + return 'ISO-8859-3' + case 'csisolatin4': + case 'iso-8859-4': + case 'iso-ir-110': + case 'iso8859-4': + case 'iso88594': + case 'iso_8859-4': + case 'iso_8859-4:1988': + case 'l4': + case 'latin4': + return 'ISO-8859-4' + case 'csisolatincyrillic': + case 'cyrillic': + case 'iso-8859-5': + case 'iso-ir-144': + case 'iso8859-5': + case 'iso88595': + case 'iso_8859-5': + case 'iso_8859-5:1988': + return 'ISO-8859-5' + case 'arabic': + case 'asmo-708': + case 'csiso88596e': + case 'csiso88596i': + case 'csisolatinarabic': + case 'ecma-114': + case 'iso-8859-6': + case 'iso-8859-6-e': + case 'iso-8859-6-i': + case 'iso-ir-127': + case 'iso8859-6': + case 'iso88596': + case 'iso_8859-6': + case 'iso_8859-6:1987': + return 'ISO-8859-6' + case 'csisolatingreek': + case 'ecma-118': + case 'elot_928': + case 'greek': + case 'greek8': + case 'iso-8859-7': + case 'iso-ir-126': + case 'iso8859-7': + case 'iso88597': + case 'iso_8859-7': + case 'iso_8859-7:1987': + case 'sun_eu_greek': + return 'ISO-8859-7' + case 'csiso88598e': + case 'csisolatinhebrew': + case 'hebrew': + case 'iso-8859-8': + case 'iso-8859-8-e': + case 'iso-ir-138': + case 'iso8859-8': + case 'iso88598': + case 'iso_8859-8': + case 'iso_8859-8:1988': + case 'visual': + return 'ISO-8859-8' + case 'csiso88598i': + case 'iso-8859-8-i': + case 'logical': + return 'ISO-8859-8-I' + case 'csisolatin6': + case 'iso-8859-10': + case 'iso-ir-157': + case 'iso8859-10': + case 'iso885910': + case 'l6': + case 'latin6': + return 'ISO-8859-10' + case 'iso-8859-13': + case 'iso8859-13': + case 'iso885913': + return 'ISO-8859-13' + case 'iso-8859-14': + case 'iso8859-14': + case 'iso885914': + return 'ISO-8859-14' + case 'csisolatin9': + case 'iso-8859-15': + case 'iso8859-15': + case 'iso885915': + case 'iso_8859-15': + case 'l9': + return 'ISO-8859-15' + case 'iso-8859-16': + return 'ISO-8859-16' + case 'cskoi8r': + case 'koi': + case 'koi8': + case 'koi8-r': + case 'koi8_r': + return 'KOI8-R' + case 'koi8-ru': + case 'koi8-u': + return 'KOI8-U' + case 'csmacintosh': + case 'mac': + case 'macintosh': + case 'x-mac-roman': + return 'macintosh' + case 'iso-8859-11': + case 'iso8859-11': + case 'iso885911': + case 'tis-620': + case 'windows-874': + return 'windows-874' + case 'cp1250': + case 'windows-1250': + case 'x-cp1250': + return 'windows-1250' + case 'cp1251': + case 'windows-1251': + case 'x-cp1251': + return 'windows-1251' + case 'ansi_x3.4-1968': + case 'ascii': + case 'cp1252': + case 'cp819': + case 'csisolatin1': + case 'ibm819': + case 'iso-8859-1': + case 'iso-ir-100': + case 'iso8859-1': + case 'iso88591': + case 'iso_8859-1': + case 'iso_8859-1:1987': + case 'l1': + case 'latin1': + case 'us-ascii': + case 'windows-1252': + case 'x-cp1252': + return 'windows-1252' + case 'cp1253': + case 'windows-1253': + case 'x-cp1253': + return 'windows-1253' + case 'cp1254': + case 'csisolatin5': + case 'iso-8859-9': + case 'iso-ir-148': + case 'iso8859-9': + case 'iso88599': + case 'iso_8859-9': + case 'iso_8859-9:1989': + case 'l5': + case 'latin5': + case 'windows-1254': + case 'x-cp1254': + return 'windows-1254' + case 'cp1255': + case 'windows-1255': + case 'x-cp1255': + return 'windows-1255' + case 'cp1256': + case 'windows-1256': + case 'x-cp1256': + return 'windows-1256' + case 'cp1257': + case 'windows-1257': + case 'x-cp1257': + return 'windows-1257' + case 'cp1258': + case 'windows-1258': + case 'x-cp1258': + return 'windows-1258' + case 'x-mac-cyrillic': + case 'x-mac-ukrainian': + return 'x-mac-cyrillic' + case 'chinese': + case 'csgb2312': + case 'csiso58gb231280': + case 'gb2312': + case 'gb_2312': + case 'gb_2312-80': + case 'gbk': + case 'iso-ir-58': + case 'x-gbk': + return 'GBK' + case 'gb18030': + return 'gb18030' + case 'big5': + case 'big5-hkscs': + case 'cn-big5': + case 'csbig5': + case 'x-x-big5': + return 'Big5' + case 'cseucpkdfmtjapanese': + case 'euc-jp': + case 'x-euc-jp': + return 'EUC-JP' + case 'csiso2022jp': + case 'iso-2022-jp': + return 'ISO-2022-JP' + case 'csshiftjis': + case 'ms932': + case 'ms_kanji': + case 'shift-jis': + case 'shift_jis': + case 'sjis': + case 'windows-31j': + case 'x-sjis': + return 'Shift_JIS' + case 'cseuckr': + case 'csksc56011987': + case 'euc-kr': + case 'iso-ir-149': + case 'korean': + case 'ks_c_5601-1987': + case 'ks_c_5601-1989': + case 'ksc5601': + case 'ksc_5601': + case 'windows-949': + return 'EUC-KR' + case 'csiso2022kr': + case 'hz-gb-2312': + case 'iso-2022-cn': + case 'iso-2022-cn-ext': + case 'iso-2022-kr': + case 'replacement': + return 'replacement' + case 'unicodefffe': + case 'utf-16be': + return 'UTF-16BE' + case 'csunicode': + case 'iso-10646-ucs-2': + case 'ucs-2': + case 'unicode': + case 'unicodefeff': + case 'utf-16': + case 'utf-16le': + return 'UTF-16LE' + case 'x-user-defined': + return 'x-user-defined' + default: return 'failure' + } +} + +module.exports = { + getEncoding +} + + +/***/ }), + +/***/ 2160: +/***/ ((module, __unused_webpack_exports, __nccwpck_require__) => { + + + +const { + staticPropertyDescriptors, + readOperation, + fireAProgressEvent +} = __nccwpck_require__(165) +const { + kState, + kError, + kResult, + kEvents, + kAborted +} = __nccwpck_require__(6812) +const { webidl } = __nccwpck_require__(4222) +const { kEnumerableProperty } = __nccwpck_require__(3440) + +class FileReader extends EventTarget { + constructor () { + super() + + this[kState] = 'empty' + this[kResult] = null + this[kError] = null + this[kEvents] = { + loadend: null, + error: null, + abort: null, + load: null, + progress: null, + loadstart: null + } + } + + /** + * @see https://w3c.github.io/FileAPI/#dfn-readAsArrayBuffer + * @param {import('buffer').Blob} blob + */ + readAsArrayBuffer (blob) { + webidl.brandCheck(this, FileReader) + + webidl.argumentLengthCheck(arguments, 1, { header: 'FileReader.readAsArrayBuffer' }) + + blob = webidl.converters.Blob(blob, { strict: false }) + + // The readAsArrayBuffer(blob) method, when invoked, + // must initiate a read operation for blob with ArrayBuffer. + readOperation(this, blob, 'ArrayBuffer') + } + + /** + * @see https://w3c.github.io/FileAPI/#readAsBinaryString + * @param {import('buffer').Blob} blob + */ + readAsBinaryString (blob) { + webidl.brandCheck(this, FileReader) + + webidl.argumentLengthCheck(arguments, 1, { header: 'FileReader.readAsBinaryString' }) + + blob = webidl.converters.Blob(blob, { strict: false }) + + // The readAsBinaryString(blob) method, when invoked, + // must initiate a read operation for blob with BinaryString. + readOperation(this, blob, 'BinaryString') + } + + /** + * @see https://w3c.github.io/FileAPI/#readAsDataText + * @param {import('buffer').Blob} blob + * @param {string?} encoding + */ + readAsText (blob, encoding = undefined) { + webidl.brandCheck(this, FileReader) + + webidl.argumentLengthCheck(arguments, 1, { header: 'FileReader.readAsText' }) + + blob = webidl.converters.Blob(blob, { strict: false }) + + if (encoding !== undefined) { + encoding = webidl.converters.DOMString(encoding) + } + + // The readAsText(blob, encoding) method, when invoked, + // must initiate a read operation for blob with Text and encoding. + readOperation(this, blob, 'Text', encoding) + } + + /** + * @see https://w3c.github.io/FileAPI/#dfn-readAsDataURL + * @param {import('buffer').Blob} blob + */ + readAsDataURL (blob) { + webidl.brandCheck(this, FileReader) + + webidl.argumentLengthCheck(arguments, 1, { header: 'FileReader.readAsDataURL' }) + + blob = webidl.converters.Blob(blob, { strict: false }) + + // The readAsDataURL(blob) method, when invoked, must + // initiate a read operation for blob with DataURL. + readOperation(this, blob, 'DataURL') + } + + /** + * @see https://w3c.github.io/FileAPI/#dfn-abort + */ + abort () { + // 1. If this's state is "empty" or if this's state is + // "done" set this's result to null and terminate + // this algorithm. + if (this[kState] === 'empty' || this[kState] === 'done') { + this[kResult] = null + return + } + + // 2. If this's state is "loading" set this's state to + // "done" and set this's result to null. + if (this[kState] === 'loading') { + this[kState] = 'done' + this[kResult] = null + } + + // 3. If there are any tasks from this on the file reading + // task source in an affiliated task queue, then remove + // those tasks from that task queue. + this[kAborted] = true + + // 4. Terminate the algorithm for the read method being processed. + // TODO + + // 5. Fire a progress event called abort at this. + fireAProgressEvent('abort', this) + + // 6. If this's state is not "loading", fire a progress + // event called loadend at this. + if (this[kState] !== 'loading') { + fireAProgressEvent('loadend', this) + } + } + + /** + * @see https://w3c.github.io/FileAPI/#dom-filereader-readystate + */ + get readyState () { + webidl.brandCheck(this, FileReader) + + switch (this[kState]) { + case 'empty': return this.EMPTY + case 'loading': return this.LOADING + case 'done': return this.DONE + } + } + + /** + * @see https://w3c.github.io/FileAPI/#dom-filereader-result + */ + get result () { + webidl.brandCheck(this, FileReader) + + // The result attribute’s getter, when invoked, must return + // this's result. + return this[kResult] + } + + /** + * @see https://w3c.github.io/FileAPI/#dom-filereader-error + */ + get error () { + webidl.brandCheck(this, FileReader) + + // The error attribute’s getter, when invoked, must return + // this's error. + return this[kError] + } + + get onloadend () { + webidl.brandCheck(this, FileReader) + + return this[kEvents].loadend + } + + set onloadend (fn) { + webidl.brandCheck(this, FileReader) + + if (this[kEvents].loadend) { + this.removeEventListener('loadend', this[kEvents].loadend) + } + + if (typeof fn === 'function') { + this[kEvents].loadend = fn + this.addEventListener('loadend', fn) + } else { + this[kEvents].loadend = null + } + } + + get onerror () { + webidl.brandCheck(this, FileReader) + + return this[kEvents].error + } + + set onerror (fn) { + webidl.brandCheck(this, FileReader) + + if (this[kEvents].error) { + this.removeEventListener('error', this[kEvents].error) + } + + if (typeof fn === 'function') { + this[kEvents].error = fn + this.addEventListener('error', fn) + } else { + this[kEvents].error = null + } + } + + get onloadstart () { + webidl.brandCheck(this, FileReader) + + return this[kEvents].loadstart + } + + set onloadstart (fn) { + webidl.brandCheck(this, FileReader) + + if (this[kEvents].loadstart) { + this.removeEventListener('loadstart', this[kEvents].loadstart) + } + + if (typeof fn === 'function') { + this[kEvents].loadstart = fn + this.addEventListener('loadstart', fn) + } else { + this[kEvents].loadstart = null + } + } + + get onprogress () { + webidl.brandCheck(this, FileReader) + + return this[kEvents].progress + } + + set onprogress (fn) { + webidl.brandCheck(this, FileReader) + + if (this[kEvents].progress) { + this.removeEventListener('progress', this[kEvents].progress) + } + + if (typeof fn === 'function') { + this[kEvents].progress = fn + this.addEventListener('progress', fn) + } else { + this[kEvents].progress = null + } + } + + get onload () { + webidl.brandCheck(this, FileReader) + + return this[kEvents].load + } + + set onload (fn) { + webidl.brandCheck(this, FileReader) + + if (this[kEvents].load) { + this.removeEventListener('load', this[kEvents].load) + } + + if (typeof fn === 'function') { + this[kEvents].load = fn + this.addEventListener('load', fn) + } else { + this[kEvents].load = null + } + } + + get onabort () { + webidl.brandCheck(this, FileReader) + + return this[kEvents].abort + } + + set onabort (fn) { + webidl.brandCheck(this, FileReader) + + if (this[kEvents].abort) { + this.removeEventListener('abort', this[kEvents].abort) + } + + if (typeof fn === 'function') { + this[kEvents].abort = fn + this.addEventListener('abort', fn) + } else { + this[kEvents].abort = null + } + } +} + +// https://w3c.github.io/FileAPI/#dom-filereader-empty +FileReader.EMPTY = FileReader.prototype.EMPTY = 0 +// https://w3c.github.io/FileAPI/#dom-filereader-loading +FileReader.LOADING = FileReader.prototype.LOADING = 1 +// https://w3c.github.io/FileAPI/#dom-filereader-done +FileReader.DONE = FileReader.prototype.DONE = 2 + +Object.defineProperties(FileReader.prototype, { + EMPTY: staticPropertyDescriptors, + LOADING: staticPropertyDescriptors, + DONE: staticPropertyDescriptors, + readAsArrayBuffer: kEnumerableProperty, + readAsBinaryString: kEnumerableProperty, + readAsText: kEnumerableProperty, + readAsDataURL: kEnumerableProperty, + abort: kEnumerableProperty, + readyState: kEnumerableProperty, + result: kEnumerableProperty, + error: kEnumerableProperty, + onloadstart: kEnumerableProperty, + onprogress: kEnumerableProperty, + onload: kEnumerableProperty, + onabort: kEnumerableProperty, + onerror: kEnumerableProperty, + onloadend: kEnumerableProperty, + [Symbol.toStringTag]: { + value: 'FileReader', + writable: false, + enumerable: false, + configurable: true + } +}) + +Object.defineProperties(FileReader, { + EMPTY: staticPropertyDescriptors, + LOADING: staticPropertyDescriptors, + DONE: staticPropertyDescriptors +}) + +module.exports = { + FileReader +} + + +/***/ }), + +/***/ 5976: +/***/ ((module, __unused_webpack_exports, __nccwpck_require__) => { + + + +const { webidl } = __nccwpck_require__(4222) + +const kState = Symbol('ProgressEvent state') + +/** + * @see https://xhr.spec.whatwg.org/#progressevent + */ +class ProgressEvent extends Event { + constructor (type, eventInitDict = {}) { + type = webidl.converters.DOMString(type) + eventInitDict = webidl.converters.ProgressEventInit(eventInitDict ?? {}) + + super(type, eventInitDict) + + this[kState] = { + lengthComputable: eventInitDict.lengthComputable, + loaded: eventInitDict.loaded, + total: eventInitDict.total + } + } + + get lengthComputable () { + webidl.brandCheck(this, ProgressEvent) + + return this[kState].lengthComputable + } + + get loaded () { + webidl.brandCheck(this, ProgressEvent) + + return this[kState].loaded + } + + get total () { + webidl.brandCheck(this, ProgressEvent) + + return this[kState].total + } +} + +webidl.converters.ProgressEventInit = webidl.dictionaryConverter([ + { + key: 'lengthComputable', + converter: webidl.converters.boolean, + defaultValue: false + }, + { + key: 'loaded', + converter: webidl.converters['unsigned long long'], + defaultValue: 0 + }, + { + key: 'total', + converter: webidl.converters['unsigned long long'], + defaultValue: 0 + }, + { + key: 'bubbles', + converter: webidl.converters.boolean, + defaultValue: false + }, + { + key: 'cancelable', + converter: webidl.converters.boolean, + defaultValue: false + }, + { + key: 'composed', + converter: webidl.converters.boolean, + defaultValue: false + } +]) + +module.exports = { + ProgressEvent +} + + +/***/ }), + +/***/ 6812: +/***/ ((module) => { + + + +module.exports = { + kState: Symbol('FileReader state'), + kResult: Symbol('FileReader result'), + kError: Symbol('FileReader error'), + kLastProgressEventFired: Symbol('FileReader last progress event fired timestamp'), + kEvents: Symbol('FileReader events'), + kAborted: Symbol('FileReader aborted') +} + + +/***/ }), + +/***/ 165: +/***/ ((module, __unused_webpack_exports, __nccwpck_require__) => { + + + +const { + kState, + kError, + kResult, + kAborted, + kLastProgressEventFired +} = __nccwpck_require__(6812) +const { ProgressEvent } = __nccwpck_require__(5976) +const { getEncoding } = __nccwpck_require__(396) +const { DOMException } = __nccwpck_require__(7326) +const { serializeAMimeType, parseMIMEType } = __nccwpck_require__(4322) +const { types } = __nccwpck_require__(9023) +const { StringDecoder } = __nccwpck_require__(3193) +const { btoa } = __nccwpck_require__(181) + +/** @type {PropertyDescriptor} */ +const staticPropertyDescriptors = { + enumerable: true, + writable: false, + configurable: false +} + +/** + * @see https://w3c.github.io/FileAPI/#readOperation + * @param {import('./filereader').FileReader} fr + * @param {import('buffer').Blob} blob + * @param {string} type + * @param {string?} encodingName + */ +function readOperation (fr, blob, type, encodingName) { + // 1. If fr’s state is "loading", throw an InvalidStateError + // DOMException. + if (fr[kState] === 'loading') { + throw new DOMException('Invalid state', 'InvalidStateError') + } + + // 2. Set fr’s state to "loading". + fr[kState] = 'loading' + + // 3. Set fr’s result to null. + fr[kResult] = null + + // 4. Set fr’s error to null. + fr[kError] = null + + // 5. Let stream be the result of calling get stream on blob. + /** @type {import('stream/web').ReadableStream} */ + const stream = blob.stream() + + // 6. Let reader be the result of getting a reader from stream. + const reader = stream.getReader() + + // 7. Let bytes be an empty byte sequence. + /** @type {Uint8Array[]} */ + const bytes = [] + + // 8. Let chunkPromise be the result of reading a chunk from + // stream with reader. + let chunkPromise = reader.read() + + // 9. Let isFirstChunk be true. + let isFirstChunk = true + + // 10. In parallel, while true: + // Note: "In parallel" just means non-blocking + // Note 2: readOperation itself cannot be async as double + // reading the body would then reject the promise, instead + // of throwing an error. + ;(async () => { + while (!fr[kAborted]) { + // 1. Wait for chunkPromise to be fulfilled or rejected. + try { + const { done, value } = await chunkPromise + + // 2. If chunkPromise is fulfilled, and isFirstChunk is + // true, queue a task to fire a progress event called + // loadstart at fr. + if (isFirstChunk && !fr[kAborted]) { + queueMicrotask(() => { + fireAProgressEvent('loadstart', fr) + }) + } + + // 3. Set isFirstChunk to false. + isFirstChunk = false + + // 4. If chunkPromise is fulfilled with an object whose + // done property is false and whose value property is + // a Uint8Array object, run these steps: + if (!done && types.isUint8Array(value)) { + // 1. Let bs be the byte sequence represented by the + // Uint8Array object. + + // 2. Append bs to bytes. + bytes.push(value) + + // 3. If roughly 50ms have passed since these steps + // were last invoked, queue a task to fire a + // progress event called progress at fr. + if ( + ( + fr[kLastProgressEventFired] === undefined || + Date.now() - fr[kLastProgressEventFired] >= 50 + ) && + !fr[kAborted] + ) { + fr[kLastProgressEventFired] = Date.now() + queueMicrotask(() => { + fireAProgressEvent('progress', fr) + }) + } + + // 4. Set chunkPromise to the result of reading a + // chunk from stream with reader. + chunkPromise = reader.read() + } else if (done) { + // 5. Otherwise, if chunkPromise is fulfilled with an + // object whose done property is true, queue a task + // to run the following steps and abort this algorithm: + queueMicrotask(() => { + // 1. Set fr’s state to "done". + fr[kState] = 'done' + + // 2. Let result be the result of package data given + // bytes, type, blob’s type, and encodingName. + try { + const result = packageData(bytes, type, blob.type, encodingName) + + // 4. Else: + + if (fr[kAborted]) { + return + } + + // 1. Set fr’s result to result. + fr[kResult] = result + + // 2. Fire a progress event called load at the fr. + fireAProgressEvent('load', fr) + } catch (error) { + // 3. If package data threw an exception error: + + // 1. Set fr’s error to error. + fr[kError] = error + + // 2. Fire a progress event called error at fr. + fireAProgressEvent('error', fr) + } + + // 5. If fr’s state is not "loading", fire a progress + // event called loadend at the fr. + if (fr[kState] !== 'loading') { + fireAProgressEvent('loadend', fr) + } + }) + + break + } + } catch (error) { + if (fr[kAborted]) { + return + } + + // 6. Otherwise, if chunkPromise is rejected with an + // error error, queue a task to run the following + // steps and abort this algorithm: + queueMicrotask(() => { + // 1. Set fr’s state to "done". + fr[kState] = 'done' + + // 2. Set fr’s error to error. + fr[kError] = error + + // 3. Fire a progress event called error at fr. + fireAProgressEvent('error', fr) + + // 4. If fr’s state is not "loading", fire a progress + // event called loadend at fr. + if (fr[kState] !== 'loading') { + fireAProgressEvent('loadend', fr) + } + }) + + break + } + } + })() +} + +/** + * @see https://w3c.github.io/FileAPI/#fire-a-progress-event + * @see https://dom.spec.whatwg.org/#concept-event-fire + * @param {string} e The name of the event + * @param {import('./filereader').FileReader} reader + */ +function fireAProgressEvent (e, reader) { + // The progress event e does not bubble. e.bubbles must be false + // The progress event e is NOT cancelable. e.cancelable must be false + const event = new ProgressEvent(e, { + bubbles: false, + cancelable: false + }) + + reader.dispatchEvent(event) +} + +/** + * @see https://w3c.github.io/FileAPI/#blob-package-data + * @param {Uint8Array[]} bytes + * @param {string} type + * @param {string?} mimeType + * @param {string?} encodingName + */ +function packageData (bytes, type, mimeType, encodingName) { + // 1. A Blob has an associated package data algorithm, given + // bytes, a type, a optional mimeType, and a optional + // encodingName, which switches on type and runs the + // associated steps: + + switch (type) { + case 'DataURL': { + // 1. Return bytes as a DataURL [RFC2397] subject to + // the considerations below: + // * Use mimeType as part of the Data URL if it is + // available in keeping with the Data URL + // specification [RFC2397]. + // * If mimeType is not available return a Data URL + // without a media-type. [RFC2397]. + + // https://datatracker.ietf.org/doc/html/rfc2397#section-3 + // dataurl := "data:" [ mediatype ] [ ";base64" ] "," data + // mediatype := [ type "/" subtype ] *( ";" parameter ) + // data := *urlchar + // parameter := attribute "=" value + let dataURL = 'data:' + + const parsed = parseMIMEType(mimeType || 'application/octet-stream') + + if (parsed !== 'failure') { + dataURL += serializeAMimeType(parsed) + } + + dataURL += ';base64,' + + const decoder = new StringDecoder('latin1') + + for (const chunk of bytes) { + dataURL += btoa(decoder.write(chunk)) + } + + dataURL += btoa(decoder.end()) + + return dataURL + } + case 'Text': { + // 1. Let encoding be failure + let encoding = 'failure' + + // 2. If the encodingName is present, set encoding to the + // result of getting an encoding from encodingName. + if (encodingName) { + encoding = getEncoding(encodingName) + } + + // 3. If encoding is failure, and mimeType is present: + if (encoding === 'failure' && mimeType) { + // 1. Let type be the result of parse a MIME type + // given mimeType. + const type = parseMIMEType(mimeType) + + // 2. If type is not failure, set encoding to the result + // of getting an encoding from type’s parameters["charset"]. + if (type !== 'failure') { + encoding = getEncoding(type.parameters.get('charset')) + } + } + + // 4. If encoding is failure, then set encoding to UTF-8. + if (encoding === 'failure') { + encoding = 'UTF-8' + } + + // 5. Decode bytes using fallback encoding encoding, and + // return the result. + return decode(bytes, encoding) + } + case 'ArrayBuffer': { + // Return a new ArrayBuffer whose contents are bytes. + const sequence = combineByteSequences(bytes) + + return sequence.buffer + } + case 'BinaryString': { + // Return bytes as a binary string, in which every byte + // is represented by a code unit of equal value [0..255]. + let binaryString = '' + + const decoder = new StringDecoder('latin1') + + for (const chunk of bytes) { + binaryString += decoder.write(chunk) + } + + binaryString += decoder.end() + + return binaryString + } + } +} + +/** + * @see https://encoding.spec.whatwg.org/#decode + * @param {Uint8Array[]} ioQueue + * @param {string} encoding + */ +function decode (ioQueue, encoding) { + const bytes = combineByteSequences(ioQueue) + + // 1. Let BOMEncoding be the result of BOM sniffing ioQueue. + const BOMEncoding = BOMSniffing(bytes) + + let slice = 0 + + // 2. If BOMEncoding is non-null: + if (BOMEncoding !== null) { + // 1. Set encoding to BOMEncoding. + encoding = BOMEncoding + + // 2. Read three bytes from ioQueue, if BOMEncoding is + // UTF-8; otherwise read two bytes. + // (Do nothing with those bytes.) + slice = BOMEncoding === 'UTF-8' ? 3 : 2 + } + + // 3. Process a queue with an instance of encoding’s + // decoder, ioQueue, output, and "replacement". + + // 4. Return output. + + const sliced = bytes.slice(slice) + return new TextDecoder(encoding).decode(sliced) +} + +/** + * @see https://encoding.spec.whatwg.org/#bom-sniff + * @param {Uint8Array} ioQueue + */ +function BOMSniffing (ioQueue) { + // 1. Let BOM be the result of peeking 3 bytes from ioQueue, + // converted to a byte sequence. + const [a, b, c] = ioQueue + + // 2. For each of the rows in the table below, starting with + // the first one and going down, if BOM starts with the + // bytes given in the first column, then return the + // encoding given in the cell in the second column of that + // row. Otherwise, return null. + if (a === 0xEF && b === 0xBB && c === 0xBF) { + return 'UTF-8' + } else if (a === 0xFE && b === 0xFF) { + return 'UTF-16BE' + } else if (a === 0xFF && b === 0xFE) { + return 'UTF-16LE' + } + + return null +} + +/** + * @param {Uint8Array[]} sequences + */ +function combineByteSequences (sequences) { + const size = sequences.reduce((a, b) => { + return a + b.byteLength + }, 0) + + let offset = 0 + + return sequences.reduce((a, b) => { + a.set(b, offset) + offset += b.byteLength + return a + }, new Uint8Array(size)) +} + +module.exports = { + staticPropertyDescriptors, + readOperation, + fireAProgressEvent +} + + +/***/ }), + +/***/ 2581: +/***/ ((module, __unused_webpack_exports, __nccwpck_require__) => { + + + +// We include a version number for the Dispatcher API. In case of breaking changes, +// this version number must be increased to avoid conflicts. +const globalDispatcher = Symbol.for('undici.globalDispatcher.1') +const { InvalidArgumentError } = __nccwpck_require__(8707) +const Agent = __nccwpck_require__(9965) + +if (getGlobalDispatcher() === undefined) { + setGlobalDispatcher(new Agent()) +} + +function setGlobalDispatcher (agent) { + if (!agent || typeof agent.dispatch !== 'function') { + throw new InvalidArgumentError('Argument agent must implement Agent') + } + Object.defineProperty(globalThis, globalDispatcher, { + value: agent, + writable: true, + enumerable: false, + configurable: false + }) +} + +function getGlobalDispatcher () { + return globalThis[globalDispatcher] +} + +module.exports = { + setGlobalDispatcher, + getGlobalDispatcher +} + + +/***/ }), + +/***/ 8840: +/***/ ((module) => { + + + +module.exports = class DecoratorHandler { + constructor (handler) { + this.handler = handler + } + + onConnect (...args) { + return this.handler.onConnect(...args) + } + + onError (...args) { + return this.handler.onError(...args) + } + + onUpgrade (...args) { + return this.handler.onUpgrade(...args) + } + + onHeaders (...args) { + return this.handler.onHeaders(...args) + } + + onData (...args) { + return this.handler.onData(...args) + } + + onComplete (...args) { + return this.handler.onComplete(...args) + } + + onBodySent (...args) { + return this.handler.onBodySent(...args) + } +} + + +/***/ }), + +/***/ 8299: +/***/ ((module, __unused_webpack_exports, __nccwpck_require__) => { + + + +const util = __nccwpck_require__(3440) +const { kBodyUsed } = __nccwpck_require__(6443) +const assert = __nccwpck_require__(2613) +const { InvalidArgumentError } = __nccwpck_require__(8707) +const EE = __nccwpck_require__(4434) + +const redirectableStatusCodes = [300, 301, 302, 303, 307, 308] + +const kBody = Symbol('body') + +class BodyAsyncIterable { + constructor (body) { + this[kBody] = body + this[kBodyUsed] = false + } + + async * [Symbol.asyncIterator] () { + assert(!this[kBodyUsed], 'disturbed') + this[kBodyUsed] = true + yield * this[kBody] + } +} + +class RedirectHandler { + constructor (dispatch, maxRedirections, opts, handler) { + if (maxRedirections != null && (!Number.isInteger(maxRedirections) || maxRedirections < 0)) { + throw new InvalidArgumentError('maxRedirections must be a positive number') + } + + util.validateHandler(handler, opts.method, opts.upgrade) + + this.dispatch = dispatch + this.location = null + this.abort = null + this.opts = { ...opts, maxRedirections: 0 } // opts must be a copy + this.maxRedirections = maxRedirections + this.handler = handler + this.history = [] + + if (util.isStream(this.opts.body)) { + // TODO (fix): Provide some way for the user to cache the file to e.g. /tmp + // so that it can be dispatched again? + // TODO (fix): Do we need 100-expect support to provide a way to do this properly? + if (util.bodyLength(this.opts.body) === 0) { + this.opts.body + .on('data', function () { + assert(false) + }) + } + + if (typeof this.opts.body.readableDidRead !== 'boolean') { + this.opts.body[kBodyUsed] = false + EE.prototype.on.call(this.opts.body, 'data', function () { + this[kBodyUsed] = true + }) + } + } else if (this.opts.body && typeof this.opts.body.pipeTo === 'function') { + // TODO (fix): We can't access ReadableStream internal state + // to determine whether or not it has been disturbed. This is just + // a workaround. + this.opts.body = new BodyAsyncIterable(this.opts.body) + } else if ( + this.opts.body && + typeof this.opts.body !== 'string' && + !ArrayBuffer.isView(this.opts.body) && + util.isIterable(this.opts.body) + ) { + // TODO: Should we allow re-using iterable if !this.opts.idempotent + // or through some other flag? + this.opts.body = new BodyAsyncIterable(this.opts.body) + } + } + + onConnect (abort) { + this.abort = abort + this.handler.onConnect(abort, { history: this.history }) + } + + onUpgrade (statusCode, headers, socket) { + this.handler.onUpgrade(statusCode, headers, socket) + } + + onError (error) { + this.handler.onError(error) + } + + onHeaders (statusCode, headers, resume, statusText) { + this.location = this.history.length >= this.maxRedirections || util.isDisturbed(this.opts.body) + ? null + : parseLocation(statusCode, headers) + + if (this.opts.origin) { + this.history.push(new URL(this.opts.path, this.opts.origin)) + } + + if (!this.location) { + return this.handler.onHeaders(statusCode, headers, resume, statusText) + } + + const { origin, pathname, search } = util.parseURL(new URL(this.location, this.opts.origin && new URL(this.opts.path, this.opts.origin))) + const path = search ? `${pathname}${search}` : pathname + + // Remove headers referring to the original URL. + // By default it is Host only, unless it's a 303 (see below), which removes also all Content-* headers. + // https://tools.ietf.org/html/rfc7231#section-6.4 + this.opts.headers = cleanRequestHeaders(this.opts.headers, statusCode === 303, this.opts.origin !== origin) + this.opts.path = path + this.opts.origin = origin + this.opts.maxRedirections = 0 + this.opts.query = null + + // https://tools.ietf.org/html/rfc7231#section-6.4.4 + // In case of HTTP 303, always replace method to be either HEAD or GET + if (statusCode === 303 && this.opts.method !== 'HEAD') { + this.opts.method = 'GET' + this.opts.body = null + } + } + + onData (chunk) { + if (this.location) { + /* + https://tools.ietf.org/html/rfc7231#section-6.4 + + TLDR: undici always ignores 3xx response bodies. + + Redirection is used to serve the requested resource from another URL, so it is assumes that + no body is generated (and thus can be ignored). Even though generating a body is not prohibited. + + For status 301, 302, 303, 307 and 308 (the latter from RFC 7238), the specs mention that the body usually + (which means it's optional and not mandated) contain just an hyperlink to the value of + the Location response header, so the body can be ignored safely. + + For status 300, which is "Multiple Choices", the spec mentions both generating a Location + response header AND a response body with the other possible location to follow. + Since the spec explicitily chooses not to specify a format for such body and leave it to + servers and browsers implementors, we ignore the body as there is no specified way to eventually parse it. + */ + } else { + return this.handler.onData(chunk) + } + } + + onComplete (trailers) { + if (this.location) { + /* + https://tools.ietf.org/html/rfc7231#section-6.4 + + TLDR: undici always ignores 3xx response trailers as they are not expected in case of redirections + and neither are useful if present. + + See comment on onData method above for more detailed informations. + */ + + this.location = null + this.abort = null + + this.dispatch(this.opts, this) + } else { + this.handler.onComplete(trailers) + } + } + + onBodySent (chunk) { + if (this.handler.onBodySent) { + this.handler.onBodySent(chunk) + } + } +} + +function parseLocation (statusCode, headers) { + if (redirectableStatusCodes.indexOf(statusCode) === -1) { + return null + } + + for (let i = 0; i < headers.length; i += 2) { + if (headers[i].toString().toLowerCase() === 'location') { + return headers[i + 1] + } + } +} + +// https://tools.ietf.org/html/rfc7231#section-6.4.4 +function shouldRemoveHeader (header, removeContent, unknownOrigin) { + if (header.length === 4) { + return util.headerNameToString(header) === 'host' + } + if (removeContent && util.headerNameToString(header).startsWith('content-')) { + return true + } + if (unknownOrigin && (header.length === 13 || header.length === 6 || header.length === 19)) { + const name = util.headerNameToString(header) + return name === 'authorization' || name === 'cookie' || name === 'proxy-authorization' + } + return false +} + +// https://tools.ietf.org/html/rfc7231#section-6.4 +function cleanRequestHeaders (headers, removeContent, unknownOrigin) { + const ret = [] + if (Array.isArray(headers)) { + for (let i = 0; i < headers.length; i += 2) { + if (!shouldRemoveHeader(headers[i], removeContent, unknownOrigin)) { + ret.push(headers[i], headers[i + 1]) + } + } + } else if (headers && typeof headers === 'object') { + for (const key of Object.keys(headers)) { + if (!shouldRemoveHeader(key, removeContent, unknownOrigin)) { + ret.push(key, headers[key]) + } + } + } else { + assert(headers == null, 'headers must be an object or an array') + } + return ret +} + +module.exports = RedirectHandler + + +/***/ }), + +/***/ 3573: +/***/ ((module, __unused_webpack_exports, __nccwpck_require__) => { + +const assert = __nccwpck_require__(2613) + +const { kRetryHandlerDefaultRetry } = __nccwpck_require__(6443) +const { RequestRetryError } = __nccwpck_require__(8707) +const { isDisturbed, parseHeaders, parseRangeHeader } = __nccwpck_require__(3440) + +function calculateRetryAfterHeader (retryAfter) { + const current = Date.now() + const diff = new Date(retryAfter).getTime() - current + + return diff +} + +class RetryHandler { + constructor (opts, handlers) { + const { retryOptions, ...dispatchOpts } = opts + const { + // Retry scoped + retry: retryFn, + maxRetries, + maxTimeout, + minTimeout, + timeoutFactor, + // Response scoped + methods, + errorCodes, + retryAfter, + statusCodes + } = retryOptions ?? {} + + this.dispatch = handlers.dispatch + this.handler = handlers.handler + this.opts = dispatchOpts + this.abort = null + this.aborted = false + this.retryOpts = { + retry: retryFn ?? RetryHandler[kRetryHandlerDefaultRetry], + retryAfter: retryAfter ?? true, + maxTimeout: maxTimeout ?? 30 * 1000, // 30s, + timeout: minTimeout ?? 500, // .5s + timeoutFactor: timeoutFactor ?? 2, + maxRetries: maxRetries ?? 5, + // What errors we should retry + methods: methods ?? ['GET', 'HEAD', 'OPTIONS', 'PUT', 'DELETE', 'TRACE'], + // Indicates which errors to retry + statusCodes: statusCodes ?? [500, 502, 503, 504, 429], + // List of errors to retry + errorCodes: errorCodes ?? [ + 'ECONNRESET', + 'ECONNREFUSED', + 'ENOTFOUND', + 'ENETDOWN', + 'ENETUNREACH', + 'EHOSTDOWN', + 'EHOSTUNREACH', + 'EPIPE' + ] + } + + this.retryCount = 0 + this.start = 0 + this.end = null + this.etag = null + this.resume = null + + // Handle possible onConnect duplication + this.handler.onConnect(reason => { + this.aborted = true + if (this.abort) { + this.abort(reason) + } else { + this.reason = reason + } + }) + } + + onRequestSent () { + if (this.handler.onRequestSent) { + this.handler.onRequestSent() + } + } + + onUpgrade (statusCode, headers, socket) { + if (this.handler.onUpgrade) { + this.handler.onUpgrade(statusCode, headers, socket) + } + } + + onConnect (abort) { + if (this.aborted) { + abort(this.reason) + } else { + this.abort = abort + } + } + + onBodySent (chunk) { + if (this.handler.onBodySent) return this.handler.onBodySent(chunk) + } + + static [kRetryHandlerDefaultRetry] (err, { state, opts }, cb) { + const { statusCode, code, headers } = err + const { method, retryOptions } = opts + const { + maxRetries, + timeout, + maxTimeout, + timeoutFactor, + statusCodes, + errorCodes, + methods + } = retryOptions + let { counter, currentTimeout } = state + + currentTimeout = + currentTimeout != null && currentTimeout > 0 ? currentTimeout : timeout + + // Any code that is not a Undici's originated and allowed to retry + if ( + code && + code !== 'UND_ERR_REQ_RETRY' && + code !== 'UND_ERR_SOCKET' && + !errorCodes.includes(code) + ) { + cb(err) + return + } + + // If a set of method are provided and the current method is not in the list + if (Array.isArray(methods) && !methods.includes(method)) { + cb(err) + return + } + + // If a set of status code are provided and the current status code is not in the list + if ( + statusCode != null && + Array.isArray(statusCodes) && + !statusCodes.includes(statusCode) + ) { + cb(err) + return + } + + // If we reached the max number of retries + if (counter > maxRetries) { + cb(err) + return + } + + let retryAfterHeader = headers != null && headers['retry-after'] + if (retryAfterHeader) { + retryAfterHeader = Number(retryAfterHeader) + retryAfterHeader = isNaN(retryAfterHeader) + ? calculateRetryAfterHeader(retryAfterHeader) + : retryAfterHeader * 1e3 // Retry-After is in seconds + } + + const retryTimeout = + retryAfterHeader > 0 + ? Math.min(retryAfterHeader, maxTimeout) + : Math.min(currentTimeout * timeoutFactor ** counter, maxTimeout) + + state.currentTimeout = retryTimeout + + setTimeout(() => cb(null), retryTimeout) + } + + onHeaders (statusCode, rawHeaders, resume, statusMessage) { + const headers = parseHeaders(rawHeaders) + + this.retryCount += 1 + + if (statusCode >= 300) { + this.abort( + new RequestRetryError('Request failed', statusCode, { + headers, + count: this.retryCount + }) + ) + return false + } + + // Checkpoint for resume from where we left it + if (this.resume != null) { + this.resume = null + + if (statusCode !== 206) { + return true + } + + const contentRange = parseRangeHeader(headers['content-range']) + // If no content range + if (!contentRange) { + this.abort( + new RequestRetryError('Content-Range mismatch', statusCode, { + headers, + count: this.retryCount + }) + ) + return false + } + + // Let's start with a weak etag check + if (this.etag != null && this.etag !== headers.etag) { + this.abort( + new RequestRetryError('ETag mismatch', statusCode, { + headers, + count: this.retryCount + }) + ) + return false + } + + const { start, size, end = size } = contentRange + + assert(this.start === start, 'content-range mismatch') + assert(this.end == null || this.end === end, 'content-range mismatch') + + this.resume = resume + return true + } + + if (this.end == null) { + if (statusCode === 206) { + // First time we receive 206 + const range = parseRangeHeader(headers['content-range']) + + if (range == null) { + return this.handler.onHeaders( + statusCode, + rawHeaders, + resume, + statusMessage + ) + } + + const { start, size, end = size } = range + + assert( + start != null && Number.isFinite(start) && this.start !== start, + 'content-range mismatch' + ) + assert(Number.isFinite(start)) + assert( + end != null && Number.isFinite(end) && this.end !== end, + 'invalid content-length' + ) + + this.start = start + this.end = end + } + + // We make our best to checkpoint the body for further range headers + if (this.end == null) { + const contentLength = headers['content-length'] + this.end = contentLength != null ? Number(contentLength) : null + } + + assert(Number.isFinite(this.start)) + assert( + this.end == null || Number.isFinite(this.end), + 'invalid content-length' + ) + + this.resume = resume + this.etag = headers.etag != null ? headers.etag : null + + return this.handler.onHeaders( + statusCode, + rawHeaders, + resume, + statusMessage + ) + } + + const err = new RequestRetryError('Request failed', statusCode, { + headers, + count: this.retryCount + }) + + this.abort(err) + + return false + } + + onData (chunk) { + this.start += chunk.length + + return this.handler.onData(chunk) + } + + onComplete (rawTrailers) { + this.retryCount = 0 + return this.handler.onComplete(rawTrailers) + } + + onError (err) { + if (this.aborted || isDisturbed(this.opts.body)) { + return this.handler.onError(err) + } + + this.retryOpts.retry( + err, + { + state: { counter: this.retryCount++, currentTimeout: this.retryAfter }, + opts: { retryOptions: this.retryOpts, ...this.opts } + }, + onRetry.bind(this) + ) + + function onRetry (err) { + if (err != null || this.aborted || isDisturbed(this.opts.body)) { + return this.handler.onError(err) + } + + if (this.start !== 0) { + this.opts = { + ...this.opts, + headers: { + ...this.opts.headers, + range: `bytes=${this.start}-${this.end ?? ''}` + } + } + } + + try { + this.dispatch(this.opts, this) + } catch (err) { + this.handler.onError(err) + } + } + } +} + +module.exports = RetryHandler + + +/***/ }), + +/***/ 4415: +/***/ ((module, __unused_webpack_exports, __nccwpck_require__) => { + + + +const RedirectHandler = __nccwpck_require__(8299) + +function createRedirectInterceptor ({ maxRedirections: defaultMaxRedirections }) { + return (dispatch) => { + return function Intercept (opts, handler) { + const { maxRedirections = defaultMaxRedirections } = opts + + if (!maxRedirections) { + return dispatch(opts, handler) + } + + const redirectHandler = new RedirectHandler(dispatch, maxRedirections, opts, handler) + opts = { ...opts, maxRedirections: 0 } // Stop sub dispatcher from also redirecting. + return dispatch(opts, redirectHandler) + } + } +} + +module.exports = createRedirectInterceptor + + +/***/ }), + +/***/ 2824: +/***/ ((__unused_webpack_module, exports, __nccwpck_require__) => { + + +Object.defineProperty(exports, "__esModule", ({ value: true })); +exports.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; +const utils_1 = __nccwpck_require__(172); +// C headers +var ERROR; +(function (ERROR) { + ERROR[ERROR["OK"] = 0] = "OK"; + ERROR[ERROR["INTERNAL"] = 1] = "INTERNAL"; + ERROR[ERROR["STRICT"] = 2] = "STRICT"; + ERROR[ERROR["LF_EXPECTED"] = 3] = "LF_EXPECTED"; + ERROR[ERROR["UNEXPECTED_CONTENT_LENGTH"] = 4] = "UNEXPECTED_CONTENT_LENGTH"; + ERROR[ERROR["CLOSED_CONNECTION"] = 5] = "CLOSED_CONNECTION"; + ERROR[ERROR["INVALID_METHOD"] = 6] = "INVALID_METHOD"; + ERROR[ERROR["INVALID_URL"] = 7] = "INVALID_URL"; + ERROR[ERROR["INVALID_CONSTANT"] = 8] = "INVALID_CONSTANT"; + ERROR[ERROR["INVALID_VERSION"] = 9] = "INVALID_VERSION"; + ERROR[ERROR["INVALID_HEADER_TOKEN"] = 10] = "INVALID_HEADER_TOKEN"; + ERROR[ERROR["INVALID_CONTENT_LENGTH"] = 11] = "INVALID_CONTENT_LENGTH"; + ERROR[ERROR["INVALID_CHUNK_SIZE"] = 12] = "INVALID_CHUNK_SIZE"; + ERROR[ERROR["INVALID_STATUS"] = 13] = "INVALID_STATUS"; + ERROR[ERROR["INVALID_EOF_STATE"] = 14] = "INVALID_EOF_STATE"; + ERROR[ERROR["INVALID_TRANSFER_ENCODING"] = 15] = "INVALID_TRANSFER_ENCODING"; + ERROR[ERROR["CB_MESSAGE_BEGIN"] = 16] = "CB_MESSAGE_BEGIN"; + ERROR[ERROR["CB_HEADERS_COMPLETE"] = 17] = "CB_HEADERS_COMPLETE"; + ERROR[ERROR["CB_MESSAGE_COMPLETE"] = 18] = "CB_MESSAGE_COMPLETE"; + ERROR[ERROR["CB_CHUNK_HEADER"] = 19] = "CB_CHUNK_HEADER"; + ERROR[ERROR["CB_CHUNK_COMPLETE"] = 20] = "CB_CHUNK_COMPLETE"; + ERROR[ERROR["PAUSED"] = 21] = "PAUSED"; + ERROR[ERROR["PAUSED_UPGRADE"] = 22] = "PAUSED_UPGRADE"; + ERROR[ERROR["PAUSED_H2_UPGRADE"] = 23] = "PAUSED_H2_UPGRADE"; + ERROR[ERROR["USER"] = 24] = "USER"; +})(ERROR = exports.ERROR || (exports.ERROR = {})); +var TYPE; +(function (TYPE) { + TYPE[TYPE["BOTH"] = 0] = "BOTH"; + TYPE[TYPE["REQUEST"] = 1] = "REQUEST"; + TYPE[TYPE["RESPONSE"] = 2] = "RESPONSE"; +})(TYPE = exports.TYPE || (exports.TYPE = {})); +var FLAGS; +(function (FLAGS) { + FLAGS[FLAGS["CONNECTION_KEEP_ALIVE"] = 1] = "CONNECTION_KEEP_ALIVE"; + FLAGS[FLAGS["CONNECTION_CLOSE"] = 2] = "CONNECTION_CLOSE"; + FLAGS[FLAGS["CONNECTION_UPGRADE"] = 4] = "CONNECTION_UPGRADE"; + FLAGS[FLAGS["CHUNKED"] = 8] = "CHUNKED"; + FLAGS[FLAGS["UPGRADE"] = 16] = "UPGRADE"; + FLAGS[FLAGS["CONTENT_LENGTH"] = 32] = "CONTENT_LENGTH"; + FLAGS[FLAGS["SKIPBODY"] = 64] = "SKIPBODY"; + FLAGS[FLAGS["TRAILING"] = 128] = "TRAILING"; + // 1 << 8 is unused + FLAGS[FLAGS["TRANSFER_ENCODING"] = 512] = "TRANSFER_ENCODING"; +})(FLAGS = exports.FLAGS || (exports.FLAGS = {})); +var LENIENT_FLAGS; +(function (LENIENT_FLAGS) { + LENIENT_FLAGS[LENIENT_FLAGS["HEADERS"] = 1] = "HEADERS"; + LENIENT_FLAGS[LENIENT_FLAGS["CHUNKED_LENGTH"] = 2] = "CHUNKED_LENGTH"; + LENIENT_FLAGS[LENIENT_FLAGS["KEEP_ALIVE"] = 4] = "KEEP_ALIVE"; +})(LENIENT_FLAGS = exports.LENIENT_FLAGS || (exports.LENIENT_FLAGS = {})); +var METHODS; +(function (METHODS) { + METHODS[METHODS["DELETE"] = 0] = "DELETE"; + METHODS[METHODS["GET"] = 1] = "GET"; + METHODS[METHODS["HEAD"] = 2] = "HEAD"; + METHODS[METHODS["POST"] = 3] = "POST"; + METHODS[METHODS["PUT"] = 4] = "PUT"; + /* pathological */ + METHODS[METHODS["CONNECT"] = 5] = "CONNECT"; + METHODS[METHODS["OPTIONS"] = 6] = "OPTIONS"; + METHODS[METHODS["TRACE"] = 7] = "TRACE"; + /* WebDAV */ + METHODS[METHODS["COPY"] = 8] = "COPY"; + METHODS[METHODS["LOCK"] = 9] = "LOCK"; + METHODS[METHODS["MKCOL"] = 10] = "MKCOL"; + METHODS[METHODS["MOVE"] = 11] = "MOVE"; + METHODS[METHODS["PROPFIND"] = 12] = "PROPFIND"; + METHODS[METHODS["PROPPATCH"] = 13] = "PROPPATCH"; + METHODS[METHODS["SEARCH"] = 14] = "SEARCH"; + METHODS[METHODS["UNLOCK"] = 15] = "UNLOCK"; + METHODS[METHODS["BIND"] = 16] = "BIND"; + METHODS[METHODS["REBIND"] = 17] = "REBIND"; + METHODS[METHODS["UNBIND"] = 18] = "UNBIND"; + METHODS[METHODS["ACL"] = 19] = "ACL"; + /* subversion */ + METHODS[METHODS["REPORT"] = 20] = "REPORT"; + METHODS[METHODS["MKACTIVITY"] = 21] = "MKACTIVITY"; + METHODS[METHODS["CHECKOUT"] = 22] = "CHECKOUT"; + METHODS[METHODS["MERGE"] = 23] = "MERGE"; + /* upnp */ + METHODS[METHODS["M-SEARCH"] = 24] = "M-SEARCH"; + METHODS[METHODS["NOTIFY"] = 25] = "NOTIFY"; + METHODS[METHODS["SUBSCRIBE"] = 26] = "SUBSCRIBE"; + METHODS[METHODS["UNSUBSCRIBE"] = 27] = "UNSUBSCRIBE"; + /* RFC-5789 */ + METHODS[METHODS["PATCH"] = 28] = "PATCH"; + METHODS[METHODS["PURGE"] = 29] = "PURGE"; + /* CalDAV */ + METHODS[METHODS["MKCALENDAR"] = 30] = "MKCALENDAR"; + /* RFC-2068, section 19.6.1.2 */ + METHODS[METHODS["LINK"] = 31] = "LINK"; + METHODS[METHODS["UNLINK"] = 32] = "UNLINK"; + /* icecast */ + METHODS[METHODS["SOURCE"] = 33] = "SOURCE"; + /* RFC-7540, section 11.6 */ + METHODS[METHODS["PRI"] = 34] = "PRI"; + /* RFC-2326 RTSP */ + METHODS[METHODS["DESCRIBE"] = 35] = "DESCRIBE"; + METHODS[METHODS["ANNOUNCE"] = 36] = "ANNOUNCE"; + METHODS[METHODS["SETUP"] = 37] = "SETUP"; + METHODS[METHODS["PLAY"] = 38] = "PLAY"; + METHODS[METHODS["PAUSE"] = 39] = "PAUSE"; + METHODS[METHODS["TEARDOWN"] = 40] = "TEARDOWN"; + METHODS[METHODS["GET_PARAMETER"] = 41] = "GET_PARAMETER"; + METHODS[METHODS["SET_PARAMETER"] = 42] = "SET_PARAMETER"; + METHODS[METHODS["REDIRECT"] = 43] = "REDIRECT"; + METHODS[METHODS["RECORD"] = 44] = "RECORD"; + /* RAOP */ + METHODS[METHODS["FLUSH"] = 45] = "FLUSH"; +})(METHODS = exports.METHODS || (exports.METHODS = {})); +exports.METHODS_HTTP = [ + METHODS.DELETE, + METHODS.GET, + METHODS.HEAD, + METHODS.POST, + METHODS.PUT, + METHODS.CONNECT, + METHODS.OPTIONS, + METHODS.TRACE, + METHODS.COPY, + METHODS.LOCK, + METHODS.MKCOL, + METHODS.MOVE, + METHODS.PROPFIND, + METHODS.PROPPATCH, + METHODS.SEARCH, + METHODS.UNLOCK, + METHODS.BIND, + METHODS.REBIND, + METHODS.UNBIND, + METHODS.ACL, + METHODS.REPORT, + METHODS.MKACTIVITY, + METHODS.CHECKOUT, + METHODS.MERGE, + METHODS['M-SEARCH'], + METHODS.NOTIFY, + METHODS.SUBSCRIBE, + METHODS.UNSUBSCRIBE, + METHODS.PATCH, + METHODS.PURGE, + METHODS.MKCALENDAR, + METHODS.LINK, + METHODS.UNLINK, + METHODS.PRI, + // TODO(indutny): should we allow it with HTTP? + METHODS.SOURCE, +]; +exports.METHODS_ICE = [ + METHODS.SOURCE, +]; +exports.METHODS_RTSP = [ + METHODS.OPTIONS, + METHODS.DESCRIBE, + METHODS.ANNOUNCE, + METHODS.SETUP, + METHODS.PLAY, + METHODS.PAUSE, + METHODS.TEARDOWN, + METHODS.GET_PARAMETER, + METHODS.SET_PARAMETER, + METHODS.REDIRECT, + METHODS.RECORD, + METHODS.FLUSH, + // For AirPlay + METHODS.GET, + METHODS.POST, +]; +exports.METHOD_MAP = utils_1.enumToMap(METHODS); +exports.H_METHOD_MAP = {}; +Object.keys(exports.METHOD_MAP).forEach((key) => { + if (/^H/.test(key)) { + exports.H_METHOD_MAP[key] = exports.METHOD_MAP[key]; + } +}); +var FINISH; +(function (FINISH) { + FINISH[FINISH["SAFE"] = 0] = "SAFE"; + FINISH[FINISH["SAFE_WITH_CB"] = 1] = "SAFE_WITH_CB"; + FINISH[FINISH["UNSAFE"] = 2] = "UNSAFE"; +})(FINISH = exports.FINISH || (exports.FINISH = {})); +exports.ALPHA = []; +for (let i = 'A'.charCodeAt(0); i <= 'Z'.charCodeAt(0); i++) { + // Upper case + exports.ALPHA.push(String.fromCharCode(i)); + // Lower case + exports.ALPHA.push(String.fromCharCode(i + 0x20)); +} +exports.NUM_MAP = { + 0: 0, 1: 1, 2: 2, 3: 3, 4: 4, + 5: 5, 6: 6, 7: 7, 8: 8, 9: 9, +}; +exports.HEX_MAP = { + 0: 0, 1: 1, 2: 2, 3: 3, 4: 4, + 5: 5, 6: 6, 7: 7, 8: 8, 9: 9, + A: 0XA, B: 0XB, C: 0XC, D: 0XD, E: 0XE, F: 0XF, + a: 0xa, b: 0xb, c: 0xc, d: 0xd, e: 0xe, f: 0xf, +}; +exports.NUM = [ + '0', '1', '2', '3', '4', '5', '6', '7', '8', '9', +]; +exports.ALPHANUM = exports.ALPHA.concat(exports.NUM); +exports.MARK = ['-', '_', '.', '!', '~', '*', '\'', '(', ')']; +exports.USERINFO_CHARS = exports.ALPHANUM + .concat(exports.MARK) + .concat(['%', ';', ':', '&', '=', '+', '$', ',']); +// TODO(indutny): use RFC +exports.STRICT_URL_CHAR = [ + '!', '"', '$', '%', '&', '\'', + '(', ')', '*', '+', ',', '-', '.', '/', + ':', ';', '<', '=', '>', + '@', '[', '\\', ']', '^', '_', + '`', + '{', '|', '}', '~', +].concat(exports.ALPHANUM); +exports.URL_CHAR = exports.STRICT_URL_CHAR + .concat(['\t', '\f']); +// All characters with 0x80 bit set to 1 +for (let i = 0x80; i <= 0xff; i++) { + exports.URL_CHAR.push(i); +} +exports.HEX = exports.NUM.concat(['a', 'b', 'c', 'd', 'e', 'f', 'A', 'B', 'C', 'D', 'E', 'F']); +/* Tokens as defined by rfc 2616. Also lowercases them. + * token = 1* + * separators = "(" | ")" | "<" | ">" | "@" + * | "," | ";" | ":" | "\" | <"> + * | "/" | "[" | "]" | "?" | "=" + * | "{" | "}" | SP | HT + */ +exports.STRICT_TOKEN = [ + '!', '#', '$', '%', '&', '\'', + '*', '+', '-', '.', + '^', '_', '`', + '|', '~', +].concat(exports.ALPHANUM); +exports.TOKEN = exports.STRICT_TOKEN.concat([' ']); +/* + * Verify that a char is a valid visible (printable) US-ASCII + * character or %x80-FF + */ +exports.HEADER_CHARS = ['\t']; +for (let i = 32; i <= 255; i++) { + if (i !== 127) { + exports.HEADER_CHARS.push(i); + } +} +// ',' = \x44 +exports.CONNECTION_TOKEN_CHARS = exports.HEADER_CHARS.filter((c) => c !== 44); +exports.MAJOR = exports.NUM_MAP; +exports.MINOR = exports.MAJOR; +var HEADER_STATE; +(function (HEADER_STATE) { + HEADER_STATE[HEADER_STATE["GENERAL"] = 0] = "GENERAL"; + HEADER_STATE[HEADER_STATE["CONNECTION"] = 1] = "CONNECTION"; + HEADER_STATE[HEADER_STATE["CONTENT_LENGTH"] = 2] = "CONTENT_LENGTH"; + HEADER_STATE[HEADER_STATE["TRANSFER_ENCODING"] = 3] = "TRANSFER_ENCODING"; + HEADER_STATE[HEADER_STATE["UPGRADE"] = 4] = "UPGRADE"; + HEADER_STATE[HEADER_STATE["CONNECTION_KEEP_ALIVE"] = 5] = "CONNECTION_KEEP_ALIVE"; + HEADER_STATE[HEADER_STATE["CONNECTION_CLOSE"] = 6] = "CONNECTION_CLOSE"; + HEADER_STATE[HEADER_STATE["CONNECTION_UPGRADE"] = 7] = "CONNECTION_UPGRADE"; + HEADER_STATE[HEADER_STATE["TRANSFER_ENCODING_CHUNKED"] = 8] = "TRANSFER_ENCODING_CHUNKED"; +})(HEADER_STATE = exports.HEADER_STATE || (exports.HEADER_STATE = {})); +exports.SPECIAL_HEADERS = { + 'connection': HEADER_STATE.CONNECTION, + 'content-length': HEADER_STATE.CONTENT_LENGTH, + 'proxy-connection': HEADER_STATE.CONNECTION, + 'transfer-encoding': HEADER_STATE.TRANSFER_ENCODING, + 'upgrade': HEADER_STATE.UPGRADE, +}; +//# sourceMappingURL=constants.js.map + +/***/ }), + +/***/ 3870: +/***/ ((module) => { + +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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FCAAIBA2AgxBACEQDLIBCyAAKAIEIRAgAEEANgIEAkAgACAQIAEQp4CAgAAiEA0AIAEhAQxNCyAAQdMANgIcIAAgATYCFCAAIBA2AgxBACEQDLEBCyAAKAIEIRAgAEEANgIEAkAgACAQIAEQp4CAgAAiEA0AIAEhAQxRCyAAQeUANgIcIAAgATYCFCAAIBA2AgxBACEQDLABCyAAQQA2AhwgACABNgIUIABBxoqAgAA2AhAgAEEHNgIMQQAhEAyvAQsgACgCBCEQIABBADYCBAJAIAAgECABEKeAgIAAIhANACABIQEMSQsgAEHSADYCHCAAIAE2AhQgACAQNgIMQQAhEAyuAQsgACgCBCEQIABBADYCBAJAIAAgECABEKeAgIAAIhANACABIQEMSQsgAEHTADYCHCAAIAE2AhQgACAQNgIMQQAhEAytAQsgACgCBCEQIABBADYCBAJAIAAgECABEKeAgIAAIhANACABIQEMTQsgAEHlADYCHCAAIAE2AhQgACAQNgIMQQAhEAysAQsgAEEANgIcIAAgATYCFCAAQdyIgIAANgIQIABBBzYCDEEAIRAMqwELIBBBP0cNASABQQFqIQELQQUhEAyQAQtBACEQIABBADYCHCAAIAE2AhQgAEH9koCAADYCECAAQQc2AgwMqAELIAAoAgQhECAAQQA2AgQCQCAAIBAgARCngICAACIQDQAgASEBDEILIABB0gA2AhwgACABNgIUIAAgEDYCDEEAIRAMpwELIAAoAgQhECAAQQA2AgQCQCAAIBAgARCngICAACIQDQAgASEBDEILIABB0wA2AhwgACABNgIUIAAgEDYCDEEAIRAMpgELIAAoAgQhECAAQQA2AgQCQCAAIBAgARCngICAACIQDQAgASEBDEYLIABB5QA2AhwgACABNgIUIAAgEDYCDEEAIRAMpQELIAAoAgQhASAAQQA2AgQCQCAAIAEgFBCngICAACIBDQAgFCEBDD8LIABB0gA2AhwgACAUNgIUIAAgATYCDEEAIRAMpAELIAAoAgQhASAAQQA2AgQCQCAAIAEgFBCngICAACIBDQAgFCEBDD8LIABB0wA2AhwgACAUNgIUIAAgATYCDEEAIRAMowELIAAoAgQhASAAQQA2AgQCQCAAIAEgFBCngICAACIBDQAgFCEBDEMLIABB5QA2AhwgACAUNgIUIAAgATYCDEEAIRAMogELIABBADYCHCAAIBQ2AhQgAEHDj4CAADYCECAAQQc2AgxBACEQDKEBCyAAQQA2AhwgACABNgIUIABBw4+AgAA2AhAgAEEHNgIMQQAhEAygAQtBACEQIABBADYCHCAAIBQ2AhQgAEGMnICAADYCECAAQQc2AgwMnwELIABBADYCHCAAIBQ2AhQgAEGMnICAADYCECAAQQc2AgxBACEQDJ4BCyAAQQA2AhwgACAUNgIUIABB/pGAgAA2AhAgAEEHNgIMQQAhEAydAQsgAEEANgIcIAAgATYCFCAAQY6bgIAANgIQIABBBjYCDEEAIRAMnAELIBBBFUYNVyAAQQA2AhwgACABNgIUIABBzI6AgAA2AhAgAEEgNgIMQQAhEAybAQsgAEEANgIAIBBBAWohAUEkIRALIAAgEDoAKSAAKAIEIRAgAEEANgIEIAAgECABEKuAgIAAIhANVCABIQEMPgsgAEEANgIAC0EAIRAgAEEANgIcIAAgBDYCFCAAQfGbgIAANgIQIABBBjYCDAyXAQsgAUEVRg1QIABBADYCHCAAIAU2AhQgAEHwjICAADYCECAAQRs2AgxBACEQDJYBCyAAKAIEIQUgAEEANgIEIAAgBSAQEKmAgIAAIgUNASAQQQFqIQULQa0BIRAMewsgAEHBATYCHCAAIAU2AgwgACAQQQFqNgIUQQAhEAyTAQsgACgCBCEGIABBADYCBCAAIAYgEBCpgICAACIGDQEgEEEBaiEGC0GuASEQDHgLIABBwgE2AhwgACAGNgIMIAAgEEEBajYCFEEAIRAMkAELIABBADYCHCAAIAc2AhQgAEGXi4CAADYCECAAQQ02AgxBACEQDI8BCyAAQQA2AhwgACAINgIUIABB45CAgAA2AhAgAEEJNgIMQQAhEAyOAQsgAEEANgIcIAAgCDYCFCAAQZSNgIAANgIQIABBITYCDEEAIRAMjQELQQEhFkEAIRdBACEUQQEhEAsgACAQOgArIAlBAWohCAJAAkAgAC0ALUEQcQ0AAkACQAJAIAAtACoOAwEAAgQLIBZFDQMMAgsgFA0BDAILIBdFDQELIAAoAgQhECAAQQA2AgQgACAQIAgQrYCAgAAiEEUNPSAAQckBNgIcIAAgCDYCFCAAIBA2AgxBACEQDIwBCyAAKAIEIQQgAEEANgIEIAAgBCAIEK2AgIAAIgRFDXYgAEHKATYCHCAAIAg2AhQgACAENgIMQQAhEAyLAQsgACgCBCEEIABBADYCBCAAIAQgCRCtgICAACIERQ10IABBywE2AhwgACAJNgIUIAAgBDYCDEEAIRAMigELIAAoAgQhBCAAQQA2AgQgACAEIAoQrYCAgAAiBEUNciAAQc0BNgIcIAAgCjYCFCAAIAQ2AgxBACEQDIkBCwJAIAstAABBUGoiEEH/AXFBCk8NACAAIBA6ACogC0EBaiEKQbYBIRAMcAsgACgCBCEEIABBADYCBCAAIAQgCxCtgICAACIERQ1wIABBzwE2AhwgACALNgIUIAAgBDYCDEEAIRAMiAELIABBADYCHCAAIAQ2AhQgAEGQs4CAADYCECAAQQg2AgwgAEEANgIAQQAhEAyHAQsgAUEVRg0/IABBADYCHCAAIAw2AhQgAEHMjoCAADYCECAAQSA2AgxBACEQDIYBCyAAQYEEOwEoIAAoAgQhECAAQgA3AwAgACAQIAxBAWoiDBCrgICAACIQRQ04IABB0wE2AhwgACAMNgIUIAAgEDYCDEEAIRAMhQELIABBADYCAAtBACEQIABBADYCHCAAIAQ2AhQgAEHYm4CAADYCECAAQQg2AgwMgwELIAAoAgQhECAAQgA3AwAgACAQIAtBAWoiCxCrgICAACIQDQFBxgEhEAxpCyAAQQI6ACgMVQsgAEHVATYCHCAAIAs2AhQgACAQNgIMQQAhEAyAAQsgEEEVRg03IABBADYCHCAAIAQ2AhQgAEGkjICAADYCECAAQRA2AgxBACEQDH8LIAAtADRBAUcNNCAAIAQgAhC8gICAACIQRQ00IBBBFUcNNSAAQdwBNgIcIAAgBDYCFCAAQdWWgIAANgIQIABBFTYCDEEAIRAMfgtBACEQIABBADYCHCAAQa+LgIAANgIQIABBAjYCDCAAIBRBAWo2AhQMfQtBACEQDGMLQQIhEAxiC0ENIRAMYQtBDyEQDGALQSUhEAxfC0ETIRAMXgtBFSEQDF0LQRYhEAxcC0EXIRAMWwtBGCEQDFoLQRkhEAxZC0EaIRAMWAtBGyEQDFcLQRwhEAxWC0EdIRAMVQtBHyEQDFQLQSEhEAxTC0EjIRAMUgtBxgAhEAxRC0EuIRAMUAtBLyEQDE8LQTshEAxOC0E9IRAMTQtByAAhEAxMC0HJACEQDEsLQcsAIRAMSgtBzAAhEAxJC0HOACEQDEgLQdEAIRAMRwtB1QAhEAxGC0HYACEQDEULQdkAIRAMRAtB2wAhEAxDC0HkACEQDEILQeUAIRAMQQtB8QAhEAxAC0H0ACEQDD8LQY0BIRAMPgtBlwEhEAw9C0GpASEQDDwLQawBIRAMOwtBwAEhEAw6C0G5ASEQDDkLQa8BIRAMOAtBsQEhEAw3C0GyASEQDDYLQbQBIRAMNQtBtQEhEAw0C0G6ASEQDDMLQb0BIRAMMgtBvwEhEAwxC0HBASEQDDALIABBADYCHCAAIAQ2AhQgAEHpi4CAADYCECAAQR82AgxBACEQDEgLIABB2wE2AhwgACAENgIUIABB+paAgAA2AhAgAEEVNgIMQQAhEAxHCyAAQfgANgIcIAAgDDYCFCAAQcqYgIAANgIQIABBFTYCDEEAIRAMRgsgAEHRADYCHCAAIAU2AhQgAEGwl4CAADYCECAAQRU2AgxBACEQDEULIABB+QA2AhwgACABNgIUIAAgEDYCDEEAIRAMRAsgAEH4ADYCHCAAIAE2AhQgAEHKmICAADYCECAAQRU2AgxBACEQDEMLIABB5AA2AhwgACABNgIUIABB45eAgAA2AhAgAEEVNgIMQQAhEAxCCyAAQdcANgIcIAAgATYCFCAAQcmXgIAANgIQIABBFTYCDEEAIRAMQQsgAEEANgIcIAAgATYCFCAAQbmNgIAANgIQIABBGjYCDEEAIRAMQAsgAEHCADYCHCAAIAE2AhQgAEHjmICAADYCECAAQRU2AgxBACEQDD8LIABBADYCBCAAIA8gDxCxgICAACIERQ0BIABBOjYCHCAAIAQ2AgwgACAPQQFqNgIUQQAhEAw+CyAAKAIEIQQgAEEANgIEAkAgACAEIAEQsYCAgAAiBEUNACAAQTs2AhwgACAENgIMIAAgAUEBajYCFEEAIRAMPgsgAUEBaiEBDC0LIA9BAWohAQwtCyAAQQA2AhwgACAPNgIUIABB5JKAgAA2AhAgAEEENgIMQQAhEAw7CyAAQTY2AhwgACAENgIUIAAgAjYCDEEAIRAMOgsgAEEuNgIcIAAgDjYCFCAAIAQ2AgxBACEQDDkLIABB0AA2AhwgACABNgIUIABBkZiAgAA2AhAgAEEVNgIMQQAhEAw4CyANQQFqIQEMLAsgAEEVNgIcIAAgATYCFCAAQYKZgIAANgIQIABBFTYCDEEAIRAMNgsgAEEbNgIcIAAgATYCFCAAQZGXgIAANgIQIABBFTYCDEEAIRAMNQsgAEEPNgIcIAAgATYCFCAAQZGXgIAANgIQIABBFTYCDEEAIRAMNAsgAEELNgIcIAAgATYCFCAAQZGXgIAANgIQIABBFTYCDEEAIRAMMwsgAEEaNgIcIAAgATYCFCAAQYKZgIAANgIQIABBFTYCDEEAIRAMMgsgAEELNgIcIAAgATYCFCAAQYKZgIAANgIQIABBFTYCDEEAIRAMMQsgAEEKNgIcIAAgATYCFCAAQeSWgIAANgIQIABBFTYCDEEAIRAMMAsgAEEeNgIcIAAgATYCFCAAQfmXgIAANgIQIABBFTYCDEEAIRAMLwsgAEEANgIcIAAgEDYCFCAAQdqNgIAANgIQIABBFDYCDEEAIRAMLgsgAEEENgIcIAAgATYCFCAAQbCYgIAANgIQIABBFTYCDEEAIRAMLQsgAEEANgIAIAtBAWohCwtBuAEhEAwSCyAAQQA2AgAgEEEBaiEBQfUAIRAMEQsgASEBAkAgAC0AKUEFRw0AQeMAIRAMEQtB4gAhEAwQC0EAIRAgAEEANgIcIABB5JGAgAA2AhAgAEEHNgIMIAAgFEEBajYCFAwoCyAAQQA2AgAgF0EBaiEBQcAAIRAMDgtBASEBCyAAIAE6ACwgAEEANgIAIBdBAWohAQtBKCEQDAsLIAEhAQtBOCEQDAkLAkAgASIPIAJGDQADQAJAIA8tAABBgL6AgABqLQAAIgFBAUYNACABQQJHDQMgD0EBaiEBDAQLIA9BAWoiDyACRw0AC0E+IRAMIgtBPiEQDCELIABBADoALCAPIQEMAQtBCyEQDAYLQTohEAwFCyABQQFqIQFBLSEQDAQLIAAgAToALCAAQQA2AgAgFkEBaiEBQQwhEAwDCyAAQQA2AgAgF0EBaiEBQQohEAwCCyAAQQA2AgALIABBADoALCANIQFBCSEQDAALC0EAIRAgAEEANgIcIAAgCzYCFCAAQc2QgIAANgIQIABBCTYCDAwXC0EAIRAgAEEANgIcIAAgCjYCFCAAQemKgIAANgIQIABBCTYCDAwWC0EAIRAgAEEANgIcIAAgCTYCFCAAQbeQgIAANgIQIABBCTYCDAwVC0EAIRAgAEEANgIcIAAgCDYCFCAAQZyRgIAANgIQIABBCTYCDAwUC0EAIRAgAEEANgIcIAAgATYCFCAAQc2QgIAANgIQIABBCTYCDAwTC0EAIRAgAEEANgIcIAAgATYCFCAAQemKgIAANgIQIABBCTYCDAwSC0EAIRAgAEEANgIcIAAgATYCFCAAQbeQgIAANgIQIABBCTYCDAwRC0EAIRAgAEEANgIcIAAgATYCFCAAQZyRgIAANgIQIABBCTYCDAwQC0EAIRAgAEEANgIcIAAgATYCFCAAQZeVgIAANgIQIABBDzYCDAwPC0EAIRAgAEEANgIcIAAgATYCFCAAQZeVgIAANgIQIABBDzYCDAwOC0EAIRAgAEEANgIcIAAgATYCFCAAQcCSgIAANgIQIABBCzYCDAwNC0EAIRAgAEEANgIcIAAgATYCFCAAQZWJgIAANgIQIABBCzYCDAwMC0EAIRAgAEEANgIcIAAgATYCFCAAQeGPgIAANgIQIABBCjYCDAwLC0EAIRAgAEEANgIcIAAgATYCFCAAQfuPgIAANgIQIABBCjYCDAwKC0EAIRAgAEEANgIcIAAgATYCFCAAQfGZgIAANgIQIABBAjYCDAwJC0EAIRAgAEEANgIcIAAgATYCFCAAQcSUgIAANgIQIABBAjYCDAwIC0EAIRAgAEEANgIcIAAgATYCFCAAQfKVgIAANgIQIABBAjYCDAwHCyAAQQI2AhwgACABNgIUIABBnJqAgAA2AhAgAEEWNgIMQQAhEAwGC0EBIRAMBQtB1AAhECABIgQgAkYNBCADQQhqIAAgBCACQdjCgIAAQQoQxYCAgAAgAygCDCEEIAMoAggOAwEEAgALEMqAgIAAAAsgAEEANgIcIABBtZqAgAA2AhAgAEEXNgIMIAAgBEEBajYCFEEAIRAMAgsgAEEANgIcIAAgBDYCFCAAQcqagIAANgIQIABBCTYCDEEAIRAMAQsCQCABIgQgAkcNAEEiIRAMAQsgAEGJgICAADYCCCAAIAQ2AgRBISEQCyADQRBqJICAgIAAIBALrwEBAn8gASgCACEGAkACQCACIANGDQAgBCAGaiEEIAYgA2ogAmshByACIAZBf3MgBWoiBmohBQNAAkAgAi0AACAELQAARg0AQQIhBAwDCwJAIAYNAEEAIQQgBSECDAMLIAZBf2ohBiAEQQFqIQQgAkEBaiICIANHDQALIAchBiADIQILIABBATYCACABIAY2AgAgACACNgIEDwsgAUEANgIAIAAgBDYCACAAIAI2AgQLCgAgABDHgICAAAvyNgELfyOAgICAAEEQayIBJICAgIAAAkBBACgCoNCAgAANAEEAEMuAgIAAQYDUhIAAayICQdkASQ0AQQAhAwJAQQAoAuDTgIAAIgQNAEEAQn83AuzTgIAAQQBCgICEgICAwAA3AuTTgIAAQQAgAUEIakFwcUHYqtWqBXMiBDYC4NOAgABBAEEANgL004CAAEEAQQA2AsTTgIAAC0EAIAI2AszTgIAAQQBBgNSEgAA2AsjTgIAAQQBBgNSEgAA2ApjQgIAAQQAgBDYCrNCAgABBAEF/NgKo0ICAAANAIANBxNCAgABqIANBuNCAgABqIgQ2AgAgBCADQbDQgIAAaiIFNgIAIANBvNCAgABqIAU2AgAgA0HM0ICAAGogA0HA0ICAAGoiBTYCACAFIAQ2AgAgA0HU0ICAAGogA0HI0ICAAGoiBDYCACAEIAU2AgAgA0HQ0ICAAGogBDYCACADQSBqIgNBgAJHDQALQYDUhIAAQXhBgNSEgABrQQ9xQQBBgNSEgABBCGpBD3EbIgNqIgRBBGogAkFIaiIFIANrIgNBAXI2AgBBAEEAKALw04CAADYCpNCAgABBACADNgKU0ICAAEEAIAQ2AqDQgIAAQYDUhIAAIAVqQTg2AgQLAkACQAJAAkACQAJAAkACQAJAAkACQAJAIABB7AFLDQACQEEAKAKI0ICAACIGQRAgAEETakFwcSAAQQtJGyICQQN2IgR2IgNBA3FFDQACQAJAIANBAXEgBHJBAXMiBUEDdCIEQbDQgIAAaiIDIARBuNCAgABqKAIAIgQoAggiAkcNAEEAIAZBfiAFd3E2AojQgIAADAELIAMgAjYCCCACIAM2AgwLIARBCGohAyAEIAVBA3QiBUEDcjYCBCAEIAVqIgQgBCgCBEEBcjYCBAwMCyACQQAoApDQgIAAIgdNDQECQCADRQ0AAkACQCADIAR0QQIgBHQiA0EAIANrcnEiA0EAIANrcUF/aiIDIANBDHZBEHEiA3YiBEEFdkEIcSIFIANyIAQgBXYiA0ECdkEEcSIEciADIAR2IgNBAXZBAnEiBHIgAyAEdiIDQQF2QQFxIgRyIAMgBHZqIgRBA3QiA0Gw0ICAAGoiBSADQbjQgIAAaigCACIDKAIIIgBHDQBBACAGQX4gBHdxIgY2AojQgIAADAELIAUgADYCCCAAIAU2AgwLIAMgAkEDcjYCBCADIARBA3QiBGogBCACayIFNgIAIAMgAmoiACAFQQFyNgIEAkAgB0UNACAHQXhxQbDQgIAAaiECQQAoApzQgIAAIQQCQAJAIAZBASAHQQN2dCIIcQ0AQQAgBiAIcjYCiNCAgAAgAiEIDAELIAIoAgghCAsgCCAENgIMIAIgBDYCCCAEIAI2AgwgBCAINgIICyADQQhqIQNBACAANgKc0ICAAEEAIAU2ApDQgIAADAwLQQAoAozQgIAAIglFDQEgCUEAIAlrcUF/aiIDIANBDHZBEHEiA3YiBEEFdkEIcSIFIANyIAQgBXYiA0ECdkEEcSIEciADIAR2IgNBAXZBAnEiBHIgAyAEdiIDQQF2QQFxIgRyIAMgBHZqQQJ0QbjSgIAAaigCACIAKAIEQXhxIAJrIQQgACEFAkADQAJAIAUoAhAiAw0AIAVBFGooAgAiA0UNAgsgAygCBEF4cSACayIFIAQgBSAESSIFGyEEIAMgACAFGyEAIAMhBQwACwsgACgCGCEKAkAgACgCDCIIIABGDQAgACgCCCIDQQAoApjQgIAASRogCCADNgIIIAMgCDYCDAwLCwJAIABBFGoiBSgCACIDDQAgACgCECIDRQ0DIABBEGohBQsDQCAFIQsgAyIIQRRqIgUoAgAiAw0AIAhBEGohBSAIKAIQIgMNAAsgC0EANgIADAoLQX8hAiAAQb9/Sw0AIABBE2oiA0FwcSECQQAoAozQgIAAIgdFDQBBACELAkAgAkGAAkkNAEEfIQsgAkH///8HSw0AIANBCHYiAyADQYD+P2pBEHZBCHEiA3QiBCAEQYDgH2pBEHZBBHEiBHQiBSAFQYCAD2pBEHZBAnEiBXRBD3YgAyAEciAFcmsiA0EBdCACIANBFWp2QQFxckEcaiELC0EAIAJrIQQCQAJAAkACQCALQQJ0QbjSgIAAaigCACIFDQBBACEDQQAhCAwBC0EAIQMgAkEAQRkgC0EBdmsgC0EfRht0IQBBACEIA0ACQCAFKAIEQXhxIAJrIgYgBE8NACAGIQQgBSEIIAYNAEEAIQQgBSEIIAUhAwwDCyADIAVBFGooAgAiBiAGIAUgAEEddkEEcWpBEGooAgAiBUYbIAMgBhshAyAAQQF0IQAgBQ0ACwsCQCADIAhyDQBBACEIQQIgC3QiA0EAIANrciAHcSIDRQ0DIANBACADa3FBf2oiAyADQQx2QRBxIgN2IgVBBXZBCHEiACADciAFIAB2IgNBAnZBBHEiBXIgAyAFdiIDQQF2QQJxIgVyIAMgBXYiA0EBdkEBcSIFciADIAV2akECdEG40oCAAGooAgAhAwsgA0UNAQsDQCADKAIEQXhxIAJrIgYgBEkhAAJAIAMoAhAiBQ0AIANBFGooAgAhBQsgBiAEIAAbIQQgAyAIIAAbIQggBSEDIAUNAAsLIAhFDQAgBEEAKAKQ0ICAACACa08NACAIKAIYIQsCQCAIKAIMIgAgCEYNACAIKAIIIgNBACgCmNCAgABJGiAAIAM2AgggAyAANgIMDAkLAkAgCEEUaiIFKAIAIgMNACAIKAIQIgNFDQMgCEEQaiEFCwNAIAUhBiADIgBBFGoiBSgCACIDDQAgAEEQaiEFIAAoAhAiAw0ACyAGQQA2AgAMCAsCQEEAKAKQ0ICAACIDIAJJDQBBACgCnNCAgAAhBAJAAkAgAyACayIFQRBJDQAgBCACaiIAIAVBAXI2AgRBACAFNgKQ0ICAAEEAIAA2ApzQgIAAIAQgA2ogBTYCACAEIAJBA3I2AgQMAQsgBCADQQNyNgIEIAQgA2oiAyADKAIEQQFyNgIEQQBBADYCnNCAgABBAEEANgKQ0ICAAAsgBEEIaiEDDAoLAkBBACgClNCAgAAiACACTQ0AQQAoAqDQgIAAIgMgAmoiBCAAIAJrIgVBAXI2AgRBACAFNgKU0ICAAEEAIAQ2AqDQgIAAIAMgAkEDcjYCBCADQQhqIQMMCgsCQAJAQQAoAuDTgIAARQ0AQQAoAujTgIAAIQQMAQtBAEJ/NwLs04CAAEEAQoCAhICAgMAANwLk04CAAEEAIAFBDGpBcHFB2KrVqgVzNgLg04CAAEEAQQA2AvTTgIAAQQBBADYCxNOAgABBgIAEIQQLQQAhAwJAIAQgAkHHAGoiB2oiBkEAIARrIgtxIgggAksNAEEAQTA2AvjTgIAADAoLAkBBACgCwNOAgAAiA0UNAAJAQQAoArjTgIAAIgQgCGoiBSAETQ0AIAUgA00NAQtBACEDQQBBMDYC+NOAgAAMCgtBAC0AxNOAgABBBHENBAJAAkACQEEAKAKg0ICAACIERQ0AQcjTgIAAIQMDQAJAIAMoAgAiBSAESw0AIAUgAygCBGogBEsNAwsgAygCCCIDDQALC0EAEMuAgIAAIgBBf0YNBSAIIQYCQEEAKALk04CAACIDQX9qIgQgAHFFDQAgCCAAayAEIABqQQAgA2txaiEGCyAGIAJNDQUgBkH+////B0sNBQJAQQAoAsDTgIAAIgNFDQBBACgCuNOAgAAiBCAGaiIFIARNDQYgBSADSw0GCyAGEMuAgIAAIgMgAEcNAQwHCyAGIABrIAtxIgZB/v///wdLDQQgBhDLgICAACIAIAMoAgAgAygCBGpGDQMgACEDCwJAIANBf0YNACACQcgAaiAGTQ0AAkAgByAGa0EAKALo04CAACIEakEAIARrcSIEQf7///8HTQ0AIAMhAAwHCwJAIAQQy4CAgABBf0YNACAEIAZqIQYgAyEADAcLQQAgBmsQy4CAgAAaDAQLIAMhACADQX9HDQUMAwtBACEIDAcLQQAhAAwFCyAAQX9HDQILQQBBACgCxNOAgABBBHI2AsTTgIAACyAIQf7///8HSw0BIAgQy4CAgAAhAEEAEMuAgIAAIQMgAEF/Rg0BIANBf0YNASAAIANPDQEgAyAAayIGIAJBOGpNDQELQQBBACgCuNOAgAAgBmoiAzYCuNOAgAACQCADQQAoArzTgIAATQ0AQQAgAzYCvNOAgAALAkACQAJAAkBBACgCoNCAgAAiBEUNAEHI04CAACEDA0AgACADKAIAIgUgAygCBCIIakYNAiADKAIIIgMNAAwDCwsCQAJAQQAoApjQgIAAIgNFDQAgACADTw0BC0EAIAA2ApjQgIAAC0EAIQNBACAGNgLM04CAAEEAIAA2AsjTgIAAQQBBfzYCqNCAgABBAEEAKALg04CAADYCrNCAgABBAEEANgLU04CAAANAIANBxNCAgABqIANBuNCAgABqIgQ2AgAgBCADQbDQgIAAaiIFNgIAIANBvNCAgABqIAU2AgAgA0HM0ICAAGogA0HA0ICAAGoiBTYCACAFIAQ2AgAgA0HU0ICAAGogA0HI0ICAAGoiBDYCACAEIAU2AgAgA0HQ0ICAAGogBDYCACADQSBqIgNBgAJHDQALIABBeCAAa0EPcUEAIABBCGpBD3EbIgNqIgQgBkFIaiIFIANrIgNBAXI2AgRBAEEAKALw04CAADYCpNCAgABBACADNgKU0ICAAEEAIAQ2AqDQgIAAIAAgBWpBODYCBAwCCyADLQAMQQhxDQAgBCAFSQ0AIAQgAE8NACAEQXggBGtBD3FBACAEQQhqQQ9xGyIFaiIAQQAoApTQgIAAIAZqIgsgBWsiBUEBcjYCBCADIAggBmo2AgRBAEEAKALw04CAADYCpNCAgABBACAFNgKU0ICAAEEAIAA2AqDQgIAAIAQgC2pBODYCBAwBCwJAIABBACgCmNCAgAAiCE8NAEEAIAA2ApjQgIAAIAAhCAsgACAGaiEFQcjTgIAAIQMCQAJAAkACQAJAAkACQANAIAMoAgAgBUYNASADKAIIIgMNAAwCCwsgAy0ADEEIcUUNAQtByNOAgAAhAwNAAkAgAygCACIFIARLDQAgBSADKAIEaiIFIARLDQMLIAMoAgghAwwACwsgAyAANgIAIAMgAygCBCAGajYCBCAAQXggAGtBD3FBACAAQQhqQQ9xG2oiCyACQQNyNgIEIAVBeCAFa0EPcUEAIAVBCGpBD3EbaiIGIAsgAmoiAmshAwJAIAYgBEcNAEEAIAI2AqDQgIAAQQBBACgClNCAgAAgA2oiAzYClNCAgAAgAiADQQFyNgIEDAMLAkAgBkEAKAKc0ICAAEcNAEEAIAI2ApzQgIAAQQBBACgCkNCAgAAgA2oiAzYCkNCAgAAgAiADQQFyNgIEIAIgA2ogAzYCAAwDCwJAIAYoAgQiBEEDcUEBRw0AIARBeHEhBwJAAkAgBEH/AUsNACAGKAIIIgUgBEEDdiIIQQN0QbDQgIAAaiIARhoCQCAGKAIMIgQgBUcNAEEAQQAoAojQgIAAQX4gCHdxNgKI0ICAAAwCCyAEIABGGiAEIAU2AgggBSAENgIMDAELIAYoAhghCQJAAkAgBigCDCIAIAZGDQAgBigCCCIEIAhJGiAAIAQ2AgggBCAANgIMDAELAkAgBkEUaiIEKAIAIgUNACAGQRBqIgQoAgAiBQ0AQQAhAAwBCwNAIAQhCCAFIgBBFGoiBCgCACIFDQAgAEEQaiEEIAAoAhAiBQ0ACyAIQQA2AgALIAlFDQACQAJAIAYgBigCHCIFQQJ0QbjSgIAAaiIEKAIARw0AIAQgADYCACAADQFBAEEAKAKM0ICAAEF+IAV3cTYCjNCAgAAMAgsgCUEQQRQgCSgCECAGRhtqIAA2AgAgAEUNAQsgACAJNgIYAkAgBigCECIERQ0AIAAgBDYCECAEIAA2AhgLIAYoAhQiBEUNACAAQRRqIAQ2AgAgBCAANgIYCyAHIANqIQMgBiAHaiIGKAIEIQQLIAYgBEF+cTYCBCACIANqIAM2AgAgAiADQQFyNgIEAkAgA0H/AUsNACADQXhxQbDQgIAAaiEEAkACQEEAKAKI0ICAACIFQQEgA0EDdnQiA3ENAEEAIAUgA3I2AojQgIAAIAQhAwwBCyAEKAIIIQMLIAMgAjYCDCAEIAI2AgggAiAENgIMIAIgAzYCCAwDC0EfIQQCQCADQf///wdLDQAgA0EIdiIEIARBgP4/akEQdkEIcSIEdCIFIAVBgOAfakEQdkEEcSIFdCIAIABBgIAPakEQdkECcSIAdEEPdiAEIAVyIAByayIEQQF0IAMgBEEVanZBAXFyQRxqIQQLIAIgBDYCHCACQgA3AhAgBEECdEG40oCAAGohBQJAQQAoAozQgIAAIgBBASAEdCIIcQ0AIAUgAjYCAEEAIAAgCHI2AozQgIAAIAIgBTYCGCACIAI2AgggAiACNgIMDAMLIANBAEEZIARBAXZrIARBH0YbdCEEIAUoAgAhAANAIAAiBSgCBEF4cSADRg0CIARBHXYhACAEQQF0IQQgBSAAQQRxakEQaiIIKAIAIgANAAsgCCACNgIAIAIgBTYCGCACIAI2AgwgAiACNgIIDAILIABBeCAAa0EPcUEAIABBCGpBD3EbIgNqIgsgBkFIaiIIIANrIgNBAXI2AgQgACAIakE4NgIEIAQgBUE3IAVrQQ9xQQAgBUFJakEPcRtqQUFqIgggCCAEQRBqSRsiCEEjNgIEQQBBACgC8NOAgAA2AqTQgIAAQQAgAzYClNCAgABBACALNgKg0ICAACAIQRBqQQApAtDTgIAANwIAIAhBACkCyNOAgAA3AghBACAIQQhqNgLQ04CAAEEAIAY2AszTgIAAQQAgADYCyNOAgABBAEEANgLU04CAACAIQSRqIQMDQCADQQc2AgAgA0EEaiIDIAVJDQALIAggBEYNAyAIIAgoAgRBfnE2AgQgCCAIIARrIgA2AgAgBCAAQQFyNgIEAkAgAEH/AUsNACAAQXhxQbDQgIAAaiEDAkACQEEAKAKI0ICAACIFQQEgAEEDdnQiAHENAEEAIAUgAHI2AojQgIAAIAMhBQwBCyADKAIIIQULIAUgBDYCDCADIAQ2AgggBCADNgIMIAQgBTYCCAwEC0EfIQMCQCAAQf///wdLDQAgAEEIdiIDIANBgP4/akEQdkEIcSIDdCIFIAVBgOAfakEQdkEEcSIFdCIIIAhBgIAPakEQdkECcSIIdEEPdiADIAVyIAhyayIDQQF0IAAgA0EVanZBAXFyQRxqIQMLIAQgAzYCHCAEQgA3AhAgA0ECdEG40oCAAGohBQJAQQAoAozQgIAAIghBASADdCIGcQ0AIAUgBDYCAEEAIAggBnI2AozQgIAAIAQgBTYCGCAEIAQ2AgggBCAENgIMDAQLIABBAEEZIANBAXZrIANBH0YbdCEDIAUoAgAhCANAIAgiBSgCBEF4cSAARg0DIANBHXYhCCADQQF0IQMgBSAIQQRxakEQaiIGKAIAIggNAAsgBiAENgIAIAQgBTYCGCAEIAQ2AgwgBCAENgIIDAMLIAUoAggiAyACNgIMIAUgAjYCCCACQQA2AhggAiAFNgIMIAIgAzYCCAsgC0EIaiEDDAULIAUoAggiAyAENgIMIAUgBDYCCCAEQQA2AhggBCAFNgIMIAQgAzYCCAtBACgClNCAgAAiAyACTQ0AQQAoAqDQgIAAIgQgAmoiBSADIAJrIgNBAXI2AgRBACADNgKU0ICAAEEAIAU2AqDQgIAAIAQgAkEDcjYCBCAEQQhqIQMMAwtBACEDQQBBMDYC+NOAgAAMAgsCQCALRQ0AAkACQCAIIAgoAhwiBUECdEG40oCAAGoiAygCAEcNACADIAA2AgAgAA0BQQAgB0F+IAV3cSIHNgKM0ICAAAwCCyALQRBBFCALKAIQIAhGG2ogADYCACAARQ0BCyAAIAs2AhgCQCAIKAIQIgNFDQAgACADNgIQIAMgADYCGAsgCEEUaigCACIDRQ0AIABBFGogAzYCACADIAA2AhgLAkACQCAEQQ9LDQAgCCAEIAJqIgNBA3I2AgQgCCADaiIDIAMoAgRBAXI2AgQMAQsgCCACaiIAIARBAXI2AgQgCCACQQNyNgIEIAAgBGogBDYCAAJAIARB/wFLDQAgBEF4cUGw0ICAAGohAwJAAkBBACgCiNCAgAAiBUEBIARBA3Z0IgRxDQBBACAFIARyNgKI0ICAACADIQQMAQsgAygCCCEECyAEIAA2AgwgAyAANgIIIAAgAzYCDCAAIAQ2AggMAQtBHyEDAkAgBEH///8HSw0AIARBCHYiAyADQYD+P2pBEHZBCHEiA3QiBSAFQYDgH2pBEHZBBHEiBXQiAiACQYCAD2pBEHZBAnEiAnRBD3YgAyAFciACcmsiA0EBdCAEIANBFWp2QQFxckEcaiEDCyAAIAM2AhwgAEIANwIQIANBAnRBuNKAgABqIQUCQCAHQQEgA3QiAnENACAFIAA2AgBBACAHIAJyNgKM0ICAACAAIAU2AhggACAANgIIIAAgADYCDAwBCyAEQQBBGSADQQF2ayADQR9GG3QhAyAFKAIAIQICQANAIAIiBSgCBEF4cSAERg0BIANBHXYhAiADQQF0IQMgBSACQQRxakEQaiIGKAIAIgINAAsgBiAANgIAIAAgBTYCGCAAIAA2AgwgACAANgIIDAELIAUoAggiAyAANgIMIAUgADYCCCAAQQA2AhggACAFNgIMIAAgAzYCCAsgCEEIaiEDDAELAkAgCkUNAAJAAkAgACAAKAIcIgVBAnRBuNKAgABqIgMoAgBHDQAgAyAINgIAIAgNAUEAIAlBfiAFd3E2AozQgIAADAILIApBEEEUIAooAhAgAEYbaiAINgIAIAhFDQELIAggCjYCGAJAIAAoAhAiA0UNACAIIAM2AhAgAyAINgIYCyAAQRRqKAIAIgNFDQAgCEEUaiADNgIAIAMgCDYCGAsCQAJAIARBD0sNACAAIAQgAmoiA0EDcjYCBCAAIANqIgMgAygCBEEBcjYCBAwBCyAAIAJqIgUgBEEBcjYCBCAAIAJBA3I2AgQgBSAEaiAENgIAAkAgB0UNACAHQXhxQbDQgIAAaiECQQAoApzQgIAAIQMCQAJAQQEgB0EDdnQiCCAGcQ0AQQAgCCAGcjYCiNCAgAAgAiEIDAELIAIoAgghCAsgCCADNgIMIAIgAzYCCCADIAI2AgwgAyAINgIIC0EAIAU2ApzQgIAAQQAgBDYCkNCAgAALIABBCGohAwsgAUEQaiSAgICAACADCwoAIAAQyYCAgAAL4g0BB38CQCAARQ0AIABBeGoiASAAQXxqKAIAIgJBeHEiAGohAwJAIAJBAXENACACQQNxRQ0BIAEgASgCACICayIBQQAoApjQgIAAIgRJDQEgAiAAaiEAAkAgAUEAKAKc0ICAAEYNAAJAIAJB/wFLDQAgASgCCCIEIAJBA3YiBUEDdEGw0ICAAGoiBkYaAkAgASgCDCICIARHDQBBAEEAKAKI0ICAAEF+IAV3cTYCiNCAgAAMAwsgAiAGRhogAiAENgIIIAQgAjYCDAwCCyABKAIYIQcCQAJAIAEoAgwiBiABRg0AIAEoAggiAiAESRogBiACNgIIIAIgBjYCDAwBCwJAIAFBFGoiAigCACIEDQAgAUEQaiICKAIAIgQNAEEAIQYMAQsDQCACIQUgBCIGQRRqIgIoAgAiBA0AIAZBEGohAiAGKAIQIgQNAAsgBUEANgIACyAHRQ0BAkACQCABIAEoAhwiBEECdEG40oCAAGoiAigCAEcNACACIAY2AgAgBg0BQQBBACgCjNCAgABBfiAEd3E2AozQgIAADAMLIAdBEEEUIAcoAhAgAUYbaiAGNgIAIAZFDQILIAYgBzYCGAJAIAEoAhAiAkUNACAGIAI2AhAgAiAGNgIYCyABKAIUIgJFDQEgBkEUaiACNgIAIAIgBjYCGAwBCyADKAIEIgJBA3FBA0cNACADIAJBfnE2AgRBACAANgKQ0ICAACABIABqIAA2AgAgASAAQQFyNgIEDwsgASADTw0AIAMoAgQiAkEBcUUNAAJAAkAgAkECcQ0AAkAgA0EAKAKg0ICAAEcNAEEAIAE2AqDQgIAAQQBBACgClNCAgAAgAGoiADYClNCAgAAgASAAQQFyNgIEIAFBACgCnNCAgABHDQNBAEEANgKQ0ICAAEEAQQA2ApzQgIAADwsCQCADQQAoApzQgIAARw0AQQAgATYCnNCAgABBAEEAKAKQ0ICAACAAaiIANgKQ0ICAACABIABBAXI2AgQgASAAaiAANgIADwsgAkF4cSAAaiEAAkACQCACQf8BSw0AIAMoAggiBCACQQN2IgVBA3RBsNCAgABqIgZGGgJAIAMoAgwiAiAERw0AQQBBACgCiNCAgABBfiAFd3E2AojQgIAADAILIAIgBkYaIAIgBDYCCCAEIAI2AgwMAQsgAygCGCEHAkACQCADKAIMIgYgA0YNACADKAIIIgJBACgCmNCAgABJGiAGIAI2AgggAiAGNgIMDAELAkAgA0EUaiICKAIAIgQNACADQRBqIgIoAgAiBA0AQQAhBgwBCwNAIAIhBSAEIgZBFGoiAigCACIEDQAgBkEQaiECIAYoAhAiBA0ACyAFQQA2AgALIAdFDQACQAJAIAMgAygCHCIEQQJ0QbjSgIAAaiICKAIARw0AIAIgBjYCACAGDQFBAEEAKAKM0ICAAEF+IAR3cTYCjNCAgAAMAgsgB0EQQRQgBygCECADRhtqIAY2AgAgBkUNAQsgBiAHNgIYAkAgAygCECICRQ0AIAYgAjYCECACIAY2AhgLIAMoAhQiAkUNACAGQRRqIAI2AgAgAiAGNgIYCyABIABqIAA2AgAgASAAQQFyNgIEIAFBACgCnNCAgABHDQFBACAANgKQ0ICAAA8LIAMgAkF+cTYCBCABIABqIAA2AgAgASAAQQFyNgIECwJAIABB/wFLDQAgAEF4cUGw0ICAAGohAgJAAkBBACgCiNCAgAAiBEEBIABBA3Z0IgBxDQBBACAEIAByNgKI0ICAACACIQAMAQsgAigCCCEACyAAIAE2AgwgAiABNgIIIAEgAjYCDCABIAA2AggPC0EfIQICQCAAQf///wdLDQAgAEEIdiICIAJBgP4/akEQdkEIcSICdCIEIARBgOAfakEQdkEEcSIEdCIGIAZBgIAPakEQdkECcSIGdEEPdiACIARyIAZyayICQQF0IAAgAkEVanZBAXFyQRxqIQILIAEgAjYCHCABQgA3AhAgAkECdEG40oCAAGohBAJAAkBBACgCjNCAgAAiBkEBIAJ0IgNxDQAgBCABNgIAQQAgBiADcjYCjNCAgAAgASAENgIYIAEgATYCCCABIAE2AgwMAQsgAEEAQRkgAkEBdmsgAkEfRht0IQIgBCgCACEGAkADQCAGIgQoAgRBeHEgAEYNASACQR12IQYgAkEBdCECIAQgBkEEcWpBEGoiAygCACIGDQALIAMgATYCACABIAQ2AhggASABNgIMIAEgATYCCAwBCyAEKAIIIgAgATYCDCAEIAE2AgggAUEANgIYIAEgBDYCDCABIAA2AggLQQBBACgCqNCAgABBf2oiAUF/IAEbNgKo0ICAAAsLBAAAAAtOAAJAIAANAD8AQRB0DwsCQCAAQf//A3ENACAAQX9MDQACQCAAQRB2QAAiAEF/Rw0AQQBBMDYC+NOAgABBfw8LIABBEHQPCxDKgICAAAAL8gICA38BfgJAIAJFDQAgACABOgAAIAIgAGoiA0F/aiABOgAAIAJBA0kNACAAIAE6AAIgACABOgABIANBfWogAToAACADQX5qIAE6AAAgAkEHSQ0AIAAgAToAAyADQXxqIAE6AAAgAkEJSQ0AIABBACAAa0EDcSIEaiIDIAFB/wFxQYGChAhsIgE2AgAgAyACIARrQXxxIgRqIgJBfGogATYCACAEQQlJDQAgAyABNgIIIAMgATYCBCACQXhqIAE2AgAgAkF0aiABNgIAIARBGUkNACADIAE2AhggAyABNgIUIAMgATYCECADIAE2AgwgAkFwaiABNgIAIAJBbGogATYCACACQWhqIAE2AgAgAkFkaiABNgIAIAQgA0EEcUEYciIFayICQSBJDQAgAa1CgYCAgBB+IQYgAyAFaiEBA0AgASAGNwMYIAEgBjcDECABIAY3AwggASAGNwMAIAFBIGohASACQWBqIgJBH0sNAAsLIAALC45IAQBBgAgLhkgBAAAAAgAAAAMAAAAAAAAAAAAAAAQAAAAFAAAAAAAAAAAAAAAGAAAABwAAAAgAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAEludmFsaWQgY2hhciBpbiB1cmwgcXVlcnkAU3BhbiBjYWxsYmFjayBlcnJvciBpbiBvbl9ib2R5AENvbnRlbnQtTGVuZ3RoIG92ZXJmbG93AENodW5rIHNpemUgb3ZlcmZsb3cAUmVzcG9uc2Ugb3ZlcmZsb3cASW52YWxpZCBtZXRob2QgZm9yIEhUVFAveC54IHJlcXVlc3QASW52YWxpZCBtZXRob2QgZm9yIFJUU1AveC54IHJlcXVlc3QARXhwZWN0ZWQgU09VUkNFIG1ldGhvZCBmb3IgSUNFL3gueCByZXF1ZXN0AEludmFsaWQgY2hhciBpbiB1cmwgZnJhZ21lbnQgc3RhcnQARXhwZWN0ZWQgZG90AFNwYW4gY2FsbGJhY2sgZXJyb3IgaW4gb25fc3RhdHVzAEludmFsaWQgcmVzcG9uc2Ugc3RhdHVzAEludmFsaWQgY2hhcmFjdGVyIGluIGNodW5rIGV4dGVuc2lvbnMAVXNlciBjYWxsYmFjayBlcnJvcgBgb25fcmVzZXRgIGNhbGxiYWNrIGVycm9yAGBvbl9jaHVua19oZWFkZXJgIGNhbGxiYWNrIGVycm9yAGBvbl9tZXNzYWdlX2JlZ2luYCBjYWxsYmFjayBlcnJvcgBgb25fY2h1bmtfZXh0ZW5zaW9uX3ZhbHVlYCBjYWxsYmFjayBlcnJvcgBgb25fc3RhdHVzX2NvbXBsZXRlYCBjYWxsYmFjayBlcnJvcgBgb25fdmVyc2lvbl9jb21wbGV0ZWAgY2FsbGJhY2sgZXJyb3IAYG9uX3VybF9jb21wbGV0ZWAgY2FsbGJhY2sgZXJyb3IAYG9uX2NodW5rX2NvbXBsZXRlYCBjYWxsYmFjayBlcnJvcgBgb25faGVhZGVyX3ZhbHVlX2NvbXBsZXRlYCBjYWxsYmFjayBlcnJvcgBgb25fbWVzc2FnZV9jb21wbGV0ZWAgY2FsbGJhY2sgZXJyb3IAYG9uX21ldGhvZF9jb21wbGV0ZWAgY2FsbGJhY2sgZXJyb3IAYG9uX2hlYWRlcl9maWVsZF9jb21wbGV0ZWAgY2FsbGJhY2sgZXJyb3IAYG9uX2NodW5rX2V4dGVuc2lvbl9uYW1lYCBjYWxsYmFjayBlcnJvcgBVbmV4cGVjdGVkIGNoYXIgaW4gdXJsIHNlcnZlcgBJbnZhbGlkIGhlYWRlciB2YWx1ZSBjaGFyAEludmFsaWQgaGVhZGVyIGZpZWxkIGNoYXIAU3BhbiBjYWxsYmFjayBlcnJvciBpbiBvbl92ZXJzaW9uAEludmFsaWQgbWlub3IgdmVyc2lvbgBJbnZhbGlkIG1ham9yIHZlcnNpb24ARXhwZWN0ZWQgc3BhY2UgYWZ0ZXIgdmVyc2lvbgBFeHBlY3RlZCBDUkxGIGFmdGVyIHZlcnNpb24ASW52YWxpZCBIVFRQIHZlcnNpb24ASW52YWxpZCBoZWFkZXIgdG9rZW4AU3BhbiBjYWxsYmFjayBlcnJvciBpbiBvbl91cmwASW52YWxpZCBjaGFyYWN0ZXJzIGluIHVybABVbmV4cGVjdGVkIHN0YXJ0IGNoYXIgaW4gdXJsAERvdWJsZSBAIGluIHVybABFbXB0eSBDb250ZW50LUxlbmd0aABJbnZhbGlkIGNoYXJhY3RlciBpbiBDb250ZW50LUxlbmd0aABEdXBsaWNhdGUgQ29udGVudC1MZW5ndGgASW52YWxpZCBjaGFyIGluIHVybCBwYXRoAENvbnRlbnQtTGVuZ3RoIGNhbid0IGJlIHByZXNlbnQgd2l0aCBUcmFuc2Zlci1FbmNvZGluZwBJbnZhbGlkIGNoYXJhY3RlciBpbiBjaHVuayBzaXplAFNwYW4gY2FsbGJhY2sgZXJyb3IgaW4gb25faGVhZGVyX3ZhbHVlAFNwYW4gY2FsbGJhY2sgZXJyb3IgaW4gb25fY2h1bmtfZXh0ZW5zaW9uX3ZhbHVlAEludmFsaWQgY2hhcmFjdGVyIGluIGNodW5rIGV4dGVuc2lvbnMgdmFsdWUATWlzc2luZyBleHBlY3RlZCBMRiBhZnRlciBoZWFkZXIgdmFsdWUASW52YWxpZCBgVHJhbnNmZXItRW5jb2RpbmdgIGhlYWRlciB2YWx1ZQBJbnZhbGlkIGNoYXJhY3RlciBpbiBjaHVuayBleHRlbnNpb25zIHF1b3RlIHZhbHVlAEludmFsaWQgY2hhcmFjdGVyIGluIGNodW5rIGV4dGVuc2lvbnMgcXVvdGVkIHZhbHVlAFBhdXNlZCBieSBvbl9oZWFkZXJzX2NvbXBsZXRlAEludmFsaWQgRU9GIHN0YXRlAG9uX3Jlc2V0IHBhdXNlAG9uX2NodW5rX2hlYWRlciBwYXVzZQBvbl9tZXNzYWdlX2JlZ2luIHBhdXNlAG9uX2NodW5rX2V4dGVuc2lvbl92YWx1ZSBwYXVzZQBvbl9zdGF0dXNfY29tcGxldGUgcGF1c2UAb25fdmVyc2lvbl9jb21wbGV0ZSBwYXVzZQBvbl91cmxfY29tcGxldGUgcGF1c2UAb25fY2h1bmtfY29tcGxldGUgcGF1c2UAb25faGVhZGVyX3ZhbHVlX2NvbXBsZXRlIHBhdXNlAG9uX21lc3NhZ2VfY29tcGxldGUgcGF1c2UAb25fbWV0aG9kX2NvbXBsZXRlIHBhdXNlAG9uX2hlYWRlcl9maWVsZF9jb21wbGV0ZSBwYXVzZQBvbl9jaHVua19leHRlbnNpb25fbmFtZSBwYXVzZQBVbmV4cGVjdGVkIHNwYWNlIGFmdGVyIHN0YXJ0IGxpbmUAU3BhbiBjYWxsYmFjayBlcnJvciBpbiBvbl9jaHVua19leHRlbnNpb25fbmFtZQBJbnZhbGlkIGNoYXJhY3RlciBpbiBjaHVuayBleHRlbnNpb25zIG5hbWUAUGF1c2Ugb24gQ09OTkVDVC9VcGdyYWRlAFBhdXNlIG9uIFBSSS9VcGdyYWRlAEV4cGVjdGVkIEhUVFAvMiBDb25uZWN0aW9uIFByZWZhY2UAU3BhbiBjYWxsYmFjayBlcnJvciBpbiBvbl9tZXRob2QARXhwZWN0ZWQgc3BhY2UgYWZ0ZXIgbWV0aG9kAFNwYW4gY2FsbGJhY2sgZXJyb3IgaW4gb25faGVhZGVyX2ZpZWxkAFBhdXNlZABJbnZhbGlkIHdvcmQgZW5jb3VudGVyZWQASW52YWxpZCBtZXRob2QgZW5jb3VudGVyZWQAVW5leHBlY3RlZCBjaGFyIGluIHVybCBzY2hlbWEAUmVxdWVzdCBoYXMgaW52YWxpZCBgVHJhbnNmZXItRW5jb2RpbmdgAFNXSVRDSF9QUk9YWQBVU0VfUFJPWFkATUtBQ1RJVklUWQBVTlBST0NFU1NBQkxFX0VOVElUWQBDT1BZAE1PVkVEX1BFUk1BTkVOVExZAFRPT19FQVJMWQBOT1RJRlkARkFJTEVEX0RFUEVOREVOQ1kAQkFEX0dBVEVXQVkAUExBWQBQVVQAQ0hFQ0tPVVQAR0FURVdBWV9USU1FT1VUAFJFUVVFU1RfVElNRU9VVABORVRXT1JLX0NPTk5FQ1RfVElNRU9VVABDT05ORUNUSU9OX1RJTUVPVVQATE9HSU5fVElNRU9VVABORVRXT1JLX1JFQURfVElNRU9VVABQT1NUAE1JU0RJUkVDVEVEX1JFUVVFU1QAQ0xJRU5UX0NMT1NFRF9SRVFVRVNUAENMSUVOVF9DTE9TRURfTE9BRF9CQUxBTkNFRF9SRVFVRVNUAEJBRF9SRVFVRVNUAEhUVFBfUkVRVUVTVF9TRU5UX1RPX0hUVFBTX1BPUlQAUkVQT1JUAElNX0FfVEVBUE9UAFJFU0VUX0NPTlRFTlQATk9fQ09OVEVOVABQQVJUSUFMX0NPTlRFTlQASFBFX0lOVkFMSURfQ09OU1RBTlQASFBFX0NCX1JFU0VUAEdFVABIUEVfU1RSSUNUAENPTkZMSUNUAFRFTVBPUkFSWV9SRURJUkVDVABQRVJNQU5FTlRfUkVESVJFQ1QAQ09OTkVDVABNVUxUSV9TVEFUVVMASFBFX0lOVkFMSURfU1RBVFVTAFRPT19NQU5ZX1JFUVVFU1RTAEVBUkxZX0hJTlRTAFVOQVZBSUxBQkxFX0ZPUl9MRUdBTF9SRUFTT05TAE9QVElPTlMAU1dJVENISU5HX1BST1RPQ09MUwBWQVJJQU5UX0FMU09fTkVHT1RJQVRFUwBNVUxUSVBMRV9DSE9JQ0VTAElOVEVSTkFMX1NFUlZFUl9FUlJPUgBXRUJfU0VSVkVSX1VOS05PV05fRVJST1IAUkFJTEdVTl9FUlJPUgBJREVOVElUWV9QUk9WSURFUl9BVVRIRU5USUNBVElPTl9FUlJPUgBTU0xfQ0VSVElGSUNBVEVfRVJST1IASU5WQUxJRF9YX0ZPUldBUkRFRF9GT1IAU0VUX1BBUkFNRVRFUgBHRVRfUEFSQU1FVEVSAEhQRV9VU0VSAFNFRV9PVEhFUgBIUEVfQ0JfQ0hVTktfSEVBREVSAE1LQ0FMRU5EQVIAU0VUVVAAV0VCX1NFUlZFUl9JU19ET1dOAFRFQVJET1dOAEhQRV9DTE9TRURfQ09OTkVDVElPTgBIRVVSSVNUSUNfRVhQSVJBVElPTgBESVNDT05ORUNURURfT1BFUkFUSU9OAE5PTl9BVVRIT1JJVEFUSVZFX0lORk9STUFUSU9OAEhQRV9JTlZBTElEX1ZFUlNJT04ASFBFX0NCX01FU1NBR0VfQkVHSU4AU0lURV9JU19GUk9aRU4ASFBFX0lOVkFMSURfSEVBREVSX1RPS0VOAElOVkFMSURfVE9LRU4ARk9SQklEREVOAEVOSEFOQ0VfWU9VUl9DQUxNAEhQRV9JTlZBTElEX1VSTABCTE9DS0VEX0JZX1BBUkVOVEFMX0NPTlRST0wATUtDT0wAQUNMAEhQRV9JTlRFUk5BTABSRVFVRVNUX0hFQURFUl9GSUVMRFNfVE9PX0xBUkdFX1VOT0ZGSUNJQUwASFBFX09LAFVOTElOSwBVTkxPQ0sAUFJJAFJFVFJZX1dJVEgASFBFX0lOVkFMSURfQ09OVEVOVF9MRU5HVEgASFBFX1VORVhQRUNURURfQ09OVEVOVF9MRU5HVEgARkxVU0gAUFJPUFBBVENIAE0tU0VBUkNIAFVSSV9UT09fTE9ORwBQUk9DRVNTSU5HAE1JU0NFTExBTkVPVVNfUEVSU0lTVEVOVF9XQVJOSU5HAE1JU0NFTExBTkVPVVNfV0FSTklORwBIUEVfSU5WQUxJRF9UUkFOU0ZFUl9FTkNPRElORwBFeHBlY3RlZCBDUkxGAEhQRV9JTlZBTElEX0NIVU5LX1NJWkUATU9WRQBDT05USU5VRQBIUEVfQ0JfU1RBVFVTX0NPTVBMRVRFAEhQRV9DQl9IRUFERVJTX0NPTVBMRVRFAEhQRV9DQl9WRVJTSU9OX0NPTVBMRVRFAEhQRV9DQl9VUkxfQ09NUExFVEUASFBFX0NCX0NIVU5LX0NPTVBMRVRFAEhQRV9DQl9IRUFERVJfVkFMVUVfQ09NUExFVEUASFBFX0NCX0NIVU5LX0VYVEVOU0lPTl9WQUxVRV9DT01QTEVURQBIUEVfQ0JfQ0hVTktfRVhURU5TSU9OX05BTUVfQ09NUExFVEUASFBFX0NCX01FU1NBR0VfQ09NUExFVEUASFBFX0NCX01FVEhPRF9DT01QTEVURQBIUEVfQ0JfSEVBREVSX0ZJRUxEX0NPTVBMRVRFAERFTEVURQBIUEVfSU5WQUxJRF9FT0ZfU1RBVEUASU5WQUxJRF9TU0xfQ0VSVElGSUNBVEUAUEFVU0UATk9fUkVTUE9OU0UAVU5TVVBQT1JURURfTUVESUFfVFlQRQBHT05FAE5PVF9BQ0NFUFRBQkxFAFNFUlZJQ0VfVU5BVkFJTEFCTEUAUkFOR0VfTk9UX1NBVElTRklBQkxFAE9SSUdJTl9JU19VTlJFQUNIQUJMRQBSRVNQT05TRV9JU19TVEFMRQBQVVJHRQBNRVJHRQBSRVFVRVNUX0hFQURFUl9GSUVMRFNfVE9PX0xBUkdFAFJFUVVFU1RfSEVBREVSX1RPT19MQVJHRQBQQVlMT0FEX1RPT19MQVJHRQBJTlNVRkZJQ0lFTlRfU1RPUkFHRQBIUEVfUEFVU0VEX1VQR1JBREUASFBFX1BBVVNFRF9IMl9VUEdSQURFAFNPVVJDRQBBTk5PVU5DRQBUUkFDRQBIUEVfVU5FWFBFQ1RFRF9TUEFDRQBERVNDUklCRQBVTlNVQlNDUklCRQBSRUNPUkQASFBFX0lOVkFMSURfTUVUSE9EAE5PVF9GT1VORABQUk9QRklORABVTkJJTkQAUkVCSU5EAFVOQVVUSE9SSVpFRABNRVRIT0RfTk9UX0FMTE9XRUQASFRUUF9WRVJTSU9OX05PVF9TVVBQT1JURUQAQUxSRUFEWV9SRVBPUlRFRABBQ0NFUFRFRABOT1RfSU1QTEVNRU5URUQATE9PUF9ERVRFQ1RFRABIUEVfQ1JfRVhQRUNURUQASFBFX0xGX0VYUEVDVEVEAENSRUFURUQASU1fVVNFRABIUEVfUEFVU0VEAFRJTUVPVVRfT0NDVVJFRABQQVlNRU5UX1JFUVVJUkVEAFBSRUNPTkRJVElPTl9SRVFVSVJFRABQUk9YWV9BVVRIRU5USUNBVElPTl9SRVFVSVJFRABORVRXT1JLX0FVVEhFTlRJQ0FUSU9OX1JFUVVJUkVEAExFTkdUSF9SRVFVSVJFRABTU0xfQ0VSVElGSUNBVEVfUkVRVUlSRUQAVVBHUkFERV9SRVFVSVJFRABQQUdFX0VYUElSRUQAUFJFQ09ORElUSU9OX0ZBSUxFRABFWFBFQ1RBVElPTl9GQUlMRUQAUkVWQUxJREFUSU9OX0ZBSUxFRABTU0xfSEFORFNIQUtFX0ZBSUxFRABMT0NLRUQAVFJBTlNGT1JNQVRJT05fQVBQTElFRABOT1RfTU9ESUZJRUQATk9UX0VYVEVOREVEAEJBTkRXSURUSF9MSU1JVF9FWENFRURFRABTSVRFX0lTX09WRVJMT0FERUQASEVBRABFeHBlY3RlZCBIVFRQLwAAXhMAACYTAAAwEAAA8BcAAJ0TAAAVEgAAORcAAPASAAAKEAAAdRIAAK0SAACCEwAATxQAAH8QAACgFQAAIxQAAIkSAACLFAAATRUAANQRAADPFAAAEBgAAMkWAADcFgAAwREAAOAXAAC7FAAAdBQAAHwVAADlFAAACBcAAB8QAABlFQAAoxQAACgVAAACFQAAmRUAACwQAACLGQAATw8AANQOAABqEAAAzhAAAAIXAACJDgAAbhMAABwTAABmFAAAVhcAAMETAADNEwAAbBMAAGgXAABmFwAAXxcAACITAADODwAAaQ4AANgOAABjFgAAyxMAAKoOAAAoFwAAJhcAAMUTAABdFgAA6BEAAGcTAABlEwAA8hYAAHMTAAAdFwAA+RYAAPMRAADPDgAAzhUAAAwSAACzEQAApREAAGEQAAAyFwAAuxMAAAAAAAAAAAAAAAAAAAAAAAAAAQAAAAAAAAAAAAAAAAAAAAAAAAAAAAABAQIBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEAAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQAAAAAAAAAAAAAAAAABAAAAAAAAAAAAAAAAAAAAAAAAAAIDAgICAgIAAAICAAICAAICAgICAgICAgIABAAAAAAAAgICAgICAgICAgICAgICAgICAgICAgICAgIAAAACAgICAgICAgICAgICAgICAgICAgICAgICAgICAgACAAIAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAQAAAAAAAAAAAAAAAAAAAAAAAAACAAICAgICAAACAgACAgACAgICAgICAgICAAMABAAAAAICAgICAgICAgICAgICAgICAgICAgICAgICAAAAAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIAAgACAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAbG9zZWVlcC1hbGl2ZQAAAAAAAAAAAAAAAAEAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEAAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEAAAAAAAAAAAABAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAEBAQEBAQEBAQEBAQIBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAAEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBY2h1bmtlZAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAQEAAQEBAQEAAAEBAAEBAAEBAQEBAQEBAQEAAAAAAAAAAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEAAAABAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQABAAEAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAABlY3Rpb25lbnQtbGVuZ3Rob25yb3h5LWNvbm5lY3Rpb24AAAAAAAAAAAAAAAAAAAByYW5zZmVyLWVuY29kaW5ncGdyYWRlDQoNCg0KU00NCg0KVFRQL0NFL1RTUC8AAAAAAAAAAAAAAAABAgABAwAAAAAAAAAAAAAAAAAAAAAAAAQBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAAEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAAAAAAAAAAAAAQIAAQMAAAAAAAAAAAAAAAAAAAAAAAAEAQEFAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQABAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQAAAAAAAAAAAAEAAAEAAAAAAAAAAAAAAAAAAAAAAAAAAAEBAAEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQABAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEAAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEAAAAAAAAAAAAAAQAAAgAAAAAAAAAAAAAAAAAAAAAAAAMEAAAEBAQEBAQEBAQEBAUEBAQEBAQEBAQEBAQABAAGBwQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAAEAAQABAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQAAAAEAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAEAAAEAAAAAAAAAAAAAAAAAAAAAAAABAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAIAAAAAAAADAwMDAwMDAwMDAwMDAwMDAwMDAwMDAwMDAwAAAAAAAAMDAwMDAwMDAwMDAwMDAwMDAwMDAwMDAwMDAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAABAAABAAAAAAAAAAAAAAAAAAAAAAAAAQAAAAAAAAAAAAIAAAAAAgAAAAAAAAAAAAAAAAAAAAAAAwMDAwMDAwMDAwMDAwMDAwMDAwMDAwMDAwMAAAAAAAADAwMDAwMDAwMDAwMDAwMDAwMDAwMDAwMDAwAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAABOT1VOQ0VFQ0tPVVRORUNURVRFQ1JJQkVMVVNIRVRFQURTRUFSQ0hSR0VDVElWSVRZTEVOREFSVkVPVElGWVBUSU9OU0NIU0VBWVNUQVRDSEdFT1JESVJFQ1RPUlRSQ0hQQVJBTUVURVJVUkNFQlNDUklCRUFSRE9XTkFDRUlORE5LQ0tVQlNDUklCRUhUVFAvQURUUC8=' + + +/***/ }), + +/***/ 3434: +/***/ ((module) => { + +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==' + + +/***/ }), + +/***/ 172: +/***/ ((__unused_webpack_module, exports) => { + + +Object.defineProperty(exports, "__esModule", ({ value: true })); +exports.enumToMap = void 0; +function enumToMap(obj) { + const res = {}; + Object.keys(obj).forEach((key) => { + const value = obj[key]; + if (typeof value === 'number') { + res[key] = value; + } + }); + return res; +} +exports.enumToMap = enumToMap; +//# sourceMappingURL=utils.js.map + +/***/ }), + +/***/ 7501: +/***/ ((module, __unused_webpack_exports, __nccwpck_require__) => { + + + +const { kClients } = __nccwpck_require__(6443) +const Agent = __nccwpck_require__(9965) +const { + kAgent, + kMockAgentSet, + kMockAgentGet, + kDispatches, + kIsMockActive, + kNetConnect, + kGetNetConnect, + kOptions, + kFactory +} = __nccwpck_require__(1117) +const MockClient = __nccwpck_require__(7365) +const MockPool = __nccwpck_require__(4004) +const { matchValue, buildMockOptions } = __nccwpck_require__(3397) +const { InvalidArgumentError, UndiciError } = __nccwpck_require__(8707) +const Dispatcher = __nccwpck_require__(992) +const Pluralizer = __nccwpck_require__(1529) +const PendingInterceptorsFormatter = __nccwpck_require__(6142) + +class FakeWeakRef { + constructor (value) { + this.value = value + } + + deref () { + return this.value + } +} + +class MockAgent extends Dispatcher { + constructor (opts) { + super(opts) + + this[kNetConnect] = true + this[kIsMockActive] = true + + // Instantiate Agent and encapsulate + if ((opts && opts.agent && typeof opts.agent.dispatch !== 'function')) { + throw new InvalidArgumentError('Argument opts.agent must implement Agent') + } + const agent = opts && opts.agent ? opts.agent : new Agent(opts) + this[kAgent] = agent + + this[kClients] = agent[kClients] + this[kOptions] = buildMockOptions(opts) + } + + get (origin) { + let dispatcher = this[kMockAgentGet](origin) + + if (!dispatcher) { + dispatcher = this[kFactory](origin) + this[kMockAgentSet](origin, dispatcher) + } + return dispatcher + } + + dispatch (opts, handler) { + // Call MockAgent.get to perform additional setup before dispatching as normal + this.get(opts.origin) + return this[kAgent].dispatch(opts, handler) + } + + async close () { + await this[kAgent].close() + this[kClients].clear() + } + + deactivate () { + this[kIsMockActive] = false + } + + activate () { + this[kIsMockActive] = true + } + + enableNetConnect (matcher) { + if (typeof matcher === 'string' || typeof matcher === 'function' || matcher instanceof RegExp) { + if (Array.isArray(this[kNetConnect])) { + this[kNetConnect].push(matcher) + } else { + this[kNetConnect] = [matcher] + } + } else if (typeof matcher === 'undefined') { + this[kNetConnect] = true + } else { + throw new InvalidArgumentError('Unsupported matcher. Must be one of String|Function|RegExp.') + } + } + + disableNetConnect () { + this[kNetConnect] = false + } + + // This is required to bypass issues caused by using global symbols - see: + // https://github.com/nodejs/undici/issues/1447 + get isMockActive () { + return this[kIsMockActive] + } + + [kMockAgentSet] (origin, dispatcher) { + this[kClients].set(origin, new FakeWeakRef(dispatcher)) + } + + [kFactory] (origin) { + const mockOptions = Object.assign({ agent: this }, this[kOptions]) + return this[kOptions] && this[kOptions].connections === 1 + ? new MockClient(origin, mockOptions) + : new MockPool(origin, mockOptions) + } + + [kMockAgentGet] (origin) { + // First check if we can immediately find it + const ref = this[kClients].get(origin) + if (ref) { + return ref.deref() + } + + // If the origin is not a string create a dummy parent pool and return to user + if (typeof origin !== 'string') { + const dispatcher = this[kFactory]('http://localhost:9999') + this[kMockAgentSet](origin, dispatcher) + return dispatcher + } + + // If we match, create a pool and assign the same dispatches + for (const [keyMatcher, nonExplicitRef] of Array.from(this[kClients])) { + const nonExplicitDispatcher = nonExplicitRef.deref() + if (nonExplicitDispatcher && typeof keyMatcher !== 'string' && matchValue(keyMatcher, origin)) { + const dispatcher = this[kFactory](origin) + this[kMockAgentSet](origin, dispatcher) + dispatcher[kDispatches] = nonExplicitDispatcher[kDispatches] + return dispatcher + } + } + } + + [kGetNetConnect] () { + return this[kNetConnect] + } + + pendingInterceptors () { + const mockAgentClients = this[kClients] + + return Array.from(mockAgentClients.entries()) + .flatMap(([origin, scope]) => scope.deref()[kDispatches].map(dispatch => ({ ...dispatch, origin }))) + .filter(({ pending }) => pending) + } + + assertNoPendingInterceptors ({ pendingInterceptorsFormatter = new PendingInterceptorsFormatter() } = {}) { + const pending = this.pendingInterceptors() + + if (pending.length === 0) { + return + } + + const pluralizer = new Pluralizer('interceptor', 'interceptors').pluralize(pending.length) + + throw new UndiciError(` +${pluralizer.count} ${pluralizer.noun} ${pluralizer.is} pending: + +${pendingInterceptorsFormatter.format(pending)} +`.trim()) + } +} + +module.exports = MockAgent + + +/***/ }), + +/***/ 7365: +/***/ ((module, __unused_webpack_exports, __nccwpck_require__) => { + + + +const { promisify } = __nccwpck_require__(9023) +const Client = __nccwpck_require__(6197) +const { buildMockDispatch } = __nccwpck_require__(3397) +const { + kDispatches, + kMockAgent, + kClose, + kOriginalClose, + kOrigin, + kOriginalDispatch, + kConnected +} = __nccwpck_require__(1117) +const { MockInterceptor } = __nccwpck_require__(1511) +const Symbols = __nccwpck_require__(6443) +const { InvalidArgumentError } = __nccwpck_require__(8707) + +/** + * MockClient provides an API that extends the Client to influence the mockDispatches. + */ +class MockClient extends Client { + constructor (origin, opts) { + super(origin, opts) + + if (!opts || !opts.agent || typeof opts.agent.dispatch !== 'function') { + throw new InvalidArgumentError('Argument opts.agent must implement Agent') + } + + this[kMockAgent] = opts.agent + this[kOrigin] = origin + this[kDispatches] = [] + this[kConnected] = 1 + this[kOriginalDispatch] = this.dispatch + this[kOriginalClose] = this.close.bind(this) + + this.dispatch = buildMockDispatch.call(this) + this.close = this[kClose] + } + + get [Symbols.kConnected] () { + return this[kConnected] + } + + /** + * Sets up the base interceptor for mocking replies from undici. + */ + intercept (opts) { + return new MockInterceptor(opts, this[kDispatches]) + } + + async [kClose] () { + await promisify(this[kOriginalClose])() + this[kConnected] = 0 + this[kMockAgent][Symbols.kClients].delete(this[kOrigin]) + } +} + +module.exports = MockClient + + +/***/ }), + +/***/ 2429: +/***/ ((module, __unused_webpack_exports, __nccwpck_require__) => { + + + +const { UndiciError } = __nccwpck_require__(8707) + +class MockNotMatchedError extends UndiciError { + constructor (message) { + super(message) + Error.captureStackTrace(this, MockNotMatchedError) + this.name = 'MockNotMatchedError' + this.message = message || 'The request does not match any registered mock dispatches' + this.code = 'UND_MOCK_ERR_MOCK_NOT_MATCHED' + } +} + +module.exports = { + MockNotMatchedError +} + + +/***/ }), + +/***/ 1511: +/***/ ((module, __unused_webpack_exports, __nccwpck_require__) => { + + + +const { getResponseData, buildKey, addMockDispatch } = __nccwpck_require__(3397) +const { + kDispatches, + kDispatchKey, + kDefaultHeaders, + kDefaultTrailers, + kContentLength, + kMockDispatch +} = __nccwpck_require__(1117) +const { InvalidArgumentError } = __nccwpck_require__(8707) +const { buildURL } = __nccwpck_require__(3440) + +/** + * Defines the scope API for an interceptor reply + */ +class MockScope { + constructor (mockDispatch) { + this[kMockDispatch] = mockDispatch + } + + /** + * Delay a reply by a set amount in ms. + */ + delay (waitInMs) { + if (typeof waitInMs !== 'number' || !Number.isInteger(waitInMs) || waitInMs <= 0) { + throw new InvalidArgumentError('waitInMs must be a valid integer > 0') + } + + this[kMockDispatch].delay = waitInMs + return this + } + + /** + * For a defined reply, never mark as consumed. + */ + persist () { + this[kMockDispatch].persist = true + return this + } + + /** + * Allow one to define a reply for a set amount of matching requests. + */ + times (repeatTimes) { + if (typeof repeatTimes !== 'number' || !Number.isInteger(repeatTimes) || repeatTimes <= 0) { + throw new InvalidArgumentError('repeatTimes must be a valid integer > 0') + } + + this[kMockDispatch].times = repeatTimes + return this + } +} + +/** + * Defines an interceptor for a Mock + */ +class MockInterceptor { + constructor (opts, mockDispatches) { + if (typeof opts !== 'object') { + throw new InvalidArgumentError('opts must be an object') + } + if (typeof opts.path === 'undefined') { + throw new InvalidArgumentError('opts.path must be defined') + } + if (typeof opts.method === 'undefined') { + opts.method = 'GET' + } + // See https://github.com/nodejs/undici/issues/1245 + // As per RFC 3986, clients are not supposed to send URI + // fragments to servers when they retrieve a document, + if (typeof opts.path === 'string') { + if (opts.query) { + opts.path = buildURL(opts.path, opts.query) + } else { + // Matches https://github.com/nodejs/undici/blob/main/lib/fetch/index.js#L1811 + const parsedURL = new URL(opts.path, 'data://') + opts.path = parsedURL.pathname + parsedURL.search + } + } + if (typeof opts.method === 'string') { + opts.method = opts.method.toUpperCase() + } + + this[kDispatchKey] = buildKey(opts) + this[kDispatches] = mockDispatches + this[kDefaultHeaders] = {} + this[kDefaultTrailers] = {} + this[kContentLength] = false + } + + createMockScopeDispatchData (statusCode, data, responseOptions = {}) { + const responseData = getResponseData(data) + const contentLength = this[kContentLength] ? { 'content-length': responseData.length } : {} + const headers = { ...this[kDefaultHeaders], ...contentLength, ...responseOptions.headers } + const trailers = { ...this[kDefaultTrailers], ...responseOptions.trailers } + + return { statusCode, data, headers, trailers } + } + + validateReplyParameters (statusCode, data, responseOptions) { + if (typeof statusCode === 'undefined') { + throw new InvalidArgumentError('statusCode must be defined') + } + if (typeof data === 'undefined') { + throw new InvalidArgumentError('data must be defined') + } + if (typeof responseOptions !== 'object') { + throw new InvalidArgumentError('responseOptions must be an object') + } + } + + /** + * Mock an undici request with a defined reply. + */ + reply (replyData) { + // Values of reply aren't available right now as they + // can only be available when the reply callback is invoked. + if (typeof replyData === 'function') { + // We'll first wrap the provided callback in another function, + // this function will properly resolve the data from the callback + // when invoked. + const wrappedDefaultsCallback = (opts) => { + // Our reply options callback contains the parameter for statusCode, data and options. + const resolvedData = replyData(opts) + + // Check if it is in the right format + if (typeof resolvedData !== 'object') { + throw new InvalidArgumentError('reply options callback must return an object') + } + + const { statusCode, data = '', responseOptions = {} } = resolvedData + this.validateReplyParameters(statusCode, data, responseOptions) + // Since the values can be obtained immediately we return them + // from this higher order function that will be resolved later. + return { + ...this.createMockScopeDispatchData(statusCode, data, responseOptions) + } + } + + // Add usual dispatch data, but this time set the data parameter to function that will eventually provide data. + const newMockDispatch = addMockDispatch(this[kDispatches], this[kDispatchKey], wrappedDefaultsCallback) + return new MockScope(newMockDispatch) + } + + // We can have either one or three parameters, if we get here, + // we should have 1-3 parameters. So we spread the arguments of + // this function to obtain the parameters, since replyData will always + // just be the statusCode. + const [statusCode, data = '', responseOptions = {}] = [...arguments] + this.validateReplyParameters(statusCode, data, responseOptions) + + // Send in-already provided data like usual + const dispatchData = this.createMockScopeDispatchData(statusCode, data, responseOptions) + const newMockDispatch = addMockDispatch(this[kDispatches], this[kDispatchKey], dispatchData) + return new MockScope(newMockDispatch) + } + + /** + * Mock an undici request with a defined error. + */ + replyWithError (error) { + if (typeof error === 'undefined') { + throw new InvalidArgumentError('error must be defined') + } + + const newMockDispatch = addMockDispatch(this[kDispatches], this[kDispatchKey], { error }) + return new MockScope(newMockDispatch) + } + + /** + * Set default reply headers on the interceptor for subsequent replies + */ + defaultReplyHeaders (headers) { + if (typeof headers === 'undefined') { + throw new InvalidArgumentError('headers must be defined') + } + + this[kDefaultHeaders] = headers + return this + } + + /** + * Set default reply trailers on the interceptor for subsequent replies + */ + defaultReplyTrailers (trailers) { + if (typeof trailers === 'undefined') { + throw new InvalidArgumentError('trailers must be defined') + } + + this[kDefaultTrailers] = trailers + return this + } + + /** + * Set reply content length header for replies on the interceptor + */ + replyContentLength () { + this[kContentLength] = true + return this + } +} + +module.exports.MockInterceptor = MockInterceptor +module.exports.MockScope = MockScope + + +/***/ }), + +/***/ 4004: +/***/ ((module, __unused_webpack_exports, __nccwpck_require__) => { + + + +const { promisify } = __nccwpck_require__(9023) +const Pool = __nccwpck_require__(5076) +const { buildMockDispatch } = __nccwpck_require__(3397) +const { + kDispatches, + kMockAgent, + kClose, + kOriginalClose, + kOrigin, + kOriginalDispatch, + kConnected +} = __nccwpck_require__(1117) +const { MockInterceptor } = __nccwpck_require__(1511) +const Symbols = __nccwpck_require__(6443) +const { InvalidArgumentError } = __nccwpck_require__(8707) + +/** + * MockPool provides an API that extends the Pool to influence the mockDispatches. + */ +class MockPool extends Pool { + constructor (origin, opts) { + super(origin, opts) + + if (!opts || !opts.agent || typeof opts.agent.dispatch !== 'function') { + throw new InvalidArgumentError('Argument opts.agent must implement Agent') + } + + this[kMockAgent] = opts.agent + this[kOrigin] = origin + this[kDispatches] = [] + this[kConnected] = 1 + this[kOriginalDispatch] = this.dispatch + this[kOriginalClose] = this.close.bind(this) + + this.dispatch = buildMockDispatch.call(this) + this.close = this[kClose] + } + + get [Symbols.kConnected] () { + return this[kConnected] + } + + /** + * Sets up the base interceptor for mocking replies from undici. + */ + intercept (opts) { + return new MockInterceptor(opts, this[kDispatches]) + } + + async [kClose] () { + await promisify(this[kOriginalClose])() + this[kConnected] = 0 + this[kMockAgent][Symbols.kClients].delete(this[kOrigin]) + } +} + +module.exports = MockPool + + +/***/ }), + +/***/ 1117: +/***/ ((module) => { + + + +module.exports = { + kAgent: Symbol('agent'), + kOptions: Symbol('options'), + kFactory: Symbol('factory'), + kDispatches: Symbol('dispatches'), + kDispatchKey: Symbol('dispatch key'), + kDefaultHeaders: Symbol('default headers'), + kDefaultTrailers: Symbol('default trailers'), + kContentLength: Symbol('content length'), + kMockAgent: Symbol('mock agent'), + kMockAgentSet: Symbol('mock agent set'), + kMockAgentGet: Symbol('mock agent get'), + kMockDispatch: Symbol('mock dispatch'), + kClose: Symbol('close'), + kOriginalClose: Symbol('original agent close'), + kOrigin: Symbol('origin'), + kIsMockActive: Symbol('is mock active'), + kNetConnect: Symbol('net connect'), + kGetNetConnect: Symbol('get net connect'), + kConnected: Symbol('connected') +} + + +/***/ }), + +/***/ 3397: +/***/ ((module, __unused_webpack_exports, __nccwpck_require__) => { + + + +const { MockNotMatchedError } = __nccwpck_require__(2429) +const { + kDispatches, + kMockAgent, + kOriginalDispatch, + kOrigin, + kGetNetConnect +} = __nccwpck_require__(1117) +const { buildURL, nop } = __nccwpck_require__(3440) +const { STATUS_CODES } = __nccwpck_require__(8611) +const { + types: { + isPromise + } +} = __nccwpck_require__(9023) + +function matchValue (match, value) { + if (typeof match === 'string') { + return match === value + } + if (match instanceof RegExp) { + return match.test(value) + } + if (typeof match === 'function') { + return match(value) === true + } + return false +} + +function lowerCaseEntries (headers) { + return Object.fromEntries( + Object.entries(headers).map(([headerName, headerValue]) => { + return [headerName.toLocaleLowerCase(), headerValue] + }) + ) +} + +/** + * @param {import('../../index').Headers|string[]|Record} headers + * @param {string} key + */ +function getHeaderByName (headers, key) { + if (Array.isArray(headers)) { + for (let i = 0; i < headers.length; i += 2) { + if (headers[i].toLocaleLowerCase() === key.toLocaleLowerCase()) { + return headers[i + 1] + } + } + + return undefined + } else if (typeof headers.get === 'function') { + return headers.get(key) + } else { + return lowerCaseEntries(headers)[key.toLocaleLowerCase()] + } +} + +/** @param {string[]} headers */ +function buildHeadersFromArray (headers) { // fetch HeadersList + const clone = headers.slice() + const entries = [] + for (let index = 0; index < clone.length; index += 2) { + entries.push([clone[index], clone[index + 1]]) + } + return Object.fromEntries(entries) +} + +function matchHeaders (mockDispatch, headers) { + if (typeof mockDispatch.headers === 'function') { + if (Array.isArray(headers)) { // fetch HeadersList + headers = buildHeadersFromArray(headers) + } + return mockDispatch.headers(headers ? lowerCaseEntries(headers) : {}) + } + if (typeof mockDispatch.headers === 'undefined') { + return true + } + if (typeof headers !== 'object' || typeof mockDispatch.headers !== 'object') { + return false + } + + for (const [matchHeaderName, matchHeaderValue] of Object.entries(mockDispatch.headers)) { + const headerValue = getHeaderByName(headers, matchHeaderName) + + if (!matchValue(matchHeaderValue, headerValue)) { + return false + } + } + return true +} + +function safeUrl (path) { + if (typeof path !== 'string') { + return path + } + + const pathSegments = path.split('?') + + if (pathSegments.length !== 2) { + return path + } + + const qp = new URLSearchParams(pathSegments.pop()) + qp.sort() + return [...pathSegments, qp.toString()].join('?') +} + +function matchKey (mockDispatch, { path, method, body, headers }) { + const pathMatch = matchValue(mockDispatch.path, path) + const methodMatch = matchValue(mockDispatch.method, method) + const bodyMatch = typeof mockDispatch.body !== 'undefined' ? matchValue(mockDispatch.body, body) : true + const headersMatch = matchHeaders(mockDispatch, headers) + return pathMatch && methodMatch && bodyMatch && headersMatch +} + +function getResponseData (data) { + if (Buffer.isBuffer(data)) { + return data + } else if (typeof data === 'object') { + return JSON.stringify(data) + } else { + return data.toString() + } +} + +function getMockDispatch (mockDispatches, key) { + const basePath = key.query ? buildURL(key.path, key.query) : key.path + const resolvedPath = typeof basePath === 'string' ? safeUrl(basePath) : basePath + + // Match path + let matchedMockDispatches = mockDispatches.filter(({ consumed }) => !consumed).filter(({ path }) => matchValue(safeUrl(path), resolvedPath)) + if (matchedMockDispatches.length === 0) { + throw new MockNotMatchedError(`Mock dispatch not matched for path '${resolvedPath}'`) + } + + // Match method + matchedMockDispatches = matchedMockDispatches.filter(({ method }) => matchValue(method, key.method)) + if (matchedMockDispatches.length === 0) { + throw new MockNotMatchedError(`Mock dispatch not matched for method '${key.method}'`) + } + + // Match body + matchedMockDispatches = matchedMockDispatches.filter(({ body }) => typeof body !== 'undefined' ? matchValue(body, key.body) : true) + if (matchedMockDispatches.length === 0) { + throw new MockNotMatchedError(`Mock dispatch not matched for body '${key.body}'`) + } + + // Match headers + matchedMockDispatches = matchedMockDispatches.filter((mockDispatch) => matchHeaders(mockDispatch, key.headers)) + if (matchedMockDispatches.length === 0) { + throw new MockNotMatchedError(`Mock dispatch not matched for headers '${typeof key.headers === 'object' ? JSON.stringify(key.headers) : key.headers}'`) + } + + return matchedMockDispatches[0] +} + +function addMockDispatch (mockDispatches, key, data) { + const baseData = { timesInvoked: 0, times: 1, persist: false, consumed: false } + const replyData = typeof data === 'function' ? { callback: data } : { ...data } + const newMockDispatch = { ...baseData, ...key, pending: true, data: { error: null, ...replyData } } + mockDispatches.push(newMockDispatch) + return newMockDispatch +} + +function deleteMockDispatch (mockDispatches, key) { + const index = mockDispatches.findIndex(dispatch => { + if (!dispatch.consumed) { + return false + } + return matchKey(dispatch, key) + }) + if (index !== -1) { + mockDispatches.splice(index, 1) + } +} + +function buildKey (opts) { + const { path, method, body, headers, query } = opts + return { + path, + method, + body, + headers, + query + } +} + +function generateKeyValues (data) { + return Object.entries(data).reduce((keyValuePairs, [key, value]) => [ + ...keyValuePairs, + Buffer.from(`${key}`), + Array.isArray(value) ? value.map(x => Buffer.from(`${x}`)) : Buffer.from(`${value}`) + ], []) +} + +/** + * @see https://developer.mozilla.org/en-US/docs/Web/HTTP/Status + * @param {number} statusCode + */ +function getStatusText (statusCode) { + return STATUS_CODES[statusCode] || 'unknown' +} + +async function getResponse (body) { + const buffers = [] + for await (const data of body) { + buffers.push(data) + } + return Buffer.concat(buffers).toString('utf8') +} + +/** + * Mock dispatch function used to simulate undici dispatches + */ +function mockDispatch (opts, handler) { + // Get mock dispatch from built key + const key = buildKey(opts) + const mockDispatch = getMockDispatch(this[kDispatches], key) + + mockDispatch.timesInvoked++ + + // Here's where we resolve a callback if a callback is present for the dispatch data. + if (mockDispatch.data.callback) { + mockDispatch.data = { ...mockDispatch.data, ...mockDispatch.data.callback(opts) } + } + + // Parse mockDispatch data + const { data: { statusCode, data, headers, trailers, error }, delay, persist } = mockDispatch + const { timesInvoked, times } = mockDispatch + + // If it's used up and not persistent, mark as consumed + mockDispatch.consumed = !persist && timesInvoked >= times + mockDispatch.pending = timesInvoked < times + + // If specified, trigger dispatch error + if (error !== null) { + deleteMockDispatch(this[kDispatches], key) + handler.onError(error) + return true + } + + // Handle the request with a delay if necessary + if (typeof delay === 'number' && delay > 0) { + setTimeout(() => { + handleReply(this[kDispatches]) + }, delay) + } else { + handleReply(this[kDispatches]) + } + + function handleReply (mockDispatches, _data = data) { + // fetch's HeadersList is a 1D string array + const optsHeaders = Array.isArray(opts.headers) + ? buildHeadersFromArray(opts.headers) + : opts.headers + const body = typeof _data === 'function' + ? _data({ ...opts, headers: optsHeaders }) + : _data + + // util.types.isPromise is likely needed for jest. + if (isPromise(body)) { + // If handleReply is asynchronous, throwing an error + // in the callback will reject the promise, rather than + // synchronously throw the error, which breaks some tests. + // Rather, we wait for the callback to resolve if it is a + // promise, and then re-run handleReply with the new body. + body.then((newData) => handleReply(mockDispatches, newData)) + return + } + + const responseData = getResponseData(body) + const responseHeaders = generateKeyValues(headers) + const responseTrailers = generateKeyValues(trailers) + + handler.abort = nop + handler.onHeaders(statusCode, responseHeaders, resume, getStatusText(statusCode)) + handler.onData(Buffer.from(responseData)) + handler.onComplete(responseTrailers) + deleteMockDispatch(mockDispatches, key) + } + + function resume () {} + + return true +} + +function buildMockDispatch () { + const agent = this[kMockAgent] + const origin = this[kOrigin] + const originalDispatch = this[kOriginalDispatch] + + return function dispatch (opts, handler) { + if (agent.isMockActive) { + try { + mockDispatch.call(this, opts, handler) + } catch (error) { + if (error instanceof MockNotMatchedError) { + const netConnect = agent[kGetNetConnect]() + if (netConnect === false) { + throw new MockNotMatchedError(`${error.message}: subsequent request to origin ${origin} was not allowed (net.connect disabled)`) + } + if (checkNetConnect(netConnect, origin)) { + originalDispatch.call(this, opts, handler) + } else { + throw new MockNotMatchedError(`${error.message}: subsequent request to origin ${origin} was not allowed (net.connect is not enabled for this origin)`) + } + } else { + throw error + } + } + } else { + originalDispatch.call(this, opts, handler) + } + } +} + +function checkNetConnect (netConnect, origin) { + const url = new URL(origin) + if (netConnect === true) { + return true + } else if (Array.isArray(netConnect) && netConnect.some((matcher) => matchValue(matcher, url.host))) { + return true + } + return false +} + +function buildMockOptions (opts) { + if (opts) { + const { agent, ...mockOptions } = opts + return mockOptions + } +} + +module.exports = { + getResponseData, + getMockDispatch, + addMockDispatch, + deleteMockDispatch, + buildKey, + generateKeyValues, + matchValue, + getResponse, + getStatusText, + mockDispatch, + buildMockDispatch, + checkNetConnect, + buildMockOptions, + getHeaderByName +} + + +/***/ }), + +/***/ 6142: +/***/ ((module, __unused_webpack_exports, __nccwpck_require__) => { + + + +const { Transform } = __nccwpck_require__(2203) +const { Console } = __nccwpck_require__(4236) + +/** + * Gets the output of `console.table(…)` as a string. + */ +module.exports = class PendingInterceptorsFormatter { + constructor ({ disableColors } = {}) { + this.transform = new Transform({ + transform (chunk, _enc, cb) { + cb(null, chunk) + } + }) + + this.logger = new Console({ + stdout: this.transform, + inspectOptions: { + colors: !disableColors && !process.env.CI + } + }) + } + + format (pendingInterceptors) { + const withPrettyHeaders = pendingInterceptors.map( + ({ method, path, data: { statusCode }, persist, times, timesInvoked, origin }) => ({ + Method: method, + Origin: origin, + Path: path, + 'Status code': statusCode, + Persistent: persist ? '✅' : '❌', + Invocations: timesInvoked, + Remaining: persist ? Infinity : times - timesInvoked + })) + + this.logger.table(withPrettyHeaders) + return this.transform.read().toString() + } +} + + +/***/ }), + +/***/ 1529: +/***/ ((module) => { + + + +const singulars = { + pronoun: 'it', + is: 'is', + was: 'was', + this: 'this' +} + +const plurals = { + pronoun: 'they', + is: 'are', + was: 'were', + this: 'these' +} + +module.exports = class Pluralizer { + constructor (singular, plural) { + this.singular = singular + this.plural = plural + } + + pluralize (count) { + const one = count === 1 + const keys = one ? singulars : plurals + const noun = one ? this.singular : this.plural + return { ...keys, count, noun } + } +} + + +/***/ }), + +/***/ 4869: +/***/ ((module) => { + +/* eslint-disable */ + + + +// Extracted from node/lib/internal/fixed_queue.js + +// Currently optimal queue size, tested on V8 6.0 - 6.6. Must be power of two. +const kSize = 2048; +const kMask = kSize - 1; + +// The FixedQueue is implemented as a singly-linked list of fixed-size +// circular buffers. It looks something like this: +// +// head tail +// | | +// v v +// +-----------+ <-----\ +-----------+ <------\ +-----------+ +// | [null] | \----- | next | \------- | next | +// +-----------+ +-----------+ +-----------+ +// | item | <-- bottom | item | <-- bottom | [empty] | +// | item | | item | | [empty] | +// | item | | item | | [empty] | +// | item | | item | | [empty] | +// | item | | item | bottom --> | item | +// | item | | item | | item | +// | ... | | ... | | ... | +// | item | | item | | item | +// | item | | item | | item | +// | [empty] | <-- top | item | | item | +// | [empty] | | item | | item | +// | [empty] | | [empty] | <-- top top --> | [empty] | +// +-----------+ +-----------+ +-----------+ +// +// Or, if there is only one circular buffer, it looks something +// like either of these: +// +// head tail head tail +// | | | | +// v v v v +// +-----------+ +-----------+ +// | [null] | | [null] | +// +-----------+ +-----------+ +// | [empty] | | item | +// | [empty] | | item | +// | item | <-- bottom top --> | [empty] | +// | item | | [empty] | +// | [empty] | <-- top bottom --> | item | +// | [empty] | | item | +// +-----------+ +-----------+ +// +// Adding a value means moving `top` forward by one, removing means +// moving `bottom` forward by one. After reaching the end, the queue +// wraps around. +// +// When `top === bottom` the current queue is empty and when +// `top + 1 === bottom` it's full. This wastes a single space of storage +// but allows much quicker checks. + +class FixedCircularBuffer { + constructor() { + this.bottom = 0; + this.top = 0; + this.list = new Array(kSize); + this.next = null; + } + + isEmpty() { + return this.top === this.bottom; + } + + isFull() { + return ((this.top + 1) & kMask) === this.bottom; + } + + push(data) { + this.list[this.top] = data; + this.top = (this.top + 1) & kMask; + } + + shift() { + const nextItem = this.list[this.bottom]; + if (nextItem === undefined) + return null; + this.list[this.bottom] = undefined; + this.bottom = (this.bottom + 1) & kMask; + return nextItem; + } +} + +module.exports = class FixedQueue { + constructor() { + this.head = this.tail = new FixedCircularBuffer(); + } + + isEmpty() { + return this.head.isEmpty(); + } + + push(data) { + if (this.head.isFull()) { + // Head is full: Creates a new queue, sets the old queue's `.next` to it, + // and sets it as the new main queue. + this.head = this.head.next = new FixedCircularBuffer(); + } + this.head.push(data); + } + + shift() { + const tail = this.tail; + const next = tail.shift(); + if (tail.isEmpty() && tail.next !== null) { + // If there is another queue, it forms the new tail. + this.tail = tail.next; + } + return next; + } +}; + + +/***/ }), + +/***/ 8640: +/***/ ((module, __unused_webpack_exports, __nccwpck_require__) => { + + + +const DispatcherBase = __nccwpck_require__(1) +const FixedQueue = __nccwpck_require__(4869) +const { kConnected, kSize, kRunning, kPending, kQueued, kBusy, kFree, kUrl, kClose, kDestroy, kDispatch } = __nccwpck_require__(6443) +const PoolStats = __nccwpck_require__(4622) + +const kClients = Symbol('clients') +const kNeedDrain = Symbol('needDrain') +const kQueue = Symbol('queue') +const kClosedResolve = Symbol('closed resolve') +const kOnDrain = Symbol('onDrain') +const kOnConnect = Symbol('onConnect') +const kOnDisconnect = Symbol('onDisconnect') +const kOnConnectionError = Symbol('onConnectionError') +const kGetDispatcher = Symbol('get dispatcher') +const kAddClient = Symbol('add client') +const kRemoveClient = Symbol('remove client') +const kStats = Symbol('stats') + +class PoolBase extends DispatcherBase { + constructor () { + super() + + this[kQueue] = new FixedQueue() + this[kClients] = [] + this[kQueued] = 0 + + const pool = this + + this[kOnDrain] = function onDrain (origin, targets) { + const queue = pool[kQueue] + + let needDrain = false + + while (!needDrain) { + const item = queue.shift() + if (!item) { + break + } + pool[kQueued]-- + needDrain = !this.dispatch(item.opts, item.handler) + } + + this[kNeedDrain] = needDrain + + if (!this[kNeedDrain] && pool[kNeedDrain]) { + pool[kNeedDrain] = false + pool.emit('drain', origin, [pool, ...targets]) + } + + if (pool[kClosedResolve] && queue.isEmpty()) { + Promise + .all(pool[kClients].map(c => c.close())) + .then(pool[kClosedResolve]) + } + } + + this[kOnConnect] = (origin, targets) => { + pool.emit('connect', origin, [pool, ...targets]) + } + + this[kOnDisconnect] = (origin, targets, err) => { + pool.emit('disconnect', origin, [pool, ...targets], err) + } + + this[kOnConnectionError] = (origin, targets, err) => { + pool.emit('connectionError', origin, [pool, ...targets], err) + } + + this[kStats] = new PoolStats(this) + } + + get [kBusy] () { + return this[kNeedDrain] + } + + get [kConnected] () { + return this[kClients].filter(client => client[kConnected]).length + } + + get [kFree] () { + return this[kClients].filter(client => client[kConnected] && !client[kNeedDrain]).length + } + + get [kPending] () { + let ret = this[kQueued] + for (const { [kPending]: pending } of this[kClients]) { + ret += pending + } + return ret + } + + get [kRunning] () { + let ret = 0 + for (const { [kRunning]: running } of this[kClients]) { + ret += running + } + return ret + } + + get [kSize] () { + let ret = this[kQueued] + for (const { [kSize]: size } of this[kClients]) { + ret += size + } + return ret + } + + get stats () { + return this[kStats] + } + + async [kClose] () { + if (this[kQueue].isEmpty()) { + return Promise.all(this[kClients].map(c => c.close())) + } else { + return new Promise((resolve) => { + this[kClosedResolve] = resolve + }) + } + } + + async [kDestroy] (err) { + while (true) { + const item = this[kQueue].shift() + if (!item) { + break + } + item.handler.onError(err) + } + + return Promise.all(this[kClients].map(c => c.destroy(err))) + } + + [kDispatch] (opts, handler) { + const dispatcher = this[kGetDispatcher]() + + if (!dispatcher) { + this[kNeedDrain] = true + this[kQueue].push({ opts, handler }) + this[kQueued]++ + } else if (!dispatcher.dispatch(opts, handler)) { + dispatcher[kNeedDrain] = true + this[kNeedDrain] = !this[kGetDispatcher]() + } + + return !this[kNeedDrain] + } + + [kAddClient] (client) { + client + .on('drain', this[kOnDrain]) + .on('connect', this[kOnConnect]) + .on('disconnect', this[kOnDisconnect]) + .on('connectionError', this[kOnConnectionError]) + + this[kClients].push(client) + + if (this[kNeedDrain]) { + process.nextTick(() => { + if (this[kNeedDrain]) { + this[kOnDrain](client[kUrl], [this, client]) + } + }) + } + + return this + } + + [kRemoveClient] (client) { + client.close(() => { + const idx = this[kClients].indexOf(client) + if (idx !== -1) { + this[kClients].splice(idx, 1) + } + }) + + this[kNeedDrain] = this[kClients].some(dispatcher => ( + !dispatcher[kNeedDrain] && + dispatcher.closed !== true && + dispatcher.destroyed !== true + )) + } +} + +module.exports = { + PoolBase, + kClients, + kNeedDrain, + kAddClient, + kRemoveClient, + kGetDispatcher +} + + +/***/ }), + +/***/ 4622: +/***/ ((module, __unused_webpack_exports, __nccwpck_require__) => { + +const { kFree, kConnected, kPending, kQueued, kRunning, kSize } = __nccwpck_require__(6443) +const kPool = Symbol('pool') + +class PoolStats { + constructor (pool) { + this[kPool] = pool + } + + get connected () { + return this[kPool][kConnected] + } + + get free () { + return this[kPool][kFree] + } + + get pending () { + return this[kPool][kPending] + } + + get queued () { + return this[kPool][kQueued] + } + + get running () { + return this[kPool][kRunning] + } + + get size () { + return this[kPool][kSize] + } +} + +module.exports = PoolStats + + +/***/ }), + +/***/ 5076: +/***/ ((module, __unused_webpack_exports, __nccwpck_require__) => { + + + +const { + PoolBase, + kClients, + kNeedDrain, + kAddClient, + kGetDispatcher +} = __nccwpck_require__(8640) +const Client = __nccwpck_require__(6197) +const { + InvalidArgumentError +} = __nccwpck_require__(8707) +const util = __nccwpck_require__(3440) +const { kUrl, kInterceptors } = __nccwpck_require__(6443) +const buildConnector = __nccwpck_require__(9136) + +const kOptions = Symbol('options') +const kConnections = Symbol('connections') +const kFactory = Symbol('factory') + +function defaultFactory (origin, opts) { + return new Client(origin, opts) +} + +class Pool extends PoolBase { + constructor (origin, { + connections, + factory = defaultFactory, + connect, + connectTimeout, + tls, + maxCachedSessions, + socketPath, + autoSelectFamily, + autoSelectFamilyAttemptTimeout, + allowH2, + ...options + } = {}) { + super() + + if (connections != null && (!Number.isFinite(connections) || connections < 0)) { + throw new InvalidArgumentError('invalid connections') + } + + if (typeof factory !== 'function') { + throw new InvalidArgumentError('factory must be a function.') + } + + if (connect != null && typeof connect !== 'function' && typeof connect !== 'object') { + throw new InvalidArgumentError('connect must be a function or an object') + } + + if (typeof connect !== 'function') { + connect = buildConnector({ + ...tls, + maxCachedSessions, + allowH2, + socketPath, + timeout: connectTimeout, + ...(util.nodeHasAutoSelectFamily && autoSelectFamily ? { autoSelectFamily, autoSelectFamilyAttemptTimeout } : undefined), + ...connect + }) + } + + this[kInterceptors] = options.interceptors && options.interceptors.Pool && Array.isArray(options.interceptors.Pool) + ? options.interceptors.Pool + : [] + this[kConnections] = connections || null + this[kUrl] = util.parseOrigin(origin) + this[kOptions] = { ...util.deepClone(options), connect, allowH2 } + this[kOptions].interceptors = options.interceptors + ? { ...options.interceptors } + : undefined + this[kFactory] = factory + } + + [kGetDispatcher] () { + let dispatcher = this[kClients].find(dispatcher => !dispatcher[kNeedDrain]) + + if (dispatcher) { + return dispatcher + } + + if (!this[kConnections] || this[kClients].length < this[kConnections]) { + dispatcher = this[kFactory](this[kUrl], this[kOptions]) + this[kAddClient](dispatcher) + } + + return dispatcher + } +} + +module.exports = Pool + + +/***/ }), + +/***/ 2720: +/***/ ((module, __unused_webpack_exports, __nccwpck_require__) => { + + + +const { kProxy, kClose, kDestroy, kInterceptors } = __nccwpck_require__(6443) +const { URL } = __nccwpck_require__(7016) +const Agent = __nccwpck_require__(9965) +const Pool = __nccwpck_require__(5076) +const DispatcherBase = __nccwpck_require__(1) +const { InvalidArgumentError, RequestAbortedError } = __nccwpck_require__(8707) +const buildConnector = __nccwpck_require__(9136) + +const kAgent = Symbol('proxy agent') +const kClient = Symbol('proxy client') +const kProxyHeaders = Symbol('proxy headers') +const kRequestTls = Symbol('request tls settings') +const kProxyTls = Symbol('proxy tls settings') +const kConnectEndpoint = Symbol('connect endpoint function') + +function defaultProtocolPort (protocol) { + return protocol === 'https:' ? 443 : 80 +} + +function buildProxyOptions (opts) { + if (typeof opts === 'string') { + opts = { uri: opts } + } + + if (!opts || !opts.uri) { + throw new InvalidArgumentError('Proxy opts.uri is mandatory') + } + + return { + uri: opts.uri, + protocol: opts.protocol || 'https' + } +} + +function defaultFactory (origin, opts) { + return new Pool(origin, opts) +} + +class ProxyAgent extends DispatcherBase { + constructor (opts) { + super(opts) + this[kProxy] = buildProxyOptions(opts) + this[kAgent] = new Agent(opts) + this[kInterceptors] = opts.interceptors && opts.interceptors.ProxyAgent && Array.isArray(opts.interceptors.ProxyAgent) + ? opts.interceptors.ProxyAgent + : [] + + if (typeof opts === 'string') { + opts = { uri: opts } + } + + if (!opts || !opts.uri) { + throw new InvalidArgumentError('Proxy opts.uri is mandatory') + } + + const { clientFactory = defaultFactory } = opts + + if (typeof clientFactory !== 'function') { + throw new InvalidArgumentError('Proxy opts.clientFactory must be a function.') + } + + this[kRequestTls] = opts.requestTls + this[kProxyTls] = opts.proxyTls + this[kProxyHeaders] = opts.headers || {} + + const resolvedUrl = new URL(opts.uri) + const { origin, port, host, username, password } = resolvedUrl + + if (opts.auth && opts.token) { + throw new InvalidArgumentError('opts.auth cannot be used in combination with opts.token') + } else if (opts.auth) { + /* @deprecated in favour of opts.token */ + this[kProxyHeaders]['proxy-authorization'] = `Basic ${opts.auth}` + } else if (opts.token) { + this[kProxyHeaders]['proxy-authorization'] = opts.token + } else if (username && password) { + this[kProxyHeaders]['proxy-authorization'] = `Basic ${Buffer.from(`${decodeURIComponent(username)}:${decodeURIComponent(password)}`).toString('base64')}` + } + + const connect = buildConnector({ ...opts.proxyTls }) + this[kConnectEndpoint] = buildConnector({ ...opts.requestTls }) + this[kClient] = clientFactory(resolvedUrl, { connect }) + this[kAgent] = new Agent({ + ...opts, + connect: async (opts, callback) => { + let requestedHost = opts.host + if (!opts.port) { + requestedHost += `:${defaultProtocolPort(opts.protocol)}` + } + try { + const { socket, statusCode } = await this[kClient].connect({ + origin, + port, + path: requestedHost, + signal: opts.signal, + headers: { + ...this[kProxyHeaders], + host + } + }) + if (statusCode !== 200) { + socket.on('error', () => {}).destroy() + callback(new RequestAbortedError(`Proxy response (${statusCode}) !== 200 when HTTP Tunneling`)) + } + if (opts.protocol !== 'https:') { + callback(null, socket) + return + } + let servername + if (this[kRequestTls]) { + servername = this[kRequestTls].servername + } else { + servername = opts.servername + } + this[kConnectEndpoint]({ ...opts, servername, httpSocket: socket }, callback) + } catch (err) { + callback(err) + } + } + }) + } + + dispatch (opts, handler) { + const { host } = new URL(opts.origin) + const headers = buildHeaders(opts.headers) + throwIfProxyAuthIsSent(headers) + return this[kAgent].dispatch( + { + ...opts, + headers: { + ...headers, + host + } + }, + handler + ) + } + + async [kClose] () { + await this[kAgent].close() + await this[kClient].close() + } + + async [kDestroy] () { + await this[kAgent].destroy() + await this[kClient].destroy() + } +} + +/** + * @param {string[] | Record} headers + * @returns {Record} + */ +function buildHeaders (headers) { + // When using undici.fetch, the headers list is stored + // as an array. + if (Array.isArray(headers)) { + /** @type {Record} */ + const headersPair = {} + + for (let i = 0; i < headers.length; i += 2) { + headersPair[headers[i]] = headers[i + 1] + } + + return headersPair + } + + return headers +} + +/** + * @param {Record} headers + * + * Previous versions of ProxyAgent suggests the Proxy-Authorization in request headers + * Nevertheless, it was changed and to avoid a security vulnerability by end users + * this check was created. + * It should be removed in the next major version for performance reasons + */ +function throwIfProxyAuthIsSent (headers) { + const existProxyAuth = headers && Object.keys(headers) + .find((key) => key.toLowerCase() === 'proxy-authorization') + if (existProxyAuth) { + throw new InvalidArgumentError('Proxy-Authorization should be sent in ProxyAgent constructor') + } +} + +module.exports = ProxyAgent + + +/***/ }), + +/***/ 8804: +/***/ ((module) => { + + + +let fastNow = Date.now() +let fastNowTimeout + +const fastTimers = [] + +function onTimeout () { + fastNow = Date.now() + + let len = fastTimers.length + let idx = 0 + while (idx < len) { + const timer = fastTimers[idx] + + if (timer.state === 0) { + timer.state = fastNow + timer.delay + } else if (timer.state > 0 && fastNow >= timer.state) { + timer.state = -1 + timer.callback(timer.opaque) + } + + if (timer.state === -1) { + timer.state = -2 + if (idx !== len - 1) { + fastTimers[idx] = fastTimers.pop() + } else { + fastTimers.pop() + } + len -= 1 + } else { + idx += 1 + } + } + + if (fastTimers.length > 0) { + refreshTimeout() + } +} + +function refreshTimeout () { + if (fastNowTimeout && fastNowTimeout.refresh) { + fastNowTimeout.refresh() + } else { + clearTimeout(fastNowTimeout) + fastNowTimeout = setTimeout(onTimeout, 1e3) + if (fastNowTimeout.unref) { + fastNowTimeout.unref() + } + } +} + +class Timeout { + constructor (callback, delay, opaque) { + this.callback = callback + this.delay = delay + this.opaque = opaque + + // -2 not in timer list + // -1 in timer list but inactive + // 0 in timer list waiting for time + // > 0 in timer list waiting for time to expire + this.state = -2 + + this.refresh() + } + + refresh () { + if (this.state === -2) { + fastTimers.push(this) + if (!fastNowTimeout || fastTimers.length === 1) { + refreshTimeout() + } + } + + this.state = 0 + } + + clear () { + this.state = -1 + } +} + +module.exports = { + setTimeout (callback, delay, opaque) { + return delay < 1e3 + ? setTimeout(callback, delay, opaque) + : new Timeout(callback, delay, opaque) + }, + clearTimeout (timeout) { + if (timeout instanceof Timeout) { + timeout.clear() + } else { + clearTimeout(timeout) + } + } +} + + +/***/ }), + +/***/ 8550: +/***/ ((module, __unused_webpack_exports, __nccwpck_require__) => { + + + +const diagnosticsChannel = __nccwpck_require__(1637) +const { uid, states } = __nccwpck_require__(5913) +const { + kReadyState, + kSentClose, + kByteParser, + kReceivedClose +} = __nccwpck_require__(2933) +const { fireEvent, failWebsocketConnection } = __nccwpck_require__(3574) +const { CloseEvent } = __nccwpck_require__(6255) +const { makeRequest } = __nccwpck_require__(5194) +const { fetching } = __nccwpck_require__(2315) +const { Headers } = __nccwpck_require__(6349) +const { getGlobalDispatcher } = __nccwpck_require__(2581) +const { kHeadersList } = __nccwpck_require__(6443) + +const channels = {} +channels.open = diagnosticsChannel.channel('undici:websocket:open') +channels.close = diagnosticsChannel.channel('undici:websocket:close') +channels.socketError = diagnosticsChannel.channel('undici:websocket:socket_error') + +/** @type {import('crypto')} */ +let crypto +try { + crypto = __nccwpck_require__(6982) +} catch { + +} + +/** + * @see https://websockets.spec.whatwg.org/#concept-websocket-establish + * @param {URL} url + * @param {string|string[]} protocols + * @param {import('./websocket').WebSocket} ws + * @param {(response: any) => void} onEstablish + * @param {Partial} options + */ +function establishWebSocketConnection (url, protocols, ws, onEstablish, options) { + // 1. Let requestURL be a copy of url, with its scheme set to "http", if url’s + // scheme is "ws", and to "https" otherwise. + const requestURL = url + + requestURL.protocol = url.protocol === 'ws:' ? 'http:' : 'https:' + + // 2. Let request be a new request, whose URL is requestURL, client is client, + // service-workers mode is "none", referrer is "no-referrer", mode is + // "websocket", credentials mode is "include", cache mode is "no-store" , + // and redirect mode is "error". + const request = makeRequest({ + urlList: [requestURL], + serviceWorkers: 'none', + referrer: 'no-referrer', + mode: 'websocket', + credentials: 'include', + cache: 'no-store', + redirect: 'error' + }) + + // Note: undici extension, allow setting custom headers. + if (options.headers) { + const headersList = new Headers(options.headers)[kHeadersList] + + request.headersList = headersList + } + + // 3. Append (`Upgrade`, `websocket`) to request’s header list. + // 4. Append (`Connection`, `Upgrade`) to request’s header list. + // Note: both of these are handled by undici currently. + // https://github.com/nodejs/undici/blob/68c269c4144c446f3f1220951338daef4a6b5ec4/lib/client.js#L1397 + + // 5. Let keyValue be a nonce consisting of a randomly selected + // 16-byte value that has been forgiving-base64-encoded and + // isomorphic encoded. + const keyValue = crypto.randomBytes(16).toString('base64') + + // 6. Append (`Sec-WebSocket-Key`, keyValue) to request’s + // header list. + request.headersList.append('sec-websocket-key', keyValue) + + // 7. Append (`Sec-WebSocket-Version`, `13`) to request’s + // header list. + request.headersList.append('sec-websocket-version', '13') + + // 8. For each protocol in protocols, combine + // (`Sec-WebSocket-Protocol`, protocol) in request’s header + // list. + for (const protocol of protocols) { + request.headersList.append('sec-websocket-protocol', protocol) + } + + // 9. Let permessageDeflate be a user-agent defined + // "permessage-deflate" extension header value. + // https://github.com/mozilla/gecko-dev/blob/ce78234f5e653a5d3916813ff990f053510227bc/netwerk/protocol/websocket/WebSocketChannel.cpp#L2673 + // TODO: enable once permessage-deflate is supported + const permessageDeflate = '' // 'permessage-deflate; 15' + + // 10. Append (`Sec-WebSocket-Extensions`, permessageDeflate) to + // request’s header list. + // request.headersList.append('sec-websocket-extensions', permessageDeflate) + + // 11. Fetch request with useParallelQueue set to true, and + // processResponse given response being these steps: + const controller = fetching({ + request, + useParallelQueue: true, + dispatcher: options.dispatcher ?? getGlobalDispatcher(), + processResponse (response) { + // 1. If response is a network error or its status is not 101, + // fail the WebSocket connection. + if (response.type === 'error' || response.status !== 101) { + failWebsocketConnection(ws, 'Received network error or non-101 status code.') + return + } + + // 2. If protocols is not the empty list and extracting header + // list values given `Sec-WebSocket-Protocol` and response’s + // header list results in null, failure, or the empty byte + // sequence, then fail the WebSocket connection. + if (protocols.length !== 0 && !response.headersList.get('Sec-WebSocket-Protocol')) { + failWebsocketConnection(ws, 'Server did not respond with sent protocols.') + return + } + + // 3. Follow the requirements stated step 2 to step 6, inclusive, + // of the last set of steps in section 4.1 of The WebSocket + // Protocol to validate response. This either results in fail + // the WebSocket connection or the WebSocket connection is + // established. + + // 2. If the response lacks an |Upgrade| header field or the |Upgrade| + // header field contains a value that is not an ASCII case- + // insensitive match for the value "websocket", the client MUST + // _Fail the WebSocket Connection_. + if (response.headersList.get('Upgrade')?.toLowerCase() !== 'websocket') { + failWebsocketConnection(ws, 'Server did not set Upgrade header to "websocket".') + return + } + + // 3. If the response lacks a |Connection| header field or the + // |Connection| header field doesn't contain a token that is an + // ASCII case-insensitive match for the value "Upgrade", the client + // MUST _Fail the WebSocket Connection_. + if (response.headersList.get('Connection')?.toLowerCase() !== 'upgrade') { + failWebsocketConnection(ws, 'Server did not set Connection header to "upgrade".') + return + } + + // 4. If the response lacks a |Sec-WebSocket-Accept| header field or + // the |Sec-WebSocket-Accept| contains a value other than the + // base64-encoded SHA-1 of the concatenation of the |Sec-WebSocket- + // Key| (as a string, not base64-decoded) with the string "258EAFA5- + // E914-47DA-95CA-C5AB0DC85B11" but ignoring any leading and + // trailing whitespace, the client MUST _Fail the WebSocket + // Connection_. + const secWSAccept = response.headersList.get('Sec-WebSocket-Accept') + const digest = crypto.createHash('sha1').update(keyValue + uid).digest('base64') + if (secWSAccept !== digest) { + failWebsocketConnection(ws, 'Incorrect hash received in Sec-WebSocket-Accept header.') + return + } + + // 5. If the response includes a |Sec-WebSocket-Extensions| header + // field and this header field indicates the use of an extension + // that was not present in the client's handshake (the server has + // indicated an extension not requested by the client), the client + // MUST _Fail the WebSocket Connection_. (The parsing of this + // header field to determine which extensions are requested is + // discussed in Section 9.1.) + const secExtension = response.headersList.get('Sec-WebSocket-Extensions') + + if (secExtension !== null && secExtension !== permessageDeflate) { + failWebsocketConnection(ws, 'Received different permessage-deflate than the one set.') + return + } + + // 6. If the response includes a |Sec-WebSocket-Protocol| header field + // and this header field indicates the use of a subprotocol that was + // not present in the client's handshake (the server has indicated a + // subprotocol not requested by the client), the client MUST _Fail + // the WebSocket Connection_. + const secProtocol = response.headersList.get('Sec-WebSocket-Protocol') + + if (secProtocol !== null && secProtocol !== request.headersList.get('Sec-WebSocket-Protocol')) { + failWebsocketConnection(ws, 'Protocol was not set in the opening handshake.') + return + } + + response.socket.on('data', onSocketData) + response.socket.on('close', onSocketClose) + response.socket.on('error', onSocketError) + + if (channels.open.hasSubscribers) { + channels.open.publish({ + address: response.socket.address(), + protocol: secProtocol, + extensions: secExtension + }) + } + + onEstablish(response) + } + }) + + return controller +} + +/** + * @param {Buffer} chunk + */ +function onSocketData (chunk) { + if (!this.ws[kByteParser].write(chunk)) { + this.pause() + } +} + +/** + * @see https://websockets.spec.whatwg.org/#feedback-from-the-protocol + * @see https://datatracker.ietf.org/doc/html/rfc6455#section-7.1.4 + */ +function onSocketClose () { + const { ws } = this + + // If the TCP connection was closed after the + // WebSocket closing handshake was completed, the WebSocket connection + // is said to have been closed _cleanly_. + const wasClean = ws[kSentClose] && ws[kReceivedClose] + + let code = 1005 + let reason = '' + + const result = ws[kByteParser].closingInfo + + if (result) { + code = result.code ?? 1005 + reason = result.reason + } else if (!ws[kSentClose]) { + // If _The WebSocket + // Connection is Closed_ and no Close control frame was received by the + // endpoint (such as could occur if the underlying transport connection + // is lost), _The WebSocket Connection Close Code_ is considered to be + // 1006. + code = 1006 + } + + // 1. Change the ready state to CLOSED (3). + ws[kReadyState] = states.CLOSED + + // 2. If the user agent was required to fail the WebSocket + // connection, or if the WebSocket connection was closed + // after being flagged as full, fire an event named error + // at the WebSocket object. + // TODO + + // 3. Fire an event named close at the WebSocket object, + // using CloseEvent, with the wasClean attribute + // initialized to true if the connection closed cleanly + // and false otherwise, the code attribute initialized to + // the WebSocket connection close code, and the reason + // attribute initialized to the result of applying UTF-8 + // decode without BOM to the WebSocket connection close + // reason. + fireEvent('close', ws, CloseEvent, { + wasClean, code, reason + }) + + if (channels.close.hasSubscribers) { + channels.close.publish({ + websocket: ws, + code, + reason + }) + } +} + +function onSocketError (error) { + const { ws } = this + + ws[kReadyState] = states.CLOSING + + if (channels.socketError.hasSubscribers) { + channels.socketError.publish(error) + } + + this.destroy() +} + +module.exports = { + establishWebSocketConnection +} + + +/***/ }), + +/***/ 5913: +/***/ ((module) => { + + + +// This is a Globally Unique Identifier unique used +// to validate that the endpoint accepts websocket +// connections. +// See https://www.rfc-editor.org/rfc/rfc6455.html#section-1.3 +const uid = '258EAFA5-E914-47DA-95CA-C5AB0DC85B11' + +/** @type {PropertyDescriptor} */ +const staticPropertyDescriptors = { + enumerable: true, + writable: false, + configurable: false +} + +const states = { + CONNECTING: 0, + OPEN: 1, + CLOSING: 2, + CLOSED: 3 +} + +const opcodes = { + CONTINUATION: 0x0, + TEXT: 0x1, + BINARY: 0x2, + CLOSE: 0x8, + PING: 0x9, + PONG: 0xA +} + +const maxUnsigned16Bit = 2 ** 16 - 1 // 65535 + +const parserStates = { + INFO: 0, + PAYLOADLENGTH_16: 2, + PAYLOADLENGTH_64: 3, + READ_DATA: 4 +} + +const emptyBuffer = Buffer.allocUnsafe(0) + +module.exports = { + uid, + staticPropertyDescriptors, + states, + opcodes, + maxUnsigned16Bit, + parserStates, + emptyBuffer +} + + +/***/ }), + +/***/ 6255: +/***/ ((module, __unused_webpack_exports, __nccwpck_require__) => { + + + +const { webidl } = __nccwpck_require__(4222) +const { kEnumerableProperty } = __nccwpck_require__(3440) +const { MessagePort } = __nccwpck_require__(8167) + +/** + * @see https://html.spec.whatwg.org/multipage/comms.html#messageevent + */ +class MessageEvent extends Event { + #eventInit + + constructor (type, eventInitDict = {}) { + webidl.argumentLengthCheck(arguments, 1, { header: 'MessageEvent constructor' }) + + type = webidl.converters.DOMString(type) + eventInitDict = webidl.converters.MessageEventInit(eventInitDict) + + super(type, eventInitDict) + + this.#eventInit = eventInitDict + } + + get data () { + webidl.brandCheck(this, MessageEvent) + + return this.#eventInit.data + } + + get origin () { + webidl.brandCheck(this, MessageEvent) + + return this.#eventInit.origin + } + + get lastEventId () { + webidl.brandCheck(this, MessageEvent) + + return this.#eventInit.lastEventId + } + + get source () { + webidl.brandCheck(this, MessageEvent) + + return this.#eventInit.source + } + + get ports () { + webidl.brandCheck(this, MessageEvent) + + if (!Object.isFrozen(this.#eventInit.ports)) { + Object.freeze(this.#eventInit.ports) + } + + return this.#eventInit.ports + } + + initMessageEvent ( + type, + bubbles = false, + cancelable = false, + data = null, + origin = '', + lastEventId = '', + source = null, + ports = [] + ) { + webidl.brandCheck(this, MessageEvent) + + webidl.argumentLengthCheck(arguments, 1, { header: 'MessageEvent.initMessageEvent' }) + + return new MessageEvent(type, { + bubbles, cancelable, data, origin, lastEventId, source, ports + }) + } +} + +/** + * @see https://websockets.spec.whatwg.org/#the-closeevent-interface + */ +class CloseEvent extends Event { + #eventInit + + constructor (type, eventInitDict = {}) { + webidl.argumentLengthCheck(arguments, 1, { header: 'CloseEvent constructor' }) + + type = webidl.converters.DOMString(type) + eventInitDict = webidl.converters.CloseEventInit(eventInitDict) + + super(type, eventInitDict) + + this.#eventInit = eventInitDict + } + + get wasClean () { + webidl.brandCheck(this, CloseEvent) + + return this.#eventInit.wasClean + } + + get code () { + webidl.brandCheck(this, CloseEvent) + + return this.#eventInit.code + } + + get reason () { + webidl.brandCheck(this, CloseEvent) + + return this.#eventInit.reason + } +} + +// https://html.spec.whatwg.org/multipage/webappapis.html#the-errorevent-interface +class ErrorEvent extends Event { + #eventInit + + constructor (type, eventInitDict) { + webidl.argumentLengthCheck(arguments, 1, { header: 'ErrorEvent constructor' }) + + super(type, eventInitDict) + + type = webidl.converters.DOMString(type) + eventInitDict = webidl.converters.ErrorEventInit(eventInitDict ?? {}) + + this.#eventInit = eventInitDict + } + + get message () { + webidl.brandCheck(this, ErrorEvent) + + return this.#eventInit.message + } + + get filename () { + webidl.brandCheck(this, ErrorEvent) + + return this.#eventInit.filename + } + + get lineno () { + webidl.brandCheck(this, ErrorEvent) + + return this.#eventInit.lineno + } + + get colno () { + webidl.brandCheck(this, ErrorEvent) + + return this.#eventInit.colno + } + + get error () { + webidl.brandCheck(this, ErrorEvent) + + return this.#eventInit.error + } +} + +Object.defineProperties(MessageEvent.prototype, { + [Symbol.toStringTag]: { + value: 'MessageEvent', + configurable: true + }, + data: kEnumerableProperty, + origin: kEnumerableProperty, + lastEventId: kEnumerableProperty, + source: kEnumerableProperty, + ports: kEnumerableProperty, + initMessageEvent: kEnumerableProperty +}) + +Object.defineProperties(CloseEvent.prototype, { + [Symbol.toStringTag]: { + value: 'CloseEvent', + configurable: true + }, + reason: kEnumerableProperty, + code: kEnumerableProperty, + wasClean: kEnumerableProperty +}) + +Object.defineProperties(ErrorEvent.prototype, { + [Symbol.toStringTag]: { + value: 'ErrorEvent', + configurable: true + }, + message: kEnumerableProperty, + filename: kEnumerableProperty, + lineno: kEnumerableProperty, + colno: kEnumerableProperty, + error: kEnumerableProperty +}) + +webidl.converters.MessagePort = webidl.interfaceConverter(MessagePort) + +webidl.converters['sequence'] = webidl.sequenceConverter( + webidl.converters.MessagePort +) + +const eventInit = [ + { + key: 'bubbles', + converter: webidl.converters.boolean, + defaultValue: false + }, + { + key: 'cancelable', + converter: webidl.converters.boolean, + defaultValue: false + }, + { + key: 'composed', + converter: webidl.converters.boolean, + defaultValue: false + } +] + +webidl.converters.MessageEventInit = webidl.dictionaryConverter([ + ...eventInit, + { + key: 'data', + converter: webidl.converters.any, + defaultValue: null + }, + { + key: 'origin', + converter: webidl.converters.USVString, + defaultValue: '' + }, + { + key: 'lastEventId', + converter: webidl.converters.DOMString, + defaultValue: '' + }, + { + key: 'source', + // Node doesn't implement WindowProxy or ServiceWorker, so the only + // valid value for source is a MessagePort. + converter: webidl.nullableConverter(webidl.converters.MessagePort), + defaultValue: null + }, + { + key: 'ports', + converter: webidl.converters['sequence'], + get defaultValue () { + return [] + } + } +]) + +webidl.converters.CloseEventInit = webidl.dictionaryConverter([ + ...eventInit, + { + key: 'wasClean', + converter: webidl.converters.boolean, + defaultValue: false + }, + { + key: 'code', + converter: webidl.converters['unsigned short'], + defaultValue: 0 + }, + { + key: 'reason', + converter: webidl.converters.USVString, + defaultValue: '' + } +]) + +webidl.converters.ErrorEventInit = webidl.dictionaryConverter([ + ...eventInit, + { + key: 'message', + converter: webidl.converters.DOMString, + defaultValue: '' + }, + { + key: 'filename', + converter: webidl.converters.USVString, + defaultValue: '' + }, + { + key: 'lineno', + converter: webidl.converters['unsigned long'], + defaultValue: 0 + }, + { + key: 'colno', + converter: webidl.converters['unsigned long'], + defaultValue: 0 + }, + { + key: 'error', + converter: webidl.converters.any + } +]) + +module.exports = { + MessageEvent, + CloseEvent, + ErrorEvent +} + + +/***/ }), + +/***/ 1237: +/***/ ((module, __unused_webpack_exports, __nccwpck_require__) => { + + + +const { maxUnsigned16Bit } = __nccwpck_require__(5913) + +/** @type {import('crypto')} */ +let crypto +try { + crypto = __nccwpck_require__(6982) +} catch { + +} + +class WebsocketFrameSend { + /** + * @param {Buffer|undefined} data + */ + constructor (data) { + this.frameData = data + this.maskKey = crypto.randomBytes(4) + } + + createFrame (opcode) { + const bodyLength = this.frameData?.byteLength ?? 0 + + /** @type {number} */ + let payloadLength = bodyLength // 0-125 + let offset = 6 + + if (bodyLength > maxUnsigned16Bit) { + offset += 8 // payload length is next 8 bytes + payloadLength = 127 + } else if (bodyLength > 125) { + offset += 2 // payload length is next 2 bytes + payloadLength = 126 + } + + const buffer = Buffer.allocUnsafe(bodyLength + offset) + + // Clear first 2 bytes, everything else is overwritten + buffer[0] = buffer[1] = 0 + buffer[0] |= 0x80 // FIN + buffer[0] = (buffer[0] & 0xF0) + opcode // opcode + + /*! ws. MIT License. Einar Otto Stangvik */ + buffer[offset - 4] = this.maskKey[0] + buffer[offset - 3] = this.maskKey[1] + buffer[offset - 2] = this.maskKey[2] + buffer[offset - 1] = this.maskKey[3] + + buffer[1] = payloadLength + + if (payloadLength === 126) { + buffer.writeUInt16BE(bodyLength, 2) + } else if (payloadLength === 127) { + // Clear extended payload length + buffer[2] = buffer[3] = 0 + buffer.writeUIntBE(bodyLength, 4, 6) + } + + buffer[1] |= 0x80 // MASK + + // mask body + for (let i = 0; i < bodyLength; i++) { + buffer[offset + i] = this.frameData[i] ^ this.maskKey[i % 4] + } + + return buffer + } +} + +module.exports = { + WebsocketFrameSend +} + + +/***/ }), + +/***/ 3171: +/***/ ((module, __unused_webpack_exports, __nccwpck_require__) => { + + + +const { Writable } = __nccwpck_require__(2203) +const diagnosticsChannel = __nccwpck_require__(1637) +const { parserStates, opcodes, states, emptyBuffer } = __nccwpck_require__(5913) +const { kReadyState, kSentClose, kResponse, kReceivedClose } = __nccwpck_require__(2933) +const { isValidStatusCode, failWebsocketConnection, websocketMessageReceived } = __nccwpck_require__(3574) +const { WebsocketFrameSend } = __nccwpck_require__(1237) + +// This code was influenced by ws released under the MIT license. +// Copyright (c) 2011 Einar Otto Stangvik +// Copyright (c) 2013 Arnout Kazemier and contributors +// Copyright (c) 2016 Luigi Pinca and contributors + +const channels = {} +channels.ping = diagnosticsChannel.channel('undici:websocket:ping') +channels.pong = diagnosticsChannel.channel('undici:websocket:pong') + +class ByteParser extends Writable { + #buffers = [] + #byteOffset = 0 + + #state = parserStates.INFO + + #info = {} + #fragments = [] + + constructor (ws) { + super() + + this.ws = ws + } + + /** + * @param {Buffer} chunk + * @param {() => void} callback + */ + _write (chunk, _, callback) { + this.#buffers.push(chunk) + this.#byteOffset += chunk.length + + this.run(callback) + } + + /** + * Runs whenever a new chunk is received. + * Callback is called whenever there are no more chunks buffering, + * or not enough bytes are buffered to parse. + */ + run (callback) { + while (true) { + if (this.#state === parserStates.INFO) { + // If there aren't enough bytes to parse the payload length, etc. + if (this.#byteOffset < 2) { + return callback() + } + + const buffer = this.consume(2) + + this.#info.fin = (buffer[0] & 0x80) !== 0 + this.#info.opcode = buffer[0] & 0x0F + + // If we receive a fragmented message, we use the type of the first + // frame to parse the full message as binary/text, when it's terminated + this.#info.originalOpcode ??= this.#info.opcode + + this.#info.fragmented = !this.#info.fin && this.#info.opcode !== opcodes.CONTINUATION + + if (this.#info.fragmented && this.#info.opcode !== opcodes.BINARY && this.#info.opcode !== opcodes.TEXT) { + // Only text and binary frames can be fragmented + failWebsocketConnection(this.ws, 'Invalid frame type was fragmented.') + return + } + + const payloadLength = buffer[1] & 0x7F + + if (payloadLength <= 125) { + this.#info.payloadLength = payloadLength + this.#state = parserStates.READ_DATA + } else if (payloadLength === 126) { + this.#state = parserStates.PAYLOADLENGTH_16 + } else if (payloadLength === 127) { + this.#state = parserStates.PAYLOADLENGTH_64 + } + + if (this.#info.fragmented && payloadLength > 125) { + // A fragmented frame can't be fragmented itself + failWebsocketConnection(this.ws, 'Fragmented frame exceeded 125 bytes.') + return + } else if ( + (this.#info.opcode === opcodes.PING || + this.#info.opcode === opcodes.PONG || + this.#info.opcode === opcodes.CLOSE) && + payloadLength > 125 + ) { + // Control frames can have a payload length of 125 bytes MAX + failWebsocketConnection(this.ws, 'Payload length for control frame exceeded 125 bytes.') + return + } else if (this.#info.opcode === opcodes.CLOSE) { + if (payloadLength === 1) { + failWebsocketConnection(this.ws, 'Received close frame with a 1-byte body.') + return + } + + const body = this.consume(payloadLength) + + this.#info.closeInfo = this.parseCloseBody(false, body) + + if (!this.ws[kSentClose]) { + // If an endpoint receives a Close frame and did not previously send a + // Close frame, the endpoint MUST send a Close frame in response. (When + // sending a Close frame in response, the endpoint typically echos the + // status code it received.) + const body = Buffer.allocUnsafe(2) + body.writeUInt16BE(this.#info.closeInfo.code, 0) + const closeFrame = new WebsocketFrameSend(body) + + this.ws[kResponse].socket.write( + closeFrame.createFrame(opcodes.CLOSE), + (err) => { + if (!err) { + this.ws[kSentClose] = true + } + } + ) + } + + // Upon either sending or receiving a Close control frame, it is said + // that _The WebSocket Closing Handshake is Started_ and that the + // WebSocket connection is in the CLOSING state. + this.ws[kReadyState] = states.CLOSING + this.ws[kReceivedClose] = true + + this.end() + + return + } else if (this.#info.opcode === opcodes.PING) { + // Upon receipt of a Ping frame, an endpoint MUST send a Pong frame in + // response, unless it already received a Close frame. + // A Pong frame sent in response to a Ping frame must have identical + // "Application data" + + const body = this.consume(payloadLength) + + if (!this.ws[kReceivedClose]) { + const frame = new WebsocketFrameSend(body) + + this.ws[kResponse].socket.write(frame.createFrame(opcodes.PONG)) + + if (channels.ping.hasSubscribers) { + channels.ping.publish({ + payload: body + }) + } + } + + this.#state = parserStates.INFO + + if (this.#byteOffset > 0) { + continue + } else { + callback() + return + } + } else if (this.#info.opcode === opcodes.PONG) { + // A Pong frame MAY be sent unsolicited. This serves as a + // unidirectional heartbeat. A response to an unsolicited Pong frame is + // not expected. + + const body = this.consume(payloadLength) + + if (channels.pong.hasSubscribers) { + channels.pong.publish({ + payload: body + }) + } + + if (this.#byteOffset > 0) { + continue + } else { + callback() + return + } + } + } else if (this.#state === parserStates.PAYLOADLENGTH_16) { + if (this.#byteOffset < 2) { + return callback() + } + + const buffer = this.consume(2) + + this.#info.payloadLength = buffer.readUInt16BE(0) + this.#state = parserStates.READ_DATA + } else if (this.#state === parserStates.PAYLOADLENGTH_64) { + if (this.#byteOffset < 8) { + return callback() + } + + const buffer = this.consume(8) + const upper = buffer.readUInt32BE(0) + + // 2^31 is the maxinimum bytes an arraybuffer can contain + // on 32-bit systems. Although, on 64-bit systems, this is + // 2^53-1 bytes. + // https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Errors/Invalid_array_length + // https://source.chromium.org/chromium/chromium/src/+/main:v8/src/common/globals.h;drc=1946212ac0100668f14eb9e2843bdd846e510a1e;bpv=1;bpt=1;l=1275 + // https://source.chromium.org/chromium/chromium/src/+/main:v8/src/objects/js-array-buffer.h;l=34;drc=1946212ac0100668f14eb9e2843bdd846e510a1e + if (upper > 2 ** 31 - 1) { + failWebsocketConnection(this.ws, 'Received payload length > 2^31 bytes.') + return + } + + const lower = buffer.readUInt32BE(4) + + this.#info.payloadLength = (upper << 8) + lower + this.#state = parserStates.READ_DATA + } else if (this.#state === parserStates.READ_DATA) { + if (this.#byteOffset < this.#info.payloadLength) { + // If there is still more data in this chunk that needs to be read + return callback() + } else if (this.#byteOffset >= this.#info.payloadLength) { + // If the server sent multiple frames in a single chunk + + const body = this.consume(this.#info.payloadLength) + + this.#fragments.push(body) + + // If the frame is unfragmented, or a fragmented frame was terminated, + // a message was received + if (!this.#info.fragmented || (this.#info.fin && this.#info.opcode === opcodes.CONTINUATION)) { + const fullMessage = Buffer.concat(this.#fragments) + + websocketMessageReceived(this.ws, this.#info.originalOpcode, fullMessage) + + this.#info = {} + this.#fragments.length = 0 + } + + this.#state = parserStates.INFO + } + } + + if (this.#byteOffset > 0) { + continue + } else { + callback() + break + } + } + } + + /** + * Take n bytes from the buffered Buffers + * @param {number} n + * @returns {Buffer|null} + */ + consume (n) { + if (n > this.#byteOffset) { + return null + } else if (n === 0) { + return emptyBuffer + } + + if (this.#buffers[0].length === n) { + this.#byteOffset -= this.#buffers[0].length + return this.#buffers.shift() + } + + const buffer = Buffer.allocUnsafe(n) + let offset = 0 + + while (offset !== n) { + const next = this.#buffers[0] + const { length } = next + + if (length + offset === n) { + buffer.set(this.#buffers.shift(), offset) + break + } else if (length + offset > n) { + buffer.set(next.subarray(0, n - offset), offset) + this.#buffers[0] = next.subarray(n - offset) + break + } else { + buffer.set(this.#buffers.shift(), offset) + offset += next.length + } + } + + this.#byteOffset -= n + + return buffer + } + + parseCloseBody (onlyCode, data) { + // https://datatracker.ietf.org/doc/html/rfc6455#section-7.1.5 + /** @type {number|undefined} */ + let code + + if (data.length >= 2) { + // _The WebSocket Connection Close Code_ is + // defined as the status code (Section 7.4) contained in the first Close + // control frame received by the application + code = data.readUInt16BE(0) + } + + if (onlyCode) { + if (!isValidStatusCode(code)) { + return null + } + + return { code } + } + + // https://datatracker.ietf.org/doc/html/rfc6455#section-7.1.6 + /** @type {Buffer} */ + let reason = data.subarray(2) + + // Remove BOM + if (reason[0] === 0xEF && reason[1] === 0xBB && reason[2] === 0xBF) { + reason = reason.subarray(3) + } + + if (code !== undefined && !isValidStatusCode(code)) { + return null + } + + try { + // TODO: optimize this + reason = new TextDecoder('utf-8', { fatal: true }).decode(reason) + } catch { + return null + } + + return { code, reason } + } + + get closingInfo () { + return this.#info.closeInfo + } +} + +module.exports = { + ByteParser +} + + +/***/ }), + +/***/ 2933: +/***/ ((module) => { + + + +module.exports = { + kWebSocketURL: Symbol('url'), + kReadyState: Symbol('ready state'), + kController: Symbol('controller'), + kResponse: Symbol('response'), + kBinaryType: Symbol('binary type'), + kSentClose: Symbol('sent close'), + kReceivedClose: Symbol('received close'), + kByteParser: Symbol('byte parser') +} + + +/***/ }), + +/***/ 3574: +/***/ ((module, __unused_webpack_exports, __nccwpck_require__) => { + + + +const { kReadyState, kController, kResponse, kBinaryType, kWebSocketURL } = __nccwpck_require__(2933) +const { states, opcodes } = __nccwpck_require__(5913) +const { MessageEvent, ErrorEvent } = __nccwpck_require__(6255) + +/* globals Blob */ + +/** + * @param {import('./websocket').WebSocket} ws + */ +function isEstablished (ws) { + // If the server's response is validated as provided for above, it is + // said that _The WebSocket Connection is Established_ and that the + // WebSocket Connection is in the OPEN state. + return ws[kReadyState] === states.OPEN +} + +/** + * @param {import('./websocket').WebSocket} ws + */ +function isClosing (ws) { + // Upon either sending or receiving a Close control frame, it is said + // that _The WebSocket Closing Handshake is Started_ and that the + // WebSocket connection is in the CLOSING state. + return ws[kReadyState] === states.CLOSING +} + +/** + * @param {import('./websocket').WebSocket} ws + */ +function isClosed (ws) { + return ws[kReadyState] === states.CLOSED +} + +/** + * @see https://dom.spec.whatwg.org/#concept-event-fire + * @param {string} e + * @param {EventTarget} target + * @param {EventInit | undefined} eventInitDict + */ +function fireEvent (e, target, eventConstructor = Event, eventInitDict) { + // 1. If eventConstructor is not given, then let eventConstructor be Event. + + // 2. Let event be the result of creating an event given eventConstructor, + // in the relevant realm of target. + // 3. Initialize event’s type attribute to e. + const event = new eventConstructor(e, eventInitDict) // eslint-disable-line new-cap + + // 4. Initialize any other IDL attributes of event as described in the + // invocation of this algorithm. + + // 5. Return the result of dispatching event at target, with legacy target + // override flag set if set. + target.dispatchEvent(event) +} + +/** + * @see https://websockets.spec.whatwg.org/#feedback-from-the-protocol + * @param {import('./websocket').WebSocket} ws + * @param {number} type Opcode + * @param {Buffer} data application data + */ +function websocketMessageReceived (ws, type, data) { + // 1. If ready state is not OPEN (1), then return. + if (ws[kReadyState] !== states.OPEN) { + return + } + + // 2. Let dataForEvent be determined by switching on type and binary type: + let dataForEvent + + if (type === opcodes.TEXT) { + // -> type indicates that the data is Text + // a new DOMString containing data + try { + dataForEvent = new TextDecoder('utf-8', { fatal: true }).decode(data) + } catch { + failWebsocketConnection(ws, 'Received invalid UTF-8 in text frame.') + return + } + } else if (type === opcodes.BINARY) { + if (ws[kBinaryType] === 'blob') { + // -> type indicates that the data is Binary and binary type is "blob" + // a new Blob object, created in the relevant Realm of the WebSocket + // object, that represents data as its raw data + dataForEvent = new Blob([data]) + } else { + // -> type indicates that the data is Binary and binary type is "arraybuffer" + // a new ArrayBuffer object, created in the relevant Realm of the + // WebSocket object, whose contents are data + dataForEvent = new Uint8Array(data).buffer + } + } + + // 3. Fire an event named message at the WebSocket object, using MessageEvent, + // with the origin attribute initialized to the serialization of the WebSocket + // object’s url's origin, and the data attribute initialized to dataForEvent. + fireEvent('message', ws, MessageEvent, { + origin: ws[kWebSocketURL].origin, + data: dataForEvent + }) +} + +/** + * @see https://datatracker.ietf.org/doc/html/rfc6455 + * @see https://datatracker.ietf.org/doc/html/rfc2616 + * @see https://bugs.chromium.org/p/chromium/issues/detail?id=398407 + * @param {string} protocol + */ +function isValidSubprotocol (protocol) { + // If present, this value indicates one + // or more comma-separated subprotocol the client wishes to speak, + // ordered by preference. The elements that comprise this value + // MUST be non-empty strings with characters in the range U+0021 to + // U+007E not including separator characters as defined in + // [RFC2616] and MUST all be unique strings. + if (protocol.length === 0) { + return false + } + + for (const char of protocol) { + const code = char.charCodeAt(0) + + if ( + code < 0x21 || + code > 0x7E || + char === '(' || + char === ')' || + char === '<' || + char === '>' || + char === '@' || + char === ',' || + char === ';' || + char === ':' || + char === '\\' || + char === '"' || + char === '/' || + char === '[' || + char === ']' || + char === '?' || + char === '=' || + char === '{' || + char === '}' || + code === 32 || // SP + code === 9 // HT + ) { + return false + } + } + + return true +} + +/** + * @see https://datatracker.ietf.org/doc/html/rfc6455#section-7-4 + * @param {number} code + */ +function isValidStatusCode (code) { + if (code >= 1000 && code < 1015) { + return ( + code !== 1004 && // reserved + code !== 1005 && // "MUST NOT be set as a status code" + code !== 1006 // "MUST NOT be set as a status code" + ) + } + + return code >= 3000 && code <= 4999 +} + +/** + * @param {import('./websocket').WebSocket} ws + * @param {string|undefined} reason + */ +function failWebsocketConnection (ws, reason) { + const { [kController]: controller, [kResponse]: response } = ws + + controller.abort() + + if (response?.socket && !response.socket.destroyed) { + response.socket.destroy() + } + + if (reason) { + fireEvent('error', ws, ErrorEvent, { + error: new Error(reason) + }) + } +} + +module.exports = { + isEstablished, + isClosing, + isClosed, + fireEvent, + isValidSubprotocol, + isValidStatusCode, + failWebsocketConnection, + websocketMessageReceived +} + + +/***/ }), + +/***/ 5171: +/***/ ((module, __unused_webpack_exports, __nccwpck_require__) => { + + + +const { webidl } = __nccwpck_require__(4222) +const { DOMException } = __nccwpck_require__(7326) +const { URLSerializer } = __nccwpck_require__(4322) +const { getGlobalOrigin } = __nccwpck_require__(5628) +const { staticPropertyDescriptors, states, opcodes, emptyBuffer } = __nccwpck_require__(5913) +const { + kWebSocketURL, + kReadyState, + kController, + kBinaryType, + kResponse, + kSentClose, + kByteParser +} = __nccwpck_require__(2933) +const { isEstablished, isClosing, isValidSubprotocol, failWebsocketConnection, fireEvent } = __nccwpck_require__(3574) +const { establishWebSocketConnection } = __nccwpck_require__(8550) +const { WebsocketFrameSend } = __nccwpck_require__(1237) +const { ByteParser } = __nccwpck_require__(3171) +const { kEnumerableProperty, isBlobLike } = __nccwpck_require__(3440) +const { getGlobalDispatcher } = __nccwpck_require__(2581) +const { types } = __nccwpck_require__(9023) + +let experimentalWarned = false + +// https://websockets.spec.whatwg.org/#interface-definition +class WebSocket extends EventTarget { + #events = { + open: null, + error: null, + close: null, + message: null + } + + #bufferedAmount = 0 + #protocol = '' + #extensions = '' + + /** + * @param {string} url + * @param {string|string[]} protocols + */ + constructor (url, protocols = []) { + super() + + webidl.argumentLengthCheck(arguments, 1, { header: 'WebSocket constructor' }) + + if (!experimentalWarned) { + experimentalWarned = true + process.emitWarning('WebSockets are experimental, expect them to change at any time.', { + code: 'UNDICI-WS' + }) + } + + const options = webidl.converters['DOMString or sequence or WebSocketInit'](protocols) + + url = webidl.converters.USVString(url) + protocols = options.protocols + + // 1. Let baseURL be this's relevant settings object's API base URL. + const baseURL = getGlobalOrigin() + + // 1. Let urlRecord be the result of applying the URL parser to url with baseURL. + let urlRecord + + try { + urlRecord = new URL(url, baseURL) + } catch (e) { + // 3. If urlRecord is failure, then throw a "SyntaxError" DOMException. + throw new DOMException(e, 'SyntaxError') + } + + // 4. If urlRecord’s scheme is "http", then set urlRecord’s scheme to "ws". + if (urlRecord.protocol === 'http:') { + urlRecord.protocol = 'ws:' + } else if (urlRecord.protocol === 'https:') { + // 5. Otherwise, if urlRecord’s scheme is "https", set urlRecord’s scheme to "wss". + urlRecord.protocol = 'wss:' + } + + // 6. If urlRecord’s scheme is not "ws" or "wss", then throw a "SyntaxError" DOMException. + if (urlRecord.protocol !== 'ws:' && urlRecord.protocol !== 'wss:') { + throw new DOMException( + `Expected a ws: or wss: protocol, got ${urlRecord.protocol}`, + 'SyntaxError' + ) + } + + // 7. If urlRecord’s fragment is non-null, then throw a "SyntaxError" + // DOMException. + if (urlRecord.hash || urlRecord.href.endsWith('#')) { + throw new DOMException('Got fragment', 'SyntaxError') + } + + // 8. If protocols is a string, set protocols to a sequence consisting + // of just that string. + if (typeof protocols === 'string') { + protocols = [protocols] + } + + // 9. If any of the values in protocols occur more than once or otherwise + // fail to match the requirements for elements that comprise the value + // of `Sec-WebSocket-Protocol` fields as defined by The WebSocket + // protocol, then throw a "SyntaxError" DOMException. + if (protocols.length !== new Set(protocols.map(p => p.toLowerCase())).size) { + throw new DOMException('Invalid Sec-WebSocket-Protocol value', 'SyntaxError') + } + + if (protocols.length > 0 && !protocols.every(p => isValidSubprotocol(p))) { + throw new DOMException('Invalid Sec-WebSocket-Protocol value', 'SyntaxError') + } + + // 10. Set this's url to urlRecord. + this[kWebSocketURL] = new URL(urlRecord.href) + + // 11. Let client be this's relevant settings object. + + // 12. Run this step in parallel: + + // 1. Establish a WebSocket connection given urlRecord, protocols, + // and client. + this[kController] = establishWebSocketConnection( + urlRecord, + protocols, + this, + (response) => this.#onConnectionEstablished(response), + options + ) + + // Each WebSocket object has an associated ready state, which is a + // number representing the state of the connection. Initially it must + // be CONNECTING (0). + this[kReadyState] = WebSocket.CONNECTING + + // The extensions attribute must initially return the empty string. + + // The protocol attribute must initially return the empty string. + + // Each WebSocket object has an associated binary type, which is a + // BinaryType. Initially it must be "blob". + this[kBinaryType] = 'blob' + } + + /** + * @see https://websockets.spec.whatwg.org/#dom-websocket-close + * @param {number|undefined} code + * @param {string|undefined} reason + */ + close (code = undefined, reason = undefined) { + webidl.brandCheck(this, WebSocket) + + if (code !== undefined) { + code = webidl.converters['unsigned short'](code, { clamp: true }) + } + + if (reason !== undefined) { + reason = webidl.converters.USVString(reason) + } + + // 1. If code is present, but is neither an integer equal to 1000 nor an + // integer in the range 3000 to 4999, inclusive, throw an + // "InvalidAccessError" DOMException. + if (code !== undefined) { + if (code !== 1000 && (code < 3000 || code > 4999)) { + throw new DOMException('invalid code', 'InvalidAccessError') + } + } + + let reasonByteLength = 0 + + // 2. If reason is present, then run these substeps: + if (reason !== undefined) { + // 1. Let reasonBytes be the result of encoding reason. + // 2. If reasonBytes is longer than 123 bytes, then throw a + // "SyntaxError" DOMException. + reasonByteLength = Buffer.byteLength(reason) + + if (reasonByteLength > 123) { + throw new DOMException( + `Reason must be less than 123 bytes; received ${reasonByteLength}`, + 'SyntaxError' + ) + } + } + + // 3. Run the first matching steps from the following list: + if (this[kReadyState] === WebSocket.CLOSING || this[kReadyState] === WebSocket.CLOSED) { + // If this's ready state is CLOSING (2) or CLOSED (3) + // Do nothing. + } else if (!isEstablished(this)) { + // If the WebSocket connection is not yet established + // Fail the WebSocket connection and set this's ready state + // to CLOSING (2). + failWebsocketConnection(this, 'Connection was closed before it was established.') + this[kReadyState] = WebSocket.CLOSING + } else if (!isClosing(this)) { + // If the WebSocket closing handshake has not yet been started + // Start the WebSocket closing handshake and set this's ready + // state to CLOSING (2). + // - If neither code nor reason is present, the WebSocket Close + // message must not have a body. + // - If code is present, then the status code to use in the + // WebSocket Close message must be the integer given by code. + // - If reason is also present, then reasonBytes must be + // provided in the Close message after the status code. + + const frame = new WebsocketFrameSend() + + // If neither code nor reason is present, the WebSocket Close + // message must not have a body. + + // If code is present, then the status code to use in the + // WebSocket Close message must be the integer given by code. + if (code !== undefined && reason === undefined) { + frame.frameData = Buffer.allocUnsafe(2) + frame.frameData.writeUInt16BE(code, 0) + } else if (code !== undefined && reason !== undefined) { + // If reason is also present, then reasonBytes must be + // provided in the Close message after the status code. + frame.frameData = Buffer.allocUnsafe(2 + reasonByteLength) + frame.frameData.writeUInt16BE(code, 0) + // the body MAY contain UTF-8-encoded data with value /reason/ + frame.frameData.write(reason, 2, 'utf-8') + } else { + frame.frameData = emptyBuffer + } + + /** @type {import('stream').Duplex} */ + const socket = this[kResponse].socket + + socket.write(frame.createFrame(opcodes.CLOSE), (err) => { + if (!err) { + this[kSentClose] = true + } + }) + + // Upon either sending or receiving a Close control frame, it is said + // that _The WebSocket Closing Handshake is Started_ and that the + // WebSocket connection is in the CLOSING state. + this[kReadyState] = states.CLOSING + } else { + // Otherwise + // Set this's ready state to CLOSING (2). + this[kReadyState] = WebSocket.CLOSING + } + } + + /** + * @see https://websockets.spec.whatwg.org/#dom-websocket-send + * @param {NodeJS.TypedArray|ArrayBuffer|Blob|string} data + */ + send (data) { + webidl.brandCheck(this, WebSocket) + + webidl.argumentLengthCheck(arguments, 1, { header: 'WebSocket.send' }) + + data = webidl.converters.WebSocketSendData(data) + + // 1. If this's ready state is CONNECTING, then throw an + // "InvalidStateError" DOMException. + if (this[kReadyState] === WebSocket.CONNECTING) { + throw new DOMException('Sent before connected.', 'InvalidStateError') + } + + // 2. Run the appropriate set of steps from the following list: + // https://datatracker.ietf.org/doc/html/rfc6455#section-6.1 + // https://datatracker.ietf.org/doc/html/rfc6455#section-5.2 + + if (!isEstablished(this) || isClosing(this)) { + return + } + + /** @type {import('stream').Duplex} */ + const socket = this[kResponse].socket + + // If data is a string + if (typeof data === 'string') { + // If the WebSocket connection is established and the WebSocket + // closing handshake has not yet started, then the user agent + // must send a WebSocket Message comprised of the data argument + // using a text frame opcode; if the data cannot be sent, e.g. + // because it would need to be buffered but the buffer is full, + // the user agent must flag the WebSocket as full and then close + // the WebSocket connection. Any invocation of this method with a + // string argument that does not throw an exception must increase + // the bufferedAmount attribute by the number of bytes needed to + // express the argument as UTF-8. + + const value = Buffer.from(data) + const frame = new WebsocketFrameSend(value) + const buffer = frame.createFrame(opcodes.TEXT) + + this.#bufferedAmount += value.byteLength + socket.write(buffer, () => { + this.#bufferedAmount -= value.byteLength + }) + } else if (types.isArrayBuffer(data)) { + // If the WebSocket connection is established, and the WebSocket + // closing handshake has not yet started, then the user agent must + // send a WebSocket Message comprised of data using a binary frame + // opcode; if the data cannot be sent, e.g. because it would need + // to be buffered but the buffer is full, the user agent must flag + // the WebSocket as full and then close the WebSocket connection. + // The data to be sent is the data stored in the buffer described + // by the ArrayBuffer object. Any invocation of this method with an + // ArrayBuffer argument that does not throw an exception must + // increase the bufferedAmount attribute by the length of the + // ArrayBuffer in bytes. + + const value = Buffer.from(data) + const frame = new WebsocketFrameSend(value) + const buffer = frame.createFrame(opcodes.BINARY) + + this.#bufferedAmount += value.byteLength + socket.write(buffer, () => { + this.#bufferedAmount -= value.byteLength + }) + } else if (ArrayBuffer.isView(data)) { + // If the WebSocket connection is established, and the WebSocket + // closing handshake has not yet started, then the user agent must + // send a WebSocket Message comprised of data using a binary frame + // opcode; if the data cannot be sent, e.g. because it would need to + // be buffered but the buffer is full, the user agent must flag the + // WebSocket as full and then close the WebSocket connection. The + // data to be sent is the data stored in the section of the buffer + // described by the ArrayBuffer object that data references. Any + // invocation of this method with this kind of argument that does + // not throw an exception must increase the bufferedAmount attribute + // by the length of data’s buffer in bytes. + + const ab = Buffer.from(data, data.byteOffset, data.byteLength) + + const frame = new WebsocketFrameSend(ab) + const buffer = frame.createFrame(opcodes.BINARY) + + this.#bufferedAmount += ab.byteLength + socket.write(buffer, () => { + this.#bufferedAmount -= ab.byteLength + }) + } else if (isBlobLike(data)) { + // If the WebSocket connection is established, and the WebSocket + // closing handshake has not yet started, then the user agent must + // send a WebSocket Message comprised of data using a binary frame + // opcode; if the data cannot be sent, e.g. because it would need to + // be buffered but the buffer is full, the user agent must flag the + // WebSocket as full and then close the WebSocket connection. The data + // to be sent is the raw data represented by the Blob object. Any + // invocation of this method with a Blob argument that does not throw + // an exception must increase the bufferedAmount attribute by the size + // of the Blob object’s raw data, in bytes. + + const frame = new WebsocketFrameSend() + + data.arrayBuffer().then((ab) => { + const value = Buffer.from(ab) + frame.frameData = value + const buffer = frame.createFrame(opcodes.BINARY) + + this.#bufferedAmount += value.byteLength + socket.write(buffer, () => { + this.#bufferedAmount -= value.byteLength + }) + }) + } + } + + get readyState () { + webidl.brandCheck(this, WebSocket) + + // The readyState getter steps are to return this's ready state. + return this[kReadyState] + } + + get bufferedAmount () { + webidl.brandCheck(this, WebSocket) + + return this.#bufferedAmount + } + + get url () { + webidl.brandCheck(this, WebSocket) + + // The url getter steps are to return this's url, serialized. + return URLSerializer(this[kWebSocketURL]) + } + + get extensions () { + webidl.brandCheck(this, WebSocket) + + return this.#extensions + } + + get protocol () { + webidl.brandCheck(this, WebSocket) + + return this.#protocol + } + + get onopen () { + webidl.brandCheck(this, WebSocket) + + return this.#events.open + } + + set onopen (fn) { + webidl.brandCheck(this, WebSocket) + + if (this.#events.open) { + this.removeEventListener('open', this.#events.open) + } + + if (typeof fn === 'function') { + this.#events.open = fn + this.addEventListener('open', fn) + } else { + this.#events.open = null + } + } + + get onerror () { + webidl.brandCheck(this, WebSocket) + + return this.#events.error + } + + set onerror (fn) { + webidl.brandCheck(this, WebSocket) + + if (this.#events.error) { + this.removeEventListener('error', this.#events.error) + } + + if (typeof fn === 'function') { + this.#events.error = fn + this.addEventListener('error', fn) + } else { + this.#events.error = null + } + } + + get onclose () { + webidl.brandCheck(this, WebSocket) + + return this.#events.close + } + + set onclose (fn) { + webidl.brandCheck(this, WebSocket) + + if (this.#events.close) { + this.removeEventListener('close', this.#events.close) + } + + if (typeof fn === 'function') { + this.#events.close = fn + this.addEventListener('close', fn) + } else { + this.#events.close = null + } + } + + get onmessage () { + webidl.brandCheck(this, WebSocket) + + return this.#events.message + } + + set onmessage (fn) { + webidl.brandCheck(this, WebSocket) + + if (this.#events.message) { + this.removeEventListener('message', this.#events.message) + } + + if (typeof fn === 'function') { + this.#events.message = fn + this.addEventListener('message', fn) + } else { + this.#events.message = null + } + } + + get binaryType () { + webidl.brandCheck(this, WebSocket) + + return this[kBinaryType] + } + + set binaryType (type) { + webidl.brandCheck(this, WebSocket) + + if (type !== 'blob' && type !== 'arraybuffer') { + this[kBinaryType] = 'blob' + } else { + this[kBinaryType] = type + } + } + + /** + * @see https://websockets.spec.whatwg.org/#feedback-from-the-protocol + */ + #onConnectionEstablished (response) { + // processResponse is called when the "response’s header list has been received and initialized." + // once this happens, the connection is open + this[kResponse] = response + + const parser = new ByteParser(this) + parser.on('drain', function onParserDrain () { + this.ws[kResponse].socket.resume() + }) + + response.socket.ws = this + this[kByteParser] = parser + + // 1. Change the ready state to OPEN (1). + this[kReadyState] = states.OPEN + + // 2. Change the extensions attribute’s value to the extensions in use, if + // it is not the null value. + // https://datatracker.ietf.org/doc/html/rfc6455#section-9.1 + const extensions = response.headersList.get('sec-websocket-extensions') + + if (extensions !== null) { + this.#extensions = extensions + } + + // 3. Change the protocol attribute’s value to the subprotocol in use, if + // it is not the null value. + // https://datatracker.ietf.org/doc/html/rfc6455#section-1.9 + const protocol = response.headersList.get('sec-websocket-protocol') + + if (protocol !== null) { + this.#protocol = protocol + } + + // 4. Fire an event named open at the WebSocket object. + fireEvent('open', this) + } +} + +// https://websockets.spec.whatwg.org/#dom-websocket-connecting +WebSocket.CONNECTING = WebSocket.prototype.CONNECTING = states.CONNECTING +// https://websockets.spec.whatwg.org/#dom-websocket-open +WebSocket.OPEN = WebSocket.prototype.OPEN = states.OPEN +// https://websockets.spec.whatwg.org/#dom-websocket-closing +WebSocket.CLOSING = WebSocket.prototype.CLOSING = states.CLOSING +// https://websockets.spec.whatwg.org/#dom-websocket-closed +WebSocket.CLOSED = WebSocket.prototype.CLOSED = states.CLOSED + +Object.defineProperties(WebSocket.prototype, { + CONNECTING: staticPropertyDescriptors, + OPEN: staticPropertyDescriptors, + CLOSING: staticPropertyDescriptors, + CLOSED: staticPropertyDescriptors, + url: kEnumerableProperty, + readyState: kEnumerableProperty, + bufferedAmount: kEnumerableProperty, + onopen: kEnumerableProperty, + onerror: kEnumerableProperty, + onclose: kEnumerableProperty, + close: kEnumerableProperty, + onmessage: kEnumerableProperty, + binaryType: kEnumerableProperty, + send: kEnumerableProperty, + extensions: kEnumerableProperty, + protocol: kEnumerableProperty, + [Symbol.toStringTag]: { + value: 'WebSocket', + writable: false, + enumerable: false, + configurable: true + } +}) + +Object.defineProperties(WebSocket, { + CONNECTING: staticPropertyDescriptors, + OPEN: staticPropertyDescriptors, + CLOSING: staticPropertyDescriptors, + CLOSED: staticPropertyDescriptors +}) + +webidl.converters['sequence'] = webidl.sequenceConverter( + webidl.converters.DOMString +) + +webidl.converters['DOMString or sequence'] = function (V) { + if (webidl.util.Type(V) === 'Object' && Symbol.iterator in V) { + return webidl.converters['sequence'](V) + } + + return webidl.converters.DOMString(V) +} + +// This implements the propsal made in https://github.com/whatwg/websockets/issues/42 +webidl.converters.WebSocketInit = webidl.dictionaryConverter([ + { + key: 'protocols', + converter: webidl.converters['DOMString or sequence'], + get defaultValue () { + return [] + } + }, + { + key: 'dispatcher', + converter: (V) => V, + get defaultValue () { + return getGlobalDispatcher() + } + }, + { + key: 'headers', + converter: webidl.nullableConverter(webidl.converters.HeadersInit) + } +]) + +webidl.converters['DOMString or sequence or WebSocketInit'] = function (V) { + if (webidl.util.Type(V) === 'Object' && !(Symbol.iterator in V)) { + return webidl.converters.WebSocketInit(V) + } + + return { protocols: webidl.converters['DOMString or sequence'](V) } +} + +webidl.converters.WebSocketSendData = function (V) { + if (webidl.util.Type(V) === 'Object') { + if (isBlobLike(V)) { + return webidl.converters.Blob(V, { strict: false }) + } + + if (ArrayBuffer.isView(V) || types.isAnyArrayBuffer(V)) { + return webidl.converters.BufferSource(V) + } + } + + return webidl.converters.USVString(V) +} + +module.exports = { + WebSocket +} + + +/***/ }), + +/***/ 2613: +/***/ ((module) => { + +module.exports = __WEBPACK_EXTERNAL_createRequire(import.meta.url)("assert"); + +/***/ }), + +/***/ 290: +/***/ ((module) => { + +module.exports = __WEBPACK_EXTERNAL_createRequire(import.meta.url)("async_hooks"); + +/***/ }), + +/***/ 181: +/***/ ((module) => { + +module.exports = __WEBPACK_EXTERNAL_createRequire(import.meta.url)("buffer"); + +/***/ }), + +/***/ 5317: +/***/ ((module) => { + +module.exports = __WEBPACK_EXTERNAL_createRequire(import.meta.url)("child_process"); + +/***/ }), + +/***/ 4236: +/***/ ((module) => { + +module.exports = __WEBPACK_EXTERNAL_createRequire(import.meta.url)("console"); + +/***/ }), + +/***/ 6982: +/***/ ((module) => { + +module.exports = __WEBPACK_EXTERNAL_createRequire(import.meta.url)("crypto"); + +/***/ }), + +/***/ 1637: +/***/ ((module) => { + +module.exports = __WEBPACK_EXTERNAL_createRequire(import.meta.url)("diagnostics_channel"); + +/***/ }), + +/***/ 4434: +/***/ ((module) => { + +module.exports = __WEBPACK_EXTERNAL_createRequire(import.meta.url)("events"); + +/***/ }), + +/***/ 9896: +/***/ ((module) => { + +module.exports = __WEBPACK_EXTERNAL_createRequire(import.meta.url)("fs"); + +/***/ }), + +/***/ 8611: +/***/ ((module) => { + +module.exports = __WEBPACK_EXTERNAL_createRequire(import.meta.url)("http"); + +/***/ }), + +/***/ 5675: +/***/ ((module) => { + +module.exports = __WEBPACK_EXTERNAL_createRequire(import.meta.url)("http2"); + +/***/ }), + +/***/ 5692: +/***/ ((module) => { + +module.exports = __WEBPACK_EXTERNAL_createRequire(import.meta.url)("https"); + +/***/ }), + +/***/ 9278: +/***/ ((module) => { + +module.exports = __WEBPACK_EXTERNAL_createRequire(import.meta.url)("net"); + +/***/ }), + +/***/ 8474: +/***/ ((module) => { + +module.exports = __WEBPACK_EXTERNAL_createRequire(import.meta.url)("node:events"); + +/***/ }), + +/***/ 7075: +/***/ ((module) => { + +module.exports = __WEBPACK_EXTERNAL_createRequire(import.meta.url)("node:stream"); + +/***/ }), + +/***/ 7975: +/***/ ((module) => { + +module.exports = __WEBPACK_EXTERNAL_createRequire(import.meta.url)("node:util"); + +/***/ }), + +/***/ 857: +/***/ ((module) => { + +module.exports = __WEBPACK_EXTERNAL_createRequire(import.meta.url)("os"); + +/***/ }), + +/***/ 6928: +/***/ ((module) => { + +module.exports = __WEBPACK_EXTERNAL_createRequire(import.meta.url)("path"); + +/***/ }), + +/***/ 2987: +/***/ ((module) => { + +module.exports = __WEBPACK_EXTERNAL_createRequire(import.meta.url)("perf_hooks"); + +/***/ }), + +/***/ 3480: +/***/ ((module) => { + +module.exports = __WEBPACK_EXTERNAL_createRequire(import.meta.url)("querystring"); + +/***/ }), + +/***/ 2203: +/***/ ((module) => { + +module.exports = __WEBPACK_EXTERNAL_createRequire(import.meta.url)("stream"); + +/***/ }), + +/***/ 3774: +/***/ ((module) => { + +module.exports = __WEBPACK_EXTERNAL_createRequire(import.meta.url)("stream/web"); + +/***/ }), + +/***/ 3193: +/***/ ((module) => { + +module.exports = __WEBPACK_EXTERNAL_createRequire(import.meta.url)("string_decoder"); + +/***/ }), + +/***/ 3557: +/***/ ((module) => { + +module.exports = __WEBPACK_EXTERNAL_createRequire(import.meta.url)("timers"); + +/***/ }), + +/***/ 4756: +/***/ ((module) => { + +module.exports = __WEBPACK_EXTERNAL_createRequire(import.meta.url)("tls"); + +/***/ }), + +/***/ 7016: +/***/ ((module) => { + +module.exports = __WEBPACK_EXTERNAL_createRequire(import.meta.url)("url"); + +/***/ }), + +/***/ 9023: +/***/ ((module) => { + +module.exports = __WEBPACK_EXTERNAL_createRequire(import.meta.url)("util"); + +/***/ }), + +/***/ 8253: +/***/ ((module) => { + +module.exports = __WEBPACK_EXTERNAL_createRequire(import.meta.url)("util/types"); + +/***/ }), + +/***/ 8167: +/***/ ((module) => { + +module.exports = __WEBPACK_EXTERNAL_createRequire(import.meta.url)("worker_threads"); + +/***/ }), + +/***/ 3106: +/***/ ((module) => { + +module.exports = __WEBPACK_EXTERNAL_createRequire(import.meta.url)("zlib"); + +/***/ }), + +/***/ 7182: +/***/ ((module, __unused_webpack_exports, __nccwpck_require__) => { + + + +const WritableStream = (__nccwpck_require__(7075).Writable) +const inherits = (__nccwpck_require__(7975).inherits) + +const StreamSearch = __nccwpck_require__(4136) + +const PartStream = __nccwpck_require__(612) +const HeaderParser = __nccwpck_require__(2271) + +const DASH = 45 +const B_ONEDASH = Buffer.from('-') +const B_CRLF = Buffer.from('\r\n') +const EMPTY_FN = function () {} + +function Dicer (cfg) { + if (!(this instanceof Dicer)) { return new Dicer(cfg) } + WritableStream.call(this, cfg) + + if (!cfg || (!cfg.headerFirst && typeof cfg.boundary !== 'string')) { throw new TypeError('Boundary required') } + + if (typeof cfg.boundary === 'string') { this.setBoundary(cfg.boundary) } else { this._bparser = undefined } + + this._headerFirst = cfg.headerFirst + + this._dashes = 0 + this._parts = 0 + this._finished = false + this._realFinish = false + this._isPreamble = true + this._justMatched = false + this._firstWrite = true + this._inHeader = true + this._part = undefined + this._cb = undefined + this._ignoreData = false + this._partOpts = { highWaterMark: cfg.partHwm } + this._pause = false + + const self = this + this._hparser = new HeaderParser(cfg) + this._hparser.on('header', function (header) { + self._inHeader = false + self._part.emit('header', header) + }) +} +inherits(Dicer, WritableStream) + +Dicer.prototype.emit = function (ev) { + if (ev === 'finish' && !this._realFinish) { + if (!this._finished) { + const self = this + process.nextTick(function () { + self.emit('error', new Error('Unexpected end of multipart data')) + if (self._part && !self._ignoreData) { + const type = (self._isPreamble ? 'Preamble' : 'Part') + self._part.emit('error', new Error(type + ' terminated early due to unexpected end of multipart data')) + self._part.push(null) + process.nextTick(function () { + self._realFinish = true + self.emit('finish') + self._realFinish = false + }) + return + } + self._realFinish = true + self.emit('finish') + self._realFinish = false + }) + } + } else { WritableStream.prototype.emit.apply(this, arguments) } +} + +Dicer.prototype._write = function (data, encoding, cb) { + // ignore unexpected data (e.g. extra trailer data after finished) + if (!this._hparser && !this._bparser) { return cb() } + + if (this._headerFirst && this._isPreamble) { + if (!this._part) { + this._part = new PartStream(this._partOpts) + if (this.listenerCount('preamble') !== 0) { this.emit('preamble', this._part) } else { this._ignore() } + } + const r = this._hparser.push(data) + if (!this._inHeader && r !== undefined && r < data.length) { data = data.slice(r) } else { return cb() } + } + + // allows for "easier" testing + if (this._firstWrite) { + this._bparser.push(B_CRLF) + this._firstWrite = false + } + + this._bparser.push(data) + + if (this._pause) { this._cb = cb } else { cb() } +} + +Dicer.prototype.reset = function () { + this._part = undefined + this._bparser = undefined + this._hparser = undefined +} + +Dicer.prototype.setBoundary = function (boundary) { + const self = this + this._bparser = new StreamSearch('\r\n--' + boundary) + this._bparser.on('info', function (isMatch, data, start, end) { + self._oninfo(isMatch, data, start, end) + }) +} + +Dicer.prototype._ignore = function () { + if (this._part && !this._ignoreData) { + this._ignoreData = true + this._part.on('error', EMPTY_FN) + // we must perform some kind of read on the stream even though we are + // ignoring the data, otherwise node's Readable stream will not emit 'end' + // after pushing null to the stream + this._part.resume() + } +} + +Dicer.prototype._oninfo = function (isMatch, data, start, end) { + let buf; const self = this; let i = 0; let r; let shouldWriteMore = true + + if (!this._part && this._justMatched && data) { + while (this._dashes < 2 && (start + i) < end) { + if (data[start + i] === DASH) { + ++i + ++this._dashes + } else { + if (this._dashes) { buf = B_ONEDASH } + this._dashes = 0 + break + } + } + if (this._dashes === 2) { + if ((start + i) < end && this.listenerCount('trailer') !== 0) { this.emit('trailer', data.slice(start + i, end)) } + this.reset() + this._finished = true + // no more parts will be added + if (self._parts === 0) { + self._realFinish = true + self.emit('finish') + self._realFinish = false + } + } + if (this._dashes) { return } + } + if (this._justMatched) { this._justMatched = false } + if (!this._part) { + this._part = new PartStream(this._partOpts) + this._part._read = function (n) { + self._unpause() + } + if (this._isPreamble && this.listenerCount('preamble') !== 0) { + this.emit('preamble', this._part) + } else if (this._isPreamble !== true && this.listenerCount('part') !== 0) { + this.emit('part', this._part) + } else { + this._ignore() + } + if (!this._isPreamble) { this._inHeader = true } + } + if (data && start < end && !this._ignoreData) { + if (this._isPreamble || !this._inHeader) { + if (buf) { shouldWriteMore = this._part.push(buf) } + shouldWriteMore = this._part.push(data.slice(start, end)) + if (!shouldWriteMore) { this._pause = true } + } else if (!this._isPreamble && this._inHeader) { + if (buf) { this._hparser.push(buf) } + r = this._hparser.push(data.slice(start, end)) + if (!this._inHeader && r !== undefined && r < end) { this._oninfo(false, data, start + r, end) } + } + } + if (isMatch) { + this._hparser.reset() + if (this._isPreamble) { this._isPreamble = false } else { + if (start !== end) { + ++this._parts + this._part.on('end', function () { + if (--self._parts === 0) { + if (self._finished) { + self._realFinish = true + self.emit('finish') + self._realFinish = false + } else { + self._unpause() + } + } + }) + } + } + this._part.push(null) + this._part = undefined + this._ignoreData = false + this._justMatched = true + this._dashes = 0 + } +} + +Dicer.prototype._unpause = function () { + if (!this._pause) { return } + + this._pause = false + if (this._cb) { + const cb = this._cb + this._cb = undefined + cb() + } +} + +module.exports = Dicer + + +/***/ }), + +/***/ 2271: +/***/ ((module, __unused_webpack_exports, __nccwpck_require__) => { + + + +const EventEmitter = (__nccwpck_require__(8474).EventEmitter) +const inherits = (__nccwpck_require__(7975).inherits) +const getLimit = __nccwpck_require__(2393) + +const StreamSearch = __nccwpck_require__(4136) + +const B_DCRLF = Buffer.from('\r\n\r\n') +const RE_CRLF = /\r\n/g +const RE_HDR = /^([^:]+):[ \t]?([\x00-\xFF]+)?$/ // eslint-disable-line no-control-regex + +function HeaderParser (cfg) { + EventEmitter.call(this) + + cfg = cfg || {} + const self = this + this.nread = 0 + this.maxed = false + this.npairs = 0 + this.maxHeaderPairs = getLimit(cfg, 'maxHeaderPairs', 2000) + this.maxHeaderSize = getLimit(cfg, 'maxHeaderSize', 80 * 1024) + this.buffer = '' + this.header = {} + this.finished = false + this.ss = new StreamSearch(B_DCRLF) + this.ss.on('info', function (isMatch, data, start, end) { + if (data && !self.maxed) { + if (self.nread + end - start >= self.maxHeaderSize) { + end = self.maxHeaderSize - self.nread + start + self.nread = self.maxHeaderSize + self.maxed = true + } else { self.nread += (end - start) } + + self.buffer += data.toString('binary', start, end) + } + if (isMatch) { self._finish() } + }) +} +inherits(HeaderParser, EventEmitter) + +HeaderParser.prototype.push = function (data) { + const r = this.ss.push(data) + if (this.finished) { return r } +} + +HeaderParser.prototype.reset = function () { + this.finished = false + this.buffer = '' + this.header = {} + this.ss.reset() +} + +HeaderParser.prototype._finish = function () { + if (this.buffer) { this._parseHeader() } + this.ss.matches = this.ss.maxMatches + const header = this.header + this.header = {} + this.buffer = '' + this.finished = true + this.nread = this.npairs = 0 + this.maxed = false + this.emit('header', header) +} + +HeaderParser.prototype._parseHeader = function () { + if (this.npairs === this.maxHeaderPairs) { return } + + const lines = this.buffer.split(RE_CRLF) + const len = lines.length + let m, h + + for (var i = 0; i < len; ++i) { // eslint-disable-line no-var + if (lines[i].length === 0) { continue } + if (lines[i][0] === '\t' || lines[i][0] === ' ') { + // folded header content + // RFC2822 says to just remove the CRLF and not the whitespace following + // it, so we follow the RFC and include the leading whitespace ... + if (h) { + this.header[h][this.header[h].length - 1] += lines[i] + continue + } + } + + const posColon = lines[i].indexOf(':') + if ( + posColon === -1 || + posColon === 0 + ) { + return + } + m = RE_HDR.exec(lines[i]) + h = m[1].toLowerCase() + this.header[h] = this.header[h] || [] + this.header[h].push((m[2] || '')) + if (++this.npairs === this.maxHeaderPairs) { break } + } +} + +module.exports = HeaderParser + + +/***/ }), + +/***/ 612: +/***/ ((module, __unused_webpack_exports, __nccwpck_require__) => { + + + +const inherits = (__nccwpck_require__(7975).inherits) +const ReadableStream = (__nccwpck_require__(7075).Readable) + +function PartStream (opts) { + ReadableStream.call(this, opts) +} +inherits(PartStream, ReadableStream) + +PartStream.prototype._read = function (n) {} + +module.exports = PartStream + + +/***/ }), + +/***/ 4136: +/***/ ((module, __unused_webpack_exports, __nccwpck_require__) => { + + + +/** + * Copyright Brian White. All rights reserved. + * + * @see https://github.com/mscdex/streamsearch + * + * Permission is hereby granted, free of charge, to any person obtaining a copy + * of this software and associated documentation files (the "Software"), to + * deal in the Software without restriction, including without limitation the + * rights to use, copy, modify, merge, publish, distribute, sublicense, and/or + * sell copies of the Software, and to permit persons to whom the Software is + * furnished to do so, subject to the following conditions: + * + * The above copyright notice and this permission notice shall be included in + * all copies or substantial portions of the Software. + * + * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR + * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, + * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE + * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER + * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING + * FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS + * IN THE SOFTWARE. + * + * Based heavily on the Streaming Boyer-Moore-Horspool C++ implementation + * by Hongli Lai at: https://github.com/FooBarWidget/boyer-moore-horspool + */ +const EventEmitter = (__nccwpck_require__(8474).EventEmitter) +const inherits = (__nccwpck_require__(7975).inherits) + +function SBMH (needle) { + if (typeof needle === 'string') { + needle = Buffer.from(needle) + } + + if (!Buffer.isBuffer(needle)) { + throw new TypeError('The needle has to be a String or a Buffer.') + } + + const needleLength = needle.length + + if (needleLength === 0) { + throw new Error('The needle cannot be an empty String/Buffer.') + } + + if (needleLength > 256) { + throw new Error('The needle cannot have a length bigger than 256.') + } + + this.maxMatches = Infinity + this.matches = 0 + + this._occ = new Array(256) + .fill(needleLength) // Initialize occurrence table. + this._lookbehind_size = 0 + this._needle = needle + this._bufpos = 0 + + this._lookbehind = Buffer.alloc(needleLength) + + // Populate occurrence table with analysis of the needle, + // ignoring last letter. + for (var i = 0; i < needleLength - 1; ++i) { // eslint-disable-line no-var + this._occ[needle[i]] = needleLength - 1 - i + } +} +inherits(SBMH, EventEmitter) + +SBMH.prototype.reset = function () { + this._lookbehind_size = 0 + this.matches = 0 + this._bufpos = 0 +} + +SBMH.prototype.push = function (chunk, pos) { + if (!Buffer.isBuffer(chunk)) { + chunk = Buffer.from(chunk, 'binary') + } + const chlen = chunk.length + this._bufpos = pos || 0 + let r + while (r !== chlen && this.matches < this.maxMatches) { r = this._sbmh_feed(chunk) } + return r +} + +SBMH.prototype._sbmh_feed = function (data) { + const len = data.length + const needle = this._needle + const needleLength = needle.length + const lastNeedleChar = needle[needleLength - 1] + + // Positive: points to a position in `data` + // pos == 3 points to data[3] + // Negative: points to a position in the lookbehind buffer + // pos == -2 points to lookbehind[lookbehind_size - 2] + let pos = -this._lookbehind_size + let ch + + if (pos < 0) { + // Lookbehind buffer is not empty. Perform Boyer-Moore-Horspool + // search with character lookup code that considers both the + // lookbehind buffer and the current round's haystack data. + // + // Loop until + // there is a match. + // or until + // we've moved past the position that requires the + // lookbehind buffer. In this case we switch to the + // optimized loop. + // or until + // the character to look at lies outside the haystack. + while (pos < 0 && pos <= len - needleLength) { + ch = this._sbmh_lookup_char(data, pos + needleLength - 1) + + if ( + ch === lastNeedleChar && + this._sbmh_memcmp(data, pos, needleLength - 1) + ) { + this._lookbehind_size = 0 + ++this.matches + this.emit('info', true) + + return (this._bufpos = pos + needleLength) + } + pos += this._occ[ch] + } + + // No match. + + if (pos < 0) { + // There's too few data for Boyer-Moore-Horspool to run, + // so let's use a different algorithm to skip as much as + // we can. + // Forward pos until + // the trailing part of lookbehind + data + // looks like the beginning of the needle + // or until + // pos == 0 + while (pos < 0 && !this._sbmh_memcmp(data, pos, len - pos)) { ++pos } + } + + if (pos >= 0) { + // Discard lookbehind buffer. + this.emit('info', false, this._lookbehind, 0, this._lookbehind_size) + this._lookbehind_size = 0 + } else { + // Cut off part of the lookbehind buffer that has + // been processed and append the entire haystack + // into it. + const bytesToCutOff = this._lookbehind_size + pos + if (bytesToCutOff > 0) { + // The cut off data is guaranteed not to contain the needle. + this.emit('info', false, this._lookbehind, 0, bytesToCutOff) + } + + this._lookbehind.copy(this._lookbehind, 0, bytesToCutOff, + this._lookbehind_size - bytesToCutOff) + this._lookbehind_size -= bytesToCutOff + + data.copy(this._lookbehind, this._lookbehind_size) + this._lookbehind_size += len + + this._bufpos = len + return len + } + } + + pos += (pos >= 0) * this._bufpos + + // Lookbehind buffer is now empty. We only need to check if the + // needle is in the haystack. + if (data.indexOf(needle, pos) !== -1) { + pos = data.indexOf(needle, pos) + ++this.matches + if (pos > 0) { this.emit('info', true, data, this._bufpos, pos) } else { this.emit('info', true) } + + return (this._bufpos = pos + needleLength) + } else { + pos = len - needleLength + } + + // There was no match. If there's trailing haystack data that we cannot + // match yet using the Boyer-Moore-Horspool algorithm (because the trailing + // data is less than the needle size) then match using a modified + // algorithm that starts matching from the beginning instead of the end. + // Whatever trailing data is left after running this algorithm is added to + // the lookbehind buffer. + while ( + pos < len && + ( + data[pos] !== needle[0] || + ( + (Buffer.compare( + data.subarray(pos, pos + len - pos), + needle.subarray(0, len - pos) + ) !== 0) + ) + ) + ) { + ++pos + } + if (pos < len) { + data.copy(this._lookbehind, 0, pos, pos + (len - pos)) + this._lookbehind_size = len - pos + } + + // Everything until pos is guaranteed not to contain needle data. + if (pos > 0) { this.emit('info', false, data, this._bufpos, pos < len ? pos : len) } + + this._bufpos = len + return len +} + +SBMH.prototype._sbmh_lookup_char = function (data, pos) { + return (pos < 0) + ? this._lookbehind[this._lookbehind_size + pos] + : data[pos] +} + +SBMH.prototype._sbmh_memcmp = function (data, pos, len) { + for (var i = 0; i < len; ++i) { // eslint-disable-line no-var + if (this._sbmh_lookup_char(data, pos + i) !== this._needle[i]) { return false } + } + return true +} + +module.exports = SBMH + + +/***/ }), + +/***/ 9581: +/***/ ((module, __unused_webpack_exports, __nccwpck_require__) => { + + + +const WritableStream = (__nccwpck_require__(7075).Writable) +const { inherits } = __nccwpck_require__(7975) +const Dicer = __nccwpck_require__(7182) + +const MultipartParser = __nccwpck_require__(1192) +const UrlencodedParser = __nccwpck_require__(855) +const parseParams = __nccwpck_require__(8929) + +function Busboy (opts) { + if (!(this instanceof Busboy)) { return new Busboy(opts) } + + if (typeof opts !== 'object') { + throw new TypeError('Busboy expected an options-Object.') + } + if (typeof opts.headers !== 'object') { + throw new TypeError('Busboy expected an options-Object with headers-attribute.') + } + if (typeof opts.headers['content-type'] !== 'string') { + throw new TypeError('Missing Content-Type-header.') + } + + const { + headers, + ...streamOptions + } = opts + + this.opts = { + autoDestroy: false, + ...streamOptions + } + WritableStream.call(this, this.opts) + + this._done = false + this._parser = this.getParserByHeaders(headers) + this._finished = false +} +inherits(Busboy, WritableStream) + +Busboy.prototype.emit = function (ev) { + if (ev === 'finish') { + if (!this._done) { + this._parser?.end() + return + } else if (this._finished) { + return + } + this._finished = true + } + WritableStream.prototype.emit.apply(this, arguments) +} + +Busboy.prototype.getParserByHeaders = function (headers) { + const parsed = parseParams(headers['content-type']) + + const cfg = { + defCharset: this.opts.defCharset, + fileHwm: this.opts.fileHwm, + headers, + highWaterMark: this.opts.highWaterMark, + isPartAFile: this.opts.isPartAFile, + limits: this.opts.limits, + parsedConType: parsed, + preservePath: this.opts.preservePath + } + + if (MultipartParser.detect.test(parsed[0])) { + return new MultipartParser(this, cfg) + } + if (UrlencodedParser.detect.test(parsed[0])) { + return new UrlencodedParser(this, cfg) + } + throw new Error('Unsupported Content-Type.') +} + +Busboy.prototype._write = function (chunk, encoding, cb) { + this._parser.write(chunk, cb) +} + +module.exports = Busboy +module.exports["default"] = Busboy +module.exports.Busboy = Busboy + +module.exports.Dicer = Dicer + + +/***/ }), + +/***/ 1192: +/***/ ((module, __unused_webpack_exports, __nccwpck_require__) => { + + + +// TODO: +// * support 1 nested multipart level +// (see second multipart example here: +// http://www.w3.org/TR/html401/interact/forms.html#didx-multipartform-data) +// * support limits.fieldNameSize +// -- this will require modifications to utils.parseParams + +const { Readable } = __nccwpck_require__(7075) +const { inherits } = __nccwpck_require__(7975) + +const Dicer = __nccwpck_require__(7182) + +const parseParams = __nccwpck_require__(8929) +const decodeText = __nccwpck_require__(2747) +const basename = __nccwpck_require__(692) +const getLimit = __nccwpck_require__(2393) + +const RE_BOUNDARY = /^boundary$/i +const RE_FIELD = /^form-data$/i +const RE_CHARSET = /^charset$/i +const RE_FILENAME = /^filename$/i +const RE_NAME = /^name$/i + +Multipart.detect = /^multipart\/form-data/i +function Multipart (boy, cfg) { + let i + let len + const self = this + let boundary + const limits = cfg.limits + const isPartAFile = cfg.isPartAFile || ((fieldName, contentType, fileName) => (contentType === 'application/octet-stream' || fileName !== undefined)) + const parsedConType = cfg.parsedConType || [] + const defCharset = cfg.defCharset || 'utf8' + const preservePath = cfg.preservePath + const fileOpts = { highWaterMark: cfg.fileHwm } + + for (i = 0, len = parsedConType.length; i < len; ++i) { + if (Array.isArray(parsedConType[i]) && + RE_BOUNDARY.test(parsedConType[i][0])) { + boundary = parsedConType[i][1] + break + } + } + + function checkFinished () { + if (nends === 0 && finished && !boy._done) { + finished = false + self.end() + } + } + + if (typeof boundary !== 'string') { throw new Error('Multipart: Boundary not found') } + + const fieldSizeLimit = getLimit(limits, 'fieldSize', 1 * 1024 * 1024) + const fileSizeLimit = getLimit(limits, 'fileSize', Infinity) + const filesLimit = getLimit(limits, 'files', Infinity) + const fieldsLimit = getLimit(limits, 'fields', Infinity) + const partsLimit = getLimit(limits, 'parts', Infinity) + const headerPairsLimit = getLimit(limits, 'headerPairs', 2000) + const headerSizeLimit = getLimit(limits, 'headerSize', 80 * 1024) + + let nfiles = 0 + let nfields = 0 + let nends = 0 + let curFile + let curField + let finished = false + + this._needDrain = false + this._pause = false + this._cb = undefined + this._nparts = 0 + this._boy = boy + + const parserCfg = { + boundary, + maxHeaderPairs: headerPairsLimit, + maxHeaderSize: headerSizeLimit, + partHwm: fileOpts.highWaterMark, + highWaterMark: cfg.highWaterMark + } + + this.parser = new Dicer(parserCfg) + this.parser.on('drain', function () { + self._needDrain = false + if (self._cb && !self._pause) { + const cb = self._cb + self._cb = undefined + cb() + } + }).on('part', function onPart (part) { + if (++self._nparts > partsLimit) { + self.parser.removeListener('part', onPart) + self.parser.on('part', skipPart) + boy.hitPartsLimit = true + boy.emit('partsLimit') + return skipPart(part) + } + + // hack because streams2 _always_ doesn't emit 'end' until nextTick, so let + // us emit 'end' early since we know the part has ended if we are already + // seeing the next part + if (curField) { + const field = curField + field.emit('end') + field.removeAllListeners('end') + } + + part.on('header', function (header) { + let contype + let fieldname + let parsed + let charset + let encoding + let filename + let nsize = 0 + + if (header['content-type']) { + parsed = parseParams(header['content-type'][0]) + if (parsed[0]) { + contype = parsed[0].toLowerCase() + for (i = 0, len = parsed.length; i < len; ++i) { + if (RE_CHARSET.test(parsed[i][0])) { + charset = parsed[i][1].toLowerCase() + break + } + } + } + } + + if (contype === undefined) { contype = 'text/plain' } + if (charset === undefined) { charset = defCharset } + + if (header['content-disposition']) { + parsed = parseParams(header['content-disposition'][0]) + if (!RE_FIELD.test(parsed[0])) { return skipPart(part) } + for (i = 0, len = parsed.length; i < len; ++i) { + if (RE_NAME.test(parsed[i][0])) { + fieldname = parsed[i][1] + } else if (RE_FILENAME.test(parsed[i][0])) { + filename = parsed[i][1] + if (!preservePath) { filename = basename(filename) } + } + } + } else { return skipPart(part) } + + if (header['content-transfer-encoding']) { encoding = header['content-transfer-encoding'][0].toLowerCase() } else { encoding = '7bit' } + + let onData, + onEnd + + if (isPartAFile(fieldname, contype, filename)) { + // file/binary field + if (nfiles === filesLimit) { + if (!boy.hitFilesLimit) { + boy.hitFilesLimit = true + boy.emit('filesLimit') + } + return skipPart(part) + } + + ++nfiles + + if (boy.listenerCount('file') === 0) { + self.parser._ignore() + return + } + + ++nends + const file = new FileStream(fileOpts) + curFile = file + file.on('end', function () { + --nends + self._pause = false + checkFinished() + if (self._cb && !self._needDrain) { + const cb = self._cb + self._cb = undefined + cb() + } + }) + file._read = function (n) { + if (!self._pause) { return } + self._pause = false + if (self._cb && !self._needDrain) { + const cb = self._cb + self._cb = undefined + cb() + } + } + boy.emit('file', fieldname, file, filename, encoding, contype) + + onData = function (data) { + if ((nsize += data.length) > fileSizeLimit) { + const extralen = fileSizeLimit - nsize + data.length + if (extralen > 0) { file.push(data.slice(0, extralen)) } + file.truncated = true + file.bytesRead = fileSizeLimit + part.removeAllListeners('data') + file.emit('limit') + return + } else if (!file.push(data)) { self._pause = true } + + file.bytesRead = nsize + } + + onEnd = function () { + curFile = undefined + file.push(null) + } + } else { + // non-file field + if (nfields === fieldsLimit) { + if (!boy.hitFieldsLimit) { + boy.hitFieldsLimit = true + boy.emit('fieldsLimit') + } + return skipPart(part) + } + + ++nfields + ++nends + let buffer = '' + let truncated = false + curField = part + + onData = function (data) { + if ((nsize += data.length) > fieldSizeLimit) { + const extralen = (fieldSizeLimit - (nsize - data.length)) + buffer += data.toString('binary', 0, extralen) + truncated = true + part.removeAllListeners('data') + } else { buffer += data.toString('binary') } + } + + onEnd = function () { + curField = undefined + if (buffer.length) { buffer = decodeText(buffer, 'binary', charset) } + boy.emit('field', fieldname, buffer, false, truncated, encoding, contype) + --nends + checkFinished() + } + } + + /* As of node@2efe4ab761666 (v0.10.29+/v0.11.14+), busboy had become + broken. Streams2/streams3 is a huge black box of confusion, but + somehow overriding the sync state seems to fix things again (and still + seems to work for previous node versions). + */ + part._readableState.sync = false + + part.on('data', onData) + part.on('end', onEnd) + }).on('error', function (err) { + if (curFile) { curFile.emit('error', err) } + }) + }).on('error', function (err) { + boy.emit('error', err) + }).on('finish', function () { + finished = true + checkFinished() + }) +} + +Multipart.prototype.write = function (chunk, cb) { + const r = this.parser.write(chunk) + if (r && !this._pause) { + cb() + } else { + this._needDrain = !r + this._cb = cb + } +} + +Multipart.prototype.end = function () { + const self = this + + if (self.parser.writable) { + self.parser.end() + } else if (!self._boy._done) { + process.nextTick(function () { + self._boy._done = true + self._boy.emit('finish') + }) + } +} + +function skipPart (part) { + part.resume() +} + +function FileStream (opts) { + Readable.call(this, opts) + + this.bytesRead = 0 + + this.truncated = false +} + +inherits(FileStream, Readable) + +FileStream.prototype._read = function (n) {} + +module.exports = Multipart + + +/***/ }), + +/***/ 855: +/***/ ((module, __unused_webpack_exports, __nccwpck_require__) => { + + + +const Decoder = __nccwpck_require__(1496) +const decodeText = __nccwpck_require__(2747) +const getLimit = __nccwpck_require__(2393) + +const RE_CHARSET = /^charset$/i + +UrlEncoded.detect = /^application\/x-www-form-urlencoded/i +function UrlEncoded (boy, cfg) { + const limits = cfg.limits + const parsedConType = cfg.parsedConType + this.boy = boy + + this.fieldSizeLimit = getLimit(limits, 'fieldSize', 1 * 1024 * 1024) + this.fieldNameSizeLimit = getLimit(limits, 'fieldNameSize', 100) + this.fieldsLimit = getLimit(limits, 'fields', Infinity) + + let charset + for (var i = 0, len = parsedConType.length; i < len; ++i) { // eslint-disable-line no-var + if (Array.isArray(parsedConType[i]) && + RE_CHARSET.test(parsedConType[i][0])) { + charset = parsedConType[i][1].toLowerCase() + break + } + } + + if (charset === undefined) { charset = cfg.defCharset || 'utf8' } + + this.decoder = new Decoder() + this.charset = charset + this._fields = 0 + this._state = 'key' + this._checkingBytes = true + this._bytesKey = 0 + this._bytesVal = 0 + this._key = '' + this._val = '' + this._keyTrunc = false + this._valTrunc = false + this._hitLimit = false +} + +UrlEncoded.prototype.write = function (data, cb) { + if (this._fields === this.fieldsLimit) { + if (!this.boy.hitFieldsLimit) { + this.boy.hitFieldsLimit = true + this.boy.emit('fieldsLimit') + } + return cb() + } + + let idxeq; let idxamp; let i; let p = 0; const len = data.length + + while (p < len) { + if (this._state === 'key') { + idxeq = idxamp = undefined + for (i = p; i < len; ++i) { + if (!this._checkingBytes) { ++p } + if (data[i] === 0x3D/* = */) { + idxeq = i + break + } else if (data[i] === 0x26/* & */) { + idxamp = i + break + } + if (this._checkingBytes && this._bytesKey === this.fieldNameSizeLimit) { + this._hitLimit = true + break + } else if (this._checkingBytes) { ++this._bytesKey } + } + + if (idxeq !== undefined) { + // key with assignment + if (idxeq > p) { this._key += this.decoder.write(data.toString('binary', p, idxeq)) } + this._state = 'val' + + this._hitLimit = false + this._checkingBytes = true + this._val = '' + this._bytesVal = 0 + this._valTrunc = false + this.decoder.reset() + + p = idxeq + 1 + } else if (idxamp !== undefined) { + // key with no assignment + ++this._fields + let key; const keyTrunc = this._keyTrunc + if (idxamp > p) { key = (this._key += this.decoder.write(data.toString('binary', p, idxamp))) } else { key = this._key } + + this._hitLimit = false + this._checkingBytes = true + this._key = '' + this._bytesKey = 0 + this._keyTrunc = false + this.decoder.reset() + + if (key.length) { + this.boy.emit('field', decodeText(key, 'binary', this.charset), + '', + keyTrunc, + false) + } + + p = idxamp + 1 + if (this._fields === this.fieldsLimit) { return cb() } + } else if (this._hitLimit) { + // we may not have hit the actual limit if there are encoded bytes... + if (i > p) { this._key += this.decoder.write(data.toString('binary', p, i)) } + p = i + if ((this._bytesKey = this._key.length) === this.fieldNameSizeLimit) { + // yep, we actually did hit the limit + this._checkingBytes = false + this._keyTrunc = true + } + } else { + if (p < len) { this._key += this.decoder.write(data.toString('binary', p)) } + p = len + } + } else { + idxamp = undefined + for (i = p; i < len; ++i) { + if (!this._checkingBytes) { ++p } + if (data[i] === 0x26/* & */) { + idxamp = i + break + } + if (this._checkingBytes && this._bytesVal === this.fieldSizeLimit) { + this._hitLimit = true + break + } else if (this._checkingBytes) { ++this._bytesVal } + } + + if (idxamp !== undefined) { + ++this._fields + if (idxamp > p) { this._val += this.decoder.write(data.toString('binary', p, idxamp)) } + this.boy.emit('field', decodeText(this._key, 'binary', this.charset), + decodeText(this._val, 'binary', this.charset), + this._keyTrunc, + this._valTrunc) + this._state = 'key' + + this._hitLimit = false + this._checkingBytes = true + this._key = '' + this._bytesKey = 0 + this._keyTrunc = false + this.decoder.reset() + + p = idxamp + 1 + if (this._fields === this.fieldsLimit) { return cb() } + } else if (this._hitLimit) { + // we may not have hit the actual limit if there are encoded bytes... + if (i > p) { this._val += this.decoder.write(data.toString('binary', p, i)) } + p = i + if ((this._val === '' && this.fieldSizeLimit === 0) || + (this._bytesVal = this._val.length) === this.fieldSizeLimit) { + // yep, we actually did hit the limit + this._checkingBytes = false + this._valTrunc = true + } + } else { + if (p < len) { this._val += this.decoder.write(data.toString('binary', p)) } + p = len + } + } + } + cb() +} + +UrlEncoded.prototype.end = function () { + if (this.boy._done) { return } + + if (this._state === 'key' && this._key.length > 0) { + this.boy.emit('field', decodeText(this._key, 'binary', this.charset), + '', + this._keyTrunc, + false) + } else if (this._state === 'val') { + this.boy.emit('field', decodeText(this._key, 'binary', this.charset), + decodeText(this._val, 'binary', this.charset), + this._keyTrunc, + this._valTrunc) + } + this.boy._done = true + this.boy.emit('finish') +} + +module.exports = UrlEncoded + + +/***/ }), + +/***/ 1496: +/***/ ((module) => { + + + +const RE_PLUS = /\+/g + +const HEX = [ + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0, + 0, 1, 1, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 1, 1, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0 +] + +function Decoder () { + this.buffer = undefined +} +Decoder.prototype.write = function (str) { + // Replace '+' with ' ' before decoding + str = str.replace(RE_PLUS, ' ') + let res = '' + let i = 0; let p = 0; const len = str.length + for (; i < len; ++i) { + if (this.buffer !== undefined) { + if (!HEX[str.charCodeAt(i)]) { + res += '%' + this.buffer + this.buffer = undefined + --i // retry character + } else { + this.buffer += str[i] + ++p + if (this.buffer.length === 2) { + res += String.fromCharCode(parseInt(this.buffer, 16)) + this.buffer = undefined + } + } + } else if (str[i] === '%') { + if (i > p) { + res += str.substring(p, i) + p = i + } + this.buffer = '' + ++p + } + } + if (p < len && this.buffer === undefined) { res += str.substring(p) } + return res +} +Decoder.prototype.reset = function () { + this.buffer = undefined +} + +module.exports = Decoder + + +/***/ }), + +/***/ 692: +/***/ ((module) => { + + + +module.exports = function basename (path) { + if (typeof path !== 'string') { return '' } + for (var i = path.length - 1; i >= 0; --i) { // eslint-disable-line no-var + switch (path.charCodeAt(i)) { + case 0x2F: // '/' + case 0x5C: // '\' + path = path.slice(i + 1) + return (path === '..' || path === '.' ? '' : path) + } + } + return (path === '..' || path === '.' ? '' : path) +} + + +/***/ }), + +/***/ 2747: +/***/ (function(module) { + + + +// Node has always utf-8 +const utf8Decoder = new TextDecoder('utf-8') +const textDecoders = new Map([ + ['utf-8', utf8Decoder], + ['utf8', utf8Decoder] +]) + +function getDecoder (charset) { + let lc + while (true) { + switch (charset) { + case 'utf-8': + case 'utf8': + return decoders.utf8 + case 'latin1': + case 'ascii': // TODO: Make these a separate, strict decoder? + case 'us-ascii': + case 'iso-8859-1': + case 'iso8859-1': + case 'iso88591': + case 'iso_8859-1': + case 'windows-1252': + case 'iso_8859-1:1987': + case 'cp1252': + case 'x-cp1252': + return decoders.latin1 + case 'utf16le': + case 'utf-16le': + case 'ucs2': + case 'ucs-2': + return decoders.utf16le + case 'base64': + return decoders.base64 + default: + if (lc === undefined) { + lc = true + charset = charset.toLowerCase() + continue + } + return decoders.other.bind(charset) + } + } +} + +const decoders = { + utf8: (data, sourceEncoding) => { + if (data.length === 0) { + return '' + } + if (typeof data === 'string') { + data = Buffer.from(data, sourceEncoding) + } + return data.utf8Slice(0, data.length) + }, + + latin1: (data, sourceEncoding) => { + if (data.length === 0) { + return '' + } + if (typeof data === 'string') { + return data + } + return data.latin1Slice(0, data.length) + }, + + utf16le: (data, sourceEncoding) => { + if (data.length === 0) { + return '' + } + if (typeof data === 'string') { + data = Buffer.from(data, sourceEncoding) + } + return data.ucs2Slice(0, data.length) + }, + + base64: (data, sourceEncoding) => { + if (data.length === 0) { + return '' + } + if (typeof data === 'string') { + data = Buffer.from(data, sourceEncoding) + } + return data.base64Slice(0, data.length) + }, + + other: (data, sourceEncoding) => { + if (data.length === 0) { + return '' + } + if (typeof data === 'string') { + data = Buffer.from(data, sourceEncoding) + } + + if (textDecoders.has(this.toString())) { + try { + return textDecoders.get(this).decode(data) + } catch {} + } + return typeof data === 'string' + ? data + : data.toString() + } +} + +function decodeText (text, sourceEncoding, destEncoding) { + if (text) { + return getDecoder(destEncoding)(text, sourceEncoding) + } + return text +} + +module.exports = decodeText + + +/***/ }), + +/***/ 2393: +/***/ ((module) => { + + + +module.exports = function getLimit (limits, name, defaultLimit) { + if ( + !limits || + limits[name] === undefined || + limits[name] === null + ) { return defaultLimit } + + if ( + typeof limits[name] !== 'number' || + isNaN(limits[name]) + ) { throw new TypeError('Limit ' + name + ' is not a valid number') } + + return limits[name] +} + + +/***/ }), + +/***/ 8929: +/***/ ((module, __unused_webpack_exports, __nccwpck_require__) => { + +/* eslint-disable object-property-newline */ + + +const decodeText = __nccwpck_require__(2747) + +const RE_ENCODED = /%[a-fA-F0-9][a-fA-F0-9]/g + +const EncodedLookup = { + '%00': '\x00', '%01': '\x01', '%02': '\x02', '%03': '\x03', '%04': '\x04', + '%05': '\x05', '%06': '\x06', '%07': '\x07', '%08': '\x08', '%09': '\x09', + '%0a': '\x0a', '%0A': '\x0a', '%0b': '\x0b', '%0B': '\x0b', '%0c': '\x0c', + '%0C': '\x0c', '%0d': '\x0d', '%0D': '\x0d', '%0e': '\x0e', '%0E': '\x0e', + '%0f': '\x0f', '%0F': '\x0f', '%10': '\x10', '%11': '\x11', '%12': '\x12', + '%13': '\x13', '%14': '\x14', '%15': '\x15', '%16': '\x16', '%17': '\x17', + '%18': '\x18', '%19': '\x19', '%1a': '\x1a', '%1A': '\x1a', '%1b': '\x1b', + '%1B': '\x1b', '%1c': '\x1c', '%1C': '\x1c', '%1d': '\x1d', '%1D': '\x1d', + '%1e': '\x1e', '%1E': '\x1e', '%1f': '\x1f', '%1F': '\x1f', '%20': '\x20', + '%21': '\x21', '%22': '\x22', '%23': '\x23', '%24': '\x24', '%25': '\x25', + '%26': '\x26', '%27': '\x27', '%28': '\x28', '%29': '\x29', '%2a': '\x2a', + '%2A': '\x2a', '%2b': '\x2b', '%2B': '\x2b', '%2c': '\x2c', '%2C': '\x2c', + '%2d': '\x2d', '%2D': '\x2d', '%2e': '\x2e', '%2E': '\x2e', '%2f': '\x2f', + '%2F': '\x2f', '%30': '\x30', '%31': '\x31', '%32': '\x32', '%33': '\x33', + '%34': '\x34', '%35': '\x35', '%36': '\x36', '%37': '\x37', '%38': '\x38', + '%39': '\x39', '%3a': '\x3a', '%3A': '\x3a', '%3b': '\x3b', '%3B': '\x3b', + '%3c': '\x3c', '%3C': '\x3c', '%3d': '\x3d', '%3D': '\x3d', '%3e': '\x3e', + '%3E': '\x3e', '%3f': '\x3f', '%3F': '\x3f', '%40': '\x40', '%41': '\x41', + '%42': '\x42', '%43': '\x43', '%44': '\x44', '%45': '\x45', '%46': '\x46', + '%47': '\x47', '%48': '\x48', '%49': '\x49', '%4a': '\x4a', '%4A': '\x4a', + '%4b': '\x4b', '%4B': '\x4b', '%4c': '\x4c', '%4C': '\x4c', '%4d': '\x4d', + '%4D': '\x4d', '%4e': '\x4e', '%4E': '\x4e', '%4f': '\x4f', '%4F': '\x4f', + '%50': '\x50', '%51': '\x51', '%52': '\x52', '%53': '\x53', '%54': '\x54', + '%55': '\x55', '%56': '\x56', '%57': '\x57', '%58': '\x58', '%59': '\x59', + '%5a': '\x5a', '%5A': '\x5a', '%5b': '\x5b', '%5B': '\x5b', '%5c': '\x5c', + '%5C': '\x5c', '%5d': '\x5d', '%5D': '\x5d', '%5e': '\x5e', '%5E': '\x5e', + '%5f': '\x5f', '%5F': '\x5f', '%60': '\x60', '%61': '\x61', '%62': '\x62', + '%63': '\x63', '%64': '\x64', '%65': '\x65', '%66': '\x66', '%67': '\x67', + '%68': '\x68', '%69': '\x69', '%6a': '\x6a', '%6A': '\x6a', '%6b': '\x6b', + '%6B': '\x6b', '%6c': '\x6c', '%6C': '\x6c', '%6d': '\x6d', '%6D': '\x6d', + '%6e': '\x6e', '%6E': '\x6e', '%6f': '\x6f', '%6F': '\x6f', '%70': '\x70', + '%71': '\x71', '%72': '\x72', '%73': '\x73', '%74': '\x74', '%75': '\x75', + '%76': '\x76', '%77': '\x77', '%78': '\x78', '%79': '\x79', '%7a': '\x7a', + '%7A': '\x7a', '%7b': '\x7b', '%7B': '\x7b', '%7c': '\x7c', '%7C': '\x7c', + '%7d': '\x7d', '%7D': '\x7d', '%7e': '\x7e', '%7E': '\x7e', '%7f': '\x7f', + '%7F': '\x7f', '%80': '\x80', '%81': '\x81', '%82': '\x82', '%83': '\x83', + '%84': '\x84', '%85': '\x85', '%86': '\x86', '%87': '\x87', '%88': '\x88', + '%89': '\x89', '%8a': '\x8a', '%8A': '\x8a', '%8b': '\x8b', '%8B': '\x8b', + '%8c': '\x8c', '%8C': '\x8c', '%8d': '\x8d', '%8D': '\x8d', '%8e': '\x8e', + '%8E': '\x8e', '%8f': '\x8f', '%8F': '\x8f', '%90': '\x90', '%91': '\x91', + '%92': '\x92', '%93': '\x93', '%94': '\x94', '%95': '\x95', '%96': '\x96', + '%97': '\x97', '%98': '\x98', '%99': '\x99', '%9a': '\x9a', '%9A': '\x9a', + '%9b': '\x9b', '%9B': '\x9b', '%9c': '\x9c', '%9C': '\x9c', '%9d': '\x9d', + '%9D': '\x9d', '%9e': '\x9e', '%9E': '\x9e', '%9f': '\x9f', '%9F': '\x9f', + '%a0': '\xa0', '%A0': '\xa0', '%a1': '\xa1', '%A1': '\xa1', '%a2': '\xa2', + '%A2': '\xa2', '%a3': '\xa3', '%A3': '\xa3', '%a4': '\xa4', '%A4': '\xa4', + '%a5': '\xa5', '%A5': '\xa5', '%a6': '\xa6', '%A6': '\xa6', '%a7': '\xa7', + '%A7': '\xa7', '%a8': '\xa8', '%A8': '\xa8', '%a9': '\xa9', '%A9': '\xa9', + '%aa': '\xaa', '%Aa': '\xaa', '%aA': '\xaa', '%AA': '\xaa', '%ab': '\xab', + '%Ab': '\xab', '%aB': '\xab', '%AB': '\xab', '%ac': '\xac', '%Ac': '\xac', + '%aC': '\xac', '%AC': '\xac', '%ad': '\xad', '%Ad': '\xad', '%aD': '\xad', + '%AD': '\xad', '%ae': '\xae', '%Ae': '\xae', '%aE': '\xae', '%AE': '\xae', + '%af': '\xaf', '%Af': '\xaf', '%aF': '\xaf', '%AF': '\xaf', '%b0': '\xb0', + '%B0': '\xb0', '%b1': '\xb1', '%B1': '\xb1', '%b2': '\xb2', '%B2': '\xb2', + '%b3': '\xb3', '%B3': '\xb3', '%b4': '\xb4', '%B4': '\xb4', '%b5': '\xb5', + '%B5': '\xb5', '%b6': '\xb6', '%B6': '\xb6', '%b7': '\xb7', '%B7': '\xb7', + '%b8': '\xb8', '%B8': '\xb8', '%b9': '\xb9', '%B9': '\xb9', '%ba': '\xba', + '%Ba': '\xba', '%bA': '\xba', '%BA': '\xba', '%bb': '\xbb', '%Bb': '\xbb', + '%bB': '\xbb', '%BB': '\xbb', '%bc': '\xbc', '%Bc': '\xbc', '%bC': '\xbc', + '%BC': '\xbc', '%bd': '\xbd', '%Bd': '\xbd', '%bD': '\xbd', '%BD': '\xbd', + '%be': '\xbe', '%Be': '\xbe', '%bE': '\xbe', '%BE': '\xbe', '%bf': '\xbf', + '%Bf': '\xbf', '%bF': '\xbf', '%BF': '\xbf', '%c0': '\xc0', '%C0': '\xc0', + '%c1': '\xc1', '%C1': '\xc1', '%c2': '\xc2', '%C2': '\xc2', '%c3': '\xc3', + '%C3': '\xc3', '%c4': '\xc4', '%C4': '\xc4', '%c5': '\xc5', '%C5': '\xc5', + '%c6': '\xc6', '%C6': '\xc6', '%c7': '\xc7', '%C7': '\xc7', '%c8': '\xc8', + '%C8': '\xc8', '%c9': '\xc9', '%C9': '\xc9', '%ca': '\xca', '%Ca': '\xca', + '%cA': '\xca', '%CA': '\xca', '%cb': '\xcb', '%Cb': '\xcb', '%cB': '\xcb', + '%CB': '\xcb', '%cc': '\xcc', '%Cc': '\xcc', '%cC': '\xcc', '%CC': '\xcc', + '%cd': '\xcd', '%Cd': '\xcd', '%cD': '\xcd', '%CD': '\xcd', '%ce': '\xce', + '%Ce': '\xce', '%cE': '\xce', '%CE': '\xce', '%cf': '\xcf', '%Cf': '\xcf', + '%cF': '\xcf', '%CF': '\xcf', '%d0': '\xd0', '%D0': '\xd0', '%d1': '\xd1', + '%D1': '\xd1', '%d2': '\xd2', '%D2': '\xd2', '%d3': '\xd3', '%D3': '\xd3', + '%d4': '\xd4', '%D4': '\xd4', '%d5': '\xd5', '%D5': '\xd5', '%d6': '\xd6', + '%D6': '\xd6', '%d7': '\xd7', '%D7': '\xd7', '%d8': '\xd8', '%D8': '\xd8', + '%d9': '\xd9', '%D9': '\xd9', '%da': '\xda', '%Da': '\xda', '%dA': '\xda', + '%DA': '\xda', '%db': '\xdb', '%Db': '\xdb', '%dB': '\xdb', '%DB': '\xdb', + '%dc': '\xdc', '%Dc': '\xdc', '%dC': '\xdc', '%DC': '\xdc', '%dd': '\xdd', + '%Dd': '\xdd', '%dD': '\xdd', '%DD': '\xdd', '%de': '\xde', '%De': '\xde', + '%dE': '\xde', '%DE': '\xde', '%df': '\xdf', '%Df': '\xdf', '%dF': '\xdf', + '%DF': '\xdf', '%e0': '\xe0', '%E0': '\xe0', '%e1': '\xe1', '%E1': '\xe1', + '%e2': '\xe2', '%E2': '\xe2', '%e3': '\xe3', '%E3': '\xe3', '%e4': '\xe4', + '%E4': '\xe4', '%e5': '\xe5', '%E5': '\xe5', '%e6': '\xe6', '%E6': '\xe6', + '%e7': '\xe7', '%E7': '\xe7', '%e8': '\xe8', '%E8': '\xe8', '%e9': '\xe9', + '%E9': '\xe9', '%ea': '\xea', '%Ea': '\xea', '%eA': '\xea', '%EA': '\xea', + '%eb': '\xeb', '%Eb': '\xeb', '%eB': '\xeb', '%EB': '\xeb', '%ec': '\xec', + '%Ec': '\xec', '%eC': '\xec', '%EC': '\xec', '%ed': '\xed', '%Ed': '\xed', + '%eD': '\xed', '%ED': '\xed', '%ee': '\xee', '%Ee': '\xee', '%eE': '\xee', + '%EE': '\xee', '%ef': '\xef', '%Ef': '\xef', '%eF': '\xef', '%EF': '\xef', + '%f0': '\xf0', '%F0': '\xf0', '%f1': '\xf1', '%F1': '\xf1', '%f2': '\xf2', + '%F2': '\xf2', '%f3': '\xf3', '%F3': '\xf3', '%f4': '\xf4', '%F4': '\xf4', + '%f5': '\xf5', '%F5': '\xf5', '%f6': '\xf6', '%F6': '\xf6', '%f7': '\xf7', + '%F7': '\xf7', '%f8': '\xf8', '%F8': '\xf8', '%f9': '\xf9', '%F9': '\xf9', + '%fa': '\xfa', '%Fa': '\xfa', '%fA': '\xfa', '%FA': '\xfa', '%fb': '\xfb', + '%Fb': '\xfb', '%fB': '\xfb', '%FB': '\xfb', '%fc': '\xfc', '%Fc': '\xfc', + '%fC': '\xfc', '%FC': '\xfc', '%fd': '\xfd', '%Fd': '\xfd', '%fD': '\xfd', + '%FD': '\xfd', '%fe': '\xfe', '%Fe': '\xfe', '%fE': '\xfe', '%FE': '\xfe', + '%ff': '\xff', '%Ff': '\xff', '%fF': '\xff', '%FF': '\xff' +} + +function encodedReplacer (match) { + return EncodedLookup[match] +} + +const STATE_KEY = 0 +const STATE_VALUE = 1 +const STATE_CHARSET = 2 +const STATE_LANG = 3 + +function parseParams (str) { + const res = [] + let state = STATE_KEY + let charset = '' + let inquote = false + let escaping = false + let p = 0 + let tmp = '' + const len = str.length + + for (var i = 0; i < len; ++i) { // eslint-disable-line no-var + const char = str[i] + if (char === '\\' && inquote) { + if (escaping) { escaping = false } else { + escaping = true + continue + } + } else if (char === '"') { + if (!escaping) { + if (inquote) { + inquote = false + state = STATE_KEY + } else { inquote = true } + continue + } else { escaping = false } + } else { + if (escaping && inquote) { tmp += '\\' } + escaping = false + if ((state === STATE_CHARSET || state === STATE_LANG) && char === "'") { + if (state === STATE_CHARSET) { + state = STATE_LANG + charset = tmp.substring(1) + } else { state = STATE_VALUE } + tmp = '' + continue + } else if (state === STATE_KEY && + (char === '*' || char === '=') && + res.length) { + state = char === '*' + ? STATE_CHARSET + : STATE_VALUE + res[p] = [tmp, undefined] + tmp = '' + continue + } else if (!inquote && char === ';') { + state = STATE_KEY + if (charset) { + if (tmp.length) { + tmp = decodeText(tmp.replace(RE_ENCODED, encodedReplacer), + 'binary', + charset) + } + charset = '' + } else if (tmp.length) { + tmp = decodeText(tmp, 'binary', 'utf8') + } + if (res[p] === undefined) { res[p] = tmp } else { res[p][1] = tmp } + tmp = '' + ++p + continue + } else if (!inquote && (char === ' ' || char === '\t')) { continue } + } + tmp += char + } + if (charset && tmp.length) { + tmp = decodeText(tmp.replace(RE_ENCODED, encodedReplacer), + 'binary', + charset) + } else if (tmp) { + tmp = decodeText(tmp, 'binary', 'utf8') + } + + if (res[p] === undefined) { + if (tmp) { res[p] = tmp } + } else { res[p][1] = tmp } + + return res +} + +module.exports = parseParams + + +/***/ }) + +/******/ }); +/************************************************************************/ +/******/ // The module cache +/******/ var __webpack_module_cache__ = {}; +/******/ +/******/ // The require function +/******/ function __nccwpck_require__(moduleId) { +/******/ // Check if module is in cache +/******/ var cachedModule = __webpack_module_cache__[moduleId]; +/******/ if (cachedModule !== undefined) { +/******/ return cachedModule.exports; +/******/ } +/******/ // Create a new module (and put it into the cache) +/******/ var module = __webpack_module_cache__[moduleId] = { +/******/ // no module.id needed +/******/ // no module.loaded needed +/******/ exports: {} +/******/ }; +/******/ +/******/ // Execute the module function +/******/ var threw = true; +/******/ try { +/******/ __webpack_modules__[moduleId].call(module.exports, module, module.exports, __nccwpck_require__); +/******/ threw = false; +/******/ } finally { +/******/ if(threw) delete __webpack_module_cache__[moduleId]; +/******/ } +/******/ +/******/ // Return the exports of the module +/******/ return module.exports; +/******/ } +/******/ +/************************************************************************/ +/******/ /* webpack/runtime/compat */ +/******/ +/******/ if (typeof __nccwpck_require__ !== 'undefined') __nccwpck_require__.ab = new URL('.', import.meta.url).pathname.slice(import.meta.url.match(/^file:\/\/\/\w:/) ? 1 : 0, -1) + "/"; +/******/ +/************************************************************************/ +var __webpack_exports__ = {}; + +// EXTERNAL MODULE: ./node_modules/@actions/core/lib/core.js +var core = __nccwpck_require__(7484); +// EXTERNAL MODULE: external "util" +var external_util_ = __nccwpck_require__(9023); +// EXTERNAL MODULE: external "child_process" +var external_child_process_ = __nccwpck_require__(5317); +;// CONCATENATED MODULE: ./node_modules/@bufbuild/protobuf/dist/esm/service-type.js +// Copyright 2021-2024 Buf Technologies, Inc. +// +// Licensed under the Apache License, Version 2.0 (the "License"); +// you may not use this file except in compliance with the License. +// You may obtain a copy of the License at +// +// http://www.apache.org/licenses/LICENSE-2.0 +// +// Unless required by applicable law or agreed to in writing, software +// distributed under the License is distributed on an "AS IS" BASIS, +// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. +// See the License for the specific language governing permissions and +// limitations under the License. +/** + * MethodKind represents the four method types that can be declared in + * protobuf with the `stream` keyword: + * + * 1. Unary: rpc (Input) returns (Output) + * 2. ServerStreaming: rpc (Input) returns (stream Output) + * 3. ClientStreaming: rpc (stream Input) returns (Output) + * 4. BiDiStreaming: rpc (stream Input) returns (stream Output) + */ +var MethodKind; +(function (MethodKind) { + MethodKind[MethodKind["Unary"] = 0] = "Unary"; + MethodKind[MethodKind["ServerStreaming"] = 1] = "ServerStreaming"; + MethodKind[MethodKind["ClientStreaming"] = 2] = "ClientStreaming"; + MethodKind[MethodKind["BiDiStreaming"] = 3] = "BiDiStreaming"; +})(MethodKind || (MethodKind = {})); +/** + * Is this method side-effect-free (or safe in HTTP parlance), or just + * idempotent, or neither? HTTP based RPC implementation may choose GET verb + * for safe methods, and PUT verb for idempotent methods instead of the + * default POST. + * + * This enum matches the protobuf enum google.protobuf.MethodOptions.IdempotencyLevel, + * defined in the well-known type google/protobuf/descriptor.proto, but + * drops UNKNOWN. + */ +var MethodIdempotency; +(function (MethodIdempotency) { + /** + * Idempotent, no side effects. + */ + MethodIdempotency[MethodIdempotency["NoSideEffects"] = 1] = "NoSideEffects"; + /** + * Idempotent, but may have side effects. + */ + MethodIdempotency[MethodIdempotency["Idempotent"] = 2] = "Idempotent"; +})(MethodIdempotency || (MethodIdempotency = {})); + +;// CONCATENATED MODULE: ./node_modules/@connectrpc/connect/dist/esm/any-client.js +// Copyright 2021-2024 The Connect Authors +// +// Licensed under the Apache License, Version 2.0 (the "License"); +// you may not use this file except in compliance with the License. +// You may obtain a copy of the License at +// +// http://www.apache.org/licenses/LICENSE-2.0 +// +// Unless required by applicable law or agreed to in writing, software +// distributed under the License is distributed on an "AS IS" BASIS, +// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. +// See the License for the specific language governing permissions and +// limitations under the License. +/** + * Create any client for the given service. + * + * The given createMethod function is called for each method definition + * of the service. The function it returns is added to the client object + * as a method. + */ +function makeAnyClient(service, createMethod) { + const client = {}; + for (const [localName, methodInfo] of Object.entries(service.methods)) { + const method = createMethod(Object.assign(Object.assign({}, methodInfo), { localName, + service })); + if (method != null) { + client[localName] = method; + } + } + return client; +} + +;// CONCATENATED MODULE: ./node_modules/@connectrpc/connect/dist/esm/code.js +// Copyright 2021-2024 The Connect Authors +// +// Licensed under the Apache License, Version 2.0 (the "License"); +// you may not use this file except in compliance with the License. +// You may obtain a copy of the License at +// +// http://www.apache.org/licenses/LICENSE-2.0 +// +// Unless required by applicable law or agreed to in writing, software +// distributed under the License is distributed on an "AS IS" BASIS, +// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. +// See the License for the specific language governing permissions and +// limitations under the License. +/** + * Connect represents categories of errors as codes, and each code maps to a + * specific HTTP status code. The codes and their semantics were chosen to + * match gRPC. Only the codes below are valid — there are no user-defined + * codes. + * + * See the specification at https://connectrpc.com/docs/protocol#error-codes + * for details. + */ +var code_Code; +(function (Code) { + /** + * Canceled, usually be the user + */ + Code[Code["Canceled"] = 1] = "Canceled"; + /** + * Unknown error + */ + Code[Code["Unknown"] = 2] = "Unknown"; + /** + * Argument invalid regardless of system state + */ + Code[Code["InvalidArgument"] = 3] = "InvalidArgument"; + /** + * Operation expired, may or may not have completed. + */ + Code[Code["DeadlineExceeded"] = 4] = "DeadlineExceeded"; + /** + * Entity not found. + */ + Code[Code["NotFound"] = 5] = "NotFound"; + /** + * Entity already exists. + */ + Code[Code["AlreadyExists"] = 6] = "AlreadyExists"; + /** + * Operation not authorized. + */ + Code[Code["PermissionDenied"] = 7] = "PermissionDenied"; + /** + * Quota exhausted. + */ + Code[Code["ResourceExhausted"] = 8] = "ResourceExhausted"; + /** + * Argument invalid in current system state. + */ + Code[Code["FailedPrecondition"] = 9] = "FailedPrecondition"; + /** + * Operation aborted. + */ + Code[Code["Aborted"] = 10] = "Aborted"; + /** + * Out of bounds, use instead of FailedPrecondition. + */ + Code[Code["OutOfRange"] = 11] = "OutOfRange"; + /** + * Operation not implemented or disabled. + */ + Code[Code["Unimplemented"] = 12] = "Unimplemented"; + /** + * Internal error, reserved for "serious errors". + */ + Code[Code["Internal"] = 13] = "Internal"; + /** + * Unavailable, client should back off and retry. + */ + Code[Code["Unavailable"] = 14] = "Unavailable"; + /** + * Unrecoverable data loss or corruption. + */ + Code[Code["DataLoss"] = 15] = "DataLoss"; + /** + * Request isn't authenticated. + */ + Code[Code["Unauthenticated"] = 16] = "Unauthenticated"; +})(code_Code || (code_Code = {})); + +;// CONCATENATED MODULE: ./node_modules/@connectrpc/connect/dist/esm/protocol-connect/code-string.js +// Copyright 2021-2024 The Connect Authors +// +// Licensed under the Apache License, Version 2.0 (the "License"); +// you may not use this file except in compliance with the License. +// You may obtain a copy of the License at +// +// http://www.apache.org/licenses/LICENSE-2.0 +// +// Unless required by applicable law or agreed to in writing, software +// distributed under the License is distributed on an "AS IS" BASIS, +// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. +// See the License for the specific language governing permissions and +// limitations under the License. + +/** + * codeToString returns the string representation of a Code. + * + * @private Internal code, does not follow semantic versioning. + */ +function codeToString(value) { + const name = code_Code[value]; + if (typeof name != "string") { + return value.toString(); + } + return (name[0].toLowerCase() + + name.substring(1).replace(/[A-Z]/g, (c) => "_" + c.toLowerCase())); +} +let stringToCode; +/** + * codeFromString parses the string representation of a Code in snake_case. + * For example, the string "permission_denied" parses into Code.PermissionDenied. + * + * If the given string cannot be parsed, the function returns undefined. + * + * @private Internal code, does not follow semantic versioning. + */ +function codeFromString(value) { + if (!stringToCode) { + stringToCode = {}; + for (const value of Object.values(Code)) { + if (typeof value == "string") { + continue; + } + stringToCode[codeToString(value)] = value; + } + } + return stringToCode[value]; +} + +;// CONCATENATED MODULE: ./node_modules/@connectrpc/connect/dist/esm/connect-error.js +// Copyright 2021-2024 The Connect Authors +// +// Licensed under the Apache License, Version 2.0 (the "License"); +// you may not use this file except in compliance with the License. +// You may obtain a copy of the License at +// +// http://www.apache.org/licenses/LICENSE-2.0 +// +// Unless required by applicable law or agreed to in writing, software +// distributed under the License is distributed on an "AS IS" BASIS, +// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. +// See the License for the specific language governing permissions and +// limitations under the License. + + +/** + * ConnectError captures four pieces of information: a Code, an error + * message, an optional cause of the error, and an optional collection of + * arbitrary Protobuf messages called "details". + * + * Because developer tools typically show just the error message, we prefix + * it with the status code, so that the most important information is always + * visible immediately. + * + * Error details are wrapped with google.protobuf.Any on the wire, so that + * a server or middleware can attach arbitrary data to an error. Use the + * method findDetails() to retrieve the details. + */ +class connect_error_ConnectError extends Error { + /** + * Create a new ConnectError. + * If no code is provided, code "unknown" is used. + * Outgoing details are only relevant for the server side - a service may + * raise an error with details, and it is up to the protocol implementation + * to encode and send the details along with error. + */ + constructor(message, code = code_Code.Unknown, metadata, outgoingDetails, cause) { + super(createMessage(message, code)); + this.name = "ConnectError"; + // see https://www.typescriptlang.org/docs/handbook/release-notes/typescript-2-2.html#example + Object.setPrototypeOf(this, new.target.prototype); + this.rawMessage = message; + this.code = code; + this.metadata = new Headers(metadata !== null && metadata !== void 0 ? metadata : {}); + this.details = outgoingDetails !== null && outgoingDetails !== void 0 ? outgoingDetails : []; + this.cause = cause; + } + /** + * Convert any value - typically a caught error into a ConnectError, + * following these rules: + * - If the value is already a ConnectError, return it as is. + * - If the value is an AbortError from the fetch API, return the message + * of the AbortError with code Canceled. + * - For other Errors, return the error message with code Unknown by default. + * - For other values, return the values String representation as a message, + * with the code Unknown by default. + * The original value will be used for the "cause" property for the new + * ConnectError. + */ + static from(reason, code = code_Code.Unknown) { + if (reason instanceof connect_error_ConnectError) { + return reason; + } + if (reason instanceof Error) { + if (reason.name == "AbortError") { + // Fetch requests can only be canceled with an AbortController. + // We detect that condition by looking at the name of the raised + // error object, and translate to the appropriate status code. + return new connect_error_ConnectError(reason.message, code_Code.Canceled); + } + return new connect_error_ConnectError(reason.message, code, undefined, undefined, reason); + } + return new connect_error_ConnectError(String(reason), code, undefined, undefined, reason); + } + static [Symbol.hasInstance](v) { + if (!(v instanceof Error)) { + return false; + } + if (Object.getPrototypeOf(v) === connect_error_ConnectError.prototype) { + return true; + } + return (v.name === "ConnectError" && + "code" in v && + typeof v.code === "number" && + "metadata" in v && + "details" in v && + Array.isArray(v.details) && + "rawMessage" in v && + typeof v.rawMessage == "string" && + "cause" in v); + } + findDetails(typeOrRegistry) { + const registry = "typeName" in typeOrRegistry + ? { + findMessage: (typeName) => typeName === typeOrRegistry.typeName ? typeOrRegistry : undefined, + } + : typeOrRegistry; + const details = []; + for (const data of this.details) { + if ("getType" in data) { + if (registry.findMessage(data.getType().typeName)) { + details.push(data); + } + continue; + } + const type = registry.findMessage(data.type); + if (type) { + try { + details.push(type.fromBinary(data.value)); + } + catch (_) { + // We silently give up if we are unable to parse the detail, because + // that appears to be the least worst behavior. + // It is very unlikely that a user surrounds a catch body handling the + // error with another try-catch statement, and we do not want to + // recommend doing so. + } + } + } + return details; + } +} +/** + * Create an error message, prefixing the given code. + */ +function createMessage(message, code) { + return message.length + ? `[${codeToString(code)}] ${message}` + : `[${codeToString(code)}]`; +} + +;// CONCATENATED MODULE: ./node_modules/@connectrpc/connect/dist/esm/protocol/compression.js +// Copyright 2021-2024 The Connect Authors +// +// Licensed under the Apache License, Version 2.0 (the "License"); +// you may not use this file except in compliance with the License. +// You may obtain a copy of the License at +// +// http://www.apache.org/licenses/LICENSE-2.0 +// +// Unless required by applicable law or agreed to in writing, software +// distributed under the License is distributed on an "AS IS" BASIS, +// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. +// See the License for the specific language governing permissions and +// limitations under the License. + + +/** + * compressedFlag indicates that the data in a EnvelopedMessage is + * compressed. It has the same meaning in the gRPC-Web, gRPC-HTTP2, + * and Connect protocols. + * + * @private Internal code, does not follow semantic versioning. + */ +const compressedFlag = 0b00000001; +/** + * Validates the request encoding and determines the accepted response encoding. + * + * Returns the request and response compression to use. If the client requested + * an encoding that is not available, the returned object contains an error that + * must be used for the response. + * + * @private Internal code, does not follow semantic versioning. + */ +function compressionNegotiate(available, requested, // e.g. the value of the Grpc-Encoding header +accepted, // e.g. the value of the Grpc-Accept-Encoding header +headerNameAcceptEncoding) { + let request = null; + let response = null; + let error = undefined; + if (requested !== null && requested !== "identity") { + const found = available.find((c) => c.name === requested); + if (found) { + request = found; + } + else { + // To comply with https://github.com/grpc/grpc/blob/master/doc/compression.md + // and the Connect protocol, we return code "unimplemented" and specify + // acceptable compression(s). + const acceptable = available.map((c) => c.name).join(","); + error = new ConnectError(`unknown compression "${requested}": supported encodings are ${acceptable}`, Code.Unimplemented, { + [headerNameAcceptEncoding]: acceptable, + }); + } + } + if (accepted === null || accepted === "") { + // Support asymmetric compression. This logic follows + // https://github.com/grpc/grpc/blob/master/doc/compression.md and common + // sense. + response = request; + } + else { + const acceptNames = accepted.split(",").map((n) => n.trim()); + for (const name of acceptNames) { + const found = available.find((c) => c.name === name); + if (found) { + response = found; + break; + } + } + } + return { request, response, error }; +} + +;// CONCATENATED MODULE: ./node_modules/@connectrpc/connect/dist/esm/protocol/envelope.js +// Copyright 2021-2024 The Connect Authors +// +// Licensed under the Apache License, Version 2.0 (the "License"); +// you may not use this file except in compliance with the License. +// You may obtain a copy of the License at +// +// http://www.apache.org/licenses/LICENSE-2.0 +// +// Unless required by applicable law or agreed to in writing, software +// distributed under the License is distributed on an "AS IS" BASIS, +// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. +// See the License for the specific language governing permissions and +// limitations under the License. + + + +/** + * Create a WHATWG ReadableStream of enveloped messages from a ReadableStream + * of bytes. + * + * Ideally, this would simply be a TransformStream, but ReadableStream.pipeThrough + * does not have the necessary availability at this time. + * + * @private Internal code, does not follow semantic versioning. + */ +function createEnvelopeReadableStream(stream) { + let reader; + let buffer = new Uint8Array(0); + function append(chunk) { + const n = new Uint8Array(buffer.length + chunk.length); + n.set(buffer); + n.set(chunk, buffer.length); + buffer = n; + } + return new ReadableStream({ + start() { + reader = stream.getReader(); + }, + async pull(controller) { + let header = undefined; + for (;;) { + if (header === undefined && buffer.byteLength >= 5) { + let length = 0; + for (let i = 1; i < 5; i++) { + length = (length << 8) + buffer[i]; + } + header = { flags: buffer[0], length }; + } + if (header !== undefined && buffer.byteLength >= header.length + 5) { + break; + } + const result = await reader.read(); + if (result.done) { + break; + } + append(result.value); + } + if (header === undefined) { + if (buffer.byteLength == 0) { + controller.close(); + return; + } + controller.error(new ConnectError("premature end of stream", Code.DataLoss)); + return; + } + const data = buffer.subarray(5, 5 + header.length); + buffer = buffer.subarray(5 + header.length); + controller.enqueue({ + flags: header.flags, + data, + }); + }, + }); +} +/** + * Compress an EnvelopedMessage. + * + * Raises Internal if an enveloped message is already compressed. + * + * @private Internal code, does not follow semantic versioning. + */ +async function envelopeCompress(envelope, compression, compressMinBytes) { + let { flags, data } = envelope; + if ((flags & compressedFlag) === compressedFlag) { + throw new connect_error_ConnectError("invalid envelope, already compressed", code_Code.Internal); + } + if (compression && data.byteLength >= compressMinBytes) { + data = await compression.compress(data); + flags = flags | compressedFlag; + } + return { data, flags }; +} +/** + * Decompress an EnvelopedMessage. + * + * Raises InvalidArgument if an envelope is compressed, but compression is null. + * + * Relies on the provided Compression to raise ResourceExhausted if the + * *decompressed* message size is larger than readMaxBytes. If the envelope is + * not compressed, readMaxBytes is not honored. + * + * @private Internal code, does not follow semantic versioning. + */ +async function envelopeDecompress(envelope, compression, readMaxBytes) { + let { flags, data } = envelope; + if ((flags & compressedFlag) === compressedFlag) { + if (!compression) { + throw new connect_error_ConnectError("received compressed envelope, but do not know how to decompress", code_Code.Internal); + } + data = await compression.decompress(data, readMaxBytes); + flags = flags ^ compressedFlag; + } + return { data, flags }; +} +/** + * Encode a single enveloped message. + * + * @private Internal code, does not follow semantic versioning. + */ +function encodeEnvelope(flags, data) { + const bytes = new Uint8Array(data.length + 5); + bytes.set(data, 5); + const v = new DataView(bytes.buffer, bytes.byteOffset, bytes.byteLength); + v.setUint8(0, flags); // first byte is flags + v.setUint32(1, data.length); // 4 bytes message length + return bytes; +} +/** + * Encode a set of enveloped messages. + * + * @private Internal code, does not follow semantic versioning. + */ +function encodeEnvelopes(...envelopes) { + const len = envelopes.reduce((previousValue, currentValue) => previousValue + currentValue.data.length + 5, 0); + const bytes = new Uint8Array(len); + const v = new DataView(bytes.buffer); + let offset = 0; + for (const e of envelopes) { + v.setUint8(offset, e.flags); // first byte is flags + v.setUint32(offset + 1, e.data.length); // 4 bytes message length + bytes.set(e.data, offset + 5); + offset += e.data.length + 5; + } + return bytes; +} + +;// CONCATENATED MODULE: ./node_modules/@connectrpc/connect/dist/esm/protocol/limit-io.js +// Copyright 2021-2024 The Connect Authors +// +// Licensed under the Apache License, Version 2.0 (the "License"); +// you may not use this file except in compliance with the License. +// You may obtain a copy of the License at +// +// http://www.apache.org/licenses/LICENSE-2.0 +// +// Unless required by applicable law or agreed to in writing, software +// distributed under the License is distributed on an "AS IS" BASIS, +// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. +// See the License for the specific language governing permissions and +// limitations under the License. + + +/** + * At most, allow ~4GiB to be received or sent per message. + * zlib used by Node.js caps maxOutputLength at this value. It also happens to + * be the maximum theoretical message size supported by protobuf-es. + */ +const maxReadMaxBytes = 0xffffffff; +const maxWriteMaxBytes = maxReadMaxBytes; +/** + * The default value for the compressMinBytes option. The CPU cost of compressing + * very small messages usually isn't worth the small reduction in network I/O, so + * the default value is 1 kibibyte. + */ +const defaultCompressMinBytes = 1024; +/** + * Asserts that the options writeMaxBytes, readMaxBytes, and compressMinBytes + * are within sane limits, and returns default values where no value is + * provided. + * + * @private Internal code, does not follow semantic versioning. + */ +function validateReadWriteMaxBytes(readMaxBytes, writeMaxBytes, compressMinBytes) { + writeMaxBytes !== null && writeMaxBytes !== void 0 ? writeMaxBytes : (writeMaxBytes = maxWriteMaxBytes); + readMaxBytes !== null && readMaxBytes !== void 0 ? readMaxBytes : (readMaxBytes = maxReadMaxBytes); + compressMinBytes !== null && compressMinBytes !== void 0 ? compressMinBytes : (compressMinBytes = defaultCompressMinBytes); + if (writeMaxBytes < 1 || writeMaxBytes > maxWriteMaxBytes) { + throw new connect_error_ConnectError(`writeMaxBytes ${writeMaxBytes} must be >= 1 and <= ${maxWriteMaxBytes}`, code_Code.Internal); + } + if (readMaxBytes < 1 || readMaxBytes > maxReadMaxBytes) { + throw new connect_error_ConnectError(`readMaxBytes ${readMaxBytes} must be >= 1 and <= ${maxReadMaxBytes}`, code_Code.Internal); + } + return { + readMaxBytes, + writeMaxBytes, + compressMinBytes, + }; +} +/** + * Raise an error ResourceExhausted if more than writeMaxByte are written. + * + * @private Internal code, does not follow semantic versioning. + */ +function assertWriteMaxBytes(writeMaxBytes, bytesWritten) { + if (bytesWritten > writeMaxBytes) { + throw new connect_error_ConnectError(`message size ${bytesWritten} is larger than configured writeMaxBytes ${writeMaxBytes}`, code_Code.ResourceExhausted); + } +} +/** + * Raise an error ResourceExhausted if more than readMaxBytes are read. + * + * @private Internal code, does not follow semantic versioning. + */ +function limit_io_assertReadMaxBytes(readMaxBytes, bytesRead, totalSizeKnown = false) { + if (bytesRead > readMaxBytes) { + let message = `message size is larger than configured readMaxBytes ${readMaxBytes}`; + if (totalSizeKnown) { + message = `message size ${bytesRead} is larger than configured readMaxBytes ${readMaxBytes}`; + } + throw new connect_error_ConnectError(message, code_Code.ResourceExhausted); + } +} + +;// CONCATENATED MODULE: ./node_modules/@connectrpc/connect/dist/esm/protocol/async-iterable.js +// Copyright 2021-2024 The Connect Authors +// +// Licensed under the Apache License, Version 2.0 (the "License"); +// you may not use this file except in compliance with the License. +// You may obtain a copy of the License at +// +// http://www.apache.org/licenses/LICENSE-2.0 +// +// Unless required by applicable law or agreed to in writing, software +// distributed under the License is distributed on an "AS IS" BASIS, +// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. +// See the License for the specific language governing permissions and +// limitations under the License. +var __asyncValues = (undefined && undefined.__asyncValues) || function (o) { + if (!Symbol.asyncIterator) throw new TypeError("Symbol.asyncIterator is not defined."); + var m = o[Symbol.asyncIterator], i; + return m ? m.call(o) : (o = typeof __values === "function" ? __values(o) : o[Symbol.iterator](), i = {}, verb("next"), verb("throw"), verb("return"), i[Symbol.asyncIterator] = function () { return this; }, i); + function verb(n) { i[n] = o[n] && function (v) { return new Promise(function (resolve, reject) { v = o[n](v), settle(resolve, reject, v.done, v.value); }); }; } + function settle(resolve, reject, d, v) { Promise.resolve(v).then(function(v) { resolve({ value: v, done: d }); }, reject); } +}; +var __await = (undefined && undefined.__await) || function (v) { return this instanceof __await ? (this.v = v, this) : new __await(v); } +var __asyncGenerator = (undefined && undefined.__asyncGenerator) || function (thisArg, _arguments, generator) { + if (!Symbol.asyncIterator) throw new TypeError("Symbol.asyncIterator is not defined."); + var g = generator.apply(thisArg, _arguments || []), i, q = []; + return i = {}, verb("next"), verb("throw"), verb("return", awaitReturn), i[Symbol.asyncIterator] = function () { return this; }, i; + function awaitReturn(f) { return function (v) { return Promise.resolve(v).then(f, reject); }; } + function verb(n, f) { if (g[n]) { i[n] = function (v) { return new Promise(function (a, b) { q.push([n, v, a, b]) > 1 || resume(n, v); }); }; if (f) i[n] = f(i[n]); } } + function resume(n, v) { try { step(g[n](v)); } catch (e) { settle(q[0][3], e); } } + function step(r) { r.value instanceof __await ? Promise.resolve(r.value.v).then(fulfill, reject) : settle(q[0][2], r); } + function fulfill(value) { resume("next", value); } + function reject(value) { resume("throw", value); } + function settle(f, v) { if (f(v), q.shift(), q.length) resume(q[0][0], q[0][1]); } +}; +var __asyncDelegator = (undefined && undefined.__asyncDelegator) || function (o) { + var i, p; + return i = {}, verb("next"), verb("throw", function (e) { throw e; }), verb("return"), i[Symbol.iterator] = function () { return this; }, i; + function verb(n, f) { i[n] = o[n] ? function (v) { return (p = !p) ? { value: __await(o[n](v)), done: false } : f ? f(v) : v; } : f; } +}; + + + + +function pipeTo(source, ...rest) { + const [transforms, sink, opt] = pickTransformsAndSink(rest); + let iterable = source; + let abortable; + if ((opt === null || opt === void 0 ? void 0 : opt.propagateDownStreamError) === true) { + iterable = abortable = makeIterableAbortable(iterable); + } + // eslint-disable-next-line @typescript-eslint/ban-ts-comment + // @ts-ignore + iterable = pipe(iterable, ...transforms, { propagateDownStreamError: false }); + return sink(iterable).catch((reason) => { + if (abortable) { + return abortable.abort(reason).then(() => Promise.reject(reason)); + } + return Promise.reject(reason); + }); +} +// pick transforms, the sink, and options from the pipeTo() rest parameter +function pickTransformsAndSink(rest) { + let opt; + if (typeof rest[rest.length - 1] != "function") { + opt = rest.pop(); + } + const sink = rest.pop(); + return [rest, sink, opt]; +} +/** + * Creates an AsyncIterableSink that concatenates all elements from the input. + * + * @private Internal code, does not follow semantic versioning. + */ +function sinkAll() { + return async function (iterable) { + var _a, e_1, _b, _c; + const all = []; + try { + for (var _d = true, iterable_1 = __asyncValues(iterable), iterable_1_1; iterable_1_1 = await iterable_1.next(), _a = iterable_1_1.done, !_a; _d = true) { + _c = iterable_1_1.value; + _d = false; + const chunk = _c; + all.push(chunk); + } + } + catch (e_1_1) { e_1 = { error: e_1_1 }; } + finally { + try { + if (!_d && !_a && (_b = iterable_1.return)) await _b.call(iterable_1); + } + finally { if (e_1) throw e_1.error; } + } + return all; + }; +} +/** + * Creates an AsyncIterableSink that concatenates all chunks from the input into + * a single Uint8Array. + * + * The iterable raises an error if the more than readMaxBytes are read. + * + * An optional length hint can be provided to optimize allocation and validation. + * If more or less bytes are present in the source that the length hint indicates, + * and error is raised. + * If the length hint is larger than readMaxBytes, an error is raised. + * If the length hint is not a positive integer, it is ignored. + * + * @private Internal code, does not follow semantic versioning. + */ +function sinkAllBytes(readMaxBytes, lengthHint) { + return async function (iterable) { + return await readAllBytes(iterable, readMaxBytes, lengthHint); + }; +} +function pipe(source, ...rest) { + return __asyncGenerator(this, arguments, function* pipe_1() { + var _a; + const [transforms, opt] = pickTransforms(rest); + let abortable; + const sourceIt = source[Symbol.asyncIterator](); + const cachedSource = { + [Symbol.asyncIterator]() { + return sourceIt; + }, + }; + let iterable = cachedSource; + if ((opt === null || opt === void 0 ? void 0 : opt.propagateDownStreamError) === true) { + iterable = abortable = makeIterableAbortable(iterable); + } + for (const t of transforms) { + iterable = t(iterable); + } + const it = iterable[Symbol.asyncIterator](); + try { + for (;;) { + const r = yield __await(it.next()); + if (r.done === true) { + break; + } + if (!abortable) { + yield yield __await(r.value); + continue; + } + try { + yield yield __await(r.value); + } + catch (e) { + yield __await(abortable.abort(e)); // propagate downstream error to the source + throw e; + } + } + } + finally { + if ((opt === null || opt === void 0 ? void 0 : opt.propagateDownStreamError) === true) { + // Call return on the source iterable to indicate + // that we will no longer consume it and it should + // cleanup any allocated resources. + (_a = sourceIt.return) === null || _a === void 0 ? void 0 : _a.call(sourceIt).catch(() => { + // return returns a promise, which we don't care about. + // + // Uncaught promises are thrown at sometime/somewhere by the event loop, + // this is to ensure error is caught and ignored. + }); + } + } + }); +} +function pickTransforms(rest) { + let opt; + if (typeof rest[rest.length - 1] != "function") { + opt = rest.pop(); + } + return [rest, opt]; +} +/** + * Creates an AsyncIterableTransform that catches any error from the input, and + * passes it to the given catchError function. + * + * The catchError function may return a final value. + * + * @private Internal code, does not follow semantic versioning. + */ +function transformCatch(catchError) { + return function (iterable) { + return __asyncGenerator(this, arguments, function* () { + // we deliberate avoid a for-await loop because we only want to catch upstream + // errors, not downstream errors (yield). + const it = iterable[Symbol.asyncIterator](); + for (;;) { + let r; + try { + r = yield __await(it.next()); + } + catch (e) { + const caught = yield __await(catchError(e)); + if (caught !== undefined) { + yield yield __await(caught); + } + break; + } + if (r.done === true) { + break; + } + yield yield __await(r.value); + } + }); + }; +} +/** + * Creates an AsyncIterableTransform that catches any error from the input, and + * passes it to the given function. Unlike transformCatch(), the given function + * is also called when no error is raised. + * + * @private Internal code, does not follow semantic versioning. + */ +function transformCatchFinally(catchFinally) { + return function (iterable) { + return __asyncGenerator(this, arguments, function* () { + // we deliberate avoid a for-await loop because we only want to catch upstream + // errors, not downstream errors (yield). + let err; + const it = iterable[Symbol.asyncIterator](); + for (;;) { + let r; + try { + r = yield __await(it.next()); + } + catch (e) { + err = e; + break; + } + if (r.done === true) { + break; + } + yield yield __await(r.value); + } + const caught = yield __await(catchFinally(err)); + if (caught !== undefined) { + yield yield __await(caught); + } + }); + }; +} +/** + * Creates an AsyncIterableTransform that appends a value. + * + * The element to append is provided by a function. If the function returns + * undefined, no element is appended. + * + * @private Internal code, does not follow semantic versioning. + */ +function transformAppend(provide) { + return function (iterable) { + return __asyncGenerator(this, arguments, function* () { + var _a, e_2, _b, _c; + try { + for (var _d = true, iterable_2 = __asyncValues(iterable), iterable_2_1; iterable_2_1 = yield __await(iterable_2.next()), _a = iterable_2_1.done, !_a; _d = true) { + _c = iterable_2_1.value; + _d = false; + const chunk = _c; + yield yield __await(chunk); + } + } + catch (e_2_1) { e_2 = { error: e_2_1 }; } + finally { + try { + if (!_d && !_a && (_b = iterable_2.return)) yield __await(_b.call(iterable_2)); + } + finally { if (e_2) throw e_2.error; } + } + const append = yield __await(provide()); + if (append !== undefined) { + yield yield __await(append); + } + }); + }; +} +/** + * Creates an AsyncIterableTransform that prepends an element. + * + * The element to prepend is provided by a function. If the function returns + * undefined, no element is appended. + * + * @private Internal code, does not follow semantic versioning. + */ +function transformPrepend(provide) { + return function (iterable) { + return __asyncGenerator(this, arguments, function* () { + var _a, e_3, _b, _c; + const prepend = yield __await(provide()); + if (prepend !== undefined) { + yield yield __await(prepend); + } + try { + for (var _d = true, iterable_3 = __asyncValues(iterable), iterable_3_1; iterable_3_1 = yield __await(iterable_3.next()), _a = iterable_3_1.done, !_a; _d = true) { + _c = iterable_3_1.value; + _d = false; + const chunk = _c; + yield yield __await(chunk); + } + } + catch (e_3_1) { e_3 = { error: e_3_1 }; } + finally { + try { + if (!_d && !_a && (_b = iterable_3.return)) yield __await(_b.call(iterable_3)); + } + finally { if (e_3) throw e_3.error; } + } + }); + }; +} +/** + * Creates an AsyncIterableTransform that reads all bytes from the input, and + * concatenates them to a single Uint8Array. + * + * The iterable raises an error if the more than readMaxBytes are read. + * + * An optional length hint can be provided to optimize allocation and validation. + * If more or less bytes are present in the source that the length hint indicates, + * and error is raised. + * If the length hint is larger than readMaxBytes, an error is raised. + * If the length hint is not a positive integer, it is ignored. + * + * @private Internal code, does not follow semantic versioning. + */ +function transformReadAllBytes(readMaxBytes, lengthHint) { + return function (iterable) { + return __asyncGenerator(this, arguments, function* () { + yield yield __await(yield __await(readAllBytes(iterable, readMaxBytes, lengthHint))); + }); + }; +} +function transformSerializeEnvelope(serialization, endStreamFlag, endSerialization) { + if (endStreamFlag === undefined || endSerialization === undefined) { + return function (iterable) { + return __asyncGenerator(this, arguments, function* () { + var _a, e_4, _b, _c; + try { + for (var _d = true, iterable_4 = __asyncValues(iterable), iterable_4_1; iterable_4_1 = yield __await(iterable_4.next()), _a = iterable_4_1.done, !_a; _d = true) { + _c = iterable_4_1.value; + _d = false; + const chunk = _c; + const data = serialization.serialize(chunk); + yield yield __await({ flags: 0, data }); + } + } + catch (e_4_1) { e_4 = { error: e_4_1 }; } + finally { + try { + if (!_d && !_a && (_b = iterable_4.return)) yield __await(_b.call(iterable_4)); + } + finally { if (e_4) throw e_4.error; } + } + }); + }; + } + return function (iterable) { + return __asyncGenerator(this, arguments, function* () { + var _a, e_5, _b, _c; + try { + for (var _d = true, iterable_5 = __asyncValues(iterable), iterable_5_1; iterable_5_1 = yield __await(iterable_5.next()), _a = iterable_5_1.done, !_a; _d = true) { + _c = iterable_5_1.value; + _d = false; + const chunk = _c; + let data; + let flags = 0; + if (chunk.end) { + flags = flags | endStreamFlag; + data = endSerialization.serialize(chunk.value); + } + else { + data = serialization.serialize(chunk.value); + } + yield yield __await({ flags, data }); + } + } + catch (e_5_1) { e_5 = { error: e_5_1 }; } + finally { + try { + if (!_d && !_a && (_b = iterable_5.return)) yield __await(_b.call(iterable_5)); + } + finally { if (e_5) throw e_5.error; } + } + }); + }; +} +function transformParseEnvelope(serialization, endStreamFlag, endSerialization) { + // code path always yields ParsedEnvelopedMessage + if (endSerialization && endStreamFlag !== undefined) { + return function (iterable) { + return __asyncGenerator(this, arguments, function* () { + var _a, e_6, _b, _c; + try { + for (var _d = true, iterable_6 = __asyncValues(iterable), iterable_6_1; iterable_6_1 = yield __await(iterable_6.next()), _a = iterable_6_1.done, !_a; _d = true) { + _c = iterable_6_1.value; + _d = false; + const { flags, data } = _c; + if ((flags & endStreamFlag) === endStreamFlag) { + yield yield __await({ value: endSerialization.parse(data), end: true }); + } + else { + yield yield __await({ value: serialization.parse(data), end: false }); + } + } + } + catch (e_6_1) { e_6 = { error: e_6_1 }; } + finally { + try { + if (!_d && !_a && (_b = iterable_6.return)) yield __await(_b.call(iterable_6)); + } + finally { if (e_6) throw e_6.error; } + } + }); + }; + } + // code path always yields T + return function (iterable) { + return __asyncGenerator(this, arguments, function* () { + var _a, e_7, _b, _c; + try { + for (var _d = true, iterable_7 = __asyncValues(iterable), iterable_7_1; iterable_7_1 = yield __await(iterable_7.next()), _a = iterable_7_1.done, !_a; _d = true) { + _c = iterable_7_1.value; + _d = false; + const { flags, data } = _c; + if (endStreamFlag !== undefined && + (flags & endStreamFlag) === endStreamFlag) { + if (endSerialization === null) { + throw new connect_error_ConnectError("unexpected end flag", code_Code.InvalidArgument); + } + // skips end-of-stream envelope + continue; + } + yield yield __await(serialization.parse(data)); + } + } + catch (e_7_1) { e_7 = { error: e_7_1 }; } + finally { + try { + if (!_d && !_a && (_b = iterable_7.return)) yield __await(_b.call(iterable_7)); + } + finally { if (e_7) throw e_7.error; } + } + }); + }; +} +/** + * Creates an AsyncIterableTransform that takes enveloped messages as a source, + * and compresses them if they are larger than compressMinBytes. + * + * @private Internal code, does not follow semantic versioning. + */ +function transformCompressEnvelope(compression, compressMinBytes) { + return function (iterable) { + return __asyncGenerator(this, arguments, function* () { + var _a, e_8, _b, _c; + try { + for (var _d = true, iterable_8 = __asyncValues(iterable), iterable_8_1; iterable_8_1 = yield __await(iterable_8.next()), _a = iterable_8_1.done, !_a; _d = true) { + _c = iterable_8_1.value; + _d = false; + const env = _c; + yield yield __await(yield __await(envelopeCompress(env, compression, compressMinBytes))); + } + } + catch (e_8_1) { e_8 = { error: e_8_1 }; } + finally { + try { + if (!_d && !_a && (_b = iterable_8.return)) yield __await(_b.call(iterable_8)); + } + finally { if (e_8) throw e_8.error; } + } + }); + }; +} +/** + * Creates an AsyncIterableTransform that takes enveloped messages as a source, + * and decompresses them using the given compression. + * + * The iterable raises an error if the decompressed payload of an enveloped + * message is larger than readMaxBytes, or if no compression is provided. + * + * @private Internal code, does not follow semantic versioning. + */ +function transformDecompressEnvelope(compression, readMaxBytes) { + return function (iterable) { + return __asyncGenerator(this, arguments, function* () { + var _a, e_9, _b, _c; + try { + for (var _d = true, iterable_9 = __asyncValues(iterable), iterable_9_1; iterable_9_1 = yield __await(iterable_9.next()), _a = iterable_9_1.done, !_a; _d = true) { + _c = iterable_9_1.value; + _d = false; + const env = _c; + yield yield __await(yield __await(envelopeDecompress(env, compression, readMaxBytes))); + } + } + catch (e_9_1) { e_9 = { error: e_9_1 }; } + finally { + try { + if (!_d && !_a && (_b = iterable_9.return)) yield __await(_b.call(iterable_9)); + } + finally { if (e_9) throw e_9.error; } + } + }); + }; +} +/** + * Create an AsyncIterableTransform that takes enveloped messages as a source, + * and joins them into a stream of raw bytes. + * + * @private Internal code, does not follow semantic versioning. + */ +function transformJoinEnvelopes() { + return function (iterable) { + return __asyncGenerator(this, arguments, function* () { + var _a, e_10, _b, _c; + try { + for (var _d = true, iterable_10 = __asyncValues(iterable), iterable_10_1; iterable_10_1 = yield __await(iterable_10.next()), _a = iterable_10_1.done, !_a; _d = true) { + _c = iterable_10_1.value; + _d = false; + const { flags, data } = _c; + yield yield __await(encodeEnvelope(flags, data)); + } + } + catch (e_10_1) { e_10 = { error: e_10_1 }; } + finally { + try { + if (!_d && !_a && (_b = iterable_10.return)) yield __await(_b.call(iterable_10)); + } + finally { if (e_10) throw e_10.error; } + } + }); + }; +} +/** + * Create an AsyncIterableTransform that takes raw bytes as a source, and splits + * them into enveloped messages. + * + * The iterable raises an error + * - if the payload of an enveloped message is larger than readMaxBytes, + * - if the stream ended before an enveloped message fully arrived, + * - or if the stream ended with extraneous data. + * + * @private Internal code, does not follow semantic versioning. + */ +function transformSplitEnvelope(readMaxBytes) { + // append chunk to buffer, returning updated buffer + function append(buffer, chunk) { + const n = new Uint8Array(buffer.byteLength + chunk.byteLength); + n.set(buffer); + n.set(chunk, buffer.length); + return n; + } + // tuple 0: envelope, or undefined if incomplete + // tuple 1: remainder of the buffer + function shiftEnvelope(buffer, header) { + if (buffer.byteLength < 5 + header.length) { + return [undefined, buffer]; + } + return [ + { flags: header.flags, data: buffer.subarray(5, 5 + header.length) }, + buffer.subarray(5 + header.length), + ]; + } + // undefined: header is incomplete + function peekHeader(buffer) { + if (buffer.byteLength < 5) { + return undefined; + } + const view = new DataView(buffer.buffer, buffer.byteOffset, buffer.byteLength); + const length = view.getUint32(1); // 4 bytes message length + const flags = view.getUint8(0); // first byte is flags + return { length, flags }; + } + return function (iterable) { + return __asyncGenerator(this, arguments, function* () { + var _a, e_11, _b, _c; + let buffer = new Uint8Array(0); + try { + for (var _d = true, iterable_11 = __asyncValues(iterable), iterable_11_1; iterable_11_1 = yield __await(iterable_11.next()), _a = iterable_11_1.done, !_a; _d = true) { + _c = iterable_11_1.value; + _d = false; + const chunk = _c; + buffer = append(buffer, chunk); + for (;;) { + const header = peekHeader(buffer); + if (!header) { + break; + } + limit_io_assertReadMaxBytes(readMaxBytes, header.length, true); + let env; + [env, buffer] = shiftEnvelope(buffer, header); + if (!env) { + break; + } + yield yield __await(env); + } + } + } + catch (e_11_1) { e_11 = { error: e_11_1 }; } + finally { + try { + if (!_d && !_a && (_b = iterable_11.return)) yield __await(_b.call(iterable_11)); + } + finally { if (e_11) throw e_11.error; } + } + if (buffer.byteLength > 0) { + const header = peekHeader(buffer); + let message = "protocol error: incomplete envelope"; + if (header) { + message = `protocol error: promised ${header.length} bytes in enveloped message, got ${buffer.byteLength - 5} bytes`; + } + throw new connect_error_ConnectError(message, code_Code.InvalidArgument); + } + }); + }; +} +/** + * Reads all bytes from the source, and concatenates them to a single Uint8Array. + * + * Raises an error if: + * - more than readMaxBytes are read + * - lengthHint is a positive integer, but larger than readMaxBytes + * - lengthHint is a positive integer, and the source contains more or less bytes + * than promised + * + * @private Internal code, does not follow semantic versioning. + */ +async function readAllBytes(iterable, readMaxBytes, lengthHint) { + var _a, e_12, _b, _c, _d, e_13, _e, _f; + const [ok, hint] = parseLengthHint(lengthHint); + if (ok) { + if (hint > readMaxBytes) { + assertReadMaxBytes(readMaxBytes, hint, true); + } + const buffer = new Uint8Array(hint); + let offset = 0; + try { + for (var _g = true, iterable_12 = __asyncValues(iterable), iterable_12_1; iterable_12_1 = await iterable_12.next(), _a = iterable_12_1.done, !_a; _g = true) { + _c = iterable_12_1.value; + _g = false; + const chunk = _c; + if (offset + chunk.byteLength > hint) { + throw new ConnectError(`protocol error: promised ${hint} bytes, received ${offset + chunk.byteLength}`, Code.InvalidArgument); + } + buffer.set(chunk, offset); + offset += chunk.byteLength; + } + } + catch (e_12_1) { e_12 = { error: e_12_1 }; } + finally { + try { + if (!_g && !_a && (_b = iterable_12.return)) await _b.call(iterable_12); + } + finally { if (e_12) throw e_12.error; } + } + if (offset < hint) { + throw new ConnectError(`protocol error: promised ${hint} bytes, received ${offset}`, Code.InvalidArgument); + } + return buffer; + } + const chunks = []; + let count = 0; + try { + for (var _h = true, iterable_13 = __asyncValues(iterable), iterable_13_1; iterable_13_1 = await iterable_13.next(), _d = iterable_13_1.done, !_d; _h = true) { + _f = iterable_13_1.value; + _h = false; + const chunk = _f; + count += chunk.byteLength; + assertReadMaxBytes(readMaxBytes, count); + chunks.push(chunk); + } + } + catch (e_13_1) { e_13 = { error: e_13_1 }; } + finally { + try { + if (!_h && !_d && (_e = iterable_13.return)) await _e.call(iterable_13); + } + finally { if (e_13) throw e_13.error; } + } + const all = new Uint8Array(count); + let offset = 0; + for (let chunk = chunks.shift(); chunk; chunk = chunks.shift()) { + all.set(chunk, offset); + offset += chunk.byteLength; + } + return all; +} +// parse the lengthHint argument of readAllBytes() +function parseLengthHint(lengthHint) { + if (lengthHint === undefined || lengthHint === null) { + return [false, 0]; + } + const n = typeof lengthHint == "string" ? parseInt(lengthHint, 10) : lengthHint; + if (!Number.isSafeInteger(n) || n < 0) { + return [false, n]; + } + return [true, n]; +} +/** + * Wait for the first element of an iterable without modifying the iterable. + * This consumes the first element, but pushes it back on the stack. + * + * @private Internal code, does not follow semantic versioning. + */ +async function untilFirst(iterable) { + const it = iterable[Symbol.asyncIterator](); + let first = await it.next(); + return { + [Symbol.asyncIterator]() { + const w = { + async next() { + if (first !== null) { + const n = first; + first = null; + return n; + } + return await it.next(); + }, + }; + if (it.throw !== undefined) { + // eslint-disable-next-line @typescript-eslint/no-non-null-assertion -- can't handle mutated object sensibly + w.throw = (e) => it.throw(e); + } + if (it.return !== undefined) { + // eslint-disable-next-line @typescript-eslint/no-non-null-assertion,@typescript-eslint/no-explicit-any -- can't handle mutated object sensibly + w.return = (value) => it.return(value); + } + return w; + }, + }; +} +/** + * Wrap the given iterable and return an iterable with an abort() method. + * + * This function exists purely for convenience. Where one would typically have + * to access the iterator directly, advance through all elements, and call + * AsyncIterator.throw() to notify the upstream iterable, this function allows + * to use convenient for-await loops and still notify the upstream iterable: + * + * ```ts + * const abortable = makeIterableAbortable(iterable); + * for await (const ele of abortable) { + * await abortable.abort("ERR"); + * } + * ``` + * There are a couple of limitations of this function: + * - the given async iterable must implement throw + * - the async iterable cannot be re-use + * - if source catches errors and yields values for them, they are ignored, and + * the source may still dangle + * + * There are four possible ways an async function* can handle yield errors: + * 1. don't catch errors at all - Abortable.abort() will resolve "rethrown" + * 2. catch errors and rethrow - Abortable.abort() will resolve "rethrown" + * 3. catch errors and return - Abortable.abort() will resolve "completed" + * 4. catch errors and yield a value - Abortable.abort() will resolve "caught" + * + * Note that catching errors and yielding a value is problematic, and it should + * be documented that this may leave the source in a dangling state. + * + * @private Internal code, does not follow semantic versioning. + */ +function makeIterableAbortable(iterable) { + const innerCandidate = iterable[Symbol.asyncIterator](); + if (innerCandidate.throw === undefined) { + throw new Error("AsyncIterable does not implement throw"); + } + const inner = innerCandidate; + let aborted; + let resultPromise; + let it = { + next() { + resultPromise = inner.next().finally(() => { + resultPromise = undefined; + }); + return resultPromise; + }, + throw(e) { + return inner.throw(e); + }, + }; + if (innerCandidate.return !== undefined) { + it = Object.assign(Object.assign({}, it), { return(value) { + return inner.return(value); + } }); + } + let used = false; + return { + abort(reason) { + if (aborted) { + return aborted.state; + } + const f = () => { + return inner.throw(reason).then((r) => (r.done === true ? "completed" : "caught"), () => "rethrown"); + }; + if (resultPromise) { + aborted = { reason, state: resultPromise.then(f, f) }; + return aborted.state; + } + aborted = { reason, state: f() }; + return aborted.state; + }, + [Symbol.asyncIterator]() { + if (used) { + throw new Error("AsyncIterable cannot be re-used"); + } + used = true; + return it; + }, + }; +} +/** + * Create a new WritableIterable. + */ +function createWritableIterable() { + // We start with two queues to capture the read and write attempts. + // + // The writes and reads each check of their counterpart is + // already available and either interact/add themselves to the queue. + const readQueue = []; + const writeQueue = []; + let err = undefined; + let nextResolve; + let nextReject; + let nextPromise = new Promise((resolve, reject) => { + nextResolve = resolve; + nextReject = reject; + }); + let closed = false; + // drain the readQueue in case of error/writer is closed by sending a + // done result. + function drain() { + for (const next of readQueue.splice(0, readQueue.length)) { + next({ done: true, value: undefined }); + } + } + return { + close() { + closed = true; + drain(); + }, + async write(payload) { + if (closed) { + throw err !== null && err !== void 0 ? err : new Error("cannot write, WritableIterable already closed"); + } + const read = readQueue.shift(); + if (read === undefined) { + // We didn't find a pending read so we add the payload to the write queue. + writeQueue.push(payload); + } + else { + // We found a pending read so we respond with the payload. + read({ done: false, value: payload }); + if (readQueue.length > 0) { + // If there are more in the read queue we can mark the write as complete. + // as the error reporting is not guaranteed to be sequential and therefore cannot + // to linked to a specific write. + return; + } + } + // We await the next call for as many times as there are items in the queue + 1 + // + // If there are no items in the write queue that means write happened and we just have + // to wait for one more call likewise if we are the nth write in the queue we + // have to wait for n writes to complete and one more. + const limit = writeQueue.length + 1; + for (let i = 0; i < limit; i++) { + await nextPromise; + } + }, + [Symbol.asyncIterator]() { + return { + next() { + // Resolve the nextPromise to indicate + // pending writes that a read attempt has been made + // after their write. + // + // We also need to reset the promise for future writes. + nextResolve(); + nextPromise = new Promise((resolve, reject) => { + nextResolve = resolve; + nextReject = reject; + }); + const write = writeQueue.shift(); + if (write !== undefined) { + // We found a pending write so response with the payload. + return Promise.resolve({ done: false, value: write }); + } + if (closed) { + return Promise.resolve({ done: true, value: undefined }); + } + // We return a promise immediately that is either resolved/rejected + // as writes happen. + let readResolve; + const readPromise = new Promise((resolve) => (readResolve = resolve)); + readQueue.push(readResolve); // eslint-disable-line @typescript-eslint/no-non-null-assertion + return readPromise; + }, + throw(throwErr) { + err = throwErr; + closed = true; + writeQueue.splice(0, writeQueue.length); + nextPromise.catch(() => { + // To make sure that the nextPromise is always resolved. + }); + // This will reject all pending writes. + nextReject(err); + drain(); + return Promise.resolve({ done: true, value: undefined }); + }, + return() { + closed = true; + writeQueue.splice(0, writeQueue.length); + // Resolve once for the write awaiting confirmation. + nextResolve(); + // Reject all future writes. + nextPromise = Promise.reject(new Error("cannot write, consumer called return")); + nextPromise.catch(() => { + // To make sure that the nextPromise is always resolved. + }); + drain(); + return Promise.resolve({ done: true, value: undefined }); + }, + }; + }, + }; +} +/** + * Create an asynchronous iterable from an array. + * + * @private Internal code, does not follow semantic versioning. + */ +// eslint-disable-next-line @typescript-eslint/require-await +function createAsyncIterable(items) { + return __asyncGenerator(this, arguments, function* createAsyncIterable_1() { + yield __await(yield* __asyncDelegator(__asyncValues(items))); + }); +} + +;// CONCATENATED MODULE: ./node_modules/@connectrpc/connect/dist/esm/promise-client.js +// Copyright 2021-2024 The Connect Authors +// +// Licensed under the Apache License, Version 2.0 (the "License"); +// you may not use this file except in compliance with the License. +// You may obtain a copy of the License at +// +// http://www.apache.org/licenses/LICENSE-2.0 +// +// Unless required by applicable law or agreed to in writing, software +// distributed under the License is distributed on an "AS IS" BASIS, +// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. +// See the License for the specific language governing permissions and +// limitations under the License. +var promise_client_asyncValues = (undefined && undefined.__asyncValues) || function (o) { + if (!Symbol.asyncIterator) throw new TypeError("Symbol.asyncIterator is not defined."); + var m = o[Symbol.asyncIterator], i; + return m ? m.call(o) : (o = typeof __values === "function" ? __values(o) : o[Symbol.iterator](), i = {}, verb("next"), verb("throw"), verb("return"), i[Symbol.asyncIterator] = function () { return this; }, i); + function verb(n) { i[n] = o[n] && function (v) { return new Promise(function (resolve, reject) { v = o[n](v), settle(resolve, reject, v.done, v.value); }); }; } + function settle(resolve, reject, d, v) { Promise.resolve(v).then(function(v) { resolve({ value: v, done: d }); }, reject); } +}; +var promise_client_await = (undefined && undefined.__await) || function (v) { return this instanceof promise_client_await ? (this.v = v, this) : new promise_client_await(v); } +var promise_client_asyncDelegator = (undefined && undefined.__asyncDelegator) || function (o) { + var i, p; + return i = {}, verb("next"), verb("throw", function (e) { throw e; }), verb("return"), i[Symbol.iterator] = function () { return this; }, i; + function verb(n, f) { i[n] = o[n] ? function (v) { return (p = !p) ? { value: promise_client_await(o[n](v)), done: false } : f ? f(v) : v; } : f; } +}; +var promise_client_asyncGenerator = (undefined && undefined.__asyncGenerator) || function (thisArg, _arguments, generator) { + if (!Symbol.asyncIterator) throw new TypeError("Symbol.asyncIterator is not defined."); + var g = generator.apply(thisArg, _arguments || []), i, q = []; + return i = {}, verb("next"), verb("throw"), verb("return", awaitReturn), i[Symbol.asyncIterator] = function () { return this; }, i; + function awaitReturn(f) { return function (v) { return Promise.resolve(v).then(f, reject); }; } + function verb(n, f) { if (g[n]) { i[n] = function (v) { return new Promise(function (a, b) { q.push([n, v, a, b]) > 1 || resume(n, v); }); }; if (f) i[n] = f(i[n]); } } + function resume(n, v) { try { step(g[n](v)); } catch (e) { settle(q[0][3], e); } } + function step(r) { r.value instanceof promise_client_await ? Promise.resolve(r.value.v).then(fulfill, reject) : settle(q[0][2], r); } + function fulfill(value) { resume("next", value); } + function reject(value) { resume("throw", value); } + function settle(f, v) { if (f(v), q.shift(), q.length) resume(q[0][0], q[0][1]); } +}; + + + + + +/** + * Create a Client for the given service, invoking RPCs through the + * given transport. + */ +function createClient(service, transport) { + return makeAnyClient(service, (method) => { + switch (method.kind) { + case MethodKind.Unary: + return createUnaryFn(transport, service, method); + case MethodKind.ServerStreaming: + return createServerStreamingFn(transport, service, method); + case MethodKind.ClientStreaming: + return createClientStreamingFn(transport, service, method); + case MethodKind.BiDiStreaming: + return createBiDiStreamingFn(transport, service, method); + default: + return null; + } + }); +} +/** + * @deprecated use createClient. + */ +function createPromiseClient(service, transport) { + return createClient(service, transport); +} +function createUnaryFn(transport, service, method) { + return async function (input, options) { + var _a, _b; + const response = await transport.unary(service, method, options === null || options === void 0 ? void 0 : options.signal, options === null || options === void 0 ? void 0 : options.timeoutMs, options === null || options === void 0 ? void 0 : options.headers, input, options === null || options === void 0 ? void 0 : options.contextValues); + (_a = options === null || options === void 0 ? void 0 : options.onHeader) === null || _a === void 0 ? void 0 : _a.call(options, response.header); + (_b = options === null || options === void 0 ? void 0 : options.onTrailer) === null || _b === void 0 ? void 0 : _b.call(options, response.trailer); + return response.message; + }; +} +function createServerStreamingFn(transport, service, method) { + return function (input, options) { + return handleStreamResponse(transport.stream(service, method, options === null || options === void 0 ? void 0 : options.signal, options === null || options === void 0 ? void 0 : options.timeoutMs, options === null || options === void 0 ? void 0 : options.headers, createAsyncIterable([input]), options === null || options === void 0 ? void 0 : options.contextValues), options); + }; +} +function createClientStreamingFn(transport, service, method) { + return async function (request, options) { + var _a, e_1, _b, _c; + var _d, _e; + const response = await transport.stream(service, method, options === null || options === void 0 ? void 0 : options.signal, options === null || options === void 0 ? void 0 : options.timeoutMs, options === null || options === void 0 ? void 0 : options.headers, request, options === null || options === void 0 ? void 0 : options.contextValues); + (_d = options === null || options === void 0 ? void 0 : options.onHeader) === null || _d === void 0 ? void 0 : _d.call(options, response.header); + let singleMessage; + let count = 0; + try { + for (var _f = true, _g = promise_client_asyncValues(response.message), _h; _h = await _g.next(), _a = _h.done, !_a; _f = true) { + _c = _h.value; + _f = false; + const message = _c; + singleMessage = message; + count++; + } + } + catch (e_1_1) { e_1 = { error: e_1_1 }; } + finally { + try { + if (!_f && !_a && (_b = _g.return)) await _b.call(_g); + } + finally { if (e_1) throw e_1.error; } + } + if (!singleMessage) { + throw new connect_error_ConnectError("protocol error: missing response message", code_Code.Unimplemented); + } + if (count > 1) { + throw new connect_error_ConnectError("protocol error: received extra messages for client streaming method", code_Code.Unimplemented); + } + (_e = options === null || options === void 0 ? void 0 : options.onTrailer) === null || _e === void 0 ? void 0 : _e.call(options, response.trailer); + return singleMessage; + }; +} +function createBiDiStreamingFn(transport, service, method) { + return function (request, options) { + return handleStreamResponse(transport.stream(service, method, options === null || options === void 0 ? void 0 : options.signal, options === null || options === void 0 ? void 0 : options.timeoutMs, options === null || options === void 0 ? void 0 : options.headers, request, options === null || options === void 0 ? void 0 : options.contextValues), options); + }; +} +function handleStreamResponse(stream, options) { + const it = (function () { + return promise_client_asyncGenerator(this, arguments, function* () { + var _a, _b; + const response = yield promise_client_await(stream); + (_a = options === null || options === void 0 ? void 0 : options.onHeader) === null || _a === void 0 ? void 0 : _a.call(options, response.header); + yield promise_client_await(yield* promise_client_asyncDelegator(promise_client_asyncValues(response.message))); + (_b = options === null || options === void 0 ? void 0 : options.onTrailer) === null || _b === void 0 ? void 0 : _b.call(options, response.trailer); + }); + })()[Symbol.asyncIterator](); + // Create a new iterable to omit throw/return. + return { + [Symbol.asyncIterator]: () => ({ + next: () => it.next(), + }), + }; +} + +// EXTERNAL MODULE: ./node_modules/undici/index.js +var undici = __nccwpck_require__(6752); +;// CONCATENATED MODULE: ./node_modules/@connectrpc/connect-node/dist/esm/node-headers-polyfill.js +// Copyright 2021-2024 The Connect Authors +// +// Licensed under the Apache License, Version 2.0 (the "License"); +// you may not use this file except in compliance with the License. +// You may obtain a copy of the License at +// +// http://www.apache.org/licenses/LICENSE-2.0 +// +// Unless required by applicable law or agreed to in writing, software +// distributed under the License is distributed on an "AS IS" BASIS, +// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. +// See the License for the specific language governing permissions and +// limitations under the License. + +// The global Headers class was introduced in Node v16.15.0, behind the +// --experimental-fetch flag. It became available by default with Node +// v18.0.0. +// If this code runs in Node < 18, it installs an alternative +// implementation if one has not already been polyfilled. +const [major] = process.versions.node + .split(".") + .map((value) => parseInt(value, 10)); +if (major < 18) { + if (typeof globalThis.Headers === "undefined") { + globalThis.Headers = undici.Headers; + } +} + +// EXTERNAL MODULE: external "zlib" +var external_zlib_ = __nccwpck_require__(3106); +;// CONCATENATED MODULE: ./node_modules/@connectrpc/connect-node/dist/esm/node-error.js +// Copyright 2021-2024 The Connect Authors +// +// Licensed under the Apache License, Version 2.0 (the "License"); +// you may not use this file except in compliance with the License. +// You may obtain a copy of the License at +// +// http://www.apache.org/licenses/LICENSE-2.0 +// +// Unless required by applicable law or agreed to in writing, software +// distributed under the License is distributed on an "AS IS" BASIS, +// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. +// See the License for the specific language governing permissions and +// limitations under the License. + +/** + * Similar to ConnectError.from(), this function turns any value into + * a ConnectError, but special cases some Node.js specific error codes and + * sets an appropriate Connect error code. + */ +function node_error_connectErrorFromNodeReason(reason) { + let code = code_Code.Internal; + const chain = unwrapNodeErrorChain(reason).map(getNodeErrorProps); + if (chain.some((p) => p.code == "ERR_STREAM_WRITE_AFTER_END")) { + // We do not want intentional errors from the server to be shadowed + // by client-side errors. + // This can occur if the server has written a response with an error + // and has ended the connection. This response may already sit in a + // buffer on the client, while it is still writing to the request + // body. + // To avoid this problem, we wrap ERR_STREAM_WRITE_AFTER_END as a + // ConnectError with Code.Aborted. The special meaning of this code + // in this situation is documented in StreamingConn.send() and in + // createServerStreamingFn(). + code = code_Code.Aborted; + } + else if (chain.some((p) => p.code == "ERR_STREAM_DESTROYED" || + p.code == "ERR_HTTP2_INVALID_STREAM" || + p.code == "ECONNRESET")) { + // A handler whose stream is suddenly destroyed usually means the client + // hung up. This behavior is triggered by the conformance test "cancel_after_begin". + code = code_Code.Aborted; + } + else if (chain.some((p) => p.code == "ETIMEDOUT" || + p.code == "ENOTFOUND" || + p.code == "EAI_AGAIN" || + p.code == "ECONNREFUSED")) { + // Calling an unresolvable host should raise a ConnectError with + // Code.Aborted. + // This behavior is covered by the conformance test "unresolvable_host". + code = code_Code.Unavailable; + } + const ce = connect_error_ConnectError.from(reason, code); + if (ce !== reason) { + ce.cause = reason; + } + return ce; +} +/** + * Unwraps a chain of errors, by walking through all "cause" properties + * recursively. + * This function is useful to find the root cause of an error. + */ +function unwrapNodeErrorChain(reason) { + const chain = []; + for (;;) { + if (!(reason instanceof Error)) { + break; + } + if (chain.includes(reason)) { + // safeguard against infinite loop when "cause" points to an ancestor + break; + } + chain.push(reason); + if (!("cause" in reason)) { + break; + } + reason = reason.cause; + } + return chain; +} +/** + * Returns standard Node.js error properties from the given reason, if present. + * + * For context: Every error raised by Node.js APIs should expose a `code` + * property - a string that permanently identifies the error. Some errors may + * have an additional `syscall` property - a string that identifies native + * components, for example "getaddrinfo" of libuv. + * For more information, see https://github.com/nodejs/node/blob/f6052c68c1f9a4400a723e9c0b79da14197ab754/lib/internal/errors.js + */ +function getNodeErrorProps(reason) { + const props = {}; + if (reason instanceof Error) { + if ("code" in reason && typeof reason.code == "string") { + props.code = reason.code; + } + if ("syscall" in reason && typeof reason.syscall == "string") { + props.syscall = reason.syscall; + } + } + return props; +} +/** + * Returns a ConnectError for an HTTP/2 error code. + */ +function node_error_connectErrorFromH2ResetCode(rstCode) { + switch (rstCode) { + case H2Code.PROTOCOL_ERROR: + case H2Code.INTERNAL_ERROR: + case H2Code.FLOW_CONTROL_ERROR: + case H2Code.SETTINGS_TIMEOUT: + case H2Code.FRAME_SIZE_ERROR: + case H2Code.COMPRESSION_ERROR: + case H2Code.CONNECT_ERROR: + return new connect_error_ConnectError(`http/2 stream closed with error code ${H2Code[rstCode]} (0x${rstCode.toString(16)})`, code_Code.Internal); + case H2Code.REFUSED_STREAM: + return new connect_error_ConnectError(`http/2 stream closed with error code ${H2Code[rstCode]} (0x${rstCode.toString(16)})`, code_Code.Unavailable); + case H2Code.CANCEL: + return new connect_error_ConnectError(`http/2 stream closed with error code ${H2Code[rstCode]} (0x${rstCode.toString(16)})`, code_Code.Canceled); + case H2Code.ENHANCE_YOUR_CALM: + return new connect_error_ConnectError(`http/2 stream closed with error code ${H2Code[rstCode]} (0x${rstCode.toString(16)})`, code_Code.ResourceExhausted); + case H2Code.INADEQUATE_SECURITY: + return new connect_error_ConnectError(`http/2 stream closed with error code ${H2Code[rstCode]} (0x${rstCode.toString(16)})`, code_Code.PermissionDenied); + case H2Code.HTTP_1_1_REQUIRED: + return new connect_error_ConnectError(`http/2 stream closed with error code ${H2Code[rstCode]} (0x${rstCode.toString(16)})`, code_Code.PermissionDenied); + case H2Code.STREAM_CLOSED: + default: + // Intentionally not mapping STREAM_CLOSED (0x5), see https://github.com/grpc/grpc/blob/master/doc/PROTOCOL-HTTP2.md#errors + break; + } + return undefined; +} +var H2Code; +(function (H2Code) { + H2Code[H2Code["PROTOCOL_ERROR"] = 1] = "PROTOCOL_ERROR"; + H2Code[H2Code["INTERNAL_ERROR"] = 2] = "INTERNAL_ERROR"; + H2Code[H2Code["FLOW_CONTROL_ERROR"] = 3] = "FLOW_CONTROL_ERROR"; + H2Code[H2Code["SETTINGS_TIMEOUT"] = 4] = "SETTINGS_TIMEOUT"; + H2Code[H2Code["STREAM_CLOSED"] = 5] = "STREAM_CLOSED"; + H2Code[H2Code["FRAME_SIZE_ERROR"] = 6] = "FRAME_SIZE_ERROR"; + H2Code[H2Code["REFUSED_STREAM"] = 7] = "REFUSED_STREAM"; + H2Code[H2Code["CANCEL"] = 8] = "CANCEL"; + H2Code[H2Code["COMPRESSION_ERROR"] = 9] = "COMPRESSION_ERROR"; + H2Code[H2Code["CONNECT_ERROR"] = 10] = "CONNECT_ERROR"; + H2Code[H2Code["ENHANCE_YOUR_CALM"] = 11] = "ENHANCE_YOUR_CALM"; + H2Code[H2Code["INADEQUATE_SECURITY"] = 12] = "INADEQUATE_SECURITY"; + H2Code[H2Code["HTTP_1_1_REQUIRED"] = 13] = "HTTP_1_1_REQUIRED"; +})(H2Code || (H2Code = {})); + +;// CONCATENATED MODULE: ./node_modules/@connectrpc/connect-node/dist/esm/compression.js +// Copyright 2021-2024 The Connect Authors +// +// Licensed under the Apache License, Version 2.0 (the "License"); +// you may not use this file except in compliance with the License. +// You may obtain a copy of the License at +// +// http://www.apache.org/licenses/LICENSE-2.0 +// +// Unless required by applicable law or agreed to in writing, software +// distributed under the License is distributed on an "AS IS" BASIS, +// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. +// See the License for the specific language governing permissions and +// limitations under the License. + + + + +const gzip = (0,external_util_.promisify)(external_zlib_.gzip); +const gunzip = (0,external_util_.promisify)(external_zlib_.gunzip); +const brotliCompress = (0,external_util_.promisify)(external_zlib_.brotliCompress); +const brotliDecompress = (0,external_util_.promisify)(external_zlib_.brotliDecompress); +/** + * The gzip compression algorithm, implemented with the Node.js built-in module + * zlib. This value can be used for the `sendCompression` and `acceptCompression` + * option of client transports, or for the `acceptCompression` option of server + * plugins like `fastifyConnectPlugin` from @connectrpc/connect-fastify. + */ +const compression_compressionGzip = { + name: "gzip", + compress(bytes) { + return gzip(bytes, {}); + }, + decompress(bytes, readMaxBytes) { + if (bytes.length == 0) { + return Promise.resolve(new Uint8Array(0)); + } + return wrapZLibErrors(gunzip(bytes, { + maxOutputLength: readMaxBytes, + }), readMaxBytes); + }, +}; +/** + * The brotli compression algorithm, implemented with the Node.js built-in module + * zlib. This value can be used for the `sendCompression` and `acceptCompression` + * option of client transports, or for the `acceptCompression` option of server + * plugins like `fastifyConnectPlugin` from @connectrpc/connect-fastify. + */ +const compression_compressionBrotli = { + name: "br", + compress(bytes) { + return brotliCompress(bytes, {}); + }, + decompress(bytes, readMaxBytes) { + if (bytes.length == 0) { + return Promise.resolve(new Uint8Array(0)); + } + return wrapZLibErrors(brotliDecompress(bytes, { + maxOutputLength: readMaxBytes, + }), readMaxBytes); + }, +}; +function wrapZLibErrors(promise, readMaxBytes) { + return promise.catch((e) => { + const props = getNodeErrorProps(e); + let code = code_Code.Internal; + let message = "decompression failed"; + // eslint-disable-next-line @typescript-eslint/switch-exhaustiveness-check + switch (props.code) { + case "ERR_BUFFER_TOO_LARGE": + code = code_Code.ResourceExhausted; + message = `message is larger than configured readMaxBytes ${readMaxBytes} after decompression`; + break; + case "Z_DATA_ERROR": + case "ERR_PADDING_2": + code = code_Code.InvalidArgument; + break; + default: + if (props.code !== undefined && + props.code.startsWith("ERR__ERROR_FORMAT_")) { + code = code_Code.InvalidArgument; + } + break; + } + return Promise.reject(new connect_error_ConnectError(message, code, undefined, undefined, e)); + }); +} + +// EXTERNAL MODULE: external "http2" +var external_http2_ = __nccwpck_require__(5675); +// EXTERNAL MODULE: external "http" +var external_http_ = __nccwpck_require__(8611); +// EXTERNAL MODULE: external "https" +var external_https_ = __nccwpck_require__(5692); +;// CONCATENATED MODULE: ./node_modules/@connectrpc/connect-node/dist/esm/node-universal-header.js +// Copyright 2021-2024 The Connect Authors +// +// Licensed under the Apache License, Version 2.0 (the "License"); +// you may not use this file except in compliance with the License. +// You may obtain a copy of the License at +// +// http://www.apache.org/licenses/LICENSE-2.0 +// +// Unless required by applicable law or agreed to in writing, software +// distributed under the License is distributed on an "AS IS" BASIS, +// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. +// See the License for the specific language governing permissions and +// limitations under the License. +/** + * Convert a Node.js header object to a fetch API Headers object. + * + * This function works for Node.js incoming and outgoing headers, and for the + * http and the http2 package. + * + * HTTP/2 pseudo-headers (:method, :path, etc.) are stripped. + */ +function node_universal_header_nodeHeaderToWebHeader(nodeHeaders) { + const header = new Headers(); + for (const [k, v] of Object.entries(nodeHeaders)) { + if (k.startsWith(":")) { + continue; + } + if (v === undefined) { + continue; + } + if (typeof v == "string") { + header.append(k, v); + } + else if (typeof v == "number") { + header.append(k, String(v)); + } + else { + for (const e of v) { + header.append(k, e); + } + } + } + return header; +} +function node_universal_header_webHeaderToNodeHeaders(headersInit, defaultNodeHeaders) { + if (headersInit === undefined && defaultNodeHeaders === undefined) { + return undefined; + } + const o = Object.create(null); + if (defaultNodeHeaders !== undefined) { + for (const [key, value] of Object.entries(defaultNodeHeaders)) { + if (Array.isArray(value)) { + o[key] = value.concat(); + } + else if (value !== undefined) { + o[key] = value; + } + } + } + if (headersInit !== undefined) { + if (Array.isArray(headersInit)) { + for (const [key, value] of headersInit) { + appendWebHeader(o, key, value); + } + } + else if ("forEach" in headersInit) { + if (typeof headersInit.forEach == "function") { + headersInit.forEach((value, key) => { + appendWebHeader(o, key, value); + }); + } + } + else { + for (const [key, value] of Object.entries(headersInit)) { + appendWebHeader(o, key, value); + } + } + } + return o; +} +function appendWebHeader(o, key, value) { + key = key.toLowerCase(); + const existing = o[key]; + if (Array.isArray(existing)) { + existing.push(value); + } + else if (existing === undefined) { + o[key] = value; + } + else { + o[key] = [existing.toString(), value]; + } +} + +;// CONCATENATED MODULE: ./node_modules/@connectrpc/connect/dist/esm/protocol/signals.js +// Copyright 2021-2024 The Connect Authors +// +// Licensed under the Apache License, Version 2.0 (the "License"); +// you may not use this file except in compliance with the License. +// You may obtain a copy of the License at +// +// http://www.apache.org/licenses/LICENSE-2.0 +// +// Unless required by applicable law or agreed to in writing, software +// distributed under the License is distributed on an "AS IS" BASIS, +// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. +// See the License for the specific language governing permissions and +// limitations under the License. + + +/** + * Create an AbortController that is automatically aborted if one of the given + * signals is aborted. + * + * For convenience, the linked AbortSignals can be undefined. + * + * If the controller or any of the signals is aborted, all event listeners are + * removed. + * + * @private Internal code, does not follow semantic versioning. + */ +function createLinkedAbortController(...signals) { + const controller = new AbortController(); + const sa = signals.filter((s) => s !== undefined).concat(controller.signal); + for (const signal of sa) { + if (signal.aborted) { + onAbort.apply(signal); + break; + } + signal.addEventListener("abort", onAbort); + } + function onAbort() { + if (!controller.signal.aborted) { + controller.abort(getAbortSignalReason(this)); + } + for (const signal of sa) { + signal.removeEventListener("abort", onAbort); + } + } + return controller; +} +/** + * Create a deadline signal. The returned object contains an AbortSignal, but + * also a cleanup function to stop the timer, which must be called once the + * calling code is no longer interested in the signal. + * + * Ideally, we would simply use AbortSignal.timeout(), but it is not widely + * available yet. + * + * @private Internal code, does not follow semantic versioning. + */ +function createDeadlineSignal(timeoutMs) { + const controller = new AbortController(); + const listener = () => { + controller.abort(new connect_error_ConnectError("the operation timed out", code_Code.DeadlineExceeded)); + }; + let timeoutId; + if (timeoutMs !== undefined) { + if (timeoutMs <= 0) + listener(); + else + timeoutId = setTimeout(listener, timeoutMs); + } + return { + signal: controller.signal, + cleanup: () => clearTimeout(timeoutId), + }; +} +/** + * Returns the reason why an AbortSignal was aborted. Returns undefined if the + * signal has not been aborted. + * + * The property AbortSignal.reason is not widely available. This function + * returns an AbortError if the signal is aborted, but reason is undefined. + * + * @private Internal code, does not follow semantic versioning. + */ +function getAbortSignalReason(signal) { + if (!signal.aborted) { + return undefined; + } + if (signal.reason !== undefined) { + return signal.reason; + } + // AbortSignal.reason is available in Node.js v16, v18, and later, + // and in all browsers since early 2022. + const e = new Error("This operation was aborted"); + e.name = "AbortError"; + return e; +} + +;// CONCATENATED MODULE: ./node_modules/@connectrpc/connect-node/dist/esm/http2-session-manager.js +// Copyright 2021-2024 The Connect Authors +// +// Licensed under the Apache License, Version 2.0 (the "License"); +// you may not use this file except in compliance with the License. +// You may obtain a copy of the License at +// +// http://www.apache.org/licenses/LICENSE-2.0 +// +// Unless required by applicable law or agreed to in writing, software +// distributed under the License is distributed on an "AS IS" BASIS, +// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. +// See the License for the specific language governing permissions and +// limitations under the License. + + + +/** + * Manage an HTTP/2 connection and keep it alive with PING frames. + * + * The logic is based on "Basic Keepalive" described in + * https://github.com/grpc/proposal/blob/0ba0c1905050525f9b0aee46f3f23c8e1e515489/A8-client-side-keepalive.md#basic-keepalive + * as well as the client channel arguments described in + * https://github.com/grpc/grpc/blob/8e137e524a1b1da7bbf4603662876d5719563b57/doc/keepalive.md + * + * Usually, the managers tracks exactly one connection, but if a connection + * receives a GOAWAY frame with NO_ERROR, the connection is maintained until + * all streams have finished, and new requests will open a new connection. + */ +class Http2SessionManager { + /** + * The current state of the connection: + * + * - "closed" + * The connection is closed, or no connection has been opened yet. + * - connecting + * Currently establishing a connection. + * + * - "open" + * A connection is open and has open streams. PING frames are sent every + * pingIntervalMs, unless a stream received data. + * If a PING frame is not responded to within pingTimeoutMs, the connection + * and all open streams close. + * + * - "idle" + * A connection is open, but it does not have any open streams. + * If pingIdleConnection is enabled, PING frames are used to keep the + * connection alive, similar to an "open" connection. + * If a connection is idle for longer than idleConnectionTimeoutMs, it closes. + * If a request is made on an idle connection that has not been used for + * longer than pingIntervalMs, the connection is verified. + * + * - "verifying" + * Verifying a connection after a long period of inactivity before issuing a + * request. A PING frame is sent, and if it times out within pingTimeoutMs, a + * new connection is opened. + * + * - "error" + * The connection is closed because of a transient error. A connection + * may have failed to reach the host, or the connection may have died, + * or it may have been aborted. + */ + state() { + if (this.s.t == "ready") { + if (this.verifying !== undefined) { + return "verifying"; + } + return this.s.streamCount() > 0 ? "open" : "idle"; + } + return this.s.t; + } + /** + * Returns the error object if the connection is in the "error" state, + * `undefined` otherwise. + */ + error() { + if (this.s.t == "error") { + return this.s.reason; + } + return undefined; + } + constructor(url, pingOptions, http2SessionOptions) { + var _a, _b, _c, _d; + this.s = http2_session_manager_closed(); + this.shuttingDown = []; + this.authority = new URL(url).origin; + this.http2SessionOptions = http2SessionOptions; + this.options = { + pingIntervalMs: (_a = pingOptions === null || pingOptions === void 0 ? void 0 : pingOptions.pingIntervalMs) !== null && _a !== void 0 ? _a : Number.POSITIVE_INFINITY, + pingTimeoutMs: (_b = pingOptions === null || pingOptions === void 0 ? void 0 : pingOptions.pingTimeoutMs) !== null && _b !== void 0 ? _b : 1000 * 15, + pingIdleConnection: (_c = pingOptions === null || pingOptions === void 0 ? void 0 : pingOptions.pingIdleConnection) !== null && _c !== void 0 ? _c : false, + idleConnectionTimeoutMs: (_d = pingOptions === null || pingOptions === void 0 ? void 0 : pingOptions.idleConnectionTimeoutMs) !== null && _d !== void 0 ? _d : 1000 * 60 * 15, + }; + } + /** + * Open a connection if none exists, verify an existing connection if + * necessary. + */ + async connect() { + try { + const ready = await this.gotoReady(); + return ready.streamCount() > 0 ? "open" : "idle"; + } + catch (e) { + return "error"; + } + } + /** + * Issue a request. + * + * This method automatically opens a connection if none exists, and verifies + * an existing connection if necessary. It calls http2.ClientHttp2Session.request(), + * and keeps track of all open http2.ClientHttp2Stream. + * + * Clients must call notifyResponseByteRead() whenever they successfully read + * data from the http2.ClientHttp2Stream. + */ + async request(method, path, headers, options) { + // Request sometimes fails with goaway/destroyed + // errors, we use a loop to retry. + // + // This is not expected to happen often, but it is possible that a + // connection is closed while we are trying to open a stream. + // + // Ref: https://github.com/nodejs/help/issues/2105 + for (;;) { + const ready = await this.gotoReady(); + try { + const stream = ready.conn.request(Object.assign(Object.assign({}, headers), { ":method": method, ":path": path }), options); + ready.registerRequest(stream); + return stream; + } + catch (e) { + // Check to see if the connection is closed or destroyed + // and if so, we try again. + if (ready.conn.closed || ready.conn.destroyed) { + continue; + } + throw e; + } + } + } + /** + * Notify the manager of a successful read from a http2.ClientHttp2Stream. + * + * Clients must call this function whenever they successfully read data from + * a http2.ClientHttp2Stream obtained from request(). This informs the + * keep-alive logic that the connection is alive, and prevents it from sending + * unnecessary PING frames. + */ + notifyResponseByteRead(stream) { + if (this.s.t == "ready") { + this.s.responseByteRead(stream); + } + for (const s of this.shuttingDown) { + s.responseByteRead(stream); + } + } + /** + * If there is an open connection, close it. This also closes any open streams. + */ + abort(reason) { + var _a, _b, _c; + const err = reason !== null && reason !== void 0 ? reason : new connect_error_ConnectError("connection aborted", code_Code.Canceled); + (_b = (_a = this.s).abort) === null || _b === void 0 ? void 0 : _b.call(_a, err); + for (const s of this.shuttingDown) { + (_c = s.abort) === null || _c === void 0 ? void 0 : _c.call(s, err); + } + this.setState(closedOrError(err)); + } + async gotoReady() { + if (this.s.t == "ready") { + if (this.s.isShuttingDown() || + this.s.conn.closed || + this.s.conn.destroyed) { + this.setState(connect(this.authority, this.http2SessionOptions)); + } + else if (this.s.requiresVerify()) { + await this.verify(this.s); + } + } + else if (this.s.t == "closed" || this.s.t == "error") { + this.setState(connect(this.authority, this.http2SessionOptions)); + } + while (this.s.t !== "ready") { + if (this.s.t === "error") { + throw this.s.reason; + } + if (this.s.t === "connecting") { + await this.s.conn; + } + } + return this.s; + } + setState(state) { + var _a, _b; + (_b = (_a = this.s).onExitState) === null || _b === void 0 ? void 0 : _b.call(_a); + if (this.s.t == "ready" && this.s.isShuttingDown()) { + // Maintain connections that have been asked to shut down. + const sd = this.s; + this.shuttingDown.push(sd); + sd.onClose = sd.onError = () => { + const i = this.shuttingDown.indexOf(sd); + if (i !== -1) { + this.shuttingDown.splice(i, 1); + } + }; + } + switch (state.t) { + case "connecting": + state.conn.then((value) => { + this.setState(ready(value, this.options)); + }, (reason) => { + this.setState(closedOrError(reason)); + }); + break; + case "ready": + state.onClose = () => this.setState(http2_session_manager_closed()); + state.onError = (err) => this.setState(closedOrError(err)); + break; + case "closed": + break; + case "error": + break; + } + this.s = state; + } + verify(stateReady) { + if (this.verifying !== undefined) { + return this.verifying; + } + this.verifying = stateReady + .verify() + .then((success) => { + if (success) { + return; + } + // verify() has destroyed the old connection + this.setState(connect(this.authority, this.http2SessionOptions)); + }, (reason) => { + this.setState(closedOrError(reason)); + }) + .finally(() => { + this.verifying = undefined; + }); + return this.verifying; + } +} +function http2_session_manager_closed() { + return { + t: "closed", + }; +} +function error(reason) { + return { + t: "error", + reason, + }; +} +function closedOrError(reason) { + const isCancel = reason instanceof connect_error_ConnectError && + connect_error_ConnectError.from(reason).code == code_Code.Canceled; + return isCancel ? http2_session_manager_closed() : error(reason); +} +function connect(authority, http2SessionOptions) { + let resolve; + let reject; + const conn = new Promise((res, rej) => { + resolve = res; + reject = rej; + }); + const newConn = external_http2_.connect(authority, http2SessionOptions); + newConn.on("connect", onConnect); + newConn.on("error", onError); + function onConnect() { + resolve === null || resolve === void 0 ? void 0 : resolve(newConn); + cleanup(); + } + function onError(err) { + reject === null || reject === void 0 ? void 0 : reject(node_error_connectErrorFromNodeReason(err)); + cleanup(); + } + function cleanup() { + newConn.off("connect", onConnect); + newConn.off("error", onError); + } + return { + t: "connecting", + conn, + abort(reason) { + if (!newConn.destroyed) { + newConn.destroy(undefined, external_http2_.constants.NGHTTP2_CANCEL); + } + // According to the documentation, destroy() should immediately terminate + // the session and the socket, but we still receive a "connect" event. + // We must not resolve a broken connection, so we reject it manually here. + reject === null || reject === void 0 ? void 0 : reject(reason); + }, + onExitState() { + cleanup(); + }, + }; +} +function ready(conn, options) { + // Users have reported an error "The session has been destroyed" raised + // from H2SessionManager.request(), see https://github.com/connectrpc/connect-es/issues/683 + // This assertion will show whether the session already died in the + // "connecting" state. + assertSessionOpen(conn); + // Do not block Node.js from exiting on an idle connection. + // Note that we ref() again for the first stream to open, and unref() again + // for the last stream to close. + conn.unref(); + // the last time we were sure that the connection is alive, via a PING + // response, or via received response bytes + let lastAliveAt = Date.now(); + // how many streams are currently open on this session + let streamCount = 0; + // timer for the keep-alive interval + let pingIntervalId; + // timer for waiting for a PING response + let pingTimeoutId; + // keep track of GOAWAY - gracefully shut down open streams / wait for connection to error + let receivedGoAway = false; + // keep track of GOAWAY with ENHANCE_YOUR_CALM and with debug data too_many_pings + let receivedGoAwayEnhanceYourCalmTooManyPings = false; + // timer for closing connections without open streams, must be initialized + let idleTimeoutId; + resetIdleTimeout(); + const state = { + t: "ready", + conn, + streamCount() { + return streamCount; + }, + requiresVerify() { + const elapsedMs = Date.now() - lastAliveAt; + return elapsedMs > options.pingIntervalMs; + }, + isShuttingDown() { + return receivedGoAway; + }, + onClose: undefined, + onError: undefined, + registerRequest(stream) { + streamCount++; + if (streamCount == 1) { + conn.ref(); + resetPingInterval(); // reset to ping with the appropriate interval for "open" + stopIdleTimeout(); + } + stream.once("response", () => { + lastAliveAt = Date.now(); + resetPingInterval(); + }); + stream.once("close", () => { + streamCount--; + if (streamCount == 0) { + conn.unref(); + resetPingInterval(); // reset to ping with the appropriate interval for "idle" + resetIdleTimeout(); + } + }); + }, + responseByteRead(stream) { + if (stream.session !== conn) { + return; + } + if (conn.closed || conn.destroyed) { + return; + } + if (streamCount <= 0) { + return; + } + lastAliveAt = Date.now(); + resetPingInterval(); + }, + verify() { + conn.ref(); + return new Promise((resolve) => { + commonPing(() => { + if (streamCount == 0) + conn.unref(); + resolve(true); + }); + conn.once("error", () => resolve(false)); + }); + }, + abort(reason) { + if (!conn.destroyed) { + conn.once("error", () => { + // conn.destroy() may raise an error after onExitState() was called + // and our error listeners are removed. + // We attach this one to swallow uncaught exceptions. + }); + conn.destroy(reason, external_http2_.constants.NGHTTP2_CANCEL); + } + }, + onExitState() { + if (state.isShuttingDown()) { + // Per the interface, this method is called when the manager is leaving + // the state. We maintain this connection in the session manager until + // all streams have finished, so we do not detach event listeners here. + return; + } + cleanup(); + this.onError = undefined; + this.onClose = undefined; + }, + }; + // start or restart the ping interval + function resetPingInterval() { + stopPingInterval(); + if (streamCount > 0 || options.pingIdleConnection) { + pingIntervalId = safeSetTimeout(onPingInterval, options.pingIntervalMs); + } + } + function stopPingInterval() { + clearTimeout(pingIntervalId); + clearTimeout(pingTimeoutId); + } + function onPingInterval() { + commonPing(resetPingInterval); + } + function commonPing(onSuccess) { + clearTimeout(pingTimeoutId); + pingTimeoutId = safeSetTimeout(() => { + conn.destroy(new connect_error_ConnectError("PING timed out", code_Code.Unavailable), external_http2_.constants.NGHTTP2_CANCEL); + }, options.pingTimeoutMs); + conn.ping((err, duration) => { + clearTimeout(pingTimeoutId); + if (err !== null) { + // We will receive an ERR_HTTP2_PING_CANCEL here if we destroy the + // connection with a pending ping. + // We might also see other errors, but they should be picked up by the + // "error" event listener. + return; + } + if (duration > options.pingTimeoutMs) { + // setTimeout is not precise, and HTTP/2 pings take less than 1ms in + // tests. + conn.destroy(new connect_error_ConnectError("PING timed out", code_Code.Unavailable), external_http2_.constants.NGHTTP2_CANCEL); + return; + } + lastAliveAt = Date.now(); + onSuccess(); + }); + } + function stopIdleTimeout() { + clearTimeout(idleTimeoutId); + } + function resetIdleTimeout() { + idleTimeoutId = safeSetTimeout(onIdleTimeout, options.idleConnectionTimeoutMs); + } + function onIdleTimeout() { + conn.close(); + onClose(); // trigger a state change right away, so we are not open to races + } + function onGoaway(errorCode, lastStreamID, opaqueData) { + receivedGoAway = true; + const tooManyPingsAscii = Buffer.from("too_many_pings", "ascii"); + if (errorCode === external_http2_.constants.NGHTTP2_ENHANCE_YOUR_CALM && + opaqueData != null && + opaqueData.equals(tooManyPingsAscii)) { + // double pingIntervalMs, following the last paragraph of https://github.com/grpc/proposal/blob/0ba0c1905050525f9b0aee46f3f23c8e1e515489/A8-client-side-keepalive.md#basic-keepalive + options.pingIntervalMs = options.pingIntervalMs * 2; + receivedGoAwayEnhanceYourCalmTooManyPings = true; + } + if (errorCode === external_http2_.constants.NGHTTP2_NO_ERROR) { + const nodeMajor = parseInt(process.versions.node.split(".")[0], 10); + // Node.js v16 closes a connection on its own when it receives a GOAWAY + // frame and there are no open streams (emitting a "close" event and + // destroying the session), but more recent versions do not. + // Calling close() ourselves is ineffective here - it appears that the + // method is already being called, see https://github.com/nodejs/node/blob/198affc63973805ce5102d246f6b7822be57f5fc/lib/internal/http2/core.js#L681 + if (streamCount == 0 && nodeMajor >= 18) { + conn.destroy(new connect_error_ConnectError("received GOAWAY without any open streams", code_Code.Canceled), external_http2_.constants.NGHTTP2_NO_ERROR); + } + } + } + function onClose() { + var _a; + cleanup(); + (_a = state.onClose) === null || _a === void 0 ? void 0 : _a.call(state); + } + function onError(err) { + var _a, _b; + cleanup(); + if (receivedGoAwayEnhanceYourCalmTooManyPings) { + // We cannot prevent node from destroying session and streams with its own + // error that does not carry debug data, but at least we can wrap the error + // we surface on the manager. + const ce = new connect_error_ConnectError(`http/2 connection closed with error code ENHANCE_YOUR_CALM (0x${external_http2_.constants.NGHTTP2_ENHANCE_YOUR_CALM.toString(16)}), too_many_pings, doubled the interval`, code_Code.ResourceExhausted); + (_a = state.onError) === null || _a === void 0 ? void 0 : _a.call(state, ce); + } + else { + (_b = state.onError) === null || _b === void 0 ? void 0 : _b.call(state, node_error_connectErrorFromNodeReason(err)); + } + } + function cleanup() { + stopPingInterval(); + stopIdleTimeout(); + conn.off("error", onError); + conn.off("close", onClose); + conn.off("goaway", onGoaway); + } + conn.on("error", onError); + conn.on("close", onClose); + conn.on("goaway", onGoaway); + return state; +} +/** + * setTimeout(), but simply ignores values larger than the maximum supported + * value (signed 32-bit integer) instead of calling the callback right away, + * and does not block Node.js from exiting. + */ +function safeSetTimeout(callback, ms) { + if (ms > 0x7fffffff) { + return; + } + return setTimeout(callback, ms).unref(); +} +function assertSessionOpen(conn) { + if (conn.connecting) { + throw new connect_error_ConnectError("expected open session, but it is connecting", code_Code.Internal); + } + if (conn.destroyed) { + throw new connect_error_ConnectError("expected open session, but it is destroyed", code_Code.Internal); + } + if (conn.closed) { + throw new connect_error_ConnectError("expected open session, but it is closed", code_Code.Internal); + } +} + +;// CONCATENATED MODULE: ./node_modules/@connectrpc/connect-node/dist/esm/node-universal-client.js +// Copyright 2021-2024 The Connect Authors +// +// Licensed under the Apache License, Version 2.0 (the "License"); +// you may not use this file except in compliance with the License. +// You may obtain a copy of the License at +// +// http://www.apache.org/licenses/LICENSE-2.0 +// +// Unless required by applicable law or agreed to in writing, software +// distributed under the License is distributed on an "AS IS" BASIS, +// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. +// See the License for the specific language governing permissions and +// limitations under the License. + + + + + + + + +/** + * Create a universal client function, a minimal abstraction of an HTTP client, + * using the Node.js `http`, `https`, or `http2` module. + * + * @private Internal code, does not follow semantic versioning. + */ +function createNodeHttpClient(options) { + var _a; + if (options.httpVersion == "1.1") { + return createNodeHttp1Client(options.nodeOptions); + } + const sessionProvider = (_a = options.sessionProvider) !== null && _a !== void 0 ? _a : ((url) => new Http2SessionManager(url)); + return createNodeHttp2Client(sessionProvider); +} +/** + * Create an HTTP client using the Node.js `http` or `https` package. + * + * The HTTP client is a simple function conforming to the type UniversalClientFn. + * It takes an UniversalClientRequest as an argument, and returns a promise for + * an UniversalClientResponse. + */ +function createNodeHttp1Client(httpOptions) { + return async function request(req) { + const sentinel = createSentinel(req.signal); + return new Promise((resolve, reject) => { + sentinel.catch((e) => { + reject(e); + }); + h1Request(sentinel, req.url, Object.assign(Object.assign({}, httpOptions), { headers: node_universal_header_webHeaderToNodeHeaders(req.header, httpOptions === null || httpOptions === void 0 ? void 0 : httpOptions.headers), method: req.method }), (request) => { + void sinkRequest(req, request, sentinel); + request.on("response", (response) => { + var _a; + response.on("error", sentinel.reject); + sentinel.catch((reason) => response.destroy(node_error_connectErrorFromNodeReason(reason))); + const trailer = new Headers(); + resolve({ + status: (_a = response.statusCode) !== null && _a !== void 0 ? _a : 0, + header: node_universal_header_nodeHeaderToWebHeader(response.headers), + body: h1ResponseIterable(sentinel, response, trailer), + trailer, + }); + }); + }); + }); + }; +} +/** + * Create an HTTP client using the Node.js `http2` package. + * + * The HTTP client is a simple function conforming to the type UniversalClientFn. + * It takes an UniversalClientRequest as an argument, and returns a promise for + * an UniversalClientResponse. + */ +function createNodeHttp2Client(sessionProvider) { + return function request(req) { + const sentinel = createSentinel(req.signal); + const sessionManager = sessionProvider(req.url); + return new Promise((resolve, reject) => { + sentinel.catch((e) => { + reject(e); + }); + h2Request(sentinel, sessionManager, req.url, req.method, node_universal_header_webHeaderToNodeHeaders(req.header), {}, (stream) => { + void sinkRequest(req, stream, sentinel); + stream.on("response", (headers) => { + var _a; + const response = { + status: (_a = headers[":status"]) !== null && _a !== void 0 ? _a : 0, + header: node_universal_header_nodeHeaderToWebHeader(headers), + body: h2ResponseIterable(sentinel, stream, sessionManager), + trailer: h2ResponseTrailer(stream), + }; + resolve(response); + }); + }); + }); + }; +} +function h1Request(sentinel, url, options, onRequest) { + let request; + if (new URL(url).protocol.startsWith("https")) { + request = external_https_.request(url, options); + } + else { + request = external_http_.request(url, options); + } + sentinel.catch((reason) => request.destroy(node_error_connectErrorFromNodeReason(reason))); + // Node.js will only send headers with the first request body byte by default. + // We force it to send headers right away for consistent behavior between + // HTTP/1.1 and HTTP/2.2 clients. + request.flushHeaders(); + request.on("error", sentinel.reject); + request.on("socket", function onRequestSocket(socket) { + function onSocketConnect() { + socket.off("connect", onSocketConnect); + onRequest(request); + } + // If readyState is open, then socket is already open due to keepAlive, so + // the 'connect' event will never fire so call onRequest explicitly + if (socket.readyState === "open") { + onRequest(request); + } + else { + socket.on("connect", onSocketConnect); + } + }); +} +function h1ResponseIterable(sentinel, response, trailer) { + const inner = response[Symbol.asyncIterator](); + return { + [Symbol.asyncIterator]() { + return { + async next() { + const r = await sentinel.race(inner.next()); + if (r.done === true) { + node_universal_header_nodeHeaderToWebHeader(response.trailers).forEach((value, key) => { + trailer.set(key, value); + }); + sentinel.resolve(); + await sentinel; + } + return r; + }, + throw(e) { + sentinel.reject(e); + throw e; + }, + }; + }, + }; +} +function h2Request(sentinel, sm, url, method, headers, options, onStream) { + const requestUrl = new URL(url); + if (requestUrl.origin !== sm.authority) { + const message = `cannot make a request to ${requestUrl.origin}: the http2 session is connected to ${sm.authority}`; + sentinel.reject(new connect_error_ConnectError(message, code_Code.Internal)); + return; + } + sm.request(method, requestUrl.pathname + requestUrl.search, headers, {}).then((stream) => { + sentinel.catch((reason) => { + if (stream.closed) { + return; + } + // Node.js http2 streams that are aborted via an AbortSignal close with + // an RST_STREAM with code INTERNAL_ERROR. + // To comply with the mapping between gRPC and HTTP/2 codes, we need to + // close with code CANCEL. + // See https://github.com/grpc/grpc/blob/master/doc/PROTOCOL-HTTP2.md#errors + // See https://www.rfc-editor.org/rfc/rfc7540#section-7 + const rstCode = reason instanceof connect_error_ConnectError && reason.code == code_Code.Canceled + ? H2Code.CANCEL + : H2Code.INTERNAL_ERROR; + return new Promise((resolve) => stream.close(rstCode, resolve)); + }); + stream.on("error", function h2StreamError(e) { + if (stream.writableEnded && + unwrapNodeErrorChain(e) + .map(getNodeErrorProps) + .some((p) => p.code == "ERR_STREAM_WRITE_AFTER_END")) { + return; + } + sentinel.reject(e); + }); + stream.on("close", function h2StreamClose() { + const err = node_error_connectErrorFromH2ResetCode(stream.rstCode); + if (err) { + sentinel.reject(err); + } + }); + onStream(stream); + }, (reason) => { + sentinel.reject(reason); + }); +} +function h2ResponseTrailer(response) { + const trailer = new Headers(); + response.on("trailers", (args) => { + node_universal_header_nodeHeaderToWebHeader(args).forEach((value, key) => { + trailer.set(key, value); + }); + }); + return trailer; +} +function h2ResponseIterable(sentinel, response, sm) { + const inner = response[Symbol.asyncIterator](); + return { + [Symbol.asyncIterator]() { + return { + async next() { + const r = await sentinel.race(inner.next()); + if (r.done === true) { + sentinel.resolve(); + await sentinel; + } + sm === null || sm === void 0 ? void 0 : sm.notifyResponseByteRead(response); + return r; + }, + throw(e) { + sentinel.reject(e); + throw e; + }, + }; + }, + }; +} +async function sinkRequest(request, nodeRequest, sentinel) { + if (request.body === undefined) { + await new Promise((resolve) => nodeRequest.end(resolve)); + return; + } + const it = request.body[Symbol.asyncIterator](); + return new Promise((resolve) => { + writeNext(); + function writeNext() { + if (sentinel.isRejected()) { + return; + } + it.next().then((r) => { + if (r.done === true) { + nodeRequest.end(resolve); + return; + } + nodeRequest.write(r.value, "binary", function (e) { + if (e === null || e === undefined) { + writeNext(); + return; + } + if (it.throw !== undefined) { + it.throw(node_error_connectErrorFromNodeReason(e)).catch(() => { + // + }); + } + // If the server responds and closes the connection before the client has written the entire response + // body, we get an ERR_STREAM_WRITE_AFTER_END error code from Node.js here. + // We do want to notify the iterable of the error condition, but we do not want to reject our sentinel, + // because that would also affect the reading side. + if (nodeRequest.writableEnded && + unwrapNodeErrorChain(e) + .map(getNodeErrorProps) + .some((p) => p.code == "ERR_STREAM_WRITE_AFTER_END")) { + return; + } + sentinel.reject(e); + }); + }, (e) => { + sentinel.reject(e); + }); + } + }); +} +function createSentinel(signal) { + let res; + let rej; + let resolved = false; + let rejected = false; + const p = new Promise((resolve, reject) => { + res = resolve; + rej = reject; + }); + const c = { + resolve() { + if (!resolved && !rejected) { + resolved = true; + res === null || res === void 0 ? void 0 : res(); + } + }, + isResolved() { + return resolved; + }, + reject(reason) { + if (!resolved && !rejected) { + rejected = true; + rej === null || rej === void 0 ? void 0 : rej(node_error_connectErrorFromNodeReason(reason)); + } + }, + isRejected() { + return rejected; + }, + async race(promise) { + const r = await Promise.race([promise, p]); + if (r === undefined && resolved) { + throw new connect_error_ConnectError("sentinel completed early", code_Code.Internal); + } + return r; + }, + }; + const s = Object.assign(p, c); + function onSignalAbort() { + c.reject(getAbortSignalReason(this)); + } + if (signal) { + if (signal.aborted) { + c.reject(getAbortSignalReason(signal)); + } + else { + signal.addEventListener("abort", onSignalAbort); + } + p.finally(() => signal.removeEventListener("abort", onSignalAbort)).catch(() => { + // We intentionally swallow sentinel rejection - errors must + // propagate through the request or response iterables. + }); + } + return s; +} + +;// CONCATENATED MODULE: ./node_modules/@connectrpc/connect-node/dist/esm/node-transport-options.js +// Copyright 2021-2024 The Connect Authors +// +// Licensed under the Apache License, Version 2.0 (the "License"); +// you may not use this file except in compliance with the License. +// You may obtain a copy of the License at +// +// http://www.apache.org/licenses/LICENSE-2.0 +// +// Unless required by applicable law or agreed to in writing, software +// distributed under the License is distributed on an "AS IS" BASIS, +// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. +// See the License for the specific language governing permissions and +// limitations under the License. + + + + + + + +/** + * Asserts that the options are within sane limits, and returns default values + * where no value is provided. + * + * @private Internal code, does not follow semantic versioning. + */ +function node_transport_options_validateNodeTransportOptions(options) { + var _a, _b, _c, _d; + let httpClient; + if (options.httpVersion == "2") { + let sessionManager; + if (options.sessionManager) { + sessionManager = options.sessionManager; + } + else { + sessionManager = new Http2SessionManager(options.baseUrl, { + pingIntervalMs: options.pingIntervalMs, + pingIdleConnection: options.pingIdleConnection, + pingTimeoutMs: options.pingTimeoutMs, + idleConnectionTimeoutMs: options.idleConnectionTimeoutMs, + }, options.nodeOptions); + } + httpClient = createNodeHttpClient({ + httpVersion: "2", + sessionProvider: () => sessionManager, + }); + } + else { + httpClient = createNodeHttpClient({ + httpVersion: "1.1", + nodeOptions: options.nodeOptions, + }); + } + return Object.assign(Object.assign(Object.assign({}, options), { httpClient, useBinaryFormat: (_a = options.useBinaryFormat) !== null && _a !== void 0 ? _a : true, interceptors: (_b = options.interceptors) !== null && _b !== void 0 ? _b : [], sendCompression: (_c = options.sendCompression) !== null && _c !== void 0 ? _c : null, acceptCompression: (_d = options.acceptCompression) !== null && _d !== void 0 ? _d : [ + compression_compressionGzip, + compression_compressionBrotli, + ] }), validateReadWriteMaxBytes(options.readMaxBytes, options.writeMaxBytes, options.compressMinBytes)); +} + +;// CONCATENATED MODULE: ./node_modules/@connectrpc/connect-node/dist/esm/grpc-web-transport.js +// Copyright 2021-2024 The Connect Authors +// +// Licensed under the Apache License, Version 2.0 (the "License"); +// you may not use this file except in compliance with the License. +// You may obtain a copy of the License at +// +// http://www.apache.org/licenses/LICENSE-2.0 +// +// Unless required by applicable law or agreed to in writing, software +// distributed under the License is distributed on an "AS IS" BASIS, +// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. +// See the License for the specific language governing permissions and +// limitations under the License. + + +/** + * Create a Transport for the gRPC-web protocol using the Node.js `http`, + * `http2`, or `http2` module. + */ +function createGrpcWebTransport(options) { + return createTransport(validateNodeTransportOptions(options)); +} + +;// CONCATENATED MODULE: ./node_modules/@connectrpc/connect/dist/esm/protocol-grpc/headers.js +// Copyright 2021-2024 The Connect Authors +// +// Licensed under the Apache License, Version 2.0 (the "License"); +// you may not use this file except in compliance with the License. +// You may obtain a copy of the License at +// +// http://www.apache.org/licenses/LICENSE-2.0 +// +// Unless required by applicable law or agreed to in writing, software +// distributed under the License is distributed on an "AS IS" BASIS, +// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. +// See the License for the specific language governing permissions and +// limitations under the License. +/** + * @private Internal code, does not follow semantic versioning. + */ +const headerContentType = "Content-Type"; +const headerEncoding = "Grpc-Encoding"; +const headerAcceptEncoding = "Grpc-Accept-Encoding"; +const headerTimeout = "Grpc-Timeout"; +const headers_headerGrpcStatus = "Grpc-Status"; +const headers_headerGrpcMessage = "Grpc-Message"; +const headers_headerStatusDetailsBin = "Grpc-Status-Details-Bin"; +const headerMessageType = "Grpc-Message-Type"; +const headerUserAgent = "User-Agent"; + +;// CONCATENATED MODULE: ./node_modules/@connectrpc/connect/dist/esm/protocol-grpc/content-type.js +// Copyright 2021-2024 The Connect Authors +// +// Licensed under the Apache License, Version 2.0 (the "License"); +// you may not use this file except in compliance with the License. +// You may obtain a copy of the License at +// +// http://www.apache.org/licenses/LICENSE-2.0 +// +// Unless required by applicable law or agreed to in writing, software +// distributed under the License is distributed on an "AS IS" BASIS, +// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. +// See the License for the specific language governing permissions and +// limitations under the License. +/** + * Regular Expression that matches any valid gRPC Content-Type header value. + * + * @private Internal code, does not follow semantic versioning. + */ +const contentTypeRegExp = /^application\/grpc(?:\+(?:(json)(?:; ?charset=utf-?8)?|proto))?$/i; +const contentTypeProto = "application/grpc+proto"; +const contentTypeJson = "application/grpc+json"; +/** + * Parse a gRPC Content-Type header. + * + * @private Internal code, does not follow semantic versioning. + */ +function parseContentType(contentType) { + const match = contentType === null || contentType === void 0 ? void 0 : contentType.match(contentTypeRegExp); + if (!match) { + return undefined; + } + const binary = !match[1]; + return { binary }; +} + +;// CONCATENATED MODULE: ./node_modules/@connectrpc/connect/dist/esm/protocol-grpc/request-header.js +// Copyright 2021-2024 The Connect Authors +// +// Licensed under the Apache License, Version 2.0 (the "License"); +// you may not use this file except in compliance with the License. +// You may obtain a copy of the License at +// +// http://www.apache.org/licenses/LICENSE-2.0 +// +// Unless required by applicable law or agreed to in writing, software +// distributed under the License is distributed on an "AS IS" BASIS, +// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. +// See the License for the specific language governing permissions and +// limitations under the License. + + +/** + * Creates headers for a gRPC request. + * + * @private Internal code, does not follow semantic versioning. + */ +function requestHeader(useBinaryFormat, timeoutMs, userProvidedHeaders) { + const result = new Headers(userProvidedHeaders !== null && userProvidedHeaders !== void 0 ? userProvidedHeaders : {}); + result.set(headerContentType, useBinaryFormat ? contentTypeProto : contentTypeJson); + // Note that we do not strictly comply with gRPC user agents. + // We use "connect-es/1.2.3" where gRPC would use "grpc-es/1.2.3". + // See https://github.com/grpc/grpc/blob/c462bb8d485fc1434ecfae438823ca8d14cf3154/doc/PROTOCOL-HTTP2.md#user-agents + result.set(headerUserAgent, "connect-es/1.6.1"); + if (timeoutMs !== undefined) { + result.set(headerTimeout, `${timeoutMs}m`); + } + // The gRPC-HTTP2 specification requires this - it flushes out proxies that + // don't support HTTP trailers. + result.set("Te", "trailers"); + return result; +} +/** + * Creates headers for a gRPC request with compression. + * + * @private Internal code, does not follow semantic versioning. + */ +function requestHeaderWithCompression(useBinaryFormat, timeoutMs, userProvidedHeaders, acceptCompression, sendCompression) { + const result = requestHeader(useBinaryFormat, timeoutMs, userProvidedHeaders); + if (sendCompression != null) { + result.set(headerEncoding, sendCompression.name); + } + if (acceptCompression.length > 0) { + result.set(headerAcceptEncoding, acceptCompression.map((c) => c.name).join(",")); + } + return result; +} + +;// CONCATENATED MODULE: ./node_modules/@connectrpc/connect/dist/esm/protocol-grpc/http-status.js +// Copyright 2021-2024 The Connect Authors +// +// Licensed under the Apache License, Version 2.0 (the "License"); +// you may not use this file except in compliance with the License. +// You may obtain a copy of the License at +// +// http://www.apache.org/licenses/LICENSE-2.0 +// +// Unless required by applicable law or agreed to in writing, software +// distributed under the License is distributed on an "AS IS" BASIS, +// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. +// See the License for the specific language governing permissions and +// limitations under the License. + +/** + * Determine the gRPC-web error code for the given HTTP status code. + * See https://github.com/grpc/grpc/blob/master/doc/http-grpc-status-mapping.md. + * + * @private Internal code, does not follow semantic versioning. + */ +function codeFromHttpStatus(httpStatus) { + switch (httpStatus) { + case 400: // Bad Request + return code_Code.Internal; + case 401: // Unauthorized + return code_Code.Unauthenticated; + case 403: // Forbidden + return code_Code.PermissionDenied; + case 404: // Not Found + return code_Code.Unimplemented; + case 429: // Too Many Requests + return code_Code.Unavailable; + case 502: // Bad Gateway + return code_Code.Unavailable; + case 503: // Service Unavailable + return code_Code.Unavailable; + case 504: // Gateway Timeout + return code_Code.Unavailable; + default: + // 200 is UNKNOWN because there should be a grpc-status in case of truly OK response. + return code_Code.Unknown; + } +} + +;// CONCATENATED MODULE: ./node_modules/@bufbuild/protobuf/dist/esm/message.js +// Copyright 2021-2024 Buf Technologies, Inc. +// +// Licensed under the Apache License, Version 2.0 (the "License"); +// you may not use this file except in compliance with the License. +// You may obtain a copy of the License at +// +// http://www.apache.org/licenses/LICENSE-2.0 +// +// Unless required by applicable law or agreed to in writing, software +// distributed under the License is distributed on an "AS IS" BASIS, +// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. +// See the License for the specific language governing permissions and +// limitations under the License. +/** + * Message is the base class of every message, generated, or created at + * runtime. + * + * It is _not_ safe to extend this class. If you want to create a message at + * run time, use proto3.makeMessageType(). + */ +class Message { + /** + * Compare with a message of the same type. + * Note that this function disregards extensions and unknown fields. + */ + equals(other) { + return this.getType().runtime.util.equals(this.getType(), this, other); + } + /** + * Create a deep copy. + */ + clone() { + return this.getType().runtime.util.clone(this); + } + /** + * Parse from binary data, merging fields. + * + * Repeated fields are appended. Map entries are added, overwriting + * existing keys. + * + * If a message field is already present, it will be merged with the + * new data. + */ + fromBinary(bytes, options) { + const type = this.getType(), format = type.runtime.bin, opt = format.makeReadOptions(options); + format.readMessage(this, opt.readerFactory(bytes), bytes.byteLength, opt); + return this; + } + /** + * Parse a message from a JSON value. + */ + fromJson(jsonValue, options) { + const type = this.getType(), format = type.runtime.json, opt = format.makeReadOptions(options); + format.readMessage(type, jsonValue, opt, this); + return this; + } + /** + * Parse a message from a JSON string. + */ + fromJsonString(jsonString, options) { + let json; + try { + json = JSON.parse(jsonString); + } + catch (e) { + throw new Error(`cannot decode ${this.getType().typeName} from JSON: ${e instanceof Error ? e.message : String(e)}`); + } + return this.fromJson(json, options); + } + /** + * Serialize the message to binary data. + */ + toBinary(options) { + const type = this.getType(), bin = type.runtime.bin, opt = bin.makeWriteOptions(options), writer = opt.writerFactory(); + bin.writeMessage(this, writer, opt); + return writer.finish(); + } + /** + * Serialize the message to a JSON value, a JavaScript value that can be + * passed to JSON.stringify(). + */ + toJson(options) { + const type = this.getType(), json = type.runtime.json, opt = json.makeWriteOptions(options); + return json.writeMessage(this, opt); + } + /** + * Serialize the message to a JSON string. + */ + toJsonString(options) { + var _a; + const value = this.toJson(options); + return JSON.stringify(value, null, (_a = options === null || options === void 0 ? void 0 : options.prettySpaces) !== null && _a !== void 0 ? _a : 0); + } + /** + * Override for serialization behavior. This will be invoked when calling + * JSON.stringify on this message (i.e. JSON.stringify(msg)). + * + * Note that this will not serialize google.protobuf.Any with a packed + * message because the protobuf JSON format specifies that it needs to be + * unpacked, and this is only possible with a type registry to look up the + * message type. As a result, attempting to serialize a message with this + * type will throw an Error. + * + * This method is protected because you should not need to invoke it + * directly -- instead use JSON.stringify or toJsonString for + * stringified JSON. Alternatively, if actual JSON is desired, you should + * use toJson. + */ + toJSON() { + return this.toJson({ + emitDefaultValues: true, + }); + } + /** + * Retrieve the MessageType of this message - a singleton that represents + * the protobuf message declaration and provides metadata for reflection- + * based operations. + */ + getType() { + // Any class that extends Message _must_ provide a complete static + // implementation of MessageType. + // eslint-disable-next-line @typescript-eslint/no-unsafe-member-access,@typescript-eslint/no-unsafe-return + return Object.getPrototypeOf(this).constructor; + } +} + +;// CONCATENATED MODULE: ./node_modules/@bufbuild/protobuf/dist/esm/private/assert.js +// Copyright 2021-2024 Buf Technologies, Inc. +// +// Licensed under the Apache License, Version 2.0 (the "License"); +// you may not use this file except in compliance with the License. +// You may obtain a copy of the License at +// +// http://www.apache.org/licenses/LICENSE-2.0 +// +// Unless required by applicable law or agreed to in writing, software +// distributed under the License is distributed on an "AS IS" BASIS, +// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. +// See the License for the specific language governing permissions and +// limitations under the License. +/** + * Assert that condition is truthy or throw error (with message) + */ +function assert(condition, msg) { + // eslint-disable-next-line @typescript-eslint/strict-boolean-expressions -- we want the implicit conversion to boolean + if (!condition) { + throw new Error(msg); + } +} +const FLOAT32_MAX = 3.4028234663852886e38, FLOAT32_MIN = -3.4028234663852886e38, UINT32_MAX = 0xffffffff, INT32_MAX = 0x7fffffff, INT32_MIN = -0x80000000; +/** + * Assert a valid signed protobuf 32-bit integer. + */ +function assertInt32(arg) { + if (typeof arg !== "number") + throw new Error("invalid int 32: " + typeof arg); + if (!Number.isInteger(arg) || arg > INT32_MAX || arg < INT32_MIN) + throw new Error("invalid int 32: " + arg); // eslint-disable-line @typescript-eslint/restrict-plus-operands -- we want the implicit conversion to string +} +/** + * Assert a valid unsigned protobuf 32-bit integer. + */ +function assertUInt32(arg) { + if (typeof arg !== "number") + throw new Error("invalid uint 32: " + typeof arg); + if (!Number.isInteger(arg) || arg > UINT32_MAX || arg < 0) + throw new Error("invalid uint 32: " + arg); // eslint-disable-line @typescript-eslint/restrict-plus-operands -- we want the implicit conversion to string +} +/** + * Assert a valid protobuf float value. + */ +function assertFloat32(arg) { + if (typeof arg !== "number") + throw new Error("invalid float 32: " + typeof arg); + if (!Number.isFinite(arg)) + return; + if (arg > FLOAT32_MAX || arg < FLOAT32_MIN) + throw new Error("invalid float 32: " + arg); // eslint-disable-line @typescript-eslint/restrict-plus-operands -- we want the implicit conversion to string +} + +;// CONCATENATED MODULE: ./node_modules/@bufbuild/protobuf/dist/esm/private/enum.js +// Copyright 2021-2024 Buf Technologies, Inc. +// +// Licensed under the Apache License, Version 2.0 (the "License"); +// you may not use this file except in compliance with the License. +// You may obtain a copy of the License at +// +// http://www.apache.org/licenses/LICENSE-2.0 +// +// Unless required by applicable law or agreed to in writing, software +// distributed under the License is distributed on an "AS IS" BASIS, +// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. +// See the License for the specific language governing permissions and +// limitations under the License. + +const enumTypeSymbol = Symbol("@bufbuild/protobuf/enum-type"); +/** + * Get reflection information from a generated enum. + * If this function is called on something other than a generated + * enum, it raises an error. + */ +function getEnumType(enumObject) { + // eslint-disable-next-line @typescript-eslint/no-unsafe-member-access,@typescript-eslint/no-unsafe-assignment,@typescript-eslint/no-explicit-any + const t = enumObject[enumTypeSymbol]; + assert(t, "missing enum type on enum object"); + return t; // eslint-disable-line @typescript-eslint/no-unsafe-return +} +/** + * Sets reflection information on a generated enum. + */ +function setEnumType(enumObject, typeName, values, opt) { + // eslint-disable-next-line @typescript-eslint/no-unsafe-member-access, @typescript-eslint/no-explicit-any + enumObject[enumTypeSymbol] = makeEnumType(typeName, values.map((v) => ({ + no: v.no, + name: v.name, + localName: enumObject[v.no], + })), opt); +} +/** + * Create a new EnumType with the given values. + */ +function makeEnumType(typeName, values, +// eslint-disable-next-line @typescript-eslint/no-unused-vars +_opt) { + const names = Object.create(null); + const numbers = Object.create(null); + const normalValues = []; + for (const value of values) { + // We do not surface options at this time + // const value: EnumValueInfo = {...v, options: v.options ?? emptyReadonlyObject}; + const n = normalizeEnumValue(value); + normalValues.push(n); + names[value.name] = n; + numbers[value.no] = n; + } + return { + typeName, + values: normalValues, + // We do not surface options at this time + // options: opt?.options ?? Object.create(null), + findName(name) { + return names[name]; + }, + findNumber(no) { + return numbers[no]; + }, + }; +} +/** + * Create a new enum object with the given values. + * Sets reflection information. + */ +function makeEnum(typeName, values, opt) { + const enumObject = {}; + for (const value of values) { + const n = normalizeEnumValue(value); + enumObject[n.localName] = n.no; + enumObject[n.no] = n.localName; + } + setEnumType(enumObject, typeName, values, opt); + return enumObject; +} +function normalizeEnumValue(value) { + if ("localName" in value) { + return value; + } + return Object.assign(Object.assign({}, value), { localName: value.name }); +} + +;// CONCATENATED MODULE: ./node_modules/@bufbuild/protobuf/dist/esm/private/message-type.js +// Copyright 2021-2024 Buf Technologies, Inc. +// +// Licensed under the Apache License, Version 2.0 (the "License"); +// you may not use this file except in compliance with the License. +// You may obtain a copy of the License at +// +// http://www.apache.org/licenses/LICENSE-2.0 +// +// Unless required by applicable law or agreed to in writing, software +// distributed under the License is distributed on an "AS IS" BASIS, +// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. +// See the License for the specific language governing permissions and +// limitations under the License. + +/** + * Create a new message type using the given runtime. + */ +function makeMessageType(runtime, typeName, fields, opt) { + var _a; + const localName = (_a = opt === null || opt === void 0 ? void 0 : opt.localName) !== null && _a !== void 0 ? _a : typeName.substring(typeName.lastIndexOf(".") + 1); + const type = { + [localName]: function (data) { + runtime.util.initFields(this); + runtime.util.initPartial(data, this); + }, + }[localName]; + Object.setPrototypeOf(type.prototype, new Message()); + Object.assign(type, { + runtime, + typeName, + fields: runtime.util.newFieldList(fields), + fromBinary(bytes, options) { + return new type().fromBinary(bytes, options); + }, + fromJson(jsonValue, options) { + return new type().fromJson(jsonValue, options); + }, + fromJsonString(jsonString, options) { + return new type().fromJsonString(jsonString, options); + }, + equals(a, b) { + return runtime.util.equals(type, a, b); + }, + }); + return type; +} + +;// CONCATENATED MODULE: ./node_modules/@bufbuild/protobuf/dist/esm/google/varint.js +// Copyright 2008 Google Inc. All rights reserved. +// +// Redistribution and use in source and binary forms, with or without +// modification, are permitted provided that the following conditions are +// met: +// +// * Redistributions of source code must retain the above copyright +// notice, this list of conditions and the following disclaimer. +// * Redistributions in binary form must reproduce the above +// copyright notice, this list of conditions and the following disclaimer +// in the documentation and/or other materials provided with the +// distribution. +// * Neither the name of Google Inc. nor the names of its +// contributors may be used to endorse or promote products derived from +// this software without specific prior written permission. +// +// THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS +// "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT +// LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR +// A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT +// OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, +// SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT +// LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, +// DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY +// THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT +// (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE +// OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. +// +// Code generated by the Protocol Buffer compiler is owned by the owner +// of the input file used when generating it. This code is not +// standalone and requires a support library to be linked with it. This +// support library is itself covered by the above license. +/* eslint-disable prefer-const,@typescript-eslint/restrict-plus-operands */ +/** + * Read a 64 bit varint as two JS numbers. + * + * Returns tuple: + * [0]: low bits + * [1]: high bits + * + * Copyright 2008 Google Inc. All rights reserved. + * + * See https://github.com/protocolbuffers/protobuf/blob/8a71927d74a4ce34efe2d8769fda198f52d20d12/js/experimental/runtime/kernel/buffer_decoder.js#L175 + */ +function varint64read() { + let lowBits = 0; + let highBits = 0; + for (let shift = 0; shift < 28; shift += 7) { + let b = this.buf[this.pos++]; + lowBits |= (b & 0x7f) << shift; + if ((b & 0x80) == 0) { + this.assertBounds(); + return [lowBits, highBits]; + } + } + let middleByte = this.buf[this.pos++]; + // last four bits of the first 32 bit number + lowBits |= (middleByte & 0x0f) << 28; + // 3 upper bits are part of the next 32 bit number + highBits = (middleByte & 0x70) >> 4; + if ((middleByte & 0x80) == 0) { + this.assertBounds(); + return [lowBits, highBits]; + } + for (let shift = 3; shift <= 31; shift += 7) { + let b = this.buf[this.pos++]; + highBits |= (b & 0x7f) << shift; + if ((b & 0x80) == 0) { + this.assertBounds(); + return [lowBits, highBits]; + } + } + throw new Error("invalid varint"); +} +/** + * Write a 64 bit varint, given as two JS numbers, to the given bytes array. + * + * Copyright 2008 Google Inc. All rights reserved. + * + * See https://github.com/protocolbuffers/protobuf/blob/8a71927d74a4ce34efe2d8769fda198f52d20d12/js/experimental/runtime/kernel/writer.js#L344 + */ +function varint64write(lo, hi, bytes) { + for (let i = 0; i < 28; i = i + 7) { + const shift = lo >>> i; + const hasNext = !(shift >>> 7 == 0 && hi == 0); + const byte = (hasNext ? shift | 0x80 : shift) & 0xff; + bytes.push(byte); + if (!hasNext) { + return; + } + } + const splitBits = ((lo >>> 28) & 0x0f) | ((hi & 0x07) << 4); + const hasMoreBits = !(hi >> 3 == 0); + bytes.push((hasMoreBits ? splitBits | 0x80 : splitBits) & 0xff); + if (!hasMoreBits) { + return; + } + for (let i = 3; i < 31; i = i + 7) { + const shift = hi >>> i; + const hasNext = !(shift >>> 7 == 0); + const byte = (hasNext ? shift | 0x80 : shift) & 0xff; + bytes.push(byte); + if (!hasNext) { + return; + } + } + bytes.push((hi >>> 31) & 0x01); +} +// constants for binary math +const TWO_PWR_32_DBL = 0x100000000; +/** + * Parse decimal string of 64 bit integer value as two JS numbers. + * + * Copyright 2008 Google Inc. All rights reserved. + * + * See https://github.com/protocolbuffers/protobuf-javascript/blob/a428c58273abad07c66071d9753bc4d1289de426/experimental/runtime/int64.js#L10 + */ +function int64FromString(dec) { + // Check for minus sign. + const minus = dec[0] === "-"; + if (minus) { + dec = dec.slice(1); + } + // Work 6 decimal digits at a time, acting like we're converting base 1e6 + // digits to binary. This is safe to do with floating point math because + // Number.isSafeInteger(ALL_32_BITS * 1e6) == true. + const base = 1e6; + let lowBits = 0; + let highBits = 0; + function add1e6digit(begin, end) { + // Note: Number('') is 0. + const digit1e6 = Number(dec.slice(begin, end)); + highBits *= base; + lowBits = lowBits * base + digit1e6; + // Carry bits from lowBits to + if (lowBits >= TWO_PWR_32_DBL) { + highBits = highBits + ((lowBits / TWO_PWR_32_DBL) | 0); + lowBits = lowBits % TWO_PWR_32_DBL; + } + } + add1e6digit(-24, -18); + add1e6digit(-18, -12); + add1e6digit(-12, -6); + add1e6digit(-6); + return minus ? negate(lowBits, highBits) : newBits(lowBits, highBits); +} +/** + * Losslessly converts a 64-bit signed integer in 32:32 split representation + * into a decimal string. + * + * Copyright 2008 Google Inc. All rights reserved. + * + * See https://github.com/protocolbuffers/protobuf-javascript/blob/a428c58273abad07c66071d9753bc4d1289de426/experimental/runtime/int64.js#L10 + */ +function int64ToString(lo, hi) { + let bits = newBits(lo, hi); + // If we're treating the input as a signed value and the high bit is set, do + // a manual two's complement conversion before the decimal conversion. + const negative = (bits.hi & 0x80000000); + if (negative) { + bits = negate(bits.lo, bits.hi); + } + const result = uInt64ToString(bits.lo, bits.hi); + return negative ? "-" + result : result; +} +/** + * Losslessly converts a 64-bit unsigned integer in 32:32 split representation + * into a decimal string. + * + * Copyright 2008 Google Inc. All rights reserved. + * + * See https://github.com/protocolbuffers/protobuf-javascript/blob/a428c58273abad07c66071d9753bc4d1289de426/experimental/runtime/int64.js#L10 + */ +function uInt64ToString(lo, hi) { + ({ lo, hi } = toUnsigned(lo, hi)); + // Skip the expensive conversion if the number is small enough to use the + // built-in conversions. + // Number.MAX_SAFE_INTEGER = 0x001FFFFF FFFFFFFF, thus any number with + // highBits <= 0x1FFFFF can be safely expressed with a double and retain + // integer precision. + // Proven by: Number.isSafeInteger(0x1FFFFF * 2**32 + 0xFFFFFFFF) == true. + if (hi <= 0x1FFFFF) { + return String(TWO_PWR_32_DBL * hi + lo); + } + // What this code is doing is essentially converting the input number from + // base-2 to base-1e7, which allows us to represent the 64-bit range with + // only 3 (very large) digits. Those digits are then trivial to convert to + // a base-10 string. + // The magic numbers used here are - + // 2^24 = 16777216 = (1,6777216) in base-1e7. + // 2^48 = 281474976710656 = (2,8147497,6710656) in base-1e7. + // Split 32:32 representation into 16:24:24 representation so our + // intermediate digits don't overflow. + const low = lo & 0xFFFFFF; + const mid = ((lo >>> 24) | (hi << 8)) & 0xFFFFFF; + const high = (hi >> 16) & 0xFFFF; + // Assemble our three base-1e7 digits, ignoring carries. The maximum + // value in a digit at this step is representable as a 48-bit integer, which + // can be stored in a 64-bit floating point number. + let digitA = low + (mid * 6777216) + (high * 6710656); + let digitB = mid + (high * 8147497); + let digitC = (high * 2); + // Apply carries from A to B and from B to C. + const base = 10000000; + if (digitA >= base) { + digitB += Math.floor(digitA / base); + digitA %= base; + } + if (digitB >= base) { + digitC += Math.floor(digitB / base); + digitB %= base; + } + // If digitC is 0, then we should have returned in the trivial code path + // at the top for non-safe integers. Given this, we can assume both digitB + // and digitA need leading zeros. + return digitC.toString() + decimalFrom1e7WithLeadingZeros(digitB) + + decimalFrom1e7WithLeadingZeros(digitA); +} +function toUnsigned(lo, hi) { + return { lo: lo >>> 0, hi: hi >>> 0 }; +} +function newBits(lo, hi) { + return { lo: lo | 0, hi: hi | 0 }; +} +/** + * Returns two's compliment negation of input. + * @see https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Operators/Bitwise_Operators#Signed_32-bit_integers + */ +function negate(lowBits, highBits) { + highBits = ~highBits; + if (lowBits) { + lowBits = ~lowBits + 1; + } + else { + // If lowBits is 0, then bitwise-not is 0xFFFFFFFF, + // adding 1 to that, results in 0x100000000, which leaves + // the low bits 0x0 and simply adds one to the high bits. + highBits += 1; + } + return newBits(lowBits, highBits); +} +/** + * Returns decimal representation of digit1e7 with leading zeros. + */ +const decimalFrom1e7WithLeadingZeros = (digit1e7) => { + const partial = String(digit1e7); + return "0000000".slice(partial.length) + partial; +}; +/** + * Write a 32 bit varint, signed or unsigned. Same as `varint64write(0, value, bytes)` + * + * Copyright 2008 Google Inc. All rights reserved. + * + * See https://github.com/protocolbuffers/protobuf/blob/1b18833f4f2a2f681f4e4a25cdf3b0a43115ec26/js/binary/encoder.js#L144 + */ +function varint32write(value, bytes) { + if (value >= 0) { + // write value as varint 32 + while (value > 0x7f) { + bytes.push((value & 0x7f) | 0x80); + value = value >>> 7; + } + bytes.push(value); + } + else { + for (let i = 0; i < 9; i++) { + bytes.push((value & 127) | 128); + value = value >> 7; + } + bytes.push(1); + } +} +/** + * Read an unsigned 32 bit varint. + * + * See https://github.com/protocolbuffers/protobuf/blob/8a71927d74a4ce34efe2d8769fda198f52d20d12/js/experimental/runtime/kernel/buffer_decoder.js#L220 + */ +function varint32read() { + let b = this.buf[this.pos++]; + let result = b & 0x7f; + if ((b & 0x80) == 0) { + this.assertBounds(); + return result; + } + b = this.buf[this.pos++]; + result |= (b & 0x7f) << 7; + if ((b & 0x80) == 0) { + this.assertBounds(); + return result; + } + b = this.buf[this.pos++]; + result |= (b & 0x7f) << 14; + if ((b & 0x80) == 0) { + this.assertBounds(); + return result; + } + b = this.buf[this.pos++]; + result |= (b & 0x7f) << 21; + if ((b & 0x80) == 0) { + this.assertBounds(); + return result; + } + // Extract only last 4 bits + b = this.buf[this.pos++]; + result |= (b & 0x0f) << 28; + for (let readBytes = 5; (b & 0x80) !== 0 && readBytes < 10; readBytes++) + b = this.buf[this.pos++]; + if ((b & 0x80) != 0) + throw new Error("invalid varint"); + this.assertBounds(); + // Result can have 32 bits, convert it to unsigned + return result >>> 0; +} + +;// CONCATENATED MODULE: ./node_modules/@bufbuild/protobuf/dist/esm/proto-int64.js +// Copyright 2021-2024 Buf Technologies, Inc. +// +// Licensed under the Apache License, Version 2.0 (the "License"); +// you may not use this file except in compliance with the License. +// You may obtain a copy of the License at +// +// http://www.apache.org/licenses/LICENSE-2.0 +// +// Unless required by applicable law or agreed to in writing, software +// distributed under the License is distributed on an "AS IS" BASIS, +// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. +// See the License for the specific language governing permissions and +// limitations under the License. + + +function makeInt64Support() { + const dv = new DataView(new ArrayBuffer(8)); + // note that Safari 14 implements BigInt, but not the DataView methods + const ok = typeof BigInt === "function" && + typeof dv.getBigInt64 === "function" && + typeof dv.getBigUint64 === "function" && + typeof dv.setBigInt64 === "function" && + typeof dv.setBigUint64 === "function" && + (typeof process != "object" || + typeof process.env != "object" || + process.env.BUF_BIGINT_DISABLE !== "1"); + if (ok) { + const MIN = BigInt("-9223372036854775808"), MAX = BigInt("9223372036854775807"), UMIN = BigInt("0"), UMAX = BigInt("18446744073709551615"); + return { + zero: BigInt(0), + supported: true, + parse(value) { + const bi = typeof value == "bigint" ? value : BigInt(value); + if (bi > MAX || bi < MIN) { + throw new Error(`int64 invalid: ${value}`); + } + return bi; + }, + uParse(value) { + const bi = typeof value == "bigint" ? value : BigInt(value); + if (bi > UMAX || bi < UMIN) { + throw new Error(`uint64 invalid: ${value}`); + } + return bi; + }, + enc(value) { + dv.setBigInt64(0, this.parse(value), true); + return { + lo: dv.getInt32(0, true), + hi: dv.getInt32(4, true), + }; + }, + uEnc(value) { + dv.setBigInt64(0, this.uParse(value), true); + return { + lo: dv.getInt32(0, true), + hi: dv.getInt32(4, true), + }; + }, + dec(lo, hi) { + dv.setInt32(0, lo, true); + dv.setInt32(4, hi, true); + return dv.getBigInt64(0, true); + }, + uDec(lo, hi) { + dv.setInt32(0, lo, true); + dv.setInt32(4, hi, true); + return dv.getBigUint64(0, true); + }, + }; + } + const assertInt64String = (value) => assert(/^-?[0-9]+$/.test(value), `int64 invalid: ${value}`); + const assertUInt64String = (value) => assert(/^[0-9]+$/.test(value), `uint64 invalid: ${value}`); + return { + zero: "0", + supported: false, + parse(value) { + if (typeof value != "string") { + value = value.toString(); + } + assertInt64String(value); + return value; + }, + uParse(value) { + if (typeof value != "string") { + value = value.toString(); + } + assertUInt64String(value); + return value; + }, + enc(value) { + if (typeof value != "string") { + value = value.toString(); + } + assertInt64String(value); + return int64FromString(value); + }, + uEnc(value) { + if (typeof value != "string") { + value = value.toString(); + } + assertUInt64String(value); + return int64FromString(value); + }, + dec(lo, hi) { + return int64ToString(lo, hi); + }, + uDec(lo, hi) { + return uInt64ToString(lo, hi); + }, + }; +} +const protoInt64 = makeInt64Support(); + +;// CONCATENATED MODULE: ./node_modules/@bufbuild/protobuf/dist/esm/scalar.js +// Copyright 2021-2024 Buf Technologies, Inc. +// +// Licensed under the Apache License, Version 2.0 (the "License"); +// you may not use this file except in compliance with the License. +// You may obtain a copy of the License at +// +// http://www.apache.org/licenses/LICENSE-2.0 +// +// Unless required by applicable law or agreed to in writing, software +// distributed under the License is distributed on an "AS IS" BASIS, +// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. +// See the License for the specific language governing permissions and +// limitations under the License. +/** + * Scalar value types. This is a subset of field types declared by protobuf + * enum google.protobuf.FieldDescriptorProto.Type The types GROUP and MESSAGE + * are omitted, but the numerical values are identical. + */ +var ScalarType; +(function (ScalarType) { + // 0 is reserved for errors. + // Order is weird for historical reasons. + ScalarType[ScalarType["DOUBLE"] = 1] = "DOUBLE"; + ScalarType[ScalarType["FLOAT"] = 2] = "FLOAT"; + // Not ZigZag encoded. Negative numbers take 10 bytes. Use TYPE_SINT64 if + // negative values are likely. + ScalarType[ScalarType["INT64"] = 3] = "INT64"; + ScalarType[ScalarType["UINT64"] = 4] = "UINT64"; + // Not ZigZag encoded. Negative numbers take 10 bytes. Use TYPE_SINT32 if + // negative values are likely. + ScalarType[ScalarType["INT32"] = 5] = "INT32"; + ScalarType[ScalarType["FIXED64"] = 6] = "FIXED64"; + ScalarType[ScalarType["FIXED32"] = 7] = "FIXED32"; + ScalarType[ScalarType["BOOL"] = 8] = "BOOL"; + ScalarType[ScalarType["STRING"] = 9] = "STRING"; + // Tag-delimited aggregate. + // Group type is deprecated and not supported in proto3. However, Proto3 + // implementations should still be able to parse the group wire format and + // treat group fields as unknown fields. + // TYPE_GROUP = 10, + // TYPE_MESSAGE = 11, // Length-delimited aggregate. + // New in version 2. + ScalarType[ScalarType["BYTES"] = 12] = "BYTES"; + ScalarType[ScalarType["UINT32"] = 13] = "UINT32"; + // TYPE_ENUM = 14, + ScalarType[ScalarType["SFIXED32"] = 15] = "SFIXED32"; + ScalarType[ScalarType["SFIXED64"] = 16] = "SFIXED64"; + ScalarType[ScalarType["SINT32"] = 17] = "SINT32"; + ScalarType[ScalarType["SINT64"] = 18] = "SINT64"; +})(ScalarType || (ScalarType = {})); +/** + * JavaScript representation of fields with 64 bit integral types (int64, uint64, + * sint64, fixed64, sfixed64). + * + * This is a subset of google.protobuf.FieldOptions.JSType, which defines JS_NORMAL, + * JS_STRING, and JS_NUMBER. Protobuf-ES uses BigInt by default, but will use + * String if `[jstype = JS_STRING]` is specified. + * + * ```protobuf + * uint64 field_a = 1; // BigInt + * uint64 field_b = 2 [jstype = JS_NORMAL]; // BigInt + * uint64 field_b = 2 [jstype = JS_NUMBER]; // BigInt + * uint64 field_b = 2 [jstype = JS_STRING]; // String + * ``` + */ +var LongType; +(function (LongType) { + /** + * Use JavaScript BigInt. + */ + LongType[LongType["BIGINT"] = 0] = "BIGINT"; + /** + * Use JavaScript String. + * + * Field option `[jstype = JS_STRING]`. + */ + LongType[LongType["STRING"] = 1] = "STRING"; +})(LongType || (LongType = {})); + +;// CONCATENATED MODULE: ./node_modules/@bufbuild/protobuf/dist/esm/private/scalars.js +// Copyright 2021-2024 Buf Technologies, Inc. +// +// Licensed under the Apache License, Version 2.0 (the "License"); +// you may not use this file except in compliance with the License. +// You may obtain a copy of the License at +// +// http://www.apache.org/licenses/LICENSE-2.0 +// +// Unless required by applicable law or agreed to in writing, software +// distributed under the License is distributed on an "AS IS" BASIS, +// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. +// See the License for the specific language governing permissions and +// limitations under the License. + + +/** + * Returns true if both scalar values are equal. + */ +function scalarEquals(type, a, b) { + if (a === b) { + // This correctly matches equal values except BYTES and (possibly) 64-bit integers. + return true; + } + // Special case BYTES - we need to compare each byte individually + if (type == ScalarType.BYTES) { + if (!(a instanceof Uint8Array) || !(b instanceof Uint8Array)) { + return false; + } + if (a.length !== b.length) { + return false; + } + for (let i = 0; i < a.length; i++) { + if (a[i] !== b[i]) { + return false; + } + } + return true; + } + // Special case 64-bit integers - we support number, string and bigint representation. + // eslint-disable-next-line @typescript-eslint/switch-exhaustiveness-check + switch (type) { + case ScalarType.UINT64: + case ScalarType.FIXED64: + case ScalarType.INT64: + case ScalarType.SFIXED64: + case ScalarType.SINT64: + // Loose comparison will match between 0n, 0 and "0". + return a == b; + } + // Anything that hasn't been caught by strict comparison or special cased + // BYTES and 64-bit integers is not equal. + return false; +} +/** + * Returns the zero value for the given scalar type. + */ +function scalarZeroValue(type, longType) { + switch (type) { + case ScalarType.BOOL: + return false; + case ScalarType.UINT64: + case ScalarType.FIXED64: + case ScalarType.INT64: + case ScalarType.SFIXED64: + case ScalarType.SINT64: + // eslint-disable-next-line @typescript-eslint/no-unsafe-enum-comparison -- acceptable since it's covered by tests + return (longType == 0 ? protoInt64.zero : "0"); + case ScalarType.DOUBLE: + case ScalarType.FLOAT: + return 0.0; + case ScalarType.BYTES: + return new Uint8Array(0); + case ScalarType.STRING: + return ""; + default: + // Handles INT32, UINT32, SINT32, FIXED32, SFIXED32. + // We do not use individual cases to save a few bytes code size. + return 0; + } +} +/** + * Returns true for a zero-value. For example, an integer has the zero-value `0`, + * a boolean is `false`, a string is `""`, and bytes is an empty Uint8Array. + * + * In proto3, zero-values are not written to the wire, unless the field is + * optional or repeated. + */ +function isScalarZeroValue(type, value) { + switch (type) { + case ScalarType.BOOL: + return value === false; + case ScalarType.STRING: + return value === ""; + case ScalarType.BYTES: + return value instanceof Uint8Array && !value.byteLength; + default: + return value == 0; // Loose comparison matches 0n, 0 and "0" + } +} + +;// CONCATENATED MODULE: ./node_modules/@bufbuild/protobuf/dist/esm/private/extensions.js +// Copyright 2021-2024 Buf Technologies, Inc. +// +// Licensed under the Apache License, Version 2.0 (the "License"); +// you may not use this file except in compliance with the License. +// You may obtain a copy of the License at +// +// http://www.apache.org/licenses/LICENSE-2.0 +// +// Unless required by applicable law or agreed to in writing, software +// distributed under the License is distributed on an "AS IS" BASIS, +// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. +// See the License for the specific language governing permissions and +// limitations under the License. + + +/** + * Create a new extension using the given runtime. + */ +function makeExtension(runtime, typeName, extendee, field) { + let fi; + return { + typeName, + extendee, + get field() { + if (!fi) { + const i = (typeof field == "function" ? field() : field); + i.name = typeName.split(".").pop(); + i.jsonName = `[${typeName}]`; + fi = runtime.util.newFieldList([i]).list()[0]; + } + return fi; + }, + runtime, + }; +} +/** + * Create a container that allows us to read extension fields into it with the + * same logic as regular fields. + */ +function createExtensionContainer(extension) { + const localName = extension.field.localName; + const container = Object.create(null); + container[localName] = initExtensionField(extension); + return [container, () => container[localName]]; +} +function initExtensionField(ext) { + const field = ext.field; + if (field.repeated) { + return []; + } + if (field.default !== undefined) { + return field.default; + } + switch (field.kind) { + case "enum": + return field.T.values[0].no; + case "scalar": + return scalarZeroValue(field.T, field.L); + case "message": + // eslint-disable-next-line no-case-declarations + const T = field.T, value = new T(); + return T.fieldWrapper ? T.fieldWrapper.unwrapField(value) : value; + case "map": + throw "map fields are not allowed to be extensions"; + } +} +/** + * Helper to filter unknown fields, optimized based on field type. + */ +function filterUnknownFields(unknownFields, field) { + if (!field.repeated && (field.kind == "enum" || field.kind == "scalar")) { + // singular scalar fields do not merge, we pick the last + for (let i = unknownFields.length - 1; i >= 0; --i) { + if (unknownFields[i].no == field.no) { + return [unknownFields[i]]; + } + } + return []; + } + return unknownFields.filter((uf) => uf.no === field.no); +} + +;// CONCATENATED MODULE: ./node_modules/@bufbuild/protobuf/dist/esm/proto-base64.js +// Copyright 2021-2024 Buf Technologies, Inc. +// +// Licensed under the Apache License, Version 2.0 (the "License"); +// you may not use this file except in compliance with the License. +// You may obtain a copy of the License at +// +// http://www.apache.org/licenses/LICENSE-2.0 +// +// Unless required by applicable law or agreed to in writing, software +// distributed under the License is distributed on an "AS IS" BASIS, +// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. +// See the License for the specific language governing permissions and +// limitations under the License. +/* eslint-disable @typescript-eslint/ban-ts-comment, @typescript-eslint/no-unnecessary-condition, prefer-const */ +// lookup table from base64 character to byte +let encTable = "ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/".split(""); +// lookup table from base64 character *code* to byte because lookup by number is fast +let decTable = []; +for (let i = 0; i < encTable.length; i++) + decTable[encTable[i].charCodeAt(0)] = i; +// support base64url variants +decTable["-".charCodeAt(0)] = encTable.indexOf("+"); +decTable["_".charCodeAt(0)] = encTable.indexOf("/"); +const proto_base64_protoBase64 = { + /** + * Decodes a base64 string to a byte array. + * + * - ignores white-space, including line breaks and tabs + * - allows inner padding (can decode concatenated base64 strings) + * - does not require padding + * - understands base64url encoding: + * "-" instead of "+", + * "_" instead of "/", + * no padding + */ + dec(base64Str) { + // estimate byte size, not accounting for inner padding and whitespace + let es = (base64Str.length * 3) / 4; + if (base64Str[base64Str.length - 2] == "=") + es -= 2; + else if (base64Str[base64Str.length - 1] == "=") + es -= 1; + let bytes = new Uint8Array(es), bytePos = 0, // position in byte array + groupPos = 0, // position in base64 group + b, // current byte + p = 0; // previous byte + for (let i = 0; i < base64Str.length; i++) { + b = decTable[base64Str.charCodeAt(i)]; + if (b === undefined) { + switch (base64Str[i]) { + // @ts-ignore TS7029: Fallthrough case in switch + case "=": + groupPos = 0; // reset state when padding found + // @ts-ignore TS7029: Fallthrough case in switch + case "\n": + case "\r": + case "\t": + case " ": + continue; // skip white-space, and padding + default: + throw Error("invalid base64 string."); + } + } + switch (groupPos) { + case 0: + p = b; + groupPos = 1; + break; + case 1: + bytes[bytePos++] = (p << 2) | ((b & 48) >> 4); + p = b; + groupPos = 2; + break; + case 2: + bytes[bytePos++] = ((p & 15) << 4) | ((b & 60) >> 2); + p = b; + groupPos = 3; + break; + case 3: + bytes[bytePos++] = ((p & 3) << 6) | b; + groupPos = 0; + break; + } + } + if (groupPos == 1) + throw Error("invalid base64 string."); + return bytes.subarray(0, bytePos); + }, + /** + * Encode a byte array to a base64 string. + */ + enc(bytes) { + let base64 = "", groupPos = 0, // position in base64 group + b, // current byte + p = 0; // carry over from previous byte + for (let i = 0; i < bytes.length; i++) { + b = bytes[i]; + switch (groupPos) { + case 0: + base64 += encTable[b >> 2]; + p = (b & 3) << 4; + groupPos = 1; + break; + case 1: + base64 += encTable[p | (b >> 4)]; + p = (b & 15) << 2; + groupPos = 2; + break; + case 2: + base64 += encTable[p | (b >> 6)]; + base64 += encTable[b & 63]; + groupPos = 0; + break; + } + } + // add output padding + if (groupPos) { + base64 += encTable[p]; + base64 += "="; + if (groupPos == 1) + base64 += "="; + } + return base64; + }, +}; + +;// CONCATENATED MODULE: ./node_modules/@bufbuild/protobuf/dist/esm/extension-accessor.js +// Copyright 2021-2024 Buf Technologies, Inc. +// +// Licensed under the Apache License, Version 2.0 (the "License"); +// you may not use this file except in compliance with the License. +// You may obtain a copy of the License at +// +// http://www.apache.org/licenses/LICENSE-2.0 +// +// Unless required by applicable law or agreed to in writing, software +// distributed under the License is distributed on an "AS IS" BASIS, +// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. +// See the License for the specific language governing permissions and +// limitations under the License. + + +/** + * Retrieve an extension value from a message. + * + * The function never returns undefined. Use hasExtension() to check whether an + * extension is set. If the extension is not set, this function returns the + * default value (if one was specified in the protobuf source), or the zero value + * (for example `0` for numeric types, `[]` for repeated extension fields, and + * an empty message instance for message fields). + * + * Extensions are stored as unknown fields on a message. To mutate an extension + * value, make sure to store the new value with setExtension() after mutating. + * + * If the extension does not extend the given message, an error is raised. + */ +function getExtension(message, extension, options) { + assertExtendee(extension, message); + const opt = extension.runtime.bin.makeReadOptions(options); + const ufs = filterUnknownFields(message.getType().runtime.bin.listUnknownFields(message), extension.field); + const [container, get] = createExtensionContainer(extension); + for (const uf of ufs) { + extension.runtime.bin.readField(container, opt.readerFactory(uf.data), extension.field, uf.wireType, opt); + } + return get(); +} +/** + * Set an extension value on a message. If the message already has a value for + * this extension, the value is replaced. + * + * If the extension does not extend the given message, an error is raised. + */ +function setExtension(message, extension, value, options) { + assertExtendee(extension, message); + const readOpt = extension.runtime.bin.makeReadOptions(options); + const writeOpt = extension.runtime.bin.makeWriteOptions(options); + if (hasExtension(message, extension)) { + const ufs = message + .getType() + .runtime.bin.listUnknownFields(message) + .filter((uf) => uf.no != extension.field.no); + message.getType().runtime.bin.discardUnknownFields(message); + for (const uf of ufs) { + message + .getType() + .runtime.bin.onUnknownField(message, uf.no, uf.wireType, uf.data); + } + } + const writer = writeOpt.writerFactory(); + let f = extension.field; + // Implicit presence does not apply to extensions, see https://github.com/protocolbuffers/protobuf/issues/8234 + // We patch the field info to use explicit presence: + if (!f.opt && !f.repeated && (f.kind == "enum" || f.kind == "scalar")) { + f = Object.assign(Object.assign({}, extension.field), { opt: true }); + } + extension.runtime.bin.writeField(f, value, writer, writeOpt); + const reader = readOpt.readerFactory(writer.finish()); + while (reader.pos < reader.len) { + const [no, wireType] = reader.tag(); + const data = reader.skip(wireType, no); + message.getType().runtime.bin.onUnknownField(message, no, wireType, data); + } +} +/** + * Remove an extension value from a message. + * + * If the extension does not extend the given message, an error is raised. + */ +function clearExtension(message, extension) { + assertExtendee(extension, message); + if (hasExtension(message, extension)) { + const bin = message.getType().runtime.bin; + const ufs = bin + .listUnknownFields(message) + .filter((uf) => uf.no != extension.field.no); + bin.discardUnknownFields(message); + for (const uf of ufs) { + bin.onUnknownField(message, uf.no, uf.wireType, uf.data); + } + } +} +/** + * Check whether an extension is set on a message. + */ +function hasExtension(message, extension) { + const messageType = message.getType(); + return (extension.extendee.typeName === messageType.typeName && + !!messageType.runtime.bin + .listUnknownFields(message) + .find((uf) => uf.no == extension.field.no)); +} +function assertExtendee(extension, message) { + assert(extension.extendee.typeName == message.getType().typeName, `extension ${extension.typeName} can only be applied to message ${extension.extendee.typeName}`); +} + +;// CONCATENATED MODULE: ./node_modules/@bufbuild/protobuf/dist/esm/private/reflect.js +// Copyright 2021-2024 Buf Technologies, Inc. +// +// Licensed under the Apache License, Version 2.0 (the "License"); +// you may not use this file except in compliance with the License. +// You may obtain a copy of the License at +// +// http://www.apache.org/licenses/LICENSE-2.0 +// +// Unless required by applicable law or agreed to in writing, software +// distributed under the License is distributed on an "AS IS" BASIS, +// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. +// See the License for the specific language governing permissions and +// limitations under the License. + +/** + * Returns true if the field is set. + */ +function isFieldSet(field, target) { + const localName = field.localName; + if (field.repeated) { + return target[localName].length > 0; + } + if (field.oneof) { + return target[field.oneof.localName].case === localName; // eslint-disable-line @typescript-eslint/no-unsafe-member-access + } + switch (field.kind) { + case "enum": + case "scalar": + if (field.opt || field.req) { + // explicit presence + return target[localName] !== undefined; + } + // implicit presence + if (field.kind == "enum") { + return target[localName] !== field.T.values[0].no; + } + return !isScalarZeroValue(field.T, target[localName]); + case "message": + return target[localName] !== undefined; + case "map": + return Object.keys(target[localName]).length > 0; // eslint-disable-line @typescript-eslint/no-unsafe-argument + } +} +/** + * Resets the field, so that isFieldSet() will return false. + */ +function clearField(field, target) { + const localName = field.localName; + const implicitPresence = !field.opt && !field.req; + if (field.repeated) { + target[localName] = []; + } + else if (field.oneof) { + target[field.oneof.localName] = { case: undefined }; + } + else { + switch (field.kind) { + case "map": + target[localName] = {}; + break; + case "enum": + target[localName] = implicitPresence ? field.T.values[0].no : undefined; + break; + case "scalar": + target[localName] = implicitPresence + ? scalarZeroValue(field.T, field.L) + : undefined; + break; + case "message": + target[localName] = undefined; + break; + } + } +} + +;// CONCATENATED MODULE: ./node_modules/@bufbuild/protobuf/dist/esm/is-message.js +// Copyright 2021-2024 Buf Technologies, Inc. +// +// Licensed under the Apache License, Version 2.0 (the "License"); +// you may not use this file except in compliance with the License. +// You may obtain a copy of the License at +// +// http://www.apache.org/licenses/LICENSE-2.0 +// +// Unless required by applicable law or agreed to in writing, software +// distributed under the License is distributed on an "AS IS" BASIS, +// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. +// See the License for the specific language governing permissions and +// limitations under the License. + +/** + * Check whether the given object is any subtype of Message or is a specific + * Message by passing the type. + * + * Just like `instanceof`, `isMessage` narrows the type. The advantage of + * `isMessage` is that it compares identity by the message type name, not by + * class identity. This makes it robust against the dual package hazard and + * similar situations, where the same message is duplicated. + * + * This function is _mostly_ equivalent to the `instanceof` operator. For + * example, `isMessage(foo, MyMessage)` is the same as `foo instanceof MyMessage`, + * and `isMessage(foo)` is the same as `foo instanceof Message`. In most cases, + * `isMessage` should be preferred over `instanceof`. + * + * However, due to the fact that `isMessage` does not use class identity, there + * are subtle differences between this function and `instanceof`. Notably, + * calling `isMessage` on an explicit type of Message will return false. + */ +function isMessage(arg, type) { + if (arg === null || typeof arg != "object") { + return false; + } + if (!Object.getOwnPropertyNames(Message.prototype).every((m) => m in arg && typeof arg[m] == "function")) { + return false; + } + const actualType = arg.getType(); + if (actualType === null || + typeof actualType != "function" || + !("typeName" in actualType) || + typeof actualType.typeName != "string") { + return false; + } + return type === undefined ? true : actualType.typeName == type.typeName; +} + +;// CONCATENATED MODULE: ./node_modules/@bufbuild/protobuf/dist/esm/private/field-wrapper.js +// Copyright 2021-2024 Buf Technologies, Inc. +// +// Licensed under the Apache License, Version 2.0 (the "License"); +// you may not use this file except in compliance with the License. +// You may obtain a copy of the License at +// +// http://www.apache.org/licenses/LICENSE-2.0 +// +// Unless required by applicable law or agreed to in writing, software +// distributed under the License is distributed on an "AS IS" BASIS, +// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. +// See the License for the specific language governing permissions and +// limitations under the License. + + + +/** + * Wrap a primitive message field value in its corresponding wrapper + * message. This function is idempotent. + */ +function wrapField(type, value) { + if (isMessage(value) || !type.fieldWrapper) { + return value; + } + return type.fieldWrapper.wrapField(value); +} +/** + * If the given field uses one of the well-known wrapper types, return + * the primitive type it wraps. + */ +function getUnwrappedFieldType(field) { + if (field.fieldKind !== "message") { + return undefined; + } + if (field.repeated) { + return undefined; + } + if (field.oneof != undefined) { + return undefined; + } + return wktWrapperToScalarType[field.message.typeName]; +} +const wktWrapperToScalarType = { + "google.protobuf.DoubleValue": ScalarType.DOUBLE, + "google.protobuf.FloatValue": ScalarType.FLOAT, + "google.protobuf.Int64Value": ScalarType.INT64, + "google.protobuf.UInt64Value": ScalarType.UINT64, + "google.protobuf.Int32Value": ScalarType.INT32, + "google.protobuf.UInt32Value": ScalarType.UINT32, + "google.protobuf.BoolValue": ScalarType.BOOL, + "google.protobuf.StringValue": ScalarType.STRING, + "google.protobuf.BytesValue": ScalarType.BYTES, +}; + +;// CONCATENATED MODULE: ./node_modules/@bufbuild/protobuf/dist/esm/private/json-format.js +// Copyright 2021-2024 Buf Technologies, Inc. +// +// Licensed under the Apache License, Version 2.0 (the "License"); +// you may not use this file except in compliance with the License. +// You may obtain a copy of the License at +// +// http://www.apache.org/licenses/LICENSE-2.0 +// +// Unless required by applicable law or agreed to in writing, software +// distributed under the License is distributed on an "AS IS" BASIS, +// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. +// See the License for the specific language governing permissions and +// limitations under the License. + + + + + + + + + + + + +/* eslint-disable no-case-declarations,@typescript-eslint/no-unsafe-argument,@typescript-eslint/no-unsafe-assignment,@typescript-eslint/no-unsafe-member-access,@typescript-eslint/no-unsafe-call */ +// Default options for parsing JSON. +const jsonReadDefaults = { + ignoreUnknownFields: false, +}; +// Default options for serializing to JSON. +const jsonWriteDefaults = { + emitDefaultValues: false, + enumAsInteger: false, + useProtoFieldName: false, + prettySpaces: 0, +}; +function makeReadOptions(options) { + return options ? Object.assign(Object.assign({}, jsonReadDefaults), options) : jsonReadDefaults; +} +function makeWriteOptions(options) { + return options ? Object.assign(Object.assign({}, jsonWriteDefaults), options) : jsonWriteDefaults; +} +const tokenNull = Symbol(); +const tokenIgnoredUnknownEnum = Symbol(); +function makeJsonFormat() { + return { + makeReadOptions, + makeWriteOptions, + readMessage(type, json, options, message) { + if (json == null || Array.isArray(json) || typeof json != "object") { + throw new Error(`cannot decode message ${type.typeName} from JSON: ${debugJsonValue(json)}`); + } + message = message !== null && message !== void 0 ? message : new type(); + const oneofSeen = new Map(); + const registry = options.typeRegistry; + for (const [jsonKey, jsonValue] of Object.entries(json)) { + const field = type.fields.findJsonName(jsonKey); + if (field) { + if (field.oneof) { + if (jsonValue === null && field.kind == "scalar") { + // see conformance test Required.Proto3.JsonInput.OneofFieldNull{First,Second} + continue; + } + const seen = oneofSeen.get(field.oneof); + if (seen !== undefined) { + throw new Error(`cannot decode message ${type.typeName} from JSON: multiple keys for oneof "${field.oneof.name}" present: "${seen}", "${jsonKey}"`); + } + oneofSeen.set(field.oneof, jsonKey); + } + readField(message, jsonValue, field, options, type); + } + else { + let found = false; + if ((registry === null || registry === void 0 ? void 0 : registry.findExtension) && + jsonKey.startsWith("[") && + jsonKey.endsWith("]")) { + const ext = registry.findExtension(jsonKey.substring(1, jsonKey.length - 1)); + if (ext && ext.extendee.typeName == type.typeName) { + found = true; + const [container, get] = createExtensionContainer(ext); + readField(container, jsonValue, ext.field, options, ext); + // We pass on the options as BinaryReadOptions/BinaryWriteOptions, + // so that users can bring their own binary reader and writer factories + // if necessary. + setExtension(message, ext, get(), options); + } + } + if (!found && !options.ignoreUnknownFields) { + throw new Error(`cannot decode message ${type.typeName} from JSON: key "${jsonKey}" is unknown`); + } + } + } + return message; + }, + writeMessage(message, options) { + const type = message.getType(); + const json = {}; + let field; + try { + for (field of type.fields.byNumber()) { + if (!isFieldSet(field, message)) { + // eslint-disable-next-line @typescript-eslint/strict-boolean-expressions + if (field.req) { + throw `required field not set`; + } + if (!options.emitDefaultValues) { + continue; + } + if (!canEmitFieldDefaultValue(field)) { + continue; + } + } + const value = field.oneof + ? message[field.oneof.localName].value + : message[field.localName]; + const jsonValue = writeField(field, value, options); + if (jsonValue !== undefined) { + json[options.useProtoFieldName ? field.name : field.jsonName] = + jsonValue; + } + } + const registry = options.typeRegistry; + if (registry === null || registry === void 0 ? void 0 : registry.findExtensionFor) { + for (const uf of type.runtime.bin.listUnknownFields(message)) { + const ext = registry.findExtensionFor(type.typeName, uf.no); + if (ext && hasExtension(message, ext)) { + // We pass on the options as BinaryReadOptions, so that users can bring their own + // binary reader factory if necessary. + const value = getExtension(message, ext, options); + const jsonValue = writeField(ext.field, value, options); + if (jsonValue !== undefined) { + json[ext.field.jsonName] = jsonValue; + } + } + } + } + } + catch (e) { + const m = field + ? `cannot encode field ${type.typeName}.${field.name} to JSON` + : `cannot encode message ${type.typeName} to JSON`; + const r = e instanceof Error ? e.message : String(e); + throw new Error(m + (r.length > 0 ? `: ${r}` : "")); + } + return json; + }, + readScalar(type, json, longType) { + // The signature of our internal function has changed. For backwards- + // compatibility, we support the old form that is part of the public API + // through the interface JsonFormat. + return readScalar(type, json, longType !== null && longType !== void 0 ? longType : LongType.BIGINT, true); + }, + writeScalar(type, value, emitDefaultValues) { + // The signature of our internal function has changed. For backwards- + // compatibility, we support the old form that is part of the public API + // through the interface JsonFormat. + if (value === undefined) { + return undefined; + } + if (emitDefaultValues || isScalarZeroValue(type, value)) { + return writeScalar(type, value); + } + return undefined; + }, + debug: debugJsonValue, + }; +} +function debugJsonValue(json) { + if (json === null) { + return "null"; + } + switch (typeof json) { + case "object": + return Array.isArray(json) ? "array" : "object"; + case "string": + return json.length > 100 ? "string" : `"${json.split('"').join('\\"')}"`; + default: + return String(json); + } +} +// Read a JSON value for a field. +// The "parentType" argument is only used to provide context in errors. +function readField(target, jsonValue, field, options, parentType) { + let localName = field.localName; + if (field.repeated) { + assert(field.kind != "map"); + if (jsonValue === null) { + return; + } + if (!Array.isArray(jsonValue)) { + throw new Error(`cannot decode field ${parentType.typeName}.${field.name} from JSON: ${debugJsonValue(jsonValue)}`); + } + const targetArray = target[localName]; + for (const jsonItem of jsonValue) { + if (jsonItem === null) { + throw new Error(`cannot decode field ${parentType.typeName}.${field.name} from JSON: ${debugJsonValue(jsonItem)}`); + } + switch (field.kind) { + case "message": + targetArray.push(field.T.fromJson(jsonItem, options)); + break; + case "enum": + const enumValue = readEnum(field.T, jsonItem, options.ignoreUnknownFields, true); + if (enumValue !== tokenIgnoredUnknownEnum) { + targetArray.push(enumValue); + } + break; + case "scalar": + try { + targetArray.push(readScalar(field.T, jsonItem, field.L, true)); + } + catch (e) { + let m = `cannot decode field ${parentType.typeName}.${field.name} from JSON: ${debugJsonValue(jsonItem)}`; + if (e instanceof Error && e.message.length > 0) { + m += `: ${e.message}`; + } + throw new Error(m); + } + break; + } + } + } + else if (field.kind == "map") { + if (jsonValue === null) { + return; + } + if (typeof jsonValue != "object" || Array.isArray(jsonValue)) { + throw new Error(`cannot decode field ${parentType.typeName}.${field.name} from JSON: ${debugJsonValue(jsonValue)}`); + } + const targetMap = target[localName]; + for (const [jsonMapKey, jsonMapValue] of Object.entries(jsonValue)) { + if (jsonMapValue === null) { + throw new Error(`cannot decode field ${parentType.typeName}.${field.name} from JSON: map value null`); + } + let key; + try { + key = readMapKey(field.K, jsonMapKey); + } + catch (e) { + let m = `cannot decode map key for field ${parentType.typeName}.${field.name} from JSON: ${debugJsonValue(jsonValue)}`; + if (e instanceof Error && e.message.length > 0) { + m += `: ${e.message}`; + } + throw new Error(m); + } + switch (field.V.kind) { + case "message": + targetMap[key] = field.V.T.fromJson(jsonMapValue, options); + break; + case "enum": + const enumValue = readEnum(field.V.T, jsonMapValue, options.ignoreUnknownFields, true); + if (enumValue !== tokenIgnoredUnknownEnum) { + targetMap[key] = enumValue; + } + break; + case "scalar": + try { + targetMap[key] = readScalar(field.V.T, jsonMapValue, LongType.BIGINT, true); + } + catch (e) { + let m = `cannot decode map value for field ${parentType.typeName}.${field.name} from JSON: ${debugJsonValue(jsonValue)}`; + if (e instanceof Error && e.message.length > 0) { + m += `: ${e.message}`; + } + throw new Error(m); + } + break; + } + } + } + else { + if (field.oneof) { + target = target[field.oneof.localName] = { case: localName }; + localName = "value"; + } + switch (field.kind) { + case "message": + const messageType = field.T; + if (jsonValue === null && + messageType.typeName != "google.protobuf.Value") { + return; + } + let currentValue = target[localName]; + if (isMessage(currentValue)) { + currentValue.fromJson(jsonValue, options); + } + else { + target[localName] = currentValue = messageType.fromJson(jsonValue, options); + if (messageType.fieldWrapper && !field.oneof) { + target[localName] = + messageType.fieldWrapper.unwrapField(currentValue); + } + } + break; + case "enum": + const enumValue = readEnum(field.T, jsonValue, options.ignoreUnknownFields, false); + switch (enumValue) { + case tokenNull: + clearField(field, target); + break; + case tokenIgnoredUnknownEnum: + break; + default: + target[localName] = enumValue; + break; + } + break; + case "scalar": + try { + const scalarValue = readScalar(field.T, jsonValue, field.L, false); + switch (scalarValue) { + case tokenNull: + clearField(field, target); + break; + default: + target[localName] = scalarValue; + break; + } + } + catch (e) { + let m = `cannot decode field ${parentType.typeName}.${field.name} from JSON: ${debugJsonValue(jsonValue)}`; + if (e instanceof Error && e.message.length > 0) { + m += `: ${e.message}`; + } + throw new Error(m); + } + break; + } + } +} +function readMapKey(type, json) { + if (type === ScalarType.BOOL) { + // eslint-disable-next-line @typescript-eslint/switch-exhaustiveness-check + switch (json) { + case "true": + json = true; + break; + case "false": + json = false; + break; + } + } + return readScalar(type, json, LongType.BIGINT, true).toString(); +} +function readScalar(type, json, longType, nullAsZeroValue) { + if (json === null) { + if (nullAsZeroValue) { + return scalarZeroValue(type, longType); + } + return tokenNull; + } + // every valid case in the switch below returns, and every fall + // through is regarded as a failure. + switch (type) { + // float, double: JSON value will be a number or one of the special string values "NaN", "Infinity", and "-Infinity". + // Either numbers or strings are accepted. Exponent notation is also accepted. + case ScalarType.DOUBLE: + case ScalarType.FLOAT: + if (json === "NaN") + return Number.NaN; + if (json === "Infinity") + return Number.POSITIVE_INFINITY; + if (json === "-Infinity") + return Number.NEGATIVE_INFINITY; + if (json === "") { + // empty string is not a number + break; + } + if (typeof json == "string" && json.trim().length !== json.length) { + // extra whitespace + break; + } + if (typeof json != "string" && typeof json != "number") { + break; + } + const float = Number(json); + if (Number.isNaN(float)) { + // not a number + break; + } + if (!Number.isFinite(float)) { + // infinity and -infinity are handled by string representation above, so this is an error + break; + } + if (type == ScalarType.FLOAT) + assertFloat32(float); + return float; + // int32, fixed32, uint32: JSON value will be a decimal number. Either numbers or strings are accepted. + case ScalarType.INT32: + case ScalarType.FIXED32: + case ScalarType.SFIXED32: + case ScalarType.SINT32: + case ScalarType.UINT32: + let int32; + if (typeof json == "number") + int32 = json; + else if (typeof json == "string" && json.length > 0) { + if (json.trim().length === json.length) + int32 = Number(json); + } + if (int32 === undefined) + break; + if (type == ScalarType.UINT32 || type == ScalarType.FIXED32) + assertUInt32(int32); + else + assertInt32(int32); + return int32; + // int64, fixed64, uint64: JSON value will be a decimal string. Either numbers or strings are accepted. + case ScalarType.INT64: + case ScalarType.SFIXED64: + case ScalarType.SINT64: + if (typeof json != "number" && typeof json != "string") + break; + const long = protoInt64.parse(json); + // eslint-disable-next-line @typescript-eslint/strict-boolean-expressions + return longType ? long.toString() : long; + case ScalarType.FIXED64: + case ScalarType.UINT64: + if (typeof json != "number" && typeof json != "string") + break; + const uLong = protoInt64.uParse(json); + // eslint-disable-next-line @typescript-eslint/strict-boolean-expressions + return longType ? uLong.toString() : uLong; + // bool: + case ScalarType.BOOL: + if (typeof json !== "boolean") + break; + return json; + // string: + case ScalarType.STRING: + if (typeof json !== "string") { + break; + } + // A string must always contain UTF-8 encoded or 7-bit ASCII. + // We validate with encodeURIComponent, which appears to be the fastest widely available option. + try { + encodeURIComponent(json); + } + catch (e) { + throw new Error("invalid UTF8"); + } + return json; + // bytes: JSON value will be the data encoded as a string using standard base64 encoding with paddings. + // Either standard or URL-safe base64 encoding with/without paddings are accepted. + case ScalarType.BYTES: + if (json === "") + return new Uint8Array(0); + if (typeof json !== "string") + break; + return proto_base64_protoBase64.dec(json); + } + throw new Error(); +} +function readEnum(type, json, ignoreUnknownFields, nullAsZeroValue) { + if (json === null) { + if (type.typeName == "google.protobuf.NullValue") { + return 0; // google.protobuf.NullValue.NULL_VALUE = 0 + } + return nullAsZeroValue ? type.values[0].no : tokenNull; + } + // eslint-disable-next-line @typescript-eslint/switch-exhaustiveness-check + switch (typeof json) { + case "number": + if (Number.isInteger(json)) { + return json; + } + break; + case "string": + const value = type.findName(json); + if (value !== undefined) { + return value.no; + } + if (ignoreUnknownFields) { + return tokenIgnoredUnknownEnum; + } + break; + } + throw new Error(`cannot decode enum ${type.typeName} from JSON: ${debugJsonValue(json)}`); +} +// Decide whether an unset field should be emitted with JSON write option `emitDefaultValues` +function canEmitFieldDefaultValue(field) { + if (field.repeated || field.kind == "map") { + // maps are {}, repeated fields are [] + return true; + } + if (field.oneof) { + // oneof fields are never emitted + return false; + } + if (field.kind == "message") { + // singular message field are allowed to emit JSON null, but we do not + return false; + } + // eslint-disable-next-line @typescript-eslint/strict-boolean-expressions + if (field.opt || field.req) { + // the field uses explicit presence, so we cannot emit a zero value + return false; + } + return true; +} +function writeField(field, value, options) { + if (field.kind == "map") { + assert(typeof value == "object" && value != null); + const jsonObj = {}; + const entries = Object.entries(value); + switch (field.V.kind) { + case "scalar": + for (const [entryKey, entryValue] of entries) { + jsonObj[entryKey.toString()] = writeScalar(field.V.T, entryValue); // JSON standard allows only (double quoted) string as property key + } + break; + case "message": + for (const [entryKey, entryValue] of entries) { + // JSON standard allows only (double quoted) string as property key + jsonObj[entryKey.toString()] = entryValue.toJson(options); + } + break; + case "enum": + const enumType = field.V.T; + for (const [entryKey, entryValue] of entries) { + // JSON standard allows only (double quoted) string as property key + jsonObj[entryKey.toString()] = writeEnum(enumType, entryValue, options.enumAsInteger); + } + break; + } + return options.emitDefaultValues || entries.length > 0 + ? jsonObj + : undefined; + } + if (field.repeated) { + assert(Array.isArray(value)); + const jsonArr = []; + switch (field.kind) { + case "scalar": + for (let i = 0; i < value.length; i++) { + jsonArr.push(writeScalar(field.T, value[i])); + } + break; + case "enum": + for (let i = 0; i < value.length; i++) { + jsonArr.push(writeEnum(field.T, value[i], options.enumAsInteger)); + } + break; + case "message": + for (let i = 0; i < value.length; i++) { + jsonArr.push(value[i].toJson(options)); + } + break; + } + return options.emitDefaultValues || jsonArr.length > 0 + ? jsonArr + : undefined; + } + switch (field.kind) { + case "scalar": + return writeScalar(field.T, value); + case "enum": + return writeEnum(field.T, value, options.enumAsInteger); + case "message": + return wrapField(field.T, value).toJson(options); + } +} +function writeEnum(type, value, enumAsInteger) { + var _a; + assert(typeof value == "number"); + if (type.typeName == "google.protobuf.NullValue") { + return null; + } + if (enumAsInteger) { + return value; + } + const val = type.findNumber(value); + return (_a = val === null || val === void 0 ? void 0 : val.name) !== null && _a !== void 0 ? _a : value; // if we don't know the enum value, just return the number +} +function writeScalar(type, value) { + switch (type) { + // int32, fixed32, uint32: JSON value will be a decimal number. Either numbers or strings are accepted. + case ScalarType.INT32: + case ScalarType.SFIXED32: + case ScalarType.SINT32: + case ScalarType.FIXED32: + case ScalarType.UINT32: + assert(typeof value == "number"); + return value; + // float, double: JSON value will be a number or one of the special string values "NaN", "Infinity", and "-Infinity". + // Either numbers or strings are accepted. Exponent notation is also accepted. + case ScalarType.FLOAT: + // assertFloat32(value); + case ScalarType.DOUBLE: // eslint-disable-line no-fallthrough + assert(typeof value == "number"); + if (Number.isNaN(value)) + return "NaN"; + if (value === Number.POSITIVE_INFINITY) + return "Infinity"; + if (value === Number.NEGATIVE_INFINITY) + return "-Infinity"; + return value; + // string: + case ScalarType.STRING: + assert(typeof value == "string"); + return value; + // bool: + case ScalarType.BOOL: + assert(typeof value == "boolean"); + return value; + // JSON value will be a decimal string. Either numbers or strings are accepted. + case ScalarType.UINT64: + case ScalarType.FIXED64: + case ScalarType.INT64: + case ScalarType.SFIXED64: + case ScalarType.SINT64: + assert(typeof value == "bigint" || + typeof value == "string" || + typeof value == "number"); + return value.toString(); + // bytes: JSON value will be the data encoded as a string using standard base64 encoding with paddings. + // Either standard or URL-safe base64 encoding with/without paddings are accepted. + case ScalarType.BYTES: + assert(value instanceof Uint8Array); + return proto_base64_protoBase64.enc(value); + } +} + +;// CONCATENATED MODULE: ./node_modules/@bufbuild/protobuf/dist/esm/binary-encoding.js +// Copyright 2021-2024 Buf Technologies, Inc. +// +// Licensed under the Apache License, Version 2.0 (the "License"); +// you may not use this file except in compliance with the License. +// You may obtain a copy of the License at +// +// http://www.apache.org/licenses/LICENSE-2.0 +// +// Unless required by applicable law or agreed to in writing, software +// distributed under the License is distributed on an "AS IS" BASIS, +// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. +// See the License for the specific language governing permissions and +// limitations under the License. + + + +/* eslint-disable prefer-const,no-case-declarations,@typescript-eslint/restrict-plus-operands */ +/** + * Protobuf binary format wire types. + * + * A wire type provides just enough information to find the length of the + * following value. + * + * See https://developers.google.com/protocol-buffers/docs/encoding#structure + */ +var WireType; +(function (WireType) { + /** + * Used for int32, int64, uint32, uint64, sint32, sint64, bool, enum + */ + WireType[WireType["Varint"] = 0] = "Varint"; + /** + * Used for fixed64, sfixed64, double. + * Always 8 bytes with little-endian byte order. + */ + WireType[WireType["Bit64"] = 1] = "Bit64"; + /** + * Used for string, bytes, embedded messages, packed repeated fields + * + * Only repeated numeric types (types which use the varint, 32-bit, + * or 64-bit wire types) can be packed. In proto3, such fields are + * packed by default. + */ + WireType[WireType["LengthDelimited"] = 2] = "LengthDelimited"; + /** + * Start of a tag-delimited aggregate, such as a proto2 group, or a message + * in editions with message_encoding = DELIMITED. + */ + WireType[WireType["StartGroup"] = 3] = "StartGroup"; + /** + * End of a tag-delimited aggregate. + */ + WireType[WireType["EndGroup"] = 4] = "EndGroup"; + /** + * Used for fixed32, sfixed32, float. + * Always 4 bytes with little-endian byte order. + */ + WireType[WireType["Bit32"] = 5] = "Bit32"; +})(WireType || (WireType = {})); +class BinaryWriter { + constructor(textEncoder) { + /** + * Previous fork states. + */ + this.stack = []; + this.textEncoder = textEncoder !== null && textEncoder !== void 0 ? textEncoder : new TextEncoder(); + this.chunks = []; + this.buf = []; + } + /** + * Return all bytes written and reset this writer. + */ + finish() { + this.chunks.push(new Uint8Array(this.buf)); // flush the buffer + let len = 0; + for (let i = 0; i < this.chunks.length; i++) + len += this.chunks[i].length; + let bytes = new Uint8Array(len); + let offset = 0; + for (let i = 0; i < this.chunks.length; i++) { + bytes.set(this.chunks[i], offset); + offset += this.chunks[i].length; + } + this.chunks = []; + return bytes; + } + /** + * Start a new fork for length-delimited data like a message + * or a packed repeated field. + * + * Must be joined later with `join()`. + */ + fork() { + this.stack.push({ chunks: this.chunks, buf: this.buf }); + this.chunks = []; + this.buf = []; + return this; + } + /** + * Join the last fork. Write its length and bytes, then + * return to the previous state. + */ + join() { + // get chunk of fork + let chunk = this.finish(); + // restore previous state + let prev = this.stack.pop(); + if (!prev) + throw new Error("invalid state, fork stack empty"); + this.chunks = prev.chunks; + this.buf = prev.buf; + // write length of chunk as varint + this.uint32(chunk.byteLength); + return this.raw(chunk); + } + /** + * Writes a tag (field number and wire type). + * + * Equivalent to `uint32( (fieldNo << 3 | type) >>> 0 )`. + * + * Generated code should compute the tag ahead of time and call `uint32()`. + */ + tag(fieldNo, type) { + return this.uint32(((fieldNo << 3) | type) >>> 0); + } + /** + * Write a chunk of raw bytes. + */ + raw(chunk) { + if (this.buf.length) { + this.chunks.push(new Uint8Array(this.buf)); + this.buf = []; + } + this.chunks.push(chunk); + return this; + } + /** + * Write a `uint32` value, an unsigned 32 bit varint. + */ + uint32(value) { + assertUInt32(value); + // write value as varint 32, inlined for speed + while (value > 0x7f) { + this.buf.push((value & 0x7f) | 0x80); + value = value >>> 7; + } + this.buf.push(value); + return this; + } + /** + * Write a `int32` value, a signed 32 bit varint. + */ + int32(value) { + assertInt32(value); + varint32write(value, this.buf); + return this; + } + /** + * Write a `bool` value, a variant. + */ + bool(value) { + this.buf.push(value ? 1 : 0); + return this; + } + /** + * Write a `bytes` value, length-delimited arbitrary data. + */ + bytes(value) { + this.uint32(value.byteLength); // write length of chunk as varint + return this.raw(value); + } + /** + * Write a `string` value, length-delimited data converted to UTF-8 text. + */ + string(value) { + let chunk = this.textEncoder.encode(value); + this.uint32(chunk.byteLength); // write length of chunk as varint + return this.raw(chunk); + } + /** + * Write a `float` value, 32-bit floating point number. + */ + float(value) { + assertFloat32(value); + let chunk = new Uint8Array(4); + new DataView(chunk.buffer).setFloat32(0, value, true); + return this.raw(chunk); + } + /** + * Write a `double` value, a 64-bit floating point number. + */ + double(value) { + let chunk = new Uint8Array(8); + new DataView(chunk.buffer).setFloat64(0, value, true); + return this.raw(chunk); + } + /** + * Write a `fixed32` value, an unsigned, fixed-length 32-bit integer. + */ + fixed32(value) { + assertUInt32(value); + let chunk = new Uint8Array(4); + new DataView(chunk.buffer).setUint32(0, value, true); + return this.raw(chunk); + } + /** + * Write a `sfixed32` value, a signed, fixed-length 32-bit integer. + */ + sfixed32(value) { + assertInt32(value); + let chunk = new Uint8Array(4); + new DataView(chunk.buffer).setInt32(0, value, true); + return this.raw(chunk); + } + /** + * Write a `sint32` value, a signed, zigzag-encoded 32-bit varint. + */ + sint32(value) { + assertInt32(value); + // zigzag encode + value = ((value << 1) ^ (value >> 31)) >>> 0; + varint32write(value, this.buf); + return this; + } + /** + * Write a `fixed64` value, a signed, fixed-length 64-bit integer. + */ + sfixed64(value) { + let chunk = new Uint8Array(8), view = new DataView(chunk.buffer), tc = protoInt64.enc(value); + view.setInt32(0, tc.lo, true); + view.setInt32(4, tc.hi, true); + return this.raw(chunk); + } + /** + * Write a `fixed64` value, an unsigned, fixed-length 64 bit integer. + */ + fixed64(value) { + let chunk = new Uint8Array(8), view = new DataView(chunk.buffer), tc = protoInt64.uEnc(value); + view.setInt32(0, tc.lo, true); + view.setInt32(4, tc.hi, true); + return this.raw(chunk); + } + /** + * Write a `int64` value, a signed 64-bit varint. + */ + int64(value) { + let tc = protoInt64.enc(value); + varint64write(tc.lo, tc.hi, this.buf); + return this; + } + /** + * Write a `sint64` value, a signed, zig-zag-encoded 64-bit varint. + */ + sint64(value) { + let tc = protoInt64.enc(value), + // zigzag encode + sign = tc.hi >> 31, lo = (tc.lo << 1) ^ sign, hi = ((tc.hi << 1) | (tc.lo >>> 31)) ^ sign; + varint64write(lo, hi, this.buf); + return this; + } + /** + * Write a `uint64` value, an unsigned 64-bit varint. + */ + uint64(value) { + let tc = protoInt64.uEnc(value); + varint64write(tc.lo, tc.hi, this.buf); + return this; + } +} +class BinaryReader { + constructor(buf, textDecoder) { + this.varint64 = varint64read; // dirty cast for `this` + /** + * Read a `uint32` field, an unsigned 32 bit varint. + */ + this.uint32 = varint32read; // dirty cast for `this` and access to protected `buf` + this.buf = buf; + this.len = buf.length; + this.pos = 0; + this.view = new DataView(buf.buffer, buf.byteOffset, buf.byteLength); + this.textDecoder = textDecoder !== null && textDecoder !== void 0 ? textDecoder : new TextDecoder(); + } + /** + * Reads a tag - field number and wire type. + */ + tag() { + let tag = this.uint32(), fieldNo = tag >>> 3, wireType = tag & 7; + if (fieldNo <= 0 || wireType < 0 || wireType > 5) + throw new Error("illegal tag: field no " + fieldNo + " wire type " + wireType); + return [fieldNo, wireType]; + } + /** + * Skip one element and return the skipped data. + * + * When skipping StartGroup, provide the tags field number to check for + * matching field number in the EndGroup tag. + */ + skip(wireType, fieldNo) { + let start = this.pos; + switch (wireType) { + case WireType.Varint: + while (this.buf[this.pos++] & 0x80) { + // ignore + } + break; + // eslint-disable-next-line + // @ts-ignore TS7029: Fallthrough case in switch + case WireType.Bit64: + this.pos += 4; + // eslint-disable-next-line + // @ts-ignore TS7029: Fallthrough case in switch + case WireType.Bit32: + this.pos += 4; + break; + case WireType.LengthDelimited: + let len = this.uint32(); + this.pos += len; + break; + case WireType.StartGroup: + for (;;) { + const [fn, wt] = this.tag(); + if (wt === WireType.EndGroup) { + if (fieldNo !== undefined && fn !== fieldNo) { + throw new Error("invalid end group tag"); + } + break; + } + this.skip(wt, fn); + } + break; + default: + throw new Error("cant skip wire type " + wireType); + } + this.assertBounds(); + return this.buf.subarray(start, this.pos); + } + /** + * Throws error if position in byte array is out of range. + */ + assertBounds() { + if (this.pos > this.len) + throw new RangeError("premature EOF"); + } + /** + * Read a `int32` field, a signed 32 bit varint. + */ + int32() { + return this.uint32() | 0; + } + /** + * Read a `sint32` field, a signed, zigzag-encoded 32-bit varint. + */ + sint32() { + let zze = this.uint32(); + // decode zigzag + return (zze >>> 1) ^ -(zze & 1); + } + /** + * Read a `int64` field, a signed 64-bit varint. + */ + int64() { + return protoInt64.dec(...this.varint64()); + } + /** + * Read a `uint64` field, an unsigned 64-bit varint. + */ + uint64() { + return protoInt64.uDec(...this.varint64()); + } + /** + * Read a `sint64` field, a signed, zig-zag-encoded 64-bit varint. + */ + sint64() { + let [lo, hi] = this.varint64(); + // decode zig zag + let s = -(lo & 1); + lo = ((lo >>> 1) | ((hi & 1) << 31)) ^ s; + hi = (hi >>> 1) ^ s; + return protoInt64.dec(lo, hi); + } + /** + * Read a `bool` field, a variant. + */ + bool() { + let [lo, hi] = this.varint64(); + return lo !== 0 || hi !== 0; + } + /** + * Read a `fixed32` field, an unsigned, fixed-length 32-bit integer. + */ + fixed32() { + return this.view.getUint32((this.pos += 4) - 4, true); + } + /** + * Read a `sfixed32` field, a signed, fixed-length 32-bit integer. + */ + sfixed32() { + return this.view.getInt32((this.pos += 4) - 4, true); + } + /** + * Read a `fixed64` field, an unsigned, fixed-length 64 bit integer. + */ + fixed64() { + return protoInt64.uDec(this.sfixed32(), this.sfixed32()); + } + /** + * Read a `fixed64` field, a signed, fixed-length 64-bit integer. + */ + sfixed64() { + return protoInt64.dec(this.sfixed32(), this.sfixed32()); + } + /** + * Read a `float` field, 32-bit floating point number. + */ + float() { + return this.view.getFloat32((this.pos += 4) - 4, true); + } + /** + * Read a `double` field, a 64-bit floating point number. + */ + double() { + return this.view.getFloat64((this.pos += 8) - 8, true); + } + /** + * Read a `bytes` field, length-delimited arbitrary data. + */ + bytes() { + let len = this.uint32(), start = this.pos; + this.pos += len; + this.assertBounds(); + return this.buf.subarray(start, start + len); + } + /** + * Read a `string` field, length-delimited data converted to UTF-8 text. + */ + string() { + return this.textDecoder.decode(this.bytes()); + } +} + +;// CONCATENATED MODULE: ./node_modules/@bufbuild/protobuf/dist/esm/private/binary-format.js +// Copyright 2021-2024 Buf Technologies, Inc. +// +// Licensed under the Apache License, Version 2.0 (the "License"); +// you may not use this file except in compliance with the License. +// You may obtain a copy of the License at +// +// http://www.apache.org/licenses/LICENSE-2.0 +// +// Unless required by applicable law or agreed to in writing, software +// distributed under the License is distributed on an "AS IS" BASIS, +// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. +// See the License for the specific language governing permissions and +// limitations under the License. + + + + + + + + +/* eslint-disable prefer-const,no-case-declarations,@typescript-eslint/no-explicit-any,@typescript-eslint/no-unsafe-argument,@typescript-eslint/no-unsafe-assignment,@typescript-eslint/no-unsafe-member-access,@typescript-eslint/no-unsafe-call,@typescript-eslint/no-unsafe-return */ +const unknownFieldsSymbol = Symbol("@bufbuild/protobuf/unknown-fields"); +// Default options for parsing binary data. +const readDefaults = { + readUnknownFields: true, + readerFactory: (bytes) => new BinaryReader(bytes), +}; +// Default options for serializing binary data. +const writeDefaults = { + writeUnknownFields: true, + writerFactory: () => new BinaryWriter(), +}; +function binary_format_makeReadOptions(options) { + return options ? Object.assign(Object.assign({}, readDefaults), options) : readDefaults; +} +function binary_format_makeWriteOptions(options) { + return options ? Object.assign(Object.assign({}, writeDefaults), options) : writeDefaults; +} +function makeBinaryFormat() { + return { + makeReadOptions: binary_format_makeReadOptions, + makeWriteOptions: binary_format_makeWriteOptions, + listUnknownFields(message) { + var _a; + return (_a = message[unknownFieldsSymbol]) !== null && _a !== void 0 ? _a : []; + }, + discardUnknownFields(message) { + delete message[unknownFieldsSymbol]; + }, + writeUnknownFields(message, writer) { + const m = message; + const c = m[unknownFieldsSymbol]; + if (c) { + for (const f of c) { + writer.tag(f.no, f.wireType).raw(f.data); + } + } + }, + onUnknownField(message, no, wireType, data) { + const m = message; + if (!Array.isArray(m[unknownFieldsSymbol])) { + m[unknownFieldsSymbol] = []; + } + m[unknownFieldsSymbol].push({ no, wireType, data }); + }, + readMessage(message, reader, lengthOrEndTagFieldNo, options, delimitedMessageEncoding) { + const type = message.getType(); + // eslint-disable-next-line @typescript-eslint/strict-boolean-expressions + const end = delimitedMessageEncoding + ? reader.len + : reader.pos + lengthOrEndTagFieldNo; + let fieldNo, wireType; + while (reader.pos < end) { + [fieldNo, wireType] = reader.tag(); + if (delimitedMessageEncoding === true && + wireType == WireType.EndGroup) { + break; + } + const field = type.fields.find(fieldNo); + if (!field) { + const data = reader.skip(wireType, fieldNo); + if (options.readUnknownFields) { + this.onUnknownField(message, fieldNo, wireType, data); + } + continue; + } + binary_format_readField(message, reader, field, wireType, options); + } + if (delimitedMessageEncoding && // eslint-disable-line @typescript-eslint/strict-boolean-expressions + (wireType != WireType.EndGroup || fieldNo !== lengthOrEndTagFieldNo)) { + throw new Error(`invalid end group tag`); + } + }, + readField: binary_format_readField, + writeMessage(message, writer, options) { + const type = message.getType(); + for (const field of type.fields.byNumber()) { + if (!isFieldSet(field, message)) { + if (field.req) { + throw new Error(`cannot encode field ${type.typeName}.${field.name} to binary: required field not set`); + } + continue; + } + const value = field.oneof + ? message[field.oneof.localName].value + : message[field.localName]; + binary_format_writeField(field, value, writer, options); + } + if (options.writeUnknownFields) { + this.writeUnknownFields(message, writer); + } + return writer; + }, + writeField(field, value, writer, options) { + // The behavior of our internal function has changed, it does no longer + // accept `undefined` values for singular scalar and map. + // For backwards-compatibility, we support the old form that is part of + // the public API through the interface BinaryFormat. + if (value === undefined) { + return undefined; + } + binary_format_writeField(field, value, writer, options); + }, + }; +} +function binary_format_readField(target, // eslint-disable-line @typescript-eslint/no-explicit-any -- `any` is the best choice for dynamic access +reader, field, wireType, options) { + let { repeated, localName } = field; + if (field.oneof) { + target = target[field.oneof.localName]; + if (target.case != localName) { + delete target.value; + } + target.case = localName; + localName = "value"; + } + switch (field.kind) { + case "scalar": + case "enum": + const scalarType = field.kind == "enum" ? ScalarType.INT32 : field.T; + let read = binary_format_readScalar; + // eslint-disable-next-line @typescript-eslint/no-unsafe-enum-comparison -- acceptable since it's covered by tests + if (field.kind == "scalar" && field.L > 0) { + read = readScalarLTString; + } + if (repeated) { + let arr = target[localName]; // safe to assume presence of array, oneof cannot contain repeated values + const isPacked = wireType == WireType.LengthDelimited && + scalarType != ScalarType.STRING && + scalarType != ScalarType.BYTES; + if (isPacked) { + let e = reader.uint32() + reader.pos; + while (reader.pos < e) { + arr.push(read(reader, scalarType)); + } + } + else { + arr.push(read(reader, scalarType)); + } + } + else { + target[localName] = read(reader, scalarType); + } + break; + case "message": + const messageType = field.T; + if (repeated) { + // safe to assume presence of array, oneof cannot contain repeated values + target[localName].push(readMessageField(reader, new messageType(), options, field)); + } + else { + if (isMessage(target[localName])) { + readMessageField(reader, target[localName], options, field); + } + else { + target[localName] = readMessageField(reader, new messageType(), options, field); + if (messageType.fieldWrapper && !field.oneof && !field.repeated) { + target[localName] = messageType.fieldWrapper.unwrapField(target[localName]); + } + } + } + break; + case "map": + let [mapKey, mapVal] = readMapEntry(field, reader, options); + // safe to assume presence of map object, oneof cannot contain repeated values + target[localName][mapKey] = mapVal; + break; + } +} +// Read a message, avoiding MessageType.fromBinary() to re-use the +// BinaryReadOptions and the IBinaryReader. +function readMessageField(reader, message, options, field) { + const format = message.getType().runtime.bin; + const delimited = field === null || field === void 0 ? void 0 : field.delimited; + format.readMessage(message, reader, delimited ? field.no : reader.uint32(), // eslint-disable-line @typescript-eslint/strict-boolean-expressions + options, delimited); + return message; +} +// Read a map field, expecting key field = 1, value field = 2 +function readMapEntry(field, reader, options) { + const length = reader.uint32(), end = reader.pos + length; + let key, val; + while (reader.pos < end) { + const [fieldNo] = reader.tag(); + switch (fieldNo) { + case 1: + key = binary_format_readScalar(reader, field.K); + break; + case 2: + switch (field.V.kind) { + case "scalar": + val = binary_format_readScalar(reader, field.V.T); + break; + case "enum": + val = reader.int32(); + break; + case "message": + val = readMessageField(reader, new field.V.T(), options, undefined); + break; + } + break; + } + } + if (key === undefined) { + key = scalarZeroValue(field.K, LongType.BIGINT); + } + if (typeof key != "string" && typeof key != "number") { + key = key.toString(); + } + if (val === undefined) { + switch (field.V.kind) { + case "scalar": + val = scalarZeroValue(field.V.T, LongType.BIGINT); + break; + case "enum": + val = field.V.T.values[0].no; + break; + case "message": + val = new field.V.T(); + break; + } + } + return [key, val]; +} +// Read a scalar value, but return 64 bit integral types (int64, uint64, +// sint64, fixed64, sfixed64) as string instead of bigint. +function readScalarLTString(reader, type) { + const v = binary_format_readScalar(reader, type); + return typeof v == "bigint" ? v.toString() : v; +} +// Does not use scalarTypeInfo() for better performance. +function binary_format_readScalar(reader, type) { + switch (type) { + case ScalarType.STRING: + return reader.string(); + case ScalarType.BOOL: + return reader.bool(); + case ScalarType.DOUBLE: + return reader.double(); + case ScalarType.FLOAT: + return reader.float(); + case ScalarType.INT32: + return reader.int32(); + case ScalarType.INT64: + return reader.int64(); + case ScalarType.UINT64: + return reader.uint64(); + case ScalarType.FIXED64: + return reader.fixed64(); + case ScalarType.BYTES: + return reader.bytes(); + case ScalarType.FIXED32: + return reader.fixed32(); + case ScalarType.SFIXED32: + return reader.sfixed32(); + case ScalarType.SFIXED64: + return reader.sfixed64(); + case ScalarType.SINT64: + return reader.sint64(); + case ScalarType.UINT32: + return reader.uint32(); + case ScalarType.SINT32: + return reader.sint32(); + } +} +function binary_format_writeField(field, value, writer, options) { + assert(value !== undefined); + const repeated = field.repeated; + switch (field.kind) { + case "scalar": + case "enum": + let scalarType = field.kind == "enum" ? ScalarType.INT32 : field.T; + if (repeated) { + assert(Array.isArray(value)); + if (field.packed) { + writePacked(writer, scalarType, field.no, value); + } + else { + for (const item of value) { + binary_format_writeScalar(writer, scalarType, field.no, item); + } + } + } + else { + binary_format_writeScalar(writer, scalarType, field.no, value); + } + break; + case "message": + if (repeated) { + assert(Array.isArray(value)); + for (const item of value) { + writeMessageField(writer, options, field, item); + } + } + else { + writeMessageField(writer, options, field, value); + } + break; + case "map": + assert(typeof value == "object" && value != null); + for (const [key, val] of Object.entries(value)) { + writeMapEntry(writer, options, field, key, val); + } + break; + } +} +function writeMapEntry(writer, options, field, key, value) { + writer.tag(field.no, WireType.LengthDelimited); + writer.fork(); + // javascript only allows number or string for object properties + // we convert from our representation to the protobuf type + let keyValue = key; + // eslint-disable-next-line @typescript-eslint/switch-exhaustiveness-check -- we deliberately handle just the special cases for map keys + switch (field.K) { + case ScalarType.INT32: + case ScalarType.FIXED32: + case ScalarType.UINT32: + case ScalarType.SFIXED32: + case ScalarType.SINT32: + keyValue = Number.parseInt(key); + break; + case ScalarType.BOOL: + assert(key == "true" || key == "false"); + keyValue = key == "true"; + break; + } + // write key, expecting key field number = 1 + binary_format_writeScalar(writer, field.K, 1, keyValue); + // write value, expecting value field number = 2 + switch (field.V.kind) { + case "scalar": + binary_format_writeScalar(writer, field.V.T, 2, value); + break; + case "enum": + binary_format_writeScalar(writer, ScalarType.INT32, 2, value); + break; + case "message": + assert(value !== undefined); + writer.tag(2, WireType.LengthDelimited).bytes(value.toBinary(options)); + break; + } + writer.join(); +} +// Value must not be undefined +function writeMessageField(writer, options, field, value) { + const message = wrapField(field.T, value); + // eslint-disable-next-line @typescript-eslint/strict-boolean-expressions + if (field.delimited) + writer + .tag(field.no, WireType.StartGroup) + .raw(message.toBinary(options)) + .tag(field.no, WireType.EndGroup); + else + writer + .tag(field.no, WireType.LengthDelimited) + .bytes(message.toBinary(options)); +} +function binary_format_writeScalar(writer, type, fieldNo, value) { + assert(value !== undefined); + let [wireType, method] = scalarTypeInfo(type); + writer.tag(fieldNo, wireType)[method](value); +} +function writePacked(writer, type, fieldNo, value) { + if (!value.length) { + return; + } + writer.tag(fieldNo, WireType.LengthDelimited).fork(); + let [, method] = scalarTypeInfo(type); + for (let i = 0; i < value.length; i++) { + writer[method](value[i]); + } + writer.join(); +} +/** + * Get information for writing a scalar value. + * + * Returns tuple: + * [0]: appropriate WireType + * [1]: name of the appropriate method of IBinaryWriter + * [2]: whether the given value is a default value for proto3 semantics + * + * If argument `value` is omitted, [2] is always false. + */ +// TODO replace call-sites writeScalar() and writePacked(), then remove +function scalarTypeInfo(type) { + let wireType = WireType.Varint; + // eslint-disable-next-line @typescript-eslint/switch-exhaustiveness-check -- INT32, UINT32, SINT32 are covered by the defaults + switch (type) { + case ScalarType.BYTES: + case ScalarType.STRING: + wireType = WireType.LengthDelimited; + break; + case ScalarType.DOUBLE: + case ScalarType.FIXED64: + case ScalarType.SFIXED64: + wireType = WireType.Bit64; + break; + case ScalarType.FIXED32: + case ScalarType.SFIXED32: + case ScalarType.FLOAT: + wireType = WireType.Bit32; + break; + } + const method = ScalarType[type].toLowerCase(); + return [wireType, method]; +} + +;// CONCATENATED MODULE: ./node_modules/@bufbuild/protobuf/dist/esm/private/util-common.js +// Copyright 2021-2024 Buf Technologies, Inc. +// +// Licensed under the Apache License, Version 2.0 (the "License"); +// you may not use this file except in compliance with the License. +// You may obtain a copy of the License at +// +// http://www.apache.org/licenses/LICENSE-2.0 +// +// Unless required by applicable law or agreed to in writing, software +// distributed under the License is distributed on an "AS IS" BASIS, +// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. +// See the License for the specific language governing permissions and +// limitations under the License. + + + + + +/* eslint-disable @typescript-eslint/no-explicit-any,@typescript-eslint/no-unsafe-assignment,@typescript-eslint/no-unsafe-member-access,@typescript-eslint/no-unsafe-return,@typescript-eslint/no-unsafe-argument,no-case-declarations */ +function makeUtilCommon() { + return { + setEnumType: setEnumType, + initPartial(source, target) { + if (source === undefined) { + return; + } + const type = target.getType(); + for (const member of type.fields.byMember()) { + const localName = member.localName, t = target, s = source; + if (s[localName] == null) { + // TODO if source is a Message instance, we should use isFieldSet() here to support future field presence + continue; + } + switch (member.kind) { + case "oneof": + const sk = s[localName].case; + if (sk === undefined) { + continue; + } + const sourceField = member.findField(sk); + let val = s[localName].value; + if (sourceField && + sourceField.kind == "message" && + !isMessage(val, sourceField.T)) { + val = new sourceField.T(val); + } + else if (sourceField && + sourceField.kind === "scalar" && + sourceField.T === ScalarType.BYTES) { + val = toU8Arr(val); + } + t[localName] = { case: sk, value: val }; + break; + case "scalar": + case "enum": + let copy = s[localName]; + if (member.T === ScalarType.BYTES) { + copy = member.repeated + ? copy.map(toU8Arr) + : toU8Arr(copy); + } + t[localName] = copy; + break; + case "map": + switch (member.V.kind) { + case "scalar": + case "enum": + if (member.V.T === ScalarType.BYTES) { + for (const [k, v] of Object.entries(s[localName])) { + t[localName][k] = toU8Arr(v); + } + } + else { + Object.assign(t[localName], s[localName]); + } + break; + case "message": + const messageType = member.V.T; + for (const k of Object.keys(s[localName])) { + let val = s[localName][k]; + if (!messageType.fieldWrapper) { + // We only take partial input for messages that are not a wrapper type. + // For those messages, we recursively normalize the partial input. + val = new messageType(val); + } + t[localName][k] = val; + } + break; + } + break; + case "message": + const mt = member.T; + if (member.repeated) { + t[localName] = s[localName].map((val) => isMessage(val, mt) ? val : new mt(val)); + } + else { + const val = s[localName]; + if (mt.fieldWrapper) { + if ( + // We can't use BytesValue.typeName as that will create a circular import + mt.typeName === "google.protobuf.BytesValue") { + t[localName] = toU8Arr(val); + } + else { + t[localName] = val; + } + } + else { + t[localName] = isMessage(val, mt) ? val : new mt(val); + } + } + break; + } + } + }, + // TODO use isFieldSet() here to support future field presence + equals(type, a, b) { + if (a === b) { + return true; + } + if (!a || !b) { + return false; + } + return type.fields.byMember().every((m) => { + const va = a[m.localName]; + const vb = b[m.localName]; + if (m.repeated) { + if (va.length !== vb.length) { + return false; + } + // eslint-disable-next-line @typescript-eslint/switch-exhaustiveness-check -- repeated fields are never "map" + switch (m.kind) { + case "message": + return va.every((a, i) => m.T.equals(a, vb[i])); + case "scalar": + return va.every((a, i) => scalarEquals(m.T, a, vb[i])); + case "enum": + return va.every((a, i) => scalarEquals(ScalarType.INT32, a, vb[i])); + } + throw new Error(`repeated cannot contain ${m.kind}`); + } + switch (m.kind) { + case "message": + return m.T.equals(va, vb); + case "enum": + return scalarEquals(ScalarType.INT32, va, vb); + case "scalar": + return scalarEquals(m.T, va, vb); + case "oneof": + if (va.case !== vb.case) { + return false; + } + const s = m.findField(va.case); + if (s === undefined) { + return true; + } + // eslint-disable-next-line @typescript-eslint/switch-exhaustiveness-check -- oneof fields are never "map" + switch (s.kind) { + case "message": + return s.T.equals(va.value, vb.value); + case "enum": + return scalarEquals(ScalarType.INT32, va.value, vb.value); + case "scalar": + return scalarEquals(s.T, va.value, vb.value); + } + throw new Error(`oneof cannot contain ${s.kind}`); + case "map": + const keys = Object.keys(va).concat(Object.keys(vb)); + switch (m.V.kind) { + case "message": + const messageType = m.V.T; + return keys.every((k) => messageType.equals(va[k], vb[k])); + case "enum": + return keys.every((k) => scalarEquals(ScalarType.INT32, va[k], vb[k])); + case "scalar": + const scalarType = m.V.T; + return keys.every((k) => scalarEquals(scalarType, va[k], vb[k])); + } + break; + } + }); + }, + // TODO use isFieldSet() here to support future field presence + clone(message) { + const type = message.getType(), target = new type(), any = target; + for (const member of type.fields.byMember()) { + const source = message[member.localName]; + let copy; + if (member.repeated) { + copy = source.map(cloneSingularField); + } + else if (member.kind == "map") { + copy = any[member.localName]; + for (const [key, v] of Object.entries(source)) { + copy[key] = cloneSingularField(v); + } + } + else if (member.kind == "oneof") { + const f = member.findField(source.case); + copy = f + ? { case: source.case, value: cloneSingularField(source.value) } + : { case: undefined }; + } + else { + copy = cloneSingularField(source); + } + any[member.localName] = copy; + } + for (const uf of type.runtime.bin.listUnknownFields(message)) { + type.runtime.bin.onUnknownField(any, uf.no, uf.wireType, uf.data); + } + return target; + }, + }; +} +// clone a single field value - i.e. the element type of repeated fields, the value type of maps +function cloneSingularField(value) { + if (value === undefined) { + return value; + } + if (isMessage(value)) { + return value.clone(); + } + if (value instanceof Uint8Array) { + const c = new Uint8Array(value.byteLength); + c.set(value); + return c; + } + return value; +} +// converts any ArrayLike to Uint8Array if necessary. +function toU8Arr(input) { + return input instanceof Uint8Array ? input : new Uint8Array(input); +} + +;// CONCATENATED MODULE: ./node_modules/@bufbuild/protobuf/dist/esm/private/proto-runtime.js +// Copyright 2021-2024 Buf Technologies, Inc. +// +// Licensed under the Apache License, Version 2.0 (the "License"); +// you may not use this file except in compliance with the License. +// You may obtain a copy of the License at +// +// http://www.apache.org/licenses/LICENSE-2.0 +// +// Unless required by applicable law or agreed to in writing, software +// distributed under the License is distributed on an "AS IS" BASIS, +// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. +// See the License for the specific language governing permissions and +// limitations under the License. + + + + + + +function makeProtoRuntime(syntax, newFieldList, initFields) { + return { + syntax, + json: makeJsonFormat(), + bin: makeBinaryFormat(), + util: Object.assign(Object.assign({}, makeUtilCommon()), { newFieldList, + initFields }), + makeMessageType(typeName, fields, opt) { + return makeMessageType(this, typeName, fields, opt); + }, + makeEnum: makeEnum, + makeEnumType: makeEnumType, + getEnumType: getEnumType, + makeExtension(typeName, extendee, field) { + return makeExtension(this, typeName, extendee, field); + }, + }; +} + +;// CONCATENATED MODULE: ./node_modules/@bufbuild/protobuf/dist/esm/private/field-list.js +// Copyright 2021-2024 Buf Technologies, Inc. +// +// Licensed under the Apache License, Version 2.0 (the "License"); +// you may not use this file except in compliance with the License. +// You may obtain a copy of the License at +// +// http://www.apache.org/licenses/LICENSE-2.0 +// +// Unless required by applicable law or agreed to in writing, software +// distributed under the License is distributed on an "AS IS" BASIS, +// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. +// See the License for the specific language governing permissions and +// limitations under the License. +class InternalFieldList { + constructor(fields, normalizer) { + this._fields = fields; + this._normalizer = normalizer; + } + findJsonName(jsonName) { + if (!this.jsonNames) { + const t = {}; + for (const f of this.list()) { + t[f.jsonName] = t[f.name] = f; + } + this.jsonNames = t; + } + return this.jsonNames[jsonName]; + } + find(fieldNo) { + if (!this.numbers) { + const t = {}; + for (const f of this.list()) { + t[f.no] = f; + } + this.numbers = t; + } + return this.numbers[fieldNo]; + } + list() { + if (!this.all) { + this.all = this._normalizer(this._fields); + } + return this.all; + } + byNumber() { + if (!this.numbersAsc) { + this.numbersAsc = this.list() + .concat() + .sort((a, b) => a.no - b.no); + } + return this.numbersAsc; + } + byMember() { + if (!this.members) { + this.members = []; + const a = this.members; + let o; + for (const f of this.list()) { + if (f.oneof) { + if (f.oneof !== o) { + o = f.oneof; + a.push(o); + } + } + else { + a.push(f); + } + } + } + return this.members; + } +} + +;// CONCATENATED MODULE: ./node_modules/@bufbuild/protobuf/dist/esm/private/names.js +// Copyright 2021-2024 Buf Technologies, Inc. +// +// Licensed under the Apache License, Version 2.0 (the "License"); +// you may not use this file except in compliance with the License. +// You may obtain a copy of the License at +// +// http://www.apache.org/licenses/LICENSE-2.0 +// +// Unless required by applicable law or agreed to in writing, software +// distributed under the License is distributed on an "AS IS" BASIS, +// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. +// See the License for the specific language governing permissions and +// limitations under the License. +/** + * Returns the name of a protobuf element in generated code. + * + * Field names - including oneofs - are converted to lowerCamelCase. For + * messages, enumerations and services, the package name is stripped from + * the type name. For nested messages and enumerations, the names are joined + * with an underscore. For methods, the first character is made lowercase. + */ +function localName(desc) { + switch (desc.kind) { + case "field": + return localFieldName(desc.name, desc.oneof !== undefined); + case "oneof": + return localOneofName(desc.name); + case "enum": + case "message": + case "service": + case "extension": { + const pkg = desc.file.proto.package; + const offset = pkg === undefined ? 0 : pkg.length + 1; + const name = desc.typeName.substring(offset).replace(/\./g, "_"); + // For services, we only care about safe identifiers, not safe object properties, + // but we have shipped v1 with a bug that respected object properties, and we + // do not want to introduce a breaking change, so we continue to escape for + // safe object properties. + // See https://github.com/bufbuild/protobuf-es/pull/391 + return safeObjectProperty(safeIdentifier(name)); + } + case "enum_value": { + let name = desc.name; + const sharedPrefix = desc.parent.sharedPrefix; + if (sharedPrefix !== undefined) { + name = name.substring(sharedPrefix.length); + } + return safeObjectProperty(name); + } + case "rpc": { + let name = desc.name; + if (name.length == 0) { + return name; + } + name = name[0].toLowerCase() + name.substring(1); + return safeObjectProperty(name); + } + } +} +/** + * Returns the name of a field in generated code. + */ +function localFieldName(protoName, inOneof) { + const name = protoCamelCase(protoName); + if (inOneof) { + // oneof member names are not properties, but values of the `case` property. + return name; + } + return safeObjectProperty(safeMessageProperty(name)); +} +/** + * Returns the name of a oneof group in generated code. + */ +function localOneofName(protoName) { + return localFieldName(protoName, false); +} +/** + * Returns the JSON name for a protobuf field, exactly like protoc does. + */ +const fieldJsonName = protoCamelCase; +/** + * Finds a prefix shared by enum values, for example `MY_ENUM_` for + * `enum MyEnum {MY_ENUM_A=0; MY_ENUM_B=1;}`. + */ +function findEnumSharedPrefix(enumName, valueNames) { + const prefix = camelToSnakeCase(enumName) + "_"; + for (const name of valueNames) { + if (!name.toLowerCase().startsWith(prefix)) { + return undefined; + } + const shortName = name.substring(prefix.length); + if (shortName.length == 0) { + return undefined; + } + if (/^\d/.test(shortName)) { + // identifiers must not start with numbers + return undefined; + } + } + return prefix; +} +/** + * Converts lowerCamelCase or UpperCamelCase into lower_snake_case. + * This is used to find shared prefixes in an enum. + */ +function camelToSnakeCase(camel) { + return (camel.substring(0, 1) + camel.substring(1).replace(/[A-Z]/g, (c) => "_" + c)).toLowerCase(); +} +/** + * Converts snake_case to protoCamelCase according to the convention + * used by protoc to convert a field name to a JSON name. + */ +function protoCamelCase(snakeCase) { + let capNext = false; + const b = []; + for (let i = 0; i < snakeCase.length; i++) { + let c = snakeCase.charAt(i); + switch (c) { + case "_": + capNext = true; + break; + case "0": + case "1": + case "2": + case "3": + case "4": + case "5": + case "6": + case "7": + case "8": + case "9": + b.push(c); + capNext = false; + break; + default: + if (capNext) { + capNext = false; + c = c.toUpperCase(); + } + b.push(c); + break; + } + } + return b.join(""); +} +/** + * Names that cannot be used for identifiers, such as class names, + * but _can_ be used for object properties. + */ +const reservedIdentifiers = new Set([ + // ECMAScript 2015 keywords + "break", + "case", + "catch", + "class", + "const", + "continue", + "debugger", + "default", + "delete", + "do", + "else", + "export", + "extends", + "false", + "finally", + "for", + "function", + "if", + "import", + "in", + "instanceof", + "new", + "null", + "return", + "super", + "switch", + "this", + "throw", + "true", + "try", + "typeof", + "var", + "void", + "while", + "with", + "yield", + // ECMAScript 2015 future reserved keywords + "enum", + "implements", + "interface", + "let", + "package", + "private", + "protected", + "public", + "static", + // Class name cannot be 'Object' when targeting ES5 with module CommonJS + "Object", + // TypeScript keywords that cannot be used for types (as opposed to variables) + "bigint", + "number", + "boolean", + "string", + "object", + // Identifiers reserved for the runtime, so we can generate legible code + "globalThis", + "Uint8Array", + "Partial", +]); +/** + * Names that cannot be used for object properties because they are reserved + * by built-in JavaScript properties. + */ +const reservedObjectProperties = new Set([ + // names reserved by JavaScript + "constructor", + "toString", + "toJSON", + "valueOf", +]); +/** + * Names that cannot be used for object properties because they are reserved + * by the runtime. + */ +const reservedMessageProperties = new Set([ + // names reserved by the runtime + "getType", + "clone", + "equals", + "fromBinary", + "fromJson", + "fromJsonString", + "toBinary", + "toJson", + "toJsonString", + // names reserved by the runtime for the future + "toObject", +]); +const fallback = (name) => `${name}$`; +/** + * Will wrap names that are Object prototype properties or names reserved + * for `Message`s. + */ +const safeMessageProperty = (name) => { + if (reservedMessageProperties.has(name)) { + return fallback(name); + } + return name; +}; +/** + * Names that cannot be used for object properties because they are reserved + * by built-in JavaScript properties. + */ +const safeObjectProperty = (name) => { + if (reservedObjectProperties.has(name)) { + return fallback(name); + } + return name; +}; +/** + * Names that can be used for identifiers or class properties + */ +const safeIdentifier = (name) => { + if (reservedIdentifiers.has(name)) { + return fallback(name); + } + return name; +}; + +;// CONCATENATED MODULE: ./node_modules/@bufbuild/protobuf/dist/esm/private/field.js +// Copyright 2021-2024 Buf Technologies, Inc. +// +// Licensed under the Apache License, Version 2.0 (the "License"); +// you may not use this file except in compliance with the License. +// You may obtain a copy of the License at +// +// http://www.apache.org/licenses/LICENSE-2.0 +// +// Unless required by applicable law or agreed to in writing, software +// distributed under the License is distributed on an "AS IS" BASIS, +// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. +// See the License for the specific language governing permissions and +// limitations under the License. + + +class InternalOneofInfo { + constructor(name) { + this.kind = "oneof"; + this.repeated = false; + this.packed = false; + this.opt = false; + this.req = false; + this.default = undefined; + this.fields = []; + this.name = name; + this.localName = localOneofName(name); + } + addField(field) { + assert(field.oneof === this, `field ${field.name} not one of ${this.name}`); + this.fields.push(field); + } + findField(localName) { + if (!this._lookup) { + this._lookup = Object.create(null); + for (let i = 0; i < this.fields.length; i++) { + this._lookup[this.fields[i].localName] = this.fields[i]; + } + } + return this._lookup[localName]; + } +} + +;// CONCATENATED MODULE: ./node_modules/@bufbuild/protobuf/dist/esm/private/field-normalize.js +// Copyright 2021-2024 Buf Technologies, Inc. +// +// Licensed under the Apache License, Version 2.0 (the "License"); +// you may not use this file except in compliance with the License. +// You may obtain a copy of the License at +// +// http://www.apache.org/licenses/LICENSE-2.0 +// +// Unless required by applicable law or agreed to in writing, software +// distributed under the License is distributed on an "AS IS" BASIS, +// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. +// See the License for the specific language governing permissions and +// limitations under the License. + + + +/** + * Convert a collection of field info to an array of normalized FieldInfo. + * + * The argument `packedByDefault` specifies whether fields that do not specify + * `packed` should be packed (proto3) or unpacked (proto2). + */ +function normalizeFieldInfos(fieldInfos, packedByDefault) { + var _a, _b, _c, _d, _e, _f; + const r = []; + let o; + for (const field of typeof fieldInfos == "function" + ? fieldInfos() + : fieldInfos) { + const f = field; + f.localName = localFieldName(field.name, field.oneof !== undefined); + f.jsonName = (_a = field.jsonName) !== null && _a !== void 0 ? _a : fieldJsonName(field.name); + f.repeated = (_b = field.repeated) !== null && _b !== void 0 ? _b : false; + if (field.kind == "scalar") { + f.L = (_c = field.L) !== null && _c !== void 0 ? _c : LongType.BIGINT; + } + f.delimited = (_d = field.delimited) !== null && _d !== void 0 ? _d : false; + f.req = (_e = field.req) !== null && _e !== void 0 ? _e : false; + f.opt = (_f = field.opt) !== null && _f !== void 0 ? _f : false; + if (field.packed === undefined) { + if (packedByDefault) { + f.packed = + field.kind == "enum" || + (field.kind == "scalar" && + field.T != ScalarType.BYTES && + field.T != ScalarType.STRING); + } + else { + f.packed = false; + } + } + // We do not surface options at this time + // f.options = field.options ?? emptyReadonlyObject; + if (field.oneof !== undefined) { + const ooname = typeof field.oneof == "string" ? field.oneof : field.oneof.name; + if (!o || o.name != ooname) { + o = new InternalOneofInfo(ooname); + } + f.oneof = o; + o.addField(f); + } + r.push(f); + } + return r; +} + +;// CONCATENATED MODULE: ./node_modules/@bufbuild/protobuf/dist/esm/proto3.js +// Copyright 2021-2024 Buf Technologies, Inc. +// +// Licensed under the Apache License, Version 2.0 (the "License"); +// you may not use this file except in compliance with the License. +// You may obtain a copy of the License at +// +// http://www.apache.org/licenses/LICENSE-2.0 +// +// Unless required by applicable law or agreed to in writing, software +// distributed under the License is distributed on an "AS IS" BASIS, +// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. +// See the License for the specific language governing permissions and +// limitations under the License. + + + + +/** + * Provides functionality for messages defined with the proto3 syntax. + */ +const proto3 = makeProtoRuntime("proto3", (fields) => { + return new InternalFieldList(fields, (source) => normalizeFieldInfos(source, true)); +}, +// TODO merge with proto2 and initExtensionField, also see initPartial, equals, clone +(target) => { + for (const member of target.getType().fields.byMember()) { + if (member.opt) { + continue; + } + const name = member.localName, t = target; + if (member.repeated) { + t[name] = []; + continue; + } + switch (member.kind) { + case "oneof": + t[name] = { case: undefined }; + break; + case "enum": + t[name] = 0; + break; + case "map": + t[name] = {}; + break; + case "scalar": + t[name] = scalarZeroValue(member.T, member.L); + break; + case "message": + // message fields are always optional in proto3 + break; + } + } +}); + +;// CONCATENATED MODULE: ./node_modules/@bufbuild/protobuf/dist/esm/google/protobuf/any_pb.js +// Copyright 2021-2024 Buf Technologies, Inc. +// +// Licensed under the Apache License, Version 2.0 (the "License"); +// you may not use this file except in compliance with the License. +// You may obtain a copy of the License at +// +// http://www.apache.org/licenses/LICENSE-2.0 +// +// Unless required by applicable law or agreed to in writing, software +// distributed under the License is distributed on an "AS IS" BASIS, +// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. +// See the License for the specific language governing permissions and +// limitations under the License. + + +/** + * `Any` contains an arbitrary serialized protocol buffer message along with a + * URL that describes the type of the serialized message. + * + * Protobuf library provides support to pack/unpack Any values in the form + * of utility functions or additional generated methods of the Any type. + * + * Example 1: Pack and unpack a message in C++. + * + * Foo foo = ...; + * Any any; + * any.PackFrom(foo); + * ... + * if (any.UnpackTo(&foo)) { + * ... + * } + * + * Example 2: Pack and unpack a message in Java. + * + * Foo foo = ...; + * Any any = Any.pack(foo); + * ... + * if (any.is(Foo.class)) { + * foo = any.unpack(Foo.class); + * } + * // or ... + * if (any.isSameTypeAs(Foo.getDefaultInstance())) { + * foo = any.unpack(Foo.getDefaultInstance()); + * } + * + * Example 3: Pack and unpack a message in Python. + * + * foo = Foo(...) + * any = Any() + * any.Pack(foo) + * ... + * if any.Is(Foo.DESCRIPTOR): + * any.Unpack(foo) + * ... + * + * Example 4: Pack and unpack a message in Go + * + * foo := &pb.Foo{...} + * any, err := anypb.New(foo) + * if err != nil { + * ... + * } + * ... + * foo := &pb.Foo{} + * if err := any.UnmarshalTo(foo); err != nil { + * ... + * } + * + * The pack methods provided by protobuf library will by default use + * 'type.googleapis.com/full.type.name' as the type URL and the unpack + * methods only use the fully qualified type name after the last '/' + * in the type URL, for example "foo.bar.com/x/y.z" will yield type + * name "y.z". + * + * JSON + * ==== + * The JSON representation of an `Any` value uses the regular + * representation of the deserialized, embedded message, with an + * additional field `@type` which contains the type URL. Example: + * + * package google.profile; + * message Person { + * string first_name = 1; + * string last_name = 2; + * } + * + * { + * "@type": "type.googleapis.com/google.profile.Person", + * "firstName": , + * "lastName": + * } + * + * If the embedded message type is well-known and has a custom JSON + * representation, that representation will be embedded adding a field + * `value` which holds the custom JSON in addition to the `@type` + * field. Example (for message [google.protobuf.Duration][]): + * + * { + * "@type": "type.googleapis.com/google.protobuf.Duration", + * "value": "1.212s" + * } + * + * + * @generated from message google.protobuf.Any + */ +class any_pb_Any extends Message { + constructor(data) { + super(); + /** + * A URL/resource name that uniquely identifies the type of the serialized + * protocol buffer message. This string must contain at least + * one "/" character. The last segment of the URL's path must represent + * the fully qualified name of the type (as in + * `path/google.protobuf.Duration`). The name should be in a canonical form + * (e.g., leading "." is not accepted). + * + * In practice, teams usually precompile into the binary all types that they + * expect it to use in the context of Any. However, for URLs which use the + * scheme `http`, `https`, or no scheme, one can optionally set up a type + * server that maps type URLs to message definitions as follows: + * + * * If no scheme is provided, `https` is assumed. + * * An HTTP GET on the URL must yield a [google.protobuf.Type][] + * value in binary format, or produce an error. + * * Applications are allowed to cache lookup results based on the + * URL, or have them precompiled into a binary to avoid any + * lookup. Therefore, binary compatibility needs to be preserved + * on changes to types. (Use versioned type names to manage + * breaking changes.) + * + * Note: this functionality is not currently available in the official + * protobuf release, and it is not used for type URLs beginning with + * type.googleapis.com. As of May 2023, there are no widely used type server + * implementations and no plans to implement one. + * + * Schemes other than `http`, `https` (or the empty scheme) might be + * used with implementation specific semantics. + * + * + * @generated from field: string type_url = 1; + */ + this.typeUrl = ""; + /** + * Must be a valid serialized protocol buffer of the above specified type. + * + * @generated from field: bytes value = 2; + */ + this.value = new Uint8Array(0); + proto3.util.initPartial(data, this); + } + toJson(options) { + var _a; + if (this.typeUrl === "") { + return {}; + } + const typeName = this.typeUrlToName(this.typeUrl); + const messageType = (_a = options === null || options === void 0 ? void 0 : options.typeRegistry) === null || _a === void 0 ? void 0 : _a.findMessage(typeName); + if (!messageType) { + throw new Error(`cannot encode message google.protobuf.Any to JSON: "${this.typeUrl}" is not in the type registry`); + } + const message = messageType.fromBinary(this.value); + let json = message.toJson(options); + if (typeName.startsWith("google.protobuf.") || (json === null || Array.isArray(json) || typeof json !== "object")) { + json = { value: json }; + } + json["@type"] = this.typeUrl; + return json; + } + fromJson(json, options) { + var _a; + if (json === null || Array.isArray(json) || typeof json != "object") { + throw new Error(`cannot decode message google.protobuf.Any from JSON: expected object but got ${json === null ? "null" : Array.isArray(json) ? "array" : typeof json}`); + } + if (Object.keys(json).length == 0) { + return this; + } + const typeUrl = json["@type"]; + if (typeof typeUrl != "string" || typeUrl == "") { + throw new Error(`cannot decode message google.protobuf.Any from JSON: "@type" is empty`); + } + const typeName = this.typeUrlToName(typeUrl), messageType = (_a = options === null || options === void 0 ? void 0 : options.typeRegistry) === null || _a === void 0 ? void 0 : _a.findMessage(typeName); + if (!messageType) { + throw new Error(`cannot decode message google.protobuf.Any from JSON: ${typeUrl} is not in the type registry`); + } + let message; + if (typeName.startsWith("google.protobuf.") && Object.prototype.hasOwnProperty.call(json, "value")) { + message = messageType.fromJson(json["value"], options); + } + else { + const copy = Object.assign({}, json); + delete copy["@type"]; + message = messageType.fromJson(copy, options); + } + this.packFrom(message); + return this; + } + packFrom(message) { + this.value = message.toBinary(); + this.typeUrl = this.typeNameToUrl(message.getType().typeName); + } + unpackTo(target) { + if (!this.is(target.getType())) { + return false; + } + target.fromBinary(this.value); + return true; + } + unpack(registry) { + if (this.typeUrl === "") { + return undefined; + } + const messageType = registry.findMessage(this.typeUrlToName(this.typeUrl)); + if (!messageType) { + return undefined; + } + return messageType.fromBinary(this.value); + } + is(type) { + if (this.typeUrl === '') { + return false; + } + const name = this.typeUrlToName(this.typeUrl); + let typeName = ''; + if (typeof type === 'string') { + typeName = type; + } + else { + typeName = type.typeName; + } + return name === typeName; + } + typeNameToUrl(name) { + return `type.googleapis.com/${name}`; + } + typeUrlToName(url) { + if (!url.length) { + throw new Error(`invalid type url: ${url}`); + } + const slash = url.lastIndexOf("/"); + const name = slash >= 0 ? url.substring(slash + 1) : url; + if (!name.length) { + throw new Error(`invalid type url: ${url}`); + } + return name; + } + static pack(message) { + const any = new any_pb_Any(); + any.packFrom(message); + return any; + } + static fromBinary(bytes, options) { + return new any_pb_Any().fromBinary(bytes, options); + } + static fromJson(jsonValue, options) { + return new any_pb_Any().fromJson(jsonValue, options); + } + static fromJsonString(jsonString, options) { + return new any_pb_Any().fromJsonString(jsonString, options); + } + static equals(a, b) { + return proto3.util.equals(any_pb_Any, a, b); + } +} +any_pb_Any.runtime = proto3; +any_pb_Any.typeName = "google.protobuf.Any"; +any_pb_Any.fields = proto3.util.newFieldList(() => [ + { no: 1, name: "type_url", kind: "scalar", T: 9 /* ScalarType.STRING */ }, + { no: 2, name: "value", kind: "scalar", T: 12 /* ScalarType.BYTES */ }, +]); + +;// CONCATENATED MODULE: ./node_modules/@connectrpc/connect/dist/esm/protocol-grpc/gen/status_pb.js +// Copyright 2021-2024 The Connect Authors +// +// Licensed under the Apache License, Version 2.0 (the "License"); +// you may not use this file except in compliance with the License. +// You may obtain a copy of the License at +// +// http://www.apache.org/licenses/LICENSE-2.0 +// +// Unless required by applicable law or agreed to in writing, software +// distributed under the License is distributed on an "AS IS" BASIS, +// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. +// See the License for the specific language governing permissions and +// limitations under the License. + +/** + * The `Status` type defines a logical error model that is suitable for different + * programming environments, including REST APIs and RPC APIs. It is used by + * [gRPC](https://github.com/grpc). The error model is designed to be: + * + * - Simple to use and understand for most users + * - Flexible enough to meet unexpected needs + * + * # Overview + * + * The `Status` message contains three pieces of data: error code, error message, + * and error details. The error code should be an enum value of + * [google.rpc.Code][google.rpc.Code], but it may accept additional error codes if needed. The + * error message should be a developer-facing English message that helps + * developers *understand* and *resolve* the error. If a localized user-facing + * error message is needed, put the localized message in the error details or + * localize it in the client. The optional error details may contain arbitrary + * information about the error. There is a predefined set of error detail types + * in the package `google.rpc` which can be used for common error conditions. + * + * # Language mapping + * + * The `Status` message is the logical representation of the error model, but it + * is not necessarily the actual wire format. When the `Status` message is + * exposed in different client libraries and different wire protocols, it can be + * mapped differently. For example, it will likely be mapped to some exceptions + * in Java, but more likely mapped to some error codes in C. + * + * # Other uses + * + * The error model and the `Status` message can be used in a variety of + * environments, either with or without APIs, to provide a + * consistent developer experience across different environments. + * + * Example uses of this error model include: + * + * - Partial errors. If a service needs to return partial errors to the client, + * it may embed the `Status` in the normal response to indicate the partial + * errors. + * + * - Workflow errors. A typical workflow has multiple steps. Each step may + * have a `Status` message for error reporting purpose. + * + * - Batch operations. If a client uses batch request and batch response, the + * `Status` message should be used directly inside batch response, one for + * each error sub-response. + * + * - Asynchronous operations. If an API call embeds asynchronous operation + * results in its response, the status of those operations should be + * represented directly using the `Status` message. + * + * - Logging. If some API errors are stored in logs, the message `Status` could + * be used directly after any stripping needed for security/privacy reasons. + * + * @generated from message google.rpc.Status + */ +class status_pb_Status extends Message { + constructor(data) { + super(); + /** + * The status code, which should be an enum value of [google.rpc.Code][google.rpc.Code]. + * + * @generated from field: int32 code = 1; + */ + this.code = 0; + /** + * A developer-facing error message, which should be in English. Any + * user-facing error message should be localized and sent in the + * [google.rpc.Status.details][google.rpc.Status.details] field, or localized by the client. + * + * @generated from field: string message = 2; + */ + this.message = ""; + /** + * A list of messages that carry the error details. There will be a + * common set of message types for APIs to use. + * + * @generated from field: repeated google.protobuf.Any details = 3; + */ + this.details = []; + proto3.util.initPartial(data, this); + } + static fromBinary(bytes, options) { + return new status_pb_Status().fromBinary(bytes, options); + } + static fromJson(jsonValue, options) { + return new status_pb_Status().fromJson(jsonValue, options); + } + static fromJsonString(jsonString, options) { + return new status_pb_Status().fromJsonString(jsonString, options); + } + static equals(a, b) { + return proto3.util.equals(status_pb_Status, a, b); + } +} +status_pb_Status.runtime = proto3; +status_pb_Status.typeName = "google.rpc.Status"; +status_pb_Status.fields = proto3.util.newFieldList(() => [ + { no: 1, name: "code", kind: "scalar", T: 5 /* ScalarType.INT32 */ }, + { no: 2, name: "message", kind: "scalar", T: 9 /* ScalarType.STRING */ }, + { no: 3, name: "details", kind: "message", T: any_pb_Any, repeated: true }, +]); + +;// CONCATENATED MODULE: ./node_modules/@connectrpc/connect/dist/esm/http-headers.js +// Copyright 2021-2024 The Connect Authors +// +// Licensed under the Apache License, Version 2.0 (the "License"); +// you may not use this file except in compliance with the License. +// You may obtain a copy of the License at +// +// http://www.apache.org/licenses/LICENSE-2.0 +// +// Unless required by applicable law or agreed to in writing, software +// distributed under the License is distributed on an "AS IS" BASIS, +// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. +// See the License for the specific language governing permissions and +// limitations under the License. + + + +/** + * Encode a single binary header value according to the Connect + * and gRPC specifications. + * + * This function accepts raw binary data from a buffer, a string + * with UTF-8 text, or a protobuf message. It encodes the input + * with unpadded base64 and returns a string that can be used for + * a header whose name ends with `-bin`. + */ +function http_headers_encodeBinaryHeader(value) { + let bytes; + if (typeof value == "object" && "getType" in value) { + bytes = value.toBinary(); + } + else if (typeof value == "string") { + bytes = new TextEncoder().encode(value); + } + else { + bytes = value instanceof Uint8Array ? value : new Uint8Array(value); + } + return protoBase64.enc(bytes).replace(/=+$/, ""); +} +function decodeBinaryHeader(value, type, options) { + try { + const bytes = proto_base64_protoBase64.dec(value); + if (type) { + return type.fromBinary(bytes, options); + } + return bytes; + } + catch (e) { + throw connect_error_ConnectError.from(e, code_Code.DataLoss); + } +} +/** + * Merge two or more Headers objects by appending all fields from + * all inputs to a new Headers object. + */ +function appendHeaders(...headers) { + const h = new Headers(); + for (const e of headers) { + e.forEach((value, key) => { + h.append(key, value); + }); + } + return h; +} + +;// CONCATENATED MODULE: ./node_modules/@connectrpc/connect/dist/esm/protocol-grpc/trailer-status.js +// Copyright 2021-2024 The Connect Authors +// +// Licensed under the Apache License, Version 2.0 (the "License"); +// you may not use this file except in compliance with the License. +// You may obtain a copy of the License at +// +// http://www.apache.org/licenses/LICENSE-2.0 +// +// Unless required by applicable law or agreed to in writing, software +// distributed under the License is distributed on an "AS IS" BASIS, +// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. +// See the License for the specific language governing permissions and +// limitations under the License. + + + + + + +/** + * The value of the Grpc-Status header or trailer in case of success. + * Used by the gRPC and gRPC-web protocols. + * + * @private Internal code, does not follow semantic versioning. + */ +const grpcStatusOk = "0"; +/** + * Sets the fields "grpc-status" and "grpc-message" in the given + * Headers object. + * If an error is given and contains error details, the function + * will also set the field "grpc-status-details-bin" with an encoded + * google.rpc.Status message including the error details. + * + * @private Internal code, does not follow semantic versioning. + */ +function setTrailerStatus(target, error) { + if (error) { + target.set(headerGrpcStatus, error.code.toString(10)); + target.set(headerGrpcMessage, encodeURIComponent(error.rawMessage)); + if (error.details.length > 0) { + const status = new Status({ + code: error.code, + message: error.rawMessage, + details: error.details.map((value) => "getType" in value + ? Any.pack(value) + : new Any({ + typeUrl: `type.googleapis.com/${value.type}`, + value: value.value, + })), + }); + target.set(headerStatusDetailsBin, encodeBinaryHeader(status)); + } + } + else { + target.set(headerGrpcStatus, grpcStatusOk.toString()); + } + return target; +} +/** + * Find an error status in the given Headers object, which can be either + * a trailer, or a header (as allowed for so-called trailers-only responses). + * The field "grpc-status-details-bin" is inspected, and if not present, + * the fields "grpc-status" and "grpc-message" are used. + * Returns an error only if the gRPC status code is > 0. + * + * @private Internal code, does not follow semantic versioning. + */ +function findTrailerError(headerOrTrailer) { + // TODO + // let code: Code; + // let message: string = ""; + var _a; + // Prefer the protobuf-encoded data to the grpc-status header. + const statusBytes = headerOrTrailer.get(headers_headerStatusDetailsBin); + if (statusBytes != null) { + const status = decodeBinaryHeader(statusBytes, status_pb_Status); + if (status.code == 0) { + return undefined; + } + const error = new connect_error_ConnectError(status.message, status.code, headerOrTrailer); + error.details = status.details.map((any) => ({ + type: any.typeUrl.substring(any.typeUrl.lastIndexOf("/") + 1), + value: any.value, + })); + return error; + } + const grpcStatus = headerOrTrailer.get(headers_headerGrpcStatus); + if (grpcStatus != null) { + if (grpcStatus === grpcStatusOk) { + return undefined; + } + const code = parseInt(grpcStatus, 10); + if (code in code_Code) { + return new connect_error_ConnectError(decodeURIComponent((_a = headerOrTrailer.get(headers_headerGrpcMessage)) !== null && _a !== void 0 ? _a : ""), code, headerOrTrailer); + } + return new connect_error_ConnectError(`invalid grpc-status: ${grpcStatus}`, code_Code.Internal, headerOrTrailer); + } + return undefined; +} + +;// CONCATENATED MODULE: ./node_modules/@connectrpc/connect/dist/esm/protocol-grpc/validate-response.js +// Copyright 2021-2024 The Connect Authors +// +// Licensed under the Apache License, Version 2.0 (the "License"); +// you may not use this file except in compliance with the License. +// You may obtain a copy of the License at +// +// http://www.apache.org/licenses/LICENSE-2.0 +// +// Unless required by applicable law or agreed to in writing, software +// distributed under the License is distributed on an "AS IS" BASIS, +// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. +// See the License for the specific language governing permissions and +// limitations under the License. + + + + + + +/** + * Validates response status and header for the gRPC protocol. + * Throws a ConnectError if the header contains an error status, + * or if the HTTP status indicates an error. + * + * Returns an object that indicates whether a gRPC status was found + * in the response header. In this case, clients can not expect a + * trailer. + * + * @private Internal code, does not follow semantic versioning. + */ +function validateResponse(status, headers) { + if (status != 200) { + throw new connect_error_ConnectError(`HTTP ${status}`, codeFromHttpStatus(status), headers); + } + const mimeType = headers.get(headerContentType); + const parsedType = parseContentType(mimeType); + if (parsedType == undefined) { + throw new connect_error_ConnectError(`unsupported content type ${mimeType}`, code_Code.Unknown); + } + return { + foundStatus: headers.has(headers_headerGrpcStatus), + headerError: findTrailerError(headers), + }; +} +/** + * Validates response status and header for the gRPC protocol. + * This function is identical to validateResponse(), but also verifies + * that a given encoding header is acceptable. + * + * Returns an object with the response compression, and a boolean + * indicating whether a gRPC status was found in the response header + * (in this case, clients can not expect a trailer). + * + * @private Internal code, does not follow semantic versioning. + */ +function validateResponseWithCompression(acceptCompression, status, headers) { + const { foundStatus, headerError } = validateResponse(status, headers); + let compression; + const encoding = headers.get(headerEncoding); + if (encoding !== null && encoding.toLowerCase() !== "identity") { + compression = acceptCompression.find((c) => c.name === encoding); + if (!compression) { + throw new connect_error_ConnectError(`unsupported response encoding "${encoding}"`, code_Code.Internal, headers); + } + } + return { + foundStatus, + compression, + headerError, + }; +} + +;// CONCATENATED MODULE: ./node_modules/@connectrpc/connect/dist/esm/protocol-grpc/validate-trailer.js +// Copyright 2021-2024 The Connect Authors +// +// Licensed under the Apache License, Version 2.0 (the "License"); +// you may not use this file except in compliance with the License. +// You may obtain a copy of the License at +// +// http://www.apache.org/licenses/LICENSE-2.0 +// +// Unless required by applicable law or agreed to in writing, software +// distributed under the License is distributed on an "AS IS" BASIS, +// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. +// See the License for the specific language governing permissions and +// limitations under the License. + + + + +/** + * Validates a trailer for the gRPC and the gRPC-web protocol. + * + * If the trailer contains an error status, a ConnectError is + * thrown. It will include trailer and header in the error's + * "metadata" property. + * + * Throws a ConnectError with code "internal" if neither the trailer + * nor the header contain the Grpc-Status field. + * + * @private Internal code, does not follow semantic versioning. + */ +function validateTrailer(trailer, header) { + const err = findTrailerError(trailer); + if (err) { + header.forEach((value, key) => { + err.metadata.append(key, value); + }); + throw err; + } + if (!header.has(headers_headerGrpcStatus) && !trailer.has(headers_headerGrpcStatus)) { + throw new connect_error_ConnectError("protocol error: missing status", code_Code.Internal); + } +} + +;// CONCATENATED MODULE: ./node_modules/@connectrpc/connect/dist/esm/protocol/create-method-url.js +// Copyright 2021-2024 The Connect Authors +// +// Licensed under the Apache License, Version 2.0 (the "License"); +// you may not use this file except in compliance with the License. +// You may obtain a copy of the License at +// +// http://www.apache.org/licenses/LICENSE-2.0 +// +// Unless required by applicable law or agreed to in writing, software +// distributed under the License is distributed on an "AS IS" BASIS, +// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. +// See the License for the specific language governing permissions and +// limitations under the License. +/** + * Create a URL for the given RPC. This simply adds the qualified + * service name, a slash, and the method name to the path of the given + * baseUrl. + * + * For example, the baseUri https://example.com and method "Say" from + * the service example.ElizaService results in: + * https://example.com/example.ElizaService/Say + * + * This format is used by the protocols Connect, gRPC and Twirp. + * + * Note that this function also accepts a protocol-relative baseUrl. + * If given an empty string or "/" as a baseUrl, it returns just the + * path. + */ +function createMethodUrl(baseUrl, service, method) { + const s = typeof service == "string" ? service : service.typeName; + const m = typeof method == "string" ? method : method.name; + return baseUrl.toString().replace(/\/?$/, `/${s}/${m}`); +} + +;// CONCATENATED MODULE: ./node_modules/@connectrpc/connect/dist/esm/interceptor.js +// Copyright 2021-2024 The Connect Authors +// +// Licensed under the Apache License, Version 2.0 (the "License"); +// you may not use this file except in compliance with the License. +// You may obtain a copy of the License at +// +// http://www.apache.org/licenses/LICENSE-2.0 +// +// Unless required by applicable law or agreed to in writing, software +// distributed under the License is distributed on an "AS IS" BASIS, +// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. +// See the License for the specific language governing permissions and +// limitations under the License. +/** + * applyInterceptors takes the given UnaryFn or ServerStreamingFn, and wraps + * it with each of the given interceptors, returning a new UnaryFn or + * ServerStreamingFn. + */ +function applyInterceptors(next, interceptors) { + var _a; + return ((_a = interceptors === null || interceptors === void 0 ? void 0 : interceptors.concat().reverse().reduce( + // eslint-disable-next-line @typescript-eslint/no-unsafe-argument + (n, i) => i(n), next)) !== null && _a !== void 0 ? _a : next); +} + +;// CONCATENATED MODULE: ./node_modules/@connectrpc/connect/dist/esm/protocol/normalize.js +// Copyright 2021-2024 The Connect Authors +// +// Licensed under the Apache License, Version 2.0 (the "License"); +// you may not use this file except in compliance with the License. +// You may obtain a copy of the License at +// +// http://www.apache.org/licenses/LICENSE-2.0 +// +// Unless required by applicable law or agreed to in writing, software +// distributed under the License is distributed on an "AS IS" BASIS, +// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. +// See the License for the specific language governing permissions and +// limitations under the License. + +/** + * Takes a partial protobuf messages of the + * specified message type as input, and returns full instances. + */ +function normalize(type, message) { + return message instanceof type + ? message + : new type(message); +} +/** + * Takes an AsyncIterable of partial protobuf messages of the + * specified message type as input, and yields full instances. + */ +function normalizeIterable(messageType, input) { + function transform(result) { + if (result.done === true) { + return result; + } + return { + done: result.done, + value: normalize(messageType, result.value), + }; + } + return { + [Symbol.asyncIterator]() { + const it = input[Symbol.asyncIterator](); + const res = { + next: () => it.next().then(transform), + }; + if (it.throw !== undefined) { + res.throw = (e) => it.throw(e).then(transform); // eslint-disable-line @typescript-eslint/no-non-null-assertion + } + if (it.return !== undefined) { + res.return = (v) => it.return(v).then(transform); // eslint-disable-line @typescript-eslint/no-non-null-assertion + } + return res; + }, + }; +} + +;// CONCATENATED MODULE: ./node_modules/@connectrpc/connect/dist/esm/protocol/run-call.js +// Copyright 2021-2024 The Connect Authors +// +// Licensed under the Apache License, Version 2.0 (the "License"); +// you may not use this file except in compliance with the License. +// You may obtain a copy of the License at +// +// http://www.apache.org/licenses/LICENSE-2.0 +// +// Unless required by applicable law or agreed to in writing, software +// distributed under the License is distributed on an "AS IS" BASIS, +// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. +// See the License for the specific language governing permissions and +// limitations under the License. + + + + +/** + * Runs a unary method with the given interceptors. Note that this function + * is only used when implementing a Transport. + */ +function runUnaryCall(opt) { + const next = applyInterceptors(opt.next, opt.interceptors); + const [signal, abort, done] = setupSignal(opt); + const req = Object.assign(Object.assign({}, opt.req), { message: normalize(opt.req.method.I, opt.req.message), signal }); + return next(req).then((res) => { + done(); + return res; + }, abort); +} +/** + * Runs a server-streaming method with the given interceptors. Note that this + * function is only used when implementing a Transport. + */ +function runStreamingCall(opt) { + const next = applyInterceptors(opt.next, opt.interceptors); + const [signal, abort, done] = setupSignal(opt); + const req = Object.assign(Object.assign({}, opt.req), { message: normalizeIterable(opt.req.method.I, opt.req.message), signal }); + let doneCalled = false; + // Call return on the request iterable to indicate + // that we will no longer consume it and it should + // cleanup any allocated resources. + signal.addEventListener("abort", function () { + var _a, _b; + const it = opt.req.message[Symbol.asyncIterator](); + // If the signal is aborted due to an error, we want to throw + // the error to the request iterator. + if (!doneCalled) { + (_a = it.throw) === null || _a === void 0 ? void 0 : _a.call(it, this.reason).catch(() => { + // throw returns a promise, which we don't care about. + // + // Uncaught promises are thrown at sometime/somewhere by the event loop, + // this is to ensure error is caught and ignored. + }); + } + (_b = it.return) === null || _b === void 0 ? void 0 : _b.call(it).catch(() => { + // return returns a promise, which we don't care about. + // + // Uncaught promises are thrown at sometime/somewhere by the event loop, + // this is to ensure error is caught and ignored. + }); + }); + return next(req).then((res) => { + return Object.assign(Object.assign({}, res), { message: { + [Symbol.asyncIterator]() { + const it = res.message[Symbol.asyncIterator](); + return { + next() { + return it.next().then((r) => { + if (r.done == true) { + doneCalled = true; + done(); + } + return r; + }, abort); + }, + // We deliberately omit throw/return. + }; + }, + } }); + }, abort); +} +/** + * Create an AbortSignal for Transport implementations. The signal is available + * in UnaryRequest and StreamingRequest, and is triggered when the call is + * aborted (via a timeout or explicit cancellation), errored (e.g. when reading + * an error from the server from the wire), or finished successfully. + * + * Transport implementations can pass the signal to HTTP clients to ensure that + * there are no unused connections leak. + * + * Returns a tuple: + * [0]: The signal, which is also aborted if the optional deadline is reached. + * [1]: Function to call if the Transport encountered an error. + * [2]: Function to call if the Transport finished without an error. + */ +function setupSignal(opt) { + const { signal, cleanup } = createDeadlineSignal(opt.timeoutMs); + const controller = createLinkedAbortController(opt.signal, signal); + return [ + controller.signal, + function abort(reason) { + // We peek at the deadline signal because fetch() will throw an error on + // abort that discards the signal reason. + const e = connect_error_ConnectError.from(signal.aborted ? getAbortSignalReason(signal) : reason); + controller.abort(e); + cleanup(); + return Promise.reject(e); + }, + function done() { + cleanup(); + controller.abort(); + }, + ]; +} + +;// CONCATENATED MODULE: ./node_modules/@connectrpc/connect/dist/esm/protocol/serialization.js +// Copyright 2021-2024 The Connect Authors +// +// Licensed under the Apache License, Version 2.0 (the "License"); +// you may not use this file except in compliance with the License. +// You may obtain a copy of the License at +// +// http://www.apache.org/licenses/LICENSE-2.0 +// +// Unless required by applicable law or agreed to in writing, software +// distributed under the License is distributed on an "AS IS" BASIS, +// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. +// See the License for the specific language governing permissions and +// limitations under the License. + + + +/** + * Sets default JSON serialization options for connect-es. + * + * With standard protobuf JSON serialization, unknown JSON fields are + * rejected by default. In connect-es, unknown JSON fields are ignored + * by default. + */ +function getJsonOptions(options) { + var _a; + const o = Object.assign({}, options); + (_a = o.ignoreUnknownFields) !== null && _a !== void 0 ? _a : (o.ignoreUnknownFields = true); + return o; +} +/** + * Create an object that provides convenient access to request and response + * message serialization for a given method. + * + * @private Internal code, does not follow semantic versioning. + */ +function createMethodSerializationLookup(method, binaryOptions, jsonOptions, limitOptions) { + const inputBinary = limitSerialization(createBinarySerialization(method.I, binaryOptions), limitOptions); + const inputJson = limitSerialization(createJsonSerialization(method.I, jsonOptions), limitOptions); + const outputBinary = limitSerialization(createBinarySerialization(method.O, binaryOptions), limitOptions); + const outputJson = limitSerialization(createJsonSerialization(method.O, jsonOptions), limitOptions); + return { + getI(useBinaryFormat) { + return useBinaryFormat ? inputBinary : inputJson; + }, + getO(useBinaryFormat) { + return useBinaryFormat ? outputBinary : outputJson; + }, + }; +} +/** + * Returns functions to normalize and serialize the input message + * of an RPC, and to parse the output message of an RPC. + * + * @private Internal code, does not follow semantic versioning. + */ +function createClientMethodSerializers(method, useBinaryFormat, jsonOptions, binaryOptions) { + const input = useBinaryFormat + ? createBinarySerialization(method.I, binaryOptions) + : createJsonSerialization(method.I, jsonOptions); + const output = useBinaryFormat + ? createBinarySerialization(method.O, binaryOptions) + : createJsonSerialization(method.O, jsonOptions); + return { parse: output.parse, serialize: input.serialize }; +} +/** + * Apply I/O limits to a Serialization object, returning a new object. + * + * @private Internal code, does not follow semantic versioning. + */ +function limitSerialization(serialization, limitOptions) { + return { + serialize(data) { + const bytes = serialization.serialize(data); + assertWriteMaxBytes(limitOptions.writeMaxBytes, bytes.byteLength); + return bytes; + }, + parse(data) { + limit_io_assertReadMaxBytes(limitOptions.readMaxBytes, data.byteLength, true); + return serialization.parse(data); + }, + }; +} +/** + * Creates a Serialization object for serializing the given protobuf message + * with the protobuf binary format. + */ +function createBinarySerialization(messageType, options) { + return { + parse(data) { + try { + return messageType.fromBinary(data, options); + } + catch (e) { + const m = e instanceof Error ? e.message : String(e); + throw new connect_error_ConnectError(`parse binary: ${m}`, code_Code.Internal); + } + }, + serialize(data) { + try { + return data.toBinary(options); + } + catch (e) { + const m = e instanceof Error ? e.message : String(e); + throw new connect_error_ConnectError(`serialize binary: ${m}`, code_Code.Internal); + } + }, + }; +} +/** + * Creates a Serialization object for serializing the given protobuf message + * with the protobuf canonical JSON encoding. + * + * By default, unknown fields are ignored. + */ +function createJsonSerialization(messageType, options) { + var _a, _b; + const textEncoder = (_a = options === null || options === void 0 ? void 0 : options.textEncoder) !== null && _a !== void 0 ? _a : new TextEncoder(); + const textDecoder = (_b = options === null || options === void 0 ? void 0 : options.textDecoder) !== null && _b !== void 0 ? _b : new TextDecoder(); + const o = getJsonOptions(options); + return { + parse(data) { + try { + const json = textDecoder.decode(data); + return messageType.fromJsonString(json, o); + } + catch (e) { + throw connect_error_ConnectError.from(e, code_Code.InvalidArgument); + } + }, + serialize(data) { + try { + const json = data.toJsonString(o); + return textEncoder.encode(json); + } + catch (e) { + throw connect_error_ConnectError.from(e, code_Code.Internal); + } + }, + }; +} + +;// CONCATENATED MODULE: ./node_modules/@connectrpc/connect/dist/esm/context-values.js +// Copyright 2021-2024 The Connect Authors +// +// Licensed under the Apache License, Version 2.0 (the "License"); +// you may not use this file except in compliance with the License. +// You may obtain a copy of the License at +// +// http://www.apache.org/licenses/LICENSE-2.0 +// +// Unless required by applicable law or agreed to in writing, software +// distributed under the License is distributed on an "AS IS" BASIS, +// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. +// See the License for the specific language governing permissions and +// limitations under the License. +/** + * createContextValues creates a new ContextValues. + */ +function createContextValues() { + return { + get(key) { + return key.id in this ? this[key.id] : key.defaultValue; + }, + set(key, value) { + this[key.id] = value; + return this; + }, + delete(key) { + delete this[key.id]; + return this; + }, + }; +} +/** + * createContextKey creates a new ContextKey. + */ +function createContextKey(defaultValue, options) { + return { id: Symbol(options === null || options === void 0 ? void 0 : options.description), defaultValue }; +} + +;// CONCATENATED MODULE: ./node_modules/@connectrpc/connect/dist/esm/protocol-grpc/transport.js +// Copyright 2021-2024 The Connect Authors +// +// Licensed under the Apache License, Version 2.0 (the "License"); +// you may not use this file except in compliance with the License. +// You may obtain a copy of the License at +// +// http://www.apache.org/licenses/LICENSE-2.0 +// +// Unless required by applicable law or agreed to in writing, software +// distributed under the License is distributed on an "AS IS" BASIS, +// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. +// See the License for the specific language governing permissions and +// limitations under the License. +var transport_asyncValues = (undefined && undefined.__asyncValues) || function (o) { + if (!Symbol.asyncIterator) throw new TypeError("Symbol.asyncIterator is not defined."); + var m = o[Symbol.asyncIterator], i; + return m ? m.call(o) : (o = typeof __values === "function" ? __values(o) : o[Symbol.iterator](), i = {}, verb("next"), verb("throw"), verb("return"), i[Symbol.asyncIterator] = function () { return this; }, i); + function verb(n) { i[n] = o[n] && function (v) { return new Promise(function (resolve, reject) { v = o[n](v), settle(resolve, reject, v.done, v.value); }); }; } + function settle(resolve, reject, d, v) { Promise.resolve(v).then(function(v) { resolve({ value: v, done: d }); }, reject); } +}; +var transport_await = (undefined && undefined.__await) || function (v) { return this instanceof transport_await ? (this.v = v, this) : new transport_await(v); } +var transport_asyncDelegator = (undefined && undefined.__asyncDelegator) || function (o) { + var i, p; + return i = {}, verb("next"), verb("throw", function (e) { throw e; }), verb("return"), i[Symbol.iterator] = function () { return this; }, i; + function verb(n, f) { i[n] = o[n] ? function (v) { return (p = !p) ? { value: transport_await(o[n](v)), done: false } : f ? f(v) : v; } : f; } +}; +var transport_asyncGenerator = (undefined && undefined.__asyncGenerator) || function (thisArg, _arguments, generator) { + if (!Symbol.asyncIterator) throw new TypeError("Symbol.asyncIterator is not defined."); + var g = generator.apply(thisArg, _arguments || []), i, q = []; + return i = {}, verb("next"), verb("throw"), verb("return", awaitReturn), i[Symbol.asyncIterator] = function () { return this; }, i; + function awaitReturn(f) { return function (v) { return Promise.resolve(v).then(f, reject); }; } + function verb(n, f) { if (g[n]) { i[n] = function (v) { return new Promise(function (a, b) { q.push([n, v, a, b]) > 1 || resume(n, v); }); }; if (f) i[n] = f(i[n]); } } + function resume(n, v) { try { step(g[n](v)); } catch (e) { settle(q[0][3], e); } } + function step(r) { r.value instanceof transport_await ? Promise.resolve(r.value.v).then(fulfill, reject) : settle(q[0][2], r); } + function fulfill(value) { resume("next", value); } + function reject(value) { resume("throw", value); } + function settle(f, v) { if (f(v), q.shift(), q.length) resume(q[0][0], q[0][1]); } +}; + + + + + + + + + + + +/** + * Create a Transport for the gRPC protocol. + */ +function transport_createTransport(opt) { + return { + async unary(service, method, signal, timeoutMs, header, message, contextValues) { + const serialization = createMethodSerializationLookup(method, opt.binaryOptions, opt.jsonOptions, opt); + timeoutMs = + timeoutMs === undefined + ? opt.defaultTimeoutMs + : timeoutMs <= 0 + ? undefined + : timeoutMs; + return await runUnaryCall({ + interceptors: opt.interceptors, + signal, + timeoutMs, + req: { + stream: false, + service, + method, + url: createMethodUrl(opt.baseUrl, service, method), + init: {}, + header: requestHeaderWithCompression(opt.useBinaryFormat, timeoutMs, header, opt.acceptCompression, opt.sendCompression), + contextValues: contextValues !== null && contextValues !== void 0 ? contextValues : createContextValues(), + message, + }, + next: async (req) => { + const uRes = await opt.httpClient({ + url: req.url, + method: "POST", + header: req.header, + signal: req.signal, + body: pipe(createAsyncIterable([req.message]), transformSerializeEnvelope(serialization.getI(opt.useBinaryFormat)), transformCompressEnvelope(opt.sendCompression, opt.compressMinBytes), transformJoinEnvelopes(), { + propagateDownStreamError: true, + }), + }); + const { compression, headerError } = validateResponseWithCompression(opt.acceptCompression, uRes.status, uRes.header); + const message = await pipeTo(uRes.body, transformSplitEnvelope(opt.readMaxBytes), transformDecompressEnvelope(compression !== null && compression !== void 0 ? compression : null, opt.readMaxBytes), transformParseEnvelope(serialization.getO(opt.useBinaryFormat)), async (iterable) => { + var _a, e_1, _b, _c; + let message; + try { + for (var _d = true, iterable_1 = transport_asyncValues(iterable), iterable_1_1; iterable_1_1 = await iterable_1.next(), _a = iterable_1_1.done, !_a; _d = true) { + _c = iterable_1_1.value; + _d = false; + const chunk = _c; + if (message !== undefined) { + throw new connect_error_ConnectError("protocol error: received extra output message for unary method", code_Code.Unimplemented); + } + message = chunk; + } + } + catch (e_1_1) { e_1 = { error: e_1_1 }; } + finally { + try { + if (!_d && !_a && (_b = iterable_1.return)) await _b.call(iterable_1); + } + finally { if (e_1) throw e_1.error; } + } + return message; + }, { propagateDownStreamError: false }); + validateTrailer(uRes.trailer, uRes.header); + if (message === undefined) { + // Trailers only response + if (headerError) { + throw headerError; + } + throw new connect_error_ConnectError("protocol error: missing output message for unary method", uRes.trailer.has(headers_headerGrpcStatus) + ? code_Code.Unimplemented + : code_Code.Unknown); + } + if (headerError) { + throw new connect_error_ConnectError("protocol error: received output message for unary method with error status", code_Code.Unknown); + } + return { + stream: false, + service, + method, + header: uRes.header, + message, + trailer: uRes.trailer, + }; + }, + }); + }, + async stream(service, method, signal, timeoutMs, header, input, contextValues) { + const serialization = createMethodSerializationLookup(method, opt.binaryOptions, opt.jsonOptions, opt); + timeoutMs = + timeoutMs === undefined + ? opt.defaultTimeoutMs + : timeoutMs <= 0 + ? undefined + : timeoutMs; + return runStreamingCall({ + interceptors: opt.interceptors, + signal, + timeoutMs, + req: { + stream: true, + service, + method, + url: createMethodUrl(opt.baseUrl, service, method), + init: {}, + header: requestHeaderWithCompression(opt.useBinaryFormat, timeoutMs, header, opt.acceptCompression, opt.sendCompression), + contextValues: contextValues !== null && contextValues !== void 0 ? contextValues : createContextValues(), + message: input, + }, + next: async (req) => { + const uRes = await opt.httpClient({ + url: req.url, + method: "POST", + header: req.header, + signal: req.signal, + body: pipe(req.message, transformSerializeEnvelope(serialization.getI(opt.useBinaryFormat)), transformCompressEnvelope(opt.sendCompression, opt.compressMinBytes), transformJoinEnvelopes(), { propagateDownStreamError: true }), + }); + const { compression, foundStatus, headerError } = validateResponseWithCompression(opt.acceptCompression, uRes.status, uRes.header); + if (headerError) { + throw headerError; + } + const res = Object.assign(Object.assign({}, req), { header: uRes.header, trailer: uRes.trailer, message: pipe(uRes.body, transformSplitEnvelope(opt.readMaxBytes), transformDecompressEnvelope(compression !== null && compression !== void 0 ? compression : null, opt.readMaxBytes), transformParseEnvelope(serialization.getO(opt.useBinaryFormat)), function (iterable) { + return transport_asyncGenerator(this, arguments, function* () { + yield transport_await(yield* transport_asyncDelegator(transport_asyncValues(iterable))); + if (!foundStatus) { + validateTrailer(uRes.trailer, uRes.header); + } + }); + }, { propagateDownStreamError: true }) }); + return res; + }, + }); + }, + }; +} + +;// CONCATENATED MODULE: ./node_modules/@connectrpc/connect-node/dist/esm/grpc-transport.js +// Copyright 2021-2024 The Connect Authors +// +// Licensed under the Apache License, Version 2.0 (the "License"); +// you may not use this file except in compliance with the License. +// You may obtain a copy of the License at +// +// http://www.apache.org/licenses/LICENSE-2.0 +// +// Unless required by applicable law or agreed to in writing, software +// distributed under the License is distributed on an "AS IS" BASIS, +// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. +// See the License for the specific language governing permissions and +// limitations under the License. + + +/** + * Create a Transport for the gRPC protocol using the Node.js `http`, `http2`, + * or `http2` module. + */ +function createGrpcTransport(options) { + return transport_createTransport(node_transport_options_validateNodeTransportOptions(options)); +} + +;// CONCATENATED MODULE: ./node_modules/@connectrpc/connect-node/dist/esm/connect-transport.js +// Copyright 2021-2024 The Connect Authors +// +// Licensed under the Apache License, Version 2.0 (the "License"); +// you may not use this file except in compliance with the License. +// You may obtain a copy of the License at +// +// http://www.apache.org/licenses/LICENSE-2.0 +// +// Unless required by applicable law or agreed to in writing, software +// distributed under the License is distributed on an "AS IS" BASIS, +// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. +// See the License for the specific language governing permissions and +// limitations under the License. + + +/** + * Create a Transport for the Connect protocol using the Node.js `http`, `http2`, + * or `http2` module. + */ +function createConnectTransport(options) { + return createTransport(validateNodeTransportOptions(options)); +} + +;// CONCATENATED MODULE: ./node_modules/@connectrpc/connect-node/dist/esm/node-universal-handler.js +// Copyright 2021-2024 The Connect Authors +// +// Licensed under the Apache License, Version 2.0 (the "License"); +// you may not use this file except in compliance with the License. +// You may obtain a copy of the License at +// +// http://www.apache.org/licenses/LICENSE-2.0 +// +// Unless required by applicable law or agreed to in writing, software +// distributed under the License is distributed on an "AS IS" BASIS, +// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. +// See the License for the specific language governing permissions and +// limitations under the License. +var node_universal_handler_asyncValues = (undefined && undefined.__asyncValues) || function (o) { + if (!Symbol.asyncIterator) throw new TypeError("Symbol.asyncIterator is not defined."); + var m = o[Symbol.asyncIterator], i; + return m ? m.call(o) : (o = typeof __values === "function" ? __values(o) : o[Symbol.iterator](), i = {}, verb("next"), verb("throw"), verb("return"), i[Symbol.asyncIterator] = function () { return this; }, i); + function verb(n) { i[n] = o[n] && function (v) { return new Promise(function (resolve, reject) { v = o[n](v), settle(resolve, reject, v.done, v.value); }); }; } + function settle(resolve, reject, d, v) { Promise.resolve(v).then(function(v) { resolve({ value: v, done: d }); }, reject); } +}; +var node_universal_handler_await = (undefined && undefined.__await) || function (v) { return this instanceof node_universal_handler_await ? (this.v = v, this) : new node_universal_handler_await(v); } +var node_universal_handler_asyncGenerator = (undefined && undefined.__asyncGenerator) || function (thisArg, _arguments, generator) { + if (!Symbol.asyncIterator) throw new TypeError("Symbol.asyncIterator is not defined."); + var g = generator.apply(thisArg, _arguments || []), i, q = []; + return i = {}, verb("next"), verb("throw"), verb("return", awaitReturn), i[Symbol.asyncIterator] = function () { return this; }, i; + function awaitReturn(f) { return function (v) { return Promise.resolve(v).then(f, reject); }; } + function verb(n, f) { if (g[n]) { i[n] = function (v) { return new Promise(function (a, b) { q.push([n, v, a, b]) > 1 || resume(n, v); }); }; if (f) i[n] = f(i[n]); } } + function resume(n, v) { try { step(g[n](v)); } catch (e) { settle(q[0][3], e); } } + function step(r) { r.value instanceof node_universal_handler_await ? Promise.resolve(r.value.v).then(fulfill, reject) : settle(q[0][2], r); } + function fulfill(value) { resume("next", value); } + function reject(value) { resume("throw", value); } + function settle(f, v) { if (f(v), q.shift(), q.length) resume(q[0][0], q[0][1]); } +}; + + + +function node_universal_handler_universalRequestFromNodeRequest(nodeRequest, ...rest) { + var _a, _b; + const nodeResponse = rest.length === 3 ? rest[0] : undefined; + const parsedJsonBody = rest.length === 3 ? rest[1] : rest[0]; + const contextValues = rest.length === 3 ? rest[2] : rest[1]; + const encrypted = "encrypted" in nodeRequest.socket && nodeRequest.socket.encrypted; + const protocol = encrypted ? "https" : "http"; + const authority = "authority" in nodeRequest + ? nodeRequest.authority + : nodeRequest.headers.host; + const pathname = (_a = nodeRequest.url) !== null && _a !== void 0 ? _a : ""; + if (authority === undefined) { + throw new ConnectError("unable to determine request authority from Node.js server request", Code.Internal); + } + const body = parsedJsonBody !== undefined + ? parsedJsonBody + : asyncIterableFromNodeServerRequest(nodeRequest); + const abortController = new AbortController(); + if ("stream" in nodeRequest) { + // HTTP/2 has error codes we want to honor + nodeRequest.once("close", () => { + const err = connectErrorFromH2ResetCode(nodeRequest.stream.rstCode); + if (err !== undefined) { + abortController.abort(err); + } + else { + abortController.abort(); + } + }); + } + else { + // HTTP/1.1 does not have error codes, but Node.js has ECONNRESET + const nodeResponsOrRequest = nodeResponse !== null && nodeResponse !== void 0 ? nodeResponse : nodeRequest; + const onH1Error = (e) => { + nodeRequest.off("error", onH1Error); + nodeResponsOrRequest.off("close", onH1Close); + abortController.abort(connectErrorFromNodeReason(e)); + }; + const onH1Close = () => { + nodeRequest.off("error", onH1Error); + nodeResponsOrRequest.off("close", onH1Close); + // When subscribed to the response, this can get called before "error" + abortController.abort(nodeRequest.errored + ? connectErrorFromNodeReason(nodeRequest.errored) + : undefined); + }; + nodeRequest.once("error", onH1Error); + // Node emits close on the request as soon as all data is read. + // We instead subscribe to the response (if available) + // + // Ref: https://github.com/nodejs/node/issues/40775 + nodeResponsOrRequest.once("close", onH1Close); + } + return { + httpVersion: nodeRequest.httpVersion, + method: (_b = nodeRequest.method) !== null && _b !== void 0 ? _b : "", + url: new URL(pathname, `${protocol}://${authority}`).toString(), + header: nodeHeaderToWebHeader(nodeRequest.headers), + body, + signal: abortController.signal, + contextValues: contextValues, + }; +} +/** + * Writes a UniversalServerResponse to a Node.js server response. + * This function helps to implement adapters to server frameworks running + * on Node.js. Please be careful using this function in your own code, as we + * may have to make changes to it in the future. + */ +async function node_universal_handler_universalResponseToNodeResponse(universalResponse, nodeResponse) { + var _a, _b, _c; + const it = (_a = universalResponse.body) === null || _a === void 0 ? void 0 : _a[Symbol.asyncIterator](); + let isWriteError = false; + try { + if (it !== undefined) { + let chunk = await it.next(); + isWriteError = true; + // we deliberately send headers after first read, not before, + // because we have to give the implementation a chance to + // set response headers + nodeResponse.writeHead(universalResponse.status, webHeaderToNodeHeaders(universalResponse.header)); + isWriteError = false; + for (; chunk.done !== true; chunk = await it.next()) { + isWriteError = true; + await write(nodeResponse, chunk.value); + if ("flush" in nodeResponse && + typeof nodeResponse.flush == "function") { + // The npm package "compression" is an express middleware that is widely used, + // for example in next.js. It uses the npm package "compressible" to determine + // whether to apply compression to a response. Unfortunately, "compressible" + // matches every mime type that ends with "+json", causing our server-streaming + // RPCs to be buffered. + // The package modifies the response object, and adds a flush() method, which + // flushes the underlying gzip or deflate stream from the Node.js zlib module. + // The method is added here: + // https://github.com/expressjs/compression/blob/ad5113b98cafe1382a0ece30bb4673707ac59ce7/index.js#L70 + nodeResponse.flush(); + } + isWriteError = false; + } + } + if (!nodeResponse.headersSent) { + nodeResponse.writeHead(universalResponse.status, webHeaderToNodeHeaders(universalResponse.header)); + } + if (universalResponse.trailer) { + nodeResponse.addTrailers(webHeaderToNodeHeaders(universalResponse.trailer)); + } + await new Promise((resolve) => { + // The npm package "compression" crashes when a callback is passed to end() + // https://github.com/expressjs/compression/blob/ad5113b98cafe1382a0ece30bb4673707ac59ce7/index.js#L115 + nodeResponse.once("end", resolve); + nodeResponse.end(); + }); + } + catch (e) { + // Report write errors to the handler. + if (isWriteError) { + (_b = it === null || it === void 0 ? void 0 : it.throw) === null || _b === void 0 ? void 0 : _b.call(it, e).catch(() => { }); + } + throw connectErrorFromNodeReason(e); + } + finally { + (_c = it === null || it === void 0 ? void 0 : it.return) === null || _c === void 0 ? void 0 : _c.call(it).catch(() => { }); + } +} +function asyncIterableFromNodeServerRequest(request) { + return node_universal_handler_asyncGenerator(this, arguments, function* asyncIterableFromNodeServerRequest_1() { + var _a, e_1, _b, _c; + const it = request.iterator({ + // Node.js v16 closes request and response when this option isn't disabled. + // When one of our handlers receives invalid data (such as an unexpected + // compression flag in a streaming request), we're unable to write the error + // response. + // Later major versions have a more sensible behavior - we can revert this + // workaround once we stop supporting v16. + destroyOnReturn: false, + }); + try { + for (var _d = true, it_1 = node_universal_handler_asyncValues(it), it_1_1; it_1_1 = yield node_universal_handler_await(it_1.next()), _a = it_1_1.done, !_a; _d = true) { + _c = it_1_1.value; + _d = false; + const chunk = _c; + yield yield node_universal_handler_await(chunk); + } + } + catch (e_1_1) { e_1 = { error: e_1_1 }; } + finally { + try { + if (!_d && !_a && (_b = it_1.return)) yield node_universal_handler_await(_b.call(it_1)); + } + finally { if (e_1) throw e_1.error; } + } + }); +} +function write(stream, data) { + return new Promise((resolve, reject) => { + if (stream.errored) { + return error(stream.errored); + } + stream.once("error", error); + stream.once("drain", drain); + // flushed == false: the stream wishes for the calling code to wait for + // the 'drain' event to be emitted before continuing to write additional + // data. + const flushed = stream.write(data, "binary", function (err) { + if (err && !flushed) { + // We are never getting a "drain" nor an "error" event if the stream + // has already ended (ERR_STREAM_WRITE_AFTER_END), so we have to + // resolve our promise in this callback. + error(err); + // However, once we do that (and remove our event listeners), we _do_ + // get an "error" event, which ends up as an uncaught exception. + // We silence this error specifically with the following listener. + // All of this seems very fragile. + stream.once("error", () => { + // + }); + } + }); + if (flushed) { + drain(); + } + function error(err) { + stream.off("error", error); + stream.off("drain", drain); + reject(err); + } + function drain() { + stream.off("error", error); + stream.off("drain", drain); + resolve(); + } + }); +} + +;// CONCATENATED MODULE: ./node_modules/@connectrpc/connect-node/dist/esm/connect-node-adapter.js +// Copyright 2021-2024 The Connect Authors +// +// Licensed under the Apache License, Version 2.0 (the "License"); +// you may not use this file except in compliance with the License. +// You may obtain a copy of the License at +// +// http://www.apache.org/licenses/LICENSE-2.0 +// +// Unless required by applicable law or agreed to in writing, software +// distributed under the License is distributed on an "AS IS" BASIS, +// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. +// See the License for the specific language governing permissions and +// limitations under the License. + + + + +/** + * Create a Node.js request handler from a ConnectRouter. + * + * The returned function is compatible with http.RequestListener and its equivalent for http2. + */ +function connectNodeAdapter(options) { + var _a; + if (options.acceptCompression === undefined) { + options.acceptCompression = [compressionGzip, compressionBrotli]; + } + const router = createConnectRouter(options); + options.routes(router); + const prefix = (_a = options.requestPathPrefix) !== null && _a !== void 0 ? _a : ""; + const paths = new Map(); + for (const uHandler of router.handlers) { + paths.set(prefix + uHandler.requestPath, uHandler); + } + return function nodeRequestHandler(req, res) { + var _a, _b, _c, _d; + // Strip the query parameter when matching paths. + const uHandler = paths.get((_b = (_a = req.url) === null || _a === void 0 ? void 0 : _a.split("?", 2)[0]) !== null && _b !== void 0 ? _b : ""); + if (!uHandler) { + ((_c = options.fallback) !== null && _c !== void 0 ? _c : connect_node_adapter_fallback)(req, res); + return; + } + const uReq = universalRequestFromNodeRequest(req, res, undefined, (_d = options.contextValues) === null || _d === void 0 ? void 0 : _d.call(options, req)); + uHandler(uReq) + .then((uRes) => universalResponseToNodeResponse(uRes, res)) + .catch((reason) => { + if (ConnectError.from(reason).code == Code.Aborted) { + return; + } + // eslint-disable-next-line no-console + console.error(`handler for rpc ${uHandler.method.name} of ${uHandler.service.typeName} failed`, reason); + }); + }; +} +const connect_node_adapter_fallback = (request, response) => { + response.writeHead(uResponseNotFound.status); + response.end(); +}; + +;// CONCATENATED MODULE: ./node_modules/@connectrpc/connect-node/dist/esm/index.js +// Copyright 2021-2024 The Connect Authors +// +// Licensed under the Apache License, Version 2.0 (the "License"); +// you may not use this file except in compliance with the License. +// You may obtain a copy of the License at +// +// http://www.apache.org/licenses/LICENSE-2.0 +// +// Unless required by applicable law or agreed to in writing, software +// distributed under the License is distributed on an "AS IS" BASIS, +// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. +// See the License for the specific language governing permissions and +// limitations under the License. +// Polyfill the Headers API for Node versions < 18 + + + + + + + + + + +;// CONCATENATED MODULE: ./node_modules/@buf/blacksmith_vm-agent.bufbuild_es/stickydisk/v1/stickydisk_pb.js +// @generated by protoc-gen-es v1.10.0 +// @generated from file stickydisk/v1/stickydisk.proto (package stickydisk.v1, syntax proto3) +/* eslint-disable */ +// @ts-nocheck + + + +/** + * @generated from message stickydisk.v1.GetStickyDiskRequest + */ +const GetStickyDiskRequest = /*@__PURE__*/ proto3.makeMessageType( + "stickydisk.v1.GetStickyDiskRequest", + () => [ + { no: 1, name: "sticky_disk_key", kind: "scalar", T: 9 /* ScalarType.STRING */ }, + { no: 2, name: "region", kind: "scalar", T: 9 /* ScalarType.STRING */ }, + { no: 3, name: "installation_model_id", kind: "scalar", T: 9 /* ScalarType.STRING */ }, + { no: 4, name: "vm_id", kind: "scalar", T: 9 /* ScalarType.STRING */ }, + { no: 5, name: "sticky_disk_type", kind: "scalar", T: 9 /* ScalarType.STRING */ }, + { no: 6, name: "repo_name", kind: "scalar", T: 9 /* ScalarType.STRING */ }, + { no: 7, name: "sticky_disk_token", kind: "scalar", T: 9 /* ScalarType.STRING */ }, + ], +); + +/** + * @generated from message stickydisk.v1.GetStickyDiskResponse + */ +const GetStickyDiskResponse = /*@__PURE__*/ proto3.makeMessageType( + "stickydisk.v1.GetStickyDiskResponse", + () => [ + { no: 1, name: "expose_id", kind: "scalar", T: 9 /* ScalarType.STRING */ }, + { no: 2, name: "disk_identifier", kind: "scalar", T: 9 /* ScalarType.STRING */ }, + ], +); + +/** + * @generated from message stickydisk.v1.CommitStickyDiskRequest + */ +const CommitStickyDiskRequest = /*@__PURE__*/ proto3.makeMessageType( + "stickydisk.v1.CommitStickyDiskRequest", + () => [ + { no: 1, name: "expose_id", kind: "scalar", T: 9 /* ScalarType.STRING */ }, + { no: 2, name: "sticky_disk_key", kind: "scalar", T: 9 /* ScalarType.STRING */ }, + { no: 3, name: "vm_id", kind: "scalar", T: 9 /* ScalarType.STRING */ }, + { no: 4, name: "should_commit", kind: "scalar", T: 8 /* ScalarType.BOOL */ }, + { no: 5, name: "repo_name", kind: "scalar", T: 9 /* ScalarType.STRING */ }, + { no: 6, name: "sticky_disk_token", kind: "scalar", T: 9 /* ScalarType.STRING */ }, + ], +); + +/** + * @generated from message stickydisk.v1.CommitStickyDiskResponse + */ +const CommitStickyDiskResponse = /*@__PURE__*/ proto3.makeMessageType( + "stickydisk.v1.CommitStickyDiskResponse", + [], +); + +/** + * @generated from message stickydisk.v1.UpRequest + */ +const UpRequest = /*@__PURE__*/ proto3.makeMessageType( + "stickydisk.v1.UpRequest", + [], +); + +/** + * @generated from message stickydisk.v1.UpResponse + */ +const UpResponse = /*@__PURE__*/ proto3.makeMessageType( + "stickydisk.v1.UpResponse", + [], +); + + +;// CONCATENATED MODULE: ./node_modules/@buf/blacksmith_vm-agent.connectrpc_es/stickydisk/v1/stickydisk_connect.js +// @generated by protoc-gen-connect-es v1.6.1 +// @generated from file stickydisk/v1/stickydisk.proto (package stickydisk.v1, syntax proto3) +/* eslint-disable */ +// @ts-nocheck + + + + +/** + * @generated from service stickydisk.v1.StickyDiskService + */ +const StickyDiskService = { + typeName: "stickydisk.v1.StickyDiskService", + methods: { + /** + * @generated from rpc stickydisk.v1.StickyDiskService.GetStickyDisk + */ + getStickyDisk: { + name: "GetStickyDisk", + I: GetStickyDiskRequest, + O: GetStickyDiskResponse, + kind: MethodKind.Unary, + }, + /** + * @generated from rpc stickydisk.v1.StickyDiskService.CommitStickyDisk + */ + commitStickyDisk: { + name: "CommitStickyDisk", + I: CommitStickyDiskRequest, + O: CommitStickyDiskResponse, + kind: MethodKind.Unary, + }, + /** + * @generated from rpc stickydisk.v1.StickyDiskService.Up + */ + up: { + name: "Up", + I: UpRequest, + O: UpResponse, + kind: MethodKind.Unary, + }, + } +}; + + +;// CONCATENATED MODULE: ./src/utils.ts + + + +function createStickyDiskClient() { + const transport = createGrpcTransport({ + baseUrl: 'http://192.168.127.1:5557', + httpVersion: '2', + }); + return createClient(StickyDiskService, transport); +} + +;// CONCATENATED MODULE: ./src/post.ts + + + + + +const execAsync = (0,external_util_.promisify)(external_child_process_.exec); +async function commitStickydisk(exposeId, stickyDiskKey) { + core.info(`Committing sticky disk ${stickyDiskKey} with expose ID ${exposeId}`); + if (!exposeId || !stickyDiskKey) { + core.warning('No expose ID or sticky disk key found, cannot report sticky disk to Blacksmith'); + return; + } + try { + const client = await createStickyDiskClient(); + await client.commitStickyDisk({ + exposeId, + stickyDiskKey, + vmId: process.env.VM_ID || '', + shouldCommit: true, + repoName: process.env.GITHUB_REPO_NAME || '', + stickyDiskToken: process.env.BLACKSMITH_STICKYDISK_TOKEN || '' + }, { + timeoutMs: 30000 + }); + core.info(`Successfully committed sticky disk ${stickyDiskKey} with expose ID ${exposeId}`); + } + catch (error) { + core.warning(`Error committing sticky disk: ${error instanceof Error ? error.message : String(error)}`); + } +} +async function cleanupStickyDiskWithoutCommit(exposeId, stickyDiskKey) { + core.info(`Cleaning up sticky disk ${stickyDiskKey} with expose ID ${exposeId}`); + if (!exposeId || !stickyDiskKey) { + core.warning('No expose ID or sticky disk key found, cannot report sticky disk to Blacksmith'); + return; + } + try { + const client = await createStickyDiskClient(); + await client.commitStickyDisk({ + exposeId, + stickyDiskKey, + vmId: process.env.VM_ID || '', + shouldCommit: false, + repoName: process.env.GITHUB_REPO_NAME || '', + stickyDiskToken: process.env.BLACKSMITH_STICKYDISK_TOKEN || '' + }, { + timeoutMs: 30000 + }); + } + catch (error) { + core.warning(`Error reporting build failed: ${error instanceof Error ? error.message : String(error)}`); + // We don't want to fail the build if this fails so we swallow the error. + } +} +async function run() { + const stickyDiskPath = (0,core.getState)('STICKYDISK_PATH'); + const exposeId = (0,core.getState)('STICKYDISK_EXPOSE_ID'); + const stickyDiskKey = (0,core.getState)('STICKYDISK_KEY'); + if (!stickyDiskPath) { + core.debug('No STICKYDISK_PATH in state, skipping unmount'); + return; + } + try { + // Check if path is mounted. + try { + const { stdout: mountOutput } = await execAsync(`mount | grep ${stickyDiskPath}`); + if (!mountOutput) { + core.debug(`${stickyDiskPath} is not mounted, skipping unmount`); + return; + } + } + catch { + // grep returns non-zero if no match found + core.debug(`${stickyDiskPath} is not mounted, skipping unmount`); + return; + } + // First try to unmount with retries + for (let attempt = 1; attempt <= 10; attempt++) { + try { + await execAsync(`sudo umount ${stickyDiskPath}`); + core.info(`Successfully unmounted ${stickyDiskPath}`); + break; + } + catch (error) { + if (attempt === 10) { + throw error; + } + core.warning(`Unmount failed, retrying (${attempt}/10)...`); + await new Promise(resolve => setTimeout(resolve, 300)); + } + } + const stickyDiskError = (0,core.getState)('STICKYDISK_ERROR') === 'true'; + if (!stickyDiskError) { + await commitStickydisk(exposeId, stickyDiskKey); + } + else { + await cleanupStickyDiskWithoutCommit(exposeId, stickyDiskKey); + } + } + catch (error) { + if (error instanceof Error) { + core.error(`Failed to cleanup and commit sticky disk at ${stickyDiskPath}: ${error}`); + } + } +} +run(); + diff --git a/dist/post/package.json b/dist/post/package.json new file mode 100644 index 0000000..3dbc1ca --- /dev/null +++ b/dist/post/package.json @@ -0,0 +1,3 @@ +{ + "type": "module" +} diff --git a/package-lock.json b/package-lock.json index 4134e62..961ce14 100644 --- a/package-lock.json +++ b/package-lock.json @@ -7,19 +7,28 @@ "name": "root", "dependencies": { "@actions/core": "^1.10.1", + "@buf/blacksmith_vm-agent.connectrpc_es": "^1.6.1-20241213043610-906584953dd9.2", + "@bufbuild/connect": "^0.13.0", + "@bufbuild/connect-web": "^0.13.0", + "@bufbuild/protobuf": "^1.4.2", + "@connectrpc/connect": "^1.6.1", + "@connectrpc/connect-node": "^1.6.1", "node-fetch": "^2.7.0", "tslib": "^2.6.2" }, "devDependencies": { + "@bufbuild/protoc-gen-connect-es": "^0.13.0", + "@bufbuild/protoc-gen-es": "^1.4.2", + "@types/axios": "^0.14.4", "@types/jest": "^29.5.12", - "@types/node": "^20.0.0", + "@types/node": "^20.17.9", "@types/node-fetch": "^2.6.11", "@vercel/ncc": "^0.38.1", "eslint": "^9.15.0", "jest": "^29.7.0", "prettier": "^3.3.3", "ts-jest": "^29.1.2", - "typescript": "^5.0.0", + "typescript": "5.5.4", "typescript-eslint": "^8.15.0" } }, @@ -588,6 +597,149 @@ "dev": true, "license": "MIT" }, + "node_modules/@buf/blacksmith_vm-agent.bufbuild_es": { + "version": "1.10.0-20241213043610-906584953dd9.1", + "resolved": "https://buf.build/gen/npm/v1/@buf/blacksmith_vm-agent.bufbuild_es/-/blacksmith_vm-agent.bufbuild_es-1.10.0-20241213043610-906584953dd9.1.tgz", + "peerDependencies": { + "@bufbuild/protobuf": "^1.10.0" + } + }, + "node_modules/@buf/blacksmith_vm-agent.connectrpc_es": { + "version": "1.6.1-20241213043610-906584953dd9.2", + "resolved": "https://buf.build/gen/npm/v1/@buf/blacksmith_vm-agent.connectrpc_es/-/blacksmith_vm-agent.connectrpc_es-1.6.1-20241213043610-906584953dd9.2.tgz", + "dependencies": { + "@buf/blacksmith_vm-agent.bufbuild_es": "1.10.0-20241213043610-906584953dd9.1" + }, + "peerDependencies": { + "@connectrpc/connect": "^1.6.1" + } + }, + "node_modules/@bufbuild/connect": { + "version": "0.13.0", + "resolved": "https://registry.npmjs.org/@bufbuild/connect/-/connect-0.13.0.tgz", + "integrity": "sha512-eZSMbVLyUFtXiZNORgCEvv580xKZeYQdMOWj2i/nxOcpXQcrEzTMTA7SZzWv4k4gveWCOSRoWmYDeOhfWXJv0g==", + "deprecated": "Connect has moved to its own org @connectrpc and has a stable v1. Run `npx @connectrpc/connect-migrate@latest` to update. See https://github.com/connectrpc/connect-es/releases/tag/v0.13.1 for details.", + "peerDependencies": { + "@bufbuild/protobuf": "^1.2.1" + } + }, + "node_modules/@bufbuild/connect-web": { + "version": "0.13.0", + "resolved": "https://registry.npmjs.org/@bufbuild/connect-web/-/connect-web-0.13.0.tgz", + "integrity": "sha512-Ys9VFDWYktD9yFQSLOlkpsD42LonDNMCysLCfjXFuxlupYuf4f7qg0zkT5bESyTfqk4xtRDSSGR3xygaj/ONIQ==", + "deprecated": "Connect has moved to its own org @connectrpc and has a stable v1. Run `npx @connectrpc/connect-migrate@latest` to update. See https://github.com/connectrpc/connect-es/releases/tag/v0.13.1 for details.", + "dependencies": { + "@bufbuild/connect": "0.13.0" + }, + "peerDependencies": { + "@bufbuild/protobuf": "^1.2.1" + } + }, + "node_modules/@bufbuild/protobuf": { + "version": "1.10.0", + "resolved": "https://registry.npmjs.org/@bufbuild/protobuf/-/protobuf-1.10.0.tgz", + "integrity": "sha512-QDdVFLoN93Zjg36NoQPZfsVH9tZew7wKDKyV5qRdj8ntT4wQCOradQjRaTdwMhWUYsgKsvCINKKm87FdEk96Ag==" + }, + "node_modules/@bufbuild/protoc-gen-connect-es": { + "version": "0.13.0", + "resolved": "https://registry.npmjs.org/@bufbuild/protoc-gen-connect-es/-/protoc-gen-connect-es-0.13.0.tgz", + "integrity": "sha512-4HbxWQ799ZLszJJIJsuVMFwkBx8DJ4VEhNDNtKpPJFsTdVUOp1LyFGY66Yjfj9vcuOeH44bS0ALE5pRP3rCxXA==", + "deprecated": "Connect has moved to its own org @connectrpc and has a stable v1. Run `npx @connectrpc/connect-migrate@latest` to update. See https://github.com/connectrpc/connect-es/releases/tag/v0.13.1 for details.", + "dev": true, + "dependencies": { + "@bufbuild/protobuf": "^1.2.1", + "@bufbuild/protoplugin": "^1.2.1" + }, + "bin": { + "protoc-gen-connect-es": "bin/protoc-gen-connect-es" + }, + "engines": { + "node": ">=16.0.0" + }, + "peerDependencies": { + "@bufbuild/connect": "0.13.0", + "@bufbuild/protoc-gen-es": "^1.2.1" + }, + "peerDependenciesMeta": { + "@bufbuild/connect": { + "optional": true + }, + "@bufbuild/protoc-gen-es": { + "optional": true + } + } + }, + "node_modules/@bufbuild/protoc-gen-es": { + "version": "1.10.0", + "resolved": "https://registry.npmjs.org/@bufbuild/protoc-gen-es/-/protoc-gen-es-1.10.0.tgz", + "integrity": "sha512-zBYBsVT/ul4uZb6F+kD7/k4sWNHVVbEPfJwKi0FDr+9VJo8MKIofI6pkr5ksBLr4fi/74r+e/75Xi/0clL5dXg==", + "dev": true, + "dependencies": { + "@bufbuild/protobuf": "^1.10.0", + "@bufbuild/protoplugin": "1.10.0" + }, + "bin": { + "protoc-gen-es": "bin/protoc-gen-es" + }, + "engines": { + "node": ">=14" + }, + "peerDependencies": { + "@bufbuild/protobuf": "1.10.0" + }, + "peerDependenciesMeta": { + "@bufbuild/protobuf": { + "optional": true + } + } + }, + "node_modules/@bufbuild/protoplugin": { + "version": "1.10.0", + "resolved": "https://registry.npmjs.org/@bufbuild/protoplugin/-/protoplugin-1.10.0.tgz", + "integrity": "sha512-u6NE4vL0lw1+EK4/PiE/SQB7fKO4LRJNTEScIXVOi2x88K/c8WKc/k0KyEaA0asVBMpwekJQZGnRyj04ZtN5Gg==", + "dev": true, + "dependencies": { + "@bufbuild/protobuf": "1.10.0", + "@typescript/vfs": "^1.4.0", + "typescript": "4.5.2" + } + }, + "node_modules/@bufbuild/protoplugin/node_modules/typescript": { + "version": "4.5.2", + "resolved": "https://registry.npmjs.org/typescript/-/typescript-4.5.2.tgz", + "integrity": "sha512-5BlMof9H1yGt0P8/WF+wPNw6GfctgGjXp5hkblpyT+8rkASSmkUKMXrxR0Xg8ThVCi/JnHQiKXeBaEwCeQwMFw==", + "dev": true, + "bin": { + "tsc": "bin/tsc", + "tsserver": "bin/tsserver" + }, + "engines": { + "node": ">=4.2.0" + } + }, + "node_modules/@connectrpc/connect": { + "version": "1.6.1", + "resolved": "https://registry.npmjs.org/@connectrpc/connect/-/connect-1.6.1.tgz", + "integrity": "sha512-KchMDNtU4CDTdkyf0qG7ugJ6qHTOR/aI7XebYn3OTCNagaDYWiZUVKgRgwH79yeMkpNgvEUaXSK7wKjaBK9b/Q==", + "peerDependencies": { + "@bufbuild/protobuf": "^1.10.0" + } + }, + "node_modules/@connectrpc/connect-node": { + "version": "1.6.1", + "resolved": "https://registry.npmjs.org/@connectrpc/connect-node/-/connect-node-1.6.1.tgz", + "integrity": "sha512-DxcD1wsF/aX9GegjAtl7VbpiZNjVJozy87VbaFoN6AF0Ln1Q757r5dgV59Gz0wmlk5f17txUsrEr1f2inlnnAg==", + "dependencies": { + "undici": "^5.28.4" + }, + "engines": { + "node": ">=16.0.0" + }, + "peerDependencies": { + "@bufbuild/protobuf": "^1.10.0", + "@connectrpc/connect": "1.6.1" + } + }, "node_modules/@eslint-community/eslint-utils": { "version": "4.4.1", "resolved": "https://registry.npmjs.org/@eslint-community/eslint-utils/-/eslint-utils-4.4.1.tgz", @@ -1314,6 +1466,16 @@ "@sinonjs/commons": "^3.0.0" } }, + "node_modules/@types/axios": { + "version": "0.14.4", + "resolved": "https://registry.npmjs.org/@types/axios/-/axios-0.14.4.tgz", + "integrity": "sha512-9JgOaunvQdsQ/qW2OPmE5+hCeUB52lQSolecrFrthct55QekhmXEwT203s20RL+UHtCQc15y3VXpby9E7Kkh/g==", + "deprecated": "This is a stub types definition. axios provides its own type definitions, so you do not need this installed.", + "dev": true, + "dependencies": { + "axios": "*" + } + }, "node_modules/@types/babel__core": { "version": "7.20.5", "resolved": "https://registry.npmjs.org/@types/babel__core/-/babel__core-7.20.5.tgz", @@ -1422,11 +1584,10 @@ "license": "MIT" }, "node_modules/@types/node": { - "version": "20.17.7", - "resolved": "https://registry.npmjs.org/@types/node/-/node-20.17.7.tgz", - "integrity": "sha512-sZXXnpBFMKbao30dUAvzKbdwA2JM1fwUtVEq/kxKuPI5mMwZiRElCpTXb0Biq/LMEVpXDZL5G5V0RPnxKeyaYg==", + "version": "20.17.9", + "resolved": "https://registry.npmjs.org/@types/node/-/node-20.17.9.tgz", + "integrity": "sha512-0JOXkRyLanfGPE2QRCwgxhzlBAvaRdCNMcvbd7jFfpmD4eEXll7LRwy5ymJmyeZqk7Nh7eD2LeUyQ68BbndmXw==", "dev": true, - "license": "MIT", "dependencies": { "undici-types": "~6.19.2" } @@ -1690,6 +1851,18 @@ "url": "https://opencollective.com/typescript-eslint" } }, + "node_modules/@typescript/vfs": { + "version": "1.6.0", + "resolved": "https://registry.npmjs.org/@typescript/vfs/-/vfs-1.6.0.tgz", + "integrity": "sha512-hvJUjNVeBMp77qPINuUvYXj4FyWeeMMKZkxEATEU3hqBAQ7qdTBCUFT7Sp0Zu0faeEtFf+ldXxMEDr/bk73ISg==", + "dev": true, + "dependencies": { + "debug": "^4.1.1" + }, + "peerDependencies": { + "typescript": "*" + } + }, "node_modules/@vercel/ncc": { "version": "0.38.3", "resolved": "https://registry.npmjs.org/@vercel/ncc/-/ncc-0.38.3.tgz", @@ -1817,6 +1990,17 @@ "dev": true, "license": "MIT" }, + "node_modules/axios": { + "version": "1.7.9", + "resolved": "https://registry.npmjs.org/axios/-/axios-1.7.9.tgz", + "integrity": "sha512-LhLcE7Hbiryz8oMDdDptSrWowmB4Bl6RCt6sIJKpRB4XtVf0iEgewX3au/pJqm+Py1kCASkb/FFKjxQaLtxJvw==", + "dev": true, + "dependencies": { + "follow-redirects": "^1.15.6", + "form-data": "^4.0.0", + "proxy-from-env": "^1.1.0" + } + }, "node_modules/babel-jest": { "version": "29.7.0", "resolved": "https://registry.npmjs.org/babel-jest/-/babel-jest-29.7.0.tgz", @@ -2787,6 +2971,26 @@ "dev": true, "license": "ISC" }, + "node_modules/follow-redirects": { + "version": "1.15.9", + "resolved": "https://registry.npmjs.org/follow-redirects/-/follow-redirects-1.15.9.tgz", + "integrity": "sha512-gew4GsXizNgdoRyqmyfMHyAmXsZDk6mHkSxZFCzW9gwlbtOW44CDtYavM+y+72qD/Vq2l550kMF52DT8fOLJqQ==", + "dev": true, + "funding": [ + { + "type": "individual", + "url": "https://github.com/sponsors/RubenVerborgh" + } + ], + "engines": { + "node": ">=4.0" + }, + "peerDependenciesMeta": { + "debug": { + "optional": true + } + } + }, "node_modules/form-data": { "version": "4.0.1", "resolved": "https://registry.npmjs.org/form-data/-/form-data-4.0.1.tgz", @@ -4492,6 +4696,12 @@ "node": ">= 6" } }, + "node_modules/proxy-from-env": { + "version": "1.1.0", + "resolved": "https://registry.npmjs.org/proxy-from-env/-/proxy-from-env-1.1.0.tgz", + "integrity": "sha512-D+zkORCbA9f1tdWRK0RaCR3GPv50cMxcrz4X8k5LTSUD1Dkw47mKJEZQNunItRTkWwgtaUSo1RVFRIG9ZXiFYg==", + "dev": true + }, "node_modules/punycode": { "version": "2.3.1", "resolved": "https://registry.npmjs.org/punycode/-/punycode-2.3.1.tgz", @@ -5020,11 +5230,10 @@ } }, "node_modules/typescript": { - "version": "5.7.2", - "resolved": "https://registry.npmjs.org/typescript/-/typescript-5.7.2.tgz", - "integrity": "sha512-i5t66RHxDvVN40HfDd1PsEThGNnlMCMT3jMUuoh9/0TaqWevNontacunWyN02LA9/fIbEWlcHZcgTKb9QoaLfg==", + "version": "5.5.4", + "resolved": "https://registry.npmjs.org/typescript/-/typescript-5.5.4.tgz", + "integrity": "sha512-Mtq29sKDAEYP7aljRgtPOpTvOfbwRWlS6dPRzwjdE+C0R4brX/GUyhHSecbHMFLNBLcJIPt9nl9yG5TZ1weH+Q==", "dev": true, - "license": "Apache-2.0", "bin": { "tsc": "bin/tsc", "tsserver": "bin/tsserver" diff --git a/package.json b/package.json index 79ef783..6ca1438 100644 --- a/package.json +++ b/package.json @@ -3,26 +3,35 @@ "private": true, "type": "module", "scripts": { - "build": "ncc build src/main.ts -o dist", + "build": "ncc build src/main.ts -o dist && ncc build src/post.ts -o dist/post", "format": "prettier --write --cache . !dist", "lint": "eslint", "test": "jest" }, "dependencies": { "@actions/core": "^1.10.1", + "@buf/blacksmith_vm-agent.connectrpc_es": "^1.6.1-20241213043610-906584953dd9.2", + "@bufbuild/connect": "^0.13.0", + "@bufbuild/connect-web": "^0.13.0", + "@bufbuild/protobuf": "^1.4.2", + "@connectrpc/connect": "^1.6.1", + "@connectrpc/connect-node": "^1.6.1", "node-fetch": "^2.7.0", "tslib": "^2.6.2" }, "devDependencies": { - "prettier": "^3.3.3", - "eslint": "^9.15.0", - "typescript-eslint": "^8.15.0", - "@vercel/ncc": "^0.38.1", - "@types/node": "^20.0.0", + "@bufbuild/protoc-gen-connect-es": "^0.13.0", + "@bufbuild/protoc-gen-es": "^1.4.2", + "@types/axios": "^0.14.4", + "@types/jest": "^29.5.12", + "@types/node": "^20.17.9", "@types/node-fetch": "^2.6.11", - "typescript": "^5.0.0", + "@vercel/ncc": "^0.38.1", + "eslint": "^9.15.0", "jest": "^29.7.0", - "@types/jest": "^29.5.12", - "ts-jest": "^29.1.2" + "prettier": "^3.3.3", + "ts-jest": "^29.1.2", + "typescript": "5.5.4", + "typescript-eslint": "^8.15.0" } } diff --git a/src/__tests__/main.test.ts b/src/__tests__/main.test.ts index 27aab0d..e69de29 100644 --- a/src/__tests__/main.test.ts +++ b/src/__tests__/main.test.ts @@ -1,210 +0,0 @@ -import { beforeEach, describe, expect, it, jest } from "@jest/globals"; -import { deleteCache } from "../main"; -import fetch, { Response } from "node-fetch"; -import { info } from "@actions/core"; - -jest.mock("node-fetch"); -jest.mock("@actions/core", () => ({ - info: jest.fn(), - setFailed: jest.fn(), - getInput: jest.fn(), -})); - -const mockedFetch = jest.mocked(fetch); -const mockedInfo = jest.mocked(info); - -describe("deleteCache", () => { - beforeEach(() => { - jest.clearAllMocks(); - mockedFetch.mockResolvedValue({ - ok: true, - status: 200, - statusText: "OK", - json: () => Promise.resolve({ deleted: 1 }), - } as Response); - }); - - const defaultParams = { - baseUrl: "https://api.blacksmith.sh/cache", - repoName: "test-repo", - cacheToken: "test-token", - region: "eu-central", - }; - - it("should send DELETE request for a specific cache key", async () => { - await deleteCache({ - cacheKey: "npm-cache", - ...defaultParams, - }); - - expect(mockedFetch).toHaveBeenCalledWith( - "https://api.blacksmith.sh/cache/caches/npm-cache", - { - method: "DELETE", - headers: { - Accept: "application/json; version=6.0-preview.1", - "X-GitHub-Repo-Name": "test-repo", - Authorization: "Bearer test-token", - "X-Cache-Region": "eu-central", - }, - } - ); - expect(mockedInfo).toHaveBeenCalledWith( - "Successfully deleted cache: npm-cache" - ); - expect(mockedInfo).toHaveBeenCalledWith("Deleted 1 cache entries"); - }); - - it("should send DELETE request for a specific cache version", async () => { - await deleteCache({ - cacheKey: "npm-cache", - cacheVersion: "v1.0", - ...defaultParams, - }); - - expect(mockedFetch).toHaveBeenCalledWith( - "https://api.blacksmith.sh/cache/caches/npm-cache/v1.0", - { - method: "DELETE", - headers: { - Accept: "application/json; version=6.0-preview.1", - "X-GitHub-Repo-Name": "test-repo", - Authorization: "Bearer test-token", - "X-Cache-Region": "eu-central", - }, - } - ); - expect(mockedInfo).toHaveBeenCalledWith( - "Successfully deleted cache version: npm-cache@v1.0" - ); - expect(mockedInfo).toHaveBeenCalledWith("Deleted 1 cache entries"); - }); - - it("should send DELETE request with prefix parameter", async () => { - mockedFetch.mockResolvedValue({ - ok: true, - status: 200, - statusText: "OK", - json: () => Promise.resolve({ deleted: 5 }), - } as Response); - - await deleteCache({ - cacheKey: "npm-", - prefix: true, - ...defaultParams, - }); - - expect(mockedFetch).toHaveBeenCalledWith( - "https://api.blacksmith.sh/cache/caches/npm-?prefix", - { - method: "DELETE", - headers: { - Accept: "application/json; version=6.0-preview.1", - "X-GitHub-Repo-Name": "test-repo", - Authorization: "Bearer test-token", - "X-Cache-Region": "eu-central", - }, - } - ); - expect(mockedInfo).toHaveBeenCalledWith( - "Successfully deleted caches with prefix: npm-" - ); - expect(mockedInfo).toHaveBeenCalledWith("Deleted 5 cache entries"); - }); - - it("should send DELETE request with empty key and prefix parameter", async () => { - mockedFetch.mockResolvedValue({ - ok: true, - status: 200, - statusText: "OK", - json: () => Promise.resolve({ deleted: 10 }), - } as Response); - - await deleteCache({ - cacheKey: "", - prefix: true, - ...defaultParams, - }); - - expect(mockedFetch).toHaveBeenCalledWith( - "https://api.blacksmith.sh/cache/caches/?prefix", - { - method: "DELETE", - headers: { - Accept: "application/json; version=6.0-preview.1", - "X-GitHub-Repo-Name": "test-repo", - Authorization: "Bearer test-token", - "X-Cache-Region": "eu-central", - }, - } - ); - expect(mockedInfo).toHaveBeenCalledWith( - "Successfully deleted caches with prefix: " - ); - expect(mockedInfo).toHaveBeenCalledWith("Deleted 10 cache entries"); - }); - - it("should fail if key is empty and prefix is not true", async () => { - await expect( - deleteCache({ - cacheKey: "", - prefix: false, - ...defaultParams, - }) - ).rejects.toThrow("Cache key cannot be empty unless prefix is true"); - }); - - it("should fail if version is specified with prefix", async () => { - await expect( - deleteCache({ - cacheKey: "npm-cache", - cacheVersion: "v1.0", - prefix: true, - ...defaultParams, - }) - ).rejects.toThrow("Cannot specify version when using prefix"); - }); - - it("should handle 404 response", async () => { - mockedFetch.mockResolvedValue({ - ok: false, - status: 404, - statusText: "Not Found", - json: () => Promise.resolve({}), - } as Response); - - await deleteCache({ - cacheKey: "non-existent", - ...defaultParams, - }); - - expect(mockedInfo).toHaveBeenCalledWith("Cache not found: non-existent"); - }); - - it("should throw error for non-404 failure", async () => { - mockedFetch.mockResolvedValue({ - ok: false, - status: 500, - statusText: "Internal Server Error", - json: () => Promise.resolve({}), - } as Response); - - await expect( - deleteCache({ - cacheKey: "npm-cache", - ...defaultParams, - }) - ).rejects.toThrow("Failed to delete cache: 500 Internal Server Error"); - }); - - it("should fail if version is specified with empty key", async () => { - await expect( - deleteCache({ - cacheKey: "", - cacheVersion: "v1.0", - prefix: true, - ...defaultParams, - }) - ).rejects.toThrow("Cannot specify version when using empty key"); - }); -}); diff --git a/src/main.ts b/src/main.ts index d92a83b..04d0b28 100644 --- a/src/main.ts +++ b/src/main.ts @@ -1,88 +1,119 @@ -import { getInput, setFailed, info } from "@actions/core"; -import fetch from "node-fetch"; +import { getInput, saveState } from "@actions/core"; +import * as core from '@actions/core'; +import { promisify } from 'util'; +import { exec } from 'child_process'; +import { createStickyDiskClient } from './utils'; -interface DeleteCacheParams { - cacheKey: string; - cacheVersion?: string; - prefix?: boolean; - baseUrl?: string; - repoName?: string; - cacheToken?: string; - region?: string; -} - -export async function deleteCache({ - cacheKey, - cacheVersion, - prefix = false, - baseUrl = process.env.BLACKSMITH_CACHE_URL || - (process.env.PETNAME?.includes("staging") - ? "https://stagingapi.blacksmith.sh/cache" - : "https://api.blacksmith.sh/cache"), - repoName = process.env["GITHUB_REPO_NAME"] ?? "", - cacheToken = process.env["BLACKSMITH_CACHE_TOKEN"], - region = process.env["BLACKSMITH_REGION"] ?? "eu-central", -}: DeleteCacheParams): Promise { - if (!cacheKey && !prefix) { - throw new Error("Cache key cannot be empty unless prefix is true"); - } - if (cacheVersion && !cacheKey) { - throw new Error("Cannot specify version when using empty key"); - } - if (prefix && cacheVersion) { - throw new Error("Cannot specify version when using prefix"); - } +const execAsync = promisify(exec); - const resource = cacheVersion ? `${cacheKey}/${cacheVersion}` : cacheKey; - const url = `${baseUrl}/caches/${resource}`; - - const response = await fetch(prefix ? `${url}?prefix` : url, { - method: "DELETE", - headers: { - Accept: "application/json; version=6.0-preview.1", - "X-GitHub-Repo-Name": repoName, - Authorization: `Bearer ${cacheToken}`, - "X-Cache-Region": region, - }, +async function getStickyDisk(stickyDiskKey: string, options?: {signal?: AbortSignal}): Promise<{expose_id: string; device: string}> { + const client = createStickyDiskClient(); + + core.debug(`Getting sticky disk for ${stickyDiskKey}`); + const response = await client.getStickyDisk({ + stickyDiskKey: stickyDiskKey, + region: process.env.BLACKSMITH_REGION || 'eu-central', + installationModelId: process.env.BLACKSMITH_INSTALLATION_MODEL_ID || '', + vmId: process.env.VM_ID || '', + stickyDiskType: 'stickydisk', + stickyDiskToken: process.env.BLACKSMITH_STICKYDISK_TOKEN, + repoName: process.env.GITHUB_REPO_NAME || '' + }, { + signal: options?.signal, }); - if (!response.ok && response.status !== 404) { - throw new Error( - `Failed to delete cache: ${response.status} ${response.statusText}` - ); - } + return { + expose_id: response.exposeId, + device: response.diskIdentifier + }; +} + +async function maybeFormatBlockDevice(device: string): Promise { + try { + // Check if device is formatted with ext4 + try { + const {stdout} = await execAsync(`sudo blkid -o value -s TYPE ${device}`); + if (stdout.trim() === 'ext4') { + core.debug(`Device ${device} is already formatted with ext4`); + try { + // Run resize2fs to ensure filesystem uses full block device + await execAsync(`sudo resize2fs -f ${device}`); + core.debug(`Resized ext4 filesystem on ${device}`); + } catch (error) { + if (error instanceof Error) { + core.warning(`Error resizing ext4 filesystem on ${device}: ${error}`); + } + } + return device; + } + } catch { + // blkid returns non-zero if no filesystem found, which is fine + core.debug(`No filesystem found on ${device}, will format it`); + } - if (response.status === 404) { - info( - `Cache not found${cacheKey ? `: ${cacheKey}` : ""}${cacheVersion ? `@${cacheVersion}` : ""}` - ); - } else { - const data = await response.json(); - info( - `Successfully deleted ${prefix ? "caches with prefix" : "cache"}${ - cacheVersion ? " version" : "" - }: ${cacheKey}${cacheVersion ? `@${cacheVersion}` : ""}` - ); - if (data.deleted !== undefined) { - info(`Deleted ${data.deleted} cache entries`); + // Format device with ext4 + core.debug(`Formatting device ${device} with ext4`); + await execAsync(`sudo mkfs.ext4 -m0 -Enodiscard,lazy_itable_init=1,lazy_journal_init=1 -F ${device}`); + core.debug(`Successfully formatted ${device} with ext4`); + return device; + } catch (error) { + if (error instanceof Error) { + core.error(`Failed to format device ${device}: ${error}`); } + throw error; } } +async function mountStickyDisk(stickyDiskKey: string, stickyDiskPath: string, signal: AbortSignal, controller: AbortController): Promise<{device: string, exposeId: string}> { + const timeoutId = setTimeout(() => controller.abort(), 15000); + const stickyDiskResponse = await getStickyDisk(stickyDiskKey, {signal}); + const device = stickyDiskResponse.device; + const exposeId = stickyDiskResponse.expose_id; + clearTimeout(timeoutId); + await maybeFormatBlockDevice(device); + await execAsync(`sudo mkdir -p ${stickyDiskPath}`); + await execAsync(`sudo mount ${device} ${stickyDiskPath}`); + core.debug(`${device} has been mounted to ${stickyDiskPath} with expose ID ${exposeId}`); + return {device, exposeId}; +} + async function run(): Promise { + let stickyDiskError: Error | undefined; + let exposeId: string | undefined; + let device = ''; + const stickyDiskKey = getInput("key"); + const stickyDiskPath = getInput("path"); + + // Save these values to GitHub Actions state + saveState('STICKYDISK_PATH', stickyDiskPath); + saveState('STICKYDISK_KEY', stickyDiskKey); + + core.info(`Mounting sticky disk at ${stickyDiskPath} with key ${stickyDiskKey}`); + try { - const cacheKey = getInput("key"); - const cacheVersion = getInput("version"); - const prefix = getInput("prefix") === "true"; + const controller = new AbortController(); - await deleteCache({ cacheKey, cacheVersion, prefix }); + try { + ({device, exposeId} = await mountStickyDisk(stickyDiskKey, stickyDiskPath, controller.signal, controller)); + saveState('STICKYDISK_EXPOSE_ID', exposeId); + core.debug(`Sticky disk mounted to ${device}, expose ID: ${exposeId}`); + } catch (error) { + if (error instanceof Error && error.name === 'AbortError') { + core.warning('Request to get sticky disk timed out'); + } + throw error; + } } catch (error) { if (error instanceof Error) { - setFailed(error.message); - } else { - setFailed("An unexpected error occurred"); + core.warning(`Error getting sticky disk: ${error}`); + stickyDiskError = error; + saveState('STICKYDISK_ERROR', 'true'); } } + + if (stickyDiskError) { + core.setFailed(`Error getting sticky disk: ${stickyDiskError}`); + } } run(); diff --git a/src/post.ts b/src/post.ts new file mode 100644 index 0000000..bedff4b --- /dev/null +++ b/src/post.ts @@ -0,0 +1,111 @@ +import * as core from '@actions/core'; +import { promisify } from 'util'; +import { exec } from 'child_process'; +import { getState } from '@actions/core'; +import { createStickyDiskClient } from './utils'; + +const execAsync = promisify(exec); + +async function commitStickydisk(exposeId: string, stickyDiskKey: string): Promise { + core.info(`Committing sticky disk ${stickyDiskKey} with expose ID ${exposeId}`); + if (!exposeId || !stickyDiskKey) { + core.warning('No expose ID or sticky disk key found, cannot report sticky disk to Blacksmith'); + return; + } + + try { + const client = await createStickyDiskClient(); + await client.commitStickyDisk({ + exposeId, + stickyDiskKey, + vmId: process.env.VM_ID || '', + shouldCommit: true, + repoName: process.env.GITHUB_REPO_NAME || '', + stickyDiskToken: process.env.BLACKSMITH_STICKYDISK_TOKEN || '' + }, { + timeoutMs: 30000 + }); + core.info(`Successfully committed sticky disk ${stickyDiskKey} with expose ID ${exposeId}`); + } catch (error) { + core.warning(`Error committing sticky disk: ${error instanceof Error ? error.message : String(error)}`); + } +} + +async function cleanupStickyDiskWithoutCommit(exposeId: string, stickyDiskKey: string): Promise { + core.info(`Cleaning up sticky disk ${stickyDiskKey} with expose ID ${exposeId}`); + if (!exposeId || !stickyDiskKey) { + core.warning('No expose ID or sticky disk key found, cannot report sticky disk to Blacksmith'); + return; + } + + try { + const client = await createStickyDiskClient(); + await client.commitStickyDisk({ + exposeId, + stickyDiskKey, + vmId: process.env.VM_ID || '', + shouldCommit: false, + repoName: process.env.GITHUB_REPO_NAME || '', + stickyDiskToken: process.env.BLACKSMITH_STICKYDISK_TOKEN || '' + }, { + timeoutMs: 30000 + }); + } catch (error) { + core.warning(`Error reporting build failed: ${error instanceof Error ? error.message : String(error)}`); + // We don't want to fail the build if this fails so we swallow the error. + } +} + +async function run(): Promise { + const stickyDiskPath = getState('STICKYDISK_PATH'); + const exposeId = getState('STICKYDISK_EXPOSE_ID'); + const stickyDiskKey = getState('STICKYDISK_KEY'); + + if (!stickyDiskPath) { + core.debug('No STICKYDISK_PATH in state, skipping unmount'); + return; + } + + try { + // Check if path is mounted. + try { + const { stdout: mountOutput } = await execAsync(`mount | grep ${stickyDiskPath}`); + if (!mountOutput) { + core.debug(`${stickyDiskPath} is not mounted, skipping unmount`); + return; + } + } catch { + // grep returns non-zero if no match found + core.debug(`${stickyDiskPath} is not mounted, skipping unmount`); + return; + } + + // First try to unmount with retries + for (let attempt = 1; attempt <= 10; attempt++) { + try { + await execAsync(`sudo umount ${stickyDiskPath}`); + core.info(`Successfully unmounted ${stickyDiskPath}`); + break; + } catch (error) { + if (attempt === 10) { + throw error; + } + core.warning(`Unmount failed, retrying (${attempt}/10)...`); + await new Promise(resolve => setTimeout(resolve, 300)); + } + } + + const stickyDiskError = getState('STICKYDISK_ERROR') === 'true'; + if (!stickyDiskError) { + await commitStickydisk(exposeId, stickyDiskKey); + } else { + await cleanupStickyDiskWithoutCommit(exposeId, stickyDiskKey); + } + } catch (error) { + if (error instanceof Error) { + core.error(`Failed to cleanup and commit sticky disk at ${stickyDiskPath}: ${error}`); + } + } +} + +run(); diff --git a/src/utils.ts b/src/utils.ts new file mode 100644 index 0000000..3bf2c3c --- /dev/null +++ b/src/utils.ts @@ -0,0 +1,12 @@ +import { createClient } from "@connectrpc/connect"; +import { createGrpcTransport } from "@connectrpc/connect-node"; +import { StickyDiskService } from "@buf/blacksmith_vm-agent.connectrpc_es/stickydisk/v1/stickydisk_connect"; + +export function createStickyDiskClient() { + const transport = createGrpcTransport({ + baseUrl: 'http://192.168.127.1:5557', + httpVersion: '2', + }); + + return createClient(StickyDiskService, transport); +} \ No newline at end of file From 1e9b1c303c62490bf234f11a99f1c4e6814efc02 Mon Sep 17 00:00:00 2001 From: Aditya Maru Date: Mon, 16 Dec 2024 15:48:35 -0500 Subject: [PATCH 02/17] README: update use cases in README --- README.md | 6 ++++-- 1 file changed, 4 insertions(+), 2 deletions(-) diff --git a/README.md b/README.md index 0fbe4cd..2ecd898 100644 --- a/README.md +++ b/README.md @@ -4,10 +4,12 @@ A GitHub Action that helps persist state written to disk across jobs. Each stick Some common use cases of this action include: -- Caching Docker images to minimize pull and extract times - Caching build artifacts such as NPM packages (egs: node_modules, yarn.lock, etc) - Caching Bazel build artifacts -- Caching large GitHub repositories to minimize checkout times + +Coming soon: +- Caching docker pull and extraction to minimize container startup times +- Caching large repositories to make checking out code instantaneous ## Usage From 86672c0b0663ad9536fa73bf0ac8164c63fd7d21 Mon Sep 17 00:00:00 2001 From: Aditya Maru Date: Mon, 16 Dec 2024 15:59:20 -0500 Subject: [PATCH 03/17] README: update README --- README.md | 16 +++++----------- 1 file changed, 5 insertions(+), 11 deletions(-) diff --git a/README.md b/README.md index 2ecd898..90e7669 100644 --- a/README.md +++ b/README.md @@ -1,15 +1,9 @@ # Blacksmith Sticky Disk Action -A GitHub Action that helps persist state written to disk across jobs. Each sticky disk is backed by local NVMe storage and is formmatted as an ext4 filesystem. +A GitHub Action that helps persist state written to disk across jobs. Each sticky disk is hot-loaded into the runner and mounted at the specified path. +The sticky disk is formatted as an ext4 filesystem. -Some common use cases of this action include: - -- Caching build artifacts such as NPM packages (egs: node_modules, yarn.lock, etc) -- Caching Bazel build artifacts - -Coming soon: -- Caching docker pull and extraction to minimize container startup times -- Caching large repositories to make checking out code instantaneous +A common use case of this action is to cache build artifacts such as NPM packages (egs: node_modules, yarn.lock, etc) across job runs. ## Usage @@ -19,10 +13,10 @@ jobs: runs-on: blacksmith steps: - name: Cache NPM packages - uses: useblacksmith/stickydisk-action@master + uses: useblacksmith/stickydisk@v1 with: key: ${{ github.repository }}-npm-cache path: ~/.node_modules ``` -Each sticky disk is uniquely identified by a key. The sticky disk will be mounted at the specified path. Once the job completes, the sticky disk will be unmounted and committed for future invocations. At the moment, customers can use up to 5 sticky disks in a single GitHub Action job. +Each sticky disk is uniquely identified by a key. The sticky disk will be mounted at the specified path. Once the job completes, the sticky disk will be unmounted and committed for future invocations. At the moment, customers can use up to 10 sticky disks in a single GitHub Action job. From 133fc0b41dae042b58927e08d3ace65bfb15216c Mon Sep 17 00:00:00 2001 From: Aayush Shah Date: Mon, 16 Dec 2024 16:11:53 -0500 Subject: [PATCH 04/17] README: add blacksmith logo (#4) --- Blacksmith_Logo-Black-Large.png | Bin 0 -> 24274 bytes Blacksmith_Logo-White-Large.png | Bin 0 -> 25451 bytes README.md | 10 ++++++++++ 3 files changed, 10 insertions(+) create mode 100644 Blacksmith_Logo-Black-Large.png create mode 100644 Blacksmith_Logo-White-Large.png diff --git a/Blacksmith_Logo-Black-Large.png b/Blacksmith_Logo-Black-Large.png new file mode 100644 index 0000000000000000000000000000000000000000..78fdea516331b8d63c4a8d61019dbbf3b46230bf GIT binary patch literal 24274 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 VtMkLv%nY-(g_h=I7q{2ys|I|u*( literal 0 HcmV?d00001 diff --git a/Blacksmith_Logo-White-Large.png b/Blacksmith_Logo-White-Large.png new file mode 100644 index 0000000000000000000000000000000000000000..502e19be12cb0f5a95a02750c619c8716a6ee742 GIT binary patch literal 25451 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 literal 0 HcmV?d00001 diff --git a/README.md b/README.md index 90e7669..8e84082 100644 --- a/README.md +++ b/README.md @@ -1,3 +1,13 @@ +

+ + + + + + Blacksmith Logo + +

+ # Blacksmith Sticky Disk Action A GitHub Action that helps persist state written to disk across jobs. Each sticky disk is hot-loaded into the runner and mounted at the specified path. From d29289de91715f4ec28f1750f337b9e0fca8fab4 Mon Sep 17 00:00:00 2001 From: Aditya Maru Date: Thu, 19 Dec 2024 09:51:54 -0500 Subject: [PATCH 05/17] main: maintain runner perms when mounting a stickydisk --- .github/workflows/bump-tag.yaml | 22 ++++++++++++++++++++++ dist/index.js | 19 +++++++++++++++---- src/main.ts | 22 ++++++++++++++++++---- 3 files changed, 55 insertions(+), 8 deletions(-) create mode 100644 .github/workflows/bump-tag.yaml diff --git a/.github/workflows/bump-tag.yaml b/.github/workflows/bump-tag.yaml new file mode 100644 index 0000000..7a5239b --- /dev/null +++ b/.github/workflows/bump-tag.yaml @@ -0,0 +1,22 @@ +name: Bump Tag + +on: + workflow_dispatch: + +jobs: + bump-tag: + runs-on: ubuntu-latest + permissions: + contents: write + steps: + - uses: actions/checkout@v4 + with: + fetch-depth: 0 + ref: main + + - name: Bump v1 tag + run: | + git config --global user.name "github-actions[bot]" + git config --global user.email "41898282+github-actions[bot]@users.noreply.github.com" + git tag -f v1 + git push origin v1 -f diff --git a/dist/index.js b/dist/index.js index 793e7f8..1d07b6b 100644 --- a/dist/index.js +++ b/dist/index.js @@ -36229,11 +36229,13 @@ async function maybeFormatBlockDevice(device) { try { // Check if device is formatted with ext4 try { + // Need sudo for blkid as it requires root to read block device metadata const { stdout } = await execAsync(`sudo blkid -o value -s TYPE ${device}`); if (stdout.trim() === 'ext4') { core.debug(`Device ${device} is already formatted with ext4`); try { - // Run resize2fs to ensure filesystem uses full block device + // Need sudo for resize2fs as it requires root to modify block device + // This operation preserves existing filesystem ownership and permissions await execAsync(`sudo resize2fs -f ${device}`); core.debug(`Resized ext4 filesystem on ${device}`); } @@ -36249,9 +36251,13 @@ async function maybeFormatBlockDevice(device) { // blkid returns non-zero if no filesystem found, which is fine core.debug(`No filesystem found on ${device}, will format it`); } - // Format device with ext4 + // Format device with ext4, setting default ownership to current user. core.debug(`Formatting device ${device} with ext4`); - await execAsync(`sudo mkfs.ext4 -m0 -Enodiscard,lazy_itable_init=1,lazy_journal_init=1 -F ${device}`); + // Need sudo for mkfs.ext4 as it requires root to format block device + // -m0: Disable reserved blocks (all space available to non-root users) + // root_owner=$(id -u):$(id -g): Sets filesystem root directory owner to current (runner) user + // This ensures the filesystem is owned by runner user from the start + await execAsync(`sudo mkfs.ext4 -m0 -E root_owner=$(id -u):$(id -g) -Enodiscard,lazy_itable_init=1,lazy_journal_init=1 -F ${device}`); core.debug(`Successfully formatted ${device} with ext4`); return device; } @@ -36269,8 +36275,13 @@ async function mountStickyDisk(stickyDiskKey, stickyDiskPath, signal, controller const exposeId = stickyDiskResponse.expose_id; clearTimeout(timeoutId); await maybeFormatBlockDevice(device); - await execAsync(`sudo mkdir -p ${stickyDiskPath}`); + // Create mount point WITHOUT sudo so the directory is owned by runner user + // This is important because the mount point ownership affects access when nothing is mounted. + await execAsync(`mkdir -p ${stickyDiskPath}`); + // Mount the device with default options await execAsync(`sudo mount ${device} ${stickyDiskPath}`); + // After mounting, set the ownership of the mount point + await execAsync(`sudo chown $(id -u):$(id -g) ${stickyDiskPath}`); core.debug(`${device} has been mounted to ${stickyDiskPath} with expose ID ${exposeId}`); return { device, exposeId }; } diff --git a/src/main.ts b/src/main.ts index 04d0b28..f33782f 100644 --- a/src/main.ts +++ b/src/main.ts @@ -32,11 +32,13 @@ async function maybeFormatBlockDevice(device: string): Promise { try { // Check if device is formatted with ext4 try { + // Need sudo for blkid as it requires root to read block device metadata const {stdout} = await execAsync(`sudo blkid -o value -s TYPE ${device}`); if (stdout.trim() === 'ext4') { core.debug(`Device ${device} is already formatted with ext4`); try { - // Run resize2fs to ensure filesystem uses full block device + // Need sudo for resize2fs as it requires root to modify block device + // This operation preserves existing filesystem ownership and permissions await execAsync(`sudo resize2fs -f ${device}`); core.debug(`Resized ext4 filesystem on ${device}`); } catch (error) { @@ -51,9 +53,13 @@ async function maybeFormatBlockDevice(device: string): Promise { core.debug(`No filesystem found on ${device}, will format it`); } - // Format device with ext4 + // Format device with ext4, setting default ownership to current user. core.debug(`Formatting device ${device} with ext4`); - await execAsync(`sudo mkfs.ext4 -m0 -Enodiscard,lazy_itable_init=1,lazy_journal_init=1 -F ${device}`); + // Need sudo for mkfs.ext4 as it requires root to format block device + // -m0: Disable reserved blocks (all space available to non-root users) + // root_owner=$(id -u):$(id -g): Sets filesystem root directory owner to current (runner) user + // This ensures the filesystem is owned by runner user from the start + await execAsync(`sudo mkfs.ext4 -m0 -E root_owner=$(id -u):$(id -g) -Enodiscard,lazy_itable_init=1,lazy_journal_init=1 -F ${device}`); core.debug(`Successfully formatted ${device} with ext4`); return device; } catch (error) { @@ -71,8 +77,16 @@ async function mountStickyDisk(stickyDiskKey: string, stickyDiskPath: string, si const exposeId = stickyDiskResponse.expose_id; clearTimeout(timeoutId); await maybeFormatBlockDevice(device); - await execAsync(`sudo mkdir -p ${stickyDiskPath}`); + // Create mount point WITHOUT sudo so the directory is owned by runner user + // This is important because the mount point ownership affects access when nothing is mounted. + await execAsync(`mkdir -p ${stickyDiskPath}`); + + // Mount the device with default options await execAsync(`sudo mount ${device} ${stickyDiskPath}`); + + // After mounting, set the ownership of the mount point + await execAsync(`sudo chown $(id -u):$(id -g) ${stickyDiskPath}`); + core.debug(`${device} has been mounted to ${stickyDiskPath} with expose ID ${exposeId}`); return {device, exposeId}; } From 60fc5d58fab25559952460c39598498bda2bf8d6 Mon Sep 17 00:00:00 2001 From: Aayush Shah Date: Thu, 19 Dec 2024 11:37:20 -0500 Subject: [PATCH 06/17] update README (#6) --- README.md | 2 -- 1 file changed, 2 deletions(-) diff --git a/README.md b/README.md index 8e84082..b34419e 100644 --- a/README.md +++ b/README.md @@ -8,8 +8,6 @@

-# Blacksmith Sticky Disk Action - A GitHub Action that helps persist state written to disk across jobs. Each sticky disk is hot-loaded into the runner and mounted at the specified path. The sticky disk is formatted as an ext4 filesystem. From ea2e5f8990fcc02b4c3adf0826b2942ac38b4181 Mon Sep 17 00:00:00 2001 From: Aditya Maru Date: Thu, 16 Jan 2025 18:46:58 -0500 Subject: [PATCH 07/17] README: update README with use cases and arch diagram --- README.md | 81 +++++++++++++++++++++++++++++++++++++++++++-- arch-dark-mode.png | Bin 0 -> 174222 bytes arch-light.png | Bin 0 -> 171415 bytes dist/index.js | 57 +++++++++++++++++++++++++++++++ dist/post/index.js | 57 +++++++++++++++++++++++++++++++ package-lock.json | 12 +++---- package.json | 2 +- 7 files changed, 200 insertions(+), 9 deletions(-) create mode 100644 arch-dark-mode.png create mode 100644 arch-light.png diff --git a/README.md b/README.md index b34419e..524eb85 100644 --- a/README.md +++ b/README.md @@ -11,8 +11,6 @@ A GitHub Action that helps persist state written to disk across jobs. Each sticky disk is hot-loaded into the runner and mounted at the specified path. The sticky disk is formatted as an ext4 filesystem. -A common use case of this action is to cache build artifacts such as NPM packages (egs: node_modules, yarn.lock, etc) across job runs. - ## Usage ```yaml @@ -28,3 +26,82 @@ jobs: ``` Each sticky disk is uniquely identified by a key. The sticky disk will be mounted at the specified path. Once the job completes, the sticky disk will be unmounted and committed for future invocations. At the moment, customers can use up to 10 sticky disks in a single GitHub Action job. + +# Use Cases + +## Bazel Build Caching + +Bazel's remote cache can significantly improve build times, but uploading and downloading cached artifacts can still be a bottleneck. Using sticky disks with Blacksmith runners provides near-instant access to your Bazel caches as they bind mounted into your runners on demand. Our [`useblacksmith/setup-bazel@v2`](https://github.com/useblacksmith/setup-bazel) action is a zero-confg way to use sticky disks to store the disk, repository, and external cache. + +```yaml +jobs: + build: + runs-on: blacksmith + steps: + - uses: actions/checkout@v4 + + - name: Setup Bazel + uses: useblacksmith/setup-bazel@v2 + with: + version: '6.x' + + - name: Build + run: | + bazel build //... +``` + +### Cache Performance Comparison + +| Caching Solution | Cache Size | Average Download Speed | Time to Access | +|-----------------|------------|----------------|----------------| +| GitHub Actions Cache | 6GB | 70 Mbps | ~11.5 minutes | +| Blacksmith Cache | 6GB | 400 Mbps | ~2 minutes | +| Sticky Disks | 6GB | N/A | 3 seconds | + + +## NPM Package Caching + +Node.js projects can have extensive dependency trees, leading to large `node_modules` directories. Sticky disks provide persistent, high-performance storage for your NPM packages. + +```yaml +jobs: + build: + runs-on: blacksmith + steps: + - uses: actions/checkout@v4 + + - name: Setup Node.js + uses: actions/setup-node@v4 + with: + node-version: '18.x' + + - name: Mount NPM Cache + uses: useblacksmith/stickydisk@v1 + with: + key: ${{ github.repository }}-npm-cache + path: ~/.npm + + - name: Mount node_modules + uses: useblacksmith/stickydisk@v1 + with: + key: ${{ github.repository }}-node-modules + path: ./node_modules + + - name: Install Dependencies + run: npm ci + + - name: Build + run: npm run build +``` + +# Architecture + +

+ + + + + + Blacksmith Logo + +

diff --git a/arch-dark-mode.png b/arch-dark-mode.png new file mode 100644 index 0000000000000000000000000000000000000000..1a71e334cdeea2740c6a2da22f6c55e40a6474ac GIT binary patch literal 174222 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⁢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
YM;GE@ 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 literal 0 HcmV?d00001 diff --git a/arch-light.png b/arch-light.png new file mode 100644 index 0000000000000000000000000000000000000000..83f7980e52666555e50e8c44aaa53b2463130b01 GIT binary patch literal 171415 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
    =td2+dc+ckqn* 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 literal 0 HcmV?d00001 diff --git a/dist/index.js b/dist/index.js index 1d07b6b..7faeb22 100644 --- a/dist/index.js +++ b/dist/index.js @@ -36124,6 +36124,54 @@ const CommitStickyDiskResponse = /*@__PURE__*/ proto3.makeMessageType( [], ); +/** + * @generated from message stickydisk.v1.Metric + */ +const Metric = /*@__PURE__*/ proto3.makeMessageType( + "stickydisk.v1.Metric", + () => [ + { no: 1, name: "int_value", kind: "scalar", T: 3 /* ScalarType.INT64 */, oneof: "value" }, + { no: 2, name: "double_value", kind: "scalar", T: 1 /* ScalarType.DOUBLE */, oneof: "value" }, + { no: 3, name: "type", kind: "enum", T: proto3.getEnumType(Metric_MetricType) }, + ], +); + +/** + * @generated from enum stickydisk.v1.Metric.MetricType + */ +const Metric_MetricType = /*@__PURE__*/ proto3.makeEnum( + "stickydisk.v1.Metric.MetricType", + [ + {no: 0, name: "METRIC_TYPE_UNSPECIFIED"}, + {no: 1, name: "BPA_HOTLOAD_DURATION_MS"}, + {no: 2, name: "BPA_BUILDKITD_READY_DURATION_MS"}, + {no: 3, name: "BPA_BUILDKITD_SHUTDOWN_DURATION_MS"}, + {no: 4, name: "BPA_FEATURE_USAGE"}, + {no: 5, name: "BAZEL_HOTLOAD_DURATION_MS"}, + {no: 6, name: "BAZEL_FEATURE_USAGE"}, + ], +); + +/** + * @generated from message stickydisk.v1.ReportMetricRequest + */ +const ReportMetricRequest = /*@__PURE__*/ proto3.makeMessageType( + "stickydisk.v1.ReportMetricRequest", + () => [ + { no: 1, name: "repo_name", kind: "scalar", T: 9 /* ScalarType.STRING */ }, + { no: 2, name: "region", kind: "scalar", T: 9 /* ScalarType.STRING */ }, + { no: 3, name: "metric", kind: "message", T: Metric }, + ], +); + +/** + * @generated from message stickydisk.v1.ReportMetricResponse + */ +const ReportMetricResponse = /*@__PURE__*/ proto3.makeMessageType( + "stickydisk.v1.ReportMetricResponse", + [], +); + /** * @generated from message stickydisk.v1.UpRequest */ @@ -36183,6 +36231,15 @@ const StickyDiskService = { O: UpResponse, kind: MethodKind.Unary, }, + /** + * @generated from rpc stickydisk.v1.StickyDiskService.ReportMetric + */ + reportMetric: { + name: "ReportMetric", + I: ReportMetricRequest, + O: ReportMetricResponse, + kind: MethodKind.Unary, + }, } }; diff --git a/dist/post/index.js b/dist/post/index.js index bcefe50..62881f2 100644 --- a/dist/post/index.js +++ b/dist/post/index.js @@ -36124,6 +36124,54 @@ const CommitStickyDiskResponse = /*@__PURE__*/ proto3.makeMessageType( [], ); +/** + * @generated from message stickydisk.v1.Metric + */ +const Metric = /*@__PURE__*/ proto3.makeMessageType( + "stickydisk.v1.Metric", + () => [ + { no: 1, name: "int_value", kind: "scalar", T: 3 /* ScalarType.INT64 */, oneof: "value" }, + { no: 2, name: "double_value", kind: "scalar", T: 1 /* ScalarType.DOUBLE */, oneof: "value" }, + { no: 3, name: "type", kind: "enum", T: proto3.getEnumType(Metric_MetricType) }, + ], +); + +/** + * @generated from enum stickydisk.v1.Metric.MetricType + */ +const Metric_MetricType = /*@__PURE__*/ proto3.makeEnum( + "stickydisk.v1.Metric.MetricType", + [ + {no: 0, name: "METRIC_TYPE_UNSPECIFIED"}, + {no: 1, name: "BPA_HOTLOAD_DURATION_MS"}, + {no: 2, name: "BPA_BUILDKITD_READY_DURATION_MS"}, + {no: 3, name: "BPA_BUILDKITD_SHUTDOWN_DURATION_MS"}, + {no: 4, name: "BPA_FEATURE_USAGE"}, + {no: 5, name: "BAZEL_HOTLOAD_DURATION_MS"}, + {no: 6, name: "BAZEL_FEATURE_USAGE"}, + ], +); + +/** + * @generated from message stickydisk.v1.ReportMetricRequest + */ +const ReportMetricRequest = /*@__PURE__*/ proto3.makeMessageType( + "stickydisk.v1.ReportMetricRequest", + () => [ + { no: 1, name: "repo_name", kind: "scalar", T: 9 /* ScalarType.STRING */ }, + { no: 2, name: "region", kind: "scalar", T: 9 /* ScalarType.STRING */ }, + { no: 3, name: "metric", kind: "message", T: Metric }, + ], +); + +/** + * @generated from message stickydisk.v1.ReportMetricResponse + */ +const ReportMetricResponse = /*@__PURE__*/ proto3.makeMessageType( + "stickydisk.v1.ReportMetricResponse", + [], +); + /** * @generated from message stickydisk.v1.UpRequest */ @@ -36183,6 +36231,15 @@ const StickyDiskService = { O: UpResponse, kind: MethodKind.Unary, }, + /** + * @generated from rpc stickydisk.v1.StickyDiskService.ReportMetric + */ + reportMetric: { + name: "ReportMetric", + I: ReportMetricRequest, + O: ReportMetricResponse, + kind: MethodKind.Unary, + }, } }; diff --git a/package-lock.json b/package-lock.json index 961ce14..ecaa082 100644 --- a/package-lock.json +++ b/package-lock.json @@ -7,7 +7,7 @@ "name": "root", "dependencies": { "@actions/core": "^1.10.1", - "@buf/blacksmith_vm-agent.connectrpc_es": "^1.6.1-20241213043610-906584953dd9.2", + "@buf/blacksmith_vm-agent.connectrpc_es": "^1.6.1-20241220192643-e85a9caa965d.2", "@bufbuild/connect": "^0.13.0", "@bufbuild/connect-web": "^0.13.0", "@bufbuild/protobuf": "^1.4.2", @@ -598,17 +598,17 @@ "license": "MIT" }, "node_modules/@buf/blacksmith_vm-agent.bufbuild_es": { - "version": "1.10.0-20241213043610-906584953dd9.1", - "resolved": "https://buf.build/gen/npm/v1/@buf/blacksmith_vm-agent.bufbuild_es/-/blacksmith_vm-agent.bufbuild_es-1.10.0-20241213043610-906584953dd9.1.tgz", + "version": "1.10.0-20241220192643-e85a9caa965d.1", + "resolved": "https://buf.build/gen/npm/v1/@buf/blacksmith_vm-agent.bufbuild_es/-/blacksmith_vm-agent.bufbuild_es-1.10.0-20241220192643-e85a9caa965d.1.tgz", "peerDependencies": { "@bufbuild/protobuf": "^1.10.0" } }, "node_modules/@buf/blacksmith_vm-agent.connectrpc_es": { - "version": "1.6.1-20241213043610-906584953dd9.2", - "resolved": "https://buf.build/gen/npm/v1/@buf/blacksmith_vm-agent.connectrpc_es/-/blacksmith_vm-agent.connectrpc_es-1.6.1-20241213043610-906584953dd9.2.tgz", + "version": "1.6.1-20241220192643-e85a9caa965d.2", + "resolved": "https://buf.build/gen/npm/v1/@buf/blacksmith_vm-agent.connectrpc_es/-/blacksmith_vm-agent.connectrpc_es-1.6.1-20241220192643-e85a9caa965d.2.tgz", "dependencies": { - "@buf/blacksmith_vm-agent.bufbuild_es": "1.10.0-20241213043610-906584953dd9.1" + "@buf/blacksmith_vm-agent.bufbuild_es": "1.10.0-20241220192643-e85a9caa965d.1" }, "peerDependencies": { "@connectrpc/connect": "^1.6.1" diff --git a/package.json b/package.json index 6ca1438..e03febc 100644 --- a/package.json +++ b/package.json @@ -10,7 +10,7 @@ }, "dependencies": { "@actions/core": "^1.10.1", - "@buf/blacksmith_vm-agent.connectrpc_es": "^1.6.1-20241213043610-906584953dd9.2", + "@buf/blacksmith_vm-agent.connectrpc_es": "^1.6.1-20241220192643-e85a9caa965d.2", "@bufbuild/connect": "^0.13.0", "@bufbuild/connect-web": "^0.13.0", "@bufbuild/protobuf": "^1.4.2", From 3d6bf16bc81a00dbab026cebbbf8c18cbd55a215 Mon Sep 17 00:00:00 2001 From: Aditya Maru Date: Thu, 16 Jan 2025 19:02:32 -0500 Subject: [PATCH 08/17] .github: fix typo --- README.md | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/README.md b/README.md index 524eb85..74527a5 100644 --- a/README.md +++ b/README.md @@ -31,7 +31,7 @@ Each sticky disk is uniquely identified by a key. The sticky disk will be mounte ## Bazel Build Caching -Bazel's remote cache can significantly improve build times, but uploading and downloading cached artifacts can still be a bottleneck. Using sticky disks with Blacksmith runners provides near-instant access to your Bazel caches as they bind mounted into your runners on demand. Our [`useblacksmith/setup-bazel@v2`](https://github.com/useblacksmith/setup-bazel) action is a zero-confg way to use sticky disks to store the disk, repository, and external cache. +Bazel's remote cache can significantly improve build times, but uploading and downloading cached artifacts can still be a bottleneck. Using sticky disks with Blacksmith runners provides near-instant access to your Bazel caches as they are bind mounted into your runners on demand. Our [`useblacksmith/setup-bazel@v2`](https://github.com/useblacksmith/setup-bazel) action is a zero-confg way to use sticky disks to store the disk, repository, and external cache. ```yaml jobs: From 6d5bf41e5cb8f5bfbe0f9f61da51bd4239c3c9e2 Mon Sep 17 00:00:00 2001 From: Aditya Maru Date: Thu, 16 Jan 2025 19:06:48 -0500 Subject: [PATCH 09/17] README: fix nits --- README.md | 92 +++++++++++++++++++++++-------------------------------- 1 file changed, 39 insertions(+), 53 deletions(-) diff --git a/README.md b/README.md index 74527a5..faea109 100644 --- a/README.md +++ b/README.md @@ -11,54 +11,22 @@ A GitHub Action that helps persist state written to disk across jobs. Each sticky disk is hot-loaded into the runner and mounted at the specified path. The sticky disk is formatted as an ext4 filesystem. -## Usage +# Architecture -```yaml -jobs: - build: - runs-on: blacksmith - steps: - - name: Cache NPM packages - uses: useblacksmith/stickydisk@v1 - with: - key: ${{ github.repository }}-npm-cache - path: ~/.node_modules -``` +

    + + + + + + Blacksmith Logo + +

    -Each sticky disk is uniquely identified by a key. The sticky disk will be mounted at the specified path. Once the job completes, the sticky disk will be unmounted and committed for future invocations. At the moment, customers can use up to 10 sticky disks in a single GitHub Action job. +Blacksmith stores sticky disk artifacts in a secure, highly performant Ceph cluster. Our runners proxy their requests through our Storage Agents to interact with the Ceph cluster. Each sticky disk is uniquely identified by a key. When a GitHub Action job requests a sticky disk, the last committed snapshot will be cloned and mounted into the runner at the specified path. Once the job completes, the sticky disk will be unmounted and committed for future invocations. At the moment, customers can use up to 5 sticky disks in a single GitHub Action job. # Use Cases -## Bazel Build Caching - -Bazel's remote cache can significantly improve build times, but uploading and downloading cached artifacts can still be a bottleneck. Using sticky disks with Blacksmith runners provides near-instant access to your Bazel caches as they are bind mounted into your runners on demand. Our [`useblacksmith/setup-bazel@v2`](https://github.com/useblacksmith/setup-bazel) action is a zero-confg way to use sticky disks to store the disk, repository, and external cache. - -```yaml -jobs: - build: - runs-on: blacksmith - steps: - - uses: actions/checkout@v4 - - - name: Setup Bazel - uses: useblacksmith/setup-bazel@v2 - with: - version: '6.x' - - - name: Build - run: | - bazel build //... -``` - -### Cache Performance Comparison - -| Caching Solution | Cache Size | Average Download Speed | Time to Access | -|-----------------|------------|----------------|----------------| -| GitHub Actions Cache | 6GB | 70 Mbps | ~11.5 minutes | -| Blacksmith Cache | 6GB | 400 Mbps | ~2 minutes | -| Sticky Disks | 6GB | N/A | 3 seconds | - - ## NPM Package Caching Node.js projects can have extensive dependency trees, leading to large `node_modules` directories. Sticky disks provide persistent, high-performance storage for your NPM packages. @@ -94,14 +62,32 @@ jobs: run: npm run build ``` -# Architecture +## Bazel Build Caching + +Bazel's remote cache can significantly improve build times, but uploading and downloading cached artifacts can still be a bottleneck. Using sticky disks with Blacksmith runners provides near-instant access to your Bazel caches as they are bind mounted into your runners on demand. Our [`useblacksmith/setup-bazel@v2`](https://github.com/useblacksmith/setup-bazel) action is a zero-confg way to use sticky disks to store the disk, repository, and external cache. + +```yaml +jobs: + build: + runs-on: blacksmith + steps: + - uses: actions/checkout@v4 + + - name: Setup Bazel + uses: useblacksmith/setup-bazel@v2 + with: + version: '6.x' + + - name: Build + run: | + bazel build //... +``` + +### Cache Performance Comparison + +| Caching Solution | Cache Size | Average Download Speed | Time to Access | +|-----------------|------------|----------------|----------------| +| GitHub Actions Cache | 6GB | 90 MB/s | ~1m6s | +| Blacksmith Cache | 6GB | 400 MB/s | ~15s | +| Sticky Disks | 6GB | N/A | 3 seconds | -

    - - - - - - Blacksmith Logo - -

    From af6814d145d580e329aa80950d4aa8bb0bccc265 Mon Sep 17 00:00:00 2001 From: Aditya Maru Date: Thu, 16 Jan 2025 19:17:32 -0500 Subject: [PATCH 10/17] Update README.md --- README.md | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/README.md b/README.md index faea109..4ac8811 100644 --- a/README.md +++ b/README.md @@ -23,7 +23,7 @@ The sticky disk is formatted as an ext4 filesystem.

    -Blacksmith stores sticky disk artifacts in a secure, highly performant Ceph cluster. Our runners proxy their requests through our Storage Agents to interact with the Ceph cluster. Each sticky disk is uniquely identified by a key. When a GitHub Action job requests a sticky disk, the last committed snapshot will be cloned and mounted into the runner at the specified path. Once the job completes, the sticky disk will be unmounted and committed for future invocations. At the moment, customers can use up to 5 sticky disks in a single GitHub Action job. +Blacksmith stores sticky disk artifacts in a secure, highly performant Ceph cluster, running on local NVMe drives. Our runners proxy their requests through our Storage Agents to interact with the Ceph cluster. Each sticky disk is uniquely identified by a key. When a GitHub Action job requests a sticky disk, the last committed snapshot will be cloned and mounted into the runner at the specified path. Once the job completes, the sticky disk will be unmounted and committed for future invocations. At the moment, customers can use up to 5 sticky disks in a single GitHub Action job. # Use Cases From b26d421d50c7ad03efd9a28e1117a0a0c76f7f33 Mon Sep 17 00:00:00 2001 From: Aditya Maru Date: Thu, 16 Jan 2025 19:24:43 -0500 Subject: [PATCH 11/17] .github: clarify in first sentence --- README.md | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/README.md b/README.md index 4ac8811..6fa0ede 100644 --- a/README.md +++ b/README.md @@ -8,7 +8,7 @@

    -A GitHub Action that helps persist state written to disk across jobs. Each sticky disk is hot-loaded into the runner and mounted at the specified path. +A GitHub Action that helps persist state written to disk across jobs. This action can serve as a superior alternative to the Actions cache, especially when the cache artifacts are extremely large. Each sticky disk is hot-loaded into the runner and mounted at the specified path. The sticky disk is formatted as an ext4 filesystem. # Architecture From a978eb7f86243ef184b728378ceec00ad81d3431 Mon Sep 17 00:00:00 2001 From: Aditya Maru Date: Thu, 16 Jan 2025 19:25:29 -0500 Subject: [PATCH 12/17] Update README.md --- README.md | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/README.md b/README.md index 6fa0ede..e871ede 100644 --- a/README.md +++ b/README.md @@ -8,7 +8,7 @@

    -A GitHub Action that helps persist state written to disk across jobs. This action can serve as a superior alternative to the Actions cache, especially when the cache artifacts are extremely large. Each sticky disk is hot-loaded into the runner and mounted at the specified path. +A GitHub Action that helps persist state written to disk across jobs. This action can serve as a superior alternative to the [Actions cache](https://github.com/useblacksmith/cache), especially when the cache artifacts are extremely large. Each sticky disk is hot-loaded into the runner and mounted at the specified path. The sticky disk is formatted as an ext4 filesystem. # Architecture From 7464a4c82c0ade1a243a3ee1b3c7b1b79dd3b417 Mon Sep 17 00:00:00 2001 From: Aditya Jayaprakash Date: Fri, 17 Jan 2025 14:43:39 -0500 Subject: [PATCH 13/17] Update README.md --- README.md | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/README.md b/README.md index e871ede..c1304c5 100644 --- a/README.md +++ b/README.md @@ -39,7 +39,7 @@ jobs: - uses: actions/checkout@v4 - name: Setup Node.js - uses: actions/setup-node@v4 + uses: useblacksmith/setup-node@v5 with: node-version: '18.x' From a85354cb43244cb135088514ddb1ab0d07c13a95 Mon Sep 17 00:00:00 2001 From: Aditya Maru Date: Tue, 21 Jan 2025 19:30:42 -0500 Subject: [PATCH 14/17] src: add sync before umount --- dist/post/index.js | 4 +++- src/post.ts | 5 ++++- 2 files changed, 7 insertions(+), 2 deletions(-) diff --git a/dist/post/index.js b/dist/post/index.js index 62881f2..0d62b1f 100644 --- a/dist/post/index.js +++ b/dist/post/index.js @@ -36333,7 +36333,9 @@ async function run() { core.debug(`${stickyDiskPath} is not mounted, skipping unmount`); return; } - // First try to unmount with retries + // Ensure all pending writes are flushed to disk before unmounting. + await execAsync('sync'); + // Unmount with retries. for (let attempt = 1; attempt <= 10; attempt++) { try { await execAsync(`sudo umount ${stickyDiskPath}`); diff --git a/src/post.ts b/src/post.ts index bedff4b..412d19c 100644 --- a/src/post.ts +++ b/src/post.ts @@ -80,7 +80,10 @@ async function run(): Promise { return; } - // First try to unmount with retries + // Ensure all pending writes are flushed to disk before unmounting. + await execAsync('sync'); + + // Unmount with retries. for (let attempt = 1; attempt <= 10; attempt++) { try { await execAsync(`sudo umount ${stickyDiskPath}`); From 5175c4c79a1fa919f6f7b264f9896fe16e82007b Mon Sep 17 00:00:00 2001 From: Aditya Maru Date: Mon, 10 Feb 2025 15:18:31 -0500 Subject: [PATCH 15/17] src: increase timeout to the same as build-push-action --- dist/index.js | 10 +++++++--- dist/post/index.js | 2 +- package-lock.json | 33 +++++++++++++++++++++++++++------ package.json | 2 +- src/main.ts | 11 ++++++++--- src/post.ts | 2 +- 6 files changed, 45 insertions(+), 15 deletions(-) diff --git a/dist/index.js b/dist/index.js index 7faeb22..d2d4851 100644 --- a/dist/index.js +++ b/dist/index.js @@ -36263,6 +36263,10 @@ function createStickyDiskClient() { const execAsync = (0,external_util_.promisify)(external_child_process_.exec); +// stickyDiskTimeoutMs states the max amount of time this action will wait for the VM agent to +// expose the sticky disk from the storage agent, map it onto the host and then patch the drive +// into the VM. +const stickyDiskTimeoutMs = 45000; async function getStickyDisk(stickyDiskKey, options) { const client = createStickyDiskClient(); core.debug(`Getting sticky disk for ${stickyDiskKey}`); @@ -36320,13 +36324,13 @@ async function maybeFormatBlockDevice(device) { } catch (error) { if (error instanceof Error) { - core.error(`Failed to format device ${device}: ${error}`); + core.warning(`Failed to format device ${device}: ${error}`); } throw error; } } async function mountStickyDisk(stickyDiskKey, stickyDiskPath, signal, controller) { - const timeoutId = setTimeout(() => controller.abort(), 15000); + const timeoutId = setTimeout(() => controller.abort(), stickyDiskTimeoutMs); const stickyDiskResponse = await getStickyDisk(stickyDiskKey, { signal }); const device = stickyDiskResponse.device; const exposeId = stickyDiskResponse.expose_id; @@ -36374,7 +36378,7 @@ async function run() { } } if (stickyDiskError) { - core.setFailed(`Error getting sticky disk: ${stickyDiskError}`); + core.warning(`Error getting sticky disk: ${stickyDiskError}`); } } run(); diff --git a/dist/post/index.js b/dist/post/index.js index 0d62b1f..e6fd9f9 100644 --- a/dist/post/index.js +++ b/dist/post/index.js @@ -36360,7 +36360,7 @@ async function run() { } catch (error) { if (error instanceof Error) { - core.error(`Failed to cleanup and commit sticky disk at ${stickyDiskPath}: ${error}`); + core.warning(`Failed to cleanup and commit sticky disk at ${stickyDiskPath}: ${error}`); } } } diff --git a/package-lock.json b/package-lock.json index ecaa082..48de3cc 100644 --- a/package-lock.json +++ b/package-lock.json @@ -7,7 +7,7 @@ "name": "root", "dependencies": { "@actions/core": "^1.10.1", - "@buf/blacksmith_vm-agent.connectrpc_es": "^1.6.1-20241220192643-e85a9caa965d.2", + "@buf/blacksmith_vm-agent.connectrpc_es": "^1.6.1-20250209182455-7d83cfb8ddb1.2", "@bufbuild/connect": "^0.13.0", "@bufbuild/connect-web": "^0.13.0", "@bufbuild/protobuf": "^1.4.2", @@ -598,17 +598,38 @@ "license": "MIT" }, "node_modules/@buf/blacksmith_vm-agent.bufbuild_es": { - "version": "1.10.0-20241220192643-e85a9caa965d.1", - "resolved": "https://buf.build/gen/npm/v1/@buf/blacksmith_vm-agent.bufbuild_es/-/blacksmith_vm-agent.bufbuild_es-1.10.0-20241220192643-e85a9caa965d.1.tgz", + "version": "1.10.0-20250209182455-7d83cfb8ddb1.1", + "resolved": "https://buf.build/gen/npm/v1/@buf/blacksmith_vm-agent.bufbuild_es/-/blacksmith_vm-agent.bufbuild_es-1.10.0-20250209182455-7d83cfb8ddb1.1.tgz", + "dependencies": { + "@buf/googleapis_googleapis.bufbuild_es": "1.10.0-20250203201857-83c0f6c19b2f.1" + }, "peerDependencies": { "@bufbuild/protobuf": "^1.10.0" } }, "node_modules/@buf/blacksmith_vm-agent.connectrpc_es": { - "version": "1.6.1-20241220192643-e85a9caa965d.2", - "resolved": "https://buf.build/gen/npm/v1/@buf/blacksmith_vm-agent.connectrpc_es/-/blacksmith_vm-agent.connectrpc_es-1.6.1-20241220192643-e85a9caa965d.2.tgz", + "version": "1.6.1-20250209182455-7d83cfb8ddb1.2", + "resolved": "https://buf.build/gen/npm/v1/@buf/blacksmith_vm-agent.connectrpc_es/-/blacksmith_vm-agent.connectrpc_es-1.6.1-20250209182455-7d83cfb8ddb1.2.tgz", + "dependencies": { + "@buf/blacksmith_vm-agent.bufbuild_es": "1.10.0-20250209182455-7d83cfb8ddb1.1", + "@buf/googleapis_googleapis.connectrpc_es": "1.6.1-20250203201857-83c0f6c19b2f.2" + }, + "peerDependencies": { + "@connectrpc/connect": "^1.6.1" + } + }, + "node_modules/@buf/googleapis_googleapis.bufbuild_es": { + "version": "1.10.0-20250203201857-83c0f6c19b2f.1", + "resolved": "https://buf.build/gen/npm/v1/@buf/googleapis_googleapis.bufbuild_es/-/googleapis_googleapis.bufbuild_es-1.10.0-20250203201857-83c0f6c19b2f.1.tgz", + "peerDependencies": { + "@bufbuild/protobuf": "^1.10.0" + } + }, + "node_modules/@buf/googleapis_googleapis.connectrpc_es": { + "version": "1.6.1-20250203201857-83c0f6c19b2f.2", + "resolved": "https://buf.build/gen/npm/v1/@buf/googleapis_googleapis.connectrpc_es/-/googleapis_googleapis.connectrpc_es-1.6.1-20250203201857-83c0f6c19b2f.2.tgz", "dependencies": { - "@buf/blacksmith_vm-agent.bufbuild_es": "1.10.0-20241220192643-e85a9caa965d.1" + "@buf/googleapis_googleapis.bufbuild_es": "1.10.0-20250203201857-83c0f6c19b2f.1" }, "peerDependencies": { "@connectrpc/connect": "^1.6.1" diff --git a/package.json b/package.json index e03febc..37d77fc 100644 --- a/package.json +++ b/package.json @@ -10,7 +10,7 @@ }, "dependencies": { "@actions/core": "^1.10.1", - "@buf/blacksmith_vm-agent.connectrpc_es": "^1.6.1-20241220192643-e85a9caa965d.2", + "@buf/blacksmith_vm-agent.connectrpc_es": "^1.6.1-20250209182455-7d83cfb8ddb1.2", "@bufbuild/connect": "^0.13.0", "@bufbuild/connect-web": "^0.13.0", "@bufbuild/protobuf": "^1.4.2", diff --git a/src/main.ts b/src/main.ts index f33782f..fd6362b 100644 --- a/src/main.ts +++ b/src/main.ts @@ -6,6 +6,11 @@ import { createStickyDiskClient } from './utils'; const execAsync = promisify(exec); +// stickyDiskTimeoutMs states the max amount of time this action will wait for the VM agent to +// expose the sticky disk from the storage agent, map it onto the host and then patch the drive +// into the VM. +const stickyDiskTimeoutMs = 45000; + async function getStickyDisk(stickyDiskKey: string, options?: {signal?: AbortSignal}): Promise<{expose_id: string; device: string}> { const client = createStickyDiskClient(); @@ -64,14 +69,14 @@ async function maybeFormatBlockDevice(device: string): Promise { return device; } catch (error) { if (error instanceof Error) { - core.error(`Failed to format device ${device}: ${error}`); + core.warning(`Failed to format device ${device}: ${error}`); } throw error; } } async function mountStickyDisk(stickyDiskKey: string, stickyDiskPath: string, signal: AbortSignal, controller: AbortController): Promise<{device: string, exposeId: string}> { - const timeoutId = setTimeout(() => controller.abort(), 15000); + const timeoutId = setTimeout(() => controller.abort(), stickyDiskTimeoutMs); const stickyDiskResponse = await getStickyDisk(stickyDiskKey, {signal}); const device = stickyDiskResponse.device; const exposeId = stickyDiskResponse.expose_id; @@ -126,7 +131,7 @@ async function run(): Promise { } if (stickyDiskError) { - core.setFailed(`Error getting sticky disk: ${stickyDiskError}`); + core.warning(`Error getting sticky disk: ${stickyDiskError}`); } } diff --git a/src/post.ts b/src/post.ts index 412d19c..1acf6f3 100644 --- a/src/post.ts +++ b/src/post.ts @@ -106,7 +106,7 @@ async function run(): Promise { } } catch (error) { if (error instanceof Error) { - core.error(`Failed to cleanup and commit sticky disk at ${stickyDiskPath}: ${error}`); + core.warning(`Failed to cleanup and commit sticky disk at ${stickyDiskPath}: ${error}`); } } } From eb09d7fe84e78072084a847bc1b3ee2e9d8f3f81 Mon Sep 17 00:00:00 2001 From: Aayush Shah Date: Thu, 27 Feb 2025 22:22:11 -0500 Subject: [PATCH 16/17] src: explicitly flush journal before umounting (#12) * src: explicitly flush journal before umounting * *: generated code * *: upgrade @buf/blacksmith_vm-agent.connectrpc_es@latest --- .github/workflows/basic.yaml | 45 +++++++------ dist/index.js | 42 ++++++++++++ dist/post/index.js | 79 ++++++++++++++++++----- package-lock.json | 12 ++-- package.json | 2 +- src/post.ts | 121 ++++++++++++++++++++++------------- 6 files changed, 212 insertions(+), 89 deletions(-) diff --git a/.github/workflows/basic.yaml b/.github/workflows/basic.yaml index dd780c3..1bd1124 100644 --- a/.github/workflows/basic.yaml +++ b/.github/workflows/basic.yaml @@ -6,68 +6,71 @@ on: jobs: test-sticky-disk: name: Test Sticky Disk - runs-on: blacksmith-staging + runs-on: blacksmith strategy: matrix: iteration: [1, 2, 3, 4, 5, 6, 7, 8, 9, 10] fail-fast: false steps: + - name: Create directory called + run: sudo mkdir -p ./shouldseethis + - name: Mount First Sticky Disk - uses: useblacksmith/stickydisk@initial-commit + uses: useblacksmith/stickydisk@main with: key: foo - path: /shouldseethis + path: ./shouldseethis - name: List first directory if exists run: | - if [ -d "/shouldseethis" ]; then - ls -la /shouldseethis + if [ -d "./shouldseethis" ]; then + ls -la ./shouldseethis fi - name: Write test file to first disk - run: sudo sh -c 'echo "Hello from first sticky disk" > /shouldseethis/test.txt' + run: sudo sh -c 'echo "Hello from first sticky disk" > ./shouldseethis/test.txt' - name: Mount Second Sticky Disk - uses: useblacksmith/stickydisk@initial-commit + uses: useblacksmith/stickydisk@main with: key: bar - path: /seconddisk + path: ./seconddisk - name: List second directory if exists run: | - if [ -d "/seconddisk" ]; then - ls -la /seconddisk + if [ -d "./seconddisk" ]; then + ls -la ./seconddisk fi - name: Write test file to second disk - run: sudo sh -c 'echo "Hello from second sticky disk" > /seconddisk/test.txt' + run: sudo sh -c 'echo "Hello from second sticky disk" > ./seconddisk/test.txt' - name: Mount Third Sticky Disk - uses: useblacksmith/stickydisk@initial-commit + uses: useblacksmith/stickydisk@main with: key: baz - path: /thirddisk + path: ./thirddisk - name: List third directory if exists run: | - if [ -d "/thirddisk" ]; then - ls -la /thirddisk + if [ -d "./thirddisk" ]; then + ls -la ./thirddisk fi - name: Write test file to third disk - run: sudo sh -c 'echo "Hello from third sticky disk" > /thirddisk/test.txt' + run: sudo sh -c 'echo "Hello from third sticky disk" > ./thirddisk/test.txt' - name: Mount First Sticky Disk Again - uses: useblacksmith/stickydisk@initial-commit + uses: useblacksmith/stickydisk@main with: key: foo - path: /shouldseethis_again + path: ./shouldseethis_again - name: List first directory again if exists run: | - if [ -d "/shouldseethis_again" ]; then - ls -la /shouldseethis_again + if [ -d "./shouldseethis_again" ]; then + ls -la ./shouldseethis_again fi - name: Write test file to first disk again - run: sudo sh -c 'echo "Hello again from first sticky disk" > /shouldseethis_again/test2.txt' + run: sudo sh -c 'echo "Hello again from first sticky disk" > ./shouldseethis_again/test2.txt' diff --git a/dist/index.js b/dist/index.js index d2d4851..58880be 100644 --- a/dist/index.js +++ b/dist/index.js @@ -36074,6 +36074,18 @@ const connect_node_adapter_fallback = (request, response) => { +/** + * @generated from enum stickydisk.v1.Architecture + */ +const Architecture = /*@__PURE__*/ proto3.makeEnum( + "stickydisk.v1.Architecture", + [ + {no: 0, name: "ARCHITECTURE_UNSPECIFIED", localName: "UNSPECIFIED"}, + {no: 1, name: "ARCHITECTURE_AMD64", localName: "AMD64"}, + {no: 2, name: "ARCHITECTURE_ARM64", localName: "ARM64"}, + ], +); + /** * @generated from message stickydisk.v1.GetStickyDiskRequest */ @@ -36188,6 +36200,27 @@ const UpResponse = /*@__PURE__*/ proto3.makeMessageType( [], ); +/** + * @generated from message stickydisk.v1.QueueDockerJobRequest + */ +const QueueDockerJobRequest = /*@__PURE__*/ proto3.makeMessageType( + "stickydisk.v1.QueueDockerJobRequest", + () => [ + { no: 1, name: "job_name", kind: "scalar", T: 9 /* ScalarType.STRING */ }, + { no: 2, name: "tailscale_hostname", kind: "scalar", T: 9 /* ScalarType.STRING */ }, + { no: 3, name: "vm_id", kind: "scalar", T: 9 /* ScalarType.STRING */ }, + { no: 4, name: "arch", kind: "enum", T: proto3.getEnumType(Architecture) }, + ], +); + +/** + * @generated from message stickydisk.v1.QueueDockerJobResponse + */ +const QueueDockerJobResponse = /*@__PURE__*/ proto3.makeMessageType( + "stickydisk.v1.QueueDockerJobResponse", + [], +); + ;// CONCATENATED MODULE: ./node_modules/@buf/blacksmith_vm-agent.connectrpc_es/stickydisk/v1/stickydisk_connect.js // @generated by protoc-gen-connect-es v1.6.1 @@ -36240,6 +36273,15 @@ const StickyDiskService = { O: ReportMetricResponse, kind: MethodKind.Unary, }, + /** + * @generated from rpc stickydisk.v1.StickyDiskService.QueueDockerJob + */ + queueDockerJob: { + name: "QueueDockerJob", + I: QueueDockerJobRequest, + O: QueueDockerJobResponse, + kind: MethodKind.Unary, + }, } }; diff --git a/dist/post/index.js b/dist/post/index.js index e6fd9f9..5c70a49 100644 --- a/dist/post/index.js +++ b/dist/post/index.js @@ -36074,6 +36074,18 @@ const connect_node_adapter_fallback = (request, response) => { +/** + * @generated from enum stickydisk.v1.Architecture + */ +const Architecture = /*@__PURE__*/ proto3.makeEnum( + "stickydisk.v1.Architecture", + [ + {no: 0, name: "ARCHITECTURE_UNSPECIFIED", localName: "UNSPECIFIED"}, + {no: 1, name: "ARCHITECTURE_AMD64", localName: "AMD64"}, + {no: 2, name: "ARCHITECTURE_ARM64", localName: "ARM64"}, + ], +); + /** * @generated from message stickydisk.v1.GetStickyDiskRequest */ @@ -36188,6 +36200,27 @@ const UpResponse = /*@__PURE__*/ proto3.makeMessageType( [], ); +/** + * @generated from message stickydisk.v1.QueueDockerJobRequest + */ +const QueueDockerJobRequest = /*@__PURE__*/ proto3.makeMessageType( + "stickydisk.v1.QueueDockerJobRequest", + () => [ + { no: 1, name: "job_name", kind: "scalar", T: 9 /* ScalarType.STRING */ }, + { no: 2, name: "tailscale_hostname", kind: "scalar", T: 9 /* ScalarType.STRING */ }, + { no: 3, name: "vm_id", kind: "scalar", T: 9 /* ScalarType.STRING */ }, + { no: 4, name: "arch", kind: "enum", T: proto3.getEnumType(Architecture) }, + ], +); + +/** + * @generated from message stickydisk.v1.QueueDockerJobResponse + */ +const QueueDockerJobResponse = /*@__PURE__*/ proto3.makeMessageType( + "stickydisk.v1.QueueDockerJobResponse", + [], +); + ;// CONCATENATED MODULE: ./node_modules/@buf/blacksmith_vm-agent.connectrpc_es/stickydisk/v1/stickydisk_connect.js // @generated by protoc-gen-connect-es v1.6.1 @@ -36240,6 +36273,15 @@ const StickyDiskService = { O: ReportMetricResponse, kind: MethodKind.Unary, }, + /** + * @generated from rpc stickydisk.v1.StickyDiskService.QueueDockerJob + */ + queueDockerJob: { + name: "QueueDockerJob", + I: QueueDockerJobRequest, + O: QueueDockerJobResponse, + kind: MethodKind.Unary, + }, } }; @@ -36266,7 +36308,7 @@ const execAsync = (0,external_util_.promisify)(external_child_process_.exec); async function commitStickydisk(exposeId, stickyDiskKey) { core.info(`Committing sticky disk ${stickyDiskKey} with expose ID ${exposeId}`); if (!exposeId || !stickyDiskKey) { - core.warning('No expose ID or sticky disk key found, cannot report sticky disk to Blacksmith'); + core.warning("No expose ID or sticky disk key found, cannot report sticky disk to Blacksmith"); return; } try { @@ -36274,12 +36316,12 @@ async function commitStickydisk(exposeId, stickyDiskKey) { await client.commitStickyDisk({ exposeId, stickyDiskKey, - vmId: process.env.VM_ID || '', + vmId: process.env.VM_ID || "", shouldCommit: true, - repoName: process.env.GITHUB_REPO_NAME || '', - stickyDiskToken: process.env.BLACKSMITH_STICKYDISK_TOKEN || '' + repoName: process.env.GITHUB_REPO_NAME || "", + stickyDiskToken: process.env.BLACKSMITH_STICKYDISK_TOKEN || "", }, { - timeoutMs: 30000 + timeoutMs: 30000, }); core.info(`Successfully committed sticky disk ${stickyDiskKey} with expose ID ${exposeId}`); } @@ -36290,7 +36332,7 @@ async function commitStickydisk(exposeId, stickyDiskKey) { async function cleanupStickyDiskWithoutCommit(exposeId, stickyDiskKey) { core.info(`Cleaning up sticky disk ${stickyDiskKey} with expose ID ${exposeId}`); if (!exposeId || !stickyDiskKey) { - core.warning('No expose ID or sticky disk key found, cannot report sticky disk to Blacksmith'); + core.warning("No expose ID or sticky disk key found, cannot report sticky disk to Blacksmith"); return; } try { @@ -36298,12 +36340,12 @@ async function cleanupStickyDiskWithoutCommit(exposeId, stickyDiskKey) { await client.commitStickyDisk({ exposeId, stickyDiskKey, - vmId: process.env.VM_ID || '', + vmId: process.env.VM_ID || "", shouldCommit: false, - repoName: process.env.GITHUB_REPO_NAME || '', - stickyDiskToken: process.env.BLACKSMITH_STICKYDISK_TOKEN || '' + repoName: process.env.GITHUB_REPO_NAME || "", + stickyDiskToken: process.env.BLACKSMITH_STICKYDISK_TOKEN || "", }, { - timeoutMs: 30000 + timeoutMs: 30000, }); } catch (error) { @@ -36312,11 +36354,11 @@ async function cleanupStickyDiskWithoutCommit(exposeId, stickyDiskKey) { } } async function run() { - const stickyDiskPath = (0,core.getState)('STICKYDISK_PATH'); - const exposeId = (0,core.getState)('STICKYDISK_EXPOSE_ID'); - const stickyDiskKey = (0,core.getState)('STICKYDISK_KEY'); + const stickyDiskPath = (0,core.getState)("STICKYDISK_PATH"); + const exposeId = (0,core.getState)("STICKYDISK_EXPOSE_ID"); + const stickyDiskKey = (0,core.getState)("STICKYDISK_KEY"); if (!stickyDiskPath) { - core.debug('No STICKYDISK_PATH in state, skipping unmount'); + core.debug("No STICKYDISK_PATH in state, skipping unmount"); return; } try { @@ -36334,7 +36376,10 @@ async function run() { return; } // Ensure all pending writes are flushed to disk before unmounting. - await execAsync('sync'); + await execAsync("sync"); + // Drop page cache, dentries and inodes to ensure clean unmount + // This helps prevent "device is busy" errors during unmount + await execAsync("sudo sh -c 'echo 3 > /proc/sys/vm/drop_caches'"); // Unmount with retries. for (let attempt = 1; attempt <= 10; attempt++) { try { @@ -36347,10 +36392,10 @@ async function run() { throw error; } core.warning(`Unmount failed, retrying (${attempt}/10)...`); - await new Promise(resolve => setTimeout(resolve, 300)); + await new Promise((resolve) => setTimeout(resolve, 300)); } } - const stickyDiskError = (0,core.getState)('STICKYDISK_ERROR') === 'true'; + const stickyDiskError = (0,core.getState)("STICKYDISK_ERROR") === "true"; if (!stickyDiskError) { await commitStickydisk(exposeId, stickyDiskKey); } diff --git a/package-lock.json b/package-lock.json index 48de3cc..8818fda 100644 --- a/package-lock.json +++ b/package-lock.json @@ -7,7 +7,7 @@ "name": "root", "dependencies": { "@actions/core": "^1.10.1", - "@buf/blacksmith_vm-agent.connectrpc_es": "^1.6.1-20250209182455-7d83cfb8ddb1.2", + "@buf/blacksmith_vm-agent.connectrpc_es": "^1.6.1-20250224144138-e3a92532f7c4.2", "@bufbuild/connect": "^0.13.0", "@bufbuild/connect-web": "^0.13.0", "@bufbuild/protobuf": "^1.4.2", @@ -598,8 +598,8 @@ "license": "MIT" }, "node_modules/@buf/blacksmith_vm-agent.bufbuild_es": { - "version": "1.10.0-20250209182455-7d83cfb8ddb1.1", - "resolved": "https://buf.build/gen/npm/v1/@buf/blacksmith_vm-agent.bufbuild_es/-/blacksmith_vm-agent.bufbuild_es-1.10.0-20250209182455-7d83cfb8ddb1.1.tgz", + "version": "1.10.0-20250224144138-e3a92532f7c4.1", + "resolved": "https://buf.build/gen/npm/v1/@buf/blacksmith_vm-agent.bufbuild_es/-/blacksmith_vm-agent.bufbuild_es-1.10.0-20250224144138-e3a92532f7c4.1.tgz", "dependencies": { "@buf/googleapis_googleapis.bufbuild_es": "1.10.0-20250203201857-83c0f6c19b2f.1" }, @@ -608,10 +608,10 @@ } }, "node_modules/@buf/blacksmith_vm-agent.connectrpc_es": { - "version": "1.6.1-20250209182455-7d83cfb8ddb1.2", - "resolved": "https://buf.build/gen/npm/v1/@buf/blacksmith_vm-agent.connectrpc_es/-/blacksmith_vm-agent.connectrpc_es-1.6.1-20250209182455-7d83cfb8ddb1.2.tgz", + "version": "1.6.1-20250224144138-e3a92532f7c4.2", + "resolved": "https://buf.build/gen/npm/v1/@buf/blacksmith_vm-agent.connectrpc_es/-/blacksmith_vm-agent.connectrpc_es-1.6.1-20250224144138-e3a92532f7c4.2.tgz", "dependencies": { - "@buf/blacksmith_vm-agent.bufbuild_es": "1.10.0-20250209182455-7d83cfb8ddb1.1", + "@buf/blacksmith_vm-agent.bufbuild_es": "1.10.0-20250224144138-e3a92532f7c4.1", "@buf/googleapis_googleapis.connectrpc_es": "1.6.1-20250203201857-83c0f6c19b2f.2" }, "peerDependencies": { diff --git a/package.json b/package.json index 37d77fc..92a7946 100644 --- a/package.json +++ b/package.json @@ -10,7 +10,7 @@ }, "dependencies": { "@actions/core": "^1.10.1", - "@buf/blacksmith_vm-agent.connectrpc_es": "^1.6.1-20250209182455-7d83cfb8ddb1.2", + "@buf/blacksmith_vm-agent.connectrpc_es": "^1.6.1-20250224144138-e3a92532f7c4.2", "@bufbuild/connect": "^0.13.0", "@bufbuild/connect-web": "^0.13.0", "@bufbuild/protobuf": "^1.4.2", diff --git a/src/post.ts b/src/post.ts index 1acf6f3..0a7222f 100644 --- a/src/post.ts +++ b/src/post.ts @@ -1,75 +1,103 @@ -import * as core from '@actions/core'; -import { promisify } from 'util'; -import { exec } from 'child_process'; -import { getState } from '@actions/core'; -import { createStickyDiskClient } from './utils'; +import * as core from "@actions/core"; +import { promisify } from "util"; +import { exec } from "child_process"; +import { getState } from "@actions/core"; +import { createStickyDiskClient } from "./utils"; const execAsync = promisify(exec); -async function commitStickydisk(exposeId: string, stickyDiskKey: string): Promise { - core.info(`Committing sticky disk ${stickyDiskKey} with expose ID ${exposeId}`); +async function commitStickydisk( + exposeId: string, + stickyDiskKey: string +): Promise { + core.info( + `Committing sticky disk ${stickyDiskKey} with expose ID ${exposeId}` + ); if (!exposeId || !stickyDiskKey) { - core.warning('No expose ID or sticky disk key found, cannot report sticky disk to Blacksmith'); + core.warning( + "No expose ID or sticky disk key found, cannot report sticky disk to Blacksmith" + ); return; } try { const client = await createStickyDiskClient(); - await client.commitStickyDisk({ - exposeId, - stickyDiskKey, - vmId: process.env.VM_ID || '', - shouldCommit: true, - repoName: process.env.GITHUB_REPO_NAME || '', - stickyDiskToken: process.env.BLACKSMITH_STICKYDISK_TOKEN || '' - }, { - timeoutMs: 30000 - }); - core.info(`Successfully committed sticky disk ${stickyDiskKey} with expose ID ${exposeId}`); + await client.commitStickyDisk( + { + exposeId, + stickyDiskKey, + vmId: process.env.VM_ID || "", + shouldCommit: true, + repoName: process.env.GITHUB_REPO_NAME || "", + stickyDiskToken: process.env.BLACKSMITH_STICKYDISK_TOKEN || "", + }, + { + timeoutMs: 30000, + } + ); + core.info( + `Successfully committed sticky disk ${stickyDiskKey} with expose ID ${exposeId}` + ); } catch (error) { - core.warning(`Error committing sticky disk: ${error instanceof Error ? error.message : String(error)}`); + core.warning( + `Error committing sticky disk: ${error instanceof Error ? error.message : String(error)}` + ); } } -async function cleanupStickyDiskWithoutCommit(exposeId: string, stickyDiskKey: string): Promise { - core.info(`Cleaning up sticky disk ${stickyDiskKey} with expose ID ${exposeId}`); +async function cleanupStickyDiskWithoutCommit( + exposeId: string, + stickyDiskKey: string +): Promise { + core.info( + `Cleaning up sticky disk ${stickyDiskKey} with expose ID ${exposeId}` + ); if (!exposeId || !stickyDiskKey) { - core.warning('No expose ID or sticky disk key found, cannot report sticky disk to Blacksmith'); + core.warning( + "No expose ID or sticky disk key found, cannot report sticky disk to Blacksmith" + ); return; } try { const client = await createStickyDiskClient(); - await client.commitStickyDisk({ - exposeId, - stickyDiskKey, - vmId: process.env.VM_ID || '', - shouldCommit: false, - repoName: process.env.GITHUB_REPO_NAME || '', - stickyDiskToken: process.env.BLACKSMITH_STICKYDISK_TOKEN || '' - }, { - timeoutMs: 30000 - }); + await client.commitStickyDisk( + { + exposeId, + stickyDiskKey, + vmId: process.env.VM_ID || "", + shouldCommit: false, + repoName: process.env.GITHUB_REPO_NAME || "", + stickyDiskToken: process.env.BLACKSMITH_STICKYDISK_TOKEN || "", + }, + { + timeoutMs: 30000, + } + ); } catch (error) { - core.warning(`Error reporting build failed: ${error instanceof Error ? error.message : String(error)}`); + core.warning( + `Error reporting build failed: ${error instanceof Error ? error.message : String(error)}` + ); // We don't want to fail the build if this fails so we swallow the error. } } async function run(): Promise { - const stickyDiskPath = getState('STICKYDISK_PATH'); - const exposeId = getState('STICKYDISK_EXPOSE_ID'); - const stickyDiskKey = getState('STICKYDISK_KEY'); - + const stickyDiskPath = getState("STICKYDISK_PATH"); + const exposeId = getState("STICKYDISK_EXPOSE_ID"); + const stickyDiskKey = getState("STICKYDISK_KEY"); + if (!stickyDiskPath) { - core.debug('No STICKYDISK_PATH in state, skipping unmount'); + core.debug("No STICKYDISK_PATH in state, skipping unmount"); return; } try { // Check if path is mounted. try { - const { stdout: mountOutput } = await execAsync(`mount | grep ${stickyDiskPath}`); + const { stdout: mountOutput } = await execAsync( + `mount | grep ${stickyDiskPath}` + ); if (!mountOutput) { core.debug(`${stickyDiskPath} is not mounted, skipping unmount`); return; @@ -81,7 +109,10 @@ async function run(): Promise { } // Ensure all pending writes are flushed to disk before unmounting. - await execAsync('sync'); + await execAsync("sync"); + // Drop page cache, dentries and inodes to ensure clean unmount + // This helps prevent "device is busy" errors during unmount + await execAsync("sudo sh -c 'echo 3 > /proc/sys/vm/drop_caches'"); // Unmount with retries. for (let attempt = 1; attempt <= 10; attempt++) { @@ -94,11 +125,11 @@ async function run(): Promise { throw error; } core.warning(`Unmount failed, retrying (${attempt}/10)...`); - await new Promise(resolve => setTimeout(resolve, 300)); + await new Promise((resolve) => setTimeout(resolve, 300)); } } - const stickyDiskError = getState('STICKYDISK_ERROR') === 'true'; + const stickyDiskError = getState("STICKYDISK_ERROR") === "true"; if (!stickyDiskError) { await commitStickydisk(exposeId, stickyDiskKey); } else { @@ -106,7 +137,9 @@ async function run(): Promise { } } catch (error) { if (error instanceof Error) { - core.warning(`Failed to cleanup and commit sticky disk at ${stickyDiskPath}: ${error}`); + core.warning( + `Failed to cleanup and commit sticky disk at ${stickyDiskPath}: ${error}` + ); } } } From 617cc462d6e12f547c72453b44b09a6fa55a4e70 Mon Sep 17 00:00:00 2001 From: Aayush Date: Sun, 13 Apr 2025 11:37:45 -0400 Subject: [PATCH 17/17] use the env var for sticky disk grpc port --- dist/index.js | 5 +++-- dist/post/index.js | 5 +++-- src/utils.ts | 7 ++++--- 3 files changed, 10 insertions(+), 7 deletions(-) diff --git a/dist/index.js b/dist/index.js index 58880be..262fe71 100644 --- a/dist/index.js +++ b/dist/index.js @@ -36291,9 +36291,10 @@ const StickyDiskService = { function createStickyDiskClient() { + const port = process.env.BLACKSMITH_STICKY_DISK_GRPC_PORT || "5557"; const transport = createGrpcTransport({ - baseUrl: 'http://192.168.127.1:5557', - httpVersion: '2', + baseUrl: `http://192.168.127.1:${port}`, + httpVersion: "2", }); return createClient(StickyDiskService, transport); } diff --git a/dist/post/index.js b/dist/post/index.js index 5c70a49..c117961 100644 --- a/dist/post/index.js +++ b/dist/post/index.js @@ -36291,9 +36291,10 @@ const StickyDiskService = { function createStickyDiskClient() { + const port = process.env.BLACKSMITH_STICKY_DISK_GRPC_PORT || "5557"; const transport = createGrpcTransport({ - baseUrl: 'http://192.168.127.1:5557', - httpVersion: '2', + baseUrl: `http://192.168.127.1:${port}`, + httpVersion: "2", }); return createClient(StickyDiskService, transport); } diff --git a/src/utils.ts b/src/utils.ts index 3bf2c3c..aaa912c 100644 --- a/src/utils.ts +++ b/src/utils.ts @@ -3,10 +3,11 @@ import { createGrpcTransport } from "@connectrpc/connect-node"; import { StickyDiskService } from "@buf/blacksmith_vm-agent.connectrpc_es/stickydisk/v1/stickydisk_connect"; export function createStickyDiskClient() { + const port = process.env.BLACKSMITH_STICKY_DISK_GRPC_PORT || "5557"; const transport = createGrpcTransport({ - baseUrl: 'http://192.168.127.1:5557', - httpVersion: '2', + baseUrl: `http://192.168.127.1:${port}`, + httpVersion: "2", }); return createClient(StickyDiskService, transport); -} \ No newline at end of file +}