@lineageos-infra/android-fastboot 1.1.4 → 1.1.5
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/fastboot.cjs +0 -7
- package/dist/fastboot.cjs.map +1 -1
- package/dist/fastboot.d.ts.map +1 -1
- package/dist/fastboot.min.cjs +1 -1
- package/dist/fastboot.min.cjs.map +1 -1
- package/dist/fastboot.min.mjs +1 -1
- package/dist/fastboot.min.mjs.map +1 -1
- package/dist/fastboot.mjs +0 -7
- package/dist/fastboot.mjs.map +1 -1
- package/package.json +5 -2
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"fastboot.min.cjs","sources":["../src/utils/logger.ts","../src/common.ts","../src/utils/errors.ts","../src/sparse.ts","../src/lp.ts","../node_modules/.pnpm/@zip.js+zip.js@2.8.26/node_modules/@zip.js/zip.js/lib/core/constants.js","../node_modules/.pnpm/@zip.js+zip.js@2.8.26/node_modules/@zip.js/zip.js/lib/core/configuration.js","../node_modules/.pnpm/@zip.js+zip.js@2.8.26/node_modules/@zip.js/zip.js/lib/core/streams/codecs/crc32.js","../node_modules/.pnpm/@zip.js+zip.js@2.8.26/node_modules/@zip.js/zip.js/lib/core/streams/crc32-stream.js","../node_modules/.pnpm/@zip.js+zip.js@2.8.26/node_modules/@zip.js/zip.js/lib/core/streams/codecs/sjcl.js","../node_modules/.pnpm/@zip.js+zip.js@2.8.26/node_modules/@zip.js/zip.js/lib/core/streams/common-crypto.js","../node_modules/.pnpm/@zip.js+zip.js@2.8.26/node_modules/@zip.js/zip.js/lib/core/streams/aes-crypto-stream.js","../node_modules/.pnpm/@zip.js+zip.js@2.8.26/node_modules/@zip.js/zip.js/lib/core/util/encode-text.js","../node_modules/.pnpm/@zip.js+zip.js@2.8.26/node_modules/@zip.js/zip.js/lib/core/streams/zip-crypto-stream.js","../node_modules/.pnpm/@zip.js+zip.js@2.8.26/node_modules/@zip.js/zip.js/lib/core/streams/zip-entry-stream.js","../node_modules/.pnpm/@zip.js+zip.js@2.8.26/node_modules/@zip.js/zip.js/lib/core/streams/codec-stream.js","../node_modules/.pnpm/@zip.js+zip.js@2.8.26/node_modules/@zip.js/zip.js/lib/core/codec-worker.js","../node_modules/.pnpm/@zip.js+zip.js@2.8.26/node_modules/@zip.js/zip.js/lib/core/codec-pool.js","../node_modules/.pnpm/@zip.js+zip.js@2.8.26/node_modules/@zip.js/zip.js/lib/core/io.js","../node_modules/.pnpm/@zip.js+zip.js@2.8.26/node_modules/@zip.js/zip.js/lib/core/util/decode-cp437.js","../node_modules/.pnpm/@zip.js+zip.js@2.8.26/node_modules/@zip.js/zip.js/lib/core/util/decode-text.js","../node_modules/.pnpm/@zip.js+zip.js@2.8.26/node_modules/@zip.js/zip.js/lib/core/zip-entry.js","../node_modules/.pnpm/@zip.js+zip.js@2.8.26/node_modules/@zip.js/zip.js/lib/core/options.js","../node_modules/.pnpm/@zip.js+zip.js@2.8.26/node_modules/@zip.js/zip.js/lib/core/zip-reader.js","../node_modules/.pnpm/@zip.js+zip.js@2.8.26/node_modules/@zip.js/zip.js/lib/zip-core-base.js","../node_modules/.pnpm/@zip.js+zip.js@2.8.26/node_modules/@zip.js/zip.js/lib/core/zlib-streams-inline.js","../node_modules/.pnpm/@zip.js+zip.js@2.8.26/node_modules/@zip.js/zip.js/lib/core/streams/zlib-wasm/zlib-streams.js","../node_modules/.pnpm/@zip.js+zip.js@2.8.26/node_modules/@zip.js/zip.js/lib/core/streams/zlib-wasm/zlib-streams-loader.js","../node_modules/.pnpm/@zip.js+zip.js@2.8.26/node_modules/@zip.js/zip.js/lib/zip-module-wasm.js","../node_modules/.pnpm/@zip.js+zip.js@2.8.26/node_modules/@zip.js/zip.js/lib/core/util/mime-type.js","../src/utils/progress.ts","../node_modules/.pnpm/@zip.js+zip.js@2.8.26/node_modules/@zip.js/zip.js/lib/core/web-worker-inline-wasm.js","../node_modules/.pnpm/@zip.js+zip.js@2.8.26/node_modules/@zip.js/zip.js/lib/zip-fs-wasm.js","../src/factory.ts","../src/fastboot.ts"],"sourcesContent":["export enum DebugLevel {\n Silent = 0,\n Debug,\n Verbose,\n}\n\nexport type DebugLogger = (...data: unknown[]) => void;\n\nlet debugLevel = DebugLevel.Silent;\nlet debugLogger = console.log;\n\nexport function logDebug(...data: unknown[]) {\n if (debugLevel >= 1) {\n debugLogger(...data);\n }\n}\n\nexport function logVerbose(...data: unknown[]) {\n if (debugLevel >= 2) {\n debugLogger(...data);\n }\n}\n\n/**\n * Change the debug level for the fastboot client:\n * - 0 = silent\n * - 1 = debug, recommended for general use\n * - 2 = verbose, for debugging only\n *\n * @param {number} level - Debug level to use.\n */\nexport function setDebugLevel(level: DebugLevel) {\n debugLevel = level;\n}\n\n/**\n * Change the debug logger function for the fastboot client.\n *\n * @param {DebugLogger} logger - Debug logger function to use.\n */\nexport function setDebugLogger(logger: DebugLogger) {\n debugLogger = logger;\n}\n","/**\n * Reads all of the data in the given blob and returns it as an ArrayBuffer.\n *\n * @param {Blob} blob - Blob with the data to read.\n * @returns {Promise<ArrayBuffer>} ArrayBuffer containing data from the blob.\n * @ignore\n */\nexport function readBlobAsBuffer(blob: Blob): Promise<ArrayBuffer> {\n return new Promise((resolve, reject) => {\n const reader = new FileReader();\n reader.onload = () => {\n resolve(reader.result! as ArrayBuffer);\n };\n reader.onerror = () => {\n reject(reader.error);\n };\n\n reader.readAsArrayBuffer(blob);\n });\n}\n","/**\n * Exception class for errors returned by the bootloader, as well as high-level\n * fastboot errors resulting from bootloader responses.\n */\nexport class FastbootError extends Error {\n status: string;\n bootloaderMessage: string;\n\n constructor(status: string, message: string) {\n super(`Bootloader replied with ${status}: ${message}`);\n this.status = status;\n this.bootloaderMessage = message;\n this.name = \"FastbootError\";\n }\n}\n\n/**\n * Exception class for Sparse Image errors.\n */\nexport class ImageError extends Error {\n constructor(message: string) {\n super(message);\n this.name = \"ImageError\";\n }\n}\n\n/**\n * Exception class for logical partition parsing errors.\n */\nexport class LpError extends Error {\n constructor(message: string) {\n super(message);\n this.name = \"LpError\";\n }\n}\n\n/**\n * Exception class for operations that exceeded their timeout duration.\n */\nexport class TimeoutError extends Error {\n timeout: number;\n\n constructor(timeout: number) {\n super(`Timeout of ${timeout} ms exceeded`);\n this.name = \"TimeoutError\";\n this.timeout = timeout;\n }\n}\n\n/**\n * Exception class for USB errors not directly thrown by WebUSB.\n */\nexport class UsbError extends Error {\n constructor(message: string) {\n super(message);\n this.name = \"UsbError\";\n }\n}\n","import * as common from \"./common\";\nimport { ImageError } from \"./utils/errors\";\nimport { logDebug, logVerbose } from \"./utils/logger\";\n\nconst FILE_MAGIC = 0xed26ff3a;\n\nconst MAJOR_VERSION = 1;\nconst MINOR_VERSION = 0;\nexport const FILE_HEADER_SIZE = 28;\nconst CHUNK_HEADER_SIZE = 12;\n\n// AOSP libsparse uses 64 MiB chunks\nconst RAW_CHUNK_SIZE = 64 * 1024 * 1024;\n\nexport interface SparseSplit {\n data: ArrayBuffer;\n bytes: number;\n}\n\nexport enum ChunkType {\n Raw = 0xcac1,\n Fill = 0xcac2,\n Skip = 0xcac3,\n Crc32 = 0xcac4,\n}\n\nexport interface SparseHeader {\n blockSize: number;\n blocks: number;\n chunks: number;\n crc32: number;\n}\n\nexport interface SparseChunk {\n type: ChunkType;\n /* 2: reserved, 16 bits */\n blocks: number;\n dataBytes: number;\n data: Blob | null; // to be populated by consumer\n}\n\nclass BlobBuilder {\n private blob: Blob;\n private type: string;\n\n constructor(type: string = \"\") {\n this.type = type;\n this.blob = new Blob([], { type: this.type });\n }\n\n append(blob: Blob) {\n this.blob = new Blob([this.blob, blob], { type: this.type });\n }\n\n getBlob(): Blob {\n return this.blob;\n }\n}\n\n/**\n * Returns a parsed version of the sparse image file header from the given buffer.\n *\n * @param {ArrayBuffer} buffer - Raw file header data.\n * @returns {SparseHeader} Object containing the header information.\n */\nexport function parseFileHeader(buffer: ArrayBuffer): SparseHeader | null {\n const view = new DataView(buffer);\n\n const magic = view.getUint32(0, true);\n if (magic !== FILE_MAGIC) {\n return null;\n }\n\n // v1.0+\n const major = view.getUint16(4, true);\n const minor = view.getUint16(6, true);\n if (major !== MAJOR_VERSION || minor < MINOR_VERSION) {\n throw new ImageError(\n `Unsupported sparse image version ${major}.${minor}`,\n );\n }\n\n const fileHdrSize = view.getUint16(8, true);\n const chunkHdrSize = view.getUint16(10, true);\n if (\n fileHdrSize !== FILE_HEADER_SIZE ||\n chunkHdrSize !== CHUNK_HEADER_SIZE\n ) {\n throw new ImageError(\n `Invalid file header size ${fileHdrSize}, chunk header size ${chunkHdrSize}`,\n );\n }\n\n const blockSize = view.getUint32(12, true);\n if (blockSize % 4 !== 0) {\n throw new ImageError(`Block size ${blockSize} is not a multiple of 4`);\n }\n\n return {\n blockSize: blockSize,\n blocks: view.getUint32(16, true),\n chunks: view.getUint32(20, true),\n crc32: view.getUint32(24, true),\n };\n}\n\nfunction parseChunkHeader(buffer: ArrayBuffer) {\n const view = new DataView(buffer);\n\n // This isn't the same as what createImage takes.\n // Further processing needs to be done on the chunks.\n return {\n type: view.getUint16(0, true),\n /* 2: reserved, 16 bits */\n blocks: view.getUint32(4, true),\n dataBytes: view.getUint32(8, true) - CHUNK_HEADER_SIZE,\n data: null, // to be populated by consumer\n } as SparseChunk;\n}\n\nfunction calcChunksBlockSize(chunks: Array<SparseChunk>) {\n return chunks\n .map((chunk) => chunk.blocks)\n .reduce((total, c) => total + c, 0);\n}\n\nfunction calcChunksDataSize(chunks: Array<SparseChunk>) {\n return chunks\n .map((chunk) => chunk.data!.size)\n .reduce((total, c) => total + c, 0);\n}\n\nfunction calcChunksSize(chunks: Array<SparseChunk>) {\n // 28-byte file header, 12-byte chunk headers\n const overhead = FILE_HEADER_SIZE + CHUNK_HEADER_SIZE * chunks.length;\n return overhead + calcChunksDataSize(chunks);\n}\n\nexport async function createImage(\n header: SparseHeader,\n chunks: Array<SparseChunk>,\n): Promise<Blob> {\n const blobBuilder = new BlobBuilder();\n\n let buffer = new ArrayBuffer(FILE_HEADER_SIZE);\n let dataView = new DataView(buffer);\n\n dataView.setUint32(0, FILE_MAGIC, true);\n // v1.0\n dataView.setUint16(4, MAJOR_VERSION, true);\n dataView.setUint16(6, MINOR_VERSION, true);\n dataView.setUint16(8, FILE_HEADER_SIZE, true);\n dataView.setUint16(10, CHUNK_HEADER_SIZE, true);\n\n // Match input parameters\n dataView.setUint32(12, header.blockSize, true);\n dataView.setUint32(16, header.blocks, true);\n dataView.setUint32(20, chunks.length, true);\n\n // We don't care about the CRC. AOSP docs specify that this should be a CRC32,\n // but AOSP libsparse always sets 0 and puts the CRC in a final undocumented\n // 0xCAC4 chunk instead.\n dataView.setUint32(24, 0, true);\n\n blobBuilder.append(new Blob([buffer]));\n for (const chunk of chunks) {\n buffer = new ArrayBuffer(CHUNK_HEADER_SIZE + chunk.data!.size);\n dataView = new DataView(buffer);\n const arrayView = new Uint8Array(buffer);\n\n dataView.setUint16(0, chunk.type, true);\n dataView.setUint16(2, 0, true); // reserved\n dataView.setUint32(4, chunk.blocks, true);\n dataView.setUint32(8, CHUNK_HEADER_SIZE + chunk.data!.size, true);\n\n const chunkArrayView = new Uint8Array(\n await common.readBlobAsBuffer(chunk.data!),\n );\n arrayView.set(chunkArrayView, CHUNK_HEADER_SIZE);\n blobBuilder.append(new Blob([buffer]));\n }\n\n return blobBuilder.getBlob();\n}\n\n/**\n * Creates a sparse image from buffer containing raw image data.\n *\n * @param {Blob} blob - Blob containing the raw image data.\n * @returns {Promise<Blob>} Promise that resolves the blob containing the new sparse image.\n */\nexport async function fromRaw(blob: Blob): Promise<Blob> {\n const header = {\n blockSize: 4096,\n blocks: blob.size / 4096,\n chunks: 1,\n crc32: 0,\n };\n\n const chunks = [];\n while (blob.size > 0) {\n const chunkSize = Math.min(blob.size, RAW_CHUNK_SIZE);\n chunks.push({\n type: ChunkType.Raw,\n blocks: chunkSize / header.blockSize,\n data: blob.slice(0, chunkSize),\n } as SparseChunk);\n blob = blob.slice(chunkSize);\n }\n\n return createImage(header, chunks);\n}\n\n/**\n * Split a sparse image into smaller sparse images within the given size.\n * This takes a Blob instead of an ArrayBuffer because it may process images\n * larger than RAM.\n *\n * @param {Blob} blob - Blob containing the sparse image to split.\n * @param {number} splitSize - Maximum size per split.\n * @yields {Object} Data of the next split image and its output size in bytes.\n */\nexport async function* splitBlob(blob: Blob, splitSize: number) {\n logDebug(\n `Splitting ${blob.size}-byte sparse image into ${splitSize}-byte chunks`,\n );\n\n // 7/8 is a safe value for the split size, to account for extra overhead\n // AOSP source code does the same\n const safeSendValue = Math.floor(splitSize * (7 / 8));\n\n // Short-circuit if splitting isn't required\n if (blob.size <= splitSize) {\n logDebug(\"Blob fits in 1 payload, not splitting\");\n yield {\n data: await common.readBlobAsBuffer(blob),\n bytes: blob.size,\n } as SparseSplit;\n return;\n }\n\n const headerData = await common.readBlobAsBuffer(\n blob.slice(0, FILE_HEADER_SIZE),\n );\n const header = parseFileHeader(headerData);\n if (header === null) {\n throw new ImageError(\"Blob is not a sparse image\");\n }\n\n // Remove CRC32 (if present), otherwise splitting will invalidate it\n header.crc32 = 0;\n blob = blob.slice(FILE_HEADER_SIZE);\n\n let splitChunks: Array<SparseChunk> = [];\n let splitDataBytes = 0;\n for (let i = 0; i < header.chunks; i++) {\n const chunkHeaderData = await common.readBlobAsBuffer(\n blob.slice(0, CHUNK_HEADER_SIZE),\n );\n const originalChunk = parseChunkHeader(chunkHeaderData);\n originalChunk.data = blob.slice(\n CHUNK_HEADER_SIZE,\n CHUNK_HEADER_SIZE + originalChunk.dataBytes,\n );\n blob = blob.slice(CHUNK_HEADER_SIZE + originalChunk.dataBytes);\n\n const chunksToProcess: SparseChunk[] = [];\n\n // take into account cases where the chunk data is bigger than the maximum allowed download size\n if (originalChunk.dataBytes > safeSendValue) {\n logDebug(\n `Data of chunk ${i} is bigger than the maximum allowed download size: ${originalChunk.dataBytes} > ${safeSendValue}`,\n );\n\n // we should now split this chunk into multiple chunks that fit\n let originalDataBytes = originalChunk.dataBytes;\n let originalData = originalChunk.data;\n\n while (originalDataBytes > 0) {\n const toSend = Math.min(safeSendValue, originalDataBytes);\n\n chunksToProcess.push({\n type: originalChunk.type,\n dataBytes: toSend,\n data: originalData.slice(0, toSend),\n blocks: toSend / header?.blockSize,\n });\n\n originalData = originalData.slice(toSend);\n originalDataBytes -= toSend;\n }\n\n logDebug(\"chunksToProcess\", chunksToProcess);\n } else {\n chunksToProcess.push(originalChunk);\n }\n\n for (const chunk of chunksToProcess) {\n const bytesRemaining = splitSize - calcChunksSize(splitChunks);\n logVerbose(\n ` Chunk ${i}: type ${chunk.type}, ${chunk.dataBytes} bytes / ${chunk.blocks} blocks, ${bytesRemaining} bytes remaining`,\n );\n\n if (bytesRemaining >= chunk.dataBytes) {\n // Read the chunk and add it\n logVerbose(\" Space is available, adding chunk\");\n splitChunks.push(chunk);\n // Track amount of data written on the output device, in bytes\n splitDataBytes += chunk.blocks * header.blockSize;\n } else {\n // Out of space, finish this split\n // Blocks need to be calculated from chunk headers instead of going by size\n // because FILL and SKIP chunks cover more blocks than the data they contain.\n const splitBlocks = calcChunksBlockSize(splitChunks);\n splitChunks.push({\n type: ChunkType.Skip,\n blocks: header.blocks - splitBlocks,\n data: new Blob([]),\n dataBytes: 0,\n });\n logVerbose(\n `Partition is ${\n header.blocks\n } blocks, used ${splitBlocks}, padded with ${\n header.blocks - splitBlocks\n }, finishing split with ${calcChunksBlockSize(\n splitChunks,\n )} blocks`,\n );\n const splitImage = await createImage(header, splitChunks);\n logDebug(\n `Finished ${splitImage.size}-byte split with ${splitChunks.length} chunks`,\n );\n yield {\n data: await common.readBlobAsBuffer(splitImage),\n bytes: splitDataBytes,\n } as SparseSplit;\n\n // Start a new split. Every split is considered a full image by the\n // bootloader, so we need to skip the *total* written blocks.\n logVerbose(\n `Starting new split: skipping first ${splitBlocks} blocks and adding chunk`,\n );\n splitChunks = [\n {\n type: ChunkType.Skip,\n blocks: splitBlocks,\n data: new Blob([]),\n dataBytes: 0,\n },\n chunk,\n ];\n\n splitDataBytes = chunk.dataBytes;\n }\n }\n }\n\n // Finish the final split if necessary\n if (\n splitChunks.length > 0 &&\n (splitChunks.length > 1 || splitChunks[0].type !== ChunkType.Skip)\n ) {\n const splitImage = await createImage(header, splitChunks);\n logDebug(\n `Finishing final ${splitImage.size}-byte split with ${splitChunks.length} chunks`,\n );\n yield {\n data: await common.readBlobAsBuffer(splitImage),\n bytes: splitDataBytes,\n } as SparseSplit;\n }\n}\n","import * as common from \"./common\";\nimport * as Sparse from \"./sparse\";\nimport { LpError } from \"./utils/errors\";\nimport { logDebug } from \"./utils/logger\";\n\n// Magic values\nconst LP_METADATA_GEOMETRY_MAGIC = 0x616c4467;\nconst LP_METADATA_HEADER_MAGIC = 0x414c5030;\n\n// Layout sizes\nconst LP_SECTOR_SIZE = 512;\nconst LP_METADATA_GEOMETRY_SIZE = 4096;\nconst LP_PARTITION_RESERVED_BYTES = 4096;\n\n// Version\nconst LP_METADATA_MAJOR_VERSION = 10;\nconst LP_METADATA_MINOR_VERSION_MAX = 2;\nconst LP_METADATA_VERSION_FOR_UPDATED_ATTR = 1;\nconst LP_METADATA_VERSION_FOR_EXPANDED_HEADER = 2;\n\n// Struct sizes (packed, little-endian, from AOSP liblp)\nconst GEOMETRY_STRUCT_SIZE = 52;\nconst HEADER_V1_0_SIZE = 128;\nconst HEADER_V1_2_SIZE = 256;\nconst PARTITION_STRUCT_SIZE = 52;\nconst EXTENT_STRUCT_SIZE = 24;\nconst GROUP_STRUCT_SIZE = 48;\nconst BLOCK_DEVICE_STRUCT_SIZE = 64;\n\nconst LP_BLOCK_DEVICE_SLOT_SUFFIXED = 0x1;\n\n// Partition attribute flags\nconst LP_PARTITION_ATTR_READONLY = 0x1;\nconst LP_PARTITION_ATTR_SLOT_SUFFIXED = 0x2;\nconst LP_PARTITION_ATTR_UPDATED = 0x4;\nconst LP_PARTITION_ATTR_DISABLED = 0x8;\n\nconst LP_PARTITION_ATTRIBUTE_MASK_V0 =\n LP_PARTITION_ATTR_READONLY | LP_PARTITION_ATTR_SLOT_SUFFIXED;\nconst LP_PARTITION_ATTRIBUTE_MASK_V1 =\n LP_PARTITION_ATTR_UPDATED | LP_PARTITION_ATTR_DISABLED;\n\n// Extent target types\nconst LP_TARGET_TYPE_LINEAR = 0;\n\nexport interface LpMetadataGeometry {\n magic: number;\n structSize: number;\n checksum: Uint8Array; // 32 bytes, SHA-256\n metadataMaxSize: number;\n metadataSlotCount: number;\n logicalBlockSize: number;\n}\n\nexport interface LpMetadataTableDescriptor {\n offset: number;\n numEntries: number;\n entrySize: number;\n}\n\nexport interface LpMetadataHeader {\n magic: number;\n majorVersion: number;\n minorVersion: number;\n headerSize: number;\n headerChecksum: Uint8Array; // 32 bytes, SHA-256\n tablesSize: number;\n tablesChecksum: Uint8Array; // 32 bytes, SHA-256\n partitions: LpMetadataTableDescriptor;\n extents: LpMetadataTableDescriptor;\n groups: LpMetadataTableDescriptor;\n blockDevices: LpMetadataTableDescriptor;\n flags: number; // v1.2+ only\n}\n\nexport interface LpMetadataPartition {\n name: string; // from char[36]\n attributes: number;\n firstExtentIndex: number;\n numExtents: number;\n groupIndex: number;\n}\n\nexport interface LpMetadataExtent {\n numSectors: bigint;\n targetType: number;\n targetData: bigint;\n targetSource: number;\n}\n\nexport interface LpMetadataPartitionGroup {\n name: string; // from char[36]\n flags: number;\n maximumSize: bigint;\n}\n\nexport interface LpMetadataBlockDevice {\n firstLogicalSector: bigint;\n alignment: number;\n alignmentOffset: number;\n size: bigint;\n partitionName: string; // from char[36], null-trimmed\n flags: number;\n}\n\nexport interface LpMetadata {\n geometry: LpMetadataGeometry;\n header: LpMetadataHeader;\n partitions: LpMetadataPartition[];\n extents: LpMetadataExtent[];\n groups: LpMetadataPartitionGroup[];\n blockDevices: LpMetadataBlockDevice[];\n}\n\nexport interface WipeSuperImage {\n partitionName: string;\n data: ArrayBuffer; // sparse image\n forceSlot: boolean; // true if LP_BLOCK_DEVICE_SLOT_SUFFIXED\n}\n\n// ---------------------------------------------------------------------------\n// Helpers\n// ---------------------------------------------------------------------------\n\nfunction nameFromFixedArray(\n view: DataView,\n offset: number,\n maxLen: number,\n): string {\n const bytes: number[] = [];\n for (let i = 0; i < maxLen; i++) {\n const b = view.getUint8(offset + i);\n if (b === 0) break;\n bytes.push(b);\n }\n return new TextDecoder().decode(new Uint8Array(bytes));\n}\n\nasync function sha256(buffer: ArrayBuffer): Promise<Uint8Array> {\n const digest = await crypto.subtle.digest(\"SHA-256\", buffer);\n return new Uint8Array(digest);\n}\n\nfunction arraysEqual(a: Uint8Array, b: Uint8Array): boolean {\n if (a.length !== b.length) return false;\n for (let i = 0; i < a.length; i++) {\n if (a[i] !== b[i]) return false;\n }\n return true;\n}\n\nfunction concatBuffers(...buffers: ArrayBuffer[]): ArrayBuffer {\n const totalLen = buffers.reduce((acc, b) => acc + b.byteLength, 0);\n const out = new Uint8Array(totalLen);\n let offset = 0;\n for (const buf of buffers) {\n out.set(new Uint8Array(buf), offset);\n offset += buf.byteLength;\n }\n return out.buffer;\n}\n\n// Pad/truncate buffer to exactly `size` bytes (zero-padded at end).\nfunction padBuffer(buf: ArrayBuffer, size: number): ArrayBuffer {\n if (buf.byteLength === size) return buf;\n const out = new Uint8Array(size);\n out.set(new Uint8Array(buf.slice(0, Math.min(buf.byteLength, size))));\n return out.buffer;\n}\n\n// ---------------------------------------------------------------------------\n// Geometry parsing\n// ---------------------------------------------------------------------------\n\nasync function parseGeometry(buffer: ArrayBuffer): Promise<LpMetadataGeometry> {\n if (buffer.byteLength < GEOMETRY_STRUCT_SIZE) {\n throw new LpError(\"Geometry buffer too small\");\n }\n const view = new DataView(buffer);\n\n const magic = view.getUint32(0, true);\n if (magic !== LP_METADATA_GEOMETRY_MAGIC) {\n throw new LpError(`Invalid geometry magic: 0x${magic.toString(16)}`);\n }\n\n const structSize = view.getUint32(4, true);\n if (structSize > LP_METADATA_GEOMETRY_SIZE) {\n throw new LpError(\n `Geometry struct_size ${structSize} exceeds LP_METADATA_GEOMETRY_SIZE`,\n );\n }\n\n const storedChecksum = new Uint8Array(buffer.slice(8, 40));\n\n // Verify checksum: zero the checksum field and hash\n const forHash = new Uint8Array(buffer.slice(0, structSize));\n forHash.fill(0, 8, 40);\n const computed = await sha256(forHash.buffer);\n if (!arraysEqual(computed, storedChecksum)) {\n throw new LpError(\"Geometry checksum mismatch\");\n }\n\n const metadataMaxSize = view.getUint32(40, true);\n const metadataSlotCount = view.getUint32(44, true);\n const logicalBlockSize = view.getUint32(48, true);\n\n if (structSize !== GEOMETRY_STRUCT_SIZE) {\n throw new LpError(\n `Geometry struct_size ${structSize} does not match expected ${GEOMETRY_STRUCT_SIZE}`,\n );\n }\n if (metadataSlotCount === 0) {\n throw new LpError(\"Geometry has invalid slot count (0)\");\n }\n if (metadataMaxSize % LP_SECTOR_SIZE !== 0) {\n throw new LpError(\n `Geometry metadata_max_size ${metadataMaxSize} is not sector-aligned`,\n );\n }\n\n return {\n magic,\n structSize,\n checksum: storedChecksum,\n metadataMaxSize,\n metadataSlotCount,\n logicalBlockSize,\n };\n}\n\n// ---------------------------------------------------------------------------\n// Table descriptor parsing\n// ---------------------------------------------------------------------------\n\nfunction parseTableDescriptor(\n view: DataView,\n offset: number,\n): LpMetadataTableDescriptor {\n return {\n offset: view.getUint32(offset + 0, true),\n numEntries: view.getUint32(offset + 4, true),\n entrySize: view.getUint32(offset + 8, true),\n };\n}\n\nfunction validateTableBounds(\n header: Pick<LpMetadataHeader, \"tablesSize\">,\n table: LpMetadataTableDescriptor,\n): boolean {\n if (table.offset > header.tablesSize) return false;\n const tableSize = table.numEntries * table.entrySize;\n if (tableSize < 0) return false;\n if (header.tablesSize - table.offset < tableSize) return false;\n return true;\n}\n\n// ---------------------------------------------------------------------------\n// Header parsing\n// ---------------------------------------------------------------------------\n\nasync function parseHeader(\n buffer: ArrayBuffer,\n tablesBuffer: ArrayBuffer,\n): Promise<LpMetadataHeader> {\n if (buffer.byteLength < HEADER_V1_0_SIZE) {\n throw new LpError(\"Header buffer too small\");\n }\n const view = new DataView(buffer);\n\n const magic = view.getUint32(0, true);\n if (magic !== LP_METADATA_HEADER_MAGIC) {\n throw new LpError(`Invalid header magic: 0x${magic.toString(16)}`);\n }\n\n const majorVersion = view.getUint16(4, true);\n const minorVersion = view.getUint16(6, true);\n if (majorVersion !== LP_METADATA_MAJOR_VERSION) {\n throw new LpError(\n `Unsupported LP metadata major version: ${majorVersion}`,\n );\n }\n if (minorVersion > LP_METADATA_MINOR_VERSION_MAX) {\n throw new LpError(\n `Unsupported LP metadata minor version: ${minorVersion}`,\n );\n }\n\n const headerSize = view.getUint32(8, true);\n const expectedHeaderSize =\n minorVersion < LP_METADATA_VERSION_FOR_EXPANDED_HEADER\n ? HEADER_V1_0_SIZE\n : HEADER_V1_2_SIZE;\n if (headerSize !== expectedHeaderSize || headerSize > buffer.byteLength) {\n throw new LpError(`Invalid header size: ${headerSize}`);\n }\n\n const storedChecksum = new Uint8Array(buffer.slice(12, 44));\n\n // Verify header checksum\n const forHash = new Uint8Array(buffer.slice(0, headerSize));\n forHash.fill(0, 12, 44);\n const computed = await sha256(forHash.buffer);\n if (!arraysEqual(computed, storedChecksum)) {\n throw new LpError(\"Header checksum mismatch\");\n }\n\n const tablesSize = view.getUint32(44, true);\n const tablesChecksum = new Uint8Array(buffer.slice(48, 80));\n\n // Verify tables checksum\n if (tablesBuffer.byteLength < tablesSize) {\n throw new LpError(\"Tables buffer too small\");\n }\n const tablesComputed = await sha256(tablesBuffer.slice(0, tablesSize));\n if (!arraysEqual(tablesComputed, tablesChecksum)) {\n throw new LpError(\"Tables checksum mismatch\");\n }\n\n // Table descriptors start at offset 80\n const partitions = parseTableDescriptor(view, 80);\n const extents = parseTableDescriptor(view, 92);\n const groups = parseTableDescriptor(view, 104);\n const blockDevices = parseTableDescriptor(view, 116);\n if (\n !validateTableBounds({ tablesSize }, partitions) ||\n !validateTableBounds({ tablesSize }, extents) ||\n !validateTableBounds({ tablesSize }, groups) ||\n !validateTableBounds({ tablesSize }, blockDevices)\n ) {\n throw new LpError(\"Invalid table bounds in metadata header\");\n }\n\n // v1.2+ flags field at offset 128\n const flags =\n headerSize >= HEADER_V1_2_SIZE ? view.getUint32(128, true) : 0;\n\n return {\n magic,\n majorVersion,\n minorVersion,\n headerSize,\n headerChecksum: storedChecksum,\n tablesSize,\n tablesChecksum,\n partitions,\n extents,\n groups,\n blockDevices,\n flags,\n };\n}\n\n// ---------------------------------------------------------------------------\n// Table entry parsers\n// ---------------------------------------------------------------------------\n\nfunction parsePartition(view: DataView, offset: number): LpMetadataPartition {\n return {\n name: nameFromFixedArray(view, offset + 0, 36),\n attributes: view.getUint32(offset + 36, true),\n firstExtentIndex: view.getUint32(offset + 40, true),\n numExtents: view.getUint32(offset + 44, true),\n groupIndex: view.getUint32(offset + 48, true),\n };\n}\n\nfunction parseExtent(view: DataView, offset: number): LpMetadataExtent {\n return {\n numSectors: view.getBigUint64(offset + 0, true),\n targetType: view.getUint32(offset + 8, true),\n targetData: view.getBigUint64(offset + 12, true),\n targetSource: view.getUint32(offset + 20, true),\n };\n}\n\nfunction parseGroup(view: DataView, offset: number): LpMetadataPartitionGroup {\n return {\n name: nameFromFixedArray(view, offset + 0, 36),\n flags: view.getUint32(offset + 36, true),\n maximumSize: view.getBigUint64(offset + 40, true),\n };\n}\n\nfunction parseBlockDevice(\n view: DataView,\n offset: number,\n): LpMetadataBlockDevice {\n return {\n firstLogicalSector: view.getBigUint64(offset + 0, true),\n alignment: view.getUint32(offset + 8, true),\n alignmentOffset: view.getUint32(offset + 12, true),\n size: view.getBigUint64(offset + 16, true),\n partitionName: nameFromFixedArray(view, offset + 24, 36),\n flags: view.getUint32(offset + 60, true),\n };\n}\n\nfunction parseTable<T>(\n tablesView: DataView,\n descriptor: LpMetadataTableDescriptor,\n expectedEntrySize: number,\n parser: (view: DataView, offset: number) => T,\n): T[] {\n if (descriptor.entrySize !== expectedEntrySize) {\n throw new LpError(\n `Table entry size mismatch: expected ${expectedEntrySize}, got ${descriptor.entrySize}`,\n );\n }\n const tableSize = descriptor.numEntries * descriptor.entrySize;\n if (\n descriptor.offset > tablesView.byteLength ||\n tableSize > tablesView.byteLength - descriptor.offset\n ) {\n throw new LpError(\"Table descriptor points outside tables buffer\");\n }\n const results: T[] = [];\n for (let i = 0; i < descriptor.numEntries; i++) {\n const offset = descriptor.offset + i * descriptor.entrySize;\n results.push(parser(tablesView, offset));\n }\n return results;\n}\n\nfunction validateParsedMetadata(\n geometry: LpMetadataGeometry,\n header: LpMetadataHeader,\n partitions: LpMetadataPartition[],\n extents: LpMetadataExtent[],\n groups: LpMetadataPartitionGroup[],\n blockDevices: LpMetadataBlockDevice[],\n) {\n const superDevice = blockDevices[0];\n if (!superDevice) {\n throw new LpError(\"Metadata does not specify a super block device\");\n }\n\n const validAttributes =\n header.minorVersion >= LP_METADATA_VERSION_FOR_UPDATED_ATTR\n ? LP_PARTITION_ATTRIBUTE_MASK_V0 | LP_PARTITION_ATTRIBUTE_MASK_V1\n : LP_PARTITION_ATTRIBUTE_MASK_V0;\n\n for (const partition of partitions) {\n if (partition.attributes & ~validAttributes) {\n throw new LpError(\n `Partition \"${partition.name}\" has invalid attributes`,\n );\n }\n const end = partition.firstExtentIndex + partition.numExtents;\n if (end < partition.firstExtentIndex || end > extents.length) {\n throw new LpError(\n `Partition \"${partition.name}\" has invalid extent list`,\n );\n }\n if (partition.groupIndex >= groups.length) {\n throw new LpError(\n `Partition \"${partition.name}\" has invalid group index`,\n );\n }\n }\n\n for (const extent of extents) {\n if (\n extent.targetType === LP_TARGET_TYPE_LINEAR &&\n extent.targetSource >= blockDevices.length\n ) {\n throw new LpError(\"Linear extent references invalid block device\");\n }\n }\n\n const metadataRegion =\n BigInt(LP_PARTITION_RESERVED_BYTES) +\n BigInt(\n LP_METADATA_GEOMETRY_SIZE +\n geometry.metadataMaxSize * geometry.metadataSlotCount,\n ) *\n 2n;\n if (\n metadataRegion >\n superDevice.firstLogicalSector * BigInt(LP_SECTOR_SIZE)\n ) {\n throw new LpError(\n \"Metadata region overlaps with logical partition contents\",\n );\n }\n}\n\n// ---------------------------------------------------------------------------\n// Public: read LP metadata from a super_empty.img Blob\n// ---------------------------------------------------------------------------\n\n/**\n * Parse LP metadata from a super_empty.img Blob.\n *\n * super_empty.img layout:\n * [0 .. LP_METADATA_GEOMETRY_SIZE) — geometry struct (4096 bytes)\n * [LP_METADATA_GEOMETRY_SIZE ..) — header + tables (metadata slot 0)\n */\nexport async function readFromImageBlob(blob: Blob): Promise<LpMetadata> {\n logDebug(`Parsing LP metadata from ${blob.size}-byte image`);\n\n // super_empty.img written by AOSP WriteToImageFile(fd, metadata) has:\n // offset 0 — geometry (LP_METADATA_GEOMETRY_SIZE bytes, padded)\n // offset LP_METADATA_GEOMETRY_SIZE — header + tables\n // This matches AOSP ReadFromImageBlob / ReadFromImageFile which reads geometry at offset 0.\n const primaryGeometryOffset = 0;\n const geomBuf = await common.readBlobAsBuffer(\n blob.slice(\n primaryGeometryOffset,\n primaryGeometryOffset + LP_METADATA_GEOMETRY_SIZE,\n ),\n );\n const geometry = await parseGeometry(geomBuf);\n logDebug(\n `LP geometry: maxSize=${geometry.metadataMaxSize}, slotCount=${geometry.metadataSlotCount}, blockSize=${geometry.logicalBlockSize}`,\n );\n\n // Metadata immediately follows the single geometry block in super_empty.img\n const headerPeekOffset = LP_METADATA_GEOMETRY_SIZE;\n const headerPeekBuf = await common.readBlobAsBuffer(\n blob.slice(headerPeekOffset, headerPeekOffset + HEADER_V1_0_SIZE),\n );\n const peekView = new DataView(headerPeekBuf);\n const headerSize = peekView.getUint32(8, true);\n const tablesSize = peekView.getUint32(44, true);\n if (tablesSize > geometry.metadataMaxSize) {\n throw new LpError(\"Metadata tables exceed geometry.metadata_max_size\");\n }\n\n // Read full header + tables\n const headerBuf = await common.readBlobAsBuffer(\n blob.slice(headerPeekOffset, headerPeekOffset + headerSize),\n );\n const tablesBuf = await common.readBlobAsBuffer(\n blob.slice(\n headerPeekOffset + headerSize,\n headerPeekOffset + headerSize + tablesSize,\n ),\n );\n\n const header = await parseHeader(headerBuf, tablesBuf);\n logDebug(\n `LP header: v${header.majorVersion}.${header.minorVersion}, headerSize=${header.headerSize}`,\n );\n\n const tablesView = new DataView(tablesBuf);\n const partitions = parseTable(\n tablesView,\n header.partitions,\n PARTITION_STRUCT_SIZE,\n parsePartition,\n );\n const extents = parseTable(\n tablesView,\n header.extents,\n EXTENT_STRUCT_SIZE,\n parseExtent,\n );\n const groups = parseTable(\n tablesView,\n header.groups,\n GROUP_STRUCT_SIZE,\n parseGroup,\n );\n const blockDevices = parseTable(\n tablesView,\n header.blockDevices,\n BLOCK_DEVICE_STRUCT_SIZE,\n parseBlockDevice,\n );\n\n validateParsedMetadata(\n geometry,\n header,\n partitions,\n extents,\n groups,\n blockDevices,\n );\n\n logDebug(\n `LP: ${partitions.length} partitions, ${blockDevices.length} block device(s)`,\n );\n for (const bd of blockDevices) {\n logDebug(\n ` block device \"${bd.partitionName}\": size=${\n bd.size\n }, flags=0x${bd.flags.toString(16)}`,\n );\n }\n\n return { geometry, header, partitions, extents, groups, blockDevices };\n}\n\n// ---------------------------------------------------------------------------\n// Public helpers\n// ---------------------------------------------------------------------------\n\nexport function getMetadataSuperBlockDevice(\n metadata: LpMetadata,\n): LpMetadataBlockDevice | null {\n return metadata.blockDevices[0] ?? null;\n}\n\nexport function getBlockDevicePartitionName(bd: LpMetadataBlockDevice): string {\n return bd.partitionName;\n}\n\n// ---------------------------------------------------------------------------\n// Serialization\n// ---------------------------------------------------------------------------\n\nexport async function serializeGeometry(\n geometry: LpMetadataGeometry,\n): Promise<ArrayBuffer> {\n const buf = new ArrayBuffer(GEOMETRY_STRUCT_SIZE);\n const view = new DataView(buf);\n\n view.setUint32(0, geometry.magic, true);\n view.setUint32(4, geometry.structSize, true);\n // checksum at [8..40] — zeroed for hashing\n view.setUint32(40, geometry.metadataMaxSize, true);\n view.setUint32(44, geometry.metadataSlotCount, true);\n view.setUint32(48, geometry.logicalBlockSize, true);\n\n // Compute checksum over the struct with checksum field zeroed\n const checksum = await sha256(buf);\n const out = new Uint8Array(buf);\n out.set(checksum, 8);\n\n // Pad to LP_METADATA_GEOMETRY_SIZE\n return padBuffer(buf, LP_METADATA_GEOMETRY_SIZE);\n}\n\nfunction serializeTableDescriptor(\n view: DataView,\n offset: number,\n desc: LpMetadataTableDescriptor,\n) {\n view.setUint32(offset + 0, desc.offset, true);\n view.setUint32(offset + 4, desc.numEntries, true);\n view.setUint32(offset + 8, desc.entrySize, true);\n}\n\nfunction serializeNameToFixedArray(\n view: DataView,\n offset: number,\n name: string,\n maxLen: number,\n) {\n const encoded = new TextEncoder().encode(name);\n for (let i = 0; i < maxLen; i++) {\n view.setUint8(offset + i, i < encoded.length ? encoded[i] : 0);\n }\n}\n\nfunction serializePartition(partition: LpMetadataPartition): ArrayBuffer {\n const buf = new ArrayBuffer(PARTITION_STRUCT_SIZE);\n const view = new DataView(buf);\n serializeNameToFixedArray(view, 0, partition.name, 36);\n view.setUint32(36, partition.attributes, true);\n view.setUint32(40, partition.firstExtentIndex, true);\n view.setUint32(44, partition.numExtents, true);\n view.setUint32(48, partition.groupIndex, true);\n return buf;\n}\n\nfunction serializeExtent(extent: LpMetadataExtent): ArrayBuffer {\n const buf = new ArrayBuffer(EXTENT_STRUCT_SIZE);\n const view = new DataView(buf);\n view.setBigUint64(0, extent.numSectors, true);\n view.setUint32(8, extent.targetType, true);\n view.setBigUint64(12, extent.targetData, true);\n view.setUint32(20, extent.targetSource, true);\n return buf;\n}\n\nfunction serializeGroup(group: LpMetadataPartitionGroup): ArrayBuffer {\n const buf = new ArrayBuffer(GROUP_STRUCT_SIZE);\n const view = new DataView(buf);\n serializeNameToFixedArray(view, 0, group.name, 36);\n view.setUint32(36, group.flags, true);\n view.setBigUint64(40, group.maximumSize, true);\n return buf;\n}\n\nfunction serializeBlockDevice(bd: LpMetadataBlockDevice): ArrayBuffer {\n const buf = new ArrayBuffer(BLOCK_DEVICE_STRUCT_SIZE);\n const view = new DataView(buf);\n view.setBigUint64(0, bd.firstLogicalSector, true);\n view.setUint32(8, bd.alignment, true);\n view.setUint32(12, bd.alignmentOffset, true);\n view.setBigUint64(16, bd.size, true);\n serializeNameToFixedArray(view, 24, bd.partitionName, 36);\n view.setUint32(60, bd.flags, true);\n return buf;\n}\n\nexport async function serializeMetadata(\n metadata: LpMetadata,\n): Promise<ArrayBuffer> {\n const { header } = metadata;\n\n // Serialize each table\n const partitionBufs = metadata.partitions.map(serializePartition);\n const extentBufs = metadata.extents.map(serializeExtent);\n const groupBufs = metadata.groups.map(serializeGroup);\n const blockDevBufs = metadata.blockDevices.map(serializeBlockDevice);\n\n const tablesParts = [\n ...partitionBufs,\n ...extentBufs,\n ...groupBufs,\n ...blockDevBufs,\n ];\n const tablesBuffer = concatBuffers(...tablesParts);\n\n // Compute table descriptor offsets\n const partitionsOffset = 0;\n const extentsOffset = partitionBufs.reduce((s, b) => s + b.byteLength, 0);\n const groupsOffset =\n extentsOffset + extentBufs.reduce((s, b) => s + b.byteLength, 0);\n const blockDevicesOffset =\n groupsOffset + groupBufs.reduce((s, b) => s + b.byteLength, 0);\n\n const tablesChecksum = await sha256(tablesBuffer);\n const tablesSize = tablesBuffer.byteLength;\n\n // Enforce header size that matches metadata minor version.\n const headerSize =\n header.minorVersion < LP_METADATA_VERSION_FOR_EXPANDED_HEADER\n ? HEADER_V1_0_SIZE\n : HEADER_V1_2_SIZE;\n\n const headerBuf = new ArrayBuffer(headerSize);\n const hv = new DataView(headerBuf);\n\n hv.setUint32(0, LP_METADATA_HEADER_MAGIC, true);\n hv.setUint16(4, header.majorVersion, true);\n hv.setUint16(6, header.minorVersion, true);\n hv.setUint32(8, headerSize, true);\n // [12..44]: headerChecksum — zeroed initially for hashing\n hv.setUint32(44, tablesSize, true);\n new Uint8Array(headerBuf).set(tablesChecksum, 48); // tablesChecksum at [48..80]\n\n // Table descriptors\n const hDescView = new DataView(headerBuf);\n serializeTableDescriptor(hDescView, 80, {\n offset: partitionsOffset,\n numEntries: metadata.partitions.length,\n entrySize: PARTITION_STRUCT_SIZE,\n });\n serializeTableDescriptor(hDescView, 92, {\n offset: extentsOffset,\n numEntries: metadata.extents.length,\n entrySize: EXTENT_STRUCT_SIZE,\n });\n serializeTableDescriptor(hDescView, 104, {\n offset: groupsOffset,\n numEntries: metadata.groups.length,\n entrySize: GROUP_STRUCT_SIZE,\n });\n serializeTableDescriptor(hDescView, 116, {\n offset: blockDevicesOffset,\n numEntries: metadata.blockDevices.length,\n entrySize: BLOCK_DEVICE_STRUCT_SIZE,\n });\n\n if (headerSize >= HEADER_V1_2_SIZE) {\n hv.setUint32(128, header.flags, true);\n }\n\n // Compute header checksum\n const headerChecksum = await sha256(headerBuf);\n new Uint8Array(headerBuf).set(headerChecksum, 12);\n\n return concatBuffers(headerBuf, tablesBuffer);\n}\n\n// ---------------------------------------------------------------------------\n// Public: build wipe-super sparse images (one per block device)\n// ---------------------------------------------------------------------------\n\n/**\n * Generate sparse images suitable for flashing to wipe the super partition.\n *\n * The first block device image contains the LP metadata region (reserved zeros +\n * geometry copies + metadata slots) followed by a skip chunk for the remaining\n * device space. Secondary block devices (retrofit) get a skip-only image.\n */\nexport async function buildWipeSuperImages(\n metadata: LpMetadata,\n): Promise<WipeSuperImage[]> {\n const { geometry } = metadata;\n const blockSize = geometry.logicalBlockSize;\n\n // Validate alignment requirements (matching AOSP ImageBuilder constructor checks)\n if (blockSize % LP_SECTOR_SIZE !== 0) {\n throw new LpError(\n `Block size ${blockSize} must be a multiple of sector size ${LP_SECTOR_SIZE}`,\n );\n }\n if (LP_METADATA_GEOMETRY_SIZE % blockSize !== 0) {\n throw new LpError(\n `Geometry size ${LP_METADATA_GEOMETRY_SIZE} is not a multiple of block size ${blockSize}`,\n );\n }\n if (LP_PARTITION_RESERVED_BYTES % blockSize !== 0) {\n throw new LpError(\n `Reserved size ${LP_PARTITION_RESERVED_BYTES} is not a multiple of block size ${blockSize}`,\n );\n }\n if (geometry.metadataMaxSize % blockSize !== 0) {\n throw new LpError(\n `Metadata max size ${geometry.metadataMaxSize} must be a multiple of block size ${blockSize}`,\n );\n }\n\n // Serialize geometry and metadata once — shared across all metadata slot copies\n const [geomBuf, rawMetaBuf] = await Promise.all([\n serializeGeometry(geometry),\n serializeMetadata(metadata),\n ]);\n\n // Pad metadata blob to metadataMaxSize\n const metaBuf = padBuffer(rawMetaBuf, geometry.metadataMaxSize);\n\n // allMetadata = geometry x2 + (primary slots x slotCount) + (backup slots x slotCount)\n const slotCount = geometry.metadataSlotCount;\n const allMetaParts: ArrayBuffer[] = [\n geomBuf,\n geomBuf,\n ...Array(slotCount).fill(metaBuf),\n ...Array(slotCount).fill(metaBuf),\n ];\n const allMetadata = concatBuffers(...allMetaParts);\n const metadataBlocks = allMetadata.byteLength / blockSize;\n const reservedBlocks = LP_PARTITION_RESERVED_BYTES / blockSize;\n\n const results: WipeSuperImage[] = [];\n\n for (let i = 0; i < metadata.blockDevices.length; i++) {\n const bd = metadata.blockDevices[i];\n const partitionName = getBlockDevicePartitionName(bd);\n const forceSlot = !!(bd.flags & LP_BLOCK_DEVICE_SLOT_SUFFIXED);\n\n // Validate device size alignment and sparse block-count range\n if (bd.size % BigInt(blockSize) !== 0n) {\n throw new LpError(\n `Device \"${partitionName}\" size ${bd.size} is not a multiple of block size ${blockSize}`,\n );\n }\n const deviceBlocks = Number(bd.size) / blockSize;\n if (deviceBlocks >= 0xffffffff) {\n throw new LpError(\n `Device \"${partitionName}\" is too large to encode with sparse format`,\n );\n }\n\n let sparseBlob: Blob;\n\n if (i === 0) {\n // Primary super device: write reserved zeros + metadata region + skip rest\n const skipBlocks = deviceBlocks - reservedBlocks - metadataBlocks;\n if (skipBlocks < 0) {\n throw new LpError(\n `Device \"${partitionName}\" is too small to hold LP metadata`,\n );\n }\n\n const sparseHeader: Sparse.SparseHeader = {\n blockSize,\n blocks: deviceBlocks,\n chunks: 3,\n crc32: 0,\n };\n const chunks: Sparse.SparseChunk[] = [\n {\n type: Sparse.ChunkType.Fill,\n blocks: reservedBlocks,\n dataBytes: 4,\n data: new Blob([new Uint32Array([0]).buffer]),\n },\n {\n type: Sparse.ChunkType.Raw,\n blocks: metadataBlocks,\n dataBytes: allMetadata.byteLength,\n data: new Blob([allMetadata]),\n },\n {\n type: Sparse.ChunkType.Skip,\n blocks: skipBlocks,\n dataBytes: 0,\n data: new Blob([]),\n },\n ];\n sparseBlob = await Sparse.createImage(sparseHeader, chunks);\n } else {\n // Secondary retrofit device: skip-only image (no metadata stored here)\n const sparseHeader: Sparse.SparseHeader = {\n blockSize,\n blocks: deviceBlocks,\n chunks: 1,\n crc32: 0,\n };\n const chunks: Sparse.SparseChunk[] = [\n {\n type: Sparse.ChunkType.Skip,\n blocks: deviceBlocks,\n dataBytes: 0,\n data: new Blob([]),\n },\n ];\n sparseBlob = await Sparse.createImage(sparseHeader, chunks);\n }\n\n const data = await common.readBlobAsBuffer(sparseBlob);\n logDebug(\n `Generated ${data.byteLength}-byte sparse image for \"${partitionName}\"`,\n );\n\n results.push({ partitionName, data, forceSlot });\n }\n\n return results;\n}\n","/*\n Copyright (c) 2022 Gildas Lormeau. All rights reserved.\n\n Redistribution and use in source and binary forms, with or without\n modification, are permitted provided that the following conditions are met:\n\n 1. Redistributions of source code must retain the above copyright notice,\n this list of conditions and the following disclaimer.\n\n 2. Redistributions in binary form must reproduce the above copyright \n notice, this list of conditions and the following disclaimer in \n the documentation and/or other materials provided with the distribution.\n\n 3. The names of the authors may not be used to endorse or promote products\n derived from this software without specific prior written permission.\n\n THIS SOFTWARE IS PROVIDED ''AS IS'' AND ANY EXPRESSED OR IMPLIED WARRANTIES,\n INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND\n FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL JCRAFT,\n INC. OR ANY CONTRIBUTORS TO THIS SOFTWARE BE LIABLE FOR ANY DIRECT, INDIRECT,\n INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT\n LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA,\n OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF\n LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING\n NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE,\n EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.\n */\n\nconst MAX_32_BITS = 0xffffffff;\nconst MAX_16_BITS = 0xffff;\nconst MAX_8_BITS = 0xff;\nconst COMPRESSION_METHOD_DEFLATE = 0x08;\nconst COMPRESSION_METHOD_DEFLATE_64 = 0x09;\nconst COMPRESSION_METHOD_STORE = 0x00;\nconst COMPRESSION_METHOD_AES = 0x63;\n\nconst LOCAL_FILE_HEADER_SIGNATURE = 0x04034b50;\nconst SPLIT_ZIP_FILE_SIGNATURE = 0x08074b50;\nconst DATA_DESCRIPTOR_RECORD_SIGNATURE = SPLIT_ZIP_FILE_SIGNATURE;\nconst CENTRAL_FILE_HEADER_SIGNATURE = 0x02014b50;\nconst END_OF_CENTRAL_DIR_SIGNATURE = 0x06054b50;\nconst ZIP64_END_OF_CENTRAL_DIR_SIGNATURE = 0x06064b50;\nconst ZIP64_END_OF_CENTRAL_DIR_LOCATOR_SIGNATURE = 0x07064b50;\nconst END_OF_CENTRAL_DIR_LENGTH = 22;\nconst ZIP64_END_OF_CENTRAL_DIR_LOCATOR_LENGTH = 20;\nconst ZIP64_END_OF_CENTRAL_DIR_LENGTH = 56;\nconst ZIP64_END_OF_CENTRAL_DIR_TOTAL_LENGTH = END_OF_CENTRAL_DIR_LENGTH + ZIP64_END_OF_CENTRAL_DIR_LOCATOR_LENGTH + ZIP64_END_OF_CENTRAL_DIR_LENGTH;\n\nconst DATA_DESCRIPTOR_RECORD_LENGTH = 12;\nconst DATA_DESCRIPTOR_RECORD_ZIP_64_LENGTH = 20;\nconst DATA_DESCRIPTOR_RECORD_SIGNATURE_LENGTH = 4;\n\nconst EXTRAFIELD_TYPE_ZIP64 = 0x0001;\nconst EXTRAFIELD_TYPE_AES = 0x9901;\nconst EXTRAFIELD_TYPE_NTFS = 0x000a;\nconst EXTRAFIELD_TYPE_NTFS_TAG1 = 0x0001;\nconst EXTRAFIELD_TYPE_EXTENDED_TIMESTAMP = 0x5455;\nconst EXTRAFIELD_TYPE_UNICODE_PATH = 0x7075;\nconst EXTRAFIELD_TYPE_UNICODE_COMMENT = 0x6375;\nconst EXTRAFIELD_TYPE_USDZ = 0x1986;\nconst EXTRAFIELD_TYPE_INFOZIP = 0x7875;\nconst EXTRAFIELD_TYPE_UNIX = 0x7855;\n\nconst BITFLAG_ENCRYPTED = 0b1;\nconst BITFLAG_LEVEL = 0b0110;\nconst BITFLAG_LEVEL_MAX_MASK = 0b010;\nconst BITFLAG_LEVEL_FAST_MASK = 0b100;\nconst BITFLAG_LEVEL_SUPER_FAST_MASK = 0b110;\nconst BITFLAG_DATA_DESCRIPTOR = 0b1000;\nconst BITFLAG_LANG_ENCODING_FLAG = 0b100000000000;\nconst FILE_ATTR_MSDOS_DIR_MASK = 0b10000;\nconst FILE_ATTR_MSDOS_READONLY_MASK = 0x01;\nconst FILE_ATTR_MSDOS_HIDDEN_MASK = 0x02;\nconst FILE_ATTR_MSDOS_SYSTEM_MASK = 0x04;\nconst FILE_ATTR_MSDOS_ARCHIVE_MASK = 0x20;\nconst FILE_ATTR_UNIX_TYPE_MASK = 0o170000;\nconst FILE_ATTR_UNIX_TYPE_DIR = 0o040000;\nconst FILE_ATTR_UNIX_EXECUTABLE_MASK = 0o111;\nconst FILE_ATTR_UNIX_DEFAULT_MASK = 0o644;\nconst FILE_ATTR_UNIX_SETUID_MASK = 0o4000;\nconst FILE_ATTR_UNIX_SETGID_MASK = 0o2000;\nconst FILE_ATTR_UNIX_STICKY_MASK = 0o1000;\n\nconst VERSION_DEFLATE = 0x14;\nconst VERSION_ZIP64 = 0x2D;\nconst VERSION_AES = 0x33;\n\nconst DIRECTORY_SIGNATURE = \"/\";\n\nconst HEADER_SIZE = 30;\nconst HEADER_OFFSET_SIGNATURE = 10;\nconst HEADER_OFFSET_COMPRESSED_SIZE = 14;\nconst HEADER_OFFSET_UNCOMPRESSED_SIZE = 18;\n\nconst MAX_DATE = new Date(2107, 11, 31);\nconst MIN_DATE = new Date(1980, 0, 1);\n\nconst UNDEFINED_VALUE = undefined;\nconst INFINITY_VALUE = Infinity;\nconst UNDEFINED_TYPE = \"undefined\";\nconst FUNCTION_TYPE = \"function\";\nconst OBJECT_TYPE = \"object\";\n\nexport {\n\tMAX_32_BITS,\n\tMAX_16_BITS,\n\tMAX_8_BITS,\n\tCOMPRESSION_METHOD_DEFLATE,\n\tCOMPRESSION_METHOD_DEFLATE_64,\n\tCOMPRESSION_METHOD_STORE,\n\tCOMPRESSION_METHOD_AES,\n\tSPLIT_ZIP_FILE_SIGNATURE,\n\tLOCAL_FILE_HEADER_SIGNATURE,\n\tDATA_DESCRIPTOR_RECORD_SIGNATURE,\n\tCENTRAL_FILE_HEADER_SIGNATURE,\n\tEND_OF_CENTRAL_DIR_SIGNATURE,\n\tZIP64_END_OF_CENTRAL_DIR_LOCATOR_SIGNATURE,\n\tZIP64_END_OF_CENTRAL_DIR_SIGNATURE,\n\tDATA_DESCRIPTOR_RECORD_LENGTH,\n\tDATA_DESCRIPTOR_RECORD_ZIP_64_LENGTH,\n\tDATA_DESCRIPTOR_RECORD_SIGNATURE_LENGTH,\n\tEXTRAFIELD_TYPE_ZIP64,\n\tEXTRAFIELD_TYPE_AES,\n\tEXTRAFIELD_TYPE_NTFS,\n\tEXTRAFIELD_TYPE_NTFS_TAG1,\n\tEXTRAFIELD_TYPE_EXTENDED_TIMESTAMP,\n\tEXTRAFIELD_TYPE_UNICODE_PATH,\n\tEXTRAFIELD_TYPE_UNICODE_COMMENT,\n\tEXTRAFIELD_TYPE_USDZ,\n\tEXTRAFIELD_TYPE_INFOZIP,\n\tEXTRAFIELD_TYPE_UNIX,\n\tEND_OF_CENTRAL_DIR_LENGTH,\n\tZIP64_END_OF_CENTRAL_DIR_LOCATOR_LENGTH,\n\tZIP64_END_OF_CENTRAL_DIR_LENGTH,\n\tZIP64_END_OF_CENTRAL_DIR_TOTAL_LENGTH,\n\tBITFLAG_ENCRYPTED,\n\tBITFLAG_LEVEL,\n\tBITFLAG_LEVEL_MAX_MASK,\n\tBITFLAG_LEVEL_FAST_MASK,\n\tBITFLAG_LEVEL_SUPER_FAST_MASK,\n\tBITFLAG_DATA_DESCRIPTOR,\n\tBITFLAG_LANG_ENCODING_FLAG,\n\tFILE_ATTR_MSDOS_DIR_MASK,\n\tFILE_ATTR_MSDOS_READONLY_MASK,\n\tFILE_ATTR_MSDOS_HIDDEN_MASK,\n\tFILE_ATTR_MSDOS_SYSTEM_MASK,\n\tFILE_ATTR_MSDOS_ARCHIVE_MASK,\n\tFILE_ATTR_UNIX_TYPE_MASK,\n\tFILE_ATTR_UNIX_TYPE_DIR,\n\tFILE_ATTR_UNIX_EXECUTABLE_MASK,\n\tFILE_ATTR_UNIX_DEFAULT_MASK,\n\tFILE_ATTR_UNIX_SETUID_MASK,\n\tFILE_ATTR_UNIX_SETGID_MASK,\n\tFILE_ATTR_UNIX_STICKY_MASK,\n\tVERSION_DEFLATE,\n\tVERSION_ZIP64,\n\tVERSION_AES,\n\tHEADER_SIZE,\n\tHEADER_OFFSET_SIGNATURE,\n\tHEADER_OFFSET_COMPRESSED_SIZE,\n\tHEADER_OFFSET_UNCOMPRESSED_SIZE,\n\tDIRECTORY_SIGNATURE,\n\tMIN_DATE,\n\tMAX_DATE,\n\tUNDEFINED_VALUE,\n\tINFINITY_VALUE,\n\tUNDEFINED_TYPE,\n\tFUNCTION_TYPE,\n\tOBJECT_TYPE\n};","/*\n Copyright (c) 2025 Gildas Lormeau. All rights reserved.\n\n Redistribution and use in source and binary forms, with or without\n modification, are permitted provided that the following conditions are met:\n\n 1. Redistributions of source code must retain the above copyright notice,\n this list of conditions and the following disclaimer.\n\n 2. Redistributions in binary form must reproduce the above copyright \n notice, this list of conditions and the following disclaimer in \n the documentation and/or other materials provided with the distribution.\n\n 3. The names of the authors may not be used to endorse or promote products\n derived from this software without specific prior written permission.\n\n THIS SOFTWARE IS PROVIDED ''AS IS'' AND ANY EXPRESSED OR IMPLIED WARRANTIES,\n INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND\n FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL JCRAFT,\n INC. OR ANY CONTRIBUTORS TO THIS SOFTWARE BE LIABLE FOR ANY DIRECT, INDIRECT,\n INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT\n LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA,\n OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF\n LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING\n NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE,\n EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.\n */\n\n/* global navigator, CompressionStream, DecompressionStream */\n\nimport {\n\tUNDEFINED_VALUE,\n\tUNDEFINED_TYPE\n} from \"./constants.js\";\n\nconst MINIMUM_CHUNK_SIZE = 64;\nlet maxWorkers = 2;\ntry {\n\tif (typeof navigator != UNDEFINED_TYPE && navigator.hardwareConcurrency) {\n\t\tmaxWorkers = navigator.hardwareConcurrency;\n\t}\n} catch {\n\t// ignored\n}\nconst DEFAULT_CONFIGURATION = {\n\tworkerURI: \"./core/web-worker-wasm.js\",\n\twasmURI: \"./core/streams/zlib-wasm/zlib-streams.wasm\",\n\tchunkSize: 64 * 1024,\n\tmaxWorkers,\n\tterminateWorkerTimeout: 5000,\n\tuseWebWorkers: true,\n\tuseCompressionStream: true,\n\tCompressionStream: typeof CompressionStream != UNDEFINED_TYPE && CompressionStream,\n\tDecompressionStream: typeof DecompressionStream != UNDEFINED_TYPE && DecompressionStream\n};\n\nconst config = Object.assign({}, DEFAULT_CONFIGURATION);\n\nexport {\n\tconfigure,\n\tgetConfiguration,\n\tgetChunkSize\n};\n\nfunction getConfiguration() {\n\treturn config;\n}\n\nfunction getChunkSize(config) {\n\treturn Math.max(config.chunkSize, MINIMUM_CHUNK_SIZE);\n}\n\nfunction configure(configuration) {\n\tconst {\n\t\tbaseURI,\n\t\tchunkSize,\n\t\tmaxWorkers,\n\t\tterminateWorkerTimeout,\n\t\tuseCompressionStream,\n\t\tuseWebWorkers,\n\t\tCompressionStream,\n\t\tDecompressionStream,\n\t\tCompressionStreamZlib,\n\t\tDecompressionStreamZlib,\n\t\tworkerURI,\n\t\twasmURI\n\t} = configuration;\n\tsetIfDefined(\"baseURI\", baseURI);\n\tsetIfDefined(\"wasmURI\", wasmURI);\n\tsetIfDefined(\"workerURI\", workerURI);\n\tsetIfDefined(\"chunkSize\", chunkSize);\n\tsetIfDefined(\"maxWorkers\", maxWorkers);\n\tsetIfDefined(\"terminateWorkerTimeout\", terminateWorkerTimeout);\n\tsetIfDefined(\"useCompressionStream\", useCompressionStream);\n\tsetIfDefined(\"useWebWorkers\", useWebWorkers);\n\tsetIfDefined(\"CompressionStream\", CompressionStream);\n\tsetIfDefined(\"DecompressionStream\", DecompressionStream);\n\tsetIfDefined(\"CompressionStreamZlib\", CompressionStreamZlib);\n\tsetIfDefined(\"DecompressionStreamZlib\", DecompressionStreamZlib);\n}\n\nfunction setIfDefined(propertyName, propertyValue) {\n\tif (propertyValue !== UNDEFINED_VALUE) {\n\t\tconfig[propertyName] = propertyValue;\n\t}\n}\n","/*\n Copyright (c) 2022 Gildas Lormeau. All rights reserved.\n\n Redistribution and use in source and binary forms, with or without\n modification, are permitted provided that the following conditions are met:\n\n 1. Redistributions of source code must retain the above copyright notice,\n this list of conditions and the following disclaimer.\n\n 2. Redistributions in binary form must reproduce the above copyright \n notice, this list of conditions and the following disclaimer in \n the documentation and/or other materials provided with the distribution.\n\n 3. The names of the authors may not be used to endorse or promote products\n derived from this software without specific prior written permission.\n\n THIS SOFTWARE IS PROVIDED ''AS IS'' AND ANY EXPRESSED OR IMPLIED WARRANTIES,\n INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND\n FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL JCRAFT,\n INC. OR ANY CONTRIBUTORS TO THIS SOFTWARE BE LIABLE FOR ANY DIRECT, INDIRECT,\n INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT\n LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA,\n OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF\n LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING\n NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE,\n EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.\n */\n\nconst table = [];\nfor (let i = 0; i < 256; i++) {\n\tlet t = i;\n\tfor (let j = 0; j < 8; j++) {\n\t\tif (t & 1) {\n\t\t\tt = (t >>> 1) ^ 0xEDB88320;\n\t\t} else {\n\t\t\tt = t >>> 1;\n\t\t}\n\t}\n\ttable[i] = t;\n}\n\nclass Crc32 {\n\n\tconstructor(crc) {\n\t\tthis.crc = crc || -1;\n\t}\n\n\tappend(data) {\n\t\tlet crc = this.crc | 0;\n\t\tfor (let offset = 0, length = data.length | 0; offset < length; offset++) {\n\t\t\tcrc = (crc >>> 8) ^ table[(crc ^ data[offset]) & 0xFF];\n\t\t}\n\t\tthis.crc = crc;\n\t}\n\n\tget() {\n\t\treturn ~this.crc;\n\t}\n}\n\nexport {\n\tCrc32\n};","/*\n Copyright (c) 2022 Gildas Lormeau. All rights reserved.\n\n Redistribution and use in source and binary forms, with or without\n modification, are permitted provided that the following conditions are met:\n\n 1. Redistributions of source code must retain the above copyright notice,\n this list of conditions and the following disclaimer.\n\n 2. Redistributions in binary form must reproduce the above copyright \n notice, this list of conditions and the following disclaimer in \n the documentation and/or other materials provided with the distribution.\n\n 3. The names of the authors may not be used to endorse or promote products\n derived from this software without specific prior written permission.\n\n THIS SOFTWARE IS PROVIDED ''AS IS'' AND ANY EXPRESSED OR IMPLIED WARRANTIES,\n INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND\n FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL JCRAFT,\n INC. OR ANY CONTRIBUTORS TO THIS SOFTWARE BE LIABLE FOR ANY DIRECT, INDIRECT,\n INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT\n LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA,\n OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF\n LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING\n NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE,\n EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.\n */\n\n/* global TransformStream */\n\nimport { Crc32 } from \"./codecs/crc32.js\";\n\nclass Crc32Stream extends TransformStream {\n\n\tconstructor() {\n\t\t// deno-lint-ignore prefer-const\n\t\tlet stream;\n\t\tconst crc32 = new Crc32();\n\t\tsuper({\n\t\t\ttransform(chunk, controller) {\n\t\t\t\tcrc32.append(chunk);\n\t\t\t\tcontroller.enqueue(chunk);\n\t\t\t},\n\t\t\tflush() {\n\t\t\t\tconst value = new Uint8Array(4);\n\t\t\t\tconst dataView = new DataView(value.buffer);\n\t\t\t\tdataView.setUint32(0, crc32.get());\n\t\t\t\tstream.value = value;\n\t\t\t}\n\t\t});\n\t\tstream = this;\n\t}\n}\n\nexport {\n\tCrc32Stream\n};","// Derived from https://github.com/xqdoo00o/jszip/blob/master/lib/sjcl.js and https://github.com/bitwiseshiftleft/sjcl\n\n// deno-lint-ignore-file no-this-alias\n\n/*\n * SJCL is open. You can use, modify and redistribute it under a BSD\n * license or under the GNU GPL, version 2.0.\n */\n\n/** @fileOverview Javascript cryptography implementation.\n *\n * Crush to remove comments, shorten variable names and\n * generally reduce transmission size.\n *\n * @author Emily Stark\n * @author Mike Hamburg\n * @author Dan Boneh\n */\n\n/*jslint indent: 2, bitwise: false, nomen: false, plusplus: false, white: false, regexp: false */\n\n/** @fileOverview Arrays of bits, encoded as arrays of Numbers.\n *\n * @author Emily Stark\n * @author Mike Hamburg\n * @author Dan Boneh\n */\n\n/**\n * Arrays of bits, encoded as arrays of Numbers.\n * @namespace\n * @description\n * <p>\n * These objects are the currency accepted by SJCL's crypto functions.\n * </p>\n *\n * <p>\n * Most of our crypto primitives operate on arrays of 4-byte words internally,\n * but many of them can take arguments that are not a multiple of 4 bytes.\n * This library encodes arrays of bits (whose size need not be a multiple of 8\n * bits) as arrays of 32-bit words. The bits are packed, big-endian, into an\n * array of words, 32 bits at a time. Since the words are double-precision\n * floating point numbers, they fit some extra data. We use this (in a private,\n * possibly-changing manner) to encode the number of bits actually present\n * in the last word of the array.\n * </p>\n *\n * <p>\n * Because bitwise ops clear this out-of-band data, these arrays can be passed\n * to ciphers like AES which want arrays of words.\n * </p>\n */\nconst bitArray = {\n\t/**\n\t * Concatenate two bit arrays.\n\t * @param {bitArray} a1 The first array.\n\t * @param {bitArray} a2 The second array.\n\t * @return {bitArray} The concatenation of a1 and a2.\n\t */\n\tconcat(a1, a2) {\n\t\tif (a1.length === 0 || a2.length === 0) {\n\t\t\treturn a1.concat(a2);\n\t\t}\n\n\t\tconst last = a1[a1.length - 1], shift = bitArray.getPartial(last);\n\t\tif (shift === 32) {\n\t\t\treturn a1.concat(a2);\n\t\t} else {\n\t\t\treturn bitArray._shiftRight(a2, shift, last | 0, a1.slice(0, a1.length - 1));\n\t\t}\n\t},\n\n\t/**\n\t * Find the length of an array of bits.\n\t * @param {bitArray} a The array.\n\t * @return {Number} The length of a, in bits.\n\t */\n\tbitLength(a) {\n\t\tconst l = a.length;\n\t\tif (l === 0) {\n\t\t\treturn 0;\n\t\t}\n\t\tconst x = a[l - 1];\n\t\treturn (l - 1) * 32 + bitArray.getPartial(x);\n\t},\n\n\t/**\n\t * Truncate an array.\n\t * @param {bitArray} a The array.\n\t * @param {Number} len The length to truncate to, in bits.\n\t * @return {bitArray} A new array, truncated to len bits.\n\t */\n\tclamp(a, len) {\n\t\tif (a.length * 32 < len) {\n\t\t\treturn a;\n\t\t}\n\t\ta = a.slice(0, Math.ceil(len / 32));\n\t\tconst l = a.length;\n\t\tlen = len & 31;\n\t\tif (l > 0 && len) {\n\t\t\ta[l - 1] = bitArray.partial(len, a[l - 1] & 0x80000000 >> (len - 1), 1);\n\t\t}\n\t\treturn a;\n\t},\n\n\t/**\n\t * Make a partial word for a bit array.\n\t * @param {Number} len The number of bits in the word.\n\t * @param {Number} x The bits.\n\t * @param {Number} [_end=0] Pass 1 if x has already been shifted to the high side.\n\t * @return {Number} The partial word.\n\t */\n\tpartial(len, x, _end) {\n\t\tif (len === 32) {\n\t\t\treturn x;\n\t\t}\n\t\treturn (_end ? x | 0 : x << (32 - len)) + len * 0x10000000000;\n\t},\n\n\t/**\n\t * Get the number of bits used by a partial word.\n\t * @param {Number} x The partial word.\n\t * @return {Number} The number of bits used by the partial word.\n\t */\n\tgetPartial(x) {\n\t\treturn Math.round(x / 0x10000000000) || 32;\n\t},\n\n\t/** Shift an array right.\n\t * @param {bitArray} a The array to shift.\n\t * @param {Number} shift The number of bits to shift.\n\t * @param {Number} [carry=0] A byte to carry in\n\t * @param {bitArray} [out=[]] An array to prepend to the output.\n\t * @private\n\t */\n\t_shiftRight(a, shift, carry, out) {\n\t\tif (out === undefined) {\n\t\t\tout = [];\n\t\t}\n\n\t\tfor (; shift >= 32; shift -= 32) {\n\t\t\tout.push(carry);\n\t\t\tcarry = 0;\n\t\t}\n\t\tif (shift === 0) {\n\t\t\treturn out.concat(a);\n\t\t}\n\n\t\tfor (let i = 0; i < a.length; i++) {\n\t\t\tout.push(carry | a[i] >>> shift);\n\t\t\tcarry = a[i] << (32 - shift);\n\t\t}\n\t\tconst last2 = a.length ? a[a.length - 1] : 0;\n\t\tconst shift2 = bitArray.getPartial(last2);\n\t\tout.push(bitArray.partial(shift + shift2 & 31, (shift + shift2 > 32) ? carry : out.pop(), 1));\n\t\treturn out;\n\t}\n};\n\n/** @fileOverview Bit array codec implementations.\n *\n * @author Emily Stark\n * @author Mike Hamburg\n * @author Dan Boneh\n */\n\n/**\n * Arrays of bytes\n * @namespace\n */\nconst codec = {\n\tbytes: {\n\t\t/** Convert from a bitArray to an array of bytes. */\n\t\tfromBits(arr) {\n\t\t\tconst bl = bitArray.bitLength(arr);\n\t\t\tconst byteLength = bl / 8;\n\t\t\tconst out = new Uint8Array(byteLength);\n\t\t\tlet tmp;\n\t\t\tfor (let i = 0; i < byteLength; i++) {\n\t\t\t\tif ((i & 3) === 0) {\n\t\t\t\t\ttmp = arr[i / 4];\n\t\t\t\t}\n\t\t\t\tout[i] = tmp >>> 24;\n\t\t\t\ttmp <<= 8;\n\t\t\t}\n\t\t\treturn out;\n\t\t},\n\t\t/** Convert from an array of bytes to a bitArray. */\n\t\ttoBits(bytes) {\n\t\t\tconst out = [];\n\t\t\tlet i;\n\t\t\tlet tmp = 0;\n\t\t\tfor (i = 0; i < bytes.length; i++) {\n\t\t\t\ttmp = tmp << 8 | bytes[i];\n\t\t\t\tif ((i & 3) === 3) {\n\t\t\t\t\tout.push(tmp);\n\t\t\t\t\ttmp = 0;\n\t\t\t\t}\n\t\t\t}\n\t\t\tif (i & 3) {\n\t\t\t\tout.push(bitArray.partial(8 * (i & 3), tmp));\n\t\t\t}\n\t\t\treturn out;\n\t\t}\n\t}\n};\n\nconst hash = {};\n\n/**\n * Context for a SHA-1 operation in progress.\n * @constructor\n */\nhash.sha1 = class {\n\tconstructor(hash) {\n\t\tconst sha1 = this;\n\t\t/**\n\t\t * The hash's block size, in bits.\n\t\t * @constant\n\t\t */\n\t\tsha1.blockSize = 512;\n\t\t/**\n\t\t * The SHA-1 initialization vector.\n\t\t * @private\n\t\t */\n\t\tsha1._init = [0x67452301, 0xEFCDAB89, 0x98BADCFE, 0x10325476, 0xC3D2E1F0];\n\t\t/**\n\t\t * The SHA-1 hash key.\n\t\t * @private\n\t\t */\n\t\tsha1._key = [0x5A827999, 0x6ED9EBA1, 0x8F1BBCDC, 0xCA62C1D6];\n\t\tif (hash) {\n\t\t\tsha1._h = hash._h.slice(0);\n\t\t\tsha1._buffer = hash._buffer.slice(0);\n\t\t\tsha1._length = hash._length;\n\t\t} else {\n\t\t\tsha1.reset();\n\t\t}\n\t}\n\n\t/**\n\t * Reset the hash state.\n\t * @return this\n\t */\n\treset() {\n\t\tconst sha1 = this;\n\t\tsha1._h = sha1._init.slice(0);\n\t\tsha1._buffer = [];\n\t\tsha1._length = 0;\n\t\treturn sha1;\n\t}\n\n\t/**\n\t * Input several words to the hash.\n\t * @param {bitArray|String} data the data to hash.\n\t * @return this\n\t */\n\tupdate(data) {\n\t\tconst sha1 = this;\n\t\tif (typeof data === \"string\") {\n\t\t\tdata = codec.utf8String.toBits(data);\n\t\t}\n\t\tconst b = sha1._buffer = bitArray.concat(sha1._buffer, data);\n\t\tconst ol = sha1._length;\n\t\tconst nl = sha1._length = ol + bitArray.bitLength(data);\n\t\tif (nl > 9007199254740991) {\n\t\t\tthrow new Error(\"Cannot hash more than 2^53 - 1 bits\");\n\t\t}\n\t\tconst c = new Uint32Array(b);\n\t\tlet j = 0;\n\t\tfor (let i = sha1.blockSize + ol - ((sha1.blockSize + ol) & (sha1.blockSize - 1)); i <= nl;\n\t\t\ti += sha1.blockSize) {\n\t\t\tsha1._block(c.subarray(16 * j, 16 * (j + 1)));\n\t\t\tj += 1;\n\t\t}\n\t\tb.splice(0, 16 * j);\n\t\treturn sha1;\n\t}\n\n\t/**\n\t * Complete hashing and output the hash value.\n\t * @return {bitArray} The hash value, an array of 5 big-endian words. TODO\n\t */\n\tfinalize() {\n\t\tconst sha1 = this;\n\t\tlet b = sha1._buffer;\n\t\tconst h = sha1._h;\n\n\t\t// Round out and push the buffer\n\t\tb = bitArray.concat(b, [bitArray.partial(1, 1)]);\n\t\t// Round out the buffer to a multiple of 16 words, less the 2 length words.\n\t\tfor (let i = b.length + 2; i & 15; i++) {\n\t\t\tb.push(0);\n\t\t}\n\n\t\t// append the length\n\t\tb.push(Math.floor(sha1._length / 0x100000000));\n\t\tb.push(sha1._length | 0);\n\n\t\twhile (b.length) {\n\t\t\tsha1._block(b.splice(0, 16));\n\t\t}\n\n\t\tsha1.reset();\n\t\treturn h;\n\t}\n\n\t/**\n\t * The SHA-1 logical functions f(0), f(1), ..., f(79).\n\t * @private\n\t */\n\t_f(t, b, c, d) {\n\t\tif (t <= 19) {\n\t\t\treturn (b & c) | (~b & d);\n\t\t} else if (t <= 39) {\n\t\t\treturn b ^ c ^ d;\n\t\t} else if (t <= 59) {\n\t\t\treturn (b & c) | (b & d) | (c & d);\n\t\t} else if (t <= 79) {\n\t\t\treturn b ^ c ^ d;\n\t\t}\n\t}\n\n\t/**\n\t * Circular left-shift operator.\n\t * @private\n\t */\n\t_S(n, x) {\n\t\treturn (x << n) | (x >>> 32 - n);\n\t}\n\n\t/**\n\t * Perform one cycle of SHA-1.\n\t * @param {Uint32Array|bitArray} words one block of words.\n\t * @private\n\t */\n\t_block(words) {\n\t\tconst sha1 = this;\n\t\tconst h = sha1._h;\n\t\t// When words is passed to _block, it has 16 elements. SHA1 _block\n\t\t// function extends words with new elements (at the end there are 80 elements). \n\t\t// The problem is that if we use Uint32Array instead of Array, \n\t\t// the length of Uint32Array cannot be changed. Thus, we replace words with a \n\t\t// normal Array here.\n\t\tconst w = Array(80); // do not use Uint32Array here as the instantiation is slower\n\t\tfor (let j = 0; j < 16; j++) {\n\t\t\tw[j] = words[j];\n\t\t}\n\n\t\tlet a = h[0];\n\t\tlet b = h[1];\n\t\tlet c = h[2];\n\t\tlet d = h[3];\n\t\tlet e = h[4];\n\n\t\tfor (let t = 0; t <= 79; t++) {\n\t\t\tif (t >= 16) {\n\t\t\t\tw[t] = sha1._S(1, w[t - 3] ^ w[t - 8] ^ w[t - 14] ^ w[t - 16]);\n\t\t\t}\n\t\t\tconst tmp = (sha1._S(5, a) + sha1._f(t, b, c, d) + e + w[t] +\n\t\t\t\tsha1._key[Math.floor(t / 20)]) | 0;\n\t\t\te = d;\n\t\t\td = c;\n\t\t\tc = sha1._S(30, b);\n\t\t\tb = a;\n\t\t\ta = tmp;\n\t\t}\n\n\t\th[0] = (h[0] + a) | 0;\n\t\th[1] = (h[1] + b) | 0;\n\t\th[2] = (h[2] + c) | 0;\n\t\th[3] = (h[3] + d) | 0;\n\t\th[4] = (h[4] + e) | 0;\n\t}\n};\n\n/** @fileOverview Low-level AES implementation.\n *\n * This file contains a low-level implementation of AES, optimized for\n * size and for efficiency on several browsers. It is based on\n * OpenSSL's aes_core.c, a public-domain implementation by Vincent\n * Rijmen, Antoon Bosselaers and Paulo Barreto.\n *\n * An older version of this implementation is available in the public\n * domain, but this one is (c) Emily Stark, Mike Hamburg, Dan Boneh,\n * Stanford University 2008-2010 and BSD-licensed for liability\n * reasons.\n *\n * @author Emily Stark\n * @author Mike Hamburg\n * @author Dan Boneh\n */\n\nconst cipher = {};\n\n/**\n * Schedule out an AES key for both encryption and decryption. This\n * is a low-level class. Use a cipher mode to do bulk encryption.\n *\n * @constructor\n * @param {Array} key The key as an array of 4, 6 or 8 words.\n */\ncipher.aes = class {\n\tconstructor(key) {\n\t\t/**\n\t\t * The expanded S-box and inverse S-box tables. These will be computed\n\t\t * on the client so that we don't have to send them down the wire.\n\t\t *\n\t\t * There are two tables, _tables[0] is for encryption and\n\t\t * _tables[1] is for decryption.\n\t\t *\n\t\t * The first 4 sub-tables are the expanded S-box with MixColumns. The\n\t\t * last (_tables[01][4]) is the S-box itself.\n\t\t *\n\t\t * @private\n\t\t */\n\t\tconst aes = this;\n\t\taes._tables = [[[], [], [], [], []], [[], [], [], [], []]];\n\n\t\tif (!aes._tables[0][0][0]) {\n\t\t\taes._precompute();\n\t\t}\n\n\t\tconst sbox = aes._tables[0][4];\n\t\tconst decTable = aes._tables[1];\n\t\tconst keyLen = key.length;\n\n\t\tlet i, encKey, decKey, rcon = 1;\n\n\t\tif (keyLen !== 4 && keyLen !== 6 && keyLen !== 8) {\n\t\t\tthrow new Error(\"invalid aes key size\");\n\t\t}\n\n\t\taes._key = [encKey = key.slice(0), decKey = []];\n\n\t\t// schedule encryption keys\n\t\tfor (i = keyLen; i < 4 * keyLen + 28; i++) {\n\t\t\tlet tmp = encKey[i - 1];\n\n\t\t\t// apply sbox\n\t\t\tif (i % keyLen === 0 || (keyLen === 8 && i % keyLen === 4)) {\n\t\t\t\ttmp = sbox[tmp >>> 24] << 24 ^ sbox[tmp >> 16 & 255] << 16 ^ sbox[tmp >> 8 & 255] << 8 ^ sbox[tmp & 255];\n\n\t\t\t\t// shift rows and add rcon\n\t\t\t\tif (i % keyLen === 0) {\n\t\t\t\t\ttmp = tmp << 8 ^ tmp >>> 24 ^ rcon << 24;\n\t\t\t\t\trcon = rcon << 1 ^ (rcon >> 7) * 283;\n\t\t\t\t}\n\t\t\t}\n\n\t\t\tencKey[i] = encKey[i - keyLen] ^ tmp;\n\t\t}\n\n\t\t// schedule decryption keys\n\t\tfor (let j = 0; i; j++, i--) {\n\t\t\tconst tmp = encKey[j & 3 ? i : i - 4];\n\t\t\tif (i <= 4 || j < 4) {\n\t\t\t\tdecKey[j] = tmp;\n\t\t\t} else {\n\t\t\t\tdecKey[j] = decTable[0][sbox[tmp >>> 24]] ^\n\t\t\t\t\tdecTable[1][sbox[tmp >> 16 & 255]] ^\n\t\t\t\t\tdecTable[2][sbox[tmp >> 8 & 255]] ^\n\t\t\t\t\tdecTable[3][sbox[tmp & 255]];\n\t\t\t}\n\t\t}\n\t}\n\t// public\n\t/* Something like this might appear here eventually\n\tname: \"AES\",\n\tblockSize: 4,\n\tkeySizes: [4,6,8],\n\t*/\n\n\t/**\n\t * Encrypt an array of 4 big-endian words.\n\t * @param {Array} data The plaintext.\n\t * @return {Array} The ciphertext.\n\t */\n\tencrypt(data) {\n\t\treturn this._crypt(data, 0);\n\t}\n\n\t/**\n\t * Decrypt an array of 4 big-endian words.\n\t * @param {Array} data The ciphertext.\n\t * @return {Array} The plaintext.\n\t */\n\tdecrypt(data) {\n\t\treturn this._crypt(data, 1);\n\t}\n\n\t/**\n\t * Expand the S-box tables.\n\t *\n\t * @private\n\t */\n\t_precompute() {\n\t\tconst encTable = this._tables[0];\n\t\tconst decTable = this._tables[1];\n\t\tconst sbox = encTable[4];\n\t\tconst sboxInv = decTable[4];\n\t\tconst d = [];\n\t\tconst th = [];\n\t\tlet xInv, x2, x4, x8;\n\n\t\t// Compute double and third tables\n\t\tfor (let i = 0; i < 256; i++) {\n\t\t\tth[(d[i] = i << 1 ^ (i >> 7) * 283) ^ i] = i;\n\t\t}\n\n\t\tfor (let x = xInv = 0; !sbox[x]; x ^= x2 || 1, xInv = th[xInv] || 1) {\n\t\t\t// Compute sbox\n\t\t\tlet s = xInv ^ xInv << 1 ^ xInv << 2 ^ xInv << 3 ^ xInv << 4;\n\t\t\ts = s >> 8 ^ s & 255 ^ 99;\n\t\t\tsbox[x] = s;\n\t\t\tsboxInv[s] = x;\n\n\t\t\t// Compute MixColumns\n\t\t\tx8 = d[x4 = d[x2 = d[x]]];\n\t\t\tlet tDec = x8 * 0x1010101 ^ x4 * 0x10001 ^ x2 * 0x101 ^ x * 0x1010100;\n\t\t\tlet tEnc = d[s] * 0x101 ^ s * 0x1010100;\n\n\t\t\tfor (let i = 0; i < 4; i++) {\n\t\t\t\tencTable[i][x] = tEnc = tEnc << 24 ^ tEnc >>> 8;\n\t\t\t\tdecTable[i][s] = tDec = tDec << 24 ^ tDec >>> 8;\n\t\t\t}\n\t\t}\n\n\t\t// Compactify. Considerable speedup on Firefox.\n\t\tfor (let i = 0; i < 5; i++) {\n\t\t\tencTable[i] = encTable[i].slice(0);\n\t\t\tdecTable[i] = decTable[i].slice(0);\n\t\t}\n\t}\n\n\t/**\n\t * Encryption and decryption core.\n\t * @param {Array} input Four words to be encrypted or decrypted.\n\t * @param dir The direction, 0 for encrypt and 1 for decrypt.\n\t * @return {Array} The four encrypted or decrypted words.\n\t * @private\n\t */\n\t_crypt(input, dir) {\n\t\tif (input.length !== 4) {\n\t\t\tthrow new Error(\"invalid aes block size\");\n\t\t}\n\n\t\tconst key = this._key[dir];\n\n\t\tconst nInnerRounds = key.length / 4 - 2;\n\t\tconst out = [0, 0, 0, 0];\n\t\tconst table = this._tables[dir];\n\n\t\t// load up the tables\n\t\tconst t0 = table[0];\n\t\tconst t1 = table[1];\n\t\tconst t2 = table[2];\n\t\tconst t3 = table[3];\n\t\tconst sbox = table[4];\n\n\t\t// state variables a,b,c,d are loaded with pre-whitened data\n\t\tlet a = input[0] ^ key[0];\n\t\tlet b = input[dir ? 3 : 1] ^ key[1];\n\t\tlet c = input[2] ^ key[2];\n\t\tlet d = input[dir ? 1 : 3] ^ key[3];\n\t\tlet kIndex = 4;\n\t\tlet a2, b2, c2;\n\n\t\t// Inner rounds. Cribbed from OpenSSL.\n\t\tfor (let i = 0; i < nInnerRounds; i++) {\n\t\t\ta2 = t0[a >>> 24] ^ t1[b >> 16 & 255] ^ t2[c >> 8 & 255] ^ t3[d & 255] ^ key[kIndex];\n\t\t\tb2 = t0[b >>> 24] ^ t1[c >> 16 & 255] ^ t2[d >> 8 & 255] ^ t3[a & 255] ^ key[kIndex + 1];\n\t\t\tc2 = t0[c >>> 24] ^ t1[d >> 16 & 255] ^ t2[a >> 8 & 255] ^ t3[b & 255] ^ key[kIndex + 2];\n\t\t\td = t0[d >>> 24] ^ t1[a >> 16 & 255] ^ t2[b >> 8 & 255] ^ t3[c & 255] ^ key[kIndex + 3];\n\t\t\tkIndex += 4;\n\t\t\ta = a2; b = b2; c = c2;\n\t\t}\n\n\t\t// Last round.\n\t\tfor (let i = 0; i < 4; i++) {\n\t\t\tout[dir ? 3 & -i : i] =\n\t\t\t\tsbox[a >>> 24] << 24 ^\n\t\t\t\tsbox[b >> 16 & 255] << 16 ^\n\t\t\t\tsbox[c >> 8 & 255] << 8 ^\n\t\t\t\tsbox[d & 255] ^\n\t\t\t\tkey[kIndex++];\n\t\t\ta2 = a; a = b; b = c; c = d; d = a2;\n\t\t}\n\n\t\treturn out;\n\t}\n};\n\n/**\n * Random values\n * @namespace\n */\nconst random = {\n\t/** \n\t * Generate random words with pure js, cryptographically not as strong & safe as native implementation.\n\t * @param {TypedArray} typedArray The array to fill.\n\t * @return {TypedArray} The random values.\n\t */\n\tgetRandomValues(typedArray) {\n\t\tconst words = new Uint32Array(typedArray.buffer);\n\t\tconst r = (m_w) => {\n\t\t\tlet m_z = 0x3ade68b1;\n\t\t\tconst mask = 0xffffffff;\n\t\t\treturn function () {\n\t\t\t\tm_z = (0x9069 * (m_z & 0xFFFF) + (m_z >> 0x10)) & mask;\n\t\t\t\tm_w = (0x4650 * (m_w & 0xFFFF) + (m_w >> 0x10)) & mask;\n\t\t\t\tconst result = ((((m_z << 0x10) + m_w) & mask) / 0x100000000) + .5;\n\t\t\t\treturn result * (Math.random() > .5 ? 1 : -1);\n\t\t\t};\n\t\t};\n\t\tfor (let i = 0, rcache; i < typedArray.length; i += 4) {\n\t\t\tconst _r = r((rcache || Math.random()) * 0x100000000);\n\t\t\trcache = _r() * 0x3ade67b7;\n\t\t\twords[i / 4] = (_r() * 0x100000000) | 0;\n\t\t}\n\t\treturn typedArray;\n\t}\n};\n\n/** @fileOverview CTR mode implementation.\n *\n * Special thanks to Roy Nicholson for pointing out a bug in our\n * implementation.\n *\n * @author Emily Stark\n * @author Mike Hamburg\n * @author Dan Boneh\n */\n\n/** Brian Gladman's CTR Mode.\n* @constructor\n* @param {Object} _prf The aes instance to generate key.\n* @param {bitArray} _iv The iv for ctr mode, it must be 128 bits.\n*/\n\nconst mode = {};\n\n/**\n * Brian Gladman's CTR Mode.\n * @namespace\n */\nmode.ctrGladman = class {\n\tconstructor(prf, iv) {\n\t\tthis._prf = prf;\n\t\tthis._initIv = iv;\n\t\tthis._iv = iv;\n\t}\n\n\treset() {\n\t\tthis._iv = this._initIv;\n\t}\n\n\t/** Input some data to calculate.\n\t * @param {bitArray} data the data to process, it must be intergral multiple of 128 bits unless it's the last.\n\t */\n\tupdate(data) {\n\t\treturn this.calculate(this._prf, data, this._iv);\n\t}\n\n\tincWord(word) {\n\t\tif (((word >> 24) & 0xff) === 0xff) { //overflow\n\t\t\tlet b1 = (word >> 16) & 0xff;\n\t\t\tlet b2 = (word >> 8) & 0xff;\n\t\t\tlet b3 = word & 0xff;\n\n\t\t\tif (b1 === 0xff) { // overflow b1 \n\t\t\t\tb1 = 0;\n\t\t\t\tif (b2 === 0xff) {\n\t\t\t\t\tb2 = 0;\n\t\t\t\t\tif (b3 === 0xff) {\n\t\t\t\t\t\tb3 = 0;\n\t\t\t\t\t} else {\n\t\t\t\t\t\t++b3;\n\t\t\t\t\t}\n\t\t\t\t} else {\n\t\t\t\t\t++b2;\n\t\t\t\t}\n\t\t\t} else {\n\t\t\t\t++b1;\n\t\t\t}\n\n\t\t\tword = 0;\n\t\t\tword += (b1 << 16);\n\t\t\tword += (b2 << 8);\n\t\t\tword += b3;\n\t\t} else {\n\t\t\tword += (0x01 << 24);\n\t\t}\n\t\treturn word;\n\t}\n\n\tincCounter(counter) {\n\t\tif ((counter[0] = this.incWord(counter[0])) === 0) {\n\t\t\t// encr_data in fileenc.c from Dr Brian Gladman's counts only with DWORD j < 8\n\t\t\tcounter[1] = this.incWord(counter[1]);\n\t\t}\n\t}\n\n\tcalculate(prf, data, iv) {\n\t\tlet l;\n\t\tif (!(l = data.length)) {\n\t\t\treturn [];\n\t\t}\n\t\tconst bl = bitArray.bitLength(data);\n\t\tfor (let i = 0; i < l; i += 4) {\n\t\t\tthis.incCounter(iv);\n\t\t\tconst e = prf.encrypt(iv);\n\t\t\tdata[i] ^= e[0];\n\t\t\tdata[i + 1] ^= e[1];\n\t\t\tdata[i + 2] ^= e[2];\n\t\t\tdata[i + 3] ^= e[3];\n\t\t}\n\t\treturn bitArray.clamp(data, bl);\n\t}\n};\n\nconst misc = {\n\timportKey(password) {\n\t\treturn new misc.hmacSha1(codec.bytes.toBits(password));\n\t},\n\tpbkdf2(prf, salt, count, length) {\n\t\tcount = count || 10000;\n\t\tif (length < 0 || count < 0) {\n\t\t\tthrow new Error(\"invalid params to pbkdf2\");\n\t\t}\n\t\tconst byteLength = ((length >> 5) + 1) << 2;\n\t\tlet u, ui, i, j, k;\n\t\tconst arrayBuffer = new ArrayBuffer(byteLength);\n\t\tconst out = new DataView(arrayBuffer);\n\t\tlet outLength = 0;\n\t\tconst b = bitArray;\n\t\tsalt = codec.bytes.toBits(salt);\n\t\tfor (k = 1; outLength < (byteLength || 1); k++) {\n\t\t\tu = ui = prf.encrypt(b.concat(salt, [k]));\n\t\t\tfor (i = 1; i < count; i++) {\n\t\t\t\tui = prf.encrypt(ui);\n\t\t\t\tfor (j = 0; j < ui.length; j++) {\n\t\t\t\t\tu[j] ^= ui[j];\n\t\t\t\t}\n\t\t\t}\n\t\t\tfor (i = 0; outLength < (byteLength || 1) && i < u.length; i++) {\n\t\t\t\tout.setInt32(outLength, u[i]);\n\t\t\t\toutLength += 4;\n\t\t\t}\n\t\t}\n\t\treturn arrayBuffer.slice(0, length / 8);\n\t}\n};\n\n/** @fileOverview HMAC implementation.\n *\n * @author Emily Stark\n * @author Mike Hamburg\n * @author Dan Boneh\n */\n\n/** HMAC with the specified hash function.\n * @constructor\n * @param {bitArray} key the key for HMAC.\n * @param {Object} [Hash=hash.sha1] The hash function to use.\n */\nmisc.hmacSha1 = class {\n\n\tconstructor(key) {\n\t\tconst hmac = this;\n\t\tconst Hash = hmac._hash = hash.sha1;\n\t\tconst exKey = [[], []];\n\t\thmac._baseHash = [new Hash(), new Hash()];\n\t\tconst bs = hmac._baseHash[0].blockSize / 32;\n\n\t\tif (key.length > bs) {\n\t\t\tkey = new Hash().update(key).finalize();\n\t\t}\n\n\t\tfor (let i = 0; i < bs; i++) {\n\t\t\texKey[0][i] = key[i] ^ 0x36363636;\n\t\t\texKey[1][i] = key[i] ^ 0x5C5C5C5C;\n\t\t}\n\n\t\thmac._baseHash[0].update(exKey[0]);\n\t\thmac._baseHash[1].update(exKey[1]);\n\t\thmac._resultHash = new Hash(hmac._baseHash[0]);\n\t}\n\treset() {\n\t\tconst hmac = this;\n\t\thmac._resultHash = new hmac._hash(hmac._baseHash[0]);\n\t\thmac._updated = false;\n\t}\n\n\tupdate(data) {\n\t\tconst hmac = this;\n\t\thmac._updated = true;\n\t\thmac._resultHash.update(data);\n\t}\n\n\tdigest() {\n\t\tconst hmac = this;\n\t\tconst w = hmac._resultHash.finalize();\n\t\tconst result = new (hmac._hash)(hmac._baseHash[1]).update(w).finalize();\n\n\t\thmac.reset();\n\n\t\treturn result;\n\t}\n\n\tencrypt(data) {\n\t\tif (!this._updated) {\n\t\t\tthis.update(data);\n\t\t\treturn this.digest(data);\n\t\t} else {\n\t\t\tthrow new Error(\"encrypt on already updated hmac called!\");\n\t\t}\n\t}\n};\n\nexport {\n\tcipher,\n\tcodec,\n\tmisc,\n\tmode,\n\trandom\n};","/*\n Copyright (c) 2022 Gildas Lormeau. All rights reserved.\n\n Redistribution and use in source and binary forms, with or without\n modification, are permitted provided that the following conditions are met:\n\n 1. Redistributions of source code must retain the above copyright notice,\n this list of conditions and the following disclaimer.\n\n 2. Redistributions in binary form must reproduce the above copyright \n notice, this list of conditions and the following disclaimer in \n the documentation and/or other materials provided with the distribution.\n\n 3. The names of the authors may not be used to endorse or promote products\n derived from this software without specific prior written permission.\n\n THIS SOFTWARE IS PROVIDED ''AS IS'' AND ANY EXPRESSED OR IMPLIED WARRANTIES,\n INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND\n FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL JCRAFT,\n INC. OR ANY CONTRIBUTORS TO THIS SOFTWARE BE LIABLE FOR ANY DIRECT, INDIRECT,\n INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT\n LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA,\n OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF\n LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING\n NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE,\n EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.\n */\n\n/* global crypto */\n\nimport { FUNCTION_TYPE, UNDEFINED_TYPE } from \"../constants.js\";\nimport {\n\trandom\n} from \"./codecs/sjcl.js\";\n\nconst GET_RANDOM_VALUES_SUPPORTED = typeof crypto != UNDEFINED_TYPE && typeof crypto.getRandomValues == FUNCTION_TYPE;\n\nconst ERR_INVALID_PASSWORD = \"Invalid password\";\nconst ERR_INVALID_SIGNATURE = \"Invalid signature\";\nconst ERR_ABORT_CHECK_PASSWORD = \"zipjs-abort-check-password\";\n\nexport {\n\tgetRandomValues,\n\tERR_INVALID_PASSWORD,\n\tERR_INVALID_SIGNATURE,\n\tERR_ABORT_CHECK_PASSWORD\n};\n\nfunction getRandomValues(array) {\n\tif (GET_RANDOM_VALUES_SUPPORTED) {\n\t\treturn crypto.getRandomValues(array);\n\t} else {\n\t\treturn random.getRandomValues(array);\n\t}\n}","/*\n Copyright (c) 2022 Gildas Lormeau. All rights reserved.\n\n Redistribution and use in source and binary forms, with or without\n modification, are permitted provided that the following conditions are met:\n\n 1. Redistributions of source code must retain the above copyright notice,\n this list of conditions and the following disclaimer.\n\n 2. Redistributions in binary form must reproduce the above copyright \n notice, this list of conditions and the following disclaimer in \n the documentation and/or other materials provided with the distribution.\n\n 3. The names of the authors may not be used to endorse or promote products\n derived from this software without specific prior written permission.\n\n THIS SOFTWARE IS PROVIDED ''AS IS'' AND ANY EXPRESSED OR IMPLIED WARRANTIES,\n INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND\n FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL JCRAFT,\n INC. OR ANY CONTRIBUTORS TO THIS SOFTWARE BE LIABLE FOR ANY DIRECT, INDIRECT,\n INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT\n LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA,\n OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF\n LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING\n NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE,\n EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.\n */\n\n/* global crypto, TransformStream */\n// deno-lint-ignore-file no-this-alias\n\nimport { UNDEFINED_VALUE, UNDEFINED_TYPE, FUNCTION_TYPE } from \"../constants.js\";\nimport { encodeText } from \"./../util/encode-text.js\";\nimport {\n\tcipher,\n\tcodec,\n\tmisc,\n\tmode\n} from \"./codecs/sjcl.js\";\nimport {\n\tERR_INVALID_PASSWORD,\n\tERR_INVALID_SIGNATURE,\n\tERR_ABORT_CHECK_PASSWORD,\n\tgetRandomValues\n} from \"./common-crypto.js\";\n\nconst BLOCK_LENGTH = 16;\nconst RAW_FORMAT = \"raw\";\nconst PBKDF2_ALGORITHM = { name: \"PBKDF2\" };\nconst HASH_ALGORITHM = { name: \"HMAC\" };\nconst HASH_FUNCTION = \"SHA-1\";\nconst BASE_KEY_ALGORITHM = Object.assign({ hash: HASH_ALGORITHM }, PBKDF2_ALGORITHM);\nconst DERIVED_BITS_ALGORITHM = Object.assign({ iterations: 1000, hash: { name: HASH_FUNCTION } }, PBKDF2_ALGORITHM);\nconst DERIVED_BITS_USAGE = [\"deriveBits\"];\nconst SALT_LENGTH = [8, 12, 16];\nconst KEY_LENGTH = [16, 24, 32];\nconst SIGNATURE_LENGTH = 10;\nconst COUNTER_DEFAULT_VALUE = [0, 0, 0, 0];\n// deno-lint-ignore valid-typeof\nconst CRYPTO_API_SUPPORTED = typeof crypto != UNDEFINED_TYPE;\nconst subtle = CRYPTO_API_SUPPORTED && crypto.subtle;\nconst SUBTLE_API_SUPPORTED = CRYPTO_API_SUPPORTED && typeof subtle != UNDEFINED_TYPE;\nconst codecBytes = codec.bytes;\nconst Aes = cipher.aes;\nconst CtrGladman = mode.ctrGladman;\nconst HmacSha1 = misc.hmacSha1;\n\nlet IMPORT_KEY_SUPPORTED = CRYPTO_API_SUPPORTED && SUBTLE_API_SUPPORTED && typeof subtle.importKey == FUNCTION_TYPE;\nlet DERIVE_BITS_SUPPORTED = CRYPTO_API_SUPPORTED && SUBTLE_API_SUPPORTED && typeof subtle.deriveBits == FUNCTION_TYPE;\n\nclass AESDecryptionStream extends TransformStream {\n\n\tconstructor({ password, rawPassword, signed, encryptionStrength, checkPasswordOnly }) {\n\t\tsuper({\n\t\t\tstart() {\n\t\t\t\tObject.assign(this, {\n\t\t\t\t\tready: new Promise(resolve => this.resolveReady = resolve),\n\t\t\t\t\tpassword: encodePassword(password, rawPassword),\n\t\t\t\t\tsigned,\n\t\t\t\t\tstrength: encryptionStrength - 1,\n\t\t\t\t\tpending: new Uint8Array()\n\t\t\t\t});\n\t\t\t},\n\t\t\tasync transform(chunk, controller) {\n\t\t\t\tconst aesCrypto = this;\n\t\t\t\tconst {\n\t\t\t\t\tpassword,\n\t\t\t\t\tstrength,\n\t\t\t\t\tresolveReady,\n\t\t\t\t\tready\n\t\t\t\t} = aesCrypto;\n\t\t\t\tif (password) {\n\t\t\t\t\tawait createDecryptionKeys(aesCrypto, strength, password, subarray(chunk, 0, SALT_LENGTH[strength] + 2));\n\t\t\t\t\tchunk = subarray(chunk, SALT_LENGTH[strength] + 2);\n\t\t\t\t\tif (checkPasswordOnly) {\n\t\t\t\t\t\tcontroller.error(new Error(ERR_ABORT_CHECK_PASSWORD));\n\t\t\t\t\t} else {\n\t\t\t\t\t\tresolveReady();\n\t\t\t\t\t}\n\t\t\t\t} else {\n\t\t\t\t\tawait ready;\n\t\t\t\t}\n\t\t\t\tconst output = new Uint8Array(chunk.length - SIGNATURE_LENGTH - ((chunk.length - SIGNATURE_LENGTH) % BLOCK_LENGTH));\n\t\t\t\tcontroller.enqueue(append(aesCrypto, chunk, output, 0, SIGNATURE_LENGTH, true));\n\t\t\t},\n\t\t\tasync flush(controller) {\n\t\t\t\tconst {\n\t\t\t\t\tsigned,\n\t\t\t\t\tctr,\n\t\t\t\t\thmac,\n\t\t\t\t\tpending,\n\t\t\t\t\tready\n\t\t\t\t} = this;\n\t\t\t\tif (hmac && ctr) {\n\t\t\t\t\tawait ready;\n\t\t\t\t\tconst chunkToDecrypt = subarray(pending, 0, pending.length - SIGNATURE_LENGTH);\n\t\t\t\t\tconst originalSignature = subarray(pending, pending.length - SIGNATURE_LENGTH);\n\t\t\t\t\tlet decryptedChunkArray = new Uint8Array();\n\t\t\t\t\tif (chunkToDecrypt.length) {\n\t\t\t\t\t\tconst encryptedChunk = toBits(codecBytes, chunkToDecrypt);\n\t\t\t\t\t\thmac.update(encryptedChunk);\n\t\t\t\t\t\tconst decryptedChunk = ctr.update(encryptedChunk);\n\t\t\t\t\t\tdecryptedChunkArray = fromBits(codecBytes, decryptedChunk);\n\t\t\t\t\t}\n\t\t\t\t\tif (signed) {\n\t\t\t\t\t\tconst signature = subarray(fromBits(codecBytes, hmac.digest()), 0, SIGNATURE_LENGTH);\n\t\t\t\t\t\tfor (let indexSignature = 0; indexSignature < SIGNATURE_LENGTH; indexSignature++) {\n\t\t\t\t\t\t\tif (signature[indexSignature] != originalSignature[indexSignature]) {\n\t\t\t\t\t\t\t\tthrow new Error(ERR_INVALID_SIGNATURE);\n\t\t\t\t\t\t\t}\n\t\t\t\t\t\t}\n\t\t\t\t\t}\n\t\t\t\t\tcontroller.enqueue(decryptedChunkArray);\n\t\t\t\t}\n\t\t\t}\n\t\t});\n\t}\n}\n\nclass AESEncryptionStream extends TransformStream {\n\n\tconstructor({ password, rawPassword, encryptionStrength }) {\n\t\t// deno-lint-ignore prefer-const\n\t\tlet stream;\n\t\tsuper({\n\t\t\tstart() {\n\t\t\t\tObject.assign(this, {\n\t\t\t\t\tready: new Promise(resolve => this.resolveReady = resolve),\n\t\t\t\t\tpassword: encodePassword(password, rawPassword),\n\t\t\t\t\tstrength: encryptionStrength - 1,\n\t\t\t\t\tpending: new Uint8Array()\n\t\t\t\t});\n\t\t\t},\n\t\t\tasync transform(chunk, controller) {\n\t\t\t\tconst aesCrypto = this;\n\t\t\t\tconst {\n\t\t\t\t\tpassword,\n\t\t\t\t\tstrength,\n\t\t\t\t\tresolveReady,\n\t\t\t\t\tready\n\t\t\t\t} = aesCrypto;\n\t\t\t\tlet preamble = new Uint8Array();\n\t\t\t\tif (password) {\n\t\t\t\t\tpreamble = await createEncryptionKeys(aesCrypto, strength, password);\n\t\t\t\t\tresolveReady();\n\t\t\t\t} else {\n\t\t\t\t\tawait ready;\n\t\t\t\t}\n\t\t\t\tconst output = new Uint8Array(preamble.length + chunk.length - (chunk.length % BLOCK_LENGTH));\n\t\t\t\toutput.set(preamble, 0);\n\t\t\t\tcontroller.enqueue(append(aesCrypto, chunk, output, preamble.length, 0));\n\t\t\t},\n\t\t\tasync flush(controller) {\n\t\t\t\tconst {\n\t\t\t\t\tctr,\n\t\t\t\t\thmac,\n\t\t\t\t\tpending,\n\t\t\t\t\tready\n\t\t\t\t} = this;\n\t\t\t\tif (hmac && ctr) {\n\t\t\t\t\tawait ready;\n\t\t\t\t\tlet encryptedChunkArray = new Uint8Array();\n\t\t\t\t\tif (pending.length) {\n\t\t\t\t\t\tconst encryptedChunk = ctr.update(toBits(codecBytes, pending));\n\t\t\t\t\t\thmac.update(encryptedChunk);\n\t\t\t\t\t\tencryptedChunkArray = fromBits(codecBytes, encryptedChunk);\n\t\t\t\t\t}\n\t\t\t\t\tstream.signature = fromBits(codecBytes, hmac.digest()).slice(0, SIGNATURE_LENGTH);\n\t\t\t\t\tcontroller.enqueue(concat(encryptedChunkArray, stream.signature));\n\t\t\t\t}\n\t\t\t}\n\t\t});\n\t\tstream = this;\n\t}\n}\n\nexport {\n\tAESDecryptionStream,\n\tAESEncryptionStream,\n\tERR_INVALID_PASSWORD\n};\n\nfunction append(aesCrypto, input, output, paddingStart, paddingEnd, verifySignature) {\n\tconst {\n\t\tctr,\n\t\thmac,\n\t\tpending\n\t} = aesCrypto;\n\tconst inputLength = input.length - paddingEnd;\n\tif (pending.length) {\n\t\tinput = concat(pending, input);\n\t\toutput = expand(output, inputLength - (inputLength % BLOCK_LENGTH));\n\t}\n\tlet offset;\n\tfor (offset = 0; offset <= inputLength - BLOCK_LENGTH; offset += BLOCK_LENGTH) {\n\t\tconst inputChunk = toBits(codecBytes, subarray(input, offset, offset + BLOCK_LENGTH));\n\t\tif (verifySignature) {\n\t\t\thmac.update(inputChunk);\n\t\t}\n\t\tconst outputChunk = ctr.update(inputChunk);\n\t\tif (!verifySignature) {\n\t\t\thmac.update(outputChunk);\n\t\t}\n\t\toutput.set(fromBits(codecBytes, outputChunk), offset + paddingStart);\n\t}\n\taesCrypto.pending = subarray(input, offset);\n\treturn output;\n}\n\nasync function createDecryptionKeys(decrypt, strength, password, preamble) {\n\tconst passwordVerificationKey = await createKeys(decrypt, strength, password, subarray(preamble, 0, SALT_LENGTH[strength]));\n\tconst passwordVerification = subarray(preamble, SALT_LENGTH[strength]);\n\tif (passwordVerificationKey[0] != passwordVerification[0] || passwordVerificationKey[1] != passwordVerification[1]) {\n\t\tthrow new Error(ERR_INVALID_PASSWORD);\n\t}\n}\n\nasync function createEncryptionKeys(encrypt, strength, password) {\n\tconst salt = getRandomValues(new Uint8Array(SALT_LENGTH[strength]));\n\tconst passwordVerification = await createKeys(encrypt, strength, password, salt);\n\treturn concat(salt, passwordVerification);\n}\n\nasync function createKeys(aesCrypto, strength, password, salt) {\n\taesCrypto.password = null;\n\tconst baseKey = await importKey(RAW_FORMAT, password, BASE_KEY_ALGORITHM, false, DERIVED_BITS_USAGE);\n\tconst derivedBits = await deriveBits(Object.assign({ salt }, DERIVED_BITS_ALGORITHM), baseKey, 8 * ((KEY_LENGTH[strength] * 2) + 2));\n\tconst compositeKey = new Uint8Array(derivedBits);\n\tconst key = toBits(codecBytes, subarray(compositeKey, 0, KEY_LENGTH[strength]));\n\tconst authentication = toBits(codecBytes, subarray(compositeKey, KEY_LENGTH[strength], KEY_LENGTH[strength] * 2));\n\tconst passwordVerification = subarray(compositeKey, KEY_LENGTH[strength] * 2);\n\tObject.assign(aesCrypto, {\n\t\tkeys: {\n\t\t\tkey,\n\t\t\tauthentication,\n\t\t\tpasswordVerification\n\t\t},\n\t\tctr: new CtrGladman(new Aes(key), Array.from(COUNTER_DEFAULT_VALUE)),\n\t\thmac: new HmacSha1(authentication)\n\t});\n\treturn passwordVerification;\n}\n\nasync function importKey(format, password, algorithm, extractable, keyUsages) {\n\tif (IMPORT_KEY_SUPPORTED) {\n\t\ttry {\n\t\t\treturn await subtle.importKey(format, password, algorithm, extractable, keyUsages);\n\t\t} catch {\n\t\t\tIMPORT_KEY_SUPPORTED = false;\n\t\t\treturn misc.importKey(password);\n\t\t}\n\t} else {\n\t\treturn misc.importKey(password);\n\t}\n}\n\nasync function deriveBits(algorithm, baseKey, length) {\n\tif (DERIVE_BITS_SUPPORTED) {\n\t\ttry {\n\t\t\treturn await subtle.deriveBits(algorithm, baseKey, length);\n\t\t} catch {\n\t\t\tDERIVE_BITS_SUPPORTED = false;\n\t\t\treturn misc.pbkdf2(baseKey, algorithm.salt, DERIVED_BITS_ALGORITHM.iterations, length);\n\t\t}\n\t} else {\n\t\treturn misc.pbkdf2(baseKey, algorithm.salt, DERIVED_BITS_ALGORITHM.iterations, length);\n\t}\n}\n\nfunction encodePassword(password, rawPassword) {\n\tif (rawPassword === UNDEFINED_VALUE) {\n\t\treturn encodeText(password);\n\t} else {\n\t\treturn rawPassword;\n\t}\n}\n\nfunction concat(leftArray, rightArray) {\n\tlet array = leftArray;\n\tif (leftArray.length + rightArray.length) {\n\t\tarray = new Uint8Array(leftArray.length + rightArray.length);\n\t\tarray.set(leftArray, 0);\n\t\tarray.set(rightArray, leftArray.length);\n\t}\n\treturn array;\n}\n\nfunction expand(inputArray, length) {\n\tif (length && length > inputArray.length) {\n\t\tconst array = inputArray;\n\t\tinputArray = new Uint8Array(length);\n\t\tinputArray.set(array, 0);\n\t}\n\treturn inputArray;\n}\n\nfunction subarray(array, begin, end) {\n\treturn array.subarray(begin, end);\n}\n\nfunction fromBits(codecBytes, chunk) {\n\treturn codecBytes.fromBits(chunk);\n}\nfunction toBits(codecBytes, chunk) {\n\treturn codecBytes.toBits(chunk);\n}","/*\n Copyright (c) 2022 Gildas Lormeau. All rights reserved.\n\n Redistribution and use in source and binary forms, with or without\n modification, are permitted provided that the following conditions are met:\n\n 1. Redistributions of source code must retain the above copyright notice,\n this list of conditions and the following disclaimer.\n\n 2. Redistributions in binary form must reproduce the above copyright \n notice, this list of conditions and the following disclaimer in \n the documentation and/or other materials provided with the distribution.\n\n 3. The names of the authors may not be used to endorse or promote products\n derived from this software without specific prior written permission.\n\n THIS SOFTWARE IS PROVIDED ''AS IS'' AND ANY EXPRESSED OR IMPLIED WARRANTIES,\n INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND\n FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL JCRAFT,\n INC. OR ANY CONTRIBUTORS TO THIS SOFTWARE BE LIABLE FOR ANY DIRECT, INDIRECT,\n INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT\n LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA,\n OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF\n LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING\n NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE,\n EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.\n */\n\n/* global TextEncoder */\n\nimport { UNDEFINED_TYPE } from \"../constants.js\";\n\nexport {\n\tencodeText\n};\n\nfunction encodeText(value) {\n\t// deno-lint-ignore valid-typeof\n\tif (typeof TextEncoder == UNDEFINED_TYPE) {\n\t\tvalue = unescape(encodeURIComponent(value));\n\t\tconst result = new Uint8Array(value.length);\n\t\tfor (let i = 0; i < result.length; i++) {\n\t\t\tresult[i] = value.charCodeAt(i);\n\t\t}\n\t\treturn result;\n\t} else {\n\t\treturn new TextEncoder().encode(value);\n\t}\n}","/*\n Copyright (c) 2022 Gildas Lormeau. All rights reserved.\n\n Redistribution and use in source and binary forms, with or without\n modification, are permitted provided that the following conditions are met:\n\n 1. Redistributions of source code must retain the above copyright notice,\n this list of conditions and the following disclaimer.\n\n 2. Redistributions in binary form must reproduce the above copyright \n notice, this list of conditions and the following disclaimer in \n the documentation and/or other materials provided with the distribution.\n\n 3. The names of the authors may not be used to endorse or promote products\n derived from this software without specific prior written permission.\n\n THIS SOFTWARE IS PROVIDED ''AS IS'' AND ANY EXPRESSED OR IMPLIED WARRANTIES,\n INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND\n FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL JCRAFT,\n INC. OR ANY CONTRIBUTORS TO THIS SOFTWARE BE LIABLE FOR ANY DIRECT, INDIRECT,\n INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT\n LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA,\n OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF\n LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING\n NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE,\n EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.\n */\n\n/* global TransformStream */\n// deno-lint-ignore-file no-this-alias\n\nimport { Crc32 } from \"./codecs/crc32.js\";\nimport {\n\tERR_INVALID_PASSWORD,\n\tERR_ABORT_CHECK_PASSWORD,\n\tgetRandomValues\n} from \"./common-crypto.js\";\n\nconst HEADER_LENGTH = 12;\n\nclass ZipCryptoDecryptionStream extends TransformStream {\n\n\tconstructor({ password, passwordVerification, checkPasswordOnly }) {\n\t\tsuper({\n\t\t\tstart() {\n\t\t\t\tObject.assign(this, {\n\t\t\t\t\tpassword,\n\t\t\t\t\tpasswordVerification\n\t\t\t\t});\n\t\t\t\tcreateKeys(this, password);\n\t\t\t},\n\t\t\ttransform(chunk, controller) {\n\t\t\t\tconst zipCrypto = this;\n\t\t\t\tif (zipCrypto.password) {\n\t\t\t\t\tconst decryptedHeader = decrypt(zipCrypto, chunk.subarray(0, HEADER_LENGTH));\n\t\t\t\t\tzipCrypto.password = null;\n\t\t\t\t\tif (decryptedHeader.at(-1) != zipCrypto.passwordVerification) {\n\t\t\t\t\t\tthrow new Error(ERR_INVALID_PASSWORD);\n\t\t\t\t\t}\n\t\t\t\t\tchunk = chunk.subarray(HEADER_LENGTH);\n\t\t\t\t}\n\t\t\t\tif (checkPasswordOnly) {\n\t\t\t\t\tcontroller.error(new Error(ERR_ABORT_CHECK_PASSWORD));\n\t\t\t\t} else {\n\t\t\t\t\tcontroller.enqueue(decrypt(zipCrypto, chunk));\n\t\t\t\t}\n\t\t\t}\n\t\t});\n\t}\n}\n\nclass ZipCryptoEncryptionStream extends TransformStream {\n\n\tconstructor({ password, passwordVerification }) {\n\t\tsuper({\n\t\t\tstart() {\n\t\t\t\tObject.assign(this, {\n\t\t\t\t\tpassword,\n\t\t\t\t\tpasswordVerification\n\t\t\t\t});\n\t\t\t\tcreateKeys(this, password);\n\t\t\t},\n\t\t\ttransform(chunk, controller) {\n\t\t\t\tconst zipCrypto = this;\n\t\t\t\tlet output;\n\t\t\t\tlet offset;\n\t\t\t\tif (zipCrypto.password) {\n\t\t\t\t\tzipCrypto.password = null;\n\t\t\t\t\tconst header = getRandomValues(new Uint8Array(HEADER_LENGTH));\n\t\t\t\t\theader[HEADER_LENGTH - 1] = zipCrypto.passwordVerification;\n\t\t\t\t\toutput = new Uint8Array(chunk.length + header.length);\n\t\t\t\t\toutput.set(encrypt(zipCrypto, header), 0);\n\t\t\t\t\toffset = HEADER_LENGTH;\n\t\t\t\t} else {\n\t\t\t\t\toutput = new Uint8Array(chunk.length);\n\t\t\t\t\toffset = 0;\n\t\t\t\t}\n\t\t\t\toutput.set(encrypt(zipCrypto, chunk), offset);\n\t\t\t\tcontroller.enqueue(output);\n\t\t\t}\n\t\t});\n\t}\n}\n\nexport {\n\tZipCryptoDecryptionStream,\n\tZipCryptoEncryptionStream,\n\tERR_INVALID_PASSWORD\n};\n\nfunction decrypt(target, input) {\n\tconst output = new Uint8Array(input.length);\n\tfor (let index = 0; index < input.length; index++) {\n\t\toutput[index] = getByte(target) ^ input[index];\n\t\tupdateKeys(target, output[index]);\n\t}\n\treturn output;\n}\n\nfunction encrypt(target, input) {\n\tconst output = new Uint8Array(input.length);\n\tfor (let index = 0; index < input.length; index++) {\n\t\toutput[index] = getByte(target) ^ input[index];\n\t\tupdateKeys(target, input[index]);\n\t}\n\treturn output;\n}\n\nfunction createKeys(target, password) {\n\tconst keys = [0x12345678, 0x23456789, 0x34567890];\n\tObject.assign(target, {\n\t\tkeys,\n\t\tcrcKey0: new Crc32(keys[0]),\n\t\tcrcKey2: new Crc32(keys[2])\n\t});\n\tfor (let index = 0; index < password.length; index++) {\n\t\tupdateKeys(target, password.charCodeAt(index));\n\t}\n}\n\nfunction updateKeys(target, byte) {\n\tlet [key0, key1, key2] = target.keys;\n\ttarget.crcKey0.append([byte]);\n\tkey0 = ~target.crcKey0.get();\n\tkey1 = getInt32(Math.imul(getInt32(key1 + getInt8(key0)), 134775813) + 1);\n\ttarget.crcKey2.append([key1 >>> 24]);\n\tkey2 = ~target.crcKey2.get();\n\ttarget.keys = [key0, key1, key2];\n}\n\nfunction getByte(target) {\n\tconst temp = target.keys[2] | 2;\n\treturn getInt8(Math.imul(temp, (temp ^ 1)) >>> 8);\n}\n\nfunction getInt8(number) {\n\treturn number & 0xFF;\n}\n\nfunction getInt32(number) {\n\treturn number & 0xFFFFFFFF;\n}","/*\n Copyright (c) 2025 Gildas Lormeau. All rights reserved.\n\n Redistribution and use in source and binary forms, with or without\n modification, are permitted provided that the following conditions are met:\n\n 1. Redistributions of source code must retain the above copyright notice,\n this list of conditions and the following disclaimer.\n\n 2. Redistributions in binary form must reproduce the above copyright \n notice, this list of conditions and the following disclaimer in \n the documentation and/or other materials provided with the distribution.\n\n 3. The names of the authors may not be used to endorse or promote products\n derived from this software without specific prior written permission.\n\n THIS SOFTWARE IS PROVIDED ''AS IS'' AND ANY EXPRESSED OR IMPLIED WARRANTIES,\n INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND\n FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL JCRAFT,\n INC. OR ANY CONTRIBUTORS TO THIS SOFTWARE BE LIABLE FOR ANY DIRECT, INDIRECT,\n INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT\n LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA,\n OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF\n LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING\n NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE,\n EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.\n */\n\n/* global TransformStream */\n// deno-lint-ignore-file no-this-alias\n\nimport { Crc32Stream } from \"./crc32-stream.js\";\nimport {\n\tAESEncryptionStream,\n\tAESDecryptionStream\n} from \"./aes-crypto-stream.js\";\nimport {\n\tZipCryptoEncryptionStream,\n\tZipCryptoDecryptionStream\n} from \"./zip-crypto-stream.js\";\nimport {\n\tERR_INVALID_PASSWORD,\n\tERR_INVALID_SIGNATURE,\n\tERR_ABORT_CHECK_PASSWORD\n} from \"./common-crypto.js\";\n\nconst ERR_INVALID_UNCOMPRESSED_SIZE = \"Invalid uncompressed size\";\nconst FORMAT_DEFLATE_RAW = \"deflate-raw\";\nconst FORMAT_DEFLATE64_RAW = \"deflate64-raw\";\n\nclass DeflateStream extends TransformStream {\n\n\tconstructor(options, { chunkSize, CompressionStreamZlib, CompressionStream }) {\n\t\tsuper({});\n\t\tconst { compressed, encrypted, useCompressionStream, zipCrypto, signed, level } = options;\n\t\tconst stream = this;\n\t\tlet crc32Stream, encryptionStream;\n\t\tlet readable = super.readable;\n\t\tif ((!encrypted || zipCrypto) && signed) {\n\t\t\tcrc32Stream = new Crc32Stream();\n\t\t\treadable = pipeThrough(readable, crc32Stream);\n\t\t}\n\t\tif (compressed) {\n\t\t\treadable = pipeThroughCommpressionStream(readable, useCompressionStream, { level, chunkSize }, CompressionStream, CompressionStreamZlib, CompressionStream);\n\t\t}\n\t\tif (encrypted) {\n\t\t\tif (zipCrypto) {\n\t\t\t\treadable = pipeThrough(readable, new ZipCryptoEncryptionStream(options));\n\t\t\t} else {\n\t\t\t\tencryptionStream = new AESEncryptionStream(options);\n\t\t\t\treadable = pipeThrough(readable, encryptionStream);\n\t\t\t}\n\t\t}\n\t\tsetReadable(stream, readable, () => {\n\t\t\tlet signature;\n\t\t\tif (encrypted && !zipCrypto) {\n\t\t\t\tsignature = encryptionStream.signature;\n\t\t\t}\n\t\t\tif ((!encrypted || zipCrypto) && signed) {\n\t\t\t\tsignature = new DataView(crc32Stream.value.buffer).getUint32(0);\n\t\t\t}\n\t\t\tstream.signature = signature;\n\t\t});\n\t}\n}\n\nclass InflateStream extends TransformStream {\n\n\tconstructor(options, { chunkSize, DecompressionStreamZlib, DecompressionStream }) {\n\t\tsuper({});\n\t\tconst { zipCrypto, encrypted, signed, signature, compressed, useCompressionStream, deflate64 } = options;\n\t\tlet crc32Stream, decryptionStream;\n\t\tlet readable = super.readable;\n\t\tif (encrypted) {\n\t\t\tif (zipCrypto) {\n\t\t\t\treadable = pipeThrough(readable, new ZipCryptoDecryptionStream(options));\n\t\t\t} else {\n\t\t\t\tdecryptionStream = new AESDecryptionStream(options);\n\t\t\t\treadable = pipeThrough(readable, decryptionStream);\n\t\t\t}\n\t\t}\n\t\tif (compressed) {\n\t\t\treadable = pipeThroughCommpressionStream(readable, useCompressionStream, { chunkSize, deflate64 }, DecompressionStream, DecompressionStreamZlib, DecompressionStream);\n\t\t}\n\t\tif ((!encrypted || zipCrypto) && signed) {\n\t\t\tcrc32Stream = new Crc32Stream();\n\t\t\treadable = pipeThrough(readable, crc32Stream);\n\t\t}\n\t\tsetReadable(this, readable, () => {\n\t\t\tif ((!encrypted || zipCrypto) && signed) {\n\t\t\t\tconst dataViewSignature = new DataView(crc32Stream.value.buffer);\n\t\t\t\tif (signature != dataViewSignature.getUint32(0, false)) {\n\t\t\t\t\tthrow new Error(ERR_INVALID_SIGNATURE);\n\t\t\t\t}\n\t\t\t}\n\t\t});\n\t}\n}\n\nexport {\n\tDeflateStream,\n\tInflateStream,\n\tERR_INVALID_PASSWORD,\n\tERR_INVALID_SIGNATURE,\n\tERR_INVALID_UNCOMPRESSED_SIZE,\n\tERR_ABORT_CHECK_PASSWORD\n};\n\nfunction setReadable(stream, readable, flush) {\n\treadable = pipeThrough(readable, new TransformStream({ flush }));\n\tObject.defineProperty(stream, \"readable\", {\n\t\tget() {\n\t\t\treturn readable;\n\t\t}\n\t});\n}\n\nfunction pipeThroughCommpressionStream(readable, useCompressionStream, options, CompressionStreamNative, CompressionStreamZlib, CompressionStream) {\n\tconst Stream = useCompressionStream && CompressionStreamNative ? CompressionStreamNative : CompressionStreamZlib || CompressionStream;\n\tconst format = options.deflate64 ? FORMAT_DEFLATE64_RAW : FORMAT_DEFLATE_RAW;\n\ttry {\n\t\treadable = pipeThrough(readable, new Stream(format, options));\n\t} catch (error) {\n\t\tif (useCompressionStream) {\n\t\t\tif (CompressionStreamZlib) {\n\t\t\t\treadable = pipeThrough(readable, new CompressionStreamZlib(format, options));\n\t\t\t} else if (CompressionStream) {\n\t\t\t\treadable = pipeThrough(readable, new CompressionStream(format, options));\n\t\t\t} else {\n\t\t\t\tthrow error;\n\t\t\t}\n\t\t} else {\n\t\t\tthrow error;\n\t\t}\n\t}\n\treturn readable;\n}\n\nfunction pipeThrough(readable, transformStream) {\n\treturn readable.pipeThrough(transformStream);\n}","/*\n Copyright (c) 2022 Gildas Lormeau. All rights reserved.\n\n Redistribution and use in source and binary forms, with or without\n modification, are permitted provided that the following conditions are met:\n\n 1. Redistributions of source code must retain the above copyright notice,\n this list of conditions and the following disclaimer.\n\n 2. Redistributions in binary form must reproduce the above copyright \n notice, this list of conditions and the following disclaimer in \n the documentation and/or other materials provided with the distribution.\n\n 3. The names of the authors may not be used to endorse or promote products\n derived from this software without specific prior written permission.\n\n THIS SOFTWARE IS PROVIDED ''AS IS'' AND ANY EXPRESSED OR IMPLIED WARRANTIES,\n INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND\n FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL JCRAFT,\n INC. OR ANY CONTRIBUTORS TO THIS SOFTWARE BE LIABLE FOR ANY DIRECT, INDIRECT,\n INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT\n LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA,\n OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF\n LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING\n NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE,\n EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.\n */\n\n/*\n * This program is based on JZlib 1.0.2 ymnk, JCraft,Inc.\n * JZlib is based on zlib-1.1.3, so all credit should go authors\n * Jean-loup Gailly(jloup@gzip.org) and Mark Adler(madler@alumni.caltech.edu)\n * and contributors of zlib.\n */\n\n/* global TransformStream */\n// deno-lint-ignore-file no-this-alias\n\nimport { UNDEFINED_VALUE } from \"../constants.js\";\nimport {\n\tERR_INVALID_PASSWORD,\n\tERR_INVALID_SIGNATURE,\n\tERR_INVALID_UNCOMPRESSED_SIZE,\n\tERR_ABORT_CHECK_PASSWORD,\n\tInflateStream,\n\tDeflateStream\n} from \"./zip-entry-stream.js\";\n\nconst MESSAGE_EVENT_TYPE = \"message\";\nconst MESSAGE_START = \"start\";\nconst MESSAGE_PULL = \"pull\";\nconst MESSAGE_DATA = \"data\";\nconst MESSAGE_ACK_DATA = \"ack\";\nconst MESSAGE_CLOSE = \"close\";\nconst CODEC_DEFLATE = \"deflate\";\nconst CODEC_INFLATE = \"inflate\";\n\nexport {\n\tCODEC_DEFLATE,\n\tCODEC_INFLATE,\n\tMESSAGE_EVENT_TYPE,\n\tMESSAGE_START,\n\tMESSAGE_PULL,\n\tMESSAGE_DATA,\n\tMESSAGE_ACK_DATA,\n\tMESSAGE_CLOSE,\n\tERR_INVALID_PASSWORD,\n\tERR_INVALID_SIGNATURE,\n\tERR_INVALID_UNCOMPRESSED_SIZE,\n\tERR_ABORT_CHECK_PASSWORD,\n\tCodecStream,\n\tChunkStream\n};\n\nclass CodecStream extends TransformStream {\n\n\tconstructor(options, config) {\n\t\tsuper({});\n\t\tconst codec = this;\n\t\tconst { codecType } = options;\n\t\tlet Stream;\n\t\tif (codecType.startsWith(CODEC_DEFLATE)) {\n\t\t\tStream = DeflateStream;\n\t\t} else if (codecType.startsWith(CODEC_INFLATE)) {\n\t\t\tStream = InflateStream;\n\t\t}\n\t\tcodec.outputSize = 0;\n\t\tlet inputSize = 0;\n\t\tconst stream = new Stream(options, config);\n\t\tconst readable = super.readable;\n\t\tconst inputSizeStream = new TransformStream({\n\t\t\ttransform(chunk, controller) {\n\t\t\t\tif (chunk && chunk.length) {\n\t\t\t\t\tinputSize += chunk.length;\n\t\t\t\t\tcontroller.enqueue(chunk);\n\t\t\t\t}\n\t\t\t},\n\t\t\tflush() {\n\t\t\t\tObject.assign(codec, {\n\t\t\t\t\tinputSize\n\t\t\t\t});\n\t\t\t}\n\t\t});\n\t\tconst outputSizeStream = new TransformStream({\n\t\t\ttransform(chunk, controller) {\n\t\t\t\tif (chunk && chunk.length) {\n\t\t\t\t\tcontroller.enqueue(chunk);\n\t\t\t\t\tcodec.outputSize += chunk.length;\n\t\t\t\t\tif (options.outputSize !== UNDEFINED_VALUE && codec.outputSize > options.outputSize) {\n\t\t\t\t\t\tthrow new Error(ERR_INVALID_UNCOMPRESSED_SIZE);\n\t\t\t\t\t}\n\t\t\t\t}\n\t\t\t},\n\t\t\tflush() {\n\t\t\t\tconst { signature } = stream;\n\t\t\t\tObject.assign(codec, {\n\t\t\t\t\tsignature,\n\t\t\t\t\tinputSize\n\t\t\t\t});\n\t\t\t}\n\t\t});\n\t\tObject.defineProperty(codec, \"readable\", {\n\t\t\tget() {\n\t\t\t\treturn readable.pipeThrough(inputSizeStream).pipeThrough(stream).pipeThrough(outputSizeStream);\n\t\t\t}\n\t\t});\n\t}\n}\n\nclass ChunkStream extends TransformStream {\n\n\tconstructor(chunkSize) {\n\t\tlet pendingChunk;\n\t\tsuper({\n\t\t\ttransform,\n\t\t\tflush(controller) {\n\t\t\t\tif (pendingChunk && pendingChunk.length) {\n\t\t\t\t\tcontroller.enqueue(pendingChunk);\n\t\t\t\t}\n\t\t\t}\n\t\t});\n\n\t\tfunction transform(chunk, controller) {\n\t\t\tif (pendingChunk) {\n\t\t\t\tconst newChunk = new Uint8Array(pendingChunk.length + chunk.length);\n\t\t\t\tnewChunk.set(pendingChunk);\n\t\t\t\tnewChunk.set(chunk, pendingChunk.length);\n\t\t\t\tchunk = newChunk;\n\t\t\t\tpendingChunk = null;\n\t\t\t}\n\t\t\tif (chunk.length > chunkSize) {\n\t\t\t\tcontroller.enqueue(chunk.slice(0, chunkSize));\n\t\t\t\ttransform(chunk.slice(chunkSize), controller);\n\t\t\t} else {\n\t\t\t\tpendingChunk = chunk;\n\t\t\t}\n\t\t}\n\t}\n}","/*\n Copyright (c) 2025 Gildas Lormeau. All rights reserved.\n\n Redistribution and use in source and binary forms, with or without\n modification, are permitted provided that the following conditions are met:\n\n 1. Redistributions of source code must retain the above copyright notice,\n this list of conditions and the following disclaimer.\n\n 2. Redistributions in binary form must reproduce the above copyright \n notice, this list of conditions and the following disclaimer in \n the documentation and/or other materials provided with the distribution.\n\n 3. The names of the authors may not be used to endorse or promote products\n derived from this software without specific prior written permission.\n\n THIS SOFTWARE IS PROVIDED ''AS IS'' AND ANY EXPRESSED OR IMPLIED WARRANTIES,\n INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND\n FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL JCRAFT,\n INC. OR ANY CONTRIBUTORS TO THIS SOFTWARE BE LIABLE FOR ANY DIRECT, INDIRECT,\n INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT\n LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA,\n OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF\n LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING\n NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE,\n EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.\n */\n\n/* global Worker, URL, TransformStream, WritableStream */\n\nimport {\n\tUNDEFINED_VALUE,\n\tUNDEFINED_TYPE,\n\tFUNCTION_TYPE\n} from \"./constants.js\";\nimport {\n\tCodecStream,\n\tChunkStream,\n\tMESSAGE_EVENT_TYPE,\n\tMESSAGE_START,\n\tMESSAGE_PULL,\n\tMESSAGE_DATA,\n\tMESSAGE_ACK_DATA,\n\tMESSAGE_CLOSE\n} from \"./streams/codec-stream.js\";\n\nconst MODULE_WORKER_OPTIONS = { type: \"module\" };\n\nlet webWorkerSupported, webWorkerURI, webWorkerOptions;\nlet transferStreamsSupported = true;\ntry {\n\ttransferStreamsSupported = typeof structuredClone == FUNCTION_TYPE && structuredClone(new DOMException(\"\", \"AbortError\")).code !== UNDEFINED_VALUE;\n} catch {\n\t// ignored\n}\nlet initModule = () => { };\n\nexport {\n\tCodecWorker,\n\tconfigureWorker\n};\n\nfunction configureWorker({ initModule: initModuleFunction }) {\n\tinitModule = initModuleFunction;\n}\n\nclass CodecWorker {\n\n\tconstructor(workerData, { readable, writable }, { options, config, streamOptions, useWebWorkers, transferStreams, workerURI }, onTaskFinished) {\n\t\tconst { signal } = streamOptions;\n\t\tObject.assign(workerData, {\n\t\t\tbusy: true,\n\t\t\treadable: readable\n\t\t\t\t.pipeThrough(new ChunkStream(config.chunkSize))\n\t\t\t\t.pipeThrough(new ProgressWatcherStream(streamOptions), { signal }),\n\t\t\twritable,\n\t\t\toptions: Object.assign({}, options),\n\t\t\tworkerURI,\n\t\t\ttransferStreams,\n\t\t\tterminate() {\n\t\t\t\treturn new Promise(resolve => {\n\t\t\t\t\tconst { worker, busy } = workerData;\n\t\t\t\t\tif (worker) {\n\t\t\t\t\t\tif (busy) {\n\t\t\t\t\t\t\tworkerData.resolveTerminated = resolve;\n\t\t\t\t\t\t} else {\n\t\t\t\t\t\t\tworker.terminate();\n\t\t\t\t\t\t\tresolve();\n\t\t\t\t\t\t}\n\t\t\t\t\t\tworkerData.interface = null;\n\t\t\t\t\t} else {\n\t\t\t\t\t\tresolve();\n\t\t\t\t\t}\n\t\t\t\t});\n\t\t\t},\n\t\t\tonTaskFinished() {\n\t\t\t\tconst { resolveTerminated } = workerData;\n\t\t\t\tif (resolveTerminated) {\n\t\t\t\t\tworkerData.resolveTerminated = null;\n\t\t\t\t\tworkerData.terminated = true;\n\t\t\t\t\tworkerData.worker.terminate();\n\t\t\t\t\tresolveTerminated();\n\t\t\t\t}\n\t\t\t\tworkerData.busy = false;\n\t\t\t\tonTaskFinished(workerData);\n\t\t\t}\n\t\t});\n\t\tif (webWorkerSupported === UNDEFINED_VALUE) {\n\t\t\t// deno-lint-ignore valid-typeof\n\t\t\twebWorkerSupported = typeof Worker != UNDEFINED_TYPE;\n\t\t}\n\t\treturn (useWebWorkers && webWorkerSupported ? createWebWorkerInterface : createWorkerInterface)(workerData, config);\n\t}\n}\n\nclass ProgressWatcherStream extends TransformStream {\n\n\tconstructor({ onstart, onprogress, size, onend }) {\n\t\tlet chunkOffset = 0;\n\t\tsuper({\n\t\t\tasync start() {\n\t\t\t\tif (onstart) {\n\t\t\t\t\tawait callHandler(onstart, size);\n\t\t\t\t}\n\t\t\t},\n\t\t\tasync transform(chunk, controller) {\n\t\t\t\tchunkOffset += chunk.length;\n\t\t\t\tif (onprogress) {\n\t\t\t\t\tawait callHandler(onprogress, chunkOffset, size);\n\t\t\t\t}\n\t\t\t\tcontroller.enqueue(chunk);\n\t\t\t},\n\t\t\tasync flush() {\n\t\t\t\tif (onend) {\n\t\t\t\t\tawait callHandler(onend, chunkOffset);\n\t\t\t\t}\n\t\t\t}\n\t\t});\n\t}\n}\n\nasync function callHandler(handler, ...parameters) {\n\ttry {\n\t\tawait handler(...parameters);\n\t} catch {\n\t\t// ignored\n\t}\n}\n\nfunction createWorkerInterface(workerData, config) {\n\treturn {\n\t\trun: () => runWorker(workerData, config)\n\t};\n}\n\nfunction createWebWorkerInterface(workerData, config) {\n\tconst { baseURI, chunkSize } = config;\n\tlet { wasmURI } = config;\n\n\tif (!workerData.interface) {\n\t\t// deno-lint-ignore valid-typeof\n\t\tif (typeof wasmURI == FUNCTION_TYPE) {\n\t\t\twasmURI = wasmURI();\n\t\t}\n\t\tlet worker;\n\t\ttry {\n\t\t\tworker = getWebWorker(workerData.workerURI, baseURI, workerData);\n\t\t} catch {\n\t\t\twebWorkerSupported = false;\n\t\t\treturn createWorkerInterface(workerData, config);\n\t\t}\n\t\tObject.assign(workerData, {\n\t\t\tworker,\n\t\t\tinterface: {\n\t\t\t\trun: () => runWebWorker(workerData, { chunkSize, wasmURI, baseURI })\n\t\t\t}\n\t\t});\n\t}\n\treturn workerData.interface;\n}\n\nasync function runWorker({ options, readable, writable, onTaskFinished }, config) {\n\tlet codecStream;\n\ttry {\n\t\tif (!options.useCompressionStream) {\n\t\t\ttry {\n\t\t\t\tawait initModule(config);\n\t\t\t} catch {\n\t\t\t\toptions.useCompressionStream = true;\n\t\t\t}\n\t\t}\n\t\tcodecStream = new CodecStream(options, config);\n\t\tawait readable.pipeThrough(codecStream).pipeTo(writable, { preventClose: true, preventAbort: true });\n\t\tconst {\n\t\t\tsignature,\n\t\t\tinputSize,\n\t\t\toutputSize\n\t\t} = codecStream;\n\t\treturn {\n\t\t\tsignature,\n\t\t\tinputSize,\n\t\t\toutputSize\n\t\t};\n\t} catch (error) {\n\t\tif (codecStream) {\n\t\t\terror.outputSize = codecStream.outputSize;\n\t\t}\n\t\tthrow error;\n\t} finally {\n\t\tonTaskFinished();\n\t}\n}\n\nasync function runWebWorker(workerData, config) {\n\tlet resolveResult, rejectResult;\n\tconst result = new Promise((resolve, reject) => {\n\t\tresolveResult = resolve;\n\t\trejectResult = reject;\n\t});\n\tObject.assign(workerData, {\n\t\treader: null,\n\t\twriter: null,\n\t\tresolveResult,\n\t\trejectResult,\n\t\tresult\n\t});\n\tconst { readable, options } = workerData;\n\tconst { writable, closed } = watchClosedStream(workerData.writable);\n\tconst streamsTransferred = sendMessage({\n\t\ttype: MESSAGE_START,\n\t\toptions,\n\t\tconfig,\n\t\treadable,\n\t\twritable\n\t}, workerData);\n\tif (!streamsTransferred) {\n\t\tObject.assign(workerData, {\n\t\t\treader: readable.getReader(),\n\t\t\twriter: writable.getWriter()\n\t\t});\n\t}\n\tconst resultValue = await result;\n\tif (!streamsTransferred) {\n\t\tawait writable.getWriter().close();\n\t}\n\tawait closed;\n\treturn resultValue;\n}\n\nfunction watchClosedStream(writableSource) {\n\tconst { writable, readable } = new TransformStream();\n\tconst closed = readable.pipeTo(writableSource, { preventClose: true });\n\treturn { writable, closed };\n}\n\nfunction getWebWorker(url, baseURI, workerData, isModuleType, useBlobURI = true) {\n\tlet worker, resolvedURI, resolvedOptions;\n\tif (webWorkerURI === UNDEFINED_VALUE) {\n\t\t// deno-lint-ignore valid-typeof\n\t\tconst isFunctionURI = typeof url == FUNCTION_TYPE;\n\t\tif (isFunctionURI) {\n\t\t\tresolvedURI = url(useBlobURI);\n\t\t} else {\n\t\t\tresolvedURI = url;\n\t\t}\n\t\tconst isDataURI = resolvedURI.startsWith(\"data:\");\n\t\tconst isBlobURI = resolvedURI.startsWith(\"blob:\");\n\t\tif (isDataURI || isBlobURI) {\n\t\t\tif (isModuleType === UNDEFINED_VALUE) {\n\t\t\t\tisModuleType = false;\n\t\t\t}\n\t\t\tif (isModuleType) {\n\t\t\t\tresolvedOptions = MODULE_WORKER_OPTIONS;\n\t\t\t}\n\t\t\ttry {\n\t\t\t\tworker = new Worker(resolvedURI, resolvedOptions);\n\t\t\t} catch (error) {\n\t\t\t\tif (isBlobURI) {\n\t\t\t\t\ttry {\n\t\t\t\t\t\tURL.revokeObjectURL(resolvedURI);\n\t\t\t\t\t} catch {\n\t\t\t\t\t\t// ignored\n\t\t\t\t\t}\n\t\t\t\t}\n\t\t\t\tif (isFunctionURI && isBlobURI) {\n\t\t\t\t\treturn getWebWorker(url, baseURI, workerData, isModuleType, false);\n\t\t\t\t} else if (!isModuleType) {\n\t\t\t\t\treturn getWebWorker(url, baseURI, workerData, true, false);\n\t\t\t\t} else {\n\t\t\t\t\tthrow error;\n\t\t\t\t}\n\t\t\t}\n\t\t} else {\n\t\t\tif (isModuleType === UNDEFINED_VALUE) {\n\t\t\t\tisModuleType = true;\n\t\t\t}\n\t\t\tif (isModuleType) {\n\t\t\t\tresolvedOptions = MODULE_WORKER_OPTIONS;\n\t\t\t}\n\t\t\ttry {\n\t\t\t\tresolvedURI = new URL(resolvedURI, baseURI);\n\t\t\t} catch {\n\t\t\t\t// ignored\n\t\t\t}\n\t\t\ttry {\n\t\t\t\tworker = new Worker(resolvedURI, resolvedOptions);\n\t\t\t} catch (error) {\n\t\t\t\tif (!isModuleType) {\n\t\t\t\t\treturn getWebWorker(url, baseURI, workerData, false, useBlobURI);\n\t\t\t\t} else {\n\t\t\t\t\tthrow error;\n\t\t\t\t}\n\t\t\t}\n\t\t}\n\t\twebWorkerURI = resolvedURI;\n\t\twebWorkerOptions = resolvedOptions;\n\t} else {\n\t\tworker = new Worker(webWorkerURI, webWorkerOptions);\n\t}\n\tworker.addEventListener(MESSAGE_EVENT_TYPE, event => onMessage(event, workerData));\n\treturn worker;\n}\n\nfunction sendMessage(message, { worker, writer, onTaskFinished, transferStreams }) {\n\ttry {\n\t\tconst { value, readable, writable } = message;\n\t\tconst transferables = [];\n\t\tif (value) {\n\t\t\tmessage.value = value;\n\t\t\ttransferables.push(message.value.buffer);\n\t\t}\n\t\tif (transferStreams && transferStreamsSupported) {\n\t\t\tif (readable) {\n\t\t\t\ttransferables.push(readable);\n\t\t\t}\n\t\t\tif (writable) {\n\t\t\t\ttransferables.push(writable);\n\t\t\t}\n\t\t} else {\n\t\t\tmessage.readable = message.writable = null;\n\t\t}\n\t\tif (transferables.length) {\n\t\t\ttry {\n\t\t\t\tworker.postMessage(message, transferables);\n\t\t\t\treturn true;\n\t\t\t} catch {\n\t\t\t\ttransferStreamsSupported = false;\n\t\t\t\tmessage.readable = message.writable = null;\n\t\t\t\tworker.postMessage(message);\n\t\t\t}\n\t\t} else {\n\t\t\tworker.postMessage(message);\n\t\t}\n\t} catch (error) {\n\t\tif (writer) {\n\t\t\twriter.releaseLock();\n\t\t}\n\t\tonTaskFinished();\n\t\tthrow error;\n\t}\n}\n\nasync function onMessage({ data }, workerData) {\n\tconst { type, value, messageId, result, error } = data;\n\tconst { reader, writer, resolveResult, rejectResult, onTaskFinished } = workerData;\n\ttry {\n\t\tif (error) {\n\t\t\tconst { message, stack, code, name, outputSize } = error;\n\t\t\tconst responseError = new Error(message);\n\t\t\tObject.assign(responseError, { stack, code, name, outputSize });\n\t\t\tclose(responseError);\n\t\t} else {\n\t\t\tif (type == MESSAGE_PULL) {\n\t\t\t\tconst { value, done } = await reader.read();\n\t\t\t\tsendMessage({ type: MESSAGE_DATA, value, done, messageId }, workerData);\n\t\t\t}\n\t\t\tif (type == MESSAGE_DATA) {\n\t\t\t\tawait writer.ready;\n\t\t\t\tawait writer.write(new Uint8Array(value));\n\t\t\t\tsendMessage({ type: MESSAGE_ACK_DATA, messageId }, workerData);\n\t\t\t}\n\t\t\tif (type == MESSAGE_CLOSE) {\n\t\t\t\tclose(null, result);\n\t\t\t}\n\t\t}\n\t} catch (error) {\n\t\tsendMessage({ type: MESSAGE_CLOSE, messageId }, workerData);\n\t\tclose(error);\n\t}\n\n\tfunction close(error, result) {\n\t\tif (error) {\n\t\t\trejectResult(error);\n\t\t} else {\n\t\t\tresolveResult(result);\n\t\t}\n\t\tif (writer) {\n\t\t\twriter.releaseLock();\n\t\t}\n\t\tonTaskFinished();\n\t}\n}","/*\n Copyright (c) 2025 Gildas Lormeau. All rights reserved.\n\n Redistribution and use in source and binary forms, with or without\n modification, are permitted provided that the following conditions are met:\n\n 1. Redistributions of source code must retain the above copyright notice,\n this list of conditions and the following disclaimer.\n\n 2. Redistributions in binary form must reproduce the above copyright \n notice, this list of conditions and the following disclaimer in \n the documentation and/or other materials provided with the distribution.\n\n 3. The names of the authors may not be used to endorse or promote products\n derived from this software without specific prior written permission.\n\n THIS SOFTWARE IS PROVIDED ''AS IS'' AND ANY EXPRESSED OR IMPLIED WARRANTIES,\n INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND\n FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL JCRAFT,\n INC. OR ANY CONTRIBUTORS TO THIS SOFTWARE BE LIABLE FOR ANY DIRECT, INDIRECT,\n INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT\n LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA,\n OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF\n LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING\n NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE,\n EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.\n */\n\n/* global setTimeout, clearTimeout */\n\nimport { UNDEFINED_VALUE } from \"./constants.js\";\nimport {\n\tCODEC_INFLATE,\n\tCODEC_DEFLATE,\n\tERR_INVALID_SIGNATURE,\n\tERR_INVALID_UNCOMPRESSED_SIZE,\n\tERR_INVALID_PASSWORD,\n\tERR_ABORT_CHECK_PASSWORD\n} from \"./streams/codec-stream.js\";\nimport { CodecWorker } from \"./codec-worker.js\";\n\nlet pool = [];\nconst pendingRequests = [];\n\nexport {\n\trunWorker,\n\tterminateWorkers,\n\tCODEC_DEFLATE,\n\tCODEC_INFLATE,\n\tERR_INVALID_SIGNATURE,\n\tERR_INVALID_UNCOMPRESSED_SIZE,\n\tERR_INVALID_PASSWORD,\n\tERR_ABORT_CHECK_PASSWORD\n};\n\nlet indexWorker = 0;\n\nasync function runWorker(stream, workerOptions) {\n\tconst { options, config } = workerOptions;\n\tconst { transferStreams, useWebWorkers, useCompressionStream, compressed, signed, encrypted } = options;\n\tconst { workerURI, maxWorkers } = config;\n\tworkerOptions.transferStreams = transferStreams || transferStreams === UNDEFINED_VALUE;\n\tconst streamCopy = !compressed && !signed && !encrypted && !workerOptions.transferStreams;\n\tworkerOptions.useWebWorkers = !streamCopy && (useWebWorkers || (useWebWorkers === UNDEFINED_VALUE && config.useWebWorkers));\n\tworkerOptions.workerURI = workerOptions.useWebWorkers && workerURI ? workerURI : UNDEFINED_VALUE;\n\toptions.useCompressionStream = useCompressionStream || (useCompressionStream === UNDEFINED_VALUE && config.useCompressionStream);\n\treturn (await getWorker()).run();\n\n\t// deno-lint-ignore require-await\n\tasync function getWorker() {\n\t\tconst workerData = pool.find(workerData => !workerData.busy);\n\t\tif (workerData) {\n\t\t\tclearTerminateTimeout(workerData);\n\t\t\treturn new CodecWorker(workerData, stream, workerOptions, onTaskFinished);\n\t\t} else if (pool.length < maxWorkers) {\n\t\t\tconst workerData = { indexWorker };\n\t\t\tindexWorker++;\n\t\t\tpool.push(workerData);\n\t\t\treturn new CodecWorker(workerData, stream, workerOptions, onTaskFinished);\n\t\t} else {\n\t\t\treturn new Promise(resolve => pendingRequests.push({ resolve, stream, workerOptions }));\n\t\t}\n\t}\n\n\tfunction onTaskFinished(workerData) {\n\t\tif (pendingRequests.length) {\n\t\t\tconst [{ resolve, stream, workerOptions }] = pendingRequests.splice(0, 1);\n\t\t\tresolve(new CodecWorker(workerData, stream, workerOptions, onTaskFinished));\n\t\t} else if (workerData.worker) {\n\t\t\tclearTerminateTimeout(workerData);\n\t\t\tterminateWorker(workerData, workerOptions);\n\t\t} else {\n\t\t\tpool = pool.filter(data => data != workerData);\n\t\t}\n\t}\n}\n\nfunction terminateWorker(workerData, workerOptions) {\n\tconst { config } = workerOptions;\n\tconst { terminateWorkerTimeout } = config;\n\tif (Number.isFinite(terminateWorkerTimeout) && terminateWorkerTimeout >= 0) {\n\t\tif (workerData.terminated) {\n\t\t\tworkerData.terminated = false;\n\t\t} else {\n\t\t\tworkerData.terminateTimeout = setTimeout(async () => {\n\t\t\t\tpool = pool.filter(data => data != workerData);\n\t\t\t\ttry {\n\t\t\t\t\tawait workerData.terminate();\n\t\t\t\t} catch {\n\t\t\t\t\t// ignored\n\t\t\t\t}\n\t\t\t}, terminateWorkerTimeout);\n\t\t}\n\t}\n}\n\nfunction clearTerminateTimeout(workerData) {\n\tconst { terminateTimeout } = workerData;\n\tif (terminateTimeout) {\n\t\tclearTimeout(terminateTimeout);\n\t\tworkerData.terminateTimeout = null;\n\t}\n}\n\nasync function terminateWorkers() {\n\tawait Promise.allSettled(pool.map(workerData => {\n\t\tclearTerminateTimeout(workerData);\n\t\treturn workerData.terminate();\n\t}));\n}","/*\n Copyright (c) 2025 Gildas Lormeau. All rights reserved.\n\n Redistribution and use in source and binary forms, with or without\n modification, are permitted provided that the following conditions are met:\n\n 1. Redistributions of source code must retain the above copyright notice,\n this list of conditions and the following disclaimer.\n\n 2. Redistributions in binary form must reproduce the above copyright \n notice, this list of conditions and the following disclaimer in \n the documentation and/or other materials provided with the distribution.\n\n 3. The names of the authors may not be used to endorse or promote products\n derived from this software without specific prior written permission.\n\n THIS SOFTWARE IS PROVIDED ''AS IS'' AND ANY EXPRESSED OR IMPLIED WARRANTIES,\n INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND\n FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL JCRAFT,\n INC. OR ANY CONTRIBUTORS TO THIS SOFTWARE BE LIABLE FOR ANY DIRECT, INDIRECT,\n INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT\n LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA,\n OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF\n LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING\n NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE,\n EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.\n */\n\n/* global Blob, atob, btoa, XMLHttpRequest, URL, fetch, ReadableStream, WritableStream, FileReader, TransformStream, Response */\n// deno-lint-ignore-file no-this-alias\n\nimport {\n\tUNDEFINED_VALUE,\n\tINFINITY_VALUE,\n\tFUNCTION_TYPE,\n\tEND_OF_CENTRAL_DIR_LENGTH\n} from \"./constants.js\";\nimport { getConfiguration } from \"./configuration.js\";\n\nconst ERR_HTTP_STATUS = \"HTTP error \";\nconst ERR_HTTP_RANGE = \"HTTP Range not supported\";\nconst ERR_ITERATOR_COMPLETED_TOO_SOON = \"Writer iterator completed too soon\";\nconst ERR_WRITER_NOT_INITIALIZED = \"Writer not initialized\";\n\nconst CONTENT_TYPE_TEXT_PLAIN = \"text/plain\";\nconst HTTP_HEADER_CONTENT_LENGTH = \"Content-Length\";\nconst HTTP_HEADER_CONTENT_RANGE = \"Content-Range\";\nconst HTTP_HEADER_ACCEPT_RANGES = \"Accept-Ranges\";\nconst HTTP_HEADER_RANGE = \"Range\";\nconst HTTP_HEADER_CONTENT_TYPE = \"Content-Type\";\nconst HTTP_METHOD_HEAD = \"HEAD\";\nconst HTTP_METHOD_GET = \"GET\";\nconst HTTP_RANGE_UNIT = \"bytes\";\nconst DEFAULT_CHUNK_SIZE = 64 * 1024;\nconst DEFAULT_BUFFER_SIZE = 256 * 1024;\n\nconst PROPERTY_NAME_WRITABLE = \"writable\";\n\nclass Stream {\n\n\tconstructor() {\n\t\tthis.size = 0;\n\t}\n\n\tinit() {\n\t\tthis.initialized = true;\n\t}\n}\n\nclass Reader extends Stream {\n\n\tget readable() {\n\t\tconst reader = this;\n\t\tconst { chunkSize = DEFAULT_CHUNK_SIZE } = reader;\n\t\tconst readable = new ReadableStream({\n\t\t\tstart() {\n\t\t\t\tthis.chunkOffset = 0;\n\t\t\t},\n\t\t\tasync pull(controller) {\n\t\t\t\tconst { offset = 0, size, diskNumberStart } = readable;\n\t\t\t\tconst { chunkOffset } = this;\n\t\t\t\tconst dataSize = size === UNDEFINED_VALUE ? chunkSize : Math.min(chunkSize, size - chunkOffset);\n\t\t\t\tconst data = await readUint8Array(reader, offset + chunkOffset, dataSize, diskNumberStart);\n\t\t\t\tcontroller.enqueue(data);\n\t\t\t\tif ((chunkOffset + chunkSize > size) || (size === UNDEFINED_VALUE && !data.length && dataSize)) {\n\t\t\t\t\tcontroller.close();\n\t\t\t\t} else {\n\t\t\t\t\tthis.chunkOffset += chunkSize;\n\t\t\t\t}\n\t\t\t}\n\t\t});\n\t\treturn readable;\n\t}\n}\n\nclass Writer extends Stream {\n\n\tconstructor() {\n\t\tsuper();\n\t\tconst writer = this;\n\t\tconst writable = new WritableStream({\n\t\t\twrite(chunk) {\n\t\t\t\tif (!writer.initialized) {\n\t\t\t\t\tthrow new Error(ERR_WRITER_NOT_INITIALIZED);\n\t\t\t\t}\n\t\t\t\treturn writer.writeUint8Array(chunk);\n\t\t\t}\n\t\t});\n\t\tObject.defineProperty(writer, PROPERTY_NAME_WRITABLE, {\n\t\t\tget() {\n\t\t\t\treturn writable;\n\t\t\t}\n\t\t});\n\t}\n\n\twriteUint8Array() {\n\t\t// abstract\n\t}\n}\n\nclass Data64URIReader extends Reader {\n\n\tconstructor(dataURI) {\n\t\tsuper();\n\t\tlet dataEnd = dataURI.length;\n\t\twhile (dataURI.charAt(dataEnd - 1) == \"=\") {\n\t\t\tdataEnd--;\n\t\t}\n\t\tconst dataStart = dataURI.indexOf(\",\") + 1;\n\t\tObject.assign(this, {\n\t\t\tdataURI,\n\t\t\tdataStart,\n\t\t\tsize: Math.floor((dataEnd - dataStart) * 0.75)\n\t\t});\n\t}\n\n\treadUint8Array(offset, length) {\n\t\tconst {\n\t\t\tdataStart,\n\t\t\tdataURI\n\t\t} = this;\n\t\tconst dataArray = new Uint8Array(length);\n\t\tconst start = Math.floor(offset / 3) * 4;\n\t\tconst bytes = atob(dataURI.substring(start + dataStart, Math.ceil((offset + length) / 3) * 4 + dataStart));\n\t\tconst delta = offset - Math.floor(start / 4) * 3;\n\t\tlet effectiveLength = 0;\n\t\tfor (let indexByte = delta; indexByte < delta + length && indexByte < bytes.length; indexByte++) {\n\t\t\tdataArray[indexByte - delta] = bytes.charCodeAt(indexByte);\n\t\t\teffectiveLength++;\n\t\t}\n\t\tif (effectiveLength < dataArray.length) {\n\t\t\treturn dataArray.subarray(0, effectiveLength);\n\t\t} else {\n\t\t\treturn dataArray;\n\t\t}\n\t}\n}\n\nclass Data64URIWriter extends Writer {\n\n\tconstructor(contentType) {\n\t\tsuper();\n\t\tObject.assign(this, {\n\t\t\tdata: \"data:\" + (contentType || \"\") + \";base64,\",\n\t\t\tpending: []\n\t\t});\n\t}\n\n\twriteUint8Array(array) {\n\t\tconst writer = this;\n\t\tlet indexArray = 0;\n\t\tlet dataString = writer.pending;\n\t\tconst delta = writer.pending.length;\n\t\twriter.pending = \"\";\n\t\tfor (indexArray = 0; indexArray < (Math.floor((delta + array.length) / 3) * 3) - delta; indexArray++) {\n\t\t\tdataString += String.fromCharCode(array[indexArray]);\n\t\t}\n\t\tfor (; indexArray < array.length; indexArray++) {\n\t\t\twriter.pending += String.fromCharCode(array[indexArray]);\n\t\t}\n\t\tif (dataString.length) {\n\t\t\tif (dataString.length > 2) {\n\t\t\t\twriter.data += btoa(dataString);\n\t\t\t} else {\n\t\t\t\twriter.pending += dataString;\n\t\t\t}\n\t\t}\n\t}\n\n\tgetData() {\n\t\treturn this.data + btoa(this.pending);\n\t}\n}\n\nclass BlobReader extends Reader {\n\n\tconstructor(blob) {\n\t\tsuper();\n\t\tObject.assign(this, {\n\t\t\tblob,\n\t\t\tsize: blob.size\n\t\t});\n\t}\n\n\tasync readUint8Array(offset, length) {\n\t\tconst reader = this;\n\t\tconst offsetEnd = offset + length;\n\t\tconst blob = offset || offsetEnd < reader.size ? reader.blob.slice(offset, offsetEnd) : reader.blob;\n\t\tlet arrayBuffer = await blob.arrayBuffer();\n\t\tif (arrayBuffer.byteLength > length) {\n\t\t\tarrayBuffer = arrayBuffer.slice(offset, offsetEnd);\n\t\t}\n\t\treturn new Uint8Array(arrayBuffer);\n\t}\n}\n\nclass BlobWriter extends Stream {\n\n\tconstructor(contentType) {\n\t\tsuper();\n\t\tconst writer = this;\n\t\tconst transformStream = new TransformStream();\n\t\tconst headers = [];\n\t\tif (contentType) {\n\t\t\theaders.push([HTTP_HEADER_CONTENT_TYPE, contentType]);\n\t\t}\n\t\tObject.defineProperty(writer, PROPERTY_NAME_WRITABLE, {\n\t\t\tget() {\n\t\t\t\treturn transformStream.writable;\n\t\t\t}\n\t\t});\n\t\twriter.blob = new Response(transformStream.readable, { headers }).blob();\n\t}\n\n\tgetData() {\n\t\treturn this.blob;\n\t}\n}\n\nclass TextReader extends BlobReader {\n\n\tconstructor(text) {\n\t\tsuper(new Blob([text], { type: CONTENT_TYPE_TEXT_PLAIN }));\n\t}\n}\n\nclass TextWriter extends BlobWriter {\n\n\tconstructor(encoding) {\n\t\tsuper(encoding);\n\t\tObject.assign(this, {\n\t\t\tencoding,\n\t\t\tutf8: !encoding || encoding.toLowerCase() == \"utf-8\"\n\t\t});\n\t}\n\n\tasync getData() {\n\t\tconst {\n\t\t\tencoding,\n\t\t\tutf8\n\t\t} = this;\n\t\tconst blob = await super.getData();\n\t\tif (blob.text && utf8) {\n\t\t\treturn blob.text();\n\t\t} else {\n\t\t\tconst reader = new FileReader();\n\t\t\treturn new Promise((resolve, reject) => {\n\t\t\t\tObject.assign(reader, {\n\t\t\t\t\tonload: ({ target }) => resolve(target.result),\n\t\t\t\t\tonerror: () => reject(reader.error)\n\t\t\t\t});\n\t\t\t\treader.readAsText(blob, encoding);\n\t\t\t});\n\t\t}\n\t}\n}\n\nclass FetchReader extends Reader {\n\n\tconstructor(url, options) {\n\t\tsuper();\n\t\tcreateHttpReader(this, url, options);\n\t}\n\n\tasync init() {\n\t\tawait initHttpReader(this, sendFetchRequest, getFetchRequestData);\n\t\tsuper.init();\n\t}\n\n\treadUint8Array(index, length) {\n\t\treturn readUint8ArrayHttpReader(this, index, length, sendFetchRequest, getFetchRequestData);\n\t}\n}\n\nclass XHRReader extends Reader {\n\n\tconstructor(url, options) {\n\t\tsuper();\n\t\tcreateHttpReader(this, url, options);\n\t}\n\n\tasync init() {\n\t\tawait initHttpReader(this, sendXMLHttpRequest, getXMLHttpRequestData);\n\t\tsuper.init();\n\t}\n\n\treadUint8Array(index, length) {\n\t\treturn readUint8ArrayHttpReader(this, index, length, sendXMLHttpRequest, getXMLHttpRequestData);\n\t}\n}\n\nfunction createHttpReader(httpReader, url, options) {\n\tconst {\n\t\tpreventHeadRequest,\n\t\tuseRangeHeader,\n\t\tforceRangeRequests,\n\t\tcombineSizeEocd\n\t} = options;\n\toptions = Object.assign({}, options);\n\tdelete options.preventHeadRequest;\n\tdelete options.useRangeHeader;\n\tdelete options.forceRangeRequests;\n\tdelete options.combineSizeEocd;\n\tdelete options.useXHR;\n\tObject.assign(httpReader, {\n\t\turl,\n\t\toptions,\n\t\tpreventHeadRequest,\n\t\tuseRangeHeader,\n\t\tforceRangeRequests,\n\t\tcombineSizeEocd\n\t});\n}\n\nasync function initHttpReader(httpReader, sendRequest, getRequestData) {\n\tconst {\n\t\turl,\n\t\tpreventHeadRequest,\n\t\tuseRangeHeader,\n\t\tforceRangeRequests,\n\t\tcombineSizeEocd\n\t} = httpReader;\n\tif (isHttpFamily(url) && (useRangeHeader || forceRangeRequests) && (typeof preventHeadRequest == \"undefined\" || preventHeadRequest)) {\n\t\tconst response = await sendRequest(HTTP_METHOD_GET, httpReader, getRangeHeaders(httpReader, combineSizeEocd ? -END_OF_CENTRAL_DIR_LENGTH : undefined));\n\t\tconst acceptRanges = response.headers.get(HTTP_HEADER_ACCEPT_RANGES);\n\t\tif (!forceRangeRequests && (!acceptRanges || acceptRanges.toLowerCase() != HTTP_RANGE_UNIT)) {\n\t\t\tthrow new Error(ERR_HTTP_RANGE);\n\t\t} else {\n\t\t\tif (combineSizeEocd) {\n\t\t\t\thttpReader.eocdCache = new Uint8Array(await response.arrayBuffer());\n\t\t\t}\n\t\t\tlet contentSize;\n\t\t\tconst contentRangeHeader = response.headers.get(HTTP_HEADER_CONTENT_RANGE);\n\t\t\tif (contentRangeHeader) {\n\t\t\t\tconst splitHeader = contentRangeHeader.trim().split(/\\s*\\/\\s*/);\n\t\t\t\tif (splitHeader.length) {\n\t\t\t\t\tconst headerValue = splitHeader[1];\n\t\t\t\t\tif (headerValue && headerValue != \"*\") {\n\t\t\t\t\t\tcontentSize = Number(headerValue);\n\t\t\t\t\t}\n\t\t\t\t}\n\t\t\t}\n\t\t\tif (contentSize === UNDEFINED_VALUE) {\n\t\t\t\tawait getContentLength(httpReader, sendRequest, getRequestData);\n\t\t\t} else {\n\t\t\t\thttpReader.size = contentSize;\n\t\t\t}\n\t\t}\n\t} else {\n\t\tawait getContentLength(httpReader, sendRequest, getRequestData);\n\t}\n}\n\nasync function readUint8ArrayHttpReader(httpReader, index, length, sendRequest, getRequestData) {\n\tconst {\n\t\tuseRangeHeader,\n\t\tforceRangeRequests,\n\t\teocdCache,\n\t\tsize,\n\t\toptions\n\t} = httpReader;\n\tif (useRangeHeader || forceRangeRequests) {\n\t\tif (eocdCache && index == size - END_OF_CENTRAL_DIR_LENGTH && length == END_OF_CENTRAL_DIR_LENGTH) {\n\t\t\treturn eocdCache;\n\t\t}\n\t\tif (index >= size || length === 0) {\n\t\t\treturn new Uint8Array();\n\t\t} else {\n\t\t\tif (index + length > size) {\n\t\t\t\tlength = size - index;\n\t\t\t}\n\t\t\tconst response = await sendRequest(HTTP_METHOD_GET, httpReader, getRangeHeaders(httpReader, index, length));\n\t\t\tif (response.status != 206) {\n\t\t\t\tthrow new Error(ERR_HTTP_RANGE);\n\t\t\t}\n\t\t\treturn new Uint8Array(await response.arrayBuffer());\n\t\t}\n\t} else {\n\t\tconst { data } = httpReader;\n\t\tif (!data) {\n\t\t\tawait getRequestData(httpReader, options);\n\t\t}\n\t\treturn new Uint8Array(httpReader.data.subarray(index, index + length));\n\t}\n}\n\nfunction getRangeHeaders(httpReader, index = 0, length = 1) {\n\treturn Object.assign({}, getHeaders(httpReader), { [HTTP_HEADER_RANGE]: HTTP_RANGE_UNIT + \"=\" + (index < 0 ? index : index + \"-\" + (index + length - 1)) });\n}\n\nfunction getHeaders({ options }) {\n\tconst { headers } = options;\n\tif (headers) {\n\t\tif (Symbol.iterator in headers) {\n\t\t\treturn Object.fromEntries(headers);\n\t\t} else {\n\t\t\treturn headers;\n\t\t}\n\t}\n}\n\nasync function getFetchRequestData(httpReader) {\n\tawait getRequestData(httpReader, sendFetchRequest);\n}\n\nasync function getXMLHttpRequestData(httpReader) {\n\tawait getRequestData(httpReader, sendXMLHttpRequest);\n}\n\nasync function getRequestData(httpReader, sendRequest) {\n\tconst response = await sendRequest(HTTP_METHOD_GET, httpReader, getHeaders(httpReader));\n\thttpReader.data = new Uint8Array(await response.arrayBuffer());\n\tif (!httpReader.size) {\n\t\thttpReader.size = httpReader.data.length;\n\t}\n}\n\nasync function getContentLength(httpReader, sendRequest, getRequestData) {\n\tif (httpReader.preventHeadRequest) {\n\t\tawait getRequestData(httpReader, httpReader.options);\n\t} else {\n\t\tconst response = await sendRequest(HTTP_METHOD_HEAD, httpReader, getHeaders(httpReader));\n\t\tconst contentLength = response.headers.get(HTTP_HEADER_CONTENT_LENGTH);\n\t\tif (contentLength) {\n\t\t\thttpReader.size = Number(contentLength);\n\t\t} else {\n\t\t\tawait getRequestData(httpReader, httpReader.options);\n\t\t}\n\t}\n}\n\nasync function sendFetchRequest(method, { options, url }, headers) {\n\tconst response = await fetch(url, Object.assign({}, options, { method, headers }));\n\tif (response.status < 400) {\n\t\treturn response;\n\t} else {\n\t\tthrow response.status == 416 ? new Error(ERR_HTTP_RANGE) : new Error(ERR_HTTP_STATUS + (response.statusText || response.status));\n\t}\n}\n\nfunction sendXMLHttpRequest(method, { url }, headers) {\n\treturn new Promise((resolve, reject) => {\n\t\tconst request = new XMLHttpRequest();\n\t\trequest.addEventListener(\"load\", () => {\n\t\t\tif (request.status < 400) {\n\t\t\t\tconst headers = [];\n\t\t\t\trequest.getAllResponseHeaders().trim().split(/[\\r\\n]+/).forEach(header => {\n\t\t\t\t\tconst splitHeader = header.trim().split(/\\s*:\\s*/);\n\t\t\t\t\tsplitHeader[0] = splitHeader[0].trim().replace(/^[a-z]|-[a-z]/g, value => value.toUpperCase());\n\t\t\t\t\theaders.push(splitHeader);\n\t\t\t\t});\n\t\t\t\tresolve({\n\t\t\t\t\tstatus: request.status,\n\t\t\t\t\tarrayBuffer: () => request.response,\n\t\t\t\t\theaders: new Map(headers)\n\t\t\t\t});\n\t\t\t} else {\n\t\t\t\treject(request.status == 416 ? new Error(ERR_HTTP_RANGE) : new Error(ERR_HTTP_STATUS + (request.statusText || request.status)));\n\t\t\t}\n\t\t}, false);\n\t\trequest.addEventListener(\"error\", event => reject(event.detail ? event.detail.error : new Error(\"Network error\")), false);\n\t\trequest.open(method, url);\n\t\tif (headers) {\n\t\t\tfor (const entry of Object.entries(headers)) {\n\t\t\t\trequest.setRequestHeader(entry[0], entry[1]);\n\t\t\t}\n\t\t}\n\t\trequest.responseType = \"arraybuffer\";\n\t\trequest.send();\n\t});\n}\n\nclass HttpReader extends Reader {\n\n\tconstructor(url, options = {}) {\n\t\tsuper();\n\t\tObject.assign(this, {\n\t\t\turl,\n\t\t\treader: options.useXHR ? new XHRReader(url, options) : new FetchReader(url, options)\n\t\t});\n\t}\n\n\tset size(value) {\n\t\t// ignored\n\t}\n\n\tget size() {\n\t\treturn this.reader.size;\n\t}\n\n\tasync init() {\n\t\tawait this.reader.init();\n\t\tsuper.init();\n\t}\n\n\treadUint8Array(index, length) {\n\t\treturn this.reader.readUint8Array(index, length);\n\t}\n}\n\nclass HttpRangeReader extends HttpReader {\n\n\tconstructor(url, options = {}) {\n\t\toptions.useRangeHeader = true;\n\t\tsuper(url, options);\n\t}\n}\n\n\nclass Uint8ArrayReader extends Reader {\n\n\tconstructor(array) {\n\t\tsuper();\n\t\tarray = new Uint8Array(array.buffer, array.byteOffset, array.byteLength);\n\t\tObject.assign(this, {\n\t\t\tarray,\n\t\t\tsize: array.length\n\t\t});\n\t}\n\n\treadUint8Array(index, length) {\n\t\treturn this.array.slice(index, index + length);\n\t}\n}\n\nclass Uint8ArrayWriter extends Writer {\n\n\tconstructor(defaultBufferSize) {\n\t\tsuper();\n\t\tthis.defaultBufferSize = defaultBufferSize || DEFAULT_BUFFER_SIZE;\n\t}\n\n\tinit(initSize = 0) {\n\t\tObject.assign(this, {\n\t\t\toffset: 0,\n\t\t\tarray: new Uint8Array(initSize > 0 ? initSize : this.defaultBufferSize)\n\t\t});\n\t\tsuper.init();\n\t}\n\n\twriteUint8Array(array) {\n\t\tconst writer = this;\n\t\tconst requiredLength = writer.offset + array.length;\n\t\tif (requiredLength > writer.array.length) {\n\t\t\tlet newLength = writer.array.length ? writer.array.length * 2 : writer.defaultBufferSize;\n\t\t\twhile (newLength < requiredLength) {\n\t\t\t\tnewLength *= 2;\n\t\t\t}\n\t\t\tconst previousArray = writer.array;\n\t\t\twriter.array = new Uint8Array(newLength);\n\t\t\twriter.array.set(previousArray);\n\t\t}\n\t\twriter.array.set(array, writer.offset);\n\t\twriter.offset += array.length;\n\t}\n\n\tgetData() {\n\t\tif (this.offset === this.array.length) {\n\t\t\treturn this.array;\n\t\t} else {\n\t\t\treturn this.array.slice(0, this.offset);\n\t\t}\n\t}\n}\n\nclass SplitDataReader extends Reader {\n\n\tconstructor(readers) {\n\t\tsuper();\n\t\tthis.readers = readers;\n\t}\n\n\tasync init() {\n\t\tconst reader = this;\n\t\tconst { readers } = reader;\n\t\treader.lastDiskNumber = 0;\n\t\treader.lastDiskOffset = 0;\n\t\tawait Promise.all(readers.map(async (diskReader, indexDiskReader) => {\n\t\t\tawait diskReader.init();\n\t\t\tif (indexDiskReader != readers.length - 1) {\n\t\t\t\treader.lastDiskOffset += diskReader.size;\n\t\t\t}\n\t\t\treader.size += diskReader.size;\n\t\t}));\n\t\tsuper.init();\n\t}\n\n\tasync readUint8Array(offset, length, diskNumber = 0) {\n\t\tconst reader = this;\n\t\tconst { readers } = this;\n\t\tlet result;\n\t\tlet currentDiskNumber = diskNumber;\n\t\tif (currentDiskNumber == -1) {\n\t\t\tcurrentDiskNumber = readers.length - 1;\n\t\t}\n\t\tlet currentReaderOffset = offset;\n\t\twhile (readers[currentDiskNumber] && currentReaderOffset >= readers[currentDiskNumber].size) {\n\t\t\tcurrentReaderOffset -= readers[currentDiskNumber].size;\n\t\t\tcurrentDiskNumber++;\n\t\t}\n\t\tconst currentReader = readers[currentDiskNumber];\n\t\tif (currentReader) {\n\t\t\tconst currentReaderSize = currentReader.size;\n\t\t\tif (currentReaderOffset + length <= currentReaderSize) {\n\t\t\t\tresult = await readUint8Array(currentReader, currentReaderOffset, length);\n\t\t\t} else {\n\t\t\t\tconst chunkLength = currentReaderSize - currentReaderOffset;\n\t\t\t\tresult = new Uint8Array(length);\n\t\t\t\tconst firstPart = await readUint8Array(currentReader, currentReaderOffset, chunkLength);\n\t\t\t\tresult.set(firstPart, 0);\n\t\t\t\tconst secondPart = await reader.readUint8Array(offset + chunkLength, length - chunkLength, diskNumber);\n\t\t\t\tresult.set(secondPart, chunkLength);\n\t\t\t\tif (firstPart.length + secondPart.length < length) {\n\t\t\t\t\tresult = result.subarray(0, firstPart.length + secondPart.length);\n\t\t\t\t}\n\t\t\t}\n\t\t} else {\n\t\t\tresult = new Uint8Array();\n\t\t}\n\t\treader.lastDiskNumber = Math.max(currentDiskNumber, reader.lastDiskNumber);\n\t\treturn result;\n\t}\n}\n\nclass SplitDataWriter extends Stream {\n\n\tconstructor(writerGenerator, maxSize = 4294967295) {\n\t\tsuper();\n\t\tconst writer = this;\n\t\tObject.assign(writer, {\n\t\t\tdiskNumber: 0,\n\t\t\tdiskOffset: 0,\n\t\t\tsize: 0,\n\t\t\tmaxSize,\n\t\t\tavailableSize: maxSize\n\t\t});\n\t\tlet diskSourceWriter, diskWritable, diskWriter;\n\t\tconst writable = new WritableStream({\n\t\t\tasync write(chunk) {\n\t\t\t\tconst { availableSize } = writer;\n\t\t\t\tif (!diskWriter) {\n\t\t\t\t\tconst { value, done } = await writerGenerator.next();\n\t\t\t\t\tif (done && !value) {\n\t\t\t\t\t\tthrow new Error(ERR_ITERATOR_COMPLETED_TOO_SOON);\n\t\t\t\t\t} else {\n\t\t\t\t\t\tdiskSourceWriter = value;\n\t\t\t\t\t\tdiskSourceWriter.size = 0;\n\t\t\t\t\t\tif (diskSourceWriter.maxSize) {\n\t\t\t\t\t\t\twriter.maxSize = diskSourceWriter.maxSize;\n\t\t\t\t\t\t}\n\t\t\t\t\t\twriter.availableSize = writer.maxSize;\n\t\t\t\t\t\tawait initStream(diskSourceWriter);\n\t\t\t\t\t\tdiskWritable = value.writable;\n\t\t\t\t\t\tdiskWriter = diskWritable.getWriter();\n\t\t\t\t\t}\n\t\t\t\t\tawait this.write(chunk);\n\t\t\t\t} else if (chunk.length >= availableSize) {\n\t\t\t\t\tawait writeChunk(chunk.subarray(0, availableSize));\n\t\t\t\t\tawait closeDisk();\n\t\t\t\t\twriter.diskOffset += diskSourceWriter.size;\n\t\t\t\t\twriter.diskNumber++;\n\t\t\t\t\tdiskWriter = null;\n\t\t\t\t\tawait this.write(chunk.subarray(availableSize));\n\t\t\t\t} else {\n\t\t\t\t\tawait writeChunk(chunk);\n\t\t\t\t}\n\t\t\t},\n\t\t\tasync close() {\n\t\t\t\tawait diskWriter.ready;\n\t\t\t\tawait closeDisk();\n\t\t\t}\n\t\t});\n\t\tObject.defineProperty(writer, PROPERTY_NAME_WRITABLE, {\n\t\t\tget() {\n\t\t\t\treturn writable;\n\t\t\t}\n\t\t});\n\n\t\tasync function writeChunk(chunk) {\n\t\t\tconst chunkLength = chunk.length;\n\t\t\tif (chunkLength) {\n\t\t\t\tawait diskWriter.ready;\n\t\t\t\tawait diskWriter.write(chunk);\n\t\t\t\tdiskSourceWriter.size += chunkLength;\n\t\t\t\twriter.size += chunkLength;\n\t\t\t\twriter.availableSize -= chunkLength;\n\t\t\t}\n\t\t}\n\n\t\tasync function closeDisk() {\n\t\t\tawait diskWriter.close();\n\t\t}\n\t}\n}\n\nclass GenericReader {\n\n\tconstructor(reader) {\n\t\tif (Array.isArray(reader)) {\n\t\t\treader = new SplitDataReader(reader);\n\t\t}\n\t\tif (reader instanceof ReadableStream) {\n\t\t\treader = {\n\t\t\t\treadable: reader\n\t\t\t};\n\t\t}\n\t\treturn reader;\n\t}\n}\n\nclass GenericWriter {\n\n\tconstructor(writer) {\n\t\tif (writer.writable === UNDEFINED_VALUE && typeof writer.next == FUNCTION_TYPE) {\n\t\t\twriter = new SplitDataWriter(writer);\n\t\t}\n\t\tif (writer instanceof WritableStream) {\n\t\t\twriter = {\n\t\t\t\twritable: writer\n\t\t\t};\n\t\t}\n\t\tif (writer.size === UNDEFINED_VALUE) {\n\t\t\twriter.size = 0;\n\t\t}\n\t\tif (!(writer instanceof SplitDataWriter)) {\n\t\t\tObject.assign(writer, {\n\t\t\t\tdiskNumber: 0,\n\t\t\t\tdiskOffset: 0,\n\t\t\t\tavailableSize: INFINITY_VALUE,\n\t\t\t\tmaxSize: INFINITY_VALUE\n\t\t\t});\n\t\t}\n\t\treturn writer;\n\t}\n}\n\nfunction isHttpFamily(url) {\n\tconst { baseURI } = getConfiguration();\n\tconst { protocol } = new URL(url, baseURI);\n\treturn protocol == \"http:\" || protocol == \"https:\";\n}\n\nasync function initStream(stream, initSize) {\n\tif (stream.init && !stream.initialized) {\n\t\tawait stream.init(initSize);\n\t} else {\n\t\treturn Promise.resolve();\n\t}\n}\n\nfunction readUint8Array(reader, offset, size, diskNumber) {\n\treturn reader.readUint8Array(offset, size, diskNumber);\n}\n\nexport {\n\tinitStream,\n\tGenericReader,\n\tGenericWriter,\n\treadUint8Array,\n\tReader,\n\tWriter,\n\tTextReader,\n\tTextWriter,\n\tData64URIReader,\n\tData64URIWriter,\n\tBlobReader,\n\tBlobWriter,\n\tUint8ArrayReader,\n\tUint8ArrayWriter,\n\tHttpReader,\n\tHttpRangeReader,\n\tSplitDataReader,\n\tSplitDataWriter,\n\tERR_HTTP_RANGE,\n\tERR_ITERATOR_COMPLETED_TOO_SOON,\n\tERR_WRITER_NOT_INITIALIZED\n};","/*\n Copyright (c) 2022 Gildas Lormeau. All rights reserved.\n\n Redistribution and use in source and binary forms, with or without\n modification, are permitted provided that the following conditions are met:\n\n 1. Redistributions of source code must retain the above copyright notice,\n this list of conditions and the following disclaimer.\n\n 2. Redistributions in binary form must reproduce the above copyright \n notice, this list of conditions and the following disclaimer in \n the documentation and/or other materials provided with the distribution.\n\n 3. The names of the authors may not be used to endorse or promote products\n derived from this software without specific prior written permission.\n\n THIS SOFTWARE IS PROVIDED ''AS IS'' AND ANY EXPRESSED OR IMPLIED WARRANTIES,\n INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND\n FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL JCRAFT,\n INC. OR ANY CONTRIBUTORS TO THIS SOFTWARE BE LIABLE FOR ANY DIRECT, INDIRECT,\n INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT\n LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA,\n OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF\n LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING\n NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE,\n EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.\n */\n\n/* global TextDecoder */\n\nconst CP437 = \"\\0☺☻♥♦♣♠•◘○◙♂♀♪♫☼►◄↕‼¶§▬↨↑↓→←∟↔▲▼ !\\\"#$%&'()*+,-./0123456789:;<=>?@ABCDEFGHIJKLMNOPQRSTUVWXYZ[\\\\]^_`abcdefghijklmnopqrstuvwxyz{|}~⌂ÇüéâäàåçêëèïîìÄÅÉæÆôöòûùÿÖÜ¢£¥₧ƒáíóúñѪº¿⌐¬½¼¡«»░▒▓│┤╡╢╖╕╣║╗╝╜╛┐└┴┬├─┼╞╟╚╔╩╦╠═╬╧╨╤╥╙╘╒╓╫╪┘┌█▄▌▐▀αßΓπΣσµτΦΘΩδ∞φε∩≡±≥≤⌠⌡÷≈°∙·√ⁿ²■ \".split(\"\");\nconst VALID_CP437 = CP437.length == 256;\n\nexport {\n\tdecodeCP437\n};\n\nfunction decodeCP437(stringValue) {\n\tif (VALID_CP437) {\n\t\tlet result = \"\";\n\t\tfor (let indexCharacter = 0; indexCharacter < stringValue.length; indexCharacter++) {\n\t\t\tresult += CP437[stringValue[indexCharacter]];\n\t\t}\n\t\treturn result;\n\t} else {\n\t\treturn new TextDecoder().decode(stringValue);\n\t}\n}","/*\n Copyright (c) 2022 Gildas Lormeau. All rights reserved.\n\n Redistribution and use in source and binary forms, with or without\n modification, are permitted provided that the following conditions are met:\n\n 1. Redistributions of source code must retain the above copyright notice,\n this list of conditions and the following disclaimer.\n\n 2. Redistributions in binary form must reproduce the above copyright \n notice, this list of conditions and the following disclaimer in \n the documentation and/or other materials provided with the distribution.\n\n 3. The names of the authors may not be used to endorse or promote products\n derived from this software without specific prior written permission.\n\n THIS SOFTWARE IS PROVIDED ''AS IS'' AND ANY EXPRESSED OR IMPLIED WARRANTIES,\n INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND\n FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL JCRAFT,\n INC. OR ANY CONTRIBUTORS TO THIS SOFTWARE BE LIABLE FOR ANY DIRECT, INDIRECT,\n INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT\n LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA,\n OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF\n LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING\n NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE,\n EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.\n */\n\n/* global TextDecoder */\n\nimport { decodeCP437 } from \"./decode-cp437.js\";\n\nexport {\n\tdecodeText\n};\n\nfunction decodeText(value, encoding) {\n\tif (encoding && encoding.trim().toLowerCase() == \"cp437\") {\n\t\treturn decodeCP437(value);\n\t} else {\n\t\treturn new TextDecoder(encoding).decode(value);\n\t}\n}","/*\n Copyright (c) 2025 Gildas Lormeau. All rights reserved.\n\n Redistribution and use in source and binary forms, with or without\n modification, are permitted provided that the following conditions are met:\n\n 1. Redistributions of source code must retain the above copyright notice,\n this list of conditions and the following disclaimer.\n\n 2. Redistributions in binary form must reproduce the above copyright \n notice, this list of conditions and the following disclaimer in \n the documentation and/or other materials provided with the distribution.\n\n 3. The names of the authors may not be used to endorse or promote products\n derived from this software without specific prior written permission.\n\n THIS SOFTWARE IS PROVIDED ''AS IS'' AND ANY EXPRESSED OR IMPLIED WARRANTIES,\n INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND\n FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL JCRAFT,\n INC. OR ANY CONTRIBUTORS TO THIS SOFTWARE BE LIABLE FOR ANY DIRECT, INDIRECT,\n INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT\n LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA,\n OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF\n LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING\n NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE,\n EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.\n */\n\nconst PROPERTY_NAME_FILENAME = \"filename\";\nconst PROPERTY_NAME_RAW_FILENAME = \"rawFilename\";\nconst PROPERTY_NAME_COMMENT = \"comment\";\nconst PROPERTY_NAME_RAW_COMMENT = \"rawComment\";\nconst PROPERTY_NAME_UNCOMPRESSED_SIZE = \"uncompressedSize\";\nconst PROPERTY_NAME_COMPRESSED_SIZE = \"compressedSize\";\nconst PROPERTY_NAME_OFFSET = \"offset\";\nconst PROPERTY_NAME_DISK_NUMBER_START = \"diskNumberStart\";\nconst PROPERTY_NAME_LAST_MODIFICATION_DATE = \"lastModDate\";\nconst PROPERTY_NAME_RAW_LAST_MODIFICATION_DATE = \"rawLastModDate\";\nconst PROPERTY_NAME_LAST_ACCESS_DATE = \"lastAccessDate\";\nconst PROPERTY_NAME_RAW_LAST_ACCESS_DATE = \"rawLastAccessDate\";\nconst PROPERTY_NAME_CREATION_DATE = \"creationDate\";\nconst PROPERTY_NAME_RAW_CREATION_DATE = \"rawCreationDate\";\nconst PROPERTY_NAME_INTERNAL_FILE_ATTRIBUTES = \"internalFileAttributes\";\nconst PROPERTY_NAME_EXTERNAL_FILE_ATTRIBUTES = \"externalFileAttributes\";\nconst PROPERTY_NAME_MSDOS_ATTRIBUTES_RAW = \"msdosAttributesRaw\";\nconst PROPERTY_NAME_MSDOS_ATTRIBUTES = \"msdosAttributes\";\nconst PROPERTY_NAME_MS_DOS_COMPATIBLE = \"msDosCompatible\";\nconst PROPERTY_NAME_ZIP64 = \"zip64\";\nconst PROPERTY_NAME_ENCRYPTED = \"encrypted\";\nconst PROPERTY_NAME_VERSION = \"version\";\nconst PROPERTY_NAME_VERSION_MADE_BY = \"versionMadeBy\";\nconst PROPERTY_NAME_ZIPCRYPTO = \"zipCrypto\";\nconst PROPERTY_NAME_DIRECTORY = \"directory\";\nconst PROPERTY_NAME_EXECUTABLE = \"executable\";\nconst PROPERTY_NAME_COMPRESSION_METHOD = \"compressionMethod\";\nconst PROPERTY_NAME_SIGNATURE = \"signature\";\nconst PROPERTY_NAME_EXTRA_FIELD = \"extraField\";\nconst PROPERTY_NAME_EXTRA_FIELD_INFOZIP = \"extraFieldInfoZip\";\nconst PROPERTY_NAME_EXTRA_FIELD_UNIX = \"extraFieldUnix\";\nconst PROPERTY_NAME_UID = \"uid\";\nconst PROPERTY_NAME_GID = \"gid\";\nconst PROPERTY_NAME_UNIX_MODE = \"unixMode\";\nconst PROPERTY_NAME_SETUID = \"setuid\";\nconst PROPERTY_NAME_SETGID = \"setgid\";\nconst PROPERTY_NAME_STICKY = \"sticky\";\nconst PROPERTY_NAME_BITFLAG = \"bitFlag\";\nconst PROPERTY_NAME_FILENAME_UTF8 = \"filenameUTF8\";\nconst PROPERTY_NAME_COMMENT_UTF8 = \"commentUTF8\";\nconst PROPERTY_NAME_RAW_EXTRA_FIELD = \"rawExtraField\";\nconst PROPERTY_NAME_EXTRA_FIELD_ZIP64 = \"extraFieldZip64\";\nconst PROPERTY_NAME_EXTRA_FIELD_UNICODE_PATH = \"extraFieldUnicodePath\";\nconst PROPERTY_NAME_EXTRA_FIELD_UNICODE_COMMENT = \"extraFieldUnicodeComment\";\nconst PROPERTY_NAME_EXTRA_FIELD_AES = \"extraFieldAES\";\nconst PROPERTY_NAME_EXTRA_FIELD_NTFS = \"extraFieldNTFS\";\nconst PROPERTY_NAME_EXTRA_FIELD_EXTENDED_TIMESTAMP = \"extraFieldExtendedTimestamp\";\n\nconst PROPERTY_NAMES = [\n\tPROPERTY_NAME_FILENAME,\n\tPROPERTY_NAME_RAW_FILENAME,\n\tPROPERTY_NAME_UNCOMPRESSED_SIZE,\n\tPROPERTY_NAME_COMPRESSED_SIZE,\n\tPROPERTY_NAME_LAST_MODIFICATION_DATE,\n\tPROPERTY_NAME_RAW_LAST_MODIFICATION_DATE,\n\tPROPERTY_NAME_COMMENT,\n\tPROPERTY_NAME_RAW_COMMENT,\n\tPROPERTY_NAME_LAST_ACCESS_DATE,\n\tPROPERTY_NAME_CREATION_DATE,\n\tPROPERTY_NAME_RAW_CREATION_DATE,\n\tPROPERTY_NAME_OFFSET,\n\tPROPERTY_NAME_DISK_NUMBER_START,\n\tPROPERTY_NAME_INTERNAL_FILE_ATTRIBUTES,\n\tPROPERTY_NAME_EXTERNAL_FILE_ATTRIBUTES,\n\tPROPERTY_NAME_MSDOS_ATTRIBUTES_RAW,\n\tPROPERTY_NAME_MSDOS_ATTRIBUTES,\n\tPROPERTY_NAME_MS_DOS_COMPATIBLE,\n\tPROPERTY_NAME_ZIP64,\n\tPROPERTY_NAME_ENCRYPTED,\n\tPROPERTY_NAME_VERSION,\n\tPROPERTY_NAME_VERSION_MADE_BY,\n\tPROPERTY_NAME_ZIPCRYPTO,\n\tPROPERTY_NAME_DIRECTORY,\n\tPROPERTY_NAME_EXECUTABLE,\n\tPROPERTY_NAME_COMPRESSION_METHOD,\n\tPROPERTY_NAME_SIGNATURE,\n\tPROPERTY_NAME_EXTRA_FIELD,\n\tPROPERTY_NAME_EXTRA_FIELD_UNIX,\n\tPROPERTY_NAME_EXTRA_FIELD_INFOZIP,\n\tPROPERTY_NAME_UID,\n\tPROPERTY_NAME_GID,\n\tPROPERTY_NAME_UNIX_MODE,\n\tPROPERTY_NAME_SETUID,\n\tPROPERTY_NAME_SETGID,\n\tPROPERTY_NAME_STICKY,\n\tPROPERTY_NAME_BITFLAG,\n\tPROPERTY_NAME_FILENAME_UTF8,\n\tPROPERTY_NAME_COMMENT_UTF8,\n\tPROPERTY_NAME_RAW_EXTRA_FIELD,\n\tPROPERTY_NAME_EXTRA_FIELD_ZIP64,\n\tPROPERTY_NAME_EXTRA_FIELD_UNICODE_PATH,\n\tPROPERTY_NAME_EXTRA_FIELD_UNICODE_COMMENT,\n\tPROPERTY_NAME_EXTRA_FIELD_AES,\n\tPROPERTY_NAME_EXTRA_FIELD_NTFS,\n\tPROPERTY_NAME_EXTRA_FIELD_EXTENDED_TIMESTAMP\n];\n\nclass Entry {\n\n\tconstructor(data) {\n\t\tPROPERTY_NAMES.forEach(name => this[name] = data[name]);\n\t}\n\n}\n\nexport {\n\tPROPERTY_NAME_FILENAME,\n\tPROPERTY_NAME_RAW_FILENAME,\n\tPROPERTY_NAME_COMMENT,\n\tPROPERTY_NAME_RAW_COMMENT,\n\tPROPERTY_NAME_UNCOMPRESSED_SIZE,\n\tPROPERTY_NAME_COMPRESSED_SIZE,\n\tPROPERTY_NAME_OFFSET,\n\tPROPERTY_NAME_DISK_NUMBER_START,\n\tPROPERTY_NAME_LAST_MODIFICATION_DATE,\n\tPROPERTY_NAME_RAW_LAST_MODIFICATION_DATE,\n\tPROPERTY_NAME_LAST_ACCESS_DATE,\n\tPROPERTY_NAME_RAW_LAST_ACCESS_DATE,\n\tPROPERTY_NAME_CREATION_DATE,\n\tPROPERTY_NAME_RAW_CREATION_DATE,\n\tPROPERTY_NAME_INTERNAL_FILE_ATTRIBUTES,\n\tPROPERTY_NAME_EXTERNAL_FILE_ATTRIBUTES,\n\tPROPERTY_NAME_MSDOS_ATTRIBUTES_RAW,\n\tPROPERTY_NAME_MSDOS_ATTRIBUTES,\n\tPROPERTY_NAME_MS_DOS_COMPATIBLE,\n\tPROPERTY_NAME_ZIP64,\n\tPROPERTY_NAME_ENCRYPTED,\n\tPROPERTY_NAME_VERSION,\n\tPROPERTY_NAME_VERSION_MADE_BY,\n\tPROPERTY_NAME_ZIPCRYPTO,\n\tPROPERTY_NAME_DIRECTORY,\n\tPROPERTY_NAME_EXECUTABLE,\n\tPROPERTY_NAME_COMPRESSION_METHOD,\n\tPROPERTY_NAME_SIGNATURE,\n\tPROPERTY_NAME_EXTRA_FIELD,\n\tPROPERTY_NAME_GID,\n\tPROPERTY_NAME_UID,\n\tPROPERTY_NAME_UNIX_MODE,\n\tPROPERTY_NAME_SETUID,\n\tPROPERTY_NAME_SETGID,\n\tPROPERTY_NAME_STICKY,\n\tEntry\n};","/*\n Copyright (c) 2022 Gildas Lormeau. All rights reserved.\n\n Redistribution and use in source and binary forms, with or without\n modification, are permitted provided that the following conditions are met:\n\n 1. Redistributions of source code must retain the above copyright notice,\n this list of conditions and the following disclaimer.\n\n 2. Redistributions in binary form must reproduce the above copyright \n notice, this list of conditions and the following disclaimer in \n the documentation and/or other materials provided with the distribution.\n\n 3. The names of the authors may not be used to endorse or promote products\n derived from this software without specific prior written permission.\n\n THIS SOFTWARE IS PROVIDED ''AS IS'' AND ANY EXPRESSED OR IMPLIED WARRANTIES,\n INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND\n FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL JCRAFT,\n INC. OR ANY CONTRIBUTORS TO THIS SOFTWARE BE LIABLE FOR ANY DIRECT, INDIRECT,\n INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT\n LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA,\n OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF\n LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING\n NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE,\n EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.\n */\n\nconst OPTION_FILENAME_ENCODING = \"filenameEncoding\";\nconst OPTION_COMMENT_ENCODING = \"commentEncoding\";\nconst OPTION_DECODE_TEXT = \"decodeText\";\nconst OPTION_EXTRACT_PREPENDED_DATA = \"extractPrependedData\";\nconst OPTION_EXTRACT_APPENDED_DATA = \"extractAppendedData\";\nconst OPTION_PASSWORD = \"password\";\nconst OPTION_RAW_PASSWORD = \"rawPassword\";\nconst OPTION_PASS_THROUGH = \"passThrough\";\nconst OPTION_SIGNAL = \"signal\";\nconst OPTION_CHECK_PASSWORD_ONLY = \"checkPasswordOnly\";\nconst OPTION_CHECK_OVERLAPPING_ENTRY_ONLY = \"checkOverlappingEntryOnly\";\nconst OPTION_CHECK_OVERLAPPING_ENTRY = \"checkOverlappingEntry\";\nconst OPTION_CHECK_SIGNATURE = \"checkSignature\";\nconst OPTION_USE_WEB_WORKERS = \"useWebWorkers\";\nconst OPTION_USE_COMPRESSION_STREAM = \"useCompressionStream\";\nconst OPTION_TRANSFER_STREAMS = \"transferStreams\";\nconst OPTION_PREVENT_CLOSE = \"preventClose\";\nconst OPTION_ENCRYPTION_STRENGTH = \"encryptionStrength\";\nconst OPTION_EXTENDED_TIMESTAMP = \"extendedTimestamp\";\nconst OPTION_KEEP_ORDER = \"keepOrder\";\nconst OPTION_LEVEL = \"level\";\nconst OPTION_BUFFERED_WRITE = \"bufferedWrite\";\nconst OPTION_CREATE_TEMP_STREAM = \"createTempStream\";\nconst OPTION_DATA_DESCRIPTOR_SIGNATURE = \"dataDescriptorSignature\";\nconst OPTION_USE_UNICODE_FILE_NAMES = \"useUnicodeFileNames\";\nconst OPTION_DATA_DESCRIPTOR = \"dataDescriptor\";\nconst OPTION_SUPPORT_ZIP64_SPLIT_FILE = \"supportZip64SplitFile\";\nconst OPTION_ENCODE_TEXT = \"encodeText\";\nconst OPTION_OFFSET = \"offset\";\nconst OPTION_USDZ = \"usdz\";\nconst OPTION_UNIX_EXTRA_FIELD_TYPE = \"unixExtraFieldType\";\n\nexport {\n\tOPTION_FILENAME_ENCODING,\n\tOPTION_COMMENT_ENCODING,\n\tOPTION_DECODE_TEXT,\n\tOPTION_EXTRACT_PREPENDED_DATA,\n\tOPTION_EXTRACT_APPENDED_DATA,\n\tOPTION_PASSWORD,\n\tOPTION_RAW_PASSWORD,\n\tOPTION_PASS_THROUGH,\n\tOPTION_SIGNAL,\n\tOPTION_CHECK_PASSWORD_ONLY,\n\tOPTION_CHECK_OVERLAPPING_ENTRY_ONLY,\n\tOPTION_CHECK_OVERLAPPING_ENTRY,\n\tOPTION_CHECK_SIGNATURE,\n\tOPTION_USE_WEB_WORKERS,\n\tOPTION_USE_COMPRESSION_STREAM,\n\tOPTION_TRANSFER_STREAMS,\n\tOPTION_PREVENT_CLOSE,\n\tOPTION_ENCRYPTION_STRENGTH,\n\tOPTION_EXTENDED_TIMESTAMP,\n\tOPTION_KEEP_ORDER,\n\tOPTION_LEVEL,\n\tOPTION_BUFFERED_WRITE,\n\tOPTION_CREATE_TEMP_STREAM,\n\tOPTION_DATA_DESCRIPTOR_SIGNATURE,\n\tOPTION_USE_UNICODE_FILE_NAMES,\n\tOPTION_DATA_DESCRIPTOR,\n\tOPTION_SUPPORT_ZIP64_SPLIT_FILE,\n\tOPTION_ENCODE_TEXT,\n\tOPTION_OFFSET,\n\tOPTION_USDZ,\n\tOPTION_UNIX_EXTRA_FIELD_TYPE\n};","/*\n Copyright (c) 2025 Gildas Lormeau. All rights reserved.\n\n Redistribution and use in source and binary forms, with or without\n modification, are permitted provided that the following conditions are met:\n\n 1. Redistributions of source code must retain the above copyright notice,\n this list of conditions and the following disclaimer.\n\n 2. Redistributions in binary form must reproduce the above copyright\n notice, this list of conditions and the following disclaimer in\n the documentation and/or other materials provided with the distribution.\n\n 3. The names of the authors may not be used to endorse or promote products\n derived from this software without specific prior written permission.\n\n THIS SOFTWARE IS PROVIDED ''AS IS'' AND ANY EXPRESSED OR IMPLIED WARRANTIES,\n INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND\n FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL JCRAFT,\n INC. OR ANY CONTRIBUTORS TO THIS SOFTWARE BE LIABLE FOR ANY DIRECT, INDIRECT,\n INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT\n LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA,\n OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF\n LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING\n NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE,\n EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.\n */\n\n/* global Response, WritableStream, ReadableStream, TransformStream */\n// deno-lint-ignore-file no-this-alias\n\nimport {\n\tMAX_32_BITS,\n\tMAX_16_BITS,\n\tMAX_8_BITS,\n\tCOMPRESSION_METHOD_DEFLATE,\n\tCOMPRESSION_METHOD_STORE,\n\tCOMPRESSION_METHOD_AES,\n\tSPLIT_ZIP_FILE_SIGNATURE,\n\tDATA_DESCRIPTOR_RECORD_SIGNATURE,\n\tDATA_DESCRIPTOR_RECORD_LENGTH,\n\tDATA_DESCRIPTOR_RECORD_ZIP_64_LENGTH,\n\tDATA_DESCRIPTOR_RECORD_SIGNATURE_LENGTH,\n\tLOCAL_FILE_HEADER_SIGNATURE,\n\tCENTRAL_FILE_HEADER_SIGNATURE,\n\tEND_OF_CENTRAL_DIR_SIGNATURE,\n\tZIP64_END_OF_CENTRAL_DIR_LOCATOR_SIGNATURE,\n\tZIP64_END_OF_CENTRAL_DIR_SIGNATURE,\n\tEXTRAFIELD_TYPE_ZIP64,\n\tEXTRAFIELD_TYPE_UNICODE_PATH,\n\tEXTRAFIELD_TYPE_UNICODE_COMMENT,\n\tEXTRAFIELD_TYPE_AES,\n\tEXTRAFIELD_TYPE_NTFS,\n\tEXTRAFIELD_TYPE_NTFS_TAG1,\n\tEXTRAFIELD_TYPE_EXTENDED_TIMESTAMP,\n\tEXTRAFIELD_TYPE_INFOZIP,\n\tEXTRAFIELD_TYPE_UNIX,\n\tEXTRAFIELD_TYPE_USDZ,\n\tEND_OF_CENTRAL_DIR_LENGTH,\n\tZIP64_END_OF_CENTRAL_DIR_LOCATOR_LENGTH,\n\tZIP64_END_OF_CENTRAL_DIR_LENGTH,\n\tBITFLAG_ENCRYPTED,\n\tBITFLAG_LEVEL,\n\tBITFLAG_DATA_DESCRIPTOR,\n\tBITFLAG_LANG_ENCODING_FLAG,\n\tFILE_ATTR_MSDOS_DIR_MASK,\n\tFILE_ATTR_MSDOS_READONLY_MASK,\n\tFILE_ATTR_MSDOS_HIDDEN_MASK,\n\tFILE_ATTR_MSDOS_SYSTEM_MASK,\n\tFILE_ATTR_MSDOS_ARCHIVE_MASK,\n\tFILE_ATTR_UNIX_TYPE_MASK,\n\tFILE_ATTR_UNIX_TYPE_DIR,\n\tFILE_ATTR_UNIX_EXECUTABLE_MASK,\n\tFILE_ATTR_UNIX_DEFAULT_MASK,\n\tDIRECTORY_SIGNATURE,\n\tHEADER_SIZE,\n\tHEADER_OFFSET_SIGNATURE,\n\tHEADER_OFFSET_COMPRESSED_SIZE,\n\tHEADER_OFFSET_UNCOMPRESSED_SIZE,\n\tUNDEFINED_VALUE,\n\tCOMPRESSION_METHOD_DEFLATE_64,\n\tFILE_ATTR_UNIX_SETUID_MASK,\n\tFILE_ATTR_UNIX_SETGID_MASK,\n\tFILE_ATTR_UNIX_STICKY_MASK\n} from \"./constants.js\";\nimport {\n\tgetConfiguration,\n\tgetChunkSize\n} from \"./configuration.js\";\nimport {\n\trunWorker,\n\tCODEC_INFLATE,\n\tERR_INVALID_SIGNATURE,\n\tERR_INVALID_PASSWORD,\n\tERR_INVALID_UNCOMPRESSED_SIZE,\n\tERR_ABORT_CHECK_PASSWORD\n} from \"./codec-pool.js\";\nimport {\n\tinitStream,\n\treadUint8Array,\n\tBlobReader,\n\tGenericReader,\n\tGenericWriter\n} from \"./io.js\";\nimport { decodeText } from \"./util/decode-text.js\";\nimport { Crc32 } from \"./streams/codecs/crc32.js\";\nimport {\n\tPROPERTY_NAME_RAW_FILENAME,\n\tPROPERTY_NAME_FILENAME,\n\tPROPERTY_NAME_RAW_COMMENT,\n\tPROPERTY_NAME_COMMENT,\n\tPROPERTY_NAME_UNCOMPRESSED_SIZE,\n\tPROPERTY_NAME_COMPRESSED_SIZE,\n\tPROPERTY_NAME_OFFSET,\n\tPROPERTY_NAME_DISK_NUMBER_START,\n\tPROPERTY_NAME_LAST_MODIFICATION_DATE,\n\tPROPERTY_NAME_RAW_LAST_MODIFICATION_DATE,\n\tPROPERTY_NAME_LAST_ACCESS_DATE,\n\tPROPERTY_NAME_RAW_LAST_ACCESS_DATE,\n\tPROPERTY_NAME_CREATION_DATE,\n\tPROPERTY_NAME_RAW_CREATION_DATE,\n\tEntry\n} from \"./zip-entry.js\";\nimport {\n\tOPTION_FILENAME_ENCODING,\n\tOPTION_COMMENT_ENCODING,\n\tOPTION_DECODE_TEXT,\n\tOPTION_EXTRACT_PREPENDED_DATA,\n\tOPTION_EXTRACT_APPENDED_DATA,\n\tOPTION_PASSWORD,\n\tOPTION_RAW_PASSWORD,\n\tOPTION_PASS_THROUGH,\n\tOPTION_SIGNAL,\n\tOPTION_CHECK_PASSWORD_ONLY,\n\tOPTION_CHECK_OVERLAPPING_ENTRY_ONLY,\n\tOPTION_CHECK_OVERLAPPING_ENTRY,\n\tOPTION_CHECK_SIGNATURE,\n\tOPTION_USE_WEB_WORKERS,\n\tOPTION_USE_COMPRESSION_STREAM,\n\tOPTION_TRANSFER_STREAMS,\n\tOPTION_PREVENT_CLOSE\n} from \"./options.js\";\n\nconst ERR_BAD_FORMAT = \"File format is not recognized\";\nconst ERR_EOCDR_NOT_FOUND = \"End of central directory not found\";\nconst ERR_EOCDR_LOCATOR_ZIP64_NOT_FOUND = \"End of Zip64 central directory locator not found\";\nconst ERR_CENTRAL_DIRECTORY_NOT_FOUND = \"Central directory header not found\";\nconst ERR_LOCAL_FILE_HEADER_NOT_FOUND = \"Local file header not found\";\nconst ERR_EXTRAFIELD_ZIP64_NOT_FOUND = \"Zip64 extra field not found\";\nconst ERR_ENCRYPTED = \"File contains encrypted entry\";\nconst ERR_UNSUPPORTED_ENCRYPTION = \"Encryption method not supported\";\nconst ERR_UNSUPPORTED_COMPRESSION = \"Compression method not supported\";\nconst ERR_SPLIT_ZIP_FILE = \"Split zip file\";\nconst ERR_OVERLAPPING_ENTRY = \"Overlapping entry found\";\nconst CHARSET_UTF8 = \"utf-8\";\nconst PROPERTY_NAME_UTF8_SUFFIX = \"UTF8\";\nconst CHARSET_CP437 = \"cp437\";\nconst ZIP64_PROPERTIES = [\n\t[PROPERTY_NAME_UNCOMPRESSED_SIZE, MAX_32_BITS],\n\t[PROPERTY_NAME_COMPRESSED_SIZE, MAX_32_BITS],\n\t[PROPERTY_NAME_OFFSET, MAX_32_BITS],\n\t[PROPERTY_NAME_DISK_NUMBER_START, MAX_16_BITS]\n];\nconst ZIP64_EXTRACTION = {\n\t[MAX_16_BITS]: {\n\t\tgetValue: getUint32,\n\t\tbytes: 4\n\t},\n\t[MAX_32_BITS]: {\n\t\tgetValue: getBigUint64,\n\t\tbytes: 8\n\t}\n};\n\nclass ZipReader {\n\n\tconstructor(reader, options = {}) {\n\t\tObject.assign(this, {\n\t\t\treader: new GenericReader(reader),\n\t\t\toptions,\n\t\t\tconfig: getConfiguration(),\n\t\t\treadRanges: []\n\t\t});\n\t}\n\n\tasync* getEntriesGenerator(options = {}) {\n\t\tconst zipReader = this;\n\t\tlet { reader } = zipReader;\n\t\tconst { config } = zipReader;\n\t\tawait initStream(reader);\n\t\tif (reader.size === UNDEFINED_VALUE || !reader.readUint8Array) {\n\t\t\treader = new BlobReader(await new Response(reader.readable).blob());\n\t\t\tawait initStream(reader);\n\t\t}\n\t\tif (reader.size < END_OF_CENTRAL_DIR_LENGTH) {\n\t\t\tthrow new Error(ERR_BAD_FORMAT);\n\t\t}\n\t\treader.chunkSize = getChunkSize(config);\n\t\tconst endOfDirectoryInfo = await seekSignature(reader, END_OF_CENTRAL_DIR_SIGNATURE, reader.size, END_OF_CENTRAL_DIR_LENGTH, MAX_16_BITS * 16);\n\t\tif (!endOfDirectoryInfo) {\n\t\t\tconst signatureArray = await readUint8Array(reader, 0, 4);\n\t\t\tconst signatureView = getDataView(signatureArray);\n\t\t\tif (getUint32(signatureView) == SPLIT_ZIP_FILE_SIGNATURE) {\n\t\t\t\tthrow new Error(ERR_SPLIT_ZIP_FILE);\n\t\t\t} else {\n\t\t\t\tthrow new Error(ERR_EOCDR_NOT_FOUND);\n\t\t\t}\n\t\t}\n\t\tconst endOfDirectoryView = getDataView(endOfDirectoryInfo);\n\t\tlet directoryDataLength = getUint32(endOfDirectoryView, 12);\n\t\tlet directoryDataOffset = getUint32(endOfDirectoryView, 16);\n\t\tconst commentOffset = endOfDirectoryInfo.offset;\n\t\tconst commentLength = getUint16(endOfDirectoryView, 20);\n\t\tconst appendedDataOffset = commentOffset + END_OF_CENTRAL_DIR_LENGTH + commentLength;\n\t\tlet lastDiskNumber = getUint16(endOfDirectoryView, 4);\n\t\tconst expectedLastDiskNumber = reader.lastDiskNumber || 0;\n\t\tlet diskNumber = getUint16(endOfDirectoryView, 6);\n\t\tlet filesLength = getUint16(endOfDirectoryView, 8);\n\t\tlet prependedDataLength = 0;\n\t\tlet startOffset = 0;\n\t\tif (directoryDataOffset == MAX_32_BITS || directoryDataLength == MAX_32_BITS || filesLength == MAX_16_BITS || diskNumber == MAX_16_BITS) {\n\t\t\tconst endOfDirectoryLocatorArray = await readUint8Array(reader, endOfDirectoryInfo.offset - ZIP64_END_OF_CENTRAL_DIR_LOCATOR_LENGTH, ZIP64_END_OF_CENTRAL_DIR_LOCATOR_LENGTH);\n\t\t\tconst endOfDirectoryLocatorView = getDataView(endOfDirectoryLocatorArray);\n\t\t\tif (getUint32(endOfDirectoryLocatorView, 0) == ZIP64_END_OF_CENTRAL_DIR_LOCATOR_SIGNATURE) {\n\t\t\t\tdirectoryDataOffset = getBigUint64(endOfDirectoryLocatorView, 8);\n\t\t\t\tlet endOfDirectoryArray = await readUint8Array(reader, directoryDataOffset, ZIP64_END_OF_CENTRAL_DIR_LENGTH, -1);\n\t\t\t\tlet endOfDirectoryView = getDataView(endOfDirectoryArray);\n\t\t\t\tconst expectedDirectoryDataOffset = endOfDirectoryInfo.offset - ZIP64_END_OF_CENTRAL_DIR_LOCATOR_LENGTH - ZIP64_END_OF_CENTRAL_DIR_LENGTH;\n\t\t\t\tif (getUint32(endOfDirectoryView, 0) != ZIP64_END_OF_CENTRAL_DIR_SIGNATURE && directoryDataOffset != expectedDirectoryDataOffset) {\n\t\t\t\t\tconst originalDirectoryDataOffset = directoryDataOffset;\n\t\t\t\t\tdirectoryDataOffset = expectedDirectoryDataOffset;\n\t\t\t\t\tif (directoryDataOffset > originalDirectoryDataOffset) {\n\t\t\t\t\t\tprependedDataLength = directoryDataOffset - originalDirectoryDataOffset;\n\t\t\t\t\t}\n\t\t\t\t\tendOfDirectoryArray = await readUint8Array(reader, directoryDataOffset, ZIP64_END_OF_CENTRAL_DIR_LENGTH, -1);\n\t\t\t\t\tendOfDirectoryView = getDataView(endOfDirectoryArray);\n\t\t\t\t}\n\t\t\t\tif (getUint32(endOfDirectoryView, 0) != ZIP64_END_OF_CENTRAL_DIR_SIGNATURE) {\n\t\t\t\t\tthrow new Error(ERR_EOCDR_LOCATOR_ZIP64_NOT_FOUND);\n\t\t\t\t}\n\t\t\t\tif (lastDiskNumber == MAX_16_BITS) {\n\t\t\t\t\tlastDiskNumber = getUint32(endOfDirectoryView, 16);\n\t\t\t\t}\n\t\t\t\tif (diskNumber == MAX_16_BITS) {\n\t\t\t\t\tdiskNumber = getUint32(endOfDirectoryView, 20);\n\t\t\t\t}\n\t\t\t\tif (filesLength == MAX_16_BITS) {\n\t\t\t\t\tfilesLength = getBigUint64(endOfDirectoryView, 32);\n\t\t\t\t}\n\t\t\t\tif (directoryDataLength == MAX_32_BITS) {\n\t\t\t\t\tdirectoryDataLength = getBigUint64(endOfDirectoryView, 40);\n\t\t\t\t}\n\t\t\t\tdirectoryDataOffset -= directoryDataLength;\n\t\t\t}\n\t\t}\n\t\tif (directoryDataOffset >= reader.size) {\n\t\t\tprependedDataLength = reader.size - directoryDataOffset - directoryDataLength - END_OF_CENTRAL_DIR_LENGTH;\n\t\t\tdirectoryDataOffset = reader.size - directoryDataLength - END_OF_CENTRAL_DIR_LENGTH;\n\t\t}\n\t\tif (expectedLastDiskNumber != lastDiskNumber) {\n\t\t\tthrow new Error(ERR_SPLIT_ZIP_FILE);\n\t\t}\n\t\tif (directoryDataOffset < 0) {\n\t\t\tthrow new Error(ERR_BAD_FORMAT);\n\t\t}\n\t\tlet offset = 0;\n\t\tlet directoryArray = await readUint8Array(reader, directoryDataOffset, directoryDataLength, diskNumber);\n\t\tlet directoryView = getDataView(directoryArray);\n\t\tif (directoryDataLength) {\n\t\t\tconst expectedDirectoryDataOffset = endOfDirectoryInfo.offset - directoryDataLength;\n\t\t\tif (getUint32(directoryView, offset) != CENTRAL_FILE_HEADER_SIGNATURE && directoryDataOffset != expectedDirectoryDataOffset) {\n\t\t\t\tconst originalDirectoryDataOffset = directoryDataOffset;\n\t\t\t\tdirectoryDataOffset = expectedDirectoryDataOffset;\n\t\t\t\tif (directoryDataOffset > originalDirectoryDataOffset) {\n\t\t\t\t\tprependedDataLength += directoryDataOffset - originalDirectoryDataOffset;\n\t\t\t\t}\n\t\t\t\tdirectoryArray = await readUint8Array(reader, directoryDataOffset, directoryDataLength, diskNumber);\n\t\t\t\tdirectoryView = getDataView(directoryArray);\n\t\t\t}\n\t\t}\n\t\tconst expectedDirectoryDataLength = endOfDirectoryInfo.offset - directoryDataOffset - (reader.lastDiskOffset || 0);\n\t\tif (directoryDataLength != expectedDirectoryDataLength && expectedDirectoryDataLength >= 0) {\n\t\t\tdirectoryDataLength = expectedDirectoryDataLength;\n\t\t\tdirectoryArray = await readUint8Array(reader, directoryDataOffset, directoryDataLength, diskNumber);\n\t\t\tdirectoryView = getDataView(directoryArray);\n\t\t}\n\t\tif (directoryDataOffset < 0 || directoryDataOffset >= reader.size) {\n\t\t\tthrow new Error(ERR_BAD_FORMAT);\n\t\t}\n\t\tconst filenameEncoding = getOptionValue(zipReader, options, OPTION_FILENAME_ENCODING);\n\t\tconst commentEncoding = getOptionValue(zipReader, options, OPTION_COMMENT_ENCODING);\n\t\tfor (let indexFile = 0; indexFile < filesLength; indexFile++) {\n\t\t\tconst fileEntry = new ZipEntry(reader, config, zipReader.options);\n\t\t\tif (getUint32(directoryView, offset) != CENTRAL_FILE_HEADER_SIGNATURE) {\n\t\t\t\tthrow new Error(ERR_CENTRAL_DIRECTORY_NOT_FOUND);\n\t\t\t}\n\t\t\treadCommonHeader(fileEntry, directoryView, offset + 6);\n\t\t\tconst languageEncodingFlag = Boolean(fileEntry.bitFlag.languageEncodingFlag);\n\t\t\tconst filenameOffset = offset + 46;\n\t\t\tconst extraFieldOffset = filenameOffset + fileEntry.filenameLength;\n\t\t\tconst commentOffset = extraFieldOffset + fileEntry.extraFieldLength;\n\t\t\tconst versionMadeBy = getUint16(directoryView, offset + 4);\n\t\t\tconst msDosCompatible = versionMadeBy >> 8 == 0;\n\t\t\tconst unixCompatible = versionMadeBy >> 8 == 3;\n\t\t\tconst rawFilename = directoryArray.subarray(filenameOffset, extraFieldOffset);\n\t\t\tconst commentLength = getUint16(directoryView, offset + 32);\n\t\t\tconst endOffset = commentOffset + commentLength;\n\t\t\tconst rawComment = directoryArray.subarray(commentOffset, endOffset);\n\t\t\tconst filenameUTF8 = languageEncodingFlag;\n\t\t\tconst commentUTF8 = languageEncodingFlag;\n\t\t\tconst externalFileAttributes = getUint32(directoryView, offset + 38);\n\t\t\tconst msdosAttributesRaw = externalFileAttributes & MAX_8_BITS;\n\t\t\tconst msdosAttributes = {\n\t\t\t\treadOnly: Boolean(msdosAttributesRaw & FILE_ATTR_MSDOS_READONLY_MASK),\n\t\t\t\thidden: Boolean(msdosAttributesRaw & FILE_ATTR_MSDOS_HIDDEN_MASK),\n\t\t\t\tsystem: Boolean(msdosAttributesRaw & FILE_ATTR_MSDOS_SYSTEM_MASK),\n\t\t\t\tdirectory: Boolean(msdosAttributesRaw & FILE_ATTR_MSDOS_DIR_MASK),\n\t\t\t\tarchive: Boolean(msdosAttributesRaw & FILE_ATTR_MSDOS_ARCHIVE_MASK)\n\t\t\t};\n\t\t\tconst offsetFileEntry = getUint32(directoryView, offset + 42) + prependedDataLength;\n\t\t\tconst decode = getOptionValue(zipReader, options, OPTION_DECODE_TEXT) || decodeText;\n\t\t\tconst rawFilenameEncoding = filenameUTF8 ? CHARSET_UTF8 : filenameEncoding || CHARSET_CP437;\n\t\t\tconst rawCommentEncoding = commentUTF8 ? CHARSET_UTF8 : commentEncoding || CHARSET_CP437;\n\t\t\tlet filename = decode(rawFilename, rawFilenameEncoding);\n\t\t\tif (filename === UNDEFINED_VALUE) {\n\t\t\t\tfilename = decodeText(rawFilename, rawFilenameEncoding);\n\t\t\t}\n\t\t\tlet comment = decode(rawComment, rawCommentEncoding);\n\t\t\tif (comment === UNDEFINED_VALUE) {\n\t\t\t\tcomment = decodeText(rawComment, rawCommentEncoding);\n\t\t\t}\n\t\t\tObject.assign(fileEntry, {\n\t\t\t\tversionMadeBy,\n\t\t\t\tmsDosCompatible,\n\t\t\t\tcompressedSize: 0,\n\t\t\t\tuncompressedSize: 0,\n\t\t\t\tcommentLength,\n\t\t\t\toffset: offsetFileEntry,\n\t\t\t\tdiskNumberStart: getUint16(directoryView, offset + 34),\n\t\t\t\tinternalFileAttributes: getUint16(directoryView, offset + 36),\n\t\t\t\texternalFileAttributes,\n\t\t\t\tmsdosAttributesRaw,\n\t\t\t\tmsdosAttributes,\n\t\t\t\trawFilename,\n\t\t\t\tfilenameUTF8,\n\t\t\t\tcommentUTF8,\n\t\t\t\trawExtraField: directoryArray.subarray(extraFieldOffset, commentOffset),\n\t\t\t\trawComment,\n\t\t\t\tfilename,\n\t\t\t\tcomment\n\t\t\t});\n\t\t\tstartOffset = Math.max(offsetFileEntry, startOffset);\n\t\t\treadCommonFooter(fileEntry, fileEntry, directoryView, offset + 6);\n\t\t\tconst unixExternalUpper = (fileEntry.externalFileAttributes >> 16) & MAX_16_BITS;\n\t\t\tif (fileEntry.unixMode === UNDEFINED_VALUE && (unixExternalUpper & (FILE_ATTR_UNIX_DEFAULT_MASK | FILE_ATTR_UNIX_EXECUTABLE_MASK | FILE_ATTR_UNIX_TYPE_DIR)) != 0) {\n\t\t\t\tfileEntry.unixMode = unixExternalUpper;\n\t\t\t}\n\t\t\tconst setuid = Boolean(fileEntry.unixMode & FILE_ATTR_UNIX_SETUID_MASK);\n\t\t\tconst setgid = Boolean(fileEntry.unixMode & FILE_ATTR_UNIX_SETGID_MASK);\n\t\t\tconst sticky = Boolean(fileEntry.unixMode & FILE_ATTR_UNIX_STICKY_MASK);\n\t\t\tconst executable = (fileEntry.unixMode !== UNDEFINED_VALUE)\n\t\t\t\t? ((fileEntry.unixMode & FILE_ATTR_UNIX_EXECUTABLE_MASK) != 0)\n\t\t\t\t: (unixCompatible && ((unixExternalUpper & FILE_ATTR_UNIX_EXECUTABLE_MASK) != 0));\n\t\t\tconst modeIsDir = fileEntry.unixMode !== UNDEFINED_VALUE && ((fileEntry.unixMode & FILE_ATTR_UNIX_TYPE_MASK) == FILE_ATTR_UNIX_TYPE_DIR);\n\t\t\tconst upperIsDir = ((unixExternalUpper & FILE_ATTR_UNIX_TYPE_MASK) == FILE_ATTR_UNIX_TYPE_DIR);\n\t\t\tObject.assign(fileEntry, {\n\t\t\t\tsetuid,\n\t\t\t\tsetgid,\n\t\t\t\tsticky,\n\t\t\t\tunixExternalUpper,\n\t\t\t\tinternalFileAttribute: fileEntry.internalFileAttributes,\n\t\t\t\texternalFileAttribute: fileEntry.externalFileAttributes,\n\t\t\t\texecutable,\n\t\t\t\tdirectory: modeIsDir || upperIsDir || (msDosCompatible && msdosAttributes.directory) || (filename.endsWith(DIRECTORY_SIGNATURE) && !fileEntry.uncompressedSize),\n\t\t\t\tzipCrypto: fileEntry.encrypted && !fileEntry.extraFieldAES\n\t\t\t});\n\t\t\tconst entry = new Entry(fileEntry);\n\t\t\tentry.getData = (writer, options) => fileEntry.getData(writer, entry, zipReader.readRanges, options);\n\t\t\tentry.arrayBuffer = async options => {\n\t\t\t\tconst writer = new TransformStream();\n\t\t\t\tconst [arrayBuffer] = await Promise.all([\n\t\t\t\t\tnew Response(writer.readable).arrayBuffer(),\n\t\t\t\t\tfileEntry.getData(writer, entry, zipReader.readRanges, options)]);\n\t\t\t\treturn arrayBuffer;\n\t\t\t};\n\t\t\toffset = endOffset;\n\t\t\tconst { onprogress } = options;\n\t\t\tif (onprogress) {\n\t\t\t\ttry {\n\t\t\t\t\tawait onprogress(indexFile + 1, filesLength, new Entry(fileEntry));\n\t\t\t\t} catch {\n\t\t\t\t\t// ignored\n\t\t\t\t}\n\t\t\t}\n\t\t\tyield entry;\n\t\t}\n\t\tconst extractPrependedData = getOptionValue(zipReader, options, OPTION_EXTRACT_PREPENDED_DATA);\n\t\tconst extractAppendedData = getOptionValue(zipReader, options, OPTION_EXTRACT_APPENDED_DATA);\n\t\tif (extractPrependedData) {\n\t\t\tzipReader.prependedData = startOffset > 0 ? await readUint8Array(reader, 0, startOffset) : new Uint8Array();\n\t\t}\n\t\tzipReader.comment = commentLength ? await readUint8Array(reader, commentOffset + END_OF_CENTRAL_DIR_LENGTH, commentLength) : new Uint8Array();\n\t\tif (extractAppendedData) {\n\t\t\tzipReader.appendedData = appendedDataOffset < reader.size ? await readUint8Array(reader, appendedDataOffset, reader.size - appendedDataOffset) : new Uint8Array();\n\t\t}\n\t\treturn true;\n\t}\n\n\tasync getEntries(options = {}) {\n\t\tconst entries = [];\n\t\tfor await (const entry of this.getEntriesGenerator(options)) {\n\t\t\tentries.push(entry);\n\t\t}\n\t\treturn entries;\n\t}\n\n\tasync close() {\n\t}\n}\n\nclass ZipReaderStream {\n\n\tconstructor(options = {}) {\n\t\tconst { readable, writable } = new TransformStream();\n\t\tconst gen = new ZipReader(readable, options).getEntriesGenerator();\n\t\tthis.readable = new ReadableStream({\n\t\t\tasync pull(controller) {\n\t\t\t\tconst { done, value } = await gen.next();\n\t\t\t\tif (done)\n\t\t\t\t\treturn controller.close();\n\t\t\t\tconst chunk = {\n\t\t\t\t\t...value,\n\t\t\t\t\treadable: (function () {\n\t\t\t\t\t\tconst { readable, writable } = new TransformStream();\n\t\t\t\t\t\tif (value.getData) {\n\t\t\t\t\t\t\tvalue.getData(writable);\n\t\t\t\t\t\t\treturn readable;\n\t\t\t\t\t\t}\n\t\t\t\t\t})()\n\t\t\t\t};\n\t\t\t\tdelete chunk.getData;\n\t\t\t\tcontroller.enqueue(chunk);\n\t\t\t}\n\t\t});\n\t\tthis.writable = writable;\n\t}\n}\n\nexport {\n\tZipReader,\n\tZipReaderStream,\n\tERR_BAD_FORMAT,\n\tERR_EOCDR_NOT_FOUND,\n\tERR_EOCDR_LOCATOR_ZIP64_NOT_FOUND,\n\tERR_CENTRAL_DIRECTORY_NOT_FOUND,\n\tERR_LOCAL_FILE_HEADER_NOT_FOUND,\n\tERR_EXTRAFIELD_ZIP64_NOT_FOUND,\n\tERR_ENCRYPTED,\n\tERR_UNSUPPORTED_ENCRYPTION,\n\tERR_UNSUPPORTED_COMPRESSION,\n\tERR_INVALID_SIGNATURE,\n\tERR_INVALID_PASSWORD,\n\tERR_INVALID_UNCOMPRESSED_SIZE,\n\tERR_SPLIT_ZIP_FILE,\n\tERR_OVERLAPPING_ENTRY\n};\n\nclass ZipEntry {\n\n\tconstructor(reader, config, options) {\n\t\tObject.assign(this, {\n\t\t\treader,\n\t\t\tconfig,\n\t\t\toptions\n\t\t});\n\t}\n\n\tasync getData(writer, fileEntry, readRanges, options = {}) {\n\t\tconst zipEntry = this;\n\t\tconst {\n\t\t\treader,\n\t\t\toffset,\n\t\t\tdiskNumberStart,\n\t\t\textraFieldAES,\n\t\t\textraFieldZip64,\n\t\t\tcompressionMethod,\n\t\t\tconfig,\n\t\t\tbitFlag,\n\t\t\tsignature,\n\t\t\trawLastModDate,\n\t\t\tuncompressedSize,\n\t\t\tcompressedSize\n\t\t} = zipEntry;\n\t\tconst {\n\t\t\tdataDescriptor\n\t\t} = bitFlag;\n\t\tconst localDirectory = fileEntry.localDirectory = {};\n\t\tconst dataArray = await readUint8Array(reader, offset, HEADER_SIZE, diskNumberStart);\n\t\tconst dataView = getDataView(dataArray);\n\t\tlet password = getOptionValue(zipEntry, options, OPTION_PASSWORD);\n\t\tlet rawPassword = getOptionValue(zipEntry, options, OPTION_RAW_PASSWORD);\n\t\tconst passThrough = getOptionValue(zipEntry, options, OPTION_PASS_THROUGH);\n\t\tpassword = password && password.length && password;\n\t\trawPassword = rawPassword && rawPassword.length && rawPassword;\n\t\tif (extraFieldAES) {\n\t\t\tif (extraFieldAES.originalCompressionMethod != COMPRESSION_METHOD_AES) {\n\t\t\t\tthrow new Error(ERR_UNSUPPORTED_COMPRESSION);\n\t\t\t}\n\t\t}\n\t\tif ((compressionMethod != COMPRESSION_METHOD_STORE && compressionMethod != COMPRESSION_METHOD_DEFLATE && compressionMethod != COMPRESSION_METHOD_DEFLATE_64) && !passThrough) {\n\t\t\tthrow new Error(ERR_UNSUPPORTED_COMPRESSION);\n\t\t}\n\t\tif (getUint32(dataView, 0) != LOCAL_FILE_HEADER_SIGNATURE) {\n\t\t\tthrow new Error(ERR_LOCAL_FILE_HEADER_NOT_FOUND);\n\t\t}\n\t\treadCommonHeader(localDirectory, dataView, 4);\n\t\tconst {\n\t\t\textraFieldLength,\n\t\t\tfilenameLength,\n\t\t\tlastAccessDate,\n\t\t\tcreationDate\n\t\t} = localDirectory;\n\t\tlocalDirectory.rawExtraField = extraFieldLength ?\n\t\t\tawait readUint8Array(reader, offset + HEADER_SIZE + filenameLength, extraFieldLength, diskNumberStart) :\n\t\t\tnew Uint8Array();\n\t\treadCommonFooter(zipEntry, localDirectory, dataView, 4, true);\n\t\tObject.assign(fileEntry, { lastAccessDate, creationDate });\n\t\tconst encrypted = zipEntry.encrypted && localDirectory.encrypted && !passThrough;\n\t\tconst zipCrypto = encrypted && !extraFieldAES;\n\t\tif (!passThrough) {\n\t\t\tfileEntry.zipCrypto = zipCrypto;\n\t\t}\n\t\tif (encrypted) {\n\t\t\tif (!zipCrypto && extraFieldAES.strength === UNDEFINED_VALUE) {\n\t\t\t\tthrow new Error(ERR_UNSUPPORTED_ENCRYPTION);\n\t\t\t} else if (!password && !rawPassword) {\n\t\t\t\tthrow new Error(ERR_ENCRYPTED);\n\t\t\t}\n\t\t}\n\t\tconst dataOffset = offset + HEADER_SIZE + filenameLength + extraFieldLength;\n\t\tconst size = compressedSize;\n\t\tconst readable = reader.readable;\n\t\tObject.assign(readable, {\n\t\t\tdiskNumberStart,\n\t\t\toffset: dataOffset,\n\t\t\tsize\n\t\t});\n\t\tconst signal = getOptionValue(zipEntry, options, OPTION_SIGNAL);\n\t\tconst checkPasswordOnly = getOptionValue(zipEntry, options, OPTION_CHECK_PASSWORD_ONLY);\n\t\tlet checkOverlappingEntry = getOptionValue(zipEntry, options, OPTION_CHECK_OVERLAPPING_ENTRY);\n\t\tconst checkOverlappingEntryOnly = getOptionValue(zipEntry, options, OPTION_CHECK_OVERLAPPING_ENTRY_ONLY);\n\t\tif (checkOverlappingEntryOnly) {\n\t\t\tcheckOverlappingEntry = true;\n\t\t}\n\t\tconst { onstart, onprogress, onend } = options;\n\t\tconst deflate64 = compressionMethod == COMPRESSION_METHOD_DEFLATE_64;\n\t\tlet useCompressionStream = getOptionValue(zipEntry, options, OPTION_USE_COMPRESSION_STREAM);\n\t\tif (deflate64) {\n\t\t\tuseCompressionStream = false;\n\t\t}\n\t\tconst workerOptions = {\n\t\t\toptions: {\n\t\t\t\tcodecType: CODEC_INFLATE,\n\t\t\t\tpassword,\n\t\t\t\trawPassword,\n\t\t\t\tzipCrypto,\n\t\t\t\tencryptionStrength: extraFieldAES && extraFieldAES.strength,\n\t\t\t\tsigned: getOptionValue(zipEntry, options, OPTION_CHECK_SIGNATURE) && !passThrough,\n\t\t\t\tpasswordVerification: zipCrypto && (dataDescriptor ? ((rawLastModDate >>> 8) & MAX_8_BITS) : ((signature >>> 24) & MAX_8_BITS)),\n\t\t\t\toutputSize: passThrough ? compressedSize : uncompressedSize,\n\t\t\t\tsignature,\n\t\t\t\tcompressed: compressionMethod != 0 && !passThrough,\n\t\t\t\tencrypted: zipEntry.encrypted && !passThrough,\n\t\t\t\tuseWebWorkers: getOptionValue(zipEntry, options, OPTION_USE_WEB_WORKERS),\n\t\t\t\tuseCompressionStream,\n\t\t\t\ttransferStreams: getOptionValue(zipEntry, options, OPTION_TRANSFER_STREAMS),\n\t\t\t\tdeflate64,\n\t\t\t\tcheckPasswordOnly\n\t\t\t},\n\t\t\tconfig,\n\t\t\tstreamOptions: { signal, size, onstart, onprogress, onend }\n\t\t};\n\t\tif (checkOverlappingEntry) {\n\t\t\tawait detectOverlappingEntry({\n\t\t\t\treader,\n\t\t\t\tfileEntry,\n\t\t\t\toffset,\n\t\t\t\tdiskNumberStart,\n\t\t\t\tsignature,\n\t\t\t\tcompressedSize,\n\t\t\t\tuncompressedSize,\n\t\t\t\tdataOffset,\n\t\t\t\tdataDescriptor: dataDescriptor || localDirectory.bitFlag.dataDescriptor,\n\t\t\t\textraFieldZip64: extraFieldZip64 || localDirectory.extraFieldZip64,\n\t\t\t\treadRanges\n\t\t\t});\n\t\t}\n\t\tlet writable;\n\t\ttry {\n\t\t\tif (!checkOverlappingEntryOnly) {\n\t\t\t\tif (checkPasswordOnly) {\n\t\t\t\t\twriter = new WritableStream();\n\t\t\t\t}\n\t\t\t\twriter = new GenericWriter(writer);\n\t\t\t\tawait initStream(writer, passThrough ? compressedSize : uncompressedSize);\n\t\t\t\t({ writable } = writer);\n\t\t\t\tconst { outputSize } = await runWorker({ readable, writable }, workerOptions);\n\t\t\t\twriter.size += outputSize;\n\t\t\t\tif (outputSize != (passThrough ? compressedSize : uncompressedSize)) {\n\t\t\t\t\tthrow new Error(ERR_INVALID_UNCOMPRESSED_SIZE);\n\t\t\t\t}\n\t\t\t}\n\t\t} catch (error) {\n\t\t\tif (error.outputSize !== UNDEFINED_VALUE) {\n\t\t\t\twriter.size += error.outputSize;\n\t\t\t}\n\t\t\tif (!checkPasswordOnly || error.message != ERR_ABORT_CHECK_PASSWORD) {\n\t\t\t\tthrow error;\n\t\t\t}\n\t\t} finally {\n\t\t\tconst preventClose = getOptionValue(zipEntry, options, OPTION_PREVENT_CLOSE);\n\t\t\tif (!preventClose && writable && !writable.locked) {\n\t\t\t\tawait writable.getWriter().close();\n\t\t\t}\n\t\t}\n\t\treturn checkPasswordOnly || checkOverlappingEntryOnly ? UNDEFINED_VALUE : writer.getData ? writer.getData() : writable;\n\t}\n}\n\nfunction readCommonHeader(directory, dataView, offset) {\n\tconst rawBitFlag = directory.rawBitFlag = getUint16(dataView, offset + 2);\n\tconst encrypted = (rawBitFlag & BITFLAG_ENCRYPTED) == BITFLAG_ENCRYPTED;\n\tconst rawLastModDate = getUint32(dataView, offset + 6);\n\tObject.assign(directory, {\n\t\tencrypted,\n\t\tversion: getUint16(dataView, offset),\n\t\tbitFlag: {\n\t\t\tlevel: (rawBitFlag & BITFLAG_LEVEL) >> 1,\n\t\t\tdataDescriptor: (rawBitFlag & BITFLAG_DATA_DESCRIPTOR) == BITFLAG_DATA_DESCRIPTOR,\n\t\t\tlanguageEncodingFlag: (rawBitFlag & BITFLAG_LANG_ENCODING_FLAG) == BITFLAG_LANG_ENCODING_FLAG\n\t\t},\n\t\trawLastModDate,\n\t\tlastModDate: getDate(rawLastModDate),\n\t\tfilenameLength: getUint16(dataView, offset + 22),\n\t\textraFieldLength: getUint16(dataView, offset + 24)\n\t});\n}\n\nfunction readCommonFooter(fileEntry, directory, dataView, offset, localDirectory) {\n\tconst { rawExtraField } = directory;\n\tconst extraField = directory.extraField = new Map();\n\tconst rawExtraFieldView = getDataView(new Uint8Array(rawExtraField));\n\tlet offsetExtraField = 0;\n\ttry {\n\t\twhile (offsetExtraField < rawExtraField.length) {\n\t\t\tconst type = getUint16(rawExtraFieldView, offsetExtraField);\n\t\t\tconst size = getUint16(rawExtraFieldView, offsetExtraField + 2);\n\t\t\textraField.set(type, {\n\t\t\t\ttype,\n\t\t\t\tdata: rawExtraField.slice(offsetExtraField + 4, offsetExtraField + 4 + size)\n\t\t\t});\n\t\t\toffsetExtraField += 4 + size;\n\t\t}\n\t} catch {\n\t\t// ignored\n\t}\n\tconst compressionMethod = getUint16(dataView, offset + 4);\n\tObject.assign(directory, {\n\t\tsignature: getUint32(dataView, offset + HEADER_OFFSET_SIGNATURE),\n\t\tcompressedSize: getUint32(dataView, offset + HEADER_OFFSET_COMPRESSED_SIZE),\n\t\tuncompressedSize: getUint32(dataView, offset + HEADER_OFFSET_UNCOMPRESSED_SIZE)\n\t});\n\tconst extraFieldZip64 = extraField.get(EXTRAFIELD_TYPE_ZIP64);\n\tif (extraFieldZip64) {\n\t\treadExtraFieldZip64(extraFieldZip64, directory);\n\t\tdirectory.extraFieldZip64 = extraFieldZip64;\n\t}\n\tconst extraFieldUnicodePath = extraField.get(EXTRAFIELD_TYPE_UNICODE_PATH);\n\tif (extraFieldUnicodePath) {\n\t\treadExtraFieldUnicode(extraFieldUnicodePath, PROPERTY_NAME_FILENAME, PROPERTY_NAME_RAW_FILENAME, directory, fileEntry);\n\t\tdirectory.extraFieldUnicodePath = extraFieldUnicodePath;\n\t}\n\tconst extraFieldUnicodeComment = extraField.get(EXTRAFIELD_TYPE_UNICODE_COMMENT);\n\tif (extraFieldUnicodeComment) {\n\t\treadExtraFieldUnicode(extraFieldUnicodeComment, PROPERTY_NAME_COMMENT, PROPERTY_NAME_RAW_COMMENT, directory, fileEntry);\n\t\tdirectory.extraFieldUnicodeComment = extraFieldUnicodeComment;\n\t}\n\tconst extraFieldAES = extraField.get(EXTRAFIELD_TYPE_AES);\n\tif (extraFieldAES) {\n\t\treadExtraFieldAES(extraFieldAES, directory, compressionMethod);\n\t\tdirectory.extraFieldAES = extraFieldAES;\n\t} else {\n\t\tdirectory.compressionMethod = compressionMethod;\n\t}\n\tconst extraFieldNTFS = extraField.get(EXTRAFIELD_TYPE_NTFS);\n\tif (extraFieldNTFS) {\n\t\treadExtraFieldNTFS(extraFieldNTFS, directory);\n\t\tdirectory.extraFieldNTFS = extraFieldNTFS;\n\t}\n\tconst extraFieldUnix = extraField.get(EXTRAFIELD_TYPE_UNIX);\n\tif (extraFieldUnix) {\n\t\treadExtraFieldUnix(extraFieldUnix, directory, false);\n\t\tdirectory.extraFieldUnix = extraFieldUnix;\n\t} else {\n\t\tconst extraFieldInfoZip = extraField.get(EXTRAFIELD_TYPE_INFOZIP);\n\t\tif (extraFieldInfoZip) {\n\t\t\treadExtraFieldUnix(extraFieldInfoZip, directory, true);\n\t\t\tdirectory.extraFieldInfoZip = extraFieldInfoZip;\n\t\t}\n\t}\n\tconst extraFieldExtendedTimestamp = extraField.get(EXTRAFIELD_TYPE_EXTENDED_TIMESTAMP);\n\tif (extraFieldExtendedTimestamp) {\n\t\treadExtraFieldExtendedTimestamp(extraFieldExtendedTimestamp, directory, localDirectory);\n\t\tdirectory.extraFieldExtendedTimestamp = extraFieldExtendedTimestamp;\n\t}\n\tconst extraFieldUSDZ = extraField.get(EXTRAFIELD_TYPE_USDZ);\n\tif (extraFieldUSDZ) {\n\t\tdirectory.extraFieldUSDZ = extraFieldUSDZ;\n\t}\n}\n\nfunction readExtraFieldZip64(extraFieldZip64, directory) {\n\tdirectory.zip64 = true;\n\tconst extraFieldView = getDataView(extraFieldZip64.data);\n\tconst missingProperties = ZIP64_PROPERTIES.filter(([propertyName, max]) => directory[propertyName] == max);\n\tfor (let indexMissingProperty = 0, offset = 0; indexMissingProperty < missingProperties.length; indexMissingProperty++) {\n\t\tconst [propertyName, max] = missingProperties[indexMissingProperty];\n\t\tif (directory[propertyName] == max) {\n\t\t\tconst extraction = ZIP64_EXTRACTION[max];\n\t\t\tdirectory[propertyName] = extraFieldZip64[propertyName] = extraction.getValue(extraFieldView, offset);\n\t\t\toffset += extraction.bytes;\n\t\t} else if (extraFieldZip64[propertyName]) {\n\t\t\tthrow new Error(ERR_EXTRAFIELD_ZIP64_NOT_FOUND);\n\t\t}\n\t}\n}\n\nfunction readExtraFieldUnicode(extraFieldUnicode, propertyName, rawPropertyName, directory, fileEntry) {\n\tconst extraFieldView = getDataView(extraFieldUnicode.data);\n\tconst crc32 = new Crc32();\n\tcrc32.append(fileEntry[rawPropertyName]);\n\tconst dataViewSignature = getDataView(new Uint8Array(4));\n\tdataViewSignature.setUint32(0, crc32.get(), true);\n\tconst signature = getUint32(extraFieldView, 1);\n\tObject.assign(extraFieldUnicode, {\n\t\tversion: getUint8(extraFieldView, 0),\n\t\t[propertyName]: decodeText(extraFieldUnicode.data.subarray(5)),\n\t\tvalid: !fileEntry.bitFlag.languageEncodingFlag && signature == getUint32(dataViewSignature, 0)\n\t});\n\tif (extraFieldUnicode.valid) {\n\t\tdirectory[propertyName] = extraFieldUnicode[propertyName];\n\t\tdirectory[propertyName + PROPERTY_NAME_UTF8_SUFFIX] = true;\n\t}\n}\n\nfunction readExtraFieldAES(extraFieldAES, directory, compressionMethod) {\n\tconst extraFieldView = getDataView(extraFieldAES.data);\n\tconst strength = getUint8(extraFieldView, 4);\n\tObject.assign(extraFieldAES, {\n\t\tvendorVersion: getUint8(extraFieldView, 0),\n\t\tvendorId: getUint8(extraFieldView, 2),\n\t\tstrength,\n\t\toriginalCompressionMethod: compressionMethod,\n\t\tcompressionMethod: getUint16(extraFieldView, 5)\n\t});\n\tdirectory.compressionMethod = extraFieldAES.compressionMethod;\n}\n\nfunction readExtraFieldNTFS(extraFieldNTFS, directory) {\n\tconst extraFieldView = getDataView(extraFieldNTFS.data);\n\tlet offsetExtraField = 4;\n\tlet tag1Data;\n\ttry {\n\t\twhile (offsetExtraField < extraFieldNTFS.data.length && !tag1Data) {\n\t\t\tconst tagValue = getUint16(extraFieldView, offsetExtraField);\n\t\t\tconst attributeSize = getUint16(extraFieldView, offsetExtraField + 2);\n\t\t\tif (tagValue == EXTRAFIELD_TYPE_NTFS_TAG1) {\n\t\t\t\ttag1Data = extraFieldNTFS.data.slice(offsetExtraField + 4, offsetExtraField + 4 + attributeSize);\n\t\t\t}\n\t\t\toffsetExtraField += 4 + attributeSize;\n\t\t}\n\t} catch {\n\t\t// ignored\n\t}\n\ttry {\n\t\tif (tag1Data && tag1Data.length == 24) {\n\t\t\tconst tag1View = getDataView(tag1Data);\n\t\t\tconst rawLastModDate = tag1View.getBigUint64(0, true);\n\t\t\tconst rawLastAccessDate = tag1View.getBigUint64(8, true);\n\t\t\tconst rawCreationDate = tag1View.getBigUint64(16, true);\n\t\t\tObject.assign(extraFieldNTFS, {\n\t\t\t\trawLastModDate,\n\t\t\t\trawLastAccessDate,\n\t\t\t\trawCreationDate\n\t\t\t});\n\t\t\tconst lastModDate = getDateNTFS(rawLastModDate);\n\t\t\tconst lastAccessDate = getDateNTFS(rawLastAccessDate);\n\t\t\tconst creationDate = getDateNTFS(rawCreationDate);\n\t\t\tconst extraFieldData = { lastModDate, lastAccessDate, creationDate };\n\t\t\tObject.assign(extraFieldNTFS, extraFieldData);\n\t\t\tObject.assign(directory, extraFieldData);\n\t\t}\n\t} catch {\n\t\t// ignored\n\t}\n}\n\nfunction readExtraFieldUnix(extraField, directory, isInfoZip) {\n\ttry {\n\t\tconst view = getDataView(new Uint8Array(extraField.data));\n\t\tlet offset = 0;\n\t\tconst version = getUint8(view, offset++);\n\t\tconst uidSize = getUint8(view, offset++);\n\t\tconst uidBytes = extraField.data.subarray(offset, offset + uidSize);\n\t\toffset += uidSize;\n\t\tconst uid = unpackUnixId(uidBytes);\n\t\tconst gidSize = getUint8(view, offset++);\n\t\tconst gidBytes = extraField.data.subarray(offset, offset + gidSize);\n\t\toffset += gidSize;\n\t\tconst gid = unpackUnixId(gidBytes);\n\t\tlet unixMode = UNDEFINED_VALUE;\n\t\tif (!isInfoZip && offset + 2 <= extraField.data.length) {\n\t\t\tconst base = extraField.data;\n\t\t\tconst modeView = new DataView(base.buffer, base.byteOffset + offset, 2);\n\t\t\tunixMode = modeView.getUint16(0, true);\n\t\t}\n\t\tObject.assign(extraField, { version, uid, gid, unixMode });\n\t\tif (uid !== UNDEFINED_VALUE) {\n\t\t\tdirectory.uid = uid;\n\t\t}\n\t\tif (gid !== UNDEFINED_VALUE) {\n\t\t\tdirectory.gid = gid;\n\t\t}\n\t\tif (unixMode !== UNDEFINED_VALUE) {\n\t\t\tdirectory.unixMode = unixMode;\n\t\t}\n\t} catch {\n\t\t// ignored\n\t}\n}\n\nfunction unpackUnixId(bytes) {\n\tconst buffer = new Uint8Array(4);\n\tbuffer.set(bytes, 0);\n\tconst view = new DataView(buffer.buffer, buffer.byteOffset, 4);\n\treturn view.getUint32(0, true);\n}\n\nfunction readExtraFieldExtendedTimestamp(extraFieldExtendedTimestamp, directory, localDirectory) {\n\tconst extraFieldView = getDataView(extraFieldExtendedTimestamp.data);\n\tconst flags = getUint8(extraFieldView, 0);\n\tconst timeProperties = [];\n\tconst timeRawProperties = [];\n\tif (localDirectory) {\n\t\tif ((flags & 0x1) == 0x1) {\n\t\t\ttimeProperties.push(PROPERTY_NAME_LAST_MODIFICATION_DATE);\n\t\t\ttimeRawProperties.push(PROPERTY_NAME_RAW_LAST_MODIFICATION_DATE);\n\t\t}\n\t\tif ((flags & 0x2) == 0x2) {\n\t\t\ttimeProperties.push(PROPERTY_NAME_LAST_ACCESS_DATE);\n\t\t\ttimeRawProperties.push(PROPERTY_NAME_RAW_LAST_ACCESS_DATE);\n\t\t}\n\t\tif ((flags & 0x4) == 0x4) {\n\t\t\ttimeProperties.push(PROPERTY_NAME_CREATION_DATE);\n\t\t\ttimeRawProperties.push(PROPERTY_NAME_RAW_CREATION_DATE);\n\t\t}\n\t} else if (extraFieldExtendedTimestamp.data.length >= 5) {\n\t\ttimeProperties.push(PROPERTY_NAME_LAST_MODIFICATION_DATE);\n\t\ttimeRawProperties.push(PROPERTY_NAME_RAW_LAST_MODIFICATION_DATE);\n\t}\n\tlet offset = 1;\n\ttimeProperties.forEach((propertyName, indexProperty) => {\n\t\tif (extraFieldExtendedTimestamp.data.length >= offset + 4) {\n\t\t\tconst time = getUint32(extraFieldView, offset);\n\t\t\tdirectory[propertyName] = extraFieldExtendedTimestamp[propertyName] = new Date(time * 1000);\n\t\t\tconst rawPropertyName = timeRawProperties[indexProperty];\n\t\t\textraFieldExtendedTimestamp[rawPropertyName] = time;\n\t\t}\n\t\toffset += 4;\n\t});\n}\n\nasync function detectOverlappingEntry({\n\treader,\n\tfileEntry,\n\toffset,\n\tdiskNumberStart,\n\tsignature,\n\tcompressedSize,\n\tuncompressedSize,\n\tdataOffset,\n\tdataDescriptor,\n\textraFieldZip64,\n\treadRanges\n}) {\n\tlet diskOffset = 0;\n\tif (diskNumberStart) {\n\t\tfor (let indexReader = 0; indexReader < diskNumberStart; indexReader++) {\n\t\t\tconst diskReader = reader.readers[indexReader];\n\t\t\tdiskOffset += diskReader.size;\n\t\t}\n\t}\n\tlet dataDescriptorLength = 0;\n\tif (dataDescriptor) {\n\t\tif (extraFieldZip64) {\n\t\t\tdataDescriptorLength = DATA_DESCRIPTOR_RECORD_ZIP_64_LENGTH;\n\t\t} else {\n\t\t\tdataDescriptorLength = DATA_DESCRIPTOR_RECORD_LENGTH;\n\t\t}\n\t}\n\tif (dataDescriptorLength) {\n\t\tconst dataDescriptorArray = await readUint8Array(reader, dataOffset + compressedSize, dataDescriptorLength + DATA_DESCRIPTOR_RECORD_SIGNATURE_LENGTH, diskNumberStart);\n\t\tconst dataDescriptorSignature = getUint32(getDataView(dataDescriptorArray), 0) == DATA_DESCRIPTOR_RECORD_SIGNATURE;\n\t\tif (dataDescriptorSignature) {\n\t\t\tconst readSignature = getUint32(getDataView(dataDescriptorArray), 4);\n\t\t\tlet readCompressedSize;\n\t\t\tlet readUncompressedSize;\n\t\t\tif (extraFieldZip64) {\n\t\t\t\treadCompressedSize = getBigUint64(getDataView(dataDescriptorArray), 8);\n\t\t\t\treadUncompressedSize = getBigUint64(getDataView(dataDescriptorArray), 16);\n\t\t\t} else {\n\t\t\t\treadCompressedSize = getUint32(getDataView(dataDescriptorArray), 8);\n\t\t\t\treadUncompressedSize = getUint32(getDataView(dataDescriptorArray), 12);\n\t\t\t}\n\t\t\tconst matchSignature = (fileEntry.encrypted && !fileEntry.zipCrypto) || readSignature == signature;\n\t\t\tif (matchSignature &&\n\t\t\t\treadCompressedSize == compressedSize &&\n\t\t\t\treadUncompressedSize == uncompressedSize) {\n\t\t\t\tdataDescriptorLength += DATA_DESCRIPTOR_RECORD_SIGNATURE_LENGTH;\n\t\t\t}\n\t\t}\n\t}\n\tconst range = {\n\t\tstart: diskOffset + offset,\n\t\tend: diskOffset + dataOffset + compressedSize + dataDescriptorLength,\n\t\tfileEntry\n\t};\n\tfor (const otherRange of readRanges) {\n\t\tif (otherRange.fileEntry != fileEntry && range.start >= otherRange.start && range.start < otherRange.end) {\n\t\t\tconst error = new Error(ERR_OVERLAPPING_ENTRY);\n\t\t\terror.overlappingEntry = otherRange.fileEntry;\n\t\t\tthrow error;\n\t\t}\n\t}\n\treadRanges.push(range);\n}\n\nasync function seekSignature(reader, signature, startOffset, minimumBytes, maximumLength) {\n\tconst signatureArray = new Uint8Array(4);\n\tconst signatureView = getDataView(signatureArray);\n\tsetUint32(signatureView, 0, signature);\n\tconst maximumBytes = minimumBytes + maximumLength;\n\treturn (await seek(minimumBytes)) || await seek(Math.min(maximumBytes, startOffset));\n\n\tasync function seek(length) {\n\t\tconst offset = startOffset - length;\n\t\tconst bytes = await readUint8Array(reader, offset, length);\n\t\tfor (let indexByte = bytes.length - minimumBytes; indexByte >= 0; indexByte--) {\n\t\t\tif (bytes[indexByte] == signatureArray[0] && bytes[indexByte + 1] == signatureArray[1] &&\n\t\t\t\tbytes[indexByte + 2] == signatureArray[2] && bytes[indexByte + 3] == signatureArray[3]) {\n\t\t\t\treturn {\n\t\t\t\t\toffset: offset + indexByte,\n\t\t\t\t\tbuffer: bytes.slice(indexByte, indexByte + minimumBytes).buffer\n\t\t\t\t};\n\t\t\t}\n\t\t}\n\t}\n}\n\nfunction getOptionValue(zipReader, options, name) {\n\treturn options[name] === UNDEFINED_VALUE ? zipReader.options[name] : options[name];\n}\n\nfunction getDate(timeRaw) {\n\tconst date = (timeRaw & 0xffff0000) >> 16, time = timeRaw & MAX_16_BITS;\n\ttry {\n\t\treturn new Date(1980 + ((date & 0xFE00) >> 9), ((date & 0x01E0) >> 5) - 1, date & 0x001F, (time & 0xF800) >> 11, (time & 0x07E0) >> 5, (time & 0x001F) * 2, 0);\n\t} catch {\n\t\t// ignored\n\t}\n}\n\nfunction getDateNTFS(timeRaw) {\n\treturn new Date((Number((timeRaw / BigInt(10000)) - BigInt(11644473600000))));\n}\n\nfunction getUint8(view, offset) {\n\treturn view.getUint8(offset);\n}\n\nfunction getUint16(view, offset) {\n\treturn view.getUint16(offset, true);\n}\n\nfunction getUint32(view, offset) {\n\treturn view.getUint32(offset, true);\n}\n\nfunction getBigUint64(view, offset) {\n\treturn Number(view.getBigUint64(offset, true));\n}\n\nfunction setUint32(view, offset, value) {\n\tview.setUint32(offset, value, true);\n}\n\nfunction getDataView(array) {\n\treturn new DataView(array.buffer);\n}\n","/*\n Copyright (c) 2025 Gildas Lormeau. All rights reserved.\n\n Redistribution and use in source and binary forms, with or without\n modification, are permitted provided that the following conditions are met:\n\n 1. Redistributions of source code must retain the above copyright notice,\n this list of conditions and the following disclaimer.\n\n 2. Redistributions in binary form must reproduce the above copyright\n notice, this list of conditions and the following disclaimer in\n the documentation and/or other materials provided with the distribution.\n\n 3. The names of the authors may not be used to endorse or promote products\n derived from this software without specific prior written permission.\n\n THIS SOFTWARE IS PROVIDED ''AS IS'' AND ANY EXPRESSED OR IMPLIED WARRANTIES,\n INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND\n FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL JCRAFT,\n INC. OR ANY CONTRIBUTORS TO THIS SOFTWARE BE LIABLE FOR ANY DIRECT, INDIRECT,\n INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT\n LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA,\n OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF\n LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING\n NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE,\n EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.\n */\n\nimport { configure } from \"./core/configuration.js\";\n\ntry {\n\tconfigure({ baseURI: import.meta.url });\n} catch {\n\t// ignored\n}\n\nexport * from \"./zip-core-reader.js\";\nexport * from \"./zip-core-writer.js\";\nexport {\n\tReader,\n\tWriter,\n\tTextReader,\n\tTextWriter,\n\tData64URIReader,\n\tData64URIWriter,\n\tBlobReader,\n\tBlobWriter,\n\tHttpReader,\n\tHttpRangeReader,\n\tUint8ArrayWriter,\n\tUint8ArrayReader,\n\tSplitDataReader,\n\tSplitDataWriter,\n\tERR_HTTP_RANGE\n} from \"./core/io.js\";\nexport {\n\tgetMimeType\n} from \"./core/util/default-mime-type.js\";\nexport {\n\tconfigure\n} from \"./core/configuration.js\";","const A=\"ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/\";function g(g){let B;g({wasmURI:()=>(B||(B=\"data:application/wasm;base64,\"+(g=>{g=(g=>{const B=(g=(g+\"\").replace(/[^A-Za-z0-9+/=]/g,\"\")).length,E=[];for(let I=0;B>I;I+=4){const B=A.indexOf(g[I])<<18|A.indexOf(g[I+1])<<12|(63&A.indexOf(g[I+2]))<<6|63&A.indexOf(g[I+3]);E.push(B>>16&255),\"=\"!==g[I+2]&&E.push(B>>8&255),\"=\"!==g[I+3]&&E.push(255&B)}return new Uint8Array(E)})(g);let B=new Uint8Array(1024),E=0;for(let A=0;A<g.length;){const C=g[A++];if(128&C){const Q=3+(127&C),D=g[A++]<<8|g[A++],o=E-D;I(E+Q);for(let A=0;Q>A;A++)B[E++]=B[o+A]}else{const Q=C;I(E+Q);for(let I=0;Q>I&&A<g.length;I++)B[E++]=g[A++]}}return(g=>{let B=\"\";const E=g.length;let I=0;for(;E>I+2;I+=3){const E=g[I]<<16|g[I+1]<<8|g[I+2];B+=A[E>>18&63]+A[E>>12&63]+A[E>>6&63]+A[63&E]}const C=E-I;if(1===C){const E=g[I]<<16;B+=A[E>>18&63]+A[E>>12&63]+\"==\"}else if(2===C){const E=g[I]<<16|g[I+1]<<8;B+=A[E>>18&63]+A[E>>12&63]+A[E>>6&63]+\"=\"}return B})(new Uint8Array(B.buffer.slice(0,E)));function I(A){if(B.length<A){let g=2*B.length;for(;A>g;)g*=2;const I=new Uint8Array(g);I.set(B.subarray(0,E)),B=I}}})(\"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BAGZgAAEAVmAAAQB2YAABAE5gAAEAbmAAAQBeYAABAH5gAAEAQWAAAQBhYAABAFFgAAEAcWAAAQBJYAABAGlgAAEAWWAAAQB5YAABAEVgAAEAZWAAAQBVYAABAHVgAAEATWAAAQBtYAABAF1gAAEAfWAAAQBDYAABAGNgAAEAU2AAAQBzYAABIARMwIArYAABAFtgAAEAe2AAAQBHYAABAGdgAAEAV2AAAQB3YAABAE9gAAEAb2AAAQBfYAABAH9gAAEAROAAMIFEwEJAJOAAAgBk4AACAFTgAAIAVOAAAgB04AACAHTgAAIATOAAAgBM4AACAGzgAAIAbOAAAgBc4AACAFzgAAIAfOAAAgB84AACAELgAAIgBDagAQCgAAEgAAIAUuAAAgBS4AACAHLgAAIAcuAAAgBK4AACAErgAAIAauAAAgBq4AACAFrgAAIAWuAAAgB64AACAHrgAAIARuAAAgBG4AACAGbgAAIAZuAAAgBW4AACAFbgAAIAduAAAgB24AACAE7gAAIATuAAAgBu4AACAG7gAAIAXuAAAgBe4AACAH7gAAIAfuAAAiBA7YBB4AACAGHgAAIAYeAAAgBR4AACAFHgAAIAceAAAgBx4AACAEngAAIASeAAAgBp4AACAGngAAIAWeAAAgBZ4AACAHngAAIAeeAAAgBF4AACAEXgAAIAZeAAAgBl4AACAFXgAAIAVeAAAgB14AACAHXgAAIATeAAAgBN4AACAG3gAAIAbeAAAgBd4AACAF3gAAIAfeAAAgB94AACAEPgAAIAQ+AAAgBj4AACAGPgAAIAU+AAAgBT4AACAHPgAAIAc+AAAgBL4AACAEvgAAIAa+AAAgBr4AACAFvgAAIAW+AAAgB74AACAHvgAAIAR+AAAgBH4AACAGfgAAIAZ+AAAgBX4AACAFfgAAIAd+AAAgB34AACAE/gAAIAT+AAAgBv4AACAG/gAAIAX+AAAgBf4AACAH/gAAIAf+AAAiBBAoBQIAABAEggAAEAWCAAAQBEIAABAFQgAAEATCAAAQBcIIFVgMHAEiAAAQBKIAABAFogAAEARiAAAQBWIAABAE4gAAEAXiAAAQBBIAABAFEgAAEASSAAAQBZIAABAEUgAAEAVSAAAQBNIAABAF0gAAEAQOAAEIBg4AABAFDgAAEAcOAAAQBI4AABAGjgAAEAWOAAAQB44AABIC+K4AAdIECxgEFgABcAQWCBUoBFIAABAEMgAAEARyAAASAvlaABEQBBYIGBAEaggXqAQWAA9QBBYADuAEFgAOcgE92gAAEARGAAAQBCYAABAEZgAAEgQACARWAAAQBDYAABAEdgAAEgL59gAKkgQZAAQWAAiyBBaYBBYABtAEFgD3fAxsLTYMfuYcABIC+rooABIEHUYkABAEEjAAEAQWKAAQEQbAcC4C9CosAS40AO4UALwEGhAAEgQWIgQAEgQEKgQAEgQGSgQAEgIS2ggAEAQuEAAQBDIQABIAF24FHeQTgHQsjhQBfhQXLAhARgAVtBgcJBgoFC4A6uAQNAg4BgAclBJQeC2mFAJCFAIiFAICFAHiBAGiBAFyBBh8BEIAABAEUgAAEARiAAAQBHIAABAEggAAEASiAAAQBMIAABAE4gAAEAUCAAAQBUIAABIEGvQFwgAAEAYCAAAQBoIAABAHAgAAEAeCAAG8DHwtyjQBvgQBrgQBngQBjgQBfgQBbgQBXgQBTgQBPgQBLgQBHgQBDgQE8AYCvAEGAUc0CC22BAMcBBIAAAgEIgAAEgQEzgQJLARCAAA6DAAyBnqyAqmuEACSBB3OBAE8BCIAACIEAGIUADIEIt4MADAEggQCUgDKEgQBrAYCBCC8BBIMADIA/SAoBABAMAEGRIQv/gCUfgMDAgIKxBQgJCQoKgEk3gAABAQ2AAAEBDoAAAQEPgAABARCEAAEBEYQAAQEShAABAROEAAEBFIwAAQEVjAABARaMAAEBF4wAAQEYnAABARmcAAEBGpwAAQEbmwABARyBffsEBAQFBYHB1QEHgAABAQiEAAGAXSqCAAEBCowAAYAnsooAAYEBMJkAAYEBTJkAAYEBaLkAAYEBpLkAAYIDdYABzoUBvI0BqJ0BkLwBgAIbHLwAAQEdvAABgA9PgH05A9AqAQ==\")),B)})}export{g as configureZlibModule};\n","/*\n Copyright (c) 2025 Gildas Lormeau. All rights reserved.\n\n Redistribution and use in source and binary forms, with or without\n modification, are permitted provided that the following conditions are met:\n\n 1. Redistributions of source code must retain the above copyright notice,\n this list of conditions and the following disclaimer.\n\n 2. Redistributions in binary form must reproduce the above copyright \n notice, this list of conditions and the following disclaimer in \n the documentation and/or other materials provided with the distribution.\n\n 3. The names of the authors may not be used to endorse or promote products\n derived from this software without specific prior written permission.\n\n THIS SOFTWARE IS PROVIDED ''AS IS'' AND ANY EXPRESSED OR IMPLIED WARRANTIES,\n INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND\n FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL JCRAFT,\n INC. OR ANY CONTRIBUTORS TO THIS SOFTWARE BE LIABLE FOR ANY DIRECT, INDIRECT,\n INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT\n LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA,\n OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF\n LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING\n NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE,\n EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.\n */\n\n/* global TransformStream */\n\nlet wasm, malloc, free, memory;\n\nexport function setWasmExports(wasmAPI) {\n\twasm = wasmAPI;\n\t({ malloc, free, memory } = wasm);\n\tif (typeof malloc !== \"function\" || typeof free !== \"function\" || !memory) {\n\t\twasm = malloc = free = memory = null;\n\t\tthrow new Error(\"Invalid WASM module\");\n\t}\n}\n\nfunction _make(isCompress, type, options = {}) {\n\tconst level = (typeof options.level === \"number\") ? options.level : -1;\n\tconst outBufferSize = (typeof options.outBuffer === \"number\") ? options.outBuffer : 64 * 1024;\n\tconst inBufferSize = (typeof options.inBufferSize === \"number\") ? options.inBufferSize : 64 * 1024;\n\n\treturn new TransformStream({\n\t\tstart() {\n\t\t\tlet result;\n\t\t\tthis.out = malloc(outBufferSize);\n\t\t\tthis.in = malloc(inBufferSize);\n\t\t\tthis.inBufferSize = inBufferSize;\n\t\t\tthis._scratch = new Uint8Array(outBufferSize);\n\t\t\tif (isCompress) {\n\t\t\t\tthis._process = wasm.deflate_process;\n\t\t\t\tthis._last_consumed = wasm.deflate_last_consumed;\n\t\t\t\tthis._end = wasm.deflate_end;\n\t\t\t\tthis.streamHandle = wasm.deflate_new();\n\t\t\t\tif (type === \"gzip\") {\n\t\t\t\t\tresult = wasm.deflate_init_gzip(this.streamHandle, level);\n\t\t\t\t} else if (type === \"deflate-raw\") {\n\t\t\t\t\tresult = wasm.deflate_init_raw(this.streamHandle, level);\n\t\t\t\t} else {\n\t\t\t\t\tresult = wasm.deflate_init(this.streamHandle, level);\n\t\t\t\t}\n\t\t\t} else {\n\t\t\t\tif (type === \"deflate64-raw\") {\n\t\t\t\t\tthis._process = wasm.inflate9_process;\n\t\t\t\t\tthis._last_consumed = wasm.inflate9_last_consumed;\n\t\t\t\t\tthis._end = wasm.inflate9_end;\n\t\t\t\t\tthis.streamHandle = wasm.inflate9_new();\n\t\t\t\t\tresult = wasm.inflate9_init_raw(this.streamHandle);\n\t\t\t\t} else {\n\t\t\t\t\tthis._process = wasm.inflate_process;\n\t\t\t\t\tthis._last_consumed = wasm.inflate_last_consumed;\n\t\t\t\t\tthis._end = wasm.inflate_end;\n\t\t\t\t\tthis.streamHandle = wasm.inflate_new();\n\t\t\t\t\tif (type === \"deflate-raw\") {\n\t\t\t\t\t\tresult = wasm.inflate_init_raw(this.streamHandle);\n\t\t\t\t\t} else if (type === \"gzip\") {\n\t\t\t\t\t\tresult = wasm.inflate_init_gzip(this.streamHandle);\n\t\t\t\t\t} else {\n\t\t\t\t\t\tresult = wasm.inflate_init(this.streamHandle);\n\t\t\t\t\t}\n\t\t\t\t}\n\t\t\t}\n\t\t\tif (result !== 0) {\n\t\t\t\tthrow new Error(\"init failed:\" + result);\n\t\t\t}\n\t\t},\n\t\ttransform(chunk, controller) {\n\t\t\ttry {\n\t\t\t\tconst buffer = chunk;\n\t\t\t\tconst heap = new Uint8Array(memory.buffer);\n\t\t\t\tconst process = this._process;\n\t\t\t\tconst last_consumed = this._last_consumed;\n\t\t\t\tconst out = this.out;\n\t\t\t\tconst scratch = this._scratch;\n\t\t\t\tlet offset = 0;\n\t\t\t\twhile (offset < buffer.length) {\n\t\t\t\t\tconst toRead = Math.min(buffer.length - offset, 32 * 1024);\n\t\t\t\t\tif (!this.in || this.inBufferSize < toRead) {\n\t\t\t\t\t\tif (this.in && free) {\n\t\t\t\t\t\t\tfree(this.in);\n\t\t\t\t\t\t}\n\t\t\t\t\t\tthis.in = malloc(toRead);\n\t\t\t\t\t\tthis.inBufferSize = toRead;\n\t\t\t\t\t}\n\t\t\t\t\theap.set(buffer.subarray(offset, offset + toRead), this.in);\n\t\t\t\t\tconst result = process(this.streamHandle, this.in, toRead, out, outBufferSize, 0);\n\t\t\t\t\tconst prod = result & 0x00ffffff;\n\t\t\t\t\tif (prod) {\n\t\t\t\t\t\tscratch.set(heap.subarray(out, out + prod), 0);\n\t\t\t\t\t\tcontroller.enqueue(scratch.slice(0, prod));\n\t\t\t\t\t}\n\t\t\t\t\tif (!isCompress) {\n\t\t\t\t\t\tconst code = (result >> 24) & 0xff;\n\t\t\t\t\t\tconst signedCode = (code & 0x80) ? code - 256 : code;\n\t\t\t\t\t\tif (signedCode < 0) {\n\t\t\t\t\t\t\tthrow new Error(\"process error:\" + signedCode);\n\t\t\t\t\t\t}\n\t\t\t\t\t}\n\t\t\t\t\tconst consumed = last_consumed(this.streamHandle);\n\t\t\t\t\tif (consumed === 0) {\n\t\t\t\t\t\tbreak;\n\t\t\t\t\t}\n\t\t\t\t\toffset += consumed;\n\t\t\t\t}\n\t\t\t} catch (error) {\n\t\t\t\tif (this._end && this.streamHandle) {\n\t\t\t\t\tthis._end(this.streamHandle);\n\t\t\t\t}\n\t\t\t\tif (this.in && free) {\n\t\t\t\t\tfree(this.in);\n\t\t\t\t}\n\t\t\t\tif (this.out && free) {\n\t\t\t\t\tfree(this.out);\n\t\t\t\t}\n\t\t\t\tcontroller.error(error);\n\t\t\t}\n\t\t},\n\t\tflush(controller) {\n\t\t\ttry {\n\t\t\t\tconst heap = new Uint8Array(memory.buffer);\n\t\t\t\tconst process = this._process;\n\t\t\t\tconst out = this.out;\n\t\t\t\tconst scratch = this._scratch;\n\t\t\t\twhile (true) {\n\t\t\t\t\tconst result = process(this.streamHandle, 0, 0, out, outBufferSize, 4);\n\t\t\t\t\tconst produced = result & 0x00ffffff;\n\t\t\t\t\tconst code = (result >> 24) & 0xff;\n\t\t\t\t\tif (!isCompress) {\n\t\t\t\t\t\tconst signedCode = (code & 0x80) ? code - 256 : code;\n\t\t\t\t\t\tif (signedCode < 0) {\n\t\t\t\t\t\t\tthrow new Error(\"process error:\" + signedCode);\n\t\t\t\t\t\t}\n\t\t\t\t\t}\n\t\t\t\t\tif (produced) {\n\t\t\t\t\t\tscratch.set(heap.subarray(out, out + produced), 0);\n\t\t\t\t\t\tcontroller.enqueue(scratch.slice(0, produced));\n\t\t\t\t\t}\n\t\t\t\t\tif (code === 1 || produced === 0) {\n\t\t\t\t\t\tbreak;\n\t\t\t\t\t}\n\t\t\t\t}\n\t\t\t} catch (error) {\n\t\t\t\tcontroller.error(error);\n\t\t\t} finally {\n\t\t\t\tif (this._end && this.streamHandle) {\n\t\t\t\t\tconst result = this._end(this.streamHandle);\n\t\t\t\t\tif (result !== 0) {\n\t\t\t\t\t\tcontroller.error(new Error(\"end error:\" + result));\n\t\t\t\t\t}\n\t\t\t\t}\n\t\t\t\tif (this.in && free) {\n\t\t\t\t\tfree(this.in);\n\t\t\t\t}\n\t\t\t\tif (this.out && free) {\n\t\t\t\t\tfree(this.out);\n\t\t\t\t}\n\t\t\t}\n\t\t}\n\t});\n}\n\nexport class CompressionStreamZlib {\n\tconstructor(type = \"deflate\", options) {\n\t\treturn _make(true, type, options);\n\t}\n}\nexport class DecompressionStreamZlib {\n\tconstructor(type = \"deflate\", options) {\n\t\treturn _make(false, type, options);\n\t}\n}","/*\n Copyright (c) 2025 Gildas Lormeau. All rights reserved.\n\n Redistribution and use in source and binary forms, with or without\n modification, are permitted provided that the following conditions are met:\n\n 1. Redistributions of source code must retain the above copyright notice,\n this list of conditions and the following disclaimer.\n\n 2. Redistributions in binary form must reproduce the above copyright \n notice, this list of conditions and the following disclaimer in \n the documentation and/or other materials provided with the distribution.\n\n 3. The names of the authors may not be used to endorse or promote products\n derived from this software without specific prior written permission.\n\n THIS SOFTWARE IS PROVIDED ''AS IS'' AND ANY EXPRESSED OR IMPLIED WARRANTIES,\n INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND\n FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL JCRAFT,\n INC. OR ANY CONTRIBUTORS TO THIS SOFTWARE BE LIABLE FOR ANY DIRECT, INDIRECT,\n INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT\n LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA,\n OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF\n LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING\n NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE,\n EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.\n */\n\n/* global WebAssembly, URL, fetch, atob */\n\nimport { setWasmExports } from \"./zlib-streams.js\";\n\nlet initializedModule = false;\n\nasync function initModule(wasmURI, { baseURI }) {\n\tif (!initializedModule) {\n\t\tlet arrayBuffer, uri;\n\t\ttry {\n\t\t\ttry {\n\t\t\t\turi = new URL(wasmURI, baseURI);\n\t\t\t} catch {\n\t\t\t\t// ignored\n\t\t\t}\n\t\t\tconst response = await fetch(uri);\n\t\t\tarrayBuffer = await response.arrayBuffer();\n\t\t} catch (error) {\n\t\t\tif (wasmURI.startsWith(\"data:application/wasm;base64,\")) {\n\t\t\t\tarrayBuffer = arrayBufferFromDataURI(wasmURI);\n\t\t\t} else {\n\t\t\t\tthrow error;\n\t\t\t}\n\t\t}\n\t\tconst wasmInstance = await WebAssembly.instantiate(arrayBuffer);\n\t\tsetWasmExports(wasmInstance.instance.exports);\n\t\tinitializedModule = true;\n\t}\n}\n\nfunction resetWasmModule() {\n\tinitializedModule = false;\n}\n\nfunction arrayBufferFromDataURI(dataURI) {\n\tconst base64 = dataURI.split(\",\")[1];\n\tconst binary = atob(base64);\n\tconst len = binary.length;\n\tconst bytes = new Uint8Array(len);\n\tfor (let i = 0; i < len; ++i) {\n\t\tbytes[i] = binary.charCodeAt(i);\n\t}\n\treturn bytes.buffer;\n}\n\nexport {\n\tsetWasmExports,\n\tCompressionStreamZlib,\n\tDecompressionStreamZlib\n} from \"./zlib-streams.js\";\nexport {\n\tinitModule,\n\tresetWasmModule,\n\tinitializedModule\n};","/*\n Copyright (c) 2025 Gildas Lormeau. All rights reserved.\n\n Redistribution and use in source and binary forms, with or without\n modification, are permitted provided that the following conditions are met:\n\n 1. Redistributions of source code must retain the above copyright notice,\n this list of conditions and the following disclaimer.\n\n 2. Redistributions in binary form must reproduce the above copyright\n notice, this list of conditions and the following disclaimer in\n the documentation and/or other materials provided with the distribution.\n\n 3. The names of the authors may not be used to endorse or promote products\n derived from this software without specific prior written permission.\n\n THIS SOFTWARE IS PROVIDED ''AS IS'' AND ANY EXPRESSED OR IMPLIED WARRANTIES,\n INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND\n FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL JCRAFT,\n INC. OR ANY CONTRIBUTORS TO THIS SOFTWARE BE LIABLE FOR ANY DIRECT, INDIRECT,\n INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT\n LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA,\n OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF\n LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING\n NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE,\n EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.\n */\n\nimport { FUNCTION_TYPE } from \"./core/constants.js\";\nimport { configure } from \"./core/configuration.js\";\nimport { configureZlibModule } from \"./core/zlib-streams-inline.js\";\nimport { configureWorker } from \"./core/codec-worker.js\";\nimport { terminateWorkers } from \"./core/codec-pool.js\";\nimport { initModule, resetWasmModule, CompressionStreamZlib, DecompressionStreamZlib } from \"./core/streams/zlib-wasm/zlib-streams-loader.js\";\n\nlet modulePromise;\n\nconfigureZlibModule(configure);\nconfigureWorker({\n\tinitModule: config => {\n\t\tif (!modulePromise) {\n\t\t\tlet { wasmURI } = config;\n\t\t\t// deno-lint-ignore valid-typeof\n\t\t\tif (typeof wasmURI == FUNCTION_TYPE) {\n\t\t\t\twasmURI = wasmURI();\n\t\t\t}\n\t\t\tmodulePromise = initModule(wasmURI, config);\n\n\t\t}\n\t\treturn modulePromise;\n\t}\n});\nconfigure({\n\tCompressionStreamZlib,\n\tDecompressionStreamZlib\n});\n\nexport { terminateWorkersAndModule as terminateWorkers };\n\nfunction terminateWorkersAndModule() {\n\tmodulePromise = null;\n\tterminateWorkers();\n\tresetWasmModule();\n}","/*\n Copyright (c) 2022 Gildas Lormeau. All rights reserved.\n\n Redistribution and use in source and binary forms, with or without\n modification, are permitted provided that the following conditions are met:\n\n 1. Redistributions of source code must retain the above copyright notice,\n this list of conditions and the following disclaimer.\n\n 2. Redistributions in binary form must reproduce the above copyright \n notice, this list of conditions and the following disclaimer in \n the documentation and/or other materials provided with the distribution.\n\n 3. The names of the authors may not be used to endorse or promote products\n derived from this software without specific prior written permission.\n\n THIS SOFTWARE IS PROVIDED ''AS IS'' AND ANY EXPRESSED OR IMPLIED WARRANTIES,\n INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND\n FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL JCRAFT,\n INC. OR ANY CONTRIBUTORS TO THIS SOFTWARE BE LIABLE FOR ANY DIRECT, INDIRECT,\n INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT\n LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA,\n OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF\n LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING\n NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE,\n EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.\n */\n\nimport { getMimeType as getDefaultMimeType } from \"./default-mime-type.js\";\n\nconst table = {\n\t\"application\": {\n\t\t\"andrew-inset\": \"ez\",\n\t\t\"annodex\": \"anx\",\n\t\t\"atom+xml\": \"atom\",\n\t\t\"atomcat+xml\": \"atomcat\",\n\t\t\"atomserv+xml\": \"atomsrv\",\n\t\t\"bbolin\": \"lin\",\n\t\t\"cu-seeme\": \"cu\",\n\t\t\"davmount+xml\": \"davmount\",\n\t\t\"dsptype\": \"tsp\",\n\t\t\"ecmascript\": [\n\t\t\t\"es\",\n\t\t\t\"ecma\"\n\t\t],\n\t\t\"futuresplash\": \"spl\",\n\t\t\"hta\": \"hta\",\n\t\t\"java-archive\": \"jar\",\n\t\t\"java-serialized-object\": \"ser\",\n\t\t\"java-vm\": \"class\",\n\t\t\"m3g\": \"m3g\",\n\t\t\"mac-binhex40\": \"hqx\",\n\t\t\"mathematica\": [\n\t\t\t\"nb\",\n\t\t\t\"ma\",\n\t\t\t\"mb\"\n\t\t],\n\t\t\"msaccess\": \"mdb\",\n\t\t\"msword\": [\n\t\t\t\"doc\",\n\t\t\t\"dot\",\n\t\t\t\"wiz\"\n\t\t],\n\t\t\"mxf\": \"mxf\",\n\t\t\"oda\": \"oda\",\n\t\t\"ogg\": \"ogx\",\n\t\t\"pdf\": \"pdf\",\n\t\t\"pgp-keys\": \"key\",\n\t\t\"pgp-signature\": [\n\t\t\t\"asc\",\n\t\t\t\"sig\"\n\t\t],\n\t\t\"pics-rules\": \"prf\",\n\t\t\"postscript\": [\n\t\t\t\"ps\",\n\t\t\t\"ai\",\n\t\t\t\"eps\",\n\t\t\t\"epsi\",\n\t\t\t\"epsf\",\n\t\t\t\"eps2\",\n\t\t\t\"eps3\"\n\t\t],\n\t\t\"rar\": \"rar\",\n\t\t\"rdf+xml\": \"rdf\",\n\t\t\"rss+xml\": \"rss\",\n\t\t\"rtf\": \"rtf\",\n\t\t\"xhtml+xml\": [\n\t\t\t\"xhtml\",\n\t\t\t\"xht\"\n\t\t],\n\t\t\"xml\": [\n\t\t\t\"xml\",\n\t\t\t\"xsl\",\n\t\t\t\"xsd\",\n\t\t\t\"xpdl\"\n\t\t],\n\t\t\"xspf+xml\": \"xspf\",\n\t\t\"zip\": \"zip\",\n\t\t\"vnd.android.package-archive\": \"apk\",\n\t\t\"vnd.cinderella\": \"cdy\",\n\t\t\"vnd.google-earth.kml+xml\": \"kml\",\n\t\t\"vnd.google-earth.kmz\": \"kmz\",\n\t\t\"vnd.mozilla.xul+xml\": \"xul\",\n\t\t\"vnd.ms-excel\": [\n\t\t\t\"xls\",\n\t\t\t\"xlb\",\n\t\t\t\"xlt\",\n\t\t\t\"xlm\",\n\t\t\t\"xla\",\n\t\t\t\"xlc\",\n\t\t\t\"xlw\"\n\t\t],\n\t\t\"vnd.ms-pki.seccat\": \"cat\",\n\t\t\"vnd.ms-pki.stl\": \"stl\",\n\t\t\"vnd.ms-powerpoint\": [\n\t\t\t\"ppt\",\n\t\t\t\"pps\",\n\t\t\t\"pot\",\n\t\t\t\"ppa\",\n\t\t\t\"pwz\"\n\t\t],\n\t\t\"vnd.oasis.opendocument.chart\": \"odc\",\n\t\t\"vnd.oasis.opendocument.database\": \"odb\",\n\t\t\"vnd.oasis.opendocument.formula\": \"odf\",\n\t\t\"vnd.oasis.opendocument.graphics\": \"odg\",\n\t\t\"vnd.oasis.opendocument.graphics-template\": \"otg\",\n\t\t\"vnd.oasis.opendocument.image\": \"odi\",\n\t\t\"vnd.oasis.opendocument.presentation\": \"odp\",\n\t\t\"vnd.oasis.opendocument.presentation-template\": \"otp\",\n\t\t\"vnd.oasis.opendocument.spreadsheet\": \"ods\",\n\t\t\"vnd.oasis.opendocument.spreadsheet-template\": \"ots\",\n\t\t\"vnd.oasis.opendocument.text\": \"odt\",\n\t\t\"vnd.oasis.opendocument.text-master\": [\n\t\t\t\"odm\",\n\t\t\t\"otm\"\n\t\t],\n\t\t\"vnd.oasis.opendocument.text-template\": \"ott\",\n\t\t\"vnd.oasis.opendocument.text-web\": \"oth\",\n\t\t\"vnd.openxmlformats-officedocument.spreadsheetml.sheet\": \"xlsx\",\n\t\t\"vnd.openxmlformats-officedocument.spreadsheetml.template\": \"xltx\",\n\t\t\"vnd.openxmlformats-officedocument.presentationml.presentation\": \"pptx\",\n\t\t\"vnd.openxmlformats-officedocument.presentationml.slideshow\": \"ppsx\",\n\t\t\"vnd.openxmlformats-officedocument.presentationml.template\": \"potx\",\n\t\t\"vnd.openxmlformats-officedocument.wordprocessingml.document\": \"docx\",\n\t\t\"vnd.openxmlformats-officedocument.wordprocessingml.template\": \"dotx\",\n\t\t\"vnd.smaf\": \"mmf\",\n\t\t\"vnd.stardivision.calc\": \"sdc\",\n\t\t\"vnd.stardivision.chart\": \"sds\",\n\t\t\"vnd.stardivision.draw\": \"sda\",\n\t\t\"vnd.stardivision.impress\": \"sdd\",\n\t\t\"vnd.stardivision.math\": [\n\t\t\t\"sdf\",\n\t\t\t\"smf\"\n\t\t],\n\t\t\"vnd.stardivision.writer\": [\n\t\t\t\"sdw\",\n\t\t\t\"vor\"\n\t\t],\n\t\t\"vnd.stardivision.writer-global\": \"sgl\",\n\t\t\"vnd.sun.xml.calc\": \"sxc\",\n\t\t\"vnd.sun.xml.calc.template\": \"stc\",\n\t\t\"vnd.sun.xml.draw\": \"sxd\",\n\t\t\"vnd.sun.xml.draw.template\": \"std\",\n\t\t\"vnd.sun.xml.impress\": \"sxi\",\n\t\t\"vnd.sun.xml.impress.template\": \"sti\",\n\t\t\"vnd.sun.xml.math\": \"sxm\",\n\t\t\"vnd.sun.xml.writer\": \"sxw\",\n\t\t\"vnd.sun.xml.writer.global\": \"sxg\",\n\t\t\"vnd.sun.xml.writer.template\": \"stw\",\n\t\t\"vnd.symbian.install\": [\n\t\t\t\"sis\",\n\t\t\t\"sisx\"\n\t\t],\n\t\t\"vnd.visio\": [\n\t\t\t\"vsd\",\n\t\t\t\"vst\",\n\t\t\t\"vss\",\n\t\t\t\"vsw\",\n\t\t\t\"vsdx\",\n\t\t\t\"vssx\",\n\t\t\t\"vstx\",\n\t\t\t\"vssm\",\n\t\t\t\"vstm\"\n\t\t],\n\t\t\"vnd.wap.wbxml\": \"wbxml\",\n\t\t\"vnd.wap.wmlc\": \"wmlc\",\n\t\t\"vnd.wap.wmlscriptc\": \"wmlsc\",\n\t\t\"vnd.wordperfect\": \"wpd\",\n\t\t\"vnd.wordperfect5.1\": \"wp5\",\n\t\t\"x-123\": \"wk\",\n\t\t\"x-7z-compressed\": \"7z\",\n\t\t\"x-abiword\": \"abw\",\n\t\t\"x-apple-diskimage\": \"dmg\",\n\t\t\"x-bcpio\": \"bcpio\",\n\t\t\"x-bittorrent\": \"torrent\",\n\t\t\"x-cbr\": [\n\t\t\t\"cbr\",\n\t\t\t\"cba\",\n\t\t\t\"cbt\",\n\t\t\t\"cb7\"\n\t\t],\n\t\t\"x-cbz\": \"cbz\",\n\t\t\"x-cdf\": [\n\t\t\t\"cdf\",\n\t\t\t\"cda\"\n\t\t],\n\t\t\"x-cdlink\": \"vcd\",\n\t\t\"x-chess-pgn\": \"pgn\",\n\t\t\"x-cpio\": \"cpio\",\n\t\t\"x-csh\": \"csh\",\n\t\t\"x-director\": [\n\t\t\t\"dir\",\n\t\t\t\"dxr\",\n\t\t\t\"cst\",\n\t\t\t\"cct\",\n\t\t\t\"cxt\",\n\t\t\t\"w3d\",\n\t\t\t\"fgd\",\n\t\t\t\"swa\"\n\t\t],\n\t\t\"x-dms\": \"dms\",\n\t\t\"x-doom\": \"wad\",\n\t\t\"x-dvi\": \"dvi\",\n\t\t\"x-httpd-eruby\": \"rhtml\",\n\t\t\"x-font\": \"pcf.Z\",\n\t\t\"x-freemind\": \"mm\",\n\t\t\"x-gnumeric\": \"gnumeric\",\n\t\t\"x-go-sgf\": \"sgf\",\n\t\t\"x-graphing-calculator\": \"gcf\",\n\t\t\"x-gtar\": [\n\t\t\t\"gtar\",\n\t\t\t\"taz\"\n\t\t],\n\t\t\"x-hdf\": \"hdf\",\n\t\t\"x-httpd-php\": [\n\t\t\t\"phtml\",\n\t\t\t\"pht\",\n\t\t\t\"php\"\n\t\t],\n\t\t\"x-httpd-php-source\": \"phps\",\n\t\t\"x-httpd-php3\": \"php3\",\n\t\t\"x-httpd-php3-preprocessed\": \"php3p\",\n\t\t\"x-httpd-php4\": \"php4\",\n\t\t\"x-httpd-php5\": \"php5\",\n\t\t\"x-ica\": \"ica\",\n\t\t\"x-info\": \"info\",\n\t\t\"x-internet-signup\": [\n\t\t\t\"ins\",\n\t\t\t\"isp\"\n\t\t],\n\t\t\"x-iphone\": \"iii\",\n\t\t\"x-iso9660-image\": \"iso\",\n\t\t\"x-java-jnlp-file\": \"jnlp\",\n\t\t\"x-jmol\": \"jmz\",\n\t\t\"x-killustrator\": \"kil\",\n\t\t\"x-latex\": \"latex\",\n\t\t\"x-lyx\": \"lyx\",\n\t\t\"x-lzx\": \"lzx\",\n\t\t\"x-maker\": [\n\t\t\t\"frm\",\n\t\t\t\"fb\",\n\t\t\t\"fbdoc\"\n\t\t],\n\t\t\"x-ms-wmd\": \"wmd\",\n\t\t\"x-msdos-program\": [\n\t\t\t\"com\",\n\t\t\t\"exe\",\n\t\t\t\"bat\",\n\t\t\t\"dll\"\n\t\t],\n\t\t\"x-netcdf\": [\n\t\t\t\"nc\"\n\t\t],\n\t\t\"x-ns-proxy-autoconfig\": [\n\t\t\t\"pac\",\n\t\t\t\"dat\"\n\t\t],\n\t\t\"x-nwc\": \"nwc\",\n\t\t\"x-object\": \"o\",\n\t\t\"x-oz-application\": \"oza\",\n\t\t\"x-pkcs7-certreqresp\": \"p7r\",\n\t\t\"x-python-code\": [\n\t\t\t\"pyc\",\n\t\t\t\"pyo\"\n\t\t],\n\t\t\"x-qgis\": [\n\t\t\t\"qgs\",\n\t\t\t\"shp\",\n\t\t\t\"shx\"\n\t\t],\n\t\t\"x-quicktimeplayer\": \"qtl\",\n\t\t\"x-redhat-package-manager\": [\n\t\t\t\"rpm\",\n\t\t\t\"rpa\"\n\t\t],\n\t\t\"x-ruby\": \"rb\",\n\t\t\"x-sh\": \"sh\",\n\t\t\"x-shar\": \"shar\",\n\t\t\"x-shockwave-flash\": [\n\t\t\t\"swf\",\n\t\t\t\"swfl\"\n\t\t],\n\t\t\"x-silverlight\": \"scr\",\n\t\t\"x-stuffit\": \"sit\",\n\t\t\"x-sv4cpio\": \"sv4cpio\",\n\t\t\"x-sv4crc\": \"sv4crc\",\n\t\t\"x-tar\": \"tar\",\n\t\t\"x-tex-gf\": \"gf\",\n\t\t\"x-tex-pk\": \"pk\",\n\t\t\"x-texinfo\": [\n\t\t\t\"texinfo\",\n\t\t\t\"texi\"\n\t\t],\n\t\t\"x-trash\": [\n\t\t\t\"~\",\n\t\t\t\"%\",\n\t\t\t\"bak\",\n\t\t\t\"old\",\n\t\t\t\"sik\"\n\t\t],\n\t\t\"x-ustar\": \"ustar\",\n\t\t\"x-wais-source\": \"src\",\n\t\t\"x-wingz\": \"wz\",\n\t\t\"x-x509-ca-cert\": [\n\t\t\t\"crt\",\n\t\t\t\"der\",\n\t\t\t\"cer\"\n\t\t],\n\t\t\"x-xcf\": \"xcf\",\n\t\t\"x-xfig\": \"fig\",\n\t\t\"x-xpinstall\": \"xpi\",\n\t\t\"applixware\": \"aw\",\n\t\t\"atomsvc+xml\": \"atomsvc\",\n\t\t\"ccxml+xml\": \"ccxml\",\n\t\t\"cdmi-capability\": \"cdmia\",\n\t\t\"cdmi-container\": \"cdmic\",\n\t\t\"cdmi-domain\": \"cdmid\",\n\t\t\"cdmi-object\": \"cdmio\",\n\t\t\"cdmi-queue\": \"cdmiq\",\n\t\t\"docbook+xml\": \"dbk\",\n\t\t\"dssc+der\": \"dssc\",\n\t\t\"dssc+xml\": \"xdssc\",\n\t\t\"emma+xml\": \"emma\",\n\t\t\"epub+zip\": \"epub\",\n\t\t\"exi\": \"exi\",\n\t\t\"font-tdpfr\": \"pfr\",\n\t\t\"gml+xml\": \"gml\",\n\t\t\"gpx+xml\": \"gpx\",\n\t\t\"gxf\": \"gxf\",\n\t\t\"hyperstudio\": \"stk\",\n\t\t\"inkml+xml\": [\n\t\t\t\"ink\",\n\t\t\t\"inkml\"\n\t\t],\n\t\t\"ipfix\": \"ipfix\",\n\t\t\"jsonml+json\": \"jsonml\",\n\t\t\"lost+xml\": \"lostxml\",\n\t\t\"mads+xml\": \"mads\",\n\t\t\"marc\": \"mrc\",\n\t\t\"marcxml+xml\": \"mrcx\",\n\t\t\"mathml+xml\": [\n\t\t\t\"mathml\",\n\t\t\t\"mml\"\n\t\t],\n\t\t\"mbox\": \"mbox\",\n\t\t\"mediaservercontrol+xml\": \"mscml\",\n\t\t\"metalink+xml\": \"metalink\",\n\t\t\"metalink4+xml\": \"meta4\",\n\t\t\"mets+xml\": \"mets\",\n\t\t\"mods+xml\": \"mods\",\n\t\t\"mp21\": [\n\t\t\t\"m21\",\n\t\t\t\"mp21\"\n\t\t],\n\t\t\"mp4\": \"mp4s\",\n\t\t\"oebps-package+xml\": \"opf\",\n\t\t\"omdoc+xml\": \"omdoc\",\n\t\t\"onenote\": [\n\t\t\t\"onetoc\",\n\t\t\t\"onetoc2\",\n\t\t\t\"onetmp\",\n\t\t\t\"onepkg\"\n\t\t],\n\t\t\"oxps\": \"oxps\",\n\t\t\"patch-ops-error+xml\": \"xer\",\n\t\t\"pgp-encrypted\": \"pgp\",\n\t\t\"pkcs10\": \"p10\",\n\t\t\"pkcs7-mime\": [\n\t\t\t\"p7m\",\n\t\t\t\"p7c\"\n\t\t],\n\t\t\"pkcs7-signature\": \"p7s\",\n\t\t\"pkcs8\": \"p8\",\n\t\t\"pkix-attr-cert\": \"ac\",\n\t\t\"pkix-crl\": \"crl\",\n\t\t\"pkix-pkipath\": \"pkipath\",\n\t\t\"pkixcmp\": \"pki\",\n\t\t\"pls+xml\": \"pls\",\n\t\t\"prs.cww\": \"cww\",\n\t\t\"pskc+xml\": \"pskcxml\",\n\t\t\"reginfo+xml\": \"rif\",\n\t\t\"relax-ng-compact-syntax\": \"rnc\",\n\t\t\"resource-lists+xml\": \"rl\",\n\t\t\"resource-lists-diff+xml\": \"rld\",\n\t\t\"rls-services+xml\": \"rs\",\n\t\t\"rpki-ghostbusters\": \"gbr\",\n\t\t\"rpki-manifest\": \"mft\",\n\t\t\"rpki-roa\": \"roa\",\n\t\t\"rsd+xml\": \"rsd\",\n\t\t\"sbml+xml\": \"sbml\",\n\t\t\"scvp-cv-request\": \"scq\",\n\t\t\"scvp-cv-response\": \"scs\",\n\t\t\"scvp-vp-request\": \"spq\",\n\t\t\"scvp-vp-response\": \"spp\",\n\t\t\"sdp\": \"sdp\",\n\t\t\"set-payment-initiation\": \"setpay\",\n\t\t\"set-registration-initiation\": \"setreg\",\n\t\t\"shf+xml\": \"shf\",\n\t\t\"sparql-query\": \"rq\",\n\t\t\"sparql-results+xml\": \"srx\",\n\t\t\"srgs\": \"gram\",\n\t\t\"srgs+xml\": \"grxml\",\n\t\t\"sru+xml\": \"sru\",\n\t\t\"ssdl+xml\": \"ssdl\",\n\t\t\"ssml+xml\": \"ssml\",\n\t\t\"tei+xml\": [\n\t\t\t\"tei\",\n\t\t\t\"teicorpus\"\n\t\t],\n\t\t\"thraud+xml\": \"tfi\",\n\t\t\"timestamped-data\": \"tsd\",\n\t\t\"vnd.3gpp.pic-bw-large\": \"plb\",\n\t\t\"vnd.3gpp.pic-bw-small\": \"psb\",\n\t\t\"vnd.3gpp.pic-bw-var\": \"pvb\",\n\t\t\"vnd.3gpp2.tcap\": \"tcap\",\n\t\t\"vnd.3m.post-it-notes\": \"pwn\",\n\t\t\"vnd.accpac.simply.aso\": \"aso\",\n\t\t\"vnd.accpac.simply.imp\": \"imp\",\n\t\t\"vnd.acucobol\": \"acu\",\n\t\t\"vnd.acucorp\": [\n\t\t\t\"atc\",\n\t\t\t\"acutc\"\n\t\t],\n\t\t\"vnd.adobe.air-application-installer-package+zip\": \"air\",\n\t\t\"vnd.adobe.formscentral.fcdt\": \"fcdt\",\n\t\t\"vnd.adobe.fxp\": [\n\t\t\t\"fxp\",\n\t\t\t\"fxpl\"\n\t\t],\n\t\t\"vnd.adobe.xdp+xml\": \"xdp\",\n\t\t\"vnd.adobe.xfdf\": \"xfdf\",\n\t\t\"vnd.ahead.space\": \"ahead\",\n\t\t\"vnd.airzip.filesecure.azf\": \"azf\",\n\t\t\"vnd.airzip.filesecure.azs\": \"azs\",\n\t\t\"vnd.amazon.ebook\": \"azw\",\n\t\t\"vnd.americandynamics.acc\": \"acc\",\n\t\t\"vnd.amiga.ami\": \"ami\",\n\t\t\"vnd.anser-web-certificate-issue-initiation\": \"cii\",\n\t\t\"vnd.anser-web-funds-transfer-initiation\": \"fti\",\n\t\t\"vnd.antix.game-component\": \"atx\",\n\t\t\"vnd.apple.installer+xml\": \"mpkg\",\n\t\t\"vnd.apple.mpegurl\": \"m3u8\",\n\t\t\"vnd.aristanetworks.swi\": \"swi\",\n\t\t\"vnd.astraea-software.iota\": \"iota\",\n\t\t\"vnd.audiograph\": \"aep\",\n\t\t\"vnd.blueice.multipass\": \"mpm\",\n\t\t\"vnd.bmi\": \"bmi\",\n\t\t\"vnd.businessobjects\": \"rep\",\n\t\t\"vnd.chemdraw+xml\": \"cdxml\",\n\t\t\"vnd.chipnuts.karaoke-mmd\": \"mmd\",\n\t\t\"vnd.claymore\": \"cla\",\n\t\t\"vnd.cloanto.rp9\": \"rp9\",\n\t\t\"vnd.clonk.c4group\": [\n\t\t\t\"c4g\",\n\t\t\t\"c4d\",\n\t\t\t\"c4f\",\n\t\t\t\"c4p\",\n\t\t\t\"c4u\"\n\t\t],\n\t\t\"vnd.cluetrust.cartomobile-config\": \"c11amc\",\n\t\t\"vnd.cluetrust.cartomobile-config-pkg\": \"c11amz\",\n\t\t\"vnd.commonspace\": \"csp\",\n\t\t\"vnd.contact.cmsg\": \"cdbcmsg\",\n\t\t\"vnd.cosmocaller\": \"cmc\",\n\t\t\"vnd.crick.clicker\": \"clkx\",\n\t\t\"vnd.crick.clicker.keyboard\": \"clkk\",\n\t\t\"vnd.crick.clicker.palette\": \"clkp\",\n\t\t\"vnd.crick.clicker.template\": \"clkt\",\n\t\t\"vnd.crick.clicker.wordbank\": \"clkw\",\n\t\t\"vnd.criticaltools.wbs+xml\": \"wbs\",\n\t\t\"vnd.ctc-posml\": \"pml\",\n\t\t\"vnd.cups-ppd\": \"ppd\",\n\t\t\"vnd.curl.car\": \"car\",\n\t\t\"vnd.curl.pcurl\": \"pcurl\",\n\t\t\"vnd.dart\": \"dart\",\n\t\t\"vnd.data-vision.rdz\": \"rdz\",\n\t\t\"vnd.dece.data\": [\n\t\t\t\"uvf\",\n\t\t\t\"uvvf\",\n\t\t\t\"uvd\",\n\t\t\t\"uvvd\"\n\t\t],\n\t\t\"vnd.dece.ttml+xml\": [\n\t\t\t\"uvt\",\n\t\t\t\"uvvt\"\n\t\t],\n\t\t\"vnd.dece.unspecified\": [\n\t\t\t\"uvx\",\n\t\t\t\"uvvx\"\n\t\t],\n\t\t\"vnd.dece.zip\": [\n\t\t\t\"uvz\",\n\t\t\t\"uvvz\"\n\t\t],\n\t\t\"vnd.denovo.fcselayout-link\": \"fe_launch\",\n\t\t\"vnd.dna\": \"dna\",\n\t\t\"vnd.dolby.mlp\": \"mlp\",\n\t\t\"vnd.dpgraph\": \"dpg\",\n\t\t\"vnd.dreamfactory\": \"dfac\",\n\t\t\"vnd.ds-keypoint\": \"kpxx\",\n\t\t\"vnd.dvb.ait\": \"ait\",\n\t\t\"vnd.dvb.service\": \"svc\",\n\t\t\"vnd.dynageo\": \"geo\",\n\t\t\"vnd.ecowin.chart\": \"mag\",\n\t\t\"vnd.enliven\": \"nml\",\n\t\t\"vnd.epson.esf\": \"esf\",\n\t\t\"vnd.epson.msf\": \"msf\",\n\t\t\"vnd.epson.quickanime\": \"qam\",\n\t\t\"vnd.epson.salt\": \"slt\",\n\t\t\"vnd.epson.ssf\": \"ssf\",\n\t\t\"vnd.eszigno3+xml\": [\n\t\t\t\"es3\",\n\t\t\t\"et3\"\n\t\t],\n\t\t\"vnd.ezpix-album\": \"ez2\",\n\t\t\"vnd.ezpix-package\": \"ez3\",\n\t\t\"vnd.fdf\": \"fdf\",\n\t\t\"vnd.fdsn.mseed\": \"mseed\",\n\t\t\"vnd.fdsn.seed\": [\n\t\t\t\"seed\",\n\t\t\t\"dataless\"\n\t\t],\n\t\t\"vnd.flographit\": \"gph\",\n\t\t\"vnd.fluxtime.clip\": \"ftc\",\n\t\t\"vnd.framemaker\": [\n\t\t\t\"fm\",\n\t\t\t\"frame\",\n\t\t\t\"maker\",\n\t\t\t\"book\"\n\t\t],\n\t\t\"vnd.frogans.fnc\": \"fnc\",\n\t\t\"vnd.frogans.ltf\": \"ltf\",\n\t\t\"vnd.fsc.weblaunch\": \"fsc\",\n\t\t\"vnd.fujitsu.oasys\": \"oas\",\n\t\t\"vnd.fujitsu.oasys2\": \"oa2\",\n\t\t\"vnd.fujitsu.oasys3\": \"oa3\",\n\t\t\"vnd.fujitsu.oasysgp\": \"fg5\",\n\t\t\"vnd.fujitsu.oasysprs\": \"bh2\",\n\t\t\"vnd.fujixerox.ddd\": \"ddd\",\n\t\t\"vnd.fujixerox.docuworks\": \"xdw\",\n\t\t\"vnd.fujixerox.docuworks.binder\": \"xbd\",\n\t\t\"vnd.fuzzysheet\": \"fzs\",\n\t\t\"vnd.genomatix.tuxedo\": \"txd\",\n\t\t\"vnd.geogebra.file\": \"ggb\",\n\t\t\"vnd.geogebra.tool\": \"ggt\",\n\t\t\"vnd.geometry-explorer\": [\n\t\t\t\"gex\",\n\t\t\t\"gre\"\n\t\t],\n\t\t\"vnd.geonext\": \"gxt\",\n\t\t\"vnd.geoplan\": \"g2w\",\n\t\t\"vnd.geospace\": \"g3w\",\n\t\t\"vnd.gmx\": \"gmx\",\n\t\t\"vnd.grafeq\": [\n\t\t\t\"gqf\",\n\t\t\t\"gqs\"\n\t\t],\n\t\t\"vnd.groove-account\": \"gac\",\n\t\t\"vnd.groove-help\": \"ghf\",\n\t\t\"vnd.groove-identity-message\": \"gim\",\n\t\t\"vnd.groove-injector\": \"grv\",\n\t\t\"vnd.groove-tool-message\": \"gtm\",\n\t\t\"vnd.groove-tool-template\": \"tpl\",\n\t\t\"vnd.groove-vcard\": \"vcg\",\n\t\t\"vnd.hal+xml\": \"hal\",\n\t\t\"vnd.handheld-entertainment+xml\": \"zmm\",\n\t\t\"vnd.hbci\": \"hbci\",\n\t\t\"vnd.hhe.lesson-player\": \"les\",\n\t\t\"vnd.hp-hpgl\": \"hpgl\",\n\t\t\"vnd.hp-hpid\": \"hpid\",\n\t\t\"vnd.hp-hps\": \"hps\",\n\t\t\"vnd.hp-jlyt\": \"jlt\",\n\t\t\"vnd.hp-pcl\": \"pcl\",\n\t\t\"vnd.hp-pclxl\": \"pclxl\",\n\t\t\"vnd.hydrostatix.sof-data\": \"sfd-hdstx\",\n\t\t\"vnd.ibm.minipay\": \"mpy\",\n\t\t\"vnd.ibm.modcap\": [\n\t\t\t\"afp\",\n\t\t\t\"listafp\",\n\t\t\t\"list3820\"\n\t\t],\n\t\t\"vnd.ibm.rights-management\": \"irm\",\n\t\t\"vnd.ibm.secure-container\": \"sc\",\n\t\t\"vnd.iccprofile\": [\n\t\t\t\"icc\",\n\t\t\t\"icm\"\n\t\t],\n\t\t\"vnd.igloader\": \"igl\",\n\t\t\"vnd.immervision-ivp\": \"ivp\",\n\t\t\"vnd.immervision-ivu\": \"ivu\",\n\t\t\"vnd.insors.igm\": \"igm\",\n\t\t\"vnd.intercon.formnet\": [\n\t\t\t\"xpw\",\n\t\t\t\"xpx\"\n\t\t],\n\t\t\"vnd.intergeo\": \"i2g\",\n\t\t\"vnd.intu.qbo\": \"qbo\",\n\t\t\"vnd.intu.qfx\": \"qfx\",\n\t\t\"vnd.ipunplugged.rcprofile\": \"rcprofile\",\n\t\t\"vnd.irepository.package+xml\": \"irp\",\n\t\t\"vnd.is-xpr\": \"xpr\",\n\t\t\"vnd.isac.fcs\": \"fcs\",\n\t\t\"vnd.jam\": \"jam\",\n\t\t\"vnd.jcp.javame.midlet-rms\": \"rms\",\n\t\t\"vnd.jisp\": \"jisp\",\n\t\t\"vnd.joost.joda-archive\": \"joda\",\n\t\t\"vnd.kahootz\": [\n\t\t\t\"ktz\",\n\t\t\t\"ktr\"\n\t\t],\n\t\t\"vnd.kde.karbon\": \"karbon\",\n\t\t\"vnd.kde.kchart\": \"chrt\",\n\t\t\"vnd.kde.kformula\": \"kfo\",\n\t\t\"vnd.kde.kivio\": \"flw\",\n\t\t\"vnd.kde.kontour\": \"kon\",\n\t\t\"vnd.kde.kpresenter\": [\n\t\t\t\"kpr\",\n\t\t\t\"kpt\"\n\t\t],\n\t\t\"vnd.kde.kspread\": \"ksp\",\n\t\t\"vnd.kde.kword\": [\n\t\t\t\"kwd\",\n\t\t\t\"kwt\"\n\t\t],\n\t\t\"vnd.kenameaapp\": \"htke\",\n\t\t\"vnd.kidspiration\": \"kia\",\n\t\t\"vnd.kinar\": [\n\t\t\t\"kne\",\n\t\t\t\"knp\"\n\t\t],\n\t\t\"vnd.koan\": [\n\t\t\t\"skp\",\n\t\t\t\"skd\",\n\t\t\t\"skt\",\n\t\t\t\"skm\"\n\t\t],\n\t\t\"vnd.kodak-descriptor\": \"sse\",\n\t\t\"vnd.las.las+xml\": \"lasxml\",\n\t\t\"vnd.llamagraphics.life-balance.desktop\": \"lbd\",\n\t\t\"vnd.llamagraphics.life-balance.exchange+xml\": \"lbe\",\n\t\t\"vnd.lotus-1-2-3\": \"123\",\n\t\t\"vnd.lotus-approach\": \"apr\",\n\t\t\"vnd.lotus-freelance\": \"pre\",\n\t\t\"vnd.lotus-notes\": \"nsf\",\n\t\t\"vnd.lotus-organizer\": \"org\",\n\t\t\"vnd.lotus-screencam\": \"scm\",\n\t\t\"vnd.lotus-wordpro\": \"lwp\",\n\t\t\"vnd.macports.portpkg\": \"portpkg\",\n\t\t\"vnd.mcd\": \"mcd\",\n\t\t\"vnd.medcalcdata\": \"mc1\",\n\t\t\"vnd.mediastation.cdkey\": \"cdkey\",\n\t\t\"vnd.mfer\": \"mwf\",\n\t\t\"vnd.mfmp\": \"mfm\",\n\t\t\"vnd.micrografx.flo\": \"flo\",\n\t\t\"vnd.micrografx.igx\": \"igx\",\n\t\t\"vnd.mif\": \"mif\",\n\t\t\"vnd.mobius.daf\": \"daf\",\n\t\t\"vnd.mobius.dis\": \"dis\",\n\t\t\"vnd.mobius.mbk\": \"mbk\",\n\t\t\"vnd.mobius.mqy\": \"mqy\",\n\t\t\"vnd.mobius.msl\": \"msl\",\n\t\t\"vnd.mobius.plc\": \"plc\",\n\t\t\"vnd.mobius.txf\": \"txf\",\n\t\t\"vnd.mophun.application\": \"mpn\",\n\t\t\"vnd.mophun.certificate\": \"mpc\",\n\t\t\"vnd.ms-artgalry\": \"cil\",\n\t\t\"vnd.ms-cab-compressed\": \"cab\",\n\t\t\"vnd.ms-excel.addin.macroenabled.12\": \"xlam\",\n\t\t\"vnd.ms-excel.sheet.binary.macroenabled.12\": \"xlsb\",\n\t\t\"vnd.ms-excel.sheet.macroenabled.12\": \"xlsm\",\n\t\t\"vnd.ms-excel.template.macroenabled.12\": \"xltm\",\n\t\t\"vnd.ms-fontobject\": \"eot\",\n\t\t\"vnd.ms-htmlhelp\": \"chm\",\n\t\t\"vnd.ms-ims\": \"ims\",\n\t\t\"vnd.ms-lrm\": \"lrm\",\n\t\t\"vnd.ms-officetheme\": \"thmx\",\n\t\t\"vnd.ms-powerpoint.addin.macroenabled.12\": \"ppam\",\n\t\t\"vnd.ms-powerpoint.presentation.macroenabled.12\": \"pptm\",\n\t\t\"vnd.ms-powerpoint.slide.macroenabled.12\": \"sldm\",\n\t\t\"vnd.ms-powerpoint.slideshow.macroenabled.12\": \"ppsm\",\n\t\t\"vnd.ms-powerpoint.template.macroenabled.12\": \"potm\",\n\t\t\"vnd.ms-project\": [\n\t\t\t\"mpp\",\n\t\t\t\"mpt\"\n\t\t],\n\t\t\"vnd.ms-word.document.macroenabled.12\": \"docm\",\n\t\t\"vnd.ms-word.template.macroenabled.12\": \"dotm\",\n\t\t\"vnd.ms-works\": [\n\t\t\t\"wps\",\n\t\t\t\"wks\",\n\t\t\t\"wcm\",\n\t\t\t\"wdb\"\n\t\t],\n\t\t\"vnd.ms-wpl\": \"wpl\",\n\t\t\"vnd.ms-xpsdocument\": \"xps\",\n\t\t\"vnd.mseq\": \"mseq\",\n\t\t\"vnd.musician\": \"mus\",\n\t\t\"vnd.muvee.style\": \"msty\",\n\t\t\"vnd.mynfc\": \"taglet\",\n\t\t\"vnd.neurolanguage.nlu\": \"nlu\",\n\t\t\"vnd.nitf\": [\n\t\t\t\"ntf\",\n\t\t\t\"nitf\"\n\t\t],\n\t\t\"vnd.noblenet-directory\": \"nnd\",\n\t\t\"vnd.noblenet-sealer\": \"nns\",\n\t\t\"vnd.noblenet-web\": \"nnw\",\n\t\t\"vnd.nokia.n-gage.data\": \"ngdat\",\n\t\t\"vnd.nokia.n-gage.symbian.install\": \"n-gage\",\n\t\t\"vnd.nokia.radio-preset\": \"rpst\",\n\t\t\"vnd.nokia.radio-presets\": \"rpss\",\n\t\t\"vnd.novadigm.edm\": \"edm\",\n\t\t\"vnd.novadigm.edx\": \"edx\",\n\t\t\"vnd.novadigm.ext\": \"ext\",\n\t\t\"vnd.oasis.opendocument.chart-template\": \"otc\",\n\t\t\"vnd.oasis.opendocument.formula-template\": \"odft\",\n\t\t\"vnd.oasis.opendocument.image-template\": \"oti\",\n\t\t\"vnd.olpc-sugar\": \"xo\",\n\t\t\"vnd.oma.dd2+xml\": \"dd2\",\n\t\t\"vnd.openofficeorg.extension\": \"oxt\",\n\t\t\"vnd.openxmlformats-officedocument.presentationml.slide\": \"sldx\",\n\t\t\"vnd.osgeo.mapguide.package\": \"mgp\",\n\t\t\"vnd.osgi.dp\": \"dp\",\n\t\t\"vnd.osgi.subsystem\": \"esa\",\n\t\t\"vnd.palm\": [\n\t\t\t\"pdb\",\n\t\t\t\"pqa\",\n\t\t\t\"oprc\"\n\t\t],\n\t\t\"vnd.pawaafile\": \"paw\",\n\t\t\"vnd.pg.format\": \"str\",\n\t\t\"vnd.pg.osasli\": \"ei6\",\n\t\t\"vnd.picsel\": \"efif\",\n\t\t\"vnd.pmi.widget\": \"wg\",\n\t\t\"vnd.pocketlearn\": \"plf\",\n\t\t\"vnd.powerbuilder6\": \"pbd\",\n\t\t\"vnd.previewsystems.box\": \"box\",\n\t\t\"vnd.proteus.magazine\": \"mgz\",\n\t\t\"vnd.publishare-delta-tree\": \"qps\",\n\t\t\"vnd.pvi.ptid1\": \"ptid\",\n\t\t\"vnd.quark.quarkxpress\": [\n\t\t\t\"qxd\",\n\t\t\t\"qxt\",\n\t\t\t\"qwd\",\n\t\t\t\"qwt\",\n\t\t\t\"qxl\",\n\t\t\t\"qxb\"\n\t\t],\n\t\t\"vnd.realvnc.bed\": \"bed\",\n\t\t\"vnd.recordare.musicxml\": \"mxl\",\n\t\t\"vnd.recordare.musicxml+xml\": \"musicxml\",\n\t\t\"vnd.rig.cryptonote\": \"cryptonote\",\n\t\t\"vnd.rn-realmedia\": \"rm\",\n\t\t\"vnd.rn-realmedia-vbr\": \"rmvb\",\n\t\t\"vnd.route66.link66+xml\": \"link66\",\n\t\t\"vnd.sailingtracker.track\": \"st\",\n\t\t\"vnd.seemail\": \"see\",\n\t\t\"vnd.sema\": \"sema\",\n\t\t\"vnd.semd\": \"semd\",\n\t\t\"vnd.semf\": \"semf\",\n\t\t\"vnd.shana.informed.formdata\": \"ifm\",\n\t\t\"vnd.shana.informed.formtemplate\": \"itp\",\n\t\t\"vnd.shana.informed.interchange\": \"iif\",\n\t\t\"vnd.shana.informed.package\": \"ipk\",\n\t\t\"vnd.simtech-mindmapper\": [\n\t\t\t\"twd\",\n\t\t\t\"twds\"\n\t\t],\n\t\t\"vnd.smart.teacher\": \"teacher\",\n\t\t\"vnd.solent.sdkm+xml\": [\n\t\t\t\"sdkm\",\n\t\t\t\"sdkd\"\n\t\t],\n\t\t\"vnd.spotfire.dxp\": \"dxp\",\n\t\t\"vnd.spotfire.sfs\": \"sfs\",\n\t\t\"vnd.stepmania.package\": \"smzip\",\n\t\t\"vnd.stepmania.stepchart\": \"sm\",\n\t\t\"vnd.sus-calendar\": [\n\t\t\t\"sus\",\n\t\t\t\"susp\"\n\t\t],\n\t\t\"vnd.svd\": \"svd\",\n\t\t\"vnd.syncml+xml\": \"xsm\",\n\t\t\"vnd.syncml.dm+wbxml\": \"bdm\",\n\t\t\"vnd.syncml.dm+xml\": \"xdm\",\n\t\t\"vnd.tao.intent-module-archive\": \"tao\",\n\t\t\"vnd.tcpdump.pcap\": [\n\t\t\t\"pcap\",\n\t\t\t\"cap\",\n\t\t\t\"dmp\"\n\t\t],\n\t\t\"vnd.tmobile-livetv\": \"tmo\",\n\t\t\"vnd.trid.tpt\": \"tpt\",\n\t\t\"vnd.triscape.mxs\": \"mxs\",\n\t\t\"vnd.trueapp\": \"tra\",\n\t\t\"vnd.ufdl\": [\n\t\t\t\"ufd\",\n\t\t\t\"ufdl\"\n\t\t],\n\t\t\"vnd.uiq.theme\": \"utz\",\n\t\t\"vnd.umajin\": \"umj\",\n\t\t\"vnd.unity\": \"unityweb\",\n\t\t\"vnd.uoml+xml\": \"uoml\",\n\t\t\"vnd.vcx\": \"vcx\",\n\t\t\"vnd.visionary\": \"vis\",\n\t\t\"vnd.vsf\": \"vsf\",\n\t\t\"vnd.webturbo\": \"wtb\",\n\t\t\"vnd.wolfram.player\": \"nbp\",\n\t\t\"vnd.wqd\": \"wqd\",\n\t\t\"vnd.wt.stf\": \"stf\",\n\t\t\"vnd.xara\": \"xar\",\n\t\t\"vnd.xfdl\": \"xfdl\",\n\t\t\"vnd.yamaha.hv-dic\": \"hvd\",\n\t\t\"vnd.yamaha.hv-script\": \"hvs\",\n\t\t\"vnd.yamaha.hv-voice\": \"hvp\",\n\t\t\"vnd.yamaha.openscoreformat\": \"osf\",\n\t\t\"vnd.yamaha.openscoreformat.osfpvg+xml\": \"osfpvg\",\n\t\t\"vnd.yamaha.smaf-audio\": \"saf\",\n\t\t\"vnd.yamaha.smaf-phrase\": \"spf\",\n\t\t\"vnd.yellowriver-custom-menu\": \"cmp\",\n\t\t\"vnd.zul\": [\n\t\t\t\"zir\",\n\t\t\t\"zirz\"\n\t\t],\n\t\t\"vnd.zzazz.deck+xml\": \"zaz\",\n\t\t\"voicexml+xml\": \"vxml\",\n\t\t\"widget\": \"wgt\",\n\t\t\"winhlp\": \"hlp\",\n\t\t\"wsdl+xml\": \"wsdl\",\n\t\t\"wspolicy+xml\": \"wspolicy\",\n\t\t\"x-ace-compressed\": \"ace\",\n\t\t\"x-authorware-bin\": [\n\t\t\t\"aab\",\n\t\t\t\"x32\",\n\t\t\t\"u32\",\n\t\t\t\"vox\"\n\t\t],\n\t\t\"x-authorware-map\": \"aam\",\n\t\t\"x-authorware-seg\": \"aas\",\n\t\t\"x-blorb\": [\n\t\t\t\"blb\",\n\t\t\t\"blorb\"\n\t\t],\n\t\t\"x-bzip\": \"bz\",\n\t\t\"x-bzip2\": [\n\t\t\t\"bz2\",\n\t\t\t\"boz\"\n\t\t],\n\t\t\"x-cfs-compressed\": \"cfs\",\n\t\t\"x-chat\": \"chat\",\n\t\t\"x-conference\": \"nsc\",\n\t\t\"x-dgc-compressed\": \"dgc\",\n\t\t\"x-dtbncx+xml\": \"ncx\",\n\t\t\"x-dtbook+xml\": \"dtb\",\n\t\t\"x-dtbresource+xml\": \"res\",\n\t\t\"x-eva\": \"eva\",\n\t\t\"x-font-bdf\": \"bdf\",\n\t\t\"x-font-ghostscript\": \"gsf\",\n\t\t\"x-font-linux-psf\": \"psf\",\n\t\t\"x-font-pcf\": \"pcf\",\n\t\t\"x-font-snf\": \"snf\",\n\t\t\"x-font-ttf\": [\n\t\t\t\"ttf\",\n\t\t\t\"ttc\"\n\t\t],\n\t\t\"x-font-type1\": [\n\t\t\t\"pfa\",\n\t\t\t\"pfb\",\n\t\t\t\"pfm\",\n\t\t\t\"afm\"\n\t\t],\n\t\t\"x-freearc\": \"arc\",\n\t\t\"x-gca-compressed\": \"gca\",\n\t\t\"x-glulx\": \"ulx\",\n\t\t\"x-gramps-xml\": \"gramps\",\n\t\t\"x-install-instructions\": \"install\",\n\t\t\"x-lzh-compressed\": [\n\t\t\t\"lzh\",\n\t\t\t\"lha\"\n\t\t],\n\t\t\"x-mie\": \"mie\",\n\t\t\"x-mobipocket-ebook\": [\n\t\t\t\"prc\",\n\t\t\t\"mobi\"\n\t\t],\n\t\t\"x-ms-application\": \"application\",\n\t\t\"x-ms-shortcut\": \"lnk\",\n\t\t\"x-ms-xbap\": \"xbap\",\n\t\t\"x-msbinder\": \"obd\",\n\t\t\"x-mscardfile\": \"crd\",\n\t\t\"x-msclip\": \"clp\",\n\t\t\"application/x-ms-installer\": \"msi\",\n\t\t\"x-msmediaview\": [\n\t\t\t\"mvb\",\n\t\t\t\"m13\",\n\t\t\t\"m14\"\n\t\t],\n\t\t\"x-msmetafile\": [\n\t\t\t\"wmf\",\n\t\t\t\"wmz\",\n\t\t\t\"emf\",\n\t\t\t\"emz\"\n\t\t],\n\t\t\"x-msmoney\": \"mny\",\n\t\t\"x-mspublisher\": \"pub\",\n\t\t\"x-msschedule\": \"scd\",\n\t\t\"x-msterminal\": \"trm\",\n\t\t\"x-mswrite\": \"wri\",\n\t\t\"x-nzb\": \"nzb\",\n\t\t\"x-pkcs12\": [\n\t\t\t\"p12\",\n\t\t\t\"pfx\"\n\t\t],\n\t\t\"x-pkcs7-certificates\": [\n\t\t\t\"p7b\",\n\t\t\t\"spc\"\n\t\t],\n\t\t\"x-research-info-systems\": \"ris\",\n\t\t\"x-silverlight-app\": \"xap\",\n\t\t\"x-sql\": \"sql\",\n\t\t\"x-stuffitx\": \"sitx\",\n\t\t\"x-subrip\": \"srt\",\n\t\t\"x-t3vm-image\": \"t3\",\n\t\t\"x-tex-tfm\": \"tfm\",\n\t\t\"x-tgif\": \"obj\",\n\t\t\"x-xliff+xml\": \"xlf\",\n\t\t\"x-xz\": \"xz\",\n\t\t\"x-zmachine\": [\n\t\t\t\"z1\",\n\t\t\t\"z2\",\n\t\t\t\"z3\",\n\t\t\t\"z4\",\n\t\t\t\"z5\",\n\t\t\t\"z6\",\n\t\t\t\"z7\",\n\t\t\t\"z8\"\n\t\t],\n\t\t\"xaml+xml\": \"xaml\",\n\t\t\"xcap-diff+xml\": \"xdf\",\n\t\t\"xenc+xml\": \"xenc\",\n\t\t\"xml-dtd\": \"dtd\",\n\t\t\"xop+xml\": \"xop\",\n\t\t\"xproc+xml\": \"xpl\",\n\t\t\"xslt+xml\": \"xslt\",\n\t\t\"xv+xml\": [\n\t\t\t\"mxml\",\n\t\t\t\"xhvml\",\n\t\t\t\"xvml\",\n\t\t\t\"xvm\"\n\t\t],\n\t\t\"yang\": \"yang\",\n\t\t\"yin+xml\": \"yin\",\n\t\t\"envoy\": \"evy\",\n\t\t\"fractals\": \"fif\",\n\t\t\"internet-property-stream\": \"acx\",\n\t\t\"olescript\": \"axs\",\n\t\t\"vnd.ms-outlook\": \"msg\",\n\t\t\"vnd.ms-pkicertstore\": \"sst\",\n\t\t\"x-compress\": \"z\",\n\t\t\"x-perfmon\": [\n\t\t\t\"pma\",\n\t\t\t\"pmc\",\n\t\t\t\"pmr\",\n\t\t\t\"pmw\"\n\t\t],\n\t\t\"ynd.ms-pkipko\": \"pko\",\n\t\t\"gzip\": [\n\t\t\t\"gz\",\n\t\t\t\"tgz\"\n\t\t],\n\t\t\"smil+xml\": [\n\t\t\t\"smi\",\n\t\t\t\"smil\"\n\t\t],\n\t\t\"vnd.debian.binary-package\": [\n\t\t\t\"deb\",\n\t\t\t\"udeb\"\n\t\t],\n\t\t\"vnd.hzn-3d-crossword\": \"x3d\",\n\t\t\"vnd.sqlite3\": [\n\t\t\t\"db\",\n\t\t\t\"sqlite\",\n\t\t\t\"sqlite3\",\n\t\t\t\"db-wal\",\n\t\t\t\"sqlite-wal\",\n\t\t\t\"db-shm\",\n\t\t\t\"sqlite-shm\"\n\t\t],\n\t\t\"vnd.wap.sic\": \"sic\",\n\t\t\"vnd.wap.slc\": \"slc\",\n\t\t\"x-krita\": [\n\t\t\t\"kra\",\n\t\t\t\"krz\"\n\t\t],\n\t\t\"x-perl\": [\n\t\t\t\"pm\",\n\t\t\t\"pl\"\n\t\t],\n\t\t\"yaml\": [\n\t\t\t\"yaml\",\n\t\t\t\"yml\"\n\t\t]\n\t},\n\t\"audio\": {\n\t\t\"amr\": \"amr\",\n\t\t\"amr-wb\": \"awb\",\n\t\t\"annodex\": \"axa\",\n\t\t\"basic\": [\n\t\t\t\"au\",\n\t\t\t\"snd\"\n\t\t],\n\t\t\"flac\": \"flac\",\n\t\t\"midi\": [\n\t\t\t\"mid\",\n\t\t\t\"midi\",\n\t\t\t\"kar\",\n\t\t\t\"rmi\"\n\t\t],\n\t\t\"mpeg\": [\n\t\t\t\"mpga\",\n\t\t\t\"mpega\",\n\t\t\t\"mp3\",\n\t\t\t\"m4a\",\n\t\t\t\"mp2a\",\n\t\t\t\"m2a\",\n\t\t\t\"m3a\"\n\t\t],\n\t\t\"mpegurl\": \"m3u\",\n\t\t\"ogg\": [\n\t\t\t\"oga\",\n\t\t\t\"ogg\",\n\t\t\t\"spx\"\n\t\t],\n\t\t\"prs.sid\": \"sid\",\n\t\t\"x-aiff\": \"aifc\",\n\t\t\"x-gsm\": \"gsm\",\n\t\t\"x-ms-wma\": \"wma\",\n\t\t\"x-ms-wax\": \"wax\",\n\t\t\"x-pn-realaudio\": \"ram\",\n\t\t\"x-realaudio\": \"ra\",\n\t\t\"x-sd2\": \"sd2\",\n\t\t\"adpcm\": \"adp\",\n\t\t\"mp4\": \"mp4a\",\n\t\t\"s3m\": \"s3m\",\n\t\t\"silk\": \"sil\",\n\t\t\"vnd.dece.audio\": [\n\t\t\t\"uva\",\n\t\t\t\"uvva\"\n\t\t],\n\t\t\"vnd.digital-winds\": \"eol\",\n\t\t\"vnd.dra\": \"dra\",\n\t\t\"vnd.dts\": \"dts\",\n\t\t\"vnd.dts.hd\": \"dtshd\",\n\t\t\"vnd.lucent.voice\": \"lvp\",\n\t\t\"vnd.ms-playready.media.pya\": \"pya\",\n\t\t\"vnd.nuera.ecelp4800\": \"ecelp4800\",\n\t\t\"vnd.nuera.ecelp7470\": \"ecelp7470\",\n\t\t\"vnd.nuera.ecelp9600\": \"ecelp9600\",\n\t\t\"vnd.rip\": \"rip\",\n\t\t\"webm\": \"weba\",\n\t\t\"x-caf\": \"caf\",\n\t\t\"x-matroska\": \"mka\",\n\t\t\"x-pn-realaudio-plugin\": \"rmp\",\n\t\t\"xm\": \"xm\",\n\t\t\"aac\": \"aac\",\n\t\t\"aiff\": [\n\t\t\t\"aiff\",\n\t\t\t\"aif\",\n\t\t\t\"aff\"\n\t\t],\n\t\t\"opus\": \"opus\",\n\t\t\"wav\": \"wav\"\n\t},\n\t\"chemical\": {\n\t\t\"x-alchemy\": \"alc\",\n\t\t\"x-cache\": [\n\t\t\t\"cac\",\n\t\t\t\"cache\"\n\t\t],\n\t\t\"x-cache-csf\": \"csf\",\n\t\t\"x-cactvs-binary\": [\n\t\t\t\"cbin\",\n\t\t\t\"cascii\",\n\t\t\t\"ctab\"\n\t\t],\n\t\t\"x-cdx\": \"cdx\",\n\t\t\"x-chem3d\": \"c3d\",\n\t\t\"x-cif\": \"cif\",\n\t\t\"x-cmdf\": \"cmdf\",\n\t\t\"x-cml\": \"cml\",\n\t\t\"x-compass\": \"cpa\",\n\t\t\"x-crossfire\": \"bsd\",\n\t\t\"x-csml\": [\n\t\t\t\"csml\",\n\t\t\t\"csm\"\n\t\t],\n\t\t\"x-ctx\": \"ctx\",\n\t\t\"x-cxf\": [\n\t\t\t\"cxf\",\n\t\t\t\"cef\"\n\t\t],\n\t\t\"x-embl-dl-nucleotide\": [\n\t\t\t\"emb\",\n\t\t\t\"embl\"\n\t\t],\n\t\t\"x-gamess-input\": [\n\t\t\t\"inp\",\n\t\t\t\"gam\",\n\t\t\t\"gamin\"\n\t\t],\n\t\t\"x-gaussian-checkpoint\": [\n\t\t\t\"fch\",\n\t\t\t\"fchk\"\n\t\t],\n\t\t\"x-gaussian-cube\": \"cub\",\n\t\t\"x-gaussian-input\": [\n\t\t\t\"gau\",\n\t\t\t\"gjc\",\n\t\t\t\"gjf\"\n\t\t],\n\t\t\"x-gaussian-log\": \"gal\",\n\t\t\"x-gcg8-sequence\": \"gcg\",\n\t\t\"x-genbank\": \"gen\",\n\t\t\"x-hin\": \"hin\",\n\t\t\"x-isostar\": [\n\t\t\t\"istr\",\n\t\t\t\"ist\"\n\t\t],\n\t\t\"x-jcamp-dx\": [\n\t\t\t\"jdx\",\n\t\t\t\"dx\"\n\t\t],\n\t\t\"x-kinemage\": \"kin\",\n\t\t\"x-macmolecule\": \"mcm\",\n\t\t\"x-macromodel-input\": \"mmod\",\n\t\t\"x-mdl-molfile\": \"mol\",\n\t\t\"x-mdl-rdfile\": \"rd\",\n\t\t\"x-mdl-rxnfile\": \"rxn\",\n\t\t\"x-mdl-sdfile\": \"sd\",\n\t\t\"x-mdl-tgf\": \"tgf\",\n\t\t\"x-mmcif\": \"mcif\",\n\t\t\"x-mol2\": \"mol2\",\n\t\t\"x-molconn-Z\": \"b\",\n\t\t\"x-mopac-graph\": \"gpt\",\n\t\t\"x-mopac-input\": [\n\t\t\t\"mop\",\n\t\t\t\"mopcrt\",\n\t\t\t\"zmt\"\n\t\t],\n\t\t\"x-mopac-out\": \"moo\",\n\t\t\"x-ncbi-asn1\": \"asn\",\n\t\t\"x-ncbi-asn1-ascii\": [\n\t\t\t\"prt\",\n\t\t\t\"ent\"\n\t\t],\n\t\t\"x-ncbi-asn1-binary\": \"val\",\n\t\t\"x-rosdal\": \"ros\",\n\t\t\"x-swissprot\": \"sw\",\n\t\t\"x-vamas-iso14976\": \"vms\",\n\t\t\"x-vmd\": \"vmd\",\n\t\t\"x-xtel\": \"xtel\",\n\t\t\"x-xyz\": \"xyz\"\n\t},\n\t\"font\": {\n\t\t\"otf\": \"otf\",\n\t\t\"woff\": \"woff\",\n\t\t\"woff2\": \"woff2\"\n\t},\n\t\"image\": {\n\t\t\"gif\": \"gif\",\n\t\t\"ief\": \"ief\",\n\t\t\"jpeg\": [\n\t\t\t\"jpeg\",\n\t\t\t\"jpg\",\n\t\t\t\"jpe\",\n\t\t\t\"jfif\",\n\t\t\t\"jfif-tbnl\",\n\t\t\t\"jif\"\n\t\t],\n\t\t\"pcx\": \"pcx\",\n\t\t\"png\": \"png\",\n\t\t\"svg+xml\": [\n\t\t\t\"svg\",\n\t\t\t\"svgz\"\n\t\t],\n\t\t\"tiff\": [\n\t\t\t\"tiff\",\n\t\t\t\"tif\"\n\t\t],\n\t\t\"vnd.djvu\": [\n\t\t\t\"djvu\",\n\t\t\t\"djv\"\n\t\t],\n\t\t\"vnd.wap.wbmp\": \"wbmp\",\n\t\t\"x-canon-cr2\": \"cr2\",\n\t\t\"x-canon-crw\": \"crw\",\n\t\t\"x-cmu-raster\": \"ras\",\n\t\t\"x-coreldraw\": \"cdr\",\n\t\t\"x-coreldrawpattern\": \"pat\",\n\t\t\"x-coreldrawtemplate\": \"cdt\",\n\t\t\"x-corelphotopaint\": \"cpt\",\n\t\t\"x-epson-erf\": \"erf\",\n\t\t\"x-icon\": \"ico\",\n\t\t\"x-jg\": \"art\",\n\t\t\"x-jng\": \"jng\",\n\t\t\"x-nikon-nef\": \"nef\",\n\t\t\"x-olympus-orf\": \"orf\",\n\t\t\"x-portable-anymap\": \"pnm\",\n\t\t\"x-portable-bitmap\": \"pbm\",\n\t\t\"x-portable-graymap\": \"pgm\",\n\t\t\"x-portable-pixmap\": \"ppm\",\n\t\t\"x-rgb\": \"rgb\",\n\t\t\"x-xbitmap\": \"xbm\",\n\t\t\"x-xpixmap\": \"xpm\",\n\t\t\"x-xwindowdump\": \"xwd\",\n\t\t\"bmp\": \"bmp\",\n\t\t\"cgm\": \"cgm\",\n\t\t\"g3fax\": \"g3\",\n\t\t\"ktx\": \"ktx\",\n\t\t\"prs.btif\": \"btif\",\n\t\t\"sgi\": \"sgi\",\n\t\t\"vnd.dece.graphic\": [\n\t\t\t\"uvi\",\n\t\t\t\"uvvi\",\n\t\t\t\"uvg\",\n\t\t\t\"uvvg\"\n\t\t],\n\t\t\"vnd.dwg\": \"dwg\",\n\t\t\"vnd.dxf\": \"dxf\",\n\t\t\"vnd.fastbidsheet\": \"fbs\",\n\t\t\"vnd.fpx\": \"fpx\",\n\t\t\"vnd.fst\": \"fst\",\n\t\t\"vnd.fujixerox.edmics-mmr\": \"mmr\",\n\t\t\"vnd.fujixerox.edmics-rlc\": \"rlc\",\n\t\t\"vnd.ms-modi\": \"mdi\",\n\t\t\"vnd.ms-photo\": \"wdp\",\n\t\t\"vnd.net-fpx\": \"npx\",\n\t\t\"vnd.xiff\": \"xif\",\n\t\t\"webp\": \"webp\",\n\t\t\"x-3ds\": \"3ds\",\n\t\t\"x-cmx\": \"cmx\",\n\t\t\"x-freehand\": [\n\t\t\t\"fh\",\n\t\t\t\"fhc\",\n\t\t\t\"fh4\",\n\t\t\t\"fh5\",\n\t\t\t\"fh7\"\n\t\t],\n\t\t\"x-pict\": [\n\t\t\t\"pic\",\n\t\t\t\"pct\"\n\t\t],\n\t\t\"x-tga\": \"tga\",\n\t\t\"cis-cod\": \"cod\",\n\t\t\"avif\": \"avifs\",\n\t\t\"heic\": [\n\t\t\t\"heif\",\n\t\t\t\"heic\"\n\t\t],\n\t\t\"pjpeg\": [\n\t\t\t\"pjpg\"\n\t\t],\n\t\t\"vnd.adobe.photoshop\": \"psd\",\n\t\t\"x-adobe-dng\": \"dng\",\n\t\t\"x-fuji-raf\": \"raf\",\n\t\t\"x-icns\": \"icns\",\n\t\t\"x-kodak-dcr\": \"dcr\",\n\t\t\"x-kodak-k25\": \"k25\",\n\t\t\"x-kodak-kdc\": \"kdc\",\n\t\t\"x-minolta-mrw\": \"mrw\",\n\t\t\"x-panasonic-raw\": [\n\t\t\t\"raw\",\n\t\t\t\"rw2\",\n\t\t\t\"rwl\"\n\t\t],\n\t\t\"x-pentax-pef\": [\n\t\t\t\"pef\",\n\t\t\t\"ptx\"\n\t\t],\n\t\t\"x-sigma-x3f\": \"x3f\",\n\t\t\"x-sony-arw\": \"arw\",\n\t\t\"x-sony-sr2\": \"sr2\",\n\t\t\"x-sony-srf\": \"srf\"\n\t},\n\t\"message\": {\n\t\t\"rfc822\": [\n\t\t\t\"eml\",\n\t\t\t\"mime\",\n\t\t\t\"mht\",\n\t\t\t\"mhtml\",\n\t\t\t\"nws\"\n\t\t]\n\t},\n\t\"model\": {\n\t\t\"iges\": [\n\t\t\t\"igs\",\n\t\t\t\"iges\"\n\t\t],\n\t\t\"mesh\": [\n\t\t\t\"msh\",\n\t\t\t\"mesh\",\n\t\t\t\"silo\"\n\t\t],\n\t\t\"vrml\": [\n\t\t\t\"wrl\",\n\t\t\t\"vrml\"\n\t\t],\n\t\t\"x3d+vrml\": [\n\t\t\t\"x3dv\",\n\t\t\t\"x3dvz\"\n\t\t],\n\t\t\"x3d+xml\": \"x3dz\",\n\t\t\"x3d+binary\": [\n\t\t\t\"x3db\",\n\t\t\t\"x3dbz\"\n\t\t],\n\t\t\"vnd.collada+xml\": \"dae\",\n\t\t\"vnd.dwf\": \"dwf\",\n\t\t\"vnd.gdl\": \"gdl\",\n\t\t\"vnd.gtw\": \"gtw\",\n\t\t\"vnd.mts\": \"mts\",\n\t\t\"vnd.usdz+zip\": \"usdz\",\n\t\t\"vnd.vtu\": \"vtu\"\n\t},\n\t\"text\": {\n\t\t\"cache-manifest\": [\n\t\t\t\"manifest\",\n\t\t\t\"appcache\"\n\t\t],\n\t\t\"calendar\": [\n\t\t\t\"ics\",\n\t\t\t\"icz\",\n\t\t\t\"ifb\"\n\t\t],\n\t\t\"css\": \"css\",\n\t\t\"csv\": \"csv\",\n\t\t\"h323\": \"323\",\n\t\t\"html\": [\n\t\t\t\"html\",\n\t\t\t\"htm\",\n\t\t\t\"shtml\",\n\t\t\t\"stm\"\n\t\t],\n\t\t\"iuls\": \"uls\",\n\t\t\"plain\": [\n\t\t\t\"txt\",\n\t\t\t\"text\",\n\t\t\t\"brf\",\n\t\t\t\"conf\",\n\t\t\t\"def\",\n\t\t\t\"list\",\n\t\t\t\"log\",\n\t\t\t\"in\",\n\t\t\t\"bas\",\n\t\t\t\"diff\",\n\t\t\t\"ksh\"\n\t\t],\n\t\t\"richtext\": \"rtx\",\n\t\t\"scriptlet\": [\n\t\t\t\"sct\",\n\t\t\t\"wsc\"\n\t\t],\n\t\t\"texmacs\": \"tm\",\n\t\t\"tab-separated-values\": \"tsv\",\n\t\t\"vnd.sun.j2me.app-descriptor\": \"jad\",\n\t\t\"vnd.wap.wml\": \"wml\",\n\t\t\"vnd.wap.wmlscript\": \"wmls\",\n\t\t\"x-bibtex\": \"bib\",\n\t\t\"x-boo\": \"boo\",\n\t\t\"x-c++hdr\": [\n\t\t\t\"h++\",\n\t\t\t\"hpp\",\n\t\t\t\"hxx\",\n\t\t\t\"hh\"\n\t\t],\n\t\t\"x-c++src\": [\n\t\t\t\"c++\",\n\t\t\t\"cpp\",\n\t\t\t\"cxx\",\n\t\t\t\"cc\"\n\t\t],\n\t\t\"x-component\": \"htc\",\n\t\t\"x-dsrc\": \"d\",\n\t\t\"x-diff\": \"patch\",\n\t\t\"x-haskell\": \"hs\",\n\t\t\"x-java\": \"java\",\n\t\t\"x-literate-haskell\": \"lhs\",\n\t\t\"x-moc\": \"moc\",\n\t\t\"x-pascal\": [\n\t\t\t\"p\",\n\t\t\t\"pas\",\n\t\t\t\"pp\",\n\t\t\t\"inc\"\n\t\t],\n\t\t\"x-pcs-gcd\": \"gcd\",\n\t\t\"x-python\": \"py\",\n\t\t\"x-scala\": \"scala\",\n\t\t\"x-setext\": \"etx\",\n\t\t\"x-tcl\": [\n\t\t\t\"tcl\",\n\t\t\t\"tk\"\n\t\t],\n\t\t\"x-tex\": [\n\t\t\t\"tex\",\n\t\t\t\"ltx\",\n\t\t\t\"sty\",\n\t\t\t\"cls\"\n\t\t],\n\t\t\"x-vcalendar\": \"vcs\",\n\t\t\"x-vcard\": \"vcf\",\n\t\t\"n3\": \"n3\",\n\t\t\"prs.lines.tag\": \"dsc\",\n\t\t\"sgml\": [\n\t\t\t\"sgml\",\n\t\t\t\"sgm\"\n\t\t],\n\t\t\"troff\": [\n\t\t\t\"t\",\n\t\t\t\"tr\",\n\t\t\t\"roff\",\n\t\t\t\"man\",\n\t\t\t\"me\",\n\t\t\t\"ms\"\n\t\t],\n\t\t\"turtle\": \"ttl\",\n\t\t\"uri-list\": [\n\t\t\t\"uri\",\n\t\t\t\"uris\",\n\t\t\t\"urls\"\n\t\t],\n\t\t\"vcard\": \"vcard\",\n\t\t\"vnd.curl\": \"curl\",\n\t\t\"vnd.curl.dcurl\": \"dcurl\",\n\t\t\"vnd.curl.scurl\": \"scurl\",\n\t\t\"vnd.curl.mcurl\": \"mcurl\",\n\t\t\"vnd.dvb.subtitle\": \"sub\",\n\t\t\"vnd.fly\": \"fly\",\n\t\t\"vnd.fmi.flexstor\": \"flx\",\n\t\t\"vnd.graphviz\": \"gv\",\n\t\t\"vnd.in3d.3dml\": \"3dml\",\n\t\t\"vnd.in3d.spot\": \"spot\",\n\t\t\"x-asm\": [\n\t\t\t\"s\",\n\t\t\t\"asm\"\n\t\t],\n\t\t\"x-c\": [\n\t\t\t\"c\",\n\t\t\t\"h\",\n\t\t\t\"dic\"\n\t\t],\n\t\t\"x-fortran\": [\n\t\t\t\"f\",\n\t\t\t\"for\",\n\t\t\t\"f77\",\n\t\t\t\"f90\"\n\t\t],\n\t\t\"x-opml\": \"opml\",\n\t\t\"x-nfo\": \"nfo\",\n\t\t\"x-sfv\": \"sfv\",\n\t\t\"x-uuencode\": \"uu\",\n\t\t\"webviewhtml\": \"htt\",\n\t\t\"javascript\": \"js\",\n\t\t\"json\": \"json\",\n\t\t\"markdown\": [\n\t\t\t\"md\",\n\t\t\t\"markdown\",\n\t\t\t\"mdown\",\n\t\t\t\"markdn\"\n\t\t],\n\t\t\"vnd.wap.si\": \"si\",\n\t\t\"vnd.wap.sl\": \"sl\"\n\t},\n\t\"video\": {\n\t\t\"avif\": \"avif\",\n\t\t\"3gpp\": \"3gp\",\n\t\t\"annodex\": \"axv\",\n\t\t\"dl\": \"dl\",\n\t\t\"dv\": [\n\t\t\t\"dif\",\n\t\t\t\"dv\"\n\t\t],\n\t\t\"fli\": \"fli\",\n\t\t\"gl\": \"gl\",\n\t\t\"mpeg\": [\n\t\t\t\"mpeg\",\n\t\t\t\"mpg\",\n\t\t\t\"mpe\",\n\t\t\t\"m1v\",\n\t\t\t\"m2v\",\n\t\t\t\"mp2\",\n\t\t\t\"mpa\",\n\t\t\t\"mpv2\"\n\t\t],\n\t\t\"mp4\": [\n\t\t\t\"mp4\",\n\t\t\t\"mp4v\",\n\t\t\t\"mpg4\"\n\t\t],\n\t\t\"quicktime\": [\n\t\t\t\"qt\",\n\t\t\t\"mov\"\n\t\t],\n\t\t\"ogg\": \"ogv\",\n\t\t\"vnd.mpegurl\": [\n\t\t\t\"mxu\",\n\t\t\t\"m4u\"\n\t\t],\n\t\t\"x-flv\": \"flv\",\n\t\t\"x-la-asf\": [\n\t\t\t\"lsf\",\n\t\t\t\"lsx\"\n\t\t],\n\t\t\"x-mng\": \"mng\",\n\t\t\"x-ms-asf\": [\n\t\t\t\"asf\",\n\t\t\t\"asx\",\n\t\t\t\"asr\"\n\t\t],\n\t\t\"x-ms-wm\": \"wm\",\n\t\t\"x-ms-wmv\": \"wmv\",\n\t\t\"x-ms-wmx\": \"wmx\",\n\t\t\"x-ms-wvx\": \"wvx\",\n\t\t\"x-msvideo\": \"avi\",\n\t\t\"x-sgi-movie\": \"movie\",\n\t\t\"x-matroska\": [\n\t\t\t\"mpv\",\n\t\t\t\"mkv\",\n\t\t\t\"mk3d\",\n\t\t\t\"mks\"\n\t\t],\n\t\t\"3gpp2\": \"3g2\",\n\t\t\"h261\": \"h261\",\n\t\t\"h263\": \"h263\",\n\t\t\"h264\": \"h264\",\n\t\t\"jpeg\": \"jpgv\",\n\t\t\"jpm\": [\n\t\t\t\"jpm\",\n\t\t\t\"jpgm\"\n\t\t],\n\t\t\"mj2\": [\n\t\t\t\"mj2\",\n\t\t\t\"mjp2\"\n\t\t],\n\t\t\"vnd.dece.hd\": [\n\t\t\t\"uvh\",\n\t\t\t\"uvvh\"\n\t\t],\n\t\t\"vnd.dece.mobile\": [\n\t\t\t\"uvm\",\n\t\t\t\"uvvm\"\n\t\t],\n\t\t\"vnd.dece.pd\": [\n\t\t\t\"uvp\",\n\t\t\t\"uvvp\"\n\t\t],\n\t\t\"vnd.dece.sd\": [\n\t\t\t\"uvs\",\n\t\t\t\"uvvs\"\n\t\t],\n\t\t\"vnd.dece.video\": [\n\t\t\t\"uvv\",\n\t\t\t\"uvvv\"\n\t\t],\n\t\t\"vnd.dvb.file\": \"dvb\",\n\t\t\"vnd.fvt\": \"fvt\",\n\t\t\"vnd.ms-playready.media.pyv\": \"pyv\",\n\t\t\"vnd.uvvu.mp4\": [\n\t\t\t\"uvu\",\n\t\t\t\"uvvu\"\n\t\t],\n\t\t\"vnd.vivo\": \"viv\",\n\t\t\"webm\": \"webm\",\n\t\t\"x-f4v\": \"f4v\",\n\t\t\"x-m4v\": \"m4v\",\n\t\t\"x-ms-vob\": \"vob\",\n\t\t\"x-smv\": \"smv\",\n\t\t\"mp2t\": \"ts\"\n\t},\n\t\"x-conference\": {\n\t\t\"x-cooltalk\": \"ice\"\n\t},\n\t\"x-world\": {\n\t\t\"x-vrml\": [\n\t\t\t\"vrm\",\n\t\t\t\"flr\",\n\t\t\t\"wrz\",\n\t\t\t\"xaf\",\n\t\t\t\"xof\"\n\t\t]\n\t}\n};\n\nconst mimeTypes = (() => {\n\tconst mimeTypes = {};\n\tfor (const type of Object.keys(table)) {\n\t\tfor (const subtype of Object.keys(table[type])) {\n\t\t\tconst value = table[type][subtype];\n\t\t\tif (typeof value == \"string\") {\n\t\t\t\tmimeTypes[value] = type + \"/\" + subtype;\n\t\t\t} else {\n\t\t\t\tfor (let indexMimeType = 0; indexMimeType < value.length; indexMimeType++) {\n\t\t\t\t\tmimeTypes[value[indexMimeType]] = type + \"/\" + subtype;\n\t\t\t\t}\n\t\t\t}\n\t\t}\n\t}\n\treturn mimeTypes;\n})();\n\nexport {\n\tmimeTypes,\n\tgetMimeType\n};\n\nfunction getMimeType(filename) {\n\treturn filename && mimeTypes[filename.split(\".\").pop().toLowerCase()] || getDefaultMimeType();\n}","import { TimeoutError } from \"./errors\";\n\n/**\n * Callback for progress updates while flashing or uploading an image.\n *\n * @callback FlashProgressCallback\n * @param {number} progress - Progress for the current action, between 0 and 1.\n */\nexport type FlashProgressCallback = (progress: number) => void;\n\n/**\n * Callback for factory image flashing progress.\n *\n * @callback FactoryProgressCallback\n * @param {string} action - Action in the flashing process, e.g. unpack/flash.\n * @param {string} item - Item processed by the action, e.g. partition being flashed.\n * @param {number} progress - Progress within the current action between 0 and 1.\n */\nexport type FactoryProgressCallback = (\n action: string,\n item: string,\n progress: number,\n) => void;\n\nfunction waitForFrame() {\n return new Promise((resolve) => {\n window.requestAnimationFrame(resolve);\n });\n}\n\nexport async function runWithTimedProgress<T>(\n onProgress: FactoryProgressCallback,\n action: string,\n item: string,\n duration: number,\n workPromise: Promise<T>,\n) {\n const startTime = new Date().getTime();\n let stop = false;\n\n onProgress(action, item, 0.0);\n const progressPromise = (async () => {\n let now;\n const targetTime = startTime + duration;\n\n do {\n now = new Date().getTime();\n onProgress(action, item, (now - startTime) / duration);\n await waitForFrame();\n } while (!stop && now < targetTime);\n })();\n\n await Promise.race([progressPromise, workPromise]);\n stop = true;\n await progressPromise;\n await workPromise;\n\n onProgress(action, item, 1.0);\n}\n\nexport function runWithTimeout<T>(\n promise: Promise<T>,\n timeout: number,\n): Promise<T> {\n return new Promise((resolve, reject) => {\n // Set up timeout\n let timedOut = false;\n const tid = setTimeout(() => {\n // Set sentinel first to prevent race in promise resolving\n timedOut = true;\n reject(new TimeoutError(timeout));\n }, timeout);\n\n // Passthrough\n promise\n .then((val) => {\n if (!timedOut) {\n resolve(val);\n }\n })\n .catch((err) => {\n if (!timedOut) {\n reject(err);\n }\n })\n .finally(() => {\n if (!timedOut) {\n clearTimeout(tid);\n }\n });\n });\n}\n","function t(t){const e='(t=>{\"function\"==typeof define&&define.amd?define(t):t()})(function(){\"use strict\";const{Array:t,Object:e,Number:n,Math:s,Error:r,Uint8Array:o,Uint16Array:i,Uint32Array:c,Int32Array:a,Map:h,DataView:f,Promise:l,TextEncoder:u,crypto:w,postMessage:p,TransformStream:d,ReadableStream:y,WritableStream:m,CompressionStream:g,DecompressionStream:S}=self,b=void 0,v=\"undefined\",k=\"function\",z=[];for(let t=0;256>t;t++){let e=t;for(let t=0;8>t;t++)1&e?e=e>>>1^3988292384:e>>>=1;z[t]=e}class C{constructor(t){this.t=t||-1}append(t){let e=0|this.t;for(let n=0,s=0|t.length;s>n;n++)e=e>>>8^z[255&(e^t[n])];this.t=e}get(){return~this.t}}class A extends d{constructor(){let t;const e=new C;super({transform(t,n){e.append(t),n.enqueue(t)},flush(){const n=new o(4);new f(n.buffer).setUint32(0,e.get()),t.value=n}}),t=this}}const x={concat(t,e){if(0===t.length||0===e.length)return t.concat(e);const n=t[t.length-1],s=x.o(n);return 32===s?t.concat(e):x.i(e,s,0|n,t.slice(0,t.length-1))},h(t){const e=t.length;if(0===e)return 0;const n=t[e-1];return 32*(e-1)+x.o(n)},l(t,e){if(32*t.length<e)return t;const n=(t=t.slice(0,s.ceil(e/32))).length;return e&=31,n>0&&e&&(t[n-1]=x.u(e,t[n-1]&2147483648>>e-1,1)),t},u:(t,e,n)=>32===t?e:(n?0|e:e<<32-t)+1099511627776*t,o:t=>s.round(t/1099511627776)||32,i(t,e,n,s){for(void 0===s&&(s=[]);e>=32;e-=32)s.push(n),n=0;if(0===e)return s.concat(t);for(let r=0;r<t.length;r++)s.push(n|t[r]>>>e),n=t[r]<<32-e;const r=t.length?t[t.length-1]:0,o=x.o(r);return s.push(x.u(e+o&31,e+o>32?n:s.pop(),1)),s}},I={bytes:{p(t){const e=x.h(t)/8,n=new o(e);let s;for(let r=0;e>r;r++)3&r||(s=t[r/4]),n[r]=s>>>24,s<<=8;return n},m(t){const e=[];let n,s=0;for(n=0;n<t.length;n++)s=s<<8|t[n],3&~n||(e.push(s),s=0);return 3&n&&e.push(x.u(8*(3&n),s)),e}}},R=class{constructor(t){const e=this;e.blockSize=512,e.S=[1732584193,4023233417,2562383102,271733878,3285377520],e.v=[1518500249,1859775393,2400959708,3395469782],t?(e.k=t.k.slice(0),e.C=t.C.slice(0),e.A=t.A):e.reset()}reset(){const t=this;return t.k=t.S.slice(0),t.C=[],t.A=0,t}update(t){const e=this;\"string\"==typeof t&&(t=I.I.m(t));const n=e.C=x.concat(e.C,t),s=e.A,o=e.A=s+x.h(t);if(o>9007199254740991)throw new r(\"Cannot hash more than 2^53 - 1 bits\");const i=new c(n);let a=0;for(let t=e.blockSize+s-(e.blockSize+s&e.blockSize-1);o>=t;t+=e.blockSize)e.R(i.subarray(16*a,16*(a+1))),a+=1;return n.splice(0,16*a),e}P(){const t=this;let e=t.C;const n=t.k;e=x.concat(e,[x.u(1,1)]);for(let t=e.length+2;15&t;t++)e.push(0);for(e.push(s.floor(t.A/4294967296)),e.push(0|t.A);e.length;)t.R(e.splice(0,16));return t.reset(),n}U(t,e,n,s){return t>19?t>39?t>59?t>79?void 0:e^n^s:e&n|e&s|n&s:e^n^s:e&n|~e&s}V(t,e){return e<<t|e>>>32-t}R(e){const n=this,r=n.k,o=t(80);for(let t=0;16>t;t++)o[t]=e[t];let i=r[0],c=r[1],a=r[2],h=r[3],f=r[4];for(let t=0;79>=t;t++){16>t||(o[t]=n.V(1,o[t-3]^o[t-8]^o[t-14]^o[t-16]));const e=n.V(5,i)+n.U(t,c,a,h)+f+o[t]+n.v[s.floor(t/20)]|0;f=h,h=a,a=n.V(30,c),c=i,i=e}r[0]=r[0]+i|0,r[1]=r[1]+c|0,r[2]=r[2]+a|0,r[3]=r[3]+h|0,r[4]=r[4]+f|0}},P={getRandomValues(t){const e=new c(t.buffer),n=t=>{let e=987654321;const n=4294967295;return()=>(e=36969*(65535&e)+(e>>16)&n,(((e<<16)+(t=18e3*(65535&t)+(t>>16)&n)&n)/4294967296+.5)*(s.random()>.5?1:-1))};for(let r,o=0;o<t.length;o+=4){const t=n(4294967296*(r||s.random()));r=987654071*t(),e[o/4]=4294967296*t()|0}return t}},U={importKey:t=>new U.M(I.bytes.m(t)),_(t,e,n,s){if(n=n||1e4,0>s||0>n)throw new r(\"invalid params to pbkdf2\");const o=1+(s>>5)<<2;let i,c,a,h,l;const u=new ArrayBuffer(o),w=new f(u);let p=0;const d=x;for(e=I.bytes.m(e),l=1;(o||1)>p;l++){for(i=c=t.encrypt(d.concat(e,[l])),a=1;n>a;a++)for(c=t.encrypt(c),h=0;h<c.length;h++)i[h]^=c[h];for(a=0;(o||1)>p&&a<i.length;a++)w.setInt32(p,i[a]),p+=4}return u.slice(0,s/8)},M:class{constructor(t){const e=this,n=e.B=R,s=[[],[]];e.D=[new n,new n];const r=e.D[0].blockSize/32;t.length>r&&(t=(new n).update(t).P());for(let e=0;r>e;e++)s[0][e]=909522486^t[e],s[1][e]=1549556828^t[e];e.D[0].update(s[0]),e.D[1].update(s[1]),e.W=new n(e.D[0])}reset(){const t=this;t.W=new t.B(t.D[0]),t.K=!1}update(t){this.K=!0,this.W.update(t)}digest(){const t=this,e=t.W.P(),n=new t.B(t.D[1]).update(e).P();return t.reset(),n}encrypt(t){if(this.K)throw new r(\"encrypt on already updated hmac called!\");return this.update(t),this.digest(t)}}},V=typeof w!=v&&typeof w.getRandomValues==k,M=\"Invalid password\",_=\"Invalid signature\",B=\"zipjs-abort-check-password\";function D(t){return V?w.getRandomValues(t):P.getRandomValues(t)}const W=16,K={name:\"PBKDF2\"},E=e.assign({hash:{name:\"HMAC\"}},K),L=e.assign({iterations:1e3,hash:{name:\"SHA-1\"}},K),O=[\"deriveBits\"],T=[8,12,16],j=[16,24,32],H=10,Z=[0,0,0,0],F=typeof w!=v,N=F&&w.subtle,q=F&&typeof N!=v,G=I.bytes,J=class{constructor(t){const e=this;e.L=[[[],[],[],[],[]],[[],[],[],[],[]]],e.L[0][0][0]||e.O();const n=e.L[0][4],s=e.L[1],o=t.length;let i,c,a,h=1;if(4!==o&&6!==o&&8!==o)throw new r(\"invalid aes key size\");for(e.v=[c=t.slice(0),a=[]],i=o;4*o+28>i;i++){let t=c[i-1];(i%o===0||8===o&&i%o===4)&&(t=n[t>>>24]<<24^n[t>>16&255]<<16^n[t>>8&255]<<8^n[255&t],i%o===0&&(t=t<<8^t>>>24^h<<24,h=h<<1^283*(h>>7))),c[i]=c[i-o]^t}for(let t=0;i;t++,i--){const e=c[3&t?i:i-4];a[t]=4>=i||4>t?e:s[0][n[e>>>24]]^s[1][n[e>>16&255]]^s[2][n[e>>8&255]]^s[3][n[255&e]]}}encrypt(t){return this.T(t,0)}decrypt(t){return this.T(t,1)}O(){const t=this.L[0],e=this.L[1],n=t[4],s=e[4],r=[],o=[];let i,c,a,h;for(let t=0;256>t;t++)o[(r[t]=t<<1^283*(t>>7))^t]=t;for(let f=i=0;!n[f];f^=c||1,i=o[i]||1){let o=i^i<<1^i<<2^i<<3^i<<4;o=o>>8^255&o^99,n[f]=o,s[o]=f,h=r[a=r[c=r[f]]];let l=16843009*h^65537*a^257*c^16843008*f,u=257*r[o]^16843008*o;for(let n=0;4>n;n++)t[n][f]=u=u<<24^u>>>8,e[n][o]=l=l<<24^l>>>8}for(let n=0;5>n;n++)t[n]=t[n].slice(0),e[n]=e[n].slice(0)}T(t,e){if(4!==t.length)throw new r(\"invalid aes block size\");const n=this.v[e],s=n.length/4-2,o=[0,0,0,0],i=this.L[e],c=i[0],a=i[1],h=i[2],f=i[3],l=i[4];let u,w,p,d=t[0]^n[0],y=t[e?3:1]^n[1],m=t[2]^n[2],g=t[e?1:3]^n[3],S=4;for(let t=0;s>t;t++)u=c[d>>>24]^a[y>>16&255]^h[m>>8&255]^f[255&g]^n[S],w=c[y>>>24]^a[m>>16&255]^h[g>>8&255]^f[255&d]^n[S+1],p=c[m>>>24]^a[g>>16&255]^h[d>>8&255]^f[255&y]^n[S+2],g=c[g>>>24]^a[d>>16&255]^h[y>>8&255]^f[255&m]^n[S+3],S+=4,d=u,y=w,m=p;for(let t=0;4>t;t++)o[e?3&-t:t]=l[d>>>24]<<24^l[y>>16&255]<<16^l[m>>8&255]<<8^l[255&g]^n[S++],u=d,d=y,y=m,m=g,g=u;return o}},Q=class{constructor(t,e){this.j=t,this.H=e,this.Z=e}reset(){this.Z=this.H}update(t){return this.F(this.j,t,this.Z)}N(t){if(255&~(t>>24))t+=1<<24;else{let e=t>>16&255,n=t>>8&255,s=255&t;255===e?(e=0,255===n?(n=0,255===s?s=0:++s):++n):++e,t=0,t+=e<<16,t+=n<<8,t+=s}return t}q(t){0===(t[0]=this.N(t[0]))&&(t[1]=this.N(t[1]))}F(t,e,n){let s;if(!(s=e.length))return[];const r=x.h(e);for(let r=0;s>r;r+=4){this.q(n);const s=t.encrypt(n);e[r]^=s[0],e[r+1]^=s[1],e[r+2]^=s[2],e[r+3]^=s[3]}return x.l(e,r)}},X=U.M;let Y=F&&q&&typeof N.importKey==k,$=F&&q&&typeof N.deriveBits==k;class tt extends d{constructor({password:t,rawPassword:n,signed:s,encryptionStrength:i,checkPasswordOnly:c}){super({start(){e.assign(this,{ready:new l(t=>this.G=t),password:rt(t,n),signed:s,J:i-1,pending:new o})},async transform(t,e){const n=this,{password:s,J:i,G:a,ready:h}=n;s?(await(async(t,e,n,s)=>{const o=await st(t,e,n,it(s,0,T[e])),i=it(s,T[e]);if(o[0]!=i[0]||o[1]!=i[1])throw new r(M)})(n,i,s,it(t,0,T[i]+2)),t=it(t,T[i]+2),c?e.error(new r(B)):a()):await h;const f=new o(t.length-H-(t.length-H)%W);e.enqueue(nt(n,t,f,0,H,!0))},async flush(t){const{signed:e,X:n,Y:s,pending:i,ready:c}=this;if(s&&n){await c;const a=it(i,0,i.length-H),h=it(i,i.length-H);let f=new o;if(a.length){const t=at(G,a);s.update(t);const e=n.update(t);f=ct(G,e)}if(e){const t=it(ct(G,s.digest()),0,H);for(let e=0;H>e;e++)if(t[e]!=h[e])throw new r(_)}t.enqueue(f)}}})}}class et extends d{constructor({password:t,rawPassword:n,encryptionStrength:s}){let r;super({start(){e.assign(this,{ready:new l(t=>this.G=t),password:rt(t,n),J:s-1,pending:new o})},async transform(t,e){const n=this,{password:s,J:r,G:i,ready:c}=n;let a=new o;s?(a=await(async(t,e,n)=>{const s=D(new o(T[e]));return ot(s,await st(t,e,n,s))})(n,r,s),i()):await c;const h=new o(a.length+t.length-t.length%W);h.set(a,0),e.enqueue(nt(n,t,h,a.length,0))},async flush(t){const{X:e,Y:n,pending:s,ready:i}=this;if(n&&e){await i;let c=new o;if(s.length){const t=e.update(at(G,s));n.update(t),c=ct(G,t)}r.signature=ct(G,n.digest()).slice(0,H),t.enqueue(ot(c,r.signature))}}}),r=this}}function nt(t,e,n,s,r,i){const{X:c,Y:a,pending:h}=t,f=e.length-r;let l;for(h.length&&(e=ot(h,e),n=((t,e)=>{if(e&&e>t.length){const n=t;(t=new o(e)).set(n,0)}return t})(n,f-f%W)),l=0;f-W>=l;l+=W){const t=at(G,it(e,l,l+W));i&&a.update(t);const r=c.update(t);i||a.update(r),n.set(ct(G,r),l+s)}return t.pending=it(e,l),n}async function st(n,s,r,i){n.password=null;const c=await(async(t,e,n,s,r)=>{if(!Y)return U.importKey(e);try{return await N.importKey(\"raw\",e,n,!1,r)}catch{return Y=!1,U.importKey(e)}})(0,r,E,0,O),a=await(async(t,e,n)=>{if(!$)return U._(e,t.salt,L.iterations,n);try{return await N.deriveBits(t,e,n)}catch{return $=!1,U._(e,t.salt,L.iterations,n)}})(e.assign({salt:i},L),c,8*(2*j[s]+2)),h=new o(a),f=at(G,it(h,0,j[s])),l=at(G,it(h,j[s],2*j[s])),u=it(h,2*j[s]);return e.assign(n,{keys:{key:f,$:l,passwordVerification:u},X:new Q(new J(f),t.from(Z)),Y:new X(l)}),u}function rt(t,e){return e===b?(t=>{if(typeof u==v){const e=new o((t=unescape(encodeURIComponent(t))).length);for(let n=0;n<e.length;n++)e[n]=t.charCodeAt(n);return e}return(new u).encode(t)})(t):e}function ot(t,e){let n=t;return t.length+e.length&&(n=new o(t.length+e.length),n.set(t,0),n.set(e,t.length)),n}function it(t,e,n){return t.subarray(e,n)}function ct(t,e){return t.p(e)}function at(t,e){return t.m(e)}class ht extends d{constructor({password:t,passwordVerification:n,checkPasswordOnly:s}){super({start(){e.assign(this,{password:t,passwordVerification:n}),wt(this,t)},transform(t,e){const n=this;if(n.password){const e=lt(n,t.subarray(0,12));if(n.password=null,e.at(-1)!=n.passwordVerification)throw new r(M);t=t.subarray(12)}s?e.error(new r(B)):e.enqueue(lt(n,t))}})}}class ft extends d{constructor({password:t,passwordVerification:n}){super({start(){e.assign(this,{password:t,passwordVerification:n}),wt(this,t)},transform(t,e){const n=this;let s,r;if(n.password){n.password=null;const e=D(new o(12));e[11]=n.passwordVerification,s=new o(t.length+e.length),s.set(ut(n,e),0),r=12}else s=new o(t.length),r=0;s.set(ut(n,t),r),e.enqueue(s)}})}}function lt(t,e){const n=new o(e.length);for(let s=0;s<e.length;s++)n[s]=dt(t)^e[s],pt(t,n[s]);return n}function ut(t,e){const n=new o(e.length);for(let s=0;s<e.length;s++)n[s]=dt(t)^e[s],pt(t,e[s]);return n}function wt(t,n){const s=[305419896,591751049,878082192];e.assign(t,{keys:s,tt:new C(s[0]),et:new C(s[2])});for(let e=0;e<n.length;e++)pt(t,n.charCodeAt(e))}function pt(t,e){let[n,r,o]=t.keys;t.tt.append([e]),n=~t.tt.get(),r=mt(s.imul(mt(r+yt(n)),134775813)+1),t.et.append([r>>>24]),o=~t.et.get(),t.keys=[n,r,o]}function dt(t){const e=2|t.keys[2];return yt(s.imul(e,1^e)>>>8)}function yt(t){return 255&t}function mt(t){return 4294967295&t}class gt extends d{constructor(t,{chunkSize:e,nt:n,CompressionStream:s}){super({});const{compressed:r,encrypted:o,useCompressionStream:i,zipCrypto:c,signed:a,level:h}=t,l=this;let u,w,p=super.readable;o&&!c||!a||(u=new A,p=kt(p,u)),r&&(p=vt(p,i,{level:h,chunkSize:e},s,n,s)),o&&(c?p=kt(p,new ft(t)):(w=new et(t),p=kt(p,w))),bt(l,p,()=>{let t;o&&!c&&(t=w.signature),o&&!c||!a||(t=new f(u.value.buffer).getUint32(0)),l.signature=t})}}class St extends d{constructor(t,{chunkSize:e,st:n,DecompressionStream:s}){super({});const{zipCrypto:o,encrypted:i,signed:c,signature:a,compressed:h,useCompressionStream:l,rt:u}=t;let w,p,d=super.readable;i&&(o?d=kt(d,new ht(t)):(p=new tt(t),d=kt(d,p))),h&&(d=vt(d,l,{chunkSize:e,rt:u},s,n,s)),i&&!o||!c||(w=new A,d=kt(d,w)),bt(this,d,()=>{if((!i||o)&&c){const t=new f(w.value.buffer);if(a!=t.getUint32(0,!1))throw new r(_)}})}}function bt(t,n,s){n=kt(n,new d({flush:s})),e.defineProperty(t,\"readable\",{get:()=>n})}function vt(t,e,n,s,r,o){const i=e&&s?s:r||o,c=n.rt?\"deflate64-raw\":\"deflate-raw\";try{t=kt(t,new i(c,n))}catch(s){if(!e)throw s;if(r)t=kt(t,new r(c,n));else{if(!o)throw s;t=kt(t,new o(c,n))}}return t}function kt(t,e){return t.pipeThrough(e)}const zt=\"data\",Ct=\"close\";class At extends d{constructor(t,n){super({});const s=this,{codecType:o}=t;let i;o.startsWith(\"deflate\")?i=gt:o.startsWith(\"inflate\")&&(i=St),s.outputSize=0;let c=0;const a=new i(t,n),h=super.readable,f=new d({transform(t,e){t&&t.length&&(c+=t.length,e.enqueue(t))},flush(){e.assign(s,{inputSize:c})}}),l=new d({transform(e,n){if(e&&e.length&&(n.enqueue(e),s.outputSize+=e.length,t.outputSize!==b&&s.outputSize>t.outputSize))throw new r(\"Invalid uncompressed size\")},flush(){const{signature:t}=a;e.assign(s,{signature:t,inputSize:c})}});e.defineProperty(s,\"readable\",{get:()=>h.pipeThrough(f).pipeThrough(a).pipeThrough(l)})}}class xt extends d{constructor(t){let e;super({transform:function n(s,r){if(e){const t=new o(e.length+s.length);t.set(e),t.set(s,e.length),s=t,e=null}s.length>t?(r.enqueue(s.slice(0,t)),n(s.slice(t),r)):e=s},flush(t){e&&e.length&&t.enqueue(e)}})}}const It=new h,Rt=new h;let Pt,Ut,Vt,Mt,_t,Bt=0;async function Dt(t){try{const{options:e,config:s}=t;if(!e.useCompressionStream)try{await self.initModule(t.config)}catch{e.useCompressionStream=!0}s.CompressionStream=self.CompressionStream,s.DecompressionStream=self.DecompressionStream;const r={highWaterMark:1},o=t.readable||new y({async pull(t){const e=new l(t=>It.set(Bt,t));Wt({type:\"pull\",messageId:Bt}),Bt=(Bt+1)%n.MAX_SAFE_INTEGER;const{value:s,done:r}=await e;t.enqueue(s),r&&t.close()}},r),i=t.writable||new m({async write(t){let e;const s=new l(t=>e=t);Rt.set(Bt,e),Wt({type:zt,value:t,messageId:Bt}),Bt=(Bt+1)%n.MAX_SAFE_INTEGER,await s}},r),c=new At(e,s);Pt=new AbortController;const{signal:a}=Pt;await o.pipeThrough(c).pipeThrough(new xt(s.chunkSize)).pipeTo(i,{signal:a,preventClose:!0,preventAbort:!0}),await i.getWriter().close();const{signature:h,inputSize:f,outputSize:u}=c;Wt({type:Ct,result:{signature:h,inputSize:f,outputSize:u}})}catch(t){t.outputSize=0,Kt(t)}}function Wt(t){let{value:e}=t;if(e)if(e.length)try{e=new o(e),t.value=e.buffer,p(t,[t.value])}catch{p(t)}else p(t);else p(t)}function Kt(t=new r(\"Unknown error\")){const{message:e,stack:n,code:s,name:o,outputSize:i}=t;p({error:{message:e,stack:n,code:s,name:o,outputSize:i}})}function Et(t,e,n={}){const i=\"number\"==typeof n.level?n.level:-1,c=\"number\"==typeof n.ot?n.ot:65536,a=\"number\"==typeof n.it?n.it:65536;return new d({start(){let n;if(this.ct=Vt(c),this.in=Vt(a),this.it=a,this.ht=new o(c),t?(this.ft=Ut.deflate_process,this.lt=Ut.deflate_last_consumed,this.ut=Ut.deflate_end,this.wt=Ut.deflate_new(),n=\"gzip\"===e?Ut.deflate_init_gzip(this.wt,i):\"deflate-raw\"===e?Ut.deflate_init_raw(this.wt,i):Ut.deflate_init(this.wt,i)):\"deflate64-raw\"===e?(this.ft=Ut.inflate9_process,this.lt=Ut.inflate9_last_consumed,this.ut=Ut.inflate9_end,this.wt=Ut.inflate9_new(),n=Ut.inflate9_init_raw(this.wt)):(this.ft=Ut.inflate_process,this.lt=Ut.inflate_last_consumed,this.ut=Ut.inflate_end,this.wt=Ut.inflate_new(),n=\"deflate-raw\"===e?Ut.inflate_init_raw(this.wt):\"gzip\"===e?Ut.inflate_init_gzip(this.wt):Ut.inflate_init(this.wt)),0!==n)throw new r(\"init failed:\"+n)},transform(e,n){try{const i=e,a=new o(_t.buffer),h=this.ft,f=this.lt,l=this.ct,u=this.ht;let w=0;for(;w<i.length;){const e=s.min(i.length-w,32768);this.in&&this.it>=e||(this.in&&Mt&&Mt(this.in),this.in=Vt(e),this.it=e),a.set(i.subarray(w,w+e),this.in);const o=h(this.wt,this.in,e,l,c,0),p=16777215&o;if(p&&(u.set(a.subarray(l,l+p),0),n.enqueue(u.slice(0,p))),!t){const t=o>>24&255,e=128&t?t-256:t;if(0>e)throw new r(\"process error:\"+e)}const d=f(this.wt);if(0===d)break;w+=d}}catch(t){this.ut&&this.wt&&this.ut(this.wt),this.in&&Mt&&Mt(this.in),this.ct&&Mt&&Mt(this.ct),n.error(t)}},flush(e){try{const n=new o(_t.buffer),s=this.ft,i=this.ct,a=this.ht;for(;;){const o=s(this.wt,0,0,i,c,4),h=16777215&o,f=o>>24&255;if(!t){const t=128&f?f-256:f;if(0>t)throw new r(\"process error:\"+t)}if(h&&(a.set(n.subarray(i,i+h),0),e.enqueue(a.slice(0,h))),1===f||0===h)break}}catch(t){e.error(t)}finally{if(this.ut&&this.wt){const t=this.ut(this.wt);0!==t&&e.error(new r(\"end error:\"+t))}this.in&&Mt&&Mt(this.in),this.ct&&Mt&&Mt(this.ct)}}})}addEventListener(\"message\",({data:t})=>{const{type:e,messageId:n,value:s,done:r}=t;try{if(\"start\"==e&&Dt(t),e==zt){const t=It.get(n);It.delete(n),t({value:new o(s),done:r})}if(\"ack\"==e){const t=Rt.get(n);Rt.delete(n),t()}e==Ct&&Pt.abort()}catch(t){Kt(t)}});class Lt{constructor(t=\"deflate\",e){return Et(!0,t,e)}}class Ot{constructor(t=\"deflate\",e){return Et(!1,t,e)}}let Tt=!1;self.initModule=async t=>{try{const e=await(async(t,{baseURI:e})=>{if(!Tt){let n,s;try{try{s=new URL(t,e)}catch{}const r=await fetch(s);n=await r.arrayBuffer()}catch(e){if(!t.startsWith(\"data:application/wasm;base64,\"))throw e;n=(t=>{const e=t.split(\",\")[1],n=atob(e),s=n.length,r=new o(s);for(let t=0;s>t;++t)r[t]=n.charCodeAt(t);return r.buffer})(t)}(t=>{if(Ut=t,({malloc:Vt,free:Mt,memory:_t}=Ut),\"function\"!=typeof Vt||\"function\"!=typeof Mt||!_t)throw Ut=Vt=Mt=_t=null,new r(\"Invalid WASM module\")})((await WebAssembly.instantiate(n)).instance.exports),Tt=!0}})(t.wasmURI,t);return t.nt=Lt,t.st=Ot,e}catch{}}});\\n';t({workerURI:t=>{const n=\"text/javascript\";if(t){const t=new Blob([e],{type:n});return URL.createObjectURL(t)}return\"data:\"+n+\",\"+encodeURIComponent(e)}})}export{t as configureWebWorker};\n","/*\n Copyright (c) 2025 Gildas Lormeau. All rights reserved.\n\n Redistribution and use in source and binary forms, with or without\n modification, are permitted provided that the following conditions are met:\n\n 1. Redistributions of source code must retain the above copyright notice,\n this list of conditions and the following disclaimer.\n\n 2. Redistributions in binary form must reproduce the above copyright\n notice, this list of conditions and the following disclaimer in\n the documentation and/or other materials provided with the distribution.\n\n 3. The names of the authors may not be used to endorse or promote products\n derived from this software without specific prior written permission.\n\n THIS SOFTWARE IS PROVIDED ''AS IS'' AND ANY EXPRESSED OR IMPLIED WARRANTIES,\n INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND\n FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL JCRAFT,\n INC. OR ANY CONTRIBUTORS TO THIS SOFTWARE BE LIABLE FOR ANY DIRECT, INDIRECT,\n INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT\n LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA,\n OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF\n LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING\n NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE,\n EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.\n */\n\nimport { configure } from \"./core/configuration.js\";\nimport { configureWebWorker } from \"./core/web-worker-inline-wasm.js\";\n\nconfigureWebWorker(configure);\n\nexport * from \"./zip-fs-core-wasm.js\";\nexport { getMimeType } from \"./core/util/mime-type.js\";","import * as common from \"./common\";\nimport {\n type FileEntry,\n BlobReader,\n BlobWriter,\n TextWriter,\n ZipReader,\n} from \"@zip.js/zip.js\";\nimport type { FastbootDevice, ReconnectCallback } from \"./fastboot\";\nimport { FastbootError } from \"./utils/errors\";\nimport { logDebug } from \"./utils/logger\";\nimport {\n type FactoryProgressCallback,\n runWithTimedProgress,\n} from \"./utils/progress\";\n\n// Images needed for fastbootd\nconst BOOT_CRITICAL_IMAGES = [\n \"boot\",\n \"dt\",\n \"dtbo\",\n \"init_boot\",\n \"pvmfw\",\n \"recovery\",\n \"vbmeta_system\",\n \"vbmeta_vendor\",\n \"vbmeta\",\n \"vendor_boot\",\n \"vendor_kernel_boot\",\n];\n\n// Less critical images to flash after boot-critical ones\nconst SYSTEM_IMAGES = [\n \"odm\",\n \"odm_dlkm\",\n \"product\",\n \"system_dlkm\",\n \"system_ext\",\n \"system\",\n \"vendor_dlkm\",\n \"vendor\",\n];\n\n/**\n * User-friendly action strings for factory image flashing progress.\n * This can be indexed by the action argument in FactoryFlashCallback.\n */\nexport const USER_ACTION_MAP = {\n load: \"Loading\",\n unpack: \"Unpacking\",\n flash: \"Writing\",\n wipe: \"Wiping\",\n reboot: \"Restarting\",\n};\n\nconst BOOTLOADER_REBOOT_TIME = 4000; // ms\nconst FASTBOOTD_REBOOT_TIME = 16000; // ms\nconst USERDATA_ERASE_TIME = 1000; // ms\n\nasync function flashEntryBlob(\n device: FastbootDevice,\n entry: FileEntry,\n onProgress: FactoryProgressCallback,\n partition: string,\n slot: string = \"current\",\n) {\n logDebug(`Unpacking ${partition}`);\n onProgress(\"unpack\", partition, 0.0);\n const blob = await entry.getData<Blob>(\n new BlobWriter(\"application/octet-stream\"),\n {\n onprogress: (bytes: number, len: number) => {\n onProgress(\"unpack\", partition, bytes / len);\n },\n },\n );\n\n logDebug(`Flashing ${partition}`);\n onProgress(\"flash\", partition, 0.0);\n await device.flashBlob(partition, slot, blob, (progress) => {\n onProgress(\"flash\", partition, progress);\n });\n}\n\nasync function tryFlashImages(\n device: FastbootDevice,\n entries: Array<FileEntry>,\n onProgress: FactoryProgressCallback,\n imageNames: Array<string>,\n slot: string = \"current\",\n) {\n for (const imageName of imageNames) {\n const pattern = new RegExp(`${imageName}(?:-.+)?\\\\.img$`);\n const entry = entries.find((entry) => entry.filename.match(pattern));\n if (entry !== undefined) {\n await flashEntryBlob(device, entry, onProgress, imageName, slot);\n }\n }\n}\n\nasync function checkRequirements(device: FastbootDevice, androidInfo: string) {\n // Deal with CRLF just in case\n for (const line of androidInfo.replace(\"\\r\", \"\").split(\"\\n\")) {\n const match = line.match(/^require\\s+(.+?)=(.+)$/);\n if (!match) {\n continue;\n }\n\n let variable = match[1];\n // Historical mismatch that we still need to deal with\n if (variable === \"board\") {\n variable = \"product\";\n }\n\n const expectValue = match[2];\n const expectValues: Array<string | null> = expectValue.split(\"|\");\n\n // Special case: not a real variable at all\n if (variable === \"partition-exists\") {\n // Check whether the partition exists on the device:\n // has-slot = undefined || FAIL => doesn't exist\n // has-slot = yes || no => exists\n const hasSlot = await device.getVariable(`has-slot:${expectValue}`);\n if (hasSlot !== \"yes\" && hasSlot !== \"no\") {\n throw new FastbootError(\n \"FAIL\",\n `Requirement ${variable}=${expectValue} failed, device lacks partition`,\n );\n }\n\n // Check whether we recognize the partition\n if (\n !BOOT_CRITICAL_IMAGES.includes(expectValue) &&\n !SYSTEM_IMAGES.includes(expectValue)\n ) {\n throw new FastbootError(\n \"FAIL\",\n `Requirement ${variable}=${expectValue} failed, unrecognized partition`,\n );\n }\n } else {\n const realValue = await device.getVariable(variable);\n\n if (expectValues.includes(realValue)) {\n logDebug(`Requirement ${variable}=${expectValue} passed`);\n } else {\n const msg = `Requirement ${variable}=${expectValue} failed, value = ${realValue}`;\n logDebug(msg);\n throw new FastbootError(\"FAIL\", msg);\n }\n }\n }\n}\n\nasync function tryRebootWithSlotSwitch(\n device: FastbootDevice,\n target: string,\n onReconnect: ReconnectCallback,\n) {\n try {\n await device.rebootSwitchSlot(target, false);\n } catch {\n /* Failed = device rebooted by itself */\n }\n\n await device.waitForConnect(onReconnect);\n}\n\nexport async function flashZip(\n device: FastbootDevice,\n blob: Blob,\n wipe: boolean,\n onReconnect: ReconnectCallback,\n onProgress: FactoryProgressCallback = () => {},\n) {\n onProgress(\"load\", \"package\", 0.0);\n const reader = new ZipReader(new BlobReader(blob));\n const entries = (await reader.getEntries()).filter(\n (e) => !e.directory,\n ) as FileEntry[];\n\n // Ensure AVB custom key exists as expected.\n const avbCustomKeyEntry = entries.find((e) =>\n e.filename.endsWith(\"avb_custom_key.img\"),\n );\n if (avbCustomKeyEntry === undefined) {\n throw new Error(\n \"avb_custom_key.img not found! bootloader locking would fail.\",\n );\n }\n\n // Bootloader and radio packs can only be flashed in the bare-metal bootloader\n if ((await device.getVariable(\"is-userspace\")) === \"yes\") {\n await device.reboot(\"bootloader\", true, onReconnect);\n }\n\n // 1. Bootloader pack\n await tryFlashImages(device, entries, onProgress, [\"bootloader\"], \"other\");\n await runWithTimedProgress(\n onProgress,\n \"reboot\",\n \"device\",\n BOOTLOADER_REBOOT_TIME,\n tryRebootWithSlotSwitch(device, \"bootloader\", onReconnect),\n );\n // Flash the other slot\n await tryFlashImages(device, entries, onProgress, [\"bootloader\"], \"other\");\n await runWithTimedProgress(\n onProgress,\n \"reboot\",\n \"device\",\n BOOTLOADER_REBOOT_TIME,\n tryRebootWithSlotSwitch(device, \"bootloader\", onReconnect),\n );\n\n // 2. Radio pack\n await tryFlashImages(device, entries, onProgress, [\"radio\"], \"other\");\n await runWithTimedProgress(\n onProgress,\n \"reboot\",\n \"device\",\n BOOTLOADER_REBOOT_TIME,\n tryRebootWithSlotSwitch(device, \"bootloader\", onReconnect),\n );\n // Flash the other slot\n await tryFlashImages(device, entries, onProgress, [\"radio\"], \"other\");\n await runWithTimedProgress(\n onProgress,\n \"reboot\",\n \"device\",\n BOOTLOADER_REBOOT_TIME,\n tryRebootWithSlotSwitch(device, \"bootloader\", onReconnect),\n );\n\n // Cancel snapshot update if in progress\n const snapshotStatus = await device.getVariable(\"snapshot-update-status\");\n if (snapshotStatus !== null && snapshotStatus !== \"none\") {\n await device.runCommand(\"snapshot-update:cancel\");\n }\n\n // Load nested images for the following steps\n logDebug(\"Loading nested images from zip\");\n onProgress(\"unpack\", \"images\", 0.0);\n let entry = entries.find((e) => e.filename.match(/image-.+\\.zip$/));\n const imagesBlob = await entry!.getData<Blob>(\n new BlobWriter(\"application/zip\"),\n {\n onprogress: (bytes: number, len: number) => {\n onProgress(\"unpack\", \"images\", bytes / len);\n },\n },\n );\n const imageReader = new ZipReader(new BlobReader(imagesBlob));\n const imageEntries = (await imageReader.getEntries()).filter(\n (e) => !e.directory,\n ) as FileEntry[];\n\n // 3. Custom AVB key\n await device.runCommand(\"erase:avb_custom_key\");\n await flashEntryBlob(\n device,\n avbCustomKeyEntry,\n onProgress,\n \"avb_custom_key\",\n );\n\n // 4. Check requirements\n entry = imageEntries.find((e) => e.filename === \"android-info.txt\");\n if (entry !== undefined) {\n const reqText = await entry.getData<string>(new TextWriter());\n await checkRequirements(device, reqText);\n }\n\n // 5. Boot-critical images\n await tryFlashImages(\n device,\n imageEntries,\n onProgress,\n BOOT_CRITICAL_IMAGES,\n );\n\n // 6. Super partition template\n // This is also where we reboot to fastbootd.\n entry = imageEntries.find((e) => e.filename === \"super_empty.img\");\n if (entry !== undefined) {\n await runWithTimedProgress(\n onProgress,\n \"reboot\",\n \"device\",\n FASTBOOTD_REBOOT_TIME,\n device.reboot(\"fastboot\", true, onReconnect),\n );\n\n let superName = await device.getVariable(\"super-partition-name\");\n if (!superName) {\n superName = \"super\";\n }\n\n const superAction = wipe ? \"wipe\" : \"flash\";\n onProgress(superAction, \"super\", 0.0);\n const superBlob = await entry.getData<Blob>(\n new BlobWriter(\"application/octet-stream\"),\n );\n await device.upload(\n superName,\n await common.readBlobAsBuffer(superBlob),\n (progress) => {\n onProgress(superAction, \"super\", progress);\n },\n );\n await device.runCommand(\n `update-super:${superName}${wipe ? \":wipe\" : \"\"}`,\n );\n }\n\n // 7. Remaining system images\n await tryFlashImages(device, imageEntries, onProgress, SYSTEM_IMAGES);\n\n // We unconditionally reboot back to the bootloader here if we're in fastbootd,\n // even when there's no custom AVB key, because common follow-up actions like\n // locking the bootloader and wiping data need to be done in the bootloader.\n if ((await device.getVariable(\"is-userspace\")) === \"yes\") {\n await runWithTimedProgress(\n onProgress,\n \"reboot\",\n \"device\",\n BOOTLOADER_REBOOT_TIME,\n device.reboot(\"bootloader\", true, onReconnect),\n );\n }\n\n // 8. Wipe userdata\n if (wipe) {\n await runWithTimedProgress(\n onProgress,\n \"wipe\",\n \"data\",\n USERDATA_ERASE_TIME,\n device.runCommand(\"erase:userdata\"),\n );\n }\n}\n","import * as Sparse from \"./sparse\";\nimport * as Lp from \"./lp\";\nimport * as common from \"./common\";\nimport { flashZip } from \"./factory\";\nimport { FastbootError, UsbError } from \"./utils/errors\";\nimport { logDebug, logVerbose } from \"./utils/logger\";\nimport {\n runWithTimeout,\n type FactoryProgressCallback,\n type FlashProgressCallback,\n} from \"./utils/progress\";\n\nconst FASTBOOT_USB_CLASS = 0xff;\nconst FASTBOOT_USB_SUBCLASS = 0x42;\nconst FASTBOOT_USB_PROTOCOL = 0x03;\n\nconst BULK_TRANSFER_SIZE = 16384;\n\nconst DEFAULT_DOWNLOAD_SIZE = 512 * 1024 * 1024; // 512 MiB\n// To conserve RAM and work around Chromium's ~2 GiB size limit, we limit the\n// max download size even if the bootloader can accept more data.\nconst MAX_DOWNLOAD_SIZE = 1024 * 1024 * 1024; // 1 GiB\n\nconst GETVAR_TIMEOUT = 10000; // ms\n\ninterface CommandResponse {\n text: string;\n // hex string from DATA\n dataSize?: string;\n}\n\n/**\n * Callback for reconnecting to the USB device.\n * This is necessary because some platforms do not support automatic reconnection,\n * and USB connection requests can only be triggered as the result of explicit\n * user action.\n *\n * @callback ReconnectCallback\n */\nexport type ReconnectCallback = () => void;\n\n/**\n * This class is a client for executing fastboot commands and operations on a\n * device connected over USB.\n */\nexport class FastbootDevice {\n device: USBDevice | null;\n epIn: number | null;\n epOut: number | null;\n\n private _registeredUsbListeners: boolean;\n private _connectResolve: ((value: unknown) => void) | null;\n private _connectReject: ((value: unknown) => void) | null;\n private _disconnectResolve: ((value: unknown) => void) | null;\n\n /**\n * Create a new fastboot device instance. This doesn't actually connect to\n * any USB devices; call {@link connect} to do so.\n */\n constructor() {\n this.device = null;\n this.epIn = null;\n this.epOut = null;\n\n this._registeredUsbListeners = false;\n this._connectResolve = null;\n this._connectReject = null;\n this._disconnectResolve = null;\n }\n\n /**\n * Returns whether a USB device is connected and ready for use.\n */\n get isConnected() {\n return (\n this.device !== null &&\n this.device.opened &&\n this.device.configurations[0].interfaces[0].claimed\n );\n }\n\n /**\n * Validate the current USB device's details and connect to it.\n *\n * @private\n */\n private async _validateAndConnectDevice() {\n if (this.device === null) {\n throw new UsbError(\"Attempted to connect to null device\");\n }\n\n // Validate device\n const ife = this.device!.configurations[0].interfaces[0].alternates[0];\n if (ife.endpoints.length !== 2) {\n throw new UsbError(\"Interface has wrong number of endpoints\");\n }\n\n this.epIn = null;\n this.epOut = null;\n for (const endpoint of ife.endpoints) {\n logVerbose(\n `Checking endpoint: ` +\n `endpointNumber=${endpoint.endpointNumber}, ` +\n `direction=${endpoint.direction}, ` +\n `type=${endpoint.type}, ` +\n `packetSize=${endpoint.packetSize}`,\n );\n if (endpoint.type !== \"bulk\") {\n throw new UsbError(\"Interface endpoint is not bulk\");\n }\n\n if (endpoint.direction === \"in\") {\n if (this.epIn === null) {\n this.epIn = endpoint.endpointNumber;\n } else {\n throw new UsbError(\"Interface has multiple IN endpoints\");\n }\n } else if (endpoint.direction === \"out\") {\n if (this.epOut === null) {\n this.epOut = endpoint.endpointNumber;\n } else {\n throw new UsbError(\"Interface has multiple OUT endpoints\");\n }\n }\n }\n logVerbose(`Endpoints: in=${this.epIn}, out=${this.epOut}`);\n\n try {\n await this.device!.open();\n // Opportunistically reset to fix issues on some platforms\n try {\n await this.device!.reset();\n } catch {\n /* Failed = doesn't support reset */\n }\n\n await this.device!.selectConfiguration(1);\n await this.device!.claimInterface(0); // fastboot\n } catch (error) {\n // Propagate exception from waitForConnect()\n if (this._connectReject !== null) {\n this._connectReject(error);\n this._connectResolve = null;\n this._connectReject = null;\n }\n\n throw error;\n }\n\n // Return from waitForConnect()\n if (this._connectResolve !== null) {\n this._connectResolve(undefined);\n this._connectResolve = null;\n this._connectReject = null;\n }\n }\n\n /**\n * Wait for the current USB device to disconnect, if it's still connected.\n * Returns immediately if no device is connected.\n */\n async waitForDisconnect() {\n if (this.device === null) {\n return;\n }\n\n return await new Promise((resolve) => {\n this._disconnectResolve = resolve;\n });\n }\n\n /**\n * Wait for the USB device to connect. Returns at the next connection,\n * regardless of whether the connected USB device matches the previous one.\n *\n * @param {ReconnectCallback} onReconnect - Callback to request device reconnection on Android.\n */\n async waitForConnect(onReconnect: ReconnectCallback = () => {}) {\n // On Android, we need to request the user to reconnect the device manually\n // because there is no support for automatic reconnection.\n if (navigator.userAgent.includes(\"Android\")) {\n await this.waitForDisconnect();\n onReconnect();\n }\n\n return await new Promise((resolve, reject) => {\n this._connectResolve = resolve;\n this._connectReject = reject;\n });\n }\n\n /**\n * Request the user to select a USB device and connect to it using the\n * fastboot protocol.\n *\n * @throws {UsbError}\n */\n async connect() {\n this.device = await navigator.usb.requestDevice({\n filters: [\n {\n classCode: FASTBOOT_USB_CLASS,\n subclassCode: FASTBOOT_USB_SUBCLASS,\n protocolCode: FASTBOOT_USB_PROTOCOL,\n },\n ],\n });\n logDebug(\"Using USB device:\", this.device);\n\n if (!this._registeredUsbListeners) {\n navigator.usb.addEventListener(\"disconnect\", (event) => {\n if (event.device === this.device) {\n logDebug(\"USB device disconnected\");\n if (this._disconnectResolve !== null) {\n this._disconnectResolve(undefined);\n this._disconnectResolve = null;\n }\n }\n });\n\n navigator.usb.addEventListener(\"connect\", async (event) => {\n logDebug(\"USB device connected\");\n this.device = event.device;\n\n // Check whether waitForConnect() is pending and save it for later\n const hasPromiseReject = this._connectReject !== null;\n try {\n await this._validateAndConnectDevice();\n } catch (error) {\n // Only rethrow errors from the event handler if waitForConnect()\n // didn't already handle them\n if (!hasPromiseReject) {\n throw error;\n }\n }\n });\n\n this._registeredUsbListeners = true;\n }\n\n await this._validateAndConnectDevice();\n }\n\n /**\n * Read a raw command response from the bootloader.\n *\n * @private\n * @returns {Promise<CommandResponse>} Object containing response text and data size, if any.\n * @throws {FastbootError}\n */\n private async _readResponse(): Promise<CommandResponse> {\n const respData = {\n text: \"\",\n } as CommandResponse;\n let respStatus;\n\n do {\n const respPacket = await this.device!.transferIn(this.epIn!, 64);\n const response = new TextDecoder().decode(respPacket.data);\n\n respStatus = response.substring(0, 4);\n const respMessage = response.substring(4);\n logDebug(`Response: ${respStatus} ${respMessage}`);\n\n if (respStatus === \"OKAY\") {\n // OKAY = end of response for this command\n respData.text += respMessage;\n } else if (respStatus === \"INFO\") {\n // INFO = additional info line\n respData.text += respMessage + \"\\n\";\n } else if (respStatus === \"DATA\") {\n // DATA = hex string, but it's returned separately for safety\n respData.dataSize = respMessage;\n } else {\n // Assume FAIL or garbage data\n throw new FastbootError(respStatus, respMessage);\n }\n // INFO = more packets are coming\n } while (respStatus === \"INFO\");\n\n return respData;\n }\n\n /**\n * Send a textual command to the bootloader and read the response.\n * This is in raw fastboot format, not AOSP fastboot syntax.\n *\n * @param {string} command - The command to send.\n * @returns {Promise<CommandResponse>} Object containing response text and data size, if any.\n * @throws {FastbootError}\n */\n async runCommand(command: string): Promise<CommandResponse> {\n // Command and response length is always 64 bytes regardless of protocol\n if (command.length > 64) {\n throw new RangeError();\n }\n\n // Send raw UTF-8 command\n const cmdPacket = new TextEncoder().encode(command);\n await this.device!.transferOut(this.epOut!, cmdPacket);\n logDebug(\"Command:\", command);\n\n return this._readResponse();\n }\n\n /**\n * Read the value of a bootloader variable. Returns undefined if the variable\n * does not exist.\n *\n * @param {string} varName - The name of the variable to get.\n * @returns {Promise<string>} Textual content of the variable.\n * @throws {FastbootError}\n */\n async getVariable(varName: string): Promise<string | null> {\n let resp;\n try {\n resp = (\n await runWithTimeout(\n this.runCommand(`getvar:${varName}`),\n GETVAR_TIMEOUT,\n )\n ).text;\n } catch (error) {\n // Some bootloaders return FAIL instead of empty responses, despite\n // what the spec says. Normalize it here.\n if (error instanceof FastbootError && error.status == \"FAIL\") {\n resp = null;\n } else {\n throw error;\n }\n }\n\n // Some bootloaders send whitespace around some variables.\n // According to the spec, non-existent variables should return empty\n // responses\n return resp ? resp.trim() : null;\n }\n\n /**\n * Get the maximum download size for a single payload, in bytes.\n *\n * @private\n * @returns {Promise<number>}\n * @throws {FastbootError}\n */\n private async _getDownloadSize(): Promise<number> {\n try {\n const resp = (await this.getVariable(\n \"max-download-size\",\n ))!.toLowerCase();\n if (resp) {\n // AOSP fastboot requires hex\n return Math.min(parseInt(resp, 16), MAX_DOWNLOAD_SIZE);\n }\n } catch {\n /* Failed = no value, fallthrough */\n }\n\n // FAIL or empty variable means no max, set a reasonable limit to conserve memory\n return DEFAULT_DOWNLOAD_SIZE;\n }\n\n /**\n * Send a raw data payload to the bootloader.\n *\n * @private\n */\n private async _sendRawPayload(\n buffer: ArrayBuffer,\n onProgress: FlashProgressCallback,\n ) {\n let i = 0;\n let remainingBytes = buffer.byteLength;\n while (remainingBytes > 0) {\n const chunk = buffer.slice(\n i * BULK_TRANSFER_SIZE,\n (i + 1) * BULK_TRANSFER_SIZE,\n );\n if (i % 1000 === 0) {\n logVerbose(\n ` Sending ${chunk.byteLength} bytes to endpoint, ${remainingBytes} remaining, i=${i}`,\n );\n }\n if (i % 10 === 0) {\n onProgress(\n (buffer.byteLength - remainingBytes) / buffer.byteLength,\n );\n }\n\n await this.device!.transferOut(this.epOut!, chunk);\n\n remainingBytes -= chunk.byteLength;\n i += 1;\n }\n\n onProgress(1.0);\n }\n\n /**\n * Upload a payload to the bootloader for later use, e.g. flashing.\n * Does not handle raw images, flashing, or splitting.\n *\n * @param {string} partition - Name of the partition the payload is intended for.\n * @param {ArrayBuffer} buffer - Buffer containing the data to upload.\n * @param {FlashProgressCallback} onProgress - Callback for upload progress updates.\n * @throws {FastbootError}\n */\n async upload(\n partition: string,\n buffer: ArrayBuffer,\n onProgress: FlashProgressCallback = () => {},\n ) {\n logDebug(\n `Uploading single sparse to ${partition}: ${buffer.byteLength} bytes`,\n );\n\n // Bootloader requires an 8-digit hex number\n const xferHex = buffer.byteLength.toString(16).padStart(8, \"0\");\n if (xferHex.length !== 8) {\n throw new FastbootError(\n \"FAIL\",\n `Transfer size overflow: ${xferHex} is more than 8 digits`,\n );\n }\n\n // Check with the device and make sure size matches\n const downloadResp = await this.runCommand(`download:${xferHex}`);\n if (downloadResp.dataSize === undefined) {\n throw new FastbootError(\n \"FAIL\",\n `Unexpected response to download command: ${downloadResp.text}`,\n );\n }\n const downloadSize = parseInt(downloadResp.dataSize!, 16);\n if (downloadSize !== buffer.byteLength) {\n throw new FastbootError(\n \"FAIL\",\n `Bootloader wants ${downloadSize} bytes, requested to send ${buffer.byteLength} bytes`,\n );\n }\n\n logDebug(`Sending payload: ${buffer.byteLength} bytes`);\n await this._sendRawPayload(buffer, onProgress);\n\n logDebug(\"Payload sent, waiting for response...\");\n await this._readResponse();\n }\n\n /**\n * Reboot to the given target, and optionally wait for the device to\n * reconnect.\n *\n * @param {string} target - Where to reboot to, i.e. fastboot or bootloader.\n * @param {boolean} wait - Whether to wait for the device to reconnect.\n * @param {ReconnectCallback} onReconnect - Callback to request device reconnection, if wait is enabled.\n */\n async reboot(\n target: string = \"\",\n wait: boolean = false,\n onReconnect: ReconnectCallback = () => {},\n ) {\n if (target.length > 0) {\n await this.runCommand(`reboot-${target}`);\n } else {\n await this.runCommand(\"reboot\");\n }\n\n if (wait) {\n await this.waitForConnect(onReconnect);\n }\n }\n\n /**\n * Reboot to the given target and switch slot, and optionally wait for the device to\n * reconnect.\n *\n * @param {string} target - Where to reboot to, i.e. fastboot or bootloader.\n * @param {boolean} wait - Whether to wait for the device to reconnect.\n * @param {ReconnectCallback} onReconnect - Callback to request device reconnection, if wait is enabled.\n */\n async rebootSwitchSlot(\n target: string = \"\",\n wait: boolean = false,\n onReconnect: ReconnectCallback = () => {},\n ) {\n const otherSlot = await this.getOtherSlot();\n await this.runCommand(`set_active:${otherSlot}`);\n if (target.length > 0) {\n await this.runCommand(`reboot-${target}`);\n } else {\n await this.runCommand(\"reboot\");\n }\n\n if (wait) {\n await this.waitForConnect(onReconnect);\n }\n }\n\n /**\n * Flash the given Blob to the given partition and slot on the device. Any image\n * format supported by the bootloader is allowed, e.g. sparse or raw images.\n * Large raw images will be converted to sparse images automatically, and\n * large sparse images will be split and flashed in multiple passes\n * depending on the bootloader's payload size limit.\n *\n * @param {string} partition - The name of the partition to flash.\n * @param {string} slot - The slot to flash, defaults to current\n * @param {Blob} blob - The Blob to retrieve data from.\n * @param {FlashProgressCallback} onProgress - Callback for flashing progress updates.\n * @throws {FastbootError}\n */\n async flashBlob(\n partition: string,\n slot: string = \"current\",\n blob: Blob,\n onProgress: FlashProgressCallback = () => {},\n ) {\n // Check slot if partition is A/B\n if ((await this.getVariable(`has-slot:${partition}`)) === \"yes\") {\n const currentSlot = await this.getSlot();\n if (slot === \"current\") {\n // Default behavior, flash current slot\n partition += \"_\" + currentSlot;\n } else if (slot === \"other\") {\n // Allow flashing the other slot\n const otherSlot = await this.getOtherSlot();\n partition += \"_\" + otherSlot;\n } else {\n // Allow flashing a particular slot directly\n if (slot === \"a\" || slot === \"b\") {\n partition += \"_\" + slot;\n } else {\n throw new FastbootError(\"FAIL\", `Unknown Slot: ${slot}`);\n }\n }\n }\n logDebug(`Flashing partition ${partition}`);\n\n const maxDlSize = await this._getDownloadSize();\n const fileHeader = await common.readBlobAsBuffer(\n blob.slice(0, Sparse.FILE_HEADER_SIZE),\n );\n\n let totalBytes = blob.size;\n let isSparse = false;\n try {\n const sparseHeader = Sparse.parseFileHeader(fileHeader);\n if (sparseHeader !== null) {\n totalBytes = sparseHeader.blocks * sparseHeader.blockSize;\n isSparse = true;\n }\n } catch {\n // ImageError = invalid, so keep blob.size\n }\n\n // Logical partitions need to be resized before flashing because they're\n // sized perfectly to the payload.\n if ((await this.getVariable(`is-logical:${partition}`)) === \"yes\") {\n // As per AOSP fastboot, we reset the partition to 0 bytes first\n // to optimize extent allocation.\n await this.runCommand(`resize-logical-partition:${partition}:0`);\n // Set the actual size\n await this.runCommand(\n `resize-logical-partition:${partition}:${totalBytes}`,\n );\n }\n\n // Convert image to sparse (for splitting) if it exceeds the size limit\n if (blob.size > maxDlSize && !isSparse) {\n logDebug(`${partition} image is raw, converting to sparse`);\n blob = await Sparse.fromRaw(blob);\n }\n\n logDebug(\n `Flashing ${blob.size} bytes to ${partition}, ${maxDlSize} bytes per split`,\n );\n let splits = 0;\n let sentBytes = 0;\n for await (const split of Sparse.splitBlob(blob, maxDlSize)) {\n await this.upload(partition, split.data, (progress) => {\n onProgress((sentBytes + progress * split.bytes) / totalBytes);\n });\n\n logDebug(\"Flashing payload...\");\n await this.runCommand(`flash:${partition}`);\n\n splits += 1;\n sentBytes += split.bytes;\n }\n\n logDebug(`Flashed ${partition} with ${splits} split(s)`);\n }\n\n /**\n * Boot the given Blob on the device.\n * Equivalent to `fastboot boot boot.img`.\n *\n * @param {Blob} blob - The Blob to retrieve data from.\n * @param {FlashProgressCallback} onProgress - Callback for flashing progress updates.\n * @throws {FastbootError}\n */\n async bootBlob(blob: Blob, onProgress: FlashProgressCallback = () => {}) {\n logDebug(`Booting ${blob.size} bytes image`);\n\n const data = await common.readBlobAsBuffer(blob);\n await this.upload(\"boot.img\", data, onProgress);\n\n logDebug(\"Booting payload...\");\n await this.runCommand(\"boot\");\n\n logDebug(`Booted ${blob.size} bytes image`);\n }\n\n /**\n * Flash the given factory images zip onto the device, with automatic handling\n * of firmware, system, and logical partitions as AOSP fastboot and\n * flash-all.sh would do.\n * Equivalent to `fastboot update name.zip`.\n *\n * @param {Blob} blob - Blob containing the zip file to flash.\n * @param {boolean} wipe - Whether to wipe super and userdata. Equivalent to `fastboot -w`.\n * @param {ReconnectCallback} onReconnect - Callback to request device reconnection.\n * @param {FactoryProgressCallback} onProgress - Progress callback for image flashing.\n */\n async flashFactoryZip(\n blob: Blob,\n wipe: boolean,\n onReconnect: ReconnectCallback,\n onProgress: FactoryProgressCallback = () => {},\n ) {\n return await flashZip(this, blob, wipe, onReconnect, onProgress);\n }\n\n /**\n * Wipe the super partition by flashing a minimal sparse image derived from\n * the LP metadata in the given super_empty.img Blob. This erases all logical\n * partition data and resets the partition table to the empty layout encoded\n * in the image.\n *\n * The device must be in the bootloader (not fastbootd) when this is called.\n *\n * @param {Blob} blob - Blob containing super_empty.img.\n * @param {string} slot - The slot to target (\"current\", \"a\", or \"b\").\n * @param {FlashProgressCallback} onProgress - Callback for flashing progress updates.\n * @throws {FastbootError}\n */\n async wipeSuper(\n blob: Blob,\n slot: string = \"current\",\n onProgress: FlashProgressCallback = () => {},\n ) {\n const metadata = await Lp.readFromImageBlob(blob);\n\n // Resolve slot\n let resolvedSlot = slot;\n if (slot === \"current\") {\n resolvedSlot = (await this.getSlot()) ?? \"a\";\n } else if (slot === \"other\") {\n resolvedSlot = await this.getOtherSlot();\n }\n logDebug(`Targeting slot \"${resolvedSlot}\"`);\n\n const images = await Lp.buildWipeSuperImages(metadata);\n\n // For retrofit devices the primary block device is not named \"super\".\n // Fastboot sends \"oem allow-flash-super\" to allow flashing.\n const superDevice = Lp.getMetadataSuperBlockDevice(metadata);\n if (\n superDevice !== null &&\n Lp.getBlockDevicePartitionName(superDevice) !== \"super\"\n ) {\n try {\n await this.runCommand(\"oem allow-flash-super\");\n } catch {\n // Not all bootloaders support this command\n }\n }\n\n for (const image of images) {\n let flashPartition = image.partitionName;\n\n // Always query has-slot, even when the metadata flag requests slot-suffixing.\n // This matches AOSP do_for_partition: respect the device's own answer for\n // has-slot and only warn when force_slot is set but the partition has no slots.\n const hasSlot = await this.getVariable(\n `has-slot:${image.partitionName}`,\n );\n if (hasSlot === \"yes\") {\n flashPartition = `${image.partitionName}_${resolvedSlot}`;\n } else if (image.forceSlot) {\n logDebug(\n `Warning: ${image.partitionName} does not support slots but slot suffix was requested`,\n );\n }\n\n logDebug(\n `Flashing ${image.data.byteLength} bytes to \"${flashPartition}\"`,\n );\n await this.upload(flashPartition, image.data, onProgress);\n await this.runCommand(`flash:${flashPartition}`);\n }\n }\n\n /**\n * Determine the current slot\n */\n async getSlot() {\n const currentSlot = await this.getVariable(\"current-slot\");\n return currentSlot?.slice(-1);\n }\n\n /**\n * Determine the other slot\n * Hardcoded for A/B currently as that's what we mostly have in the field\n *\n */\n async getOtherSlot() {\n const currentSlot = await this.getSlot();\n if (currentSlot === \"a\") {\n return \"b\";\n } else if (currentSlot === \"b\") {\n return \"a\";\n } else {\n throw new FastbootError(\n \"FAIL\",\n `Unable to determine other slot, current slot: ${currentSlot}`,\n );\n }\n }\n}\n"],"names":["DebugLevel","readBlobAsBuffer","blob","Promise","resolve","reject","reader","FileReader","onload","result","onerror","error","readAsArrayBuffer","FastbootError","Error","status","bootloaderMessage","constructor","message","super","this","name","ImageError","LpError","TimeoutError","timeout","UsbError","debugLevel","Silent","debugLogger","console","log","logDebug","data","logVerbose","FILE_MAGIC","FILE_HEADER_SIZE","CHUNK_HEADER_SIZE","ChunkType","BlobBuilder","type","Blob","append","getBlob","parseFileHeader","buffer","view","DataView","getUint32","major","getUint16","minor","fileHdrSize","chunkHdrSize","blockSize","blocks","chunks","crc32","parseChunkHeader","dataBytes","calcChunksBlockSize","map","chunk","reduce","total","c","calcChunksSize","length","size","calcChunksDataSize","async","createImage","header","blobBuilder","ArrayBuffer","dataView","setUint32","setUint16","arrayView","Uint8Array","chunkArrayView","common.readBlobAsBuffer","set","LP_METADATA_HEADER_MAGIC","LP_SECTOR_SIZE","LP_METADATA_GEOMETRY_SIZE","LP_PARTITION_RESERVED_BYTES","HEADER_V1_0_SIZE","HEADER_V1_2_SIZE","nameFromFixedArray","offset","maxLen","bytes","i","b","getUint8","push","TextDecoder","decode","sha256","digest","crypto","subtle","arraysEqual","a","concatBuffers","buffers","totalLen","acc","byteLength","out","buf","padBuffer","slice","Math","min","parseTableDescriptor","numEntries","entrySize","validateTableBounds","table","tablesSize","tableSize","parsePartition","attributes","firstExtentIndex","numExtents","groupIndex","parseExtent","numSectors","getBigUint64","targetType","targetData","targetSource","parseGroup","flags","maximumSize","parseBlockDevice","firstLogicalSector","alignment","alignmentOffset","partitionName","parseTable","tablesView","descriptor","expectedEntrySize","parser","results","readFromImageBlob","geomBuf","primaryGeometryOffset","geometry","magic","toString","structSize","storedChecksum","forHash","fill","metadataMaxSize","metadataSlotCount","logicalBlockSize","checksum","parseGeometry","headerPeekOffset","headerPeekBuf","peekView","headerSize","headerBuf","tablesBuf","tablesBuffer","majorVersion","minorVersion","tablesChecksum","partitions","extents","groups","blockDevices","headerChecksum","parseHeader","superDevice","validAttributes","LP_PARTITION_ATTRIBUTE_MASK_V0","LP_PARTITION_ATTR_READONLY","partition","end","extent","BigInt","validateParsedMetadata","bd","getMetadataSuperBlockDevice","metadata","getBlockDevicePartitionName","serializeGeometry","serializeTableDescriptor","desc","serializeNameToFixedArray","encoded","TextEncoder","encode","setUint8","serializePartition","serializeExtent","setBigUint64","serializeGroup","group","serializeBlockDevice","serializeMetadata","partitionBufs","extentBufs","groupBufs","blockDevBufs","extentsOffset","s","groupsOffset","blockDevicesOffset","hv","hDescView","buildWipeSuperImages","rawMetaBuf","all","metaBuf","slotCount","allMetadata","Array","metadataBlocks","reservedBlocks","forceSlot","deviceBlocks","Number","sparseBlob","skipBlocks","sparseHeader","Sparse.ChunkType","Fill","Uint32Array","Raw","Skip","Sparse.createImage","MAX_32_BITS","MAX_16_BITS","SPLIT_ZIP_FILE_SIGNATURE","DATA_DESCRIPTOR_RECORD_SIGNATURE","CENTRAL_FILE_HEADER_SIGNATURE","ZIP64_END_OF_CENTRAL_DIR_SIGNATURE","END_OF_CENTRAL_DIR_LENGTH","FILE_ATTR_UNIX_TYPE_DIR","UNDEFINED_VALUE","undefined","INFINITY_VALUE","Infinity","UNDEFINED_TYPE","FUNCTION_TYPE","maxWorkers","navigator","hardwareConcurrency","DEFAULT_CONFIGURATION","workerURI","wasmURI","chunkSize","terminateWorkerTimeout","useWebWorkers","useCompressionStream","CompressionStream","DecompressionStream","config","Object","assign","configure","configuration","baseURI","CompressionStreamZlib","DecompressionStreamZlib","setIfDefined","propertyName","propertyValue","t","j","Crc32","crc","get","Crc32Stream","TransformStream","stream","transform","controller","enqueue","flush","value","bitArray","concat","a1","a2","last","shift","getPartial","_shiftRight","bitLength","l","x","clamp","len","ceil","partial","_end","round","carry","last2","shift2","pop","codec","fromBits","arr","tmp","toBits","hash","sha1","_init","_key","_h","_buffer","_length","reset","update","utf8String","ol","nl","_block","subarray","splice","finalize","h","floor","_f","d","_S","n","words","w","e","cipher","key","aes","_tables","_precompute","sbox","decTable","keyLen","encKey","decKey","rcon","encrypt","_crypt","decrypt","encTable","sboxInv","th","xInv","x2","x4","x8","tDec","tEnc","input","dir","nInnerRounds","t0","t1","t2","t3","b2","c2","kIndex","random","getRandomValues","typedArray","r","m_w","m_z","mask","rcache","_r","mode","prf","iv","_prf","_initIv","_iv","calculate","incWord","word","b1","b3","incCounter","counter","bl","misc","importKey","password","hmacSha1","pbkdf2","salt","count","u","ui","k","arrayBuffer","outLength","setInt32","hmac","Hash","_hash","exKey","_baseHash","bs","_resultHash","_updated","GET_RANDOM_VALUES_SUPPORTED","ERR_INVALID_PASSWORD","ERR_INVALID_SIGNATURE","ERR_ABORT_CHECK_PASSWORD","array","BLOCK_LENGTH","PBKDF2_ALGORITHM","BASE_KEY_ALGORITHM","DERIVED_BITS_ALGORITHM","iterations","DERIVED_BITS_USAGE","SALT_LENGTH","KEY_LENGTH","SIGNATURE_LENGTH","COUNTER_DEFAULT_VALUE","CRYPTO_API_SUPPORTED","SUBTLE_API_SUPPORTED","codecBytes","Aes","CtrGladman","ctrGladman","HmacSha1","IMPORT_KEY_SUPPORTED","DERIVE_BITS_SUPPORTED","deriveBits","AESDecryptionStream","rawPassword","signed","encryptionStrength","checkPasswordOnly","start","ready","resolveReady","encodePassword","strength","pending","aesCrypto","preamble","passwordVerificationKey","createKeys","passwordVerification","createDecryptionKeys","output","ctr","chunkToDecrypt","originalSignature","decryptedChunkArray","encryptedChunk","decryptedChunk","signature","indexSignature","AESEncryptionStream","createEncryptionKeys","encryptedChunkArray","paddingStart","paddingEnd","verifySignature","inputLength","inputArray","expand","inputChunk","outputChunk","baseKey","format","algorithm","extractable","keyUsages","derivedBits","compositeKey","authentication","keys","from","unescape","encodeURIComponent","charCodeAt","encodeText","leftArray","rightArray","begin","ZipCryptoDecryptionStream","zipCrypto","decryptedHeader","at","ZipCryptoEncryptionStream","HEADER_LENGTH","target","index","getByte","updateKeys","crcKey0","crcKey2","byte","key0","key1","key2","getInt32","imul","getInt8","temp","number","ERR_INVALID_UNCOMPRESSED_SIZE","DeflateStream","options","compressed","encrypted","level","crc32Stream","encryptionStream","readable","pipeThrough","pipeThroughCommpressionStream","setReadable","InflateStream","deflate64","decryptionStream","dataViewSignature","defineProperty","CompressionStreamNative","Stream","transformStream","MESSAGE_START","MESSAGE_PULL","MESSAGE_DATA","MESSAGE_CLOSE","CODEC_INFLATE","CodecStream","codecType","startsWith","outputSize","inputSize","inputSizeStream","outputSizeStream","ChunkStream","pendingChunk","newChunk","MODULE_WORKER_OPTIONS","webWorkerSupported","webWorkerURI","webWorkerOptions","transferStreamsSupported","structuredClone","DOMException","code","initModule","CodecWorker","workerData","writable","streamOptions","transferStreams","onTaskFinished","signal","busy","ProgressWatcherStream","terminate","worker","resolveTerminated","interface","terminated","Worker","createWebWorkerInterface","createWorkerInterface","onstart","onprogress","onend","chunkOffset","callHandler","handler","parameters","run","codecStream","pipeTo","preventClose","preventAbort","runWorker","getWebWorker","resolveResult","rejectResult","writer","closed","writableSource","watchClosedStream","streamsTransferred","sendMessage","getReader","getWriter","resultValue","close","runWebWorker","url","isModuleType","useBlobURI","resolvedURI","resolvedOptions","isFunctionURI","isDataURI","isBlobURI","URL","revokeObjectURL","addEventListener","event","messageId","stack","responseError","done","read","write","releaseLock","onMessage","transferables","postMessage","pool","pendingRequests","indexWorker","workerOptions","streamCopy","find","clearTerminateTimeout","getWorker","isFinite","terminateTimeout","setTimeout","filter","terminateWorker","clearTimeout","DEFAULT_CHUNK_SIZE","PROPERTY_NAME_WRITABLE","init","initialized","Reader","ReadableStream","pull","diskNumberStart","dataSize","readUint8Array","BlobReader","offsetEnd","BlobWriter","contentType","headers","Response","getData","TextWriter","encoding","utf8","toLowerCase","text","readAsText","SplitDataReader","readers","lastDiskNumber","lastDiskOffset","diskReader","indexDiskReader","diskNumber","currentDiskNumber","currentReaderOffset","currentReader","currentReaderSize","chunkLength","firstPart","secondPart","max","SplitDataWriter","writerGenerator","maxSize","diskSourceWriter","diskWritable","diskWriter","diskOffset","availableSize","WritableStream","writeChunk","closeDisk","next","initStream","GenericReader","isArray","GenericWriter","initSize","CP437","split","VALID_CP437","decodeText","trim","stringValue","indexCharacter","decodeCP437","PROPERTY_NAME_FILENAME","PROPERTY_NAME_RAW_FILENAME","PROPERTY_NAME_COMMENT","PROPERTY_NAME_RAW_COMMENT","PROPERTY_NAME_UNCOMPRESSED_SIZE","PROPERTY_NAME_COMPRESSED_SIZE","PROPERTY_NAME_OFFSET","PROPERTY_NAME_DISK_NUMBER_START","PROPERTY_NAME_LAST_MODIFICATION_DATE","PROPERTY_NAME_RAW_LAST_MODIFICATION_DATE","PROPERTY_NAME_LAST_ACCESS_DATE","PROPERTY_NAME_RAW_LAST_ACCESS_DATE","PROPERTY_NAME_CREATION_DATE","PROPERTY_NAME_RAW_CREATION_DATE","PROPERTY_NAMES","Entry","forEach","ERR_BAD_FORMAT","ERR_EXTRAFIELD_ZIP64_NOT_FOUND","ERR_UNSUPPORTED_COMPRESSION","ERR_SPLIT_ZIP_FILE","ERR_OVERLAPPING_ENTRY","CHARSET_UTF8","CHARSET_CP437","ZIP64_PROPERTIES","ZIP64_EXTRACTION","getValue","ZipReader","readRanges","getEntriesGenerator","zipReader","getChunkSize","endOfDirectoryInfo","startOffset","minimumBytes","maximumLength","signatureArray","getDataView","maximumBytes","seek","indexByte","seekSignature","endOfDirectoryView","directoryDataLength","directoryDataOffset","commentOffset","commentLength","appendedDataOffset","expectedLastDiskNumber","filesLength","prependedDataLength","endOfDirectoryLocatorView","endOfDirectoryArray","expectedDirectoryDataOffset","originalDirectoryDataOffset","directoryArray","directoryView","expectedDirectoryDataLength","filenameEncoding","getOptionValue","commentEncoding","indexFile","fileEntry","ZipEntry","readCommonHeader","languageEncodingFlag","Boolean","bitFlag","filenameOffset","extraFieldOffset","filenameLength","extraFieldLength","versionMadeBy","msDosCompatible","unixCompatible","rawFilename","endOffset","rawComment","filenameUTF8","commentUTF8","externalFileAttributes","msdosAttributesRaw","msdosAttributes","readOnly","hidden","system","directory","archive","offsetFileEntry","rawFilenameEncoding","rawCommentEncoding","filename","comment","compressedSize","uncompressedSize","internalFileAttributes","rawExtraField","readCommonFooter","unixExternalUpper","unixMode","setuid","setgid","sticky","executable","modeIsDir","upperIsDir","internalFileAttribute","externalFileAttribute","endsWith","extraFieldAES","entry","extractPrependedData","extractAppendedData","prependedData","appendedData","getEntries","entries","zipEntry","extraFieldZip64","compressionMethod","rawLastModDate","dataDescriptor","localDirectory","passThrough","originalCompressionMethod","lastAccessDate","creationDate","dataOffset","checkOverlappingEntry","checkOverlappingEntryOnly","indexReader","dataDescriptorLength","dataDescriptorArray","readSignature","readCompressedSize","readUncompressedSize","range","otherRange","overlappingEntry","detectOverlappingEntry","locked","rawBitFlag","version","lastModDate","getDate","extraField","Map","rawExtraFieldView","offsetExtraField","zip64","extraFieldView","missingProperties","indexMissingProperty","extraction","readExtraFieldZip64","extraFieldUnicodePath","readExtraFieldUnicode","extraFieldUnicodeComment","vendorVersion","vendorId","readExtraFieldAES","extraFieldNTFS","tag1Data","tagValue","attributeSize","tag1View","rawLastAccessDate","rawCreationDate","getDateNTFS","extraFieldData","readExtraFieldNTFS","extraFieldUnix","readExtraFieldUnix","extraFieldInfoZip","extraFieldExtendedTimestamp","timeProperties","timeRawProperties","indexProperty","time","Date","rawPropertyName","readExtraFieldExtendedTimestamp","extraFieldUSDZ","extraFieldUnicode","valid","isInfoZip","uidSize","uidBytes","uid","unpackUnixId","gidSize","gidBytes","gid","base","byteOffset","timeRaw","date","document","require","pathToFileURL","__filename","href","_documentCurrentScript","tagName","toUpperCase","src","A","wasm","malloc","free","memory","_make","isCompress","outBufferSize","outBuffer","inBufferSize","in","_scratch","_process","deflate_process","_last_consumed","deflate_last_consumed","deflate_end","streamHandle","deflate_new","deflate_init_gzip","deflate_init_raw","deflate_init","inflate9_process","inflate9_last_consumed","inflate9_end","inflate9_new","inflate9_init_raw","inflate_process","inflate_last_consumed","inflate_end","inflate_new","inflate_init_raw","inflate_init_gzip","inflate_init","heap","process","last_consumed","scratch","toRead","prod","signedCode","consumed","produced","modulePromise","initializedModule","uri","response","fetch","dataURI","base64","binary","atob","arrayBufferFromDataURI","wasmAPI","setWasmExports","WebAssembly","instantiate","instance","exports","g","B","replace","E","I","indexOf","C","Q","D","o","configureZlibModule","initModuleFunction","configureWorker","application","annodex","bbolin","dsptype","ecmascript","futuresplash","hta","m3g","mathematica","msaccess","msword","mxf","oda","ogg","pdf","postscript","rar","rtf","xml","zip","applixware","exi","gxf","hyperstudio","ipfix","marc","mbox","mp21","mp4","onenote","oxps","pkcs10","pkcs8","pkixcmp","sdp","srgs","widget","winhlp","yang","envoy","fractals","olescript","gzip","yaml","audio","amr","basic","flac","midi","mpeg","mpegurl","adpcm","s3m","silk","webm","xm","aac","aiff","opus","wav","chemical","font","otf","woff","woff2","image","gif","ief","jpeg","pcx","png","tiff","bmp","cgm","g3fax","ktx","sgi","webp","avif","heic","pjpeg","rfc822","model","iges","mesh","vrml","calendar","css","csv","h323","html","iuls","plain","richtext","scriptlet","texmacs","n3","sgml","troff","turtle","vcard","webviewhtml","javascript","json","markdown","video","dl","dv","fli","gl","quicktime","h261","h263","h264","jpm","mj2","mp2t","waitForFrame","window","requestAnimationFrame","runWithTimedProgress","onProgress","action","item","duration","workPromise","startTime","getTime","stop","progressPromise","now","targetTime","race","mimeTypes","subtype","indexMimeType","createObjectURL","configureWebWorker","BOOT_CRITICAL_IMAGES","SYSTEM_IMAGES","BOOTLOADER_REBOOT_TIME","flashEntryBlob","device","slot","flashBlob","progress","tryFlashImages","imageNames","imageName","pattern","RegExp","match","tryRebootWithSlotSwitch","onReconnect","rebootSwitchSlot","waitForConnect","flashZip","wipe","avbCustomKeyEntry","getVariable","reboot","snapshotStatus","runCommand","imagesBlob","imageReader","imageEntries","reqText","androidInfo","line","variable","expectValue","expectValues","hasSlot","includes","realValue","msg","checkRequirements","superName","superAction","superBlob","upload","epIn","epOut","_registeredUsbListeners","_connectResolve","_connectReject","_disconnectResolve","isConnected","opened","configurations","interfaces","claimed","_validateAndConnectDevice","ife","alternates","endpoints","endpoint","endpointNumber","direction","packetSize","open","selectConfiguration","claimInterface","waitForDisconnect","userAgent","connect","usb","requestDevice","filters","classCode","subclassCode","protocolCode","hasPromiseReject","_readResponse","respData","respStatus","respPacket","transferIn","substring","respMessage","command","RangeError","cmdPacket","transferOut","varName","resp","promise","timedOut","tid","then","val","catch","err","finally","_getDownloadSize","parseInt","_sendRawPayload","remainingBytes","xferHex","padStart","downloadResp","downloadSize","wait","otherSlot","getOtherSlot","currentSlot","getSlot","maxDlSize","fileHeader","Sparse.FILE_HEADER_SIZE","totalBytes","isSparse","Sparse.parseFileHeader","Sparse.fromRaw","splits","sentBytes","splitSize","safeSendValue","splitChunks","splitDataBytes","originalChunk","chunksToProcess","originalDataBytes","originalData","toSend","bytesRemaining","splitBlocks","splitImage","Sparse.splitBlob","bootBlob","flashFactoryZip","wipeSuper","Lp.readFromImageBlob","resolvedSlot","images","Lp.buildWipeSuperImages","Lp.getMetadataSuperBlockDevice","Lp.getBlockDevicePartitionName","flashPartition","load","unpack","flash","logger"],"mappings":"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pB,mBAAoB,CACnB,MACA,MACA,MACA,OAED,mBAAoB,MACpB,mBAAoB,MACpB,UAAW,CACV,MACA,SAED,SAAU,KACV,UAAW,CACV,MACA,OAED,mBAAoB,MACpB,SAAU,OACV,eAAgB,MAChB,mBAAoB,MACpB,eAAgB,MAChB,eAAgB,MAChB,oBAAqB,MACrB,QAAS,MACT,aAAc,MACd,qBAAsB,MACtB,mBAAoB,MACpB,aAAc,MACd,aAAc,MACd,aAAc,CACb,MACA,OAED,eAAgB,CACf,MACA,MACA,MACA,OAED,YAAa,MACb,mBAAoB,MACpB,UAAW,MACX,eAAgB,SAChB,yBAA0B,UAC1B,mBAAoB,CACnB,MACA,OAED,QAAS,MACT,qBAAsB,CACrB,MACA,QAED,mBAAoB,cACpB,gBAAiB,MACjB,YAAa,OACb,aAAc,MACd,eAAgB,MAChB,WAAY,MACZ,6BAA8B,MAC9B,gBAAiB,CAChB,MACA,MACA,OAED,eAAgB,CACf,MACA,MACA,MACA,OAED,YAAa,MACb,gBAAiB,MACjB,eAAgB,MAChB,eAAgB,MAChB,YAAa,MACb,QAAS,MACT,WAAY,CACX,MACA,OAED,uBAAwB,CACvB,MACA,OAED,0BAA2B,MAC3B,oBAAqB,MACrB,QAAS,MACT,aAAc,OACd,WAAY,MACZ,eAAgB,KAChB,YAAa,MACb,SAAU,MACV,cAAe,MACf,OAAQ,KACR,aAAc,CACb,KACA,KACA,KACA,KACA,KACA,KACA,KACA,MAED,WAAY,OACZ,gBAAiB,MACjB,WAAY,OACZ,UAAW,MACX,UAAW,MACX,YAAa,MACb,WAAY,OACZ,SAAU,CACT,OACA,QACA,OACA,OAEDC,KAAQ,OACR,UAAW,MACXC,MAAS,MACTC,SAAY,MACZ,2BAA4B,MAC5BC,UAAa,MACb,iBAAkB,MAClB,sBAAuB,MACvB,aAAc,IACd,YAAa,CACZ,MACA,MACA,MACA,OAED,gBAAiB,MACjBC,KAAQ,CACP,KACA,OAED,WAAY,CACX,MACA,QAED,4BAA6B,CAC5B,MACA,QAED,uBAAwB,MACxB,cAAe,CACd,KACA,SACA,UACA,SACA,aACA,SACA,cAED,cAAe,MACf,cAAe,MACf,UAAW,CACV,MACA,OAED,SAAU,CACT,KACA,MAEDC,KAAQ,CACP,OACA,QAGFC,MAAS,CACRC,IAAO,MACP,SAAU,MACV5C,QAAW,MACX6C,MAAS,CACR,KACA,OAEDC,KAAQ,OACRC,KAAQ,CACP,MACA,OACA,MACA,OAEDC,KAAQ,CACP,OACA,QACA,MACA,MACA,OACA,MACA,OAEDC,QAAW,MACXrC,IAAO,CACN,MACA,MACA,OAED,UAAW,MACX,SAAU,OACV,QAAS,MACT,WAAY,MACZ,WAAY,MACZ,iBAAkB,MAClB,cAAe,KACf,QAAS,MACTsC,MAAS,MACTvB,IAAO,OACPwB,IAAO,MACPC,KAAQ,MACR,iBAAkB,CACjB,MACA,QAED,oBAAqB,MACrB,UAAW,MACX,UAAW,MACX,aAAc,QACd,mBAAoB,MACpB,6BAA8B,MAC9B,sBAAuB,YACvB,sBAAuB,YACvB,sBAAuB,YACvB,UAAW,MACXC,KAAQ,OACR,QAAS,MACT,aAAc,MACd,wBAAyB,MACzBC,GAAM,KACNC,IAAO,MACPC,KAAQ,CACP,OACA,MACA,OAEDC,KAAQ,OACRC,IAAO,OAERC,SAAY,CACX,YAAa,MACb,UAAW,CACV,MACA,SAED,cAAe,MACf,kBAAmB,CAClB,OACA,SACA,QAED,QAAS,MACT,WAAY,MACZ,QAAS,MACT,SAAU,OACV,QAAS,MACT,YAAa,MACb,cAAe,MACf,SAAU,CACT,OACA,OAED,QAAS,MACT,QAAS,CACR,MACA,OAED,uBAAwB,CACvB,MACA,QAED,iBAAkB,CACjB,MACA,MACA,SAED,wBAAyB,CACxB,MACA,QAED,kBAAmB,MACnB,mBAAoB,CACnB,MACA,MACA,OAED,iBAAkB,MAClB,kBAAmB,MACnB,YAAa,MACb,QAAS,MACT,YAAa,CACZ,OACA,OAED,aAAc,CACb,MACA,MAED,aAAc,MACd,gBAAiB,MACjB,qBAAsB,OACtB,gBAAiB,MACjB,eAAgB,KAChB,gBAAiB,MACjB,eAAgB,KAChB,YAAa,MACb,UAAW,OACX,SAAU,OACV,cAAe,IACf,gBAAiB,MACjB,gBAAiB,CAChB,MACA,SACA,OAED,cAAe,MACf,cAAe,MACf,oBAAqB,CACpB,MACA,OAED,qBAAsB,MACtB,WAAY,MACZ,cAAe,KACf,mBAAoB,MACpB,QAAS,MACT,SAAU,OACV,QAAS,OAEVC,KAAQ,CACPC,IAAO,MACPC,KAAQ,OACRC,MAAS,SAEVC,MAAS,CACRC,IAAO,MACPC,IAAO,MACPC,KAAQ,CACP,OACA,MACA,MACA,OACA,YACA,OAEDC,IAAO,MACPC,IAAO,MACP,UAAW,CACV,MACA,QAEDC,KAAQ,CACP,OACA,OAED,WAAY,CACX,OACA,OAED,eAAgB,OAChB,cAAe,MACf,cAAe,MACf,eAAgB,MAChB,cAAe,MACf,qBAAsB,MACtB,sBAAuB,MACvB,oBAAqB,MACrB,cAAe,MACf,SAAU,MACV,OAAQ,MACR,QAAS,MACT,cAAe,MACf,gBAAiB,MACjB,oBAAqB,MACrB,oBAAqB,MACrB,qBAAsB,MACtB,oBAAqB,MACrB,QAAS,MACT,YAAa,MACb,YAAa,MACb,gBAAiB,MACjBC,IAAO,MACPC,IAAO,MACPC,MAAS,KACTC,IAAO,MACP,WAAY,OACZC,IAAO,MACP,mBAAoB,CACnB,MACA,OACA,MACA,QAED,UAAW,MACX,UAAW,MACX,mBAAoB,MACpB,UAAW,MACX,UAAW,MACX,2BAA4B,MAC5B,2BAA4B,MAC5B,cAAe,MACf,eAAgB,MAChB,cAAe,MACf,WAAY,MACZC,KAAQ,OACR,QAAS,MACT,QAAS,MACT,aAAc,CACb,KACA,MACA,MACA,MACA,OAED,SAAU,CACT,MACA,OAED,QAAS,MACT,UAAW,MACXC,KAAQ,QACRC,KAAQ,CACP,OACA,QAEDC,MAAS,CACR,QAED,sBAAuB,MACvB,cAAe,MACf,aAAc,MACd,SAAU,OACV,cAAe,MACf,cAAe,MACf,cAAe,MACf,gBAAiB,MACjB,kBAAmB,CAClB,MACA,MACA,OAED,eAAgB,CACf,MACA,OAED,cAAe,MACf,aAAc,MACd,aAAc,MACd,aAAc,OAEfnhC,QAAW,CACVohC,OAAU,CACT,MACA,OACA,MACA,QACA,QAGFC,MAAS,CACRC,KAAQ,CACP,MACA,QAEDC,KAAQ,CACP,MACA,OACA,QAEDC,KAAQ,CACP,MACA,QAED,WAAY,CACX,OACA,SAED,UAAW,OACX,aAAc,CACb,OACA,SAED,kBAAmB,MACnB,UAAW,MACX,UAAW,MACX,UAAW,MACX,UAAW,MACX,eAAgB,OAChB,UAAW,OAEZrZ,KAAQ,CACP,iBAAkB,CACjB,WACA,YAEDsZ,SAAY,CACX,MACA,MACA,OAEDC,IAAO,MACPC,IAAO,MACPC,KAAQ,MACRC,KAAQ,CACP,OACA,MACA,QACA,OAEDC,KAAQ,MACRC,MAAS,CACR,MACA,OACA,MACA,OACA,MACA,OACA,MACA,KACA,MACA,OACA,OAEDC,SAAY,MACZC,UAAa,CACZ,MACA,OAEDC,QAAW,KACX,uBAAwB,MACxB,8BAA+B,MAC/B,cAAe,MACf,oBAAqB,OACrB,WAAY,MACZ,QAAS,MACT,WAAY,CACX,MACA,MACA,MACA,MAED,WAAY,CACX,MACA,MACA,MACA,MAED,cAAe,MACf,SAAU,IACV,SAAU,QACV,YAAa,KACb,SAAU,OACV,qBAAsB,MACtB,QAAS,MACT,WAAY,CACX,IACA,MACA,KACA,OAED,YAAa,MACb,WAAY,KACZ,UAAW,QACX,WAAY,MACZ,QAAS,CACR,MACA,MAED,QAAS,CACR,MACA,MACA,MACA,OAED,cAAe,MACf,UAAW,MACXC,GAAM,KACN,gBAAiB,MACjBC,KAAQ,CACP,OACA,OAEDC,MAAS,CACR,IACA,KACA,OACA,MACA,KACA,MAEDC,OAAU,MACV,WAAY,CACX,MACA,OACA,QAEDC,MAAS,QACT,WAAY,OACZ,iBAAkB,QAClB,iBAAkB,QAClB,iBAAkB,QAClB,mBAAoB,MACpB,UAAW,MACX,mBAAoB,MACpB,eAAgB,KAChB,gBAAiB,OACjB,gBAAiB,OACjB,QAAS,CACR,IACA,OAED,MAAO,CACN,IACA,IACA,OAED,YAAa,CACZ,IACA,MACA,MACA,OAED,SAAU,OACV,QAAS,MACT,QAAS,MACT,aAAc,KACdC,YAAe,MACfC,WAAc,KACdC,KAAQ,OACRC,S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","x_google_ignoreList":[5,6,7,8,9,10,11,12,13,14,15,16,17,18,19,20,21,22,23,24,25,26,27,28,29,31,32]}
|
|
1
|
+
{"version":3,"file":"fastboot.min.cjs","sources":["../src/utils/logger.ts","../src/common.ts","../src/utils/errors.ts","../src/sparse.ts","../src/lp.ts","../node_modules/.pnpm/@zip.js+zip.js@2.8.26/node_modules/@zip.js/zip.js/lib/core/constants.js","../node_modules/.pnpm/@zip.js+zip.js@2.8.26/node_modules/@zip.js/zip.js/lib/core/configuration.js","../node_modules/.pnpm/@zip.js+zip.js@2.8.26/node_modules/@zip.js/zip.js/lib/core/streams/codecs/crc32.js","../node_modules/.pnpm/@zip.js+zip.js@2.8.26/node_modules/@zip.js/zip.js/lib/core/streams/crc32-stream.js","../node_modules/.pnpm/@zip.js+zip.js@2.8.26/node_modules/@zip.js/zip.js/lib/core/streams/codecs/sjcl.js","../node_modules/.pnpm/@zip.js+zip.js@2.8.26/node_modules/@zip.js/zip.js/lib/core/streams/common-crypto.js","../node_modules/.pnpm/@zip.js+zip.js@2.8.26/node_modules/@zip.js/zip.js/lib/core/streams/aes-crypto-stream.js","../node_modules/.pnpm/@zip.js+zip.js@2.8.26/node_modules/@zip.js/zip.js/lib/core/util/encode-text.js","../node_modules/.pnpm/@zip.js+zip.js@2.8.26/node_modules/@zip.js/zip.js/lib/core/streams/zip-crypto-stream.js","../node_modules/.pnpm/@zip.js+zip.js@2.8.26/node_modules/@zip.js/zip.js/lib/core/streams/zip-entry-stream.js","../node_modules/.pnpm/@zip.js+zip.js@2.8.26/node_modules/@zip.js/zip.js/lib/core/streams/codec-stream.js","../node_modules/.pnpm/@zip.js+zip.js@2.8.26/node_modules/@zip.js/zip.js/lib/core/codec-worker.js","../node_modules/.pnpm/@zip.js+zip.js@2.8.26/node_modules/@zip.js/zip.js/lib/core/codec-pool.js","../node_modules/.pnpm/@zip.js+zip.js@2.8.26/node_modules/@zip.js/zip.js/lib/core/io.js","../node_modules/.pnpm/@zip.js+zip.js@2.8.26/node_modules/@zip.js/zip.js/lib/core/util/decode-cp437.js","../node_modules/.pnpm/@zip.js+zip.js@2.8.26/node_modules/@zip.js/zip.js/lib/core/util/decode-text.js","../node_modules/.pnpm/@zip.js+zip.js@2.8.26/node_modules/@zip.js/zip.js/lib/core/zip-entry.js","../node_modules/.pnpm/@zip.js+zip.js@2.8.26/node_modules/@zip.js/zip.js/lib/core/options.js","../node_modules/.pnpm/@zip.js+zip.js@2.8.26/node_modules/@zip.js/zip.js/lib/core/zip-reader.js","../node_modules/.pnpm/@zip.js+zip.js@2.8.26/node_modules/@zip.js/zip.js/lib/zip-core-base.js","../node_modules/.pnpm/@zip.js+zip.js@2.8.26/node_modules/@zip.js/zip.js/lib/core/zlib-streams-inline.js","../node_modules/.pnpm/@zip.js+zip.js@2.8.26/node_modules/@zip.js/zip.js/lib/core/streams/zlib-wasm/zlib-streams.js","../node_modules/.pnpm/@zip.js+zip.js@2.8.26/node_modules/@zip.js/zip.js/lib/core/streams/zlib-wasm/zlib-streams-loader.js","../node_modules/.pnpm/@zip.js+zip.js@2.8.26/node_modules/@zip.js/zip.js/lib/zip-module-wasm.js","../node_modules/.pnpm/@zip.js+zip.js@2.8.26/node_modules/@zip.js/zip.js/lib/core/util/mime-type.js","../src/utils/progress.ts","../node_modules/.pnpm/@zip.js+zip.js@2.8.26/node_modules/@zip.js/zip.js/lib/core/web-worker-inline-wasm.js","../node_modules/.pnpm/@zip.js+zip.js@2.8.26/node_modules/@zip.js/zip.js/lib/zip-fs-wasm.js","../src/factory.ts","../src/fastboot.ts"],"sourcesContent":["export enum DebugLevel {\n Silent = 0,\n Debug,\n Verbose,\n}\n\nexport type DebugLogger = (...data: unknown[]) => void;\n\nlet debugLevel = DebugLevel.Silent;\nlet debugLogger = console.log;\n\nexport function logDebug(...data: unknown[]) {\n if (debugLevel >= 1) {\n debugLogger(...data);\n }\n}\n\nexport function logVerbose(...data: unknown[]) {\n if (debugLevel >= 2) {\n debugLogger(...data);\n }\n}\n\n/**\n * Change the debug level for the fastboot client:\n * - 0 = silent\n * - 1 = debug, recommended for general use\n * - 2 = verbose, for debugging only\n *\n * @param {number} level - Debug level to use.\n */\nexport function setDebugLevel(level: DebugLevel) {\n debugLevel = level;\n}\n\n/**\n * Change the debug logger function for the fastboot client.\n *\n * @param {DebugLogger} logger - Debug logger function to use.\n */\nexport function setDebugLogger(logger: DebugLogger) {\n debugLogger = logger;\n}\n","/**\n * Reads all of the data in the given blob and returns it as an ArrayBuffer.\n *\n * @param {Blob} blob - Blob with the data to read.\n * @returns {Promise<ArrayBuffer>} ArrayBuffer containing data from the blob.\n * @ignore\n */\nexport function readBlobAsBuffer(blob: Blob): Promise<ArrayBuffer> {\n return new Promise((resolve, reject) => {\n const reader = new FileReader();\n reader.onload = () => {\n resolve(reader.result! as ArrayBuffer);\n };\n reader.onerror = () => {\n reject(reader.error);\n };\n\n reader.readAsArrayBuffer(blob);\n });\n}\n","/**\n * Exception class for errors returned by the bootloader, as well as high-level\n * fastboot errors resulting from bootloader responses.\n */\nexport class FastbootError extends Error {\n status: string;\n bootloaderMessage: string;\n\n constructor(status: string, message: string) {\n super(`Bootloader replied with ${status}: ${message}`);\n this.status = status;\n this.bootloaderMessage = message;\n this.name = \"FastbootError\";\n }\n}\n\n/**\n * Exception class for Sparse Image errors.\n */\nexport class ImageError extends Error {\n constructor(message: string) {\n super(message);\n this.name = \"ImageError\";\n }\n}\n\n/**\n * Exception class for logical partition parsing errors.\n */\nexport class LpError extends Error {\n constructor(message: string) {\n super(message);\n this.name = \"LpError\";\n }\n}\n\n/**\n * Exception class for operations that exceeded their timeout duration.\n */\nexport class TimeoutError extends Error {\n timeout: number;\n\n constructor(timeout: number) {\n super(`Timeout of ${timeout} ms exceeded`);\n this.name = \"TimeoutError\";\n this.timeout = timeout;\n }\n}\n\n/**\n * Exception class for USB errors not directly thrown by WebUSB.\n */\nexport class UsbError extends Error {\n constructor(message: string) {\n super(message);\n this.name = \"UsbError\";\n }\n}\n","import * as common from \"./common\";\nimport { ImageError } from \"./utils/errors\";\nimport { logDebug, logVerbose } from \"./utils/logger\";\n\nconst FILE_MAGIC = 0xed26ff3a;\n\nconst MAJOR_VERSION = 1;\nconst MINOR_VERSION = 0;\nexport const FILE_HEADER_SIZE = 28;\nconst CHUNK_HEADER_SIZE = 12;\n\n// AOSP libsparse uses 64 MiB chunks\nconst RAW_CHUNK_SIZE = 64 * 1024 * 1024;\n\nexport interface SparseSplit {\n data: ArrayBuffer;\n bytes: number;\n}\n\nexport enum ChunkType {\n Raw = 0xcac1,\n Fill = 0xcac2,\n Skip = 0xcac3,\n Crc32 = 0xcac4,\n}\n\nexport interface SparseHeader {\n blockSize: number;\n blocks: number;\n chunks: number;\n crc32: number;\n}\n\nexport interface SparseChunk {\n type: ChunkType;\n /* 2: reserved, 16 bits */\n blocks: number;\n dataBytes: number;\n data: Blob | null; // to be populated by consumer\n}\n\nclass BlobBuilder {\n private blob: Blob;\n private type: string;\n\n constructor(type: string = \"\") {\n this.type = type;\n this.blob = new Blob([], { type: this.type });\n }\n\n append(blob: Blob) {\n this.blob = new Blob([this.blob, blob], { type: this.type });\n }\n\n getBlob(): Blob {\n return this.blob;\n }\n}\n\n/**\n * Returns a parsed version of the sparse image file header from the given buffer.\n *\n * @param {ArrayBuffer} buffer - Raw file header data.\n * @returns {SparseHeader} Object containing the header information.\n */\nexport function parseFileHeader(buffer: ArrayBuffer): SparseHeader | null {\n const view = new DataView(buffer);\n\n const magic = view.getUint32(0, true);\n if (magic !== FILE_MAGIC) {\n return null;\n }\n\n // v1.0+\n const major = view.getUint16(4, true);\n const minor = view.getUint16(6, true);\n if (major !== MAJOR_VERSION || minor < MINOR_VERSION) {\n throw new ImageError(\n `Unsupported sparse image version ${major}.${minor}`,\n );\n }\n\n const fileHdrSize = view.getUint16(8, true);\n const chunkHdrSize = view.getUint16(10, true);\n if (\n fileHdrSize !== FILE_HEADER_SIZE ||\n chunkHdrSize !== CHUNK_HEADER_SIZE\n ) {\n throw new ImageError(\n `Invalid file header size ${fileHdrSize}, chunk header size ${chunkHdrSize}`,\n );\n }\n\n const blockSize = view.getUint32(12, true);\n if (blockSize % 4 !== 0) {\n throw new ImageError(`Block size ${blockSize} is not a multiple of 4`);\n }\n\n return {\n blockSize: blockSize,\n blocks: view.getUint32(16, true),\n chunks: view.getUint32(20, true),\n crc32: view.getUint32(24, true),\n };\n}\n\nfunction parseChunkHeader(buffer: ArrayBuffer) {\n const view = new DataView(buffer);\n\n // This isn't the same as what createImage takes.\n // Further processing needs to be done on the chunks.\n return {\n type: view.getUint16(0, true),\n /* 2: reserved, 16 bits */\n blocks: view.getUint32(4, true),\n dataBytes: view.getUint32(8, true) - CHUNK_HEADER_SIZE,\n data: null, // to be populated by consumer\n } as SparseChunk;\n}\n\nfunction calcChunksBlockSize(chunks: Array<SparseChunk>) {\n return chunks\n .map((chunk) => chunk.blocks)\n .reduce((total, c) => total + c, 0);\n}\n\nfunction calcChunksDataSize(chunks: Array<SparseChunk>) {\n return chunks\n .map((chunk) => chunk.data!.size)\n .reduce((total, c) => total + c, 0);\n}\n\nfunction calcChunksSize(chunks: Array<SparseChunk>) {\n // 28-byte file header, 12-byte chunk headers\n const overhead = FILE_HEADER_SIZE + CHUNK_HEADER_SIZE * chunks.length;\n return overhead + calcChunksDataSize(chunks);\n}\n\nexport async function createImage(\n header: SparseHeader,\n chunks: Array<SparseChunk>,\n): Promise<Blob> {\n const blobBuilder = new BlobBuilder();\n\n let buffer = new ArrayBuffer(FILE_HEADER_SIZE);\n let dataView = new DataView(buffer);\n\n dataView.setUint32(0, FILE_MAGIC, true);\n // v1.0\n dataView.setUint16(4, MAJOR_VERSION, true);\n dataView.setUint16(6, MINOR_VERSION, true);\n dataView.setUint16(8, FILE_HEADER_SIZE, true);\n dataView.setUint16(10, CHUNK_HEADER_SIZE, true);\n\n // Match input parameters\n dataView.setUint32(12, header.blockSize, true);\n dataView.setUint32(16, header.blocks, true);\n dataView.setUint32(20, chunks.length, true);\n\n // We don't care about the CRC. AOSP docs specify that this should be a CRC32,\n // but AOSP libsparse always sets 0 and puts the CRC in a final undocumented\n // 0xCAC4 chunk instead.\n dataView.setUint32(24, 0, true);\n\n blobBuilder.append(new Blob([buffer]));\n for (const chunk of chunks) {\n buffer = new ArrayBuffer(CHUNK_HEADER_SIZE + chunk.data!.size);\n dataView = new DataView(buffer);\n const arrayView = new Uint8Array(buffer);\n\n dataView.setUint16(0, chunk.type, true);\n dataView.setUint16(2, 0, true); // reserved\n dataView.setUint32(4, chunk.blocks, true);\n dataView.setUint32(8, CHUNK_HEADER_SIZE + chunk.data!.size, true);\n\n const chunkArrayView = new Uint8Array(\n await common.readBlobAsBuffer(chunk.data!),\n );\n arrayView.set(chunkArrayView, CHUNK_HEADER_SIZE);\n blobBuilder.append(new Blob([buffer]));\n }\n\n return blobBuilder.getBlob();\n}\n\n/**\n * Creates a sparse image from buffer containing raw image data.\n *\n * @param {Blob} blob - Blob containing the raw image data.\n * @returns {Promise<Blob>} Promise that resolves the blob containing the new sparse image.\n */\nexport async function fromRaw(blob: Blob): Promise<Blob> {\n const header = {\n blockSize: 4096,\n blocks: blob.size / 4096,\n chunks: 1,\n crc32: 0,\n };\n\n const chunks = [];\n while (blob.size > 0) {\n const chunkSize = Math.min(blob.size, RAW_CHUNK_SIZE);\n chunks.push({\n type: ChunkType.Raw,\n blocks: chunkSize / header.blockSize,\n data: blob.slice(0, chunkSize),\n } as SparseChunk);\n blob = blob.slice(chunkSize);\n }\n\n return createImage(header, chunks);\n}\n\n/**\n * Split a sparse image into smaller sparse images within the given size.\n * This takes a Blob instead of an ArrayBuffer because it may process images\n * larger than RAM.\n *\n * @param {Blob} blob - Blob containing the sparse image to split.\n * @param {number} splitSize - Maximum size per split.\n * @yields {Object} Data of the next split image and its output size in bytes.\n */\nexport async function* splitBlob(blob: Blob, splitSize: number) {\n logDebug(\n `Splitting ${blob.size}-byte sparse image into ${splitSize}-byte chunks`,\n );\n\n // 7/8 is a safe value for the split size, to account for extra overhead\n // AOSP source code does the same\n const safeSendValue = Math.floor(splitSize * (7 / 8));\n\n // Short-circuit if splitting isn't required\n if (blob.size <= splitSize) {\n logDebug(\"Blob fits in 1 payload, not splitting\");\n yield {\n data: await common.readBlobAsBuffer(blob),\n bytes: blob.size,\n } as SparseSplit;\n return;\n }\n\n const headerData = await common.readBlobAsBuffer(\n blob.slice(0, FILE_HEADER_SIZE),\n );\n const header = parseFileHeader(headerData);\n if (header === null) {\n throw new ImageError(\"Blob is not a sparse image\");\n }\n\n // Remove CRC32 (if present), otherwise splitting will invalidate it\n header.crc32 = 0;\n blob = blob.slice(FILE_HEADER_SIZE);\n\n let splitChunks: Array<SparseChunk> = [];\n let splitDataBytes = 0;\n for (let i = 0; i < header.chunks; i++) {\n const chunkHeaderData = await common.readBlobAsBuffer(\n blob.slice(0, CHUNK_HEADER_SIZE),\n );\n const originalChunk = parseChunkHeader(chunkHeaderData);\n originalChunk.data = blob.slice(\n CHUNK_HEADER_SIZE,\n CHUNK_HEADER_SIZE + originalChunk.dataBytes,\n );\n blob = blob.slice(CHUNK_HEADER_SIZE + originalChunk.dataBytes);\n\n const chunksToProcess: SparseChunk[] = [];\n\n // take into account cases where the chunk data is bigger than the maximum allowed download size\n if (originalChunk.dataBytes > safeSendValue) {\n logDebug(\n `Data of chunk ${i} is bigger than the maximum allowed download size: ${originalChunk.dataBytes} > ${safeSendValue}`,\n );\n\n // we should now split this chunk into multiple chunks that fit\n let originalDataBytes = originalChunk.dataBytes;\n let originalData = originalChunk.data;\n\n while (originalDataBytes > 0) {\n const toSend = Math.min(safeSendValue, originalDataBytes);\n\n chunksToProcess.push({\n type: originalChunk.type,\n dataBytes: toSend,\n data: originalData.slice(0, toSend),\n blocks: toSend / header?.blockSize,\n });\n\n originalData = originalData.slice(toSend);\n originalDataBytes -= toSend;\n }\n\n logDebug(\"chunksToProcess\", chunksToProcess);\n } else {\n chunksToProcess.push(originalChunk);\n }\n\n for (const chunk of chunksToProcess) {\n const bytesRemaining = splitSize - calcChunksSize(splitChunks);\n logVerbose(\n ` Chunk ${i}: type ${chunk.type}, ${chunk.dataBytes} bytes / ${chunk.blocks} blocks, ${bytesRemaining} bytes remaining`,\n );\n\n if (bytesRemaining >= chunk.dataBytes) {\n // Read the chunk and add it\n logVerbose(\" Space is available, adding chunk\");\n splitChunks.push(chunk);\n // Track amount of data written on the output device, in bytes\n splitDataBytes += chunk.blocks * header.blockSize;\n } else {\n // Out of space, finish this split\n // Blocks need to be calculated from chunk headers instead of going by size\n // because FILL and SKIP chunks cover more blocks than the data they contain.\n const splitBlocks = calcChunksBlockSize(splitChunks);\n splitChunks.push({\n type: ChunkType.Skip,\n blocks: header.blocks - splitBlocks,\n data: new Blob([]),\n dataBytes: 0,\n });\n logVerbose(\n `Partition is ${\n header.blocks\n } blocks, used ${splitBlocks}, padded with ${\n header.blocks - splitBlocks\n }, finishing split with ${calcChunksBlockSize(\n splitChunks,\n )} blocks`,\n );\n const splitImage = await createImage(header, splitChunks);\n logDebug(\n `Finished ${splitImage.size}-byte split with ${splitChunks.length} chunks`,\n );\n yield {\n data: await common.readBlobAsBuffer(splitImage),\n bytes: splitDataBytes,\n } as SparseSplit;\n\n // Start a new split. Every split is considered a full image by the\n // bootloader, so we need to skip the *total* written blocks.\n logVerbose(\n `Starting new split: skipping first ${splitBlocks} blocks and adding chunk`,\n );\n splitChunks = [\n {\n type: ChunkType.Skip,\n blocks: splitBlocks,\n data: new Blob([]),\n dataBytes: 0,\n },\n chunk,\n ];\n\n splitDataBytes = chunk.dataBytes;\n }\n }\n }\n\n // Finish the final split if necessary\n if (\n splitChunks.length > 0 &&\n (splitChunks.length > 1 || splitChunks[0].type !== ChunkType.Skip)\n ) {\n const splitImage = await createImage(header, splitChunks);\n logDebug(\n `Finishing final ${splitImage.size}-byte split with ${splitChunks.length} chunks`,\n );\n yield {\n data: await common.readBlobAsBuffer(splitImage),\n bytes: splitDataBytes,\n } as SparseSplit;\n }\n}\n","import * as common from \"./common\";\nimport * as Sparse from \"./sparse\";\nimport { LpError } from \"./utils/errors\";\nimport { logDebug } from \"./utils/logger\";\n\n// Magic values\nconst LP_METADATA_GEOMETRY_MAGIC = 0x616c4467;\nconst LP_METADATA_HEADER_MAGIC = 0x414c5030;\n\n// Layout sizes\nconst LP_SECTOR_SIZE = 512;\nconst LP_METADATA_GEOMETRY_SIZE = 4096;\nconst LP_PARTITION_RESERVED_BYTES = 4096;\n\n// Version\nconst LP_METADATA_MAJOR_VERSION = 10;\nconst LP_METADATA_MINOR_VERSION_MAX = 2;\nconst LP_METADATA_VERSION_FOR_UPDATED_ATTR = 1;\nconst LP_METADATA_VERSION_FOR_EXPANDED_HEADER = 2;\n\n// Struct sizes (packed, little-endian, from AOSP liblp)\nconst GEOMETRY_STRUCT_SIZE = 52;\nconst HEADER_V1_0_SIZE = 128;\nconst HEADER_V1_2_SIZE = 256;\nconst PARTITION_STRUCT_SIZE = 52;\nconst EXTENT_STRUCT_SIZE = 24;\nconst GROUP_STRUCT_SIZE = 48;\nconst BLOCK_DEVICE_STRUCT_SIZE = 64;\n\nconst LP_BLOCK_DEVICE_SLOT_SUFFIXED = 0x1;\n\n// Partition attribute flags\nconst LP_PARTITION_ATTR_READONLY = 0x1;\nconst LP_PARTITION_ATTR_SLOT_SUFFIXED = 0x2;\nconst LP_PARTITION_ATTR_UPDATED = 0x4;\nconst LP_PARTITION_ATTR_DISABLED = 0x8;\n\nconst LP_PARTITION_ATTRIBUTE_MASK_V0 =\n LP_PARTITION_ATTR_READONLY | LP_PARTITION_ATTR_SLOT_SUFFIXED;\nconst LP_PARTITION_ATTRIBUTE_MASK_V1 =\n LP_PARTITION_ATTR_UPDATED | LP_PARTITION_ATTR_DISABLED;\n\n// Extent target types\nconst LP_TARGET_TYPE_LINEAR = 0;\n\nexport interface LpMetadataGeometry {\n magic: number;\n structSize: number;\n checksum: Uint8Array; // 32 bytes, SHA-256\n metadataMaxSize: number;\n metadataSlotCount: number;\n logicalBlockSize: number;\n}\n\nexport interface LpMetadataTableDescriptor {\n offset: number;\n numEntries: number;\n entrySize: number;\n}\n\nexport interface LpMetadataHeader {\n magic: number;\n majorVersion: number;\n minorVersion: number;\n headerSize: number;\n headerChecksum: Uint8Array; // 32 bytes, SHA-256\n tablesSize: number;\n tablesChecksum: Uint8Array; // 32 bytes, SHA-256\n partitions: LpMetadataTableDescriptor;\n extents: LpMetadataTableDescriptor;\n groups: LpMetadataTableDescriptor;\n blockDevices: LpMetadataTableDescriptor;\n flags: number; // v1.2+ only\n}\n\nexport interface LpMetadataPartition {\n name: string; // from char[36]\n attributes: number;\n firstExtentIndex: number;\n numExtents: number;\n groupIndex: number;\n}\n\nexport interface LpMetadataExtent {\n numSectors: bigint;\n targetType: number;\n targetData: bigint;\n targetSource: number;\n}\n\nexport interface LpMetadataPartitionGroup {\n name: string; // from char[36]\n flags: number;\n maximumSize: bigint;\n}\n\nexport interface LpMetadataBlockDevice {\n firstLogicalSector: bigint;\n alignment: number;\n alignmentOffset: number;\n size: bigint;\n partitionName: string; // from char[36], null-trimmed\n flags: number;\n}\n\nexport interface LpMetadata {\n geometry: LpMetadataGeometry;\n header: LpMetadataHeader;\n partitions: LpMetadataPartition[];\n extents: LpMetadataExtent[];\n groups: LpMetadataPartitionGroup[];\n blockDevices: LpMetadataBlockDevice[];\n}\n\nexport interface WipeSuperImage {\n partitionName: string;\n data: ArrayBuffer; // sparse image\n forceSlot: boolean; // true if LP_BLOCK_DEVICE_SLOT_SUFFIXED\n}\n\n// ---------------------------------------------------------------------------\n// Helpers\n// ---------------------------------------------------------------------------\n\nfunction nameFromFixedArray(\n view: DataView,\n offset: number,\n maxLen: number,\n): string {\n const bytes: number[] = [];\n for (let i = 0; i < maxLen; i++) {\n const b = view.getUint8(offset + i);\n if (b === 0) break;\n bytes.push(b);\n }\n return new TextDecoder().decode(new Uint8Array(bytes));\n}\n\nasync function sha256(buffer: ArrayBuffer): Promise<Uint8Array> {\n const digest = await crypto.subtle.digest(\"SHA-256\", buffer);\n return new Uint8Array(digest);\n}\n\nfunction arraysEqual(a: Uint8Array, b: Uint8Array): boolean {\n if (a.length !== b.length) return false;\n for (let i = 0; i < a.length; i++) {\n if (a[i] !== b[i]) return false;\n }\n return true;\n}\n\nfunction concatBuffers(...buffers: ArrayBuffer[]): ArrayBuffer {\n const totalLen = buffers.reduce((acc, b) => acc + b.byteLength, 0);\n const out = new Uint8Array(totalLen);\n let offset = 0;\n for (const buf of buffers) {\n out.set(new Uint8Array(buf), offset);\n offset += buf.byteLength;\n }\n return out.buffer;\n}\n\n// Pad/truncate buffer to exactly `size` bytes (zero-padded at end).\nfunction padBuffer(buf: ArrayBuffer, size: number): ArrayBuffer {\n if (buf.byteLength === size) return buf;\n const out = new Uint8Array(size);\n out.set(new Uint8Array(buf.slice(0, Math.min(buf.byteLength, size))));\n return out.buffer;\n}\n\n// ---------------------------------------------------------------------------\n// Geometry parsing\n// ---------------------------------------------------------------------------\n\nasync function parseGeometry(buffer: ArrayBuffer): Promise<LpMetadataGeometry> {\n if (buffer.byteLength < GEOMETRY_STRUCT_SIZE) {\n throw new LpError(\"Geometry buffer too small\");\n }\n const view = new DataView(buffer);\n\n const magic = view.getUint32(0, true);\n if (magic !== LP_METADATA_GEOMETRY_MAGIC) {\n throw new LpError(`Invalid geometry magic: 0x${magic.toString(16)}`);\n }\n\n const structSize = view.getUint32(4, true);\n if (structSize > LP_METADATA_GEOMETRY_SIZE) {\n throw new LpError(\n `Geometry struct_size ${structSize} exceeds LP_METADATA_GEOMETRY_SIZE`,\n );\n }\n\n const storedChecksum = new Uint8Array(buffer.slice(8, 40));\n\n // Verify checksum: zero the checksum field and hash\n const forHash = new Uint8Array(buffer.slice(0, structSize));\n forHash.fill(0, 8, 40);\n const computed = await sha256(forHash.buffer);\n if (!arraysEqual(computed, storedChecksum)) {\n throw new LpError(\"Geometry checksum mismatch\");\n }\n\n const metadataMaxSize = view.getUint32(40, true);\n const metadataSlotCount = view.getUint32(44, true);\n const logicalBlockSize = view.getUint32(48, true);\n\n if (structSize !== GEOMETRY_STRUCT_SIZE) {\n throw new LpError(\n `Geometry struct_size ${structSize} does not match expected ${GEOMETRY_STRUCT_SIZE}`,\n );\n }\n if (metadataSlotCount === 0) {\n throw new LpError(\"Geometry has invalid slot count (0)\");\n }\n if (metadataMaxSize % LP_SECTOR_SIZE !== 0) {\n throw new LpError(\n `Geometry metadata_max_size ${metadataMaxSize} is not sector-aligned`,\n );\n }\n\n return {\n magic,\n structSize,\n checksum: storedChecksum,\n metadataMaxSize,\n metadataSlotCount,\n logicalBlockSize,\n };\n}\n\n// ---------------------------------------------------------------------------\n// Table descriptor parsing\n// ---------------------------------------------------------------------------\n\nfunction parseTableDescriptor(\n view: DataView,\n offset: number,\n): LpMetadataTableDescriptor {\n return {\n offset: view.getUint32(offset + 0, true),\n numEntries: view.getUint32(offset + 4, true),\n entrySize: view.getUint32(offset + 8, true),\n };\n}\n\nfunction validateTableBounds(\n header: Pick<LpMetadataHeader, \"tablesSize\">,\n table: LpMetadataTableDescriptor,\n): boolean {\n if (table.offset > header.tablesSize) return false;\n const tableSize = table.numEntries * table.entrySize;\n if (tableSize < 0) return false;\n if (header.tablesSize - table.offset < tableSize) return false;\n return true;\n}\n\n// ---------------------------------------------------------------------------\n// Header parsing\n// ---------------------------------------------------------------------------\n\nasync function parseHeader(\n buffer: ArrayBuffer,\n tablesBuffer: ArrayBuffer,\n): Promise<LpMetadataHeader> {\n if (buffer.byteLength < HEADER_V1_0_SIZE) {\n throw new LpError(\"Header buffer too small\");\n }\n const view = new DataView(buffer);\n\n const magic = view.getUint32(0, true);\n if (magic !== LP_METADATA_HEADER_MAGIC) {\n throw new LpError(`Invalid header magic: 0x${magic.toString(16)}`);\n }\n\n const majorVersion = view.getUint16(4, true);\n const minorVersion = view.getUint16(6, true);\n if (majorVersion !== LP_METADATA_MAJOR_VERSION) {\n throw new LpError(\n `Unsupported LP metadata major version: ${majorVersion}`,\n );\n }\n if (minorVersion > LP_METADATA_MINOR_VERSION_MAX) {\n throw new LpError(\n `Unsupported LP metadata minor version: ${minorVersion}`,\n );\n }\n\n const headerSize = view.getUint32(8, true);\n const expectedHeaderSize =\n minorVersion < LP_METADATA_VERSION_FOR_EXPANDED_HEADER\n ? HEADER_V1_0_SIZE\n : HEADER_V1_2_SIZE;\n if (headerSize !== expectedHeaderSize || headerSize > buffer.byteLength) {\n throw new LpError(`Invalid header size: ${headerSize}`);\n }\n\n const storedChecksum = new Uint8Array(buffer.slice(12, 44));\n\n // Verify header checksum\n const forHash = new Uint8Array(buffer.slice(0, headerSize));\n forHash.fill(0, 12, 44);\n const computed = await sha256(forHash.buffer);\n if (!arraysEqual(computed, storedChecksum)) {\n throw new LpError(\"Header checksum mismatch\");\n }\n\n const tablesSize = view.getUint32(44, true);\n const tablesChecksum = new Uint8Array(buffer.slice(48, 80));\n\n // Verify tables checksum\n if (tablesBuffer.byteLength < tablesSize) {\n throw new LpError(\"Tables buffer too small\");\n }\n const tablesComputed = await sha256(tablesBuffer.slice(0, tablesSize));\n if (!arraysEqual(tablesComputed, tablesChecksum)) {\n throw new LpError(\"Tables checksum mismatch\");\n }\n\n // Table descriptors start at offset 80\n const partitions = parseTableDescriptor(view, 80);\n const extents = parseTableDescriptor(view, 92);\n const groups = parseTableDescriptor(view, 104);\n const blockDevices = parseTableDescriptor(view, 116);\n if (\n !validateTableBounds({ tablesSize }, partitions) ||\n !validateTableBounds({ tablesSize }, extents) ||\n !validateTableBounds({ tablesSize }, groups) ||\n !validateTableBounds({ tablesSize }, blockDevices)\n ) {\n throw new LpError(\"Invalid table bounds in metadata header\");\n }\n\n // v1.2+ flags field at offset 128\n const flags =\n headerSize >= HEADER_V1_2_SIZE ? view.getUint32(128, true) : 0;\n\n return {\n magic,\n majorVersion,\n minorVersion,\n headerSize,\n headerChecksum: storedChecksum,\n tablesSize,\n tablesChecksum,\n partitions,\n extents,\n groups,\n blockDevices,\n flags,\n };\n}\n\n// ---------------------------------------------------------------------------\n// Table entry parsers\n// ---------------------------------------------------------------------------\n\nfunction parsePartition(view: DataView, offset: number): LpMetadataPartition {\n return {\n name: nameFromFixedArray(view, offset + 0, 36),\n attributes: view.getUint32(offset + 36, true),\n firstExtentIndex: view.getUint32(offset + 40, true),\n numExtents: view.getUint32(offset + 44, true),\n groupIndex: view.getUint32(offset + 48, true),\n };\n}\n\nfunction parseExtent(view: DataView, offset: number): LpMetadataExtent {\n return {\n numSectors: view.getBigUint64(offset + 0, true),\n targetType: view.getUint32(offset + 8, true),\n targetData: view.getBigUint64(offset + 12, true),\n targetSource: view.getUint32(offset + 20, true),\n };\n}\n\nfunction parseGroup(view: DataView, offset: number): LpMetadataPartitionGroup {\n return {\n name: nameFromFixedArray(view, offset + 0, 36),\n flags: view.getUint32(offset + 36, true),\n maximumSize: view.getBigUint64(offset + 40, true),\n };\n}\n\nfunction parseBlockDevice(\n view: DataView,\n offset: number,\n): LpMetadataBlockDevice {\n return {\n firstLogicalSector: view.getBigUint64(offset + 0, true),\n alignment: view.getUint32(offset + 8, true),\n alignmentOffset: view.getUint32(offset + 12, true),\n size: view.getBigUint64(offset + 16, true),\n partitionName: nameFromFixedArray(view, offset + 24, 36),\n flags: view.getUint32(offset + 60, true),\n };\n}\n\nfunction parseTable<T>(\n tablesView: DataView,\n descriptor: LpMetadataTableDescriptor,\n expectedEntrySize: number,\n parser: (view: DataView, offset: number) => T,\n): T[] {\n if (descriptor.entrySize !== expectedEntrySize) {\n throw new LpError(\n `Table entry size mismatch: expected ${expectedEntrySize}, got ${descriptor.entrySize}`,\n );\n }\n const tableSize = descriptor.numEntries * descriptor.entrySize;\n if (\n descriptor.offset > tablesView.byteLength ||\n tableSize > tablesView.byteLength - descriptor.offset\n ) {\n throw new LpError(\"Table descriptor points outside tables buffer\");\n }\n const results: T[] = [];\n for (let i = 0; i < descriptor.numEntries; i++) {\n const offset = descriptor.offset + i * descriptor.entrySize;\n results.push(parser(tablesView, offset));\n }\n return results;\n}\n\nfunction validateParsedMetadata(\n geometry: LpMetadataGeometry,\n header: LpMetadataHeader,\n partitions: LpMetadataPartition[],\n extents: LpMetadataExtent[],\n groups: LpMetadataPartitionGroup[],\n blockDevices: LpMetadataBlockDevice[],\n) {\n const superDevice = blockDevices[0];\n if (!superDevice) {\n throw new LpError(\"Metadata does not specify a super block device\");\n }\n\n const validAttributes =\n header.minorVersion >= LP_METADATA_VERSION_FOR_UPDATED_ATTR\n ? LP_PARTITION_ATTRIBUTE_MASK_V0 | LP_PARTITION_ATTRIBUTE_MASK_V1\n : LP_PARTITION_ATTRIBUTE_MASK_V0;\n\n for (const partition of partitions) {\n if (partition.attributes & ~validAttributes) {\n throw new LpError(\n `Partition \"${partition.name}\" has invalid attributes`,\n );\n }\n const end = partition.firstExtentIndex + partition.numExtents;\n if (end < partition.firstExtentIndex || end > extents.length) {\n throw new LpError(\n `Partition \"${partition.name}\" has invalid extent list`,\n );\n }\n if (partition.groupIndex >= groups.length) {\n throw new LpError(\n `Partition \"${partition.name}\" has invalid group index`,\n );\n }\n }\n\n for (const extent of extents) {\n if (\n extent.targetType === LP_TARGET_TYPE_LINEAR &&\n extent.targetSource >= blockDevices.length\n ) {\n throw new LpError(\"Linear extent references invalid block device\");\n }\n }\n\n const metadataRegion =\n BigInt(LP_PARTITION_RESERVED_BYTES) +\n BigInt(\n LP_METADATA_GEOMETRY_SIZE +\n geometry.metadataMaxSize * geometry.metadataSlotCount,\n ) *\n 2n;\n if (\n metadataRegion >\n superDevice.firstLogicalSector * BigInt(LP_SECTOR_SIZE)\n ) {\n throw new LpError(\n \"Metadata region overlaps with logical partition contents\",\n );\n }\n}\n\n// ---------------------------------------------------------------------------\n// Public: read LP metadata from a super_empty.img Blob\n// ---------------------------------------------------------------------------\n\n/**\n * Parse LP metadata from a super_empty.img Blob.\n *\n * super_empty.img layout:\n * [0 .. LP_METADATA_GEOMETRY_SIZE) — geometry struct (4096 bytes)\n * [LP_METADATA_GEOMETRY_SIZE ..) — header + tables (metadata slot 0)\n */\nexport async function readFromImageBlob(blob: Blob): Promise<LpMetadata> {\n logDebug(`Parsing LP metadata from ${blob.size}-byte image`);\n\n // super_empty.img written by AOSP WriteToImageFile(fd, metadata) has:\n // offset 0 — geometry (LP_METADATA_GEOMETRY_SIZE bytes, padded)\n // offset LP_METADATA_GEOMETRY_SIZE — header + tables\n // This matches AOSP ReadFromImageBlob / ReadFromImageFile which reads geometry at offset 0.\n const primaryGeometryOffset = 0;\n const geomBuf = await common.readBlobAsBuffer(\n blob.slice(\n primaryGeometryOffset,\n primaryGeometryOffset + LP_METADATA_GEOMETRY_SIZE,\n ),\n );\n const geometry = await parseGeometry(geomBuf);\n logDebug(\n `LP geometry: maxSize=${geometry.metadataMaxSize}, slotCount=${geometry.metadataSlotCount}, blockSize=${geometry.logicalBlockSize}`,\n );\n\n // Metadata immediately follows the single geometry block in super_empty.img\n const headerPeekOffset = LP_METADATA_GEOMETRY_SIZE;\n const headerPeekBuf = await common.readBlobAsBuffer(\n blob.slice(headerPeekOffset, headerPeekOffset + HEADER_V1_0_SIZE),\n );\n const peekView = new DataView(headerPeekBuf);\n const headerSize = peekView.getUint32(8, true);\n const tablesSize = peekView.getUint32(44, true);\n if (tablesSize > geometry.metadataMaxSize) {\n throw new LpError(\"Metadata tables exceed geometry.metadata_max_size\");\n }\n\n // Read full header + tables\n const headerBuf = await common.readBlobAsBuffer(\n blob.slice(headerPeekOffset, headerPeekOffset + headerSize),\n );\n const tablesBuf = await common.readBlobAsBuffer(\n blob.slice(\n headerPeekOffset + headerSize,\n headerPeekOffset + headerSize + tablesSize,\n ),\n );\n\n const header = await parseHeader(headerBuf, tablesBuf);\n logDebug(\n `LP header: v${header.majorVersion}.${header.minorVersion}, headerSize=${header.headerSize}`,\n );\n\n const tablesView = new DataView(tablesBuf);\n const partitions = parseTable(\n tablesView,\n header.partitions,\n PARTITION_STRUCT_SIZE,\n parsePartition,\n );\n const extents = parseTable(\n tablesView,\n header.extents,\n EXTENT_STRUCT_SIZE,\n parseExtent,\n );\n const groups = parseTable(\n tablesView,\n header.groups,\n GROUP_STRUCT_SIZE,\n parseGroup,\n );\n const blockDevices = parseTable(\n tablesView,\n header.blockDevices,\n BLOCK_DEVICE_STRUCT_SIZE,\n parseBlockDevice,\n );\n\n validateParsedMetadata(\n geometry,\n header,\n partitions,\n extents,\n groups,\n blockDevices,\n );\n\n logDebug(\n `LP: ${partitions.length} partitions, ${blockDevices.length} block device(s)`,\n );\n for (const bd of blockDevices) {\n logDebug(\n ` block device \"${bd.partitionName}\": size=${\n bd.size\n }, flags=0x${bd.flags.toString(16)}`,\n );\n }\n\n return { geometry, header, partitions, extents, groups, blockDevices };\n}\n\n// ---------------------------------------------------------------------------\n// Public helpers\n// ---------------------------------------------------------------------------\n\nexport function getMetadataSuperBlockDevice(\n metadata: LpMetadata,\n): LpMetadataBlockDevice | null {\n return metadata.blockDevices[0] ?? null;\n}\n\nexport function getBlockDevicePartitionName(bd: LpMetadataBlockDevice): string {\n return bd.partitionName;\n}\n\n// ---------------------------------------------------------------------------\n// Serialization\n// ---------------------------------------------------------------------------\n\nexport async function serializeGeometry(\n geometry: LpMetadataGeometry,\n): Promise<ArrayBuffer> {\n const buf = new ArrayBuffer(GEOMETRY_STRUCT_SIZE);\n const view = new DataView(buf);\n\n view.setUint32(0, geometry.magic, true);\n view.setUint32(4, geometry.structSize, true);\n // checksum at [8..40] — zeroed for hashing\n view.setUint32(40, geometry.metadataMaxSize, true);\n view.setUint32(44, geometry.metadataSlotCount, true);\n view.setUint32(48, geometry.logicalBlockSize, true);\n\n // Compute checksum over the struct with checksum field zeroed\n const checksum = await sha256(buf);\n const out = new Uint8Array(buf);\n out.set(checksum, 8);\n\n // Pad to LP_METADATA_GEOMETRY_SIZE\n return padBuffer(buf, LP_METADATA_GEOMETRY_SIZE);\n}\n\nfunction serializeTableDescriptor(\n view: DataView,\n offset: number,\n desc: LpMetadataTableDescriptor,\n) {\n view.setUint32(offset + 0, desc.offset, true);\n view.setUint32(offset + 4, desc.numEntries, true);\n view.setUint32(offset + 8, desc.entrySize, true);\n}\n\nfunction serializeNameToFixedArray(\n view: DataView,\n offset: number,\n name: string,\n maxLen: number,\n) {\n const encoded = new TextEncoder().encode(name);\n for (let i = 0; i < maxLen; i++) {\n view.setUint8(offset + i, i < encoded.length ? encoded[i] : 0);\n }\n}\n\nfunction serializePartition(partition: LpMetadataPartition): ArrayBuffer {\n const buf = new ArrayBuffer(PARTITION_STRUCT_SIZE);\n const view = new DataView(buf);\n serializeNameToFixedArray(view, 0, partition.name, 36);\n view.setUint32(36, partition.attributes, true);\n view.setUint32(40, partition.firstExtentIndex, true);\n view.setUint32(44, partition.numExtents, true);\n view.setUint32(48, partition.groupIndex, true);\n return buf;\n}\n\nfunction serializeExtent(extent: LpMetadataExtent): ArrayBuffer {\n const buf = new ArrayBuffer(EXTENT_STRUCT_SIZE);\n const view = new DataView(buf);\n view.setBigUint64(0, extent.numSectors, true);\n view.setUint32(8, extent.targetType, true);\n view.setBigUint64(12, extent.targetData, true);\n view.setUint32(20, extent.targetSource, true);\n return buf;\n}\n\nfunction serializeGroup(group: LpMetadataPartitionGroup): ArrayBuffer {\n const buf = new ArrayBuffer(GROUP_STRUCT_SIZE);\n const view = new DataView(buf);\n serializeNameToFixedArray(view, 0, group.name, 36);\n view.setUint32(36, group.flags, true);\n view.setBigUint64(40, group.maximumSize, true);\n return buf;\n}\n\nfunction serializeBlockDevice(bd: LpMetadataBlockDevice): ArrayBuffer {\n const buf = new ArrayBuffer(BLOCK_DEVICE_STRUCT_SIZE);\n const view = new DataView(buf);\n view.setBigUint64(0, bd.firstLogicalSector, true);\n view.setUint32(8, bd.alignment, true);\n view.setUint32(12, bd.alignmentOffset, true);\n view.setBigUint64(16, bd.size, true);\n serializeNameToFixedArray(view, 24, bd.partitionName, 36);\n view.setUint32(60, bd.flags, true);\n return buf;\n}\n\nexport async function serializeMetadata(\n metadata: LpMetadata,\n): Promise<ArrayBuffer> {\n const { header } = metadata;\n\n // Serialize each table\n const partitionBufs = metadata.partitions.map(serializePartition);\n const extentBufs = metadata.extents.map(serializeExtent);\n const groupBufs = metadata.groups.map(serializeGroup);\n const blockDevBufs = metadata.blockDevices.map(serializeBlockDevice);\n\n const tablesParts = [\n ...partitionBufs,\n ...extentBufs,\n ...groupBufs,\n ...blockDevBufs,\n ];\n const tablesBuffer = concatBuffers(...tablesParts);\n\n // Compute table descriptor offsets\n const partitionsOffset = 0;\n const extentsOffset = partitionBufs.reduce((s, b) => s + b.byteLength, 0);\n const groupsOffset =\n extentsOffset + extentBufs.reduce((s, b) => s + b.byteLength, 0);\n const blockDevicesOffset =\n groupsOffset + groupBufs.reduce((s, b) => s + b.byteLength, 0);\n\n const tablesChecksum = await sha256(tablesBuffer);\n const tablesSize = tablesBuffer.byteLength;\n\n // Enforce header size that matches metadata minor version.\n const headerSize =\n header.minorVersion < LP_METADATA_VERSION_FOR_EXPANDED_HEADER\n ? HEADER_V1_0_SIZE\n : HEADER_V1_2_SIZE;\n\n const headerBuf = new ArrayBuffer(headerSize);\n const hv = new DataView(headerBuf);\n\n hv.setUint32(0, LP_METADATA_HEADER_MAGIC, true);\n hv.setUint16(4, header.majorVersion, true);\n hv.setUint16(6, header.minorVersion, true);\n hv.setUint32(8, headerSize, true);\n // [12..44]: headerChecksum — zeroed initially for hashing\n hv.setUint32(44, tablesSize, true);\n new Uint8Array(headerBuf).set(tablesChecksum, 48); // tablesChecksum at [48..80]\n\n // Table descriptors\n const hDescView = new DataView(headerBuf);\n serializeTableDescriptor(hDescView, 80, {\n offset: partitionsOffset,\n numEntries: metadata.partitions.length,\n entrySize: PARTITION_STRUCT_SIZE,\n });\n serializeTableDescriptor(hDescView, 92, {\n offset: extentsOffset,\n numEntries: metadata.extents.length,\n entrySize: EXTENT_STRUCT_SIZE,\n });\n serializeTableDescriptor(hDescView, 104, {\n offset: groupsOffset,\n numEntries: metadata.groups.length,\n entrySize: GROUP_STRUCT_SIZE,\n });\n serializeTableDescriptor(hDescView, 116, {\n offset: blockDevicesOffset,\n numEntries: metadata.blockDevices.length,\n entrySize: BLOCK_DEVICE_STRUCT_SIZE,\n });\n\n if (headerSize >= HEADER_V1_2_SIZE) {\n hv.setUint32(128, header.flags, true);\n }\n\n // Compute header checksum\n const headerChecksum = await sha256(headerBuf);\n new Uint8Array(headerBuf).set(headerChecksum, 12);\n\n return concatBuffers(headerBuf, tablesBuffer);\n}\n\n// ---------------------------------------------------------------------------\n// Public: build wipe-super sparse images (one per block device)\n// ---------------------------------------------------------------------------\n\n/**\n * Generate sparse images suitable for flashing to wipe the super partition.\n *\n * The first block device image contains the LP metadata region (reserved zeros +\n * geometry copies + metadata slots) followed by a skip chunk for the remaining\n * device space. Secondary block devices (retrofit) get a skip-only image.\n */\nexport async function buildWipeSuperImages(\n metadata: LpMetadata,\n): Promise<WipeSuperImage[]> {\n const { geometry } = metadata;\n const blockSize = geometry.logicalBlockSize;\n\n // Validate alignment requirements (matching AOSP ImageBuilder constructor checks)\n if (blockSize % LP_SECTOR_SIZE !== 0) {\n throw new LpError(\n `Block size ${blockSize} must be a multiple of sector size ${LP_SECTOR_SIZE}`,\n );\n }\n if (LP_METADATA_GEOMETRY_SIZE % blockSize !== 0) {\n throw new LpError(\n `Geometry size ${LP_METADATA_GEOMETRY_SIZE} is not a multiple of block size ${blockSize}`,\n );\n }\n if (LP_PARTITION_RESERVED_BYTES % blockSize !== 0) {\n throw new LpError(\n `Reserved size ${LP_PARTITION_RESERVED_BYTES} is not a multiple of block size ${blockSize}`,\n );\n }\n if (geometry.metadataMaxSize % blockSize !== 0) {\n throw new LpError(\n `Metadata max size ${geometry.metadataMaxSize} must be a multiple of block size ${blockSize}`,\n );\n }\n\n // Serialize geometry and metadata once — shared across all metadata slot copies\n const [geomBuf, rawMetaBuf] = await Promise.all([\n serializeGeometry(geometry),\n serializeMetadata(metadata),\n ]);\n\n // Pad metadata blob to metadataMaxSize\n const metaBuf = padBuffer(rawMetaBuf, geometry.metadataMaxSize);\n\n // allMetadata = geometry x2 + (primary slots x slotCount) + (backup slots x slotCount)\n const slotCount = geometry.metadataSlotCount;\n const allMetaParts: ArrayBuffer[] = [\n geomBuf,\n geomBuf,\n ...Array(slotCount).fill(metaBuf),\n ...Array(slotCount).fill(metaBuf),\n ];\n const allMetadata = concatBuffers(...allMetaParts);\n const metadataBlocks = allMetadata.byteLength / blockSize;\n const reservedBlocks = LP_PARTITION_RESERVED_BYTES / blockSize;\n\n const results: WipeSuperImage[] = [];\n\n for (let i = 0; i < metadata.blockDevices.length; i++) {\n const bd = metadata.blockDevices[i];\n const partitionName = getBlockDevicePartitionName(bd);\n const forceSlot = !!(bd.flags & LP_BLOCK_DEVICE_SLOT_SUFFIXED);\n\n // Validate device size alignment and sparse block-count range\n if (bd.size % BigInt(blockSize) !== 0n) {\n throw new LpError(\n `Device \"${partitionName}\" size ${bd.size} is not a multiple of block size ${blockSize}`,\n );\n }\n const deviceBlocks = Number(bd.size) / blockSize;\n if (deviceBlocks >= 0xffffffff) {\n throw new LpError(\n `Device \"${partitionName}\" is too large to encode with sparse format`,\n );\n }\n\n let sparseBlob: Blob;\n\n if (i === 0) {\n // Primary super device: write reserved zeros + metadata region + skip rest\n const skipBlocks = deviceBlocks - reservedBlocks - metadataBlocks;\n if (skipBlocks < 0) {\n throw new LpError(\n `Device \"${partitionName}\" is too small to hold LP metadata`,\n );\n }\n\n const sparseHeader: Sparse.SparseHeader = {\n blockSize,\n blocks: deviceBlocks,\n chunks: 3,\n crc32: 0,\n };\n const chunks: Sparse.SparseChunk[] = [\n {\n type: Sparse.ChunkType.Fill,\n blocks: reservedBlocks,\n dataBytes: 4,\n data: new Blob([new Uint32Array([0]).buffer]),\n },\n {\n type: Sparse.ChunkType.Raw,\n blocks: metadataBlocks,\n dataBytes: allMetadata.byteLength,\n data: new Blob([allMetadata]),\n },\n {\n type: Sparse.ChunkType.Skip,\n blocks: skipBlocks,\n dataBytes: 0,\n data: new Blob([]),\n },\n ];\n sparseBlob = await Sparse.createImage(sparseHeader, chunks);\n } else {\n // Secondary retrofit device: skip-only image (no metadata stored here)\n const sparseHeader: Sparse.SparseHeader = {\n blockSize,\n blocks: deviceBlocks,\n chunks: 1,\n crc32: 0,\n };\n const chunks: Sparse.SparseChunk[] = [\n {\n type: Sparse.ChunkType.Skip,\n blocks: deviceBlocks,\n dataBytes: 0,\n data: new Blob([]),\n },\n ];\n sparseBlob = await Sparse.createImage(sparseHeader, chunks);\n }\n\n const data = await common.readBlobAsBuffer(sparseBlob);\n logDebug(\n `Generated ${data.byteLength}-byte sparse image for \"${partitionName}\"`,\n );\n\n results.push({ partitionName, data, forceSlot });\n }\n\n return results;\n}\n","/*\n Copyright (c) 2022 Gildas Lormeau. All rights reserved.\n\n Redistribution and use in source and binary forms, with or without\n modification, are permitted provided that the following conditions are met:\n\n 1. Redistributions of source code must retain the above copyright notice,\n this list of conditions and the following disclaimer.\n\n 2. Redistributions in binary form must reproduce the above copyright \n notice, this list of conditions and the following disclaimer in \n the documentation and/or other materials provided with the distribution.\n\n 3. The names of the authors may not be used to endorse or promote products\n derived from this software without specific prior written permission.\n\n THIS SOFTWARE IS PROVIDED ''AS IS'' AND ANY EXPRESSED OR IMPLIED WARRANTIES,\n INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND\n FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL JCRAFT,\n INC. OR ANY CONTRIBUTORS TO THIS SOFTWARE BE LIABLE FOR ANY DIRECT, INDIRECT,\n INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT\n LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA,\n OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF\n LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING\n NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE,\n EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.\n */\n\nconst MAX_32_BITS = 0xffffffff;\nconst MAX_16_BITS = 0xffff;\nconst MAX_8_BITS = 0xff;\nconst COMPRESSION_METHOD_DEFLATE = 0x08;\nconst COMPRESSION_METHOD_DEFLATE_64 = 0x09;\nconst COMPRESSION_METHOD_STORE = 0x00;\nconst COMPRESSION_METHOD_AES = 0x63;\n\nconst LOCAL_FILE_HEADER_SIGNATURE = 0x04034b50;\nconst SPLIT_ZIP_FILE_SIGNATURE = 0x08074b50;\nconst DATA_DESCRIPTOR_RECORD_SIGNATURE = SPLIT_ZIP_FILE_SIGNATURE;\nconst CENTRAL_FILE_HEADER_SIGNATURE = 0x02014b50;\nconst END_OF_CENTRAL_DIR_SIGNATURE = 0x06054b50;\nconst ZIP64_END_OF_CENTRAL_DIR_SIGNATURE = 0x06064b50;\nconst ZIP64_END_OF_CENTRAL_DIR_LOCATOR_SIGNATURE = 0x07064b50;\nconst END_OF_CENTRAL_DIR_LENGTH = 22;\nconst ZIP64_END_OF_CENTRAL_DIR_LOCATOR_LENGTH = 20;\nconst ZIP64_END_OF_CENTRAL_DIR_LENGTH = 56;\nconst ZIP64_END_OF_CENTRAL_DIR_TOTAL_LENGTH = END_OF_CENTRAL_DIR_LENGTH + ZIP64_END_OF_CENTRAL_DIR_LOCATOR_LENGTH + ZIP64_END_OF_CENTRAL_DIR_LENGTH;\n\nconst DATA_DESCRIPTOR_RECORD_LENGTH = 12;\nconst DATA_DESCRIPTOR_RECORD_ZIP_64_LENGTH = 20;\nconst DATA_DESCRIPTOR_RECORD_SIGNATURE_LENGTH = 4;\n\nconst EXTRAFIELD_TYPE_ZIP64 = 0x0001;\nconst EXTRAFIELD_TYPE_AES = 0x9901;\nconst EXTRAFIELD_TYPE_NTFS = 0x000a;\nconst EXTRAFIELD_TYPE_NTFS_TAG1 = 0x0001;\nconst EXTRAFIELD_TYPE_EXTENDED_TIMESTAMP = 0x5455;\nconst EXTRAFIELD_TYPE_UNICODE_PATH = 0x7075;\nconst EXTRAFIELD_TYPE_UNICODE_COMMENT = 0x6375;\nconst EXTRAFIELD_TYPE_USDZ = 0x1986;\nconst EXTRAFIELD_TYPE_INFOZIP = 0x7875;\nconst EXTRAFIELD_TYPE_UNIX = 0x7855;\n\nconst BITFLAG_ENCRYPTED = 0b1;\nconst BITFLAG_LEVEL = 0b0110;\nconst BITFLAG_LEVEL_MAX_MASK = 0b010;\nconst BITFLAG_LEVEL_FAST_MASK = 0b100;\nconst BITFLAG_LEVEL_SUPER_FAST_MASK = 0b110;\nconst BITFLAG_DATA_DESCRIPTOR = 0b1000;\nconst BITFLAG_LANG_ENCODING_FLAG = 0b100000000000;\nconst FILE_ATTR_MSDOS_DIR_MASK = 0b10000;\nconst FILE_ATTR_MSDOS_READONLY_MASK = 0x01;\nconst FILE_ATTR_MSDOS_HIDDEN_MASK = 0x02;\nconst FILE_ATTR_MSDOS_SYSTEM_MASK = 0x04;\nconst FILE_ATTR_MSDOS_ARCHIVE_MASK = 0x20;\nconst FILE_ATTR_UNIX_TYPE_MASK = 0o170000;\nconst FILE_ATTR_UNIX_TYPE_DIR = 0o040000;\nconst FILE_ATTR_UNIX_EXECUTABLE_MASK = 0o111;\nconst FILE_ATTR_UNIX_DEFAULT_MASK = 0o644;\nconst FILE_ATTR_UNIX_SETUID_MASK = 0o4000;\nconst FILE_ATTR_UNIX_SETGID_MASK = 0o2000;\nconst FILE_ATTR_UNIX_STICKY_MASK = 0o1000;\n\nconst VERSION_DEFLATE = 0x14;\nconst VERSION_ZIP64 = 0x2D;\nconst VERSION_AES = 0x33;\n\nconst DIRECTORY_SIGNATURE = \"/\";\n\nconst HEADER_SIZE = 30;\nconst HEADER_OFFSET_SIGNATURE = 10;\nconst HEADER_OFFSET_COMPRESSED_SIZE = 14;\nconst HEADER_OFFSET_UNCOMPRESSED_SIZE = 18;\n\nconst MAX_DATE = new Date(2107, 11, 31);\nconst MIN_DATE = new Date(1980, 0, 1);\n\nconst UNDEFINED_VALUE = undefined;\nconst INFINITY_VALUE = Infinity;\nconst UNDEFINED_TYPE = \"undefined\";\nconst FUNCTION_TYPE = \"function\";\nconst OBJECT_TYPE = \"object\";\n\nexport {\n\tMAX_32_BITS,\n\tMAX_16_BITS,\n\tMAX_8_BITS,\n\tCOMPRESSION_METHOD_DEFLATE,\n\tCOMPRESSION_METHOD_DEFLATE_64,\n\tCOMPRESSION_METHOD_STORE,\n\tCOMPRESSION_METHOD_AES,\n\tSPLIT_ZIP_FILE_SIGNATURE,\n\tLOCAL_FILE_HEADER_SIGNATURE,\n\tDATA_DESCRIPTOR_RECORD_SIGNATURE,\n\tCENTRAL_FILE_HEADER_SIGNATURE,\n\tEND_OF_CENTRAL_DIR_SIGNATURE,\n\tZIP64_END_OF_CENTRAL_DIR_LOCATOR_SIGNATURE,\n\tZIP64_END_OF_CENTRAL_DIR_SIGNATURE,\n\tDATA_DESCRIPTOR_RECORD_LENGTH,\n\tDATA_DESCRIPTOR_RECORD_ZIP_64_LENGTH,\n\tDATA_DESCRIPTOR_RECORD_SIGNATURE_LENGTH,\n\tEXTRAFIELD_TYPE_ZIP64,\n\tEXTRAFIELD_TYPE_AES,\n\tEXTRAFIELD_TYPE_NTFS,\n\tEXTRAFIELD_TYPE_NTFS_TAG1,\n\tEXTRAFIELD_TYPE_EXTENDED_TIMESTAMP,\n\tEXTRAFIELD_TYPE_UNICODE_PATH,\n\tEXTRAFIELD_TYPE_UNICODE_COMMENT,\n\tEXTRAFIELD_TYPE_USDZ,\n\tEXTRAFIELD_TYPE_INFOZIP,\n\tEXTRAFIELD_TYPE_UNIX,\n\tEND_OF_CENTRAL_DIR_LENGTH,\n\tZIP64_END_OF_CENTRAL_DIR_LOCATOR_LENGTH,\n\tZIP64_END_OF_CENTRAL_DIR_LENGTH,\n\tZIP64_END_OF_CENTRAL_DIR_TOTAL_LENGTH,\n\tBITFLAG_ENCRYPTED,\n\tBITFLAG_LEVEL,\n\tBITFLAG_LEVEL_MAX_MASK,\n\tBITFLAG_LEVEL_FAST_MASK,\n\tBITFLAG_LEVEL_SUPER_FAST_MASK,\n\tBITFLAG_DATA_DESCRIPTOR,\n\tBITFLAG_LANG_ENCODING_FLAG,\n\tFILE_ATTR_MSDOS_DIR_MASK,\n\tFILE_ATTR_MSDOS_READONLY_MASK,\n\tFILE_ATTR_MSDOS_HIDDEN_MASK,\n\tFILE_ATTR_MSDOS_SYSTEM_MASK,\n\tFILE_ATTR_MSDOS_ARCHIVE_MASK,\n\tFILE_ATTR_UNIX_TYPE_MASK,\n\tFILE_ATTR_UNIX_TYPE_DIR,\n\tFILE_ATTR_UNIX_EXECUTABLE_MASK,\n\tFILE_ATTR_UNIX_DEFAULT_MASK,\n\tFILE_ATTR_UNIX_SETUID_MASK,\n\tFILE_ATTR_UNIX_SETGID_MASK,\n\tFILE_ATTR_UNIX_STICKY_MASK,\n\tVERSION_DEFLATE,\n\tVERSION_ZIP64,\n\tVERSION_AES,\n\tHEADER_SIZE,\n\tHEADER_OFFSET_SIGNATURE,\n\tHEADER_OFFSET_COMPRESSED_SIZE,\n\tHEADER_OFFSET_UNCOMPRESSED_SIZE,\n\tDIRECTORY_SIGNATURE,\n\tMIN_DATE,\n\tMAX_DATE,\n\tUNDEFINED_VALUE,\n\tINFINITY_VALUE,\n\tUNDEFINED_TYPE,\n\tFUNCTION_TYPE,\n\tOBJECT_TYPE\n};","/*\n Copyright (c) 2025 Gildas Lormeau. All rights reserved.\n\n Redistribution and use in source and binary forms, with or without\n modification, are permitted provided that the following conditions are met:\n\n 1. Redistributions of source code must retain the above copyright notice,\n this list of conditions and the following disclaimer.\n\n 2. Redistributions in binary form must reproduce the above copyright \n notice, this list of conditions and the following disclaimer in \n the documentation and/or other materials provided with the distribution.\n\n 3. The names of the authors may not be used to endorse or promote products\n derived from this software without specific prior written permission.\n\n THIS SOFTWARE IS PROVIDED ''AS IS'' AND ANY EXPRESSED OR IMPLIED WARRANTIES,\n INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND\n FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL JCRAFT,\n INC. OR ANY CONTRIBUTORS TO THIS SOFTWARE BE LIABLE FOR ANY DIRECT, INDIRECT,\n INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT\n LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA,\n OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF\n LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING\n NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE,\n EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.\n */\n\n/* global navigator, CompressionStream, DecompressionStream */\n\nimport {\n\tUNDEFINED_VALUE,\n\tUNDEFINED_TYPE\n} from \"./constants.js\";\n\nconst MINIMUM_CHUNK_SIZE = 64;\nlet maxWorkers = 2;\ntry {\n\tif (typeof navigator != UNDEFINED_TYPE && navigator.hardwareConcurrency) {\n\t\tmaxWorkers = navigator.hardwareConcurrency;\n\t}\n} catch {\n\t// ignored\n}\nconst DEFAULT_CONFIGURATION = {\n\tworkerURI: \"./core/web-worker-wasm.js\",\n\twasmURI: \"./core/streams/zlib-wasm/zlib-streams.wasm\",\n\tchunkSize: 64 * 1024,\n\tmaxWorkers,\n\tterminateWorkerTimeout: 5000,\n\tuseWebWorkers: true,\n\tuseCompressionStream: true,\n\tCompressionStream: typeof CompressionStream != UNDEFINED_TYPE && CompressionStream,\n\tDecompressionStream: typeof DecompressionStream != UNDEFINED_TYPE && DecompressionStream\n};\n\nconst config = Object.assign({}, DEFAULT_CONFIGURATION);\n\nexport {\n\tconfigure,\n\tgetConfiguration,\n\tgetChunkSize\n};\n\nfunction getConfiguration() {\n\treturn config;\n}\n\nfunction getChunkSize(config) {\n\treturn Math.max(config.chunkSize, MINIMUM_CHUNK_SIZE);\n}\n\nfunction configure(configuration) {\n\tconst {\n\t\tbaseURI,\n\t\tchunkSize,\n\t\tmaxWorkers,\n\t\tterminateWorkerTimeout,\n\t\tuseCompressionStream,\n\t\tuseWebWorkers,\n\t\tCompressionStream,\n\t\tDecompressionStream,\n\t\tCompressionStreamZlib,\n\t\tDecompressionStreamZlib,\n\t\tworkerURI,\n\t\twasmURI\n\t} = configuration;\n\tsetIfDefined(\"baseURI\", baseURI);\n\tsetIfDefined(\"wasmURI\", wasmURI);\n\tsetIfDefined(\"workerURI\", workerURI);\n\tsetIfDefined(\"chunkSize\", chunkSize);\n\tsetIfDefined(\"maxWorkers\", maxWorkers);\n\tsetIfDefined(\"terminateWorkerTimeout\", terminateWorkerTimeout);\n\tsetIfDefined(\"useCompressionStream\", useCompressionStream);\n\tsetIfDefined(\"useWebWorkers\", useWebWorkers);\n\tsetIfDefined(\"CompressionStream\", CompressionStream);\n\tsetIfDefined(\"DecompressionStream\", DecompressionStream);\n\tsetIfDefined(\"CompressionStreamZlib\", CompressionStreamZlib);\n\tsetIfDefined(\"DecompressionStreamZlib\", DecompressionStreamZlib);\n}\n\nfunction setIfDefined(propertyName, propertyValue) {\n\tif (propertyValue !== UNDEFINED_VALUE) {\n\t\tconfig[propertyName] = propertyValue;\n\t}\n}\n","/*\n Copyright (c) 2022 Gildas Lormeau. All rights reserved.\n\n Redistribution and use in source and binary forms, with or without\n modification, are permitted provided that the following conditions are met:\n\n 1. Redistributions of source code must retain the above copyright notice,\n this list of conditions and the following disclaimer.\n\n 2. Redistributions in binary form must reproduce the above copyright \n notice, this list of conditions and the following disclaimer in \n the documentation and/or other materials provided with the distribution.\n\n 3. The names of the authors may not be used to endorse or promote products\n derived from this software without specific prior written permission.\n\n THIS SOFTWARE IS PROVIDED ''AS IS'' AND ANY EXPRESSED OR IMPLIED WARRANTIES,\n INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND\n FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL JCRAFT,\n INC. OR ANY CONTRIBUTORS TO THIS SOFTWARE BE LIABLE FOR ANY DIRECT, INDIRECT,\n INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT\n LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA,\n OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF\n LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING\n NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE,\n EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.\n */\n\nconst table = [];\nfor (let i = 0; i < 256; i++) {\n\tlet t = i;\n\tfor (let j = 0; j < 8; j++) {\n\t\tif (t & 1) {\n\t\t\tt = (t >>> 1) ^ 0xEDB88320;\n\t\t} else {\n\t\t\tt = t >>> 1;\n\t\t}\n\t}\n\ttable[i] = t;\n}\n\nclass Crc32 {\n\n\tconstructor(crc) {\n\t\tthis.crc = crc || -1;\n\t}\n\n\tappend(data) {\n\t\tlet crc = this.crc | 0;\n\t\tfor (let offset = 0, length = data.length | 0; offset < length; offset++) {\n\t\t\tcrc = (crc >>> 8) ^ table[(crc ^ data[offset]) & 0xFF];\n\t\t}\n\t\tthis.crc = crc;\n\t}\n\n\tget() {\n\t\treturn ~this.crc;\n\t}\n}\n\nexport {\n\tCrc32\n};","/*\n Copyright (c) 2022 Gildas Lormeau. All rights reserved.\n\n Redistribution and use in source and binary forms, with or without\n modification, are permitted provided that the following conditions are met:\n\n 1. Redistributions of source code must retain the above copyright notice,\n this list of conditions and the following disclaimer.\n\n 2. Redistributions in binary form must reproduce the above copyright \n notice, this list of conditions and the following disclaimer in \n the documentation and/or other materials provided with the distribution.\n\n 3. The names of the authors may not be used to endorse or promote products\n derived from this software without specific prior written permission.\n\n THIS SOFTWARE IS PROVIDED ''AS IS'' AND ANY EXPRESSED OR IMPLIED WARRANTIES,\n INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND\n FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL JCRAFT,\n INC. OR ANY CONTRIBUTORS TO THIS SOFTWARE BE LIABLE FOR ANY DIRECT, INDIRECT,\n INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT\n LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA,\n OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF\n LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING\n NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE,\n EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.\n */\n\n/* global TransformStream */\n\nimport { Crc32 } from \"./codecs/crc32.js\";\n\nclass Crc32Stream extends TransformStream {\n\n\tconstructor() {\n\t\t// deno-lint-ignore prefer-const\n\t\tlet stream;\n\t\tconst crc32 = new Crc32();\n\t\tsuper({\n\t\t\ttransform(chunk, controller) {\n\t\t\t\tcrc32.append(chunk);\n\t\t\t\tcontroller.enqueue(chunk);\n\t\t\t},\n\t\t\tflush() {\n\t\t\t\tconst value = new Uint8Array(4);\n\t\t\t\tconst dataView = new DataView(value.buffer);\n\t\t\t\tdataView.setUint32(0, crc32.get());\n\t\t\t\tstream.value = value;\n\t\t\t}\n\t\t});\n\t\tstream = this;\n\t}\n}\n\nexport {\n\tCrc32Stream\n};","// Derived from https://github.com/xqdoo00o/jszip/blob/master/lib/sjcl.js and https://github.com/bitwiseshiftleft/sjcl\n\n// deno-lint-ignore-file no-this-alias\n\n/*\n * SJCL is open. You can use, modify and redistribute it under a BSD\n * license or under the GNU GPL, version 2.0.\n */\n\n/** @fileOverview Javascript cryptography implementation.\n *\n * Crush to remove comments, shorten variable names and\n * generally reduce transmission size.\n *\n * @author Emily Stark\n * @author Mike Hamburg\n * @author Dan Boneh\n */\n\n/*jslint indent: 2, bitwise: false, nomen: false, plusplus: false, white: false, regexp: false */\n\n/** @fileOverview Arrays of bits, encoded as arrays of Numbers.\n *\n * @author Emily Stark\n * @author Mike Hamburg\n * @author Dan Boneh\n */\n\n/**\n * Arrays of bits, encoded as arrays of Numbers.\n * @namespace\n * @description\n * <p>\n * These objects are the currency accepted by SJCL's crypto functions.\n * </p>\n *\n * <p>\n * Most of our crypto primitives operate on arrays of 4-byte words internally,\n * but many of them can take arguments that are not a multiple of 4 bytes.\n * This library encodes arrays of bits (whose size need not be a multiple of 8\n * bits) as arrays of 32-bit words. The bits are packed, big-endian, into an\n * array of words, 32 bits at a time. Since the words are double-precision\n * floating point numbers, they fit some extra data. We use this (in a private,\n * possibly-changing manner) to encode the number of bits actually present\n * in the last word of the array.\n * </p>\n *\n * <p>\n * Because bitwise ops clear this out-of-band data, these arrays can be passed\n * to ciphers like AES which want arrays of words.\n * </p>\n */\nconst bitArray = {\n\t/**\n\t * Concatenate two bit arrays.\n\t * @param {bitArray} a1 The first array.\n\t * @param {bitArray} a2 The second array.\n\t * @return {bitArray} The concatenation of a1 and a2.\n\t */\n\tconcat(a1, a2) {\n\t\tif (a1.length === 0 || a2.length === 0) {\n\t\t\treturn a1.concat(a2);\n\t\t}\n\n\t\tconst last = a1[a1.length - 1], shift = bitArray.getPartial(last);\n\t\tif (shift === 32) {\n\t\t\treturn a1.concat(a2);\n\t\t} else {\n\t\t\treturn bitArray._shiftRight(a2, shift, last | 0, a1.slice(0, a1.length - 1));\n\t\t}\n\t},\n\n\t/**\n\t * Find the length of an array of bits.\n\t * @param {bitArray} a The array.\n\t * @return {Number} The length of a, in bits.\n\t */\n\tbitLength(a) {\n\t\tconst l = a.length;\n\t\tif (l === 0) {\n\t\t\treturn 0;\n\t\t}\n\t\tconst x = a[l - 1];\n\t\treturn (l - 1) * 32 + bitArray.getPartial(x);\n\t},\n\n\t/**\n\t * Truncate an array.\n\t * @param {bitArray} a The array.\n\t * @param {Number} len The length to truncate to, in bits.\n\t * @return {bitArray} A new array, truncated to len bits.\n\t */\n\tclamp(a, len) {\n\t\tif (a.length * 32 < len) {\n\t\t\treturn a;\n\t\t}\n\t\ta = a.slice(0, Math.ceil(len / 32));\n\t\tconst l = a.length;\n\t\tlen = len & 31;\n\t\tif (l > 0 && len) {\n\t\t\ta[l - 1] = bitArray.partial(len, a[l - 1] & 0x80000000 >> (len - 1), 1);\n\t\t}\n\t\treturn a;\n\t},\n\n\t/**\n\t * Make a partial word for a bit array.\n\t * @param {Number} len The number of bits in the word.\n\t * @param {Number} x The bits.\n\t * @param {Number} [_end=0] Pass 1 if x has already been shifted to the high side.\n\t * @return {Number} The partial word.\n\t */\n\tpartial(len, x, _end) {\n\t\tif (len === 32) {\n\t\t\treturn x;\n\t\t}\n\t\treturn (_end ? x | 0 : x << (32 - len)) + len * 0x10000000000;\n\t},\n\n\t/**\n\t * Get the number of bits used by a partial word.\n\t * @param {Number} x The partial word.\n\t * @return {Number} The number of bits used by the partial word.\n\t */\n\tgetPartial(x) {\n\t\treturn Math.round(x / 0x10000000000) || 32;\n\t},\n\n\t/** Shift an array right.\n\t * @param {bitArray} a The array to shift.\n\t * @param {Number} shift The number of bits to shift.\n\t * @param {Number} [carry=0] A byte to carry in\n\t * @param {bitArray} [out=[]] An array to prepend to the output.\n\t * @private\n\t */\n\t_shiftRight(a, shift, carry, out) {\n\t\tif (out === undefined) {\n\t\t\tout = [];\n\t\t}\n\n\t\tfor (; shift >= 32; shift -= 32) {\n\t\t\tout.push(carry);\n\t\t\tcarry = 0;\n\t\t}\n\t\tif (shift === 0) {\n\t\t\treturn out.concat(a);\n\t\t}\n\n\t\tfor (let i = 0; i < a.length; i++) {\n\t\t\tout.push(carry | a[i] >>> shift);\n\t\t\tcarry = a[i] << (32 - shift);\n\t\t}\n\t\tconst last2 = a.length ? a[a.length - 1] : 0;\n\t\tconst shift2 = bitArray.getPartial(last2);\n\t\tout.push(bitArray.partial(shift + shift2 & 31, (shift + shift2 > 32) ? carry : out.pop(), 1));\n\t\treturn out;\n\t}\n};\n\n/** @fileOverview Bit array codec implementations.\n *\n * @author Emily Stark\n * @author Mike Hamburg\n * @author Dan Boneh\n */\n\n/**\n * Arrays of bytes\n * @namespace\n */\nconst codec = {\n\tbytes: {\n\t\t/** Convert from a bitArray to an array of bytes. */\n\t\tfromBits(arr) {\n\t\t\tconst bl = bitArray.bitLength(arr);\n\t\t\tconst byteLength = bl / 8;\n\t\t\tconst out = new Uint8Array(byteLength);\n\t\t\tlet tmp;\n\t\t\tfor (let i = 0; i < byteLength; i++) {\n\t\t\t\tif ((i & 3) === 0) {\n\t\t\t\t\ttmp = arr[i / 4];\n\t\t\t\t}\n\t\t\t\tout[i] = tmp >>> 24;\n\t\t\t\ttmp <<= 8;\n\t\t\t}\n\t\t\treturn out;\n\t\t},\n\t\t/** Convert from an array of bytes to a bitArray. */\n\t\ttoBits(bytes) {\n\t\t\tconst out = [];\n\t\t\tlet i;\n\t\t\tlet tmp = 0;\n\t\t\tfor (i = 0; i < bytes.length; i++) {\n\t\t\t\ttmp = tmp << 8 | bytes[i];\n\t\t\t\tif ((i & 3) === 3) {\n\t\t\t\t\tout.push(tmp);\n\t\t\t\t\ttmp = 0;\n\t\t\t\t}\n\t\t\t}\n\t\t\tif (i & 3) {\n\t\t\t\tout.push(bitArray.partial(8 * (i & 3), tmp));\n\t\t\t}\n\t\t\treturn out;\n\t\t}\n\t}\n};\n\nconst hash = {};\n\n/**\n * Context for a SHA-1 operation in progress.\n * @constructor\n */\nhash.sha1 = class {\n\tconstructor(hash) {\n\t\tconst sha1 = this;\n\t\t/**\n\t\t * The hash's block size, in bits.\n\t\t * @constant\n\t\t */\n\t\tsha1.blockSize = 512;\n\t\t/**\n\t\t * The SHA-1 initialization vector.\n\t\t * @private\n\t\t */\n\t\tsha1._init = [0x67452301, 0xEFCDAB89, 0x98BADCFE, 0x10325476, 0xC3D2E1F0];\n\t\t/**\n\t\t * The SHA-1 hash key.\n\t\t * @private\n\t\t */\n\t\tsha1._key = [0x5A827999, 0x6ED9EBA1, 0x8F1BBCDC, 0xCA62C1D6];\n\t\tif (hash) {\n\t\t\tsha1._h = hash._h.slice(0);\n\t\t\tsha1._buffer = hash._buffer.slice(0);\n\t\t\tsha1._length = hash._length;\n\t\t} else {\n\t\t\tsha1.reset();\n\t\t}\n\t}\n\n\t/**\n\t * Reset the hash state.\n\t * @return this\n\t */\n\treset() {\n\t\tconst sha1 = this;\n\t\tsha1._h = sha1._init.slice(0);\n\t\tsha1._buffer = [];\n\t\tsha1._length = 0;\n\t\treturn sha1;\n\t}\n\n\t/**\n\t * Input several words to the hash.\n\t * @param {bitArray|String} data the data to hash.\n\t * @return this\n\t */\n\tupdate(data) {\n\t\tconst sha1 = this;\n\t\tif (typeof data === \"string\") {\n\t\t\tdata = codec.utf8String.toBits(data);\n\t\t}\n\t\tconst b = sha1._buffer = bitArray.concat(sha1._buffer, data);\n\t\tconst ol = sha1._length;\n\t\tconst nl = sha1._length = ol + bitArray.bitLength(data);\n\t\tif (nl > 9007199254740991) {\n\t\t\tthrow new Error(\"Cannot hash more than 2^53 - 1 bits\");\n\t\t}\n\t\tconst c = new Uint32Array(b);\n\t\tlet j = 0;\n\t\tfor (let i = sha1.blockSize + ol - ((sha1.blockSize + ol) & (sha1.blockSize - 1)); i <= nl;\n\t\t\ti += sha1.blockSize) {\n\t\t\tsha1._block(c.subarray(16 * j, 16 * (j + 1)));\n\t\t\tj += 1;\n\t\t}\n\t\tb.splice(0, 16 * j);\n\t\treturn sha1;\n\t}\n\n\t/**\n\t * Complete hashing and output the hash value.\n\t * @return {bitArray} The hash value, an array of 5 big-endian words. TODO\n\t */\n\tfinalize() {\n\t\tconst sha1 = this;\n\t\tlet b = sha1._buffer;\n\t\tconst h = sha1._h;\n\n\t\t// Round out and push the buffer\n\t\tb = bitArray.concat(b, [bitArray.partial(1, 1)]);\n\t\t// Round out the buffer to a multiple of 16 words, less the 2 length words.\n\t\tfor (let i = b.length + 2; i & 15; i++) {\n\t\t\tb.push(0);\n\t\t}\n\n\t\t// append the length\n\t\tb.push(Math.floor(sha1._length / 0x100000000));\n\t\tb.push(sha1._length | 0);\n\n\t\twhile (b.length) {\n\t\t\tsha1._block(b.splice(0, 16));\n\t\t}\n\n\t\tsha1.reset();\n\t\treturn h;\n\t}\n\n\t/**\n\t * The SHA-1 logical functions f(0), f(1), ..., f(79).\n\t * @private\n\t */\n\t_f(t, b, c, d) {\n\t\tif (t <= 19) {\n\t\t\treturn (b & c) | (~b & d);\n\t\t} else if (t <= 39) {\n\t\t\treturn b ^ c ^ d;\n\t\t} else if (t <= 59) {\n\t\t\treturn (b & c) | (b & d) | (c & d);\n\t\t} else if (t <= 79) {\n\t\t\treturn b ^ c ^ d;\n\t\t}\n\t}\n\n\t/**\n\t * Circular left-shift operator.\n\t * @private\n\t */\n\t_S(n, x) {\n\t\treturn (x << n) | (x >>> 32 - n);\n\t}\n\n\t/**\n\t * Perform one cycle of SHA-1.\n\t * @param {Uint32Array|bitArray} words one block of words.\n\t * @private\n\t */\n\t_block(words) {\n\t\tconst sha1 = this;\n\t\tconst h = sha1._h;\n\t\t// When words is passed to _block, it has 16 elements. SHA1 _block\n\t\t// function extends words with new elements (at the end there are 80 elements). \n\t\t// The problem is that if we use Uint32Array instead of Array, \n\t\t// the length of Uint32Array cannot be changed. Thus, we replace words with a \n\t\t// normal Array here.\n\t\tconst w = Array(80); // do not use Uint32Array here as the instantiation is slower\n\t\tfor (let j = 0; j < 16; j++) {\n\t\t\tw[j] = words[j];\n\t\t}\n\n\t\tlet a = h[0];\n\t\tlet b = h[1];\n\t\tlet c = h[2];\n\t\tlet d = h[3];\n\t\tlet e = h[4];\n\n\t\tfor (let t = 0; t <= 79; t++) {\n\t\t\tif (t >= 16) {\n\t\t\t\tw[t] = sha1._S(1, w[t - 3] ^ w[t - 8] ^ w[t - 14] ^ w[t - 16]);\n\t\t\t}\n\t\t\tconst tmp = (sha1._S(5, a) + sha1._f(t, b, c, d) + e + w[t] +\n\t\t\t\tsha1._key[Math.floor(t / 20)]) | 0;\n\t\t\te = d;\n\t\t\td = c;\n\t\t\tc = sha1._S(30, b);\n\t\t\tb = a;\n\t\t\ta = tmp;\n\t\t}\n\n\t\th[0] = (h[0] + a) | 0;\n\t\th[1] = (h[1] + b) | 0;\n\t\th[2] = (h[2] + c) | 0;\n\t\th[3] = (h[3] + d) | 0;\n\t\th[4] = (h[4] + e) | 0;\n\t}\n};\n\n/** @fileOverview Low-level AES implementation.\n *\n * This file contains a low-level implementation of AES, optimized for\n * size and for efficiency on several browsers. It is based on\n * OpenSSL's aes_core.c, a public-domain implementation by Vincent\n * Rijmen, Antoon Bosselaers and Paulo Barreto.\n *\n * An older version of this implementation is available in the public\n * domain, but this one is (c) Emily Stark, Mike Hamburg, Dan Boneh,\n * Stanford University 2008-2010 and BSD-licensed for liability\n * reasons.\n *\n * @author Emily Stark\n * @author Mike Hamburg\n * @author Dan Boneh\n */\n\nconst cipher = {};\n\n/**\n * Schedule out an AES key for both encryption and decryption. This\n * is a low-level class. Use a cipher mode to do bulk encryption.\n *\n * @constructor\n * @param {Array} key The key as an array of 4, 6 or 8 words.\n */\ncipher.aes = class {\n\tconstructor(key) {\n\t\t/**\n\t\t * The expanded S-box and inverse S-box tables. These will be computed\n\t\t * on the client so that we don't have to send them down the wire.\n\t\t *\n\t\t * There are two tables, _tables[0] is for encryption and\n\t\t * _tables[1] is for decryption.\n\t\t *\n\t\t * The first 4 sub-tables are the expanded S-box with MixColumns. The\n\t\t * last (_tables[01][4]) is the S-box itself.\n\t\t *\n\t\t * @private\n\t\t */\n\t\tconst aes = this;\n\t\taes._tables = [[[], [], [], [], []], [[], [], [], [], []]];\n\n\t\tif (!aes._tables[0][0][0]) {\n\t\t\taes._precompute();\n\t\t}\n\n\t\tconst sbox = aes._tables[0][4];\n\t\tconst decTable = aes._tables[1];\n\t\tconst keyLen = key.length;\n\n\t\tlet i, encKey, decKey, rcon = 1;\n\n\t\tif (keyLen !== 4 && keyLen !== 6 && keyLen !== 8) {\n\t\t\tthrow new Error(\"invalid aes key size\");\n\t\t}\n\n\t\taes._key = [encKey = key.slice(0), decKey = []];\n\n\t\t// schedule encryption keys\n\t\tfor (i = keyLen; i < 4 * keyLen + 28; i++) {\n\t\t\tlet tmp = encKey[i - 1];\n\n\t\t\t// apply sbox\n\t\t\tif (i % keyLen === 0 || (keyLen === 8 && i % keyLen === 4)) {\n\t\t\t\ttmp = sbox[tmp >>> 24] << 24 ^ sbox[tmp >> 16 & 255] << 16 ^ sbox[tmp >> 8 & 255] << 8 ^ sbox[tmp & 255];\n\n\t\t\t\t// shift rows and add rcon\n\t\t\t\tif (i % keyLen === 0) {\n\t\t\t\t\ttmp = tmp << 8 ^ tmp >>> 24 ^ rcon << 24;\n\t\t\t\t\trcon = rcon << 1 ^ (rcon >> 7) * 283;\n\t\t\t\t}\n\t\t\t}\n\n\t\t\tencKey[i] = encKey[i - keyLen] ^ tmp;\n\t\t}\n\n\t\t// schedule decryption keys\n\t\tfor (let j = 0; i; j++, i--) {\n\t\t\tconst tmp = encKey[j & 3 ? i : i - 4];\n\t\t\tif (i <= 4 || j < 4) {\n\t\t\t\tdecKey[j] = tmp;\n\t\t\t} else {\n\t\t\t\tdecKey[j] = decTable[0][sbox[tmp >>> 24]] ^\n\t\t\t\t\tdecTable[1][sbox[tmp >> 16 & 255]] ^\n\t\t\t\t\tdecTable[2][sbox[tmp >> 8 & 255]] ^\n\t\t\t\t\tdecTable[3][sbox[tmp & 255]];\n\t\t\t}\n\t\t}\n\t}\n\t// public\n\t/* Something like this might appear here eventually\n\tname: \"AES\",\n\tblockSize: 4,\n\tkeySizes: [4,6,8],\n\t*/\n\n\t/**\n\t * Encrypt an array of 4 big-endian words.\n\t * @param {Array} data The plaintext.\n\t * @return {Array} The ciphertext.\n\t */\n\tencrypt(data) {\n\t\treturn this._crypt(data, 0);\n\t}\n\n\t/**\n\t * Decrypt an array of 4 big-endian words.\n\t * @param {Array} data The ciphertext.\n\t * @return {Array} The plaintext.\n\t */\n\tdecrypt(data) {\n\t\treturn this._crypt(data, 1);\n\t}\n\n\t/**\n\t * Expand the S-box tables.\n\t *\n\t * @private\n\t */\n\t_precompute() {\n\t\tconst encTable = this._tables[0];\n\t\tconst decTable = this._tables[1];\n\t\tconst sbox = encTable[4];\n\t\tconst sboxInv = decTable[4];\n\t\tconst d = [];\n\t\tconst th = [];\n\t\tlet xInv, x2, x4, x8;\n\n\t\t// Compute double and third tables\n\t\tfor (let i = 0; i < 256; i++) {\n\t\t\tth[(d[i] = i << 1 ^ (i >> 7) * 283) ^ i] = i;\n\t\t}\n\n\t\tfor (let x = xInv = 0; !sbox[x]; x ^= x2 || 1, xInv = th[xInv] || 1) {\n\t\t\t// Compute sbox\n\t\t\tlet s = xInv ^ xInv << 1 ^ xInv << 2 ^ xInv << 3 ^ xInv << 4;\n\t\t\ts = s >> 8 ^ s & 255 ^ 99;\n\t\t\tsbox[x] = s;\n\t\t\tsboxInv[s] = x;\n\n\t\t\t// Compute MixColumns\n\t\t\tx8 = d[x4 = d[x2 = d[x]]];\n\t\t\tlet tDec = x8 * 0x1010101 ^ x4 * 0x10001 ^ x2 * 0x101 ^ x * 0x1010100;\n\t\t\tlet tEnc = d[s] * 0x101 ^ s * 0x1010100;\n\n\t\t\tfor (let i = 0; i < 4; i++) {\n\t\t\t\tencTable[i][x] = tEnc = tEnc << 24 ^ tEnc >>> 8;\n\t\t\t\tdecTable[i][s] = tDec = tDec << 24 ^ tDec >>> 8;\n\t\t\t}\n\t\t}\n\n\t\t// Compactify. Considerable speedup on Firefox.\n\t\tfor (let i = 0; i < 5; i++) {\n\t\t\tencTable[i] = encTable[i].slice(0);\n\t\t\tdecTable[i] = decTable[i].slice(0);\n\t\t}\n\t}\n\n\t/**\n\t * Encryption and decryption core.\n\t * @param {Array} input Four words to be encrypted or decrypted.\n\t * @param dir The direction, 0 for encrypt and 1 for decrypt.\n\t * @return {Array} The four encrypted or decrypted words.\n\t * @private\n\t */\n\t_crypt(input, dir) {\n\t\tif (input.length !== 4) {\n\t\t\tthrow new Error(\"invalid aes block size\");\n\t\t}\n\n\t\tconst key = this._key[dir];\n\n\t\tconst nInnerRounds = key.length / 4 - 2;\n\t\tconst out = [0, 0, 0, 0];\n\t\tconst table = this._tables[dir];\n\n\t\t// load up the tables\n\t\tconst t0 = table[0];\n\t\tconst t1 = table[1];\n\t\tconst t2 = table[2];\n\t\tconst t3 = table[3];\n\t\tconst sbox = table[4];\n\n\t\t// state variables a,b,c,d are loaded with pre-whitened data\n\t\tlet a = input[0] ^ key[0];\n\t\tlet b = input[dir ? 3 : 1] ^ key[1];\n\t\tlet c = input[2] ^ key[2];\n\t\tlet d = input[dir ? 1 : 3] ^ key[3];\n\t\tlet kIndex = 4;\n\t\tlet a2, b2, c2;\n\n\t\t// Inner rounds. Cribbed from OpenSSL.\n\t\tfor (let i = 0; i < nInnerRounds; i++) {\n\t\t\ta2 = t0[a >>> 24] ^ t1[b >> 16 & 255] ^ t2[c >> 8 & 255] ^ t3[d & 255] ^ key[kIndex];\n\t\t\tb2 = t0[b >>> 24] ^ t1[c >> 16 & 255] ^ t2[d >> 8 & 255] ^ t3[a & 255] ^ key[kIndex + 1];\n\t\t\tc2 = t0[c >>> 24] ^ t1[d >> 16 & 255] ^ t2[a >> 8 & 255] ^ t3[b & 255] ^ key[kIndex + 2];\n\t\t\td = t0[d >>> 24] ^ t1[a >> 16 & 255] ^ t2[b >> 8 & 255] ^ t3[c & 255] ^ key[kIndex + 3];\n\t\t\tkIndex += 4;\n\t\t\ta = a2; b = b2; c = c2;\n\t\t}\n\n\t\t// Last round.\n\t\tfor (let i = 0; i < 4; i++) {\n\t\t\tout[dir ? 3 & -i : i] =\n\t\t\t\tsbox[a >>> 24] << 24 ^\n\t\t\t\tsbox[b >> 16 & 255] << 16 ^\n\t\t\t\tsbox[c >> 8 & 255] << 8 ^\n\t\t\t\tsbox[d & 255] ^\n\t\t\t\tkey[kIndex++];\n\t\t\ta2 = a; a = b; b = c; c = d; d = a2;\n\t\t}\n\n\t\treturn out;\n\t}\n};\n\n/**\n * Random values\n * @namespace\n */\nconst random = {\n\t/** \n\t * Generate random words with pure js, cryptographically not as strong & safe as native implementation.\n\t * @param {TypedArray} typedArray The array to fill.\n\t * @return {TypedArray} The random values.\n\t */\n\tgetRandomValues(typedArray) {\n\t\tconst words = new Uint32Array(typedArray.buffer);\n\t\tconst r = (m_w) => {\n\t\t\tlet m_z = 0x3ade68b1;\n\t\t\tconst mask = 0xffffffff;\n\t\t\treturn function () {\n\t\t\t\tm_z = (0x9069 * (m_z & 0xFFFF) + (m_z >> 0x10)) & mask;\n\t\t\t\tm_w = (0x4650 * (m_w & 0xFFFF) + (m_w >> 0x10)) & mask;\n\t\t\t\tconst result = ((((m_z << 0x10) + m_w) & mask) / 0x100000000) + .5;\n\t\t\t\treturn result * (Math.random() > .5 ? 1 : -1);\n\t\t\t};\n\t\t};\n\t\tfor (let i = 0, rcache; i < typedArray.length; i += 4) {\n\t\t\tconst _r = r((rcache || Math.random()) * 0x100000000);\n\t\t\trcache = _r() * 0x3ade67b7;\n\t\t\twords[i / 4] = (_r() * 0x100000000) | 0;\n\t\t}\n\t\treturn typedArray;\n\t}\n};\n\n/** @fileOverview CTR mode implementation.\n *\n * Special thanks to Roy Nicholson for pointing out a bug in our\n * implementation.\n *\n * @author Emily Stark\n * @author Mike Hamburg\n * @author Dan Boneh\n */\n\n/** Brian Gladman's CTR Mode.\n* @constructor\n* @param {Object} _prf The aes instance to generate key.\n* @param {bitArray} _iv The iv for ctr mode, it must be 128 bits.\n*/\n\nconst mode = {};\n\n/**\n * Brian Gladman's CTR Mode.\n * @namespace\n */\nmode.ctrGladman = class {\n\tconstructor(prf, iv) {\n\t\tthis._prf = prf;\n\t\tthis._initIv = iv;\n\t\tthis._iv = iv;\n\t}\n\n\treset() {\n\t\tthis._iv = this._initIv;\n\t}\n\n\t/** Input some data to calculate.\n\t * @param {bitArray} data the data to process, it must be intergral multiple of 128 bits unless it's the last.\n\t */\n\tupdate(data) {\n\t\treturn this.calculate(this._prf, data, this._iv);\n\t}\n\n\tincWord(word) {\n\t\tif (((word >> 24) & 0xff) === 0xff) { //overflow\n\t\t\tlet b1 = (word >> 16) & 0xff;\n\t\t\tlet b2 = (word >> 8) & 0xff;\n\t\t\tlet b3 = word & 0xff;\n\n\t\t\tif (b1 === 0xff) { // overflow b1 \n\t\t\t\tb1 = 0;\n\t\t\t\tif (b2 === 0xff) {\n\t\t\t\t\tb2 = 0;\n\t\t\t\t\tif (b3 === 0xff) {\n\t\t\t\t\t\tb3 = 0;\n\t\t\t\t\t} else {\n\t\t\t\t\t\t++b3;\n\t\t\t\t\t}\n\t\t\t\t} else {\n\t\t\t\t\t++b2;\n\t\t\t\t}\n\t\t\t} else {\n\t\t\t\t++b1;\n\t\t\t}\n\n\t\t\tword = 0;\n\t\t\tword += (b1 << 16);\n\t\t\tword += (b2 << 8);\n\t\t\tword += b3;\n\t\t} else {\n\t\t\tword += (0x01 << 24);\n\t\t}\n\t\treturn word;\n\t}\n\n\tincCounter(counter) {\n\t\tif ((counter[0] = this.incWord(counter[0])) === 0) {\n\t\t\t// encr_data in fileenc.c from Dr Brian Gladman's counts only with DWORD j < 8\n\t\t\tcounter[1] = this.incWord(counter[1]);\n\t\t}\n\t}\n\n\tcalculate(prf, data, iv) {\n\t\tlet l;\n\t\tif (!(l = data.length)) {\n\t\t\treturn [];\n\t\t}\n\t\tconst bl = bitArray.bitLength(data);\n\t\tfor (let i = 0; i < l; i += 4) {\n\t\t\tthis.incCounter(iv);\n\t\t\tconst e = prf.encrypt(iv);\n\t\t\tdata[i] ^= e[0];\n\t\t\tdata[i + 1] ^= e[1];\n\t\t\tdata[i + 2] ^= e[2];\n\t\t\tdata[i + 3] ^= e[3];\n\t\t}\n\t\treturn bitArray.clamp(data, bl);\n\t}\n};\n\nconst misc = {\n\timportKey(password) {\n\t\treturn new misc.hmacSha1(codec.bytes.toBits(password));\n\t},\n\tpbkdf2(prf, salt, count, length) {\n\t\tcount = count || 10000;\n\t\tif (length < 0 || count < 0) {\n\t\t\tthrow new Error(\"invalid params to pbkdf2\");\n\t\t}\n\t\tconst byteLength = ((length >> 5) + 1) << 2;\n\t\tlet u, ui, i, j, k;\n\t\tconst arrayBuffer = new ArrayBuffer(byteLength);\n\t\tconst out = new DataView(arrayBuffer);\n\t\tlet outLength = 0;\n\t\tconst b = bitArray;\n\t\tsalt = codec.bytes.toBits(salt);\n\t\tfor (k = 1; outLength < (byteLength || 1); k++) {\n\t\t\tu = ui = prf.encrypt(b.concat(salt, [k]));\n\t\t\tfor (i = 1; i < count; i++) {\n\t\t\t\tui = prf.encrypt(ui);\n\t\t\t\tfor (j = 0; j < ui.length; j++) {\n\t\t\t\t\tu[j] ^= ui[j];\n\t\t\t\t}\n\t\t\t}\n\t\t\tfor (i = 0; outLength < (byteLength || 1) && i < u.length; i++) {\n\t\t\t\tout.setInt32(outLength, u[i]);\n\t\t\t\toutLength += 4;\n\t\t\t}\n\t\t}\n\t\treturn arrayBuffer.slice(0, length / 8);\n\t}\n};\n\n/** @fileOverview HMAC implementation.\n *\n * @author Emily Stark\n * @author Mike Hamburg\n * @author Dan Boneh\n */\n\n/** HMAC with the specified hash function.\n * @constructor\n * @param {bitArray} key the key for HMAC.\n * @param {Object} [Hash=hash.sha1] The hash function to use.\n */\nmisc.hmacSha1 = class {\n\n\tconstructor(key) {\n\t\tconst hmac = this;\n\t\tconst Hash = hmac._hash = hash.sha1;\n\t\tconst exKey = [[], []];\n\t\thmac._baseHash = [new Hash(), new Hash()];\n\t\tconst bs = hmac._baseHash[0].blockSize / 32;\n\n\t\tif (key.length > bs) {\n\t\t\tkey = new Hash().update(key).finalize();\n\t\t}\n\n\t\tfor (let i = 0; i < bs; i++) {\n\t\t\texKey[0][i] = key[i] ^ 0x36363636;\n\t\t\texKey[1][i] = key[i] ^ 0x5C5C5C5C;\n\t\t}\n\n\t\thmac._baseHash[0].update(exKey[0]);\n\t\thmac._baseHash[1].update(exKey[1]);\n\t\thmac._resultHash = new Hash(hmac._baseHash[0]);\n\t}\n\treset() {\n\t\tconst hmac = this;\n\t\thmac._resultHash = new hmac._hash(hmac._baseHash[0]);\n\t\thmac._updated = false;\n\t}\n\n\tupdate(data) {\n\t\tconst hmac = this;\n\t\thmac._updated = true;\n\t\thmac._resultHash.update(data);\n\t}\n\n\tdigest() {\n\t\tconst hmac = this;\n\t\tconst w = hmac._resultHash.finalize();\n\t\tconst result = new (hmac._hash)(hmac._baseHash[1]).update(w).finalize();\n\n\t\thmac.reset();\n\n\t\treturn result;\n\t}\n\n\tencrypt(data) {\n\t\tif (!this._updated) {\n\t\t\tthis.update(data);\n\t\t\treturn this.digest(data);\n\t\t} else {\n\t\t\tthrow new Error(\"encrypt on already updated hmac called!\");\n\t\t}\n\t}\n};\n\nexport {\n\tcipher,\n\tcodec,\n\tmisc,\n\tmode,\n\trandom\n};","/*\n Copyright (c) 2022 Gildas Lormeau. All rights reserved.\n\n Redistribution and use in source and binary forms, with or without\n modification, are permitted provided that the following conditions are met:\n\n 1. Redistributions of source code must retain the above copyright notice,\n this list of conditions and the following disclaimer.\n\n 2. Redistributions in binary form must reproduce the above copyright \n notice, this list of conditions and the following disclaimer in \n the documentation and/or other materials provided with the distribution.\n\n 3. The names of the authors may not be used to endorse or promote products\n derived from this software without specific prior written permission.\n\n THIS SOFTWARE IS PROVIDED ''AS IS'' AND ANY EXPRESSED OR IMPLIED WARRANTIES,\n INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND\n FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL JCRAFT,\n INC. OR ANY CONTRIBUTORS TO THIS SOFTWARE BE LIABLE FOR ANY DIRECT, INDIRECT,\n INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT\n LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA,\n OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF\n LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING\n NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE,\n EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.\n */\n\n/* global crypto */\n\nimport { FUNCTION_TYPE, UNDEFINED_TYPE } from \"../constants.js\";\nimport {\n\trandom\n} from \"./codecs/sjcl.js\";\n\nconst GET_RANDOM_VALUES_SUPPORTED = typeof crypto != UNDEFINED_TYPE && typeof crypto.getRandomValues == FUNCTION_TYPE;\n\nconst ERR_INVALID_PASSWORD = \"Invalid password\";\nconst ERR_INVALID_SIGNATURE = \"Invalid signature\";\nconst ERR_ABORT_CHECK_PASSWORD = \"zipjs-abort-check-password\";\n\nexport {\n\tgetRandomValues,\n\tERR_INVALID_PASSWORD,\n\tERR_INVALID_SIGNATURE,\n\tERR_ABORT_CHECK_PASSWORD\n};\n\nfunction getRandomValues(array) {\n\tif (GET_RANDOM_VALUES_SUPPORTED) {\n\t\treturn crypto.getRandomValues(array);\n\t} else {\n\t\treturn random.getRandomValues(array);\n\t}\n}","/*\n Copyright (c) 2022 Gildas Lormeau. All rights reserved.\n\n Redistribution and use in source and binary forms, with or without\n modification, are permitted provided that the following conditions are met:\n\n 1. Redistributions of source code must retain the above copyright notice,\n this list of conditions and the following disclaimer.\n\n 2. Redistributions in binary form must reproduce the above copyright \n notice, this list of conditions and the following disclaimer in \n the documentation and/or other materials provided with the distribution.\n\n 3. The names of the authors may not be used to endorse or promote products\n derived from this software without specific prior written permission.\n\n THIS SOFTWARE IS PROVIDED ''AS IS'' AND ANY EXPRESSED OR IMPLIED WARRANTIES,\n INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND\n FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL JCRAFT,\n INC. OR ANY CONTRIBUTORS TO THIS SOFTWARE BE LIABLE FOR ANY DIRECT, INDIRECT,\n INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT\n LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA,\n OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF\n LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING\n NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE,\n EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.\n */\n\n/* global crypto, TransformStream */\n// deno-lint-ignore-file no-this-alias\n\nimport { UNDEFINED_VALUE, UNDEFINED_TYPE, FUNCTION_TYPE } from \"../constants.js\";\nimport { encodeText } from \"./../util/encode-text.js\";\nimport {\n\tcipher,\n\tcodec,\n\tmisc,\n\tmode\n} from \"./codecs/sjcl.js\";\nimport {\n\tERR_INVALID_PASSWORD,\n\tERR_INVALID_SIGNATURE,\n\tERR_ABORT_CHECK_PASSWORD,\n\tgetRandomValues\n} from \"./common-crypto.js\";\n\nconst BLOCK_LENGTH = 16;\nconst RAW_FORMAT = \"raw\";\nconst PBKDF2_ALGORITHM = { name: \"PBKDF2\" };\nconst HASH_ALGORITHM = { name: \"HMAC\" };\nconst HASH_FUNCTION = \"SHA-1\";\nconst BASE_KEY_ALGORITHM = Object.assign({ hash: HASH_ALGORITHM }, PBKDF2_ALGORITHM);\nconst DERIVED_BITS_ALGORITHM = Object.assign({ iterations: 1000, hash: { name: HASH_FUNCTION } }, PBKDF2_ALGORITHM);\nconst DERIVED_BITS_USAGE = [\"deriveBits\"];\nconst SALT_LENGTH = [8, 12, 16];\nconst KEY_LENGTH = [16, 24, 32];\nconst SIGNATURE_LENGTH = 10;\nconst COUNTER_DEFAULT_VALUE = [0, 0, 0, 0];\n// deno-lint-ignore valid-typeof\nconst CRYPTO_API_SUPPORTED = typeof crypto != UNDEFINED_TYPE;\nconst subtle = CRYPTO_API_SUPPORTED && crypto.subtle;\nconst SUBTLE_API_SUPPORTED = CRYPTO_API_SUPPORTED && typeof subtle != UNDEFINED_TYPE;\nconst codecBytes = codec.bytes;\nconst Aes = cipher.aes;\nconst CtrGladman = mode.ctrGladman;\nconst HmacSha1 = misc.hmacSha1;\n\nlet IMPORT_KEY_SUPPORTED = CRYPTO_API_SUPPORTED && SUBTLE_API_SUPPORTED && typeof subtle.importKey == FUNCTION_TYPE;\nlet DERIVE_BITS_SUPPORTED = CRYPTO_API_SUPPORTED && SUBTLE_API_SUPPORTED && typeof subtle.deriveBits == FUNCTION_TYPE;\n\nclass AESDecryptionStream extends TransformStream {\n\n\tconstructor({ password, rawPassword, signed, encryptionStrength, checkPasswordOnly }) {\n\t\tsuper({\n\t\t\tstart() {\n\t\t\t\tObject.assign(this, {\n\t\t\t\t\tready: new Promise(resolve => this.resolveReady = resolve),\n\t\t\t\t\tpassword: encodePassword(password, rawPassword),\n\t\t\t\t\tsigned,\n\t\t\t\t\tstrength: encryptionStrength - 1,\n\t\t\t\t\tpending: new Uint8Array()\n\t\t\t\t});\n\t\t\t},\n\t\t\tasync transform(chunk, controller) {\n\t\t\t\tconst aesCrypto = this;\n\t\t\t\tconst {\n\t\t\t\t\tpassword,\n\t\t\t\t\tstrength,\n\t\t\t\t\tresolveReady,\n\t\t\t\t\tready\n\t\t\t\t} = aesCrypto;\n\t\t\t\tif (password) {\n\t\t\t\t\tawait createDecryptionKeys(aesCrypto, strength, password, subarray(chunk, 0, SALT_LENGTH[strength] + 2));\n\t\t\t\t\tchunk = subarray(chunk, SALT_LENGTH[strength] + 2);\n\t\t\t\t\tif (checkPasswordOnly) {\n\t\t\t\t\t\tcontroller.error(new Error(ERR_ABORT_CHECK_PASSWORD));\n\t\t\t\t\t} else {\n\t\t\t\t\t\tresolveReady();\n\t\t\t\t\t}\n\t\t\t\t} else {\n\t\t\t\t\tawait ready;\n\t\t\t\t}\n\t\t\t\tconst output = new Uint8Array(chunk.length - SIGNATURE_LENGTH - ((chunk.length - SIGNATURE_LENGTH) % BLOCK_LENGTH));\n\t\t\t\tcontroller.enqueue(append(aesCrypto, chunk, output, 0, SIGNATURE_LENGTH, true));\n\t\t\t},\n\t\t\tasync flush(controller) {\n\t\t\t\tconst {\n\t\t\t\t\tsigned,\n\t\t\t\t\tctr,\n\t\t\t\t\thmac,\n\t\t\t\t\tpending,\n\t\t\t\t\tready\n\t\t\t\t} = this;\n\t\t\t\tif (hmac && ctr) {\n\t\t\t\t\tawait ready;\n\t\t\t\t\tconst chunkToDecrypt = subarray(pending, 0, pending.length - SIGNATURE_LENGTH);\n\t\t\t\t\tconst originalSignature = subarray(pending, pending.length - SIGNATURE_LENGTH);\n\t\t\t\t\tlet decryptedChunkArray = new Uint8Array();\n\t\t\t\t\tif (chunkToDecrypt.length) {\n\t\t\t\t\t\tconst encryptedChunk = toBits(codecBytes, chunkToDecrypt);\n\t\t\t\t\t\thmac.update(encryptedChunk);\n\t\t\t\t\t\tconst decryptedChunk = ctr.update(encryptedChunk);\n\t\t\t\t\t\tdecryptedChunkArray = fromBits(codecBytes, decryptedChunk);\n\t\t\t\t\t}\n\t\t\t\t\tif (signed) {\n\t\t\t\t\t\tconst signature = subarray(fromBits(codecBytes, hmac.digest()), 0, SIGNATURE_LENGTH);\n\t\t\t\t\t\tfor (let indexSignature = 0; indexSignature < SIGNATURE_LENGTH; indexSignature++) {\n\t\t\t\t\t\t\tif (signature[indexSignature] != originalSignature[indexSignature]) {\n\t\t\t\t\t\t\t\tthrow new Error(ERR_INVALID_SIGNATURE);\n\t\t\t\t\t\t\t}\n\t\t\t\t\t\t}\n\t\t\t\t\t}\n\t\t\t\t\tcontroller.enqueue(decryptedChunkArray);\n\t\t\t\t}\n\t\t\t}\n\t\t});\n\t}\n}\n\nclass AESEncryptionStream extends TransformStream {\n\n\tconstructor({ password, rawPassword, encryptionStrength }) {\n\t\t// deno-lint-ignore prefer-const\n\t\tlet stream;\n\t\tsuper({\n\t\t\tstart() {\n\t\t\t\tObject.assign(this, {\n\t\t\t\t\tready: new Promise(resolve => this.resolveReady = resolve),\n\t\t\t\t\tpassword: encodePassword(password, rawPassword),\n\t\t\t\t\tstrength: encryptionStrength - 1,\n\t\t\t\t\tpending: new Uint8Array()\n\t\t\t\t});\n\t\t\t},\n\t\t\tasync transform(chunk, controller) {\n\t\t\t\tconst aesCrypto = this;\n\t\t\t\tconst {\n\t\t\t\t\tpassword,\n\t\t\t\t\tstrength,\n\t\t\t\t\tresolveReady,\n\t\t\t\t\tready\n\t\t\t\t} = aesCrypto;\n\t\t\t\tlet preamble = new Uint8Array();\n\t\t\t\tif (password) {\n\t\t\t\t\tpreamble = await createEncryptionKeys(aesCrypto, strength, password);\n\t\t\t\t\tresolveReady();\n\t\t\t\t} else {\n\t\t\t\t\tawait ready;\n\t\t\t\t}\n\t\t\t\tconst output = new Uint8Array(preamble.length + chunk.length - (chunk.length % BLOCK_LENGTH));\n\t\t\t\toutput.set(preamble, 0);\n\t\t\t\tcontroller.enqueue(append(aesCrypto, chunk, output, preamble.length, 0));\n\t\t\t},\n\t\t\tasync flush(controller) {\n\t\t\t\tconst {\n\t\t\t\t\tctr,\n\t\t\t\t\thmac,\n\t\t\t\t\tpending,\n\t\t\t\t\tready\n\t\t\t\t} = this;\n\t\t\t\tif (hmac && ctr) {\n\t\t\t\t\tawait ready;\n\t\t\t\t\tlet encryptedChunkArray = new Uint8Array();\n\t\t\t\t\tif (pending.length) {\n\t\t\t\t\t\tconst encryptedChunk = ctr.update(toBits(codecBytes, pending));\n\t\t\t\t\t\thmac.update(encryptedChunk);\n\t\t\t\t\t\tencryptedChunkArray = fromBits(codecBytes, encryptedChunk);\n\t\t\t\t\t}\n\t\t\t\t\tstream.signature = fromBits(codecBytes, hmac.digest()).slice(0, SIGNATURE_LENGTH);\n\t\t\t\t\tcontroller.enqueue(concat(encryptedChunkArray, stream.signature));\n\t\t\t\t}\n\t\t\t}\n\t\t});\n\t\tstream = this;\n\t}\n}\n\nexport {\n\tAESDecryptionStream,\n\tAESEncryptionStream,\n\tERR_INVALID_PASSWORD\n};\n\nfunction append(aesCrypto, input, output, paddingStart, paddingEnd, verifySignature) {\n\tconst {\n\t\tctr,\n\t\thmac,\n\t\tpending\n\t} = aesCrypto;\n\tconst inputLength = input.length - paddingEnd;\n\tif (pending.length) {\n\t\tinput = concat(pending, input);\n\t\toutput = expand(output, inputLength - (inputLength % BLOCK_LENGTH));\n\t}\n\tlet offset;\n\tfor (offset = 0; offset <= inputLength - BLOCK_LENGTH; offset += BLOCK_LENGTH) {\n\t\tconst inputChunk = toBits(codecBytes, subarray(input, offset, offset + BLOCK_LENGTH));\n\t\tif (verifySignature) {\n\t\t\thmac.update(inputChunk);\n\t\t}\n\t\tconst outputChunk = ctr.update(inputChunk);\n\t\tif (!verifySignature) {\n\t\t\thmac.update(outputChunk);\n\t\t}\n\t\toutput.set(fromBits(codecBytes, outputChunk), offset + paddingStart);\n\t}\n\taesCrypto.pending = subarray(input, offset);\n\treturn output;\n}\n\nasync function createDecryptionKeys(decrypt, strength, password, preamble) {\n\tconst passwordVerificationKey = await createKeys(decrypt, strength, password, subarray(preamble, 0, SALT_LENGTH[strength]));\n\tconst passwordVerification = subarray(preamble, SALT_LENGTH[strength]);\n\tif (passwordVerificationKey[0] != passwordVerification[0] || passwordVerificationKey[1] != passwordVerification[1]) {\n\t\tthrow new Error(ERR_INVALID_PASSWORD);\n\t}\n}\n\nasync function createEncryptionKeys(encrypt, strength, password) {\n\tconst salt = getRandomValues(new Uint8Array(SALT_LENGTH[strength]));\n\tconst passwordVerification = await createKeys(encrypt, strength, password, salt);\n\treturn concat(salt, passwordVerification);\n}\n\nasync function createKeys(aesCrypto, strength, password, salt) {\n\taesCrypto.password = null;\n\tconst baseKey = await importKey(RAW_FORMAT, password, BASE_KEY_ALGORITHM, false, DERIVED_BITS_USAGE);\n\tconst derivedBits = await deriveBits(Object.assign({ salt }, DERIVED_BITS_ALGORITHM), baseKey, 8 * ((KEY_LENGTH[strength] * 2) + 2));\n\tconst compositeKey = new Uint8Array(derivedBits);\n\tconst key = toBits(codecBytes, subarray(compositeKey, 0, KEY_LENGTH[strength]));\n\tconst authentication = toBits(codecBytes, subarray(compositeKey, KEY_LENGTH[strength], KEY_LENGTH[strength] * 2));\n\tconst passwordVerification = subarray(compositeKey, KEY_LENGTH[strength] * 2);\n\tObject.assign(aesCrypto, {\n\t\tkeys: {\n\t\t\tkey,\n\t\t\tauthentication,\n\t\t\tpasswordVerification\n\t\t},\n\t\tctr: new CtrGladman(new Aes(key), Array.from(COUNTER_DEFAULT_VALUE)),\n\t\thmac: new HmacSha1(authentication)\n\t});\n\treturn passwordVerification;\n}\n\nasync function importKey(format, password, algorithm, extractable, keyUsages) {\n\tif (IMPORT_KEY_SUPPORTED) {\n\t\ttry {\n\t\t\treturn await subtle.importKey(format, password, algorithm, extractable, keyUsages);\n\t\t} catch {\n\t\t\tIMPORT_KEY_SUPPORTED = false;\n\t\t\treturn misc.importKey(password);\n\t\t}\n\t} else {\n\t\treturn misc.importKey(password);\n\t}\n}\n\nasync function deriveBits(algorithm, baseKey, length) {\n\tif (DERIVE_BITS_SUPPORTED) {\n\t\ttry {\n\t\t\treturn await subtle.deriveBits(algorithm, baseKey, length);\n\t\t} catch {\n\t\t\tDERIVE_BITS_SUPPORTED = false;\n\t\t\treturn misc.pbkdf2(baseKey, algorithm.salt, DERIVED_BITS_ALGORITHM.iterations, length);\n\t\t}\n\t} else {\n\t\treturn misc.pbkdf2(baseKey, algorithm.salt, DERIVED_BITS_ALGORITHM.iterations, length);\n\t}\n}\n\nfunction encodePassword(password, rawPassword) {\n\tif (rawPassword === UNDEFINED_VALUE) {\n\t\treturn encodeText(password);\n\t} else {\n\t\treturn rawPassword;\n\t}\n}\n\nfunction concat(leftArray, rightArray) {\n\tlet array = leftArray;\n\tif (leftArray.length + rightArray.length) {\n\t\tarray = new Uint8Array(leftArray.length + rightArray.length);\n\t\tarray.set(leftArray, 0);\n\t\tarray.set(rightArray, leftArray.length);\n\t}\n\treturn array;\n}\n\nfunction expand(inputArray, length) {\n\tif (length && length > inputArray.length) {\n\t\tconst array = inputArray;\n\t\tinputArray = new Uint8Array(length);\n\t\tinputArray.set(array, 0);\n\t}\n\treturn inputArray;\n}\n\nfunction subarray(array, begin, end) {\n\treturn array.subarray(begin, end);\n}\n\nfunction fromBits(codecBytes, chunk) {\n\treturn codecBytes.fromBits(chunk);\n}\nfunction toBits(codecBytes, chunk) {\n\treturn codecBytes.toBits(chunk);\n}","/*\n Copyright (c) 2022 Gildas Lormeau. All rights reserved.\n\n Redistribution and use in source and binary forms, with or without\n modification, are permitted provided that the following conditions are met:\n\n 1. Redistributions of source code must retain the above copyright notice,\n this list of conditions and the following disclaimer.\n\n 2. Redistributions in binary form must reproduce the above copyright \n notice, this list of conditions and the following disclaimer in \n the documentation and/or other materials provided with the distribution.\n\n 3. The names of the authors may not be used to endorse or promote products\n derived from this software without specific prior written permission.\n\n THIS SOFTWARE IS PROVIDED ''AS IS'' AND ANY EXPRESSED OR IMPLIED WARRANTIES,\n INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND\n FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL JCRAFT,\n INC. OR ANY CONTRIBUTORS TO THIS SOFTWARE BE LIABLE FOR ANY DIRECT, INDIRECT,\n INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT\n LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA,\n OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF\n LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING\n NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE,\n EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.\n */\n\n/* global TextEncoder */\n\nimport { UNDEFINED_TYPE } from \"../constants.js\";\n\nexport {\n\tencodeText\n};\n\nfunction encodeText(value) {\n\t// deno-lint-ignore valid-typeof\n\tif (typeof TextEncoder == UNDEFINED_TYPE) {\n\t\tvalue = unescape(encodeURIComponent(value));\n\t\tconst result = new Uint8Array(value.length);\n\t\tfor (let i = 0; i < result.length; i++) {\n\t\t\tresult[i] = value.charCodeAt(i);\n\t\t}\n\t\treturn result;\n\t} else {\n\t\treturn new TextEncoder().encode(value);\n\t}\n}","/*\n Copyright (c) 2022 Gildas Lormeau. All rights reserved.\n\n Redistribution and use in source and binary forms, with or without\n modification, are permitted provided that the following conditions are met:\n\n 1. Redistributions of source code must retain the above copyright notice,\n this list of conditions and the following disclaimer.\n\n 2. Redistributions in binary form must reproduce the above copyright \n notice, this list of conditions and the following disclaimer in \n the documentation and/or other materials provided with the distribution.\n\n 3. The names of the authors may not be used to endorse or promote products\n derived from this software without specific prior written permission.\n\n THIS SOFTWARE IS PROVIDED ''AS IS'' AND ANY EXPRESSED OR IMPLIED WARRANTIES,\n INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND\n FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL JCRAFT,\n INC. OR ANY CONTRIBUTORS TO THIS SOFTWARE BE LIABLE FOR ANY DIRECT, INDIRECT,\n INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT\n LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA,\n OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF\n LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING\n NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE,\n EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.\n */\n\n/* global TransformStream */\n// deno-lint-ignore-file no-this-alias\n\nimport { Crc32 } from \"./codecs/crc32.js\";\nimport {\n\tERR_INVALID_PASSWORD,\n\tERR_ABORT_CHECK_PASSWORD,\n\tgetRandomValues\n} from \"./common-crypto.js\";\n\nconst HEADER_LENGTH = 12;\n\nclass ZipCryptoDecryptionStream extends TransformStream {\n\n\tconstructor({ password, passwordVerification, checkPasswordOnly }) {\n\t\tsuper({\n\t\t\tstart() {\n\t\t\t\tObject.assign(this, {\n\t\t\t\t\tpassword,\n\t\t\t\t\tpasswordVerification\n\t\t\t\t});\n\t\t\t\tcreateKeys(this, password);\n\t\t\t},\n\t\t\ttransform(chunk, controller) {\n\t\t\t\tconst zipCrypto = this;\n\t\t\t\tif (zipCrypto.password) {\n\t\t\t\t\tconst decryptedHeader = decrypt(zipCrypto, chunk.subarray(0, HEADER_LENGTH));\n\t\t\t\t\tzipCrypto.password = null;\n\t\t\t\t\tif (decryptedHeader.at(-1) != zipCrypto.passwordVerification) {\n\t\t\t\t\t\tthrow new Error(ERR_INVALID_PASSWORD);\n\t\t\t\t\t}\n\t\t\t\t\tchunk = chunk.subarray(HEADER_LENGTH);\n\t\t\t\t}\n\t\t\t\tif (checkPasswordOnly) {\n\t\t\t\t\tcontroller.error(new Error(ERR_ABORT_CHECK_PASSWORD));\n\t\t\t\t} else {\n\t\t\t\t\tcontroller.enqueue(decrypt(zipCrypto, chunk));\n\t\t\t\t}\n\t\t\t}\n\t\t});\n\t}\n}\n\nclass ZipCryptoEncryptionStream extends TransformStream {\n\n\tconstructor({ password, passwordVerification }) {\n\t\tsuper({\n\t\t\tstart() {\n\t\t\t\tObject.assign(this, {\n\t\t\t\t\tpassword,\n\t\t\t\t\tpasswordVerification\n\t\t\t\t});\n\t\t\t\tcreateKeys(this, password);\n\t\t\t},\n\t\t\ttransform(chunk, controller) {\n\t\t\t\tconst zipCrypto = this;\n\t\t\t\tlet output;\n\t\t\t\tlet offset;\n\t\t\t\tif (zipCrypto.password) {\n\t\t\t\t\tzipCrypto.password = null;\n\t\t\t\t\tconst header = getRandomValues(new Uint8Array(HEADER_LENGTH));\n\t\t\t\t\theader[HEADER_LENGTH - 1] = zipCrypto.passwordVerification;\n\t\t\t\t\toutput = new Uint8Array(chunk.length + header.length);\n\t\t\t\t\toutput.set(encrypt(zipCrypto, header), 0);\n\t\t\t\t\toffset = HEADER_LENGTH;\n\t\t\t\t} else {\n\t\t\t\t\toutput = new Uint8Array(chunk.length);\n\t\t\t\t\toffset = 0;\n\t\t\t\t}\n\t\t\t\toutput.set(encrypt(zipCrypto, chunk), offset);\n\t\t\t\tcontroller.enqueue(output);\n\t\t\t}\n\t\t});\n\t}\n}\n\nexport {\n\tZipCryptoDecryptionStream,\n\tZipCryptoEncryptionStream,\n\tERR_INVALID_PASSWORD\n};\n\nfunction decrypt(target, input) {\n\tconst output = new Uint8Array(input.length);\n\tfor (let index = 0; index < input.length; index++) {\n\t\toutput[index] = getByte(target) ^ input[index];\n\t\tupdateKeys(target, output[index]);\n\t}\n\treturn output;\n}\n\nfunction encrypt(target, input) {\n\tconst output = new Uint8Array(input.length);\n\tfor (let index = 0; index < input.length; index++) {\n\t\toutput[index] = getByte(target) ^ input[index];\n\t\tupdateKeys(target, input[index]);\n\t}\n\treturn output;\n}\n\nfunction createKeys(target, password) {\n\tconst keys = [0x12345678, 0x23456789, 0x34567890];\n\tObject.assign(target, {\n\t\tkeys,\n\t\tcrcKey0: new Crc32(keys[0]),\n\t\tcrcKey2: new Crc32(keys[2])\n\t});\n\tfor (let index = 0; index < password.length; index++) {\n\t\tupdateKeys(target, password.charCodeAt(index));\n\t}\n}\n\nfunction updateKeys(target, byte) {\n\tlet [key0, key1, key2] = target.keys;\n\ttarget.crcKey0.append([byte]);\n\tkey0 = ~target.crcKey0.get();\n\tkey1 = getInt32(Math.imul(getInt32(key1 + getInt8(key0)), 134775813) + 1);\n\ttarget.crcKey2.append([key1 >>> 24]);\n\tkey2 = ~target.crcKey2.get();\n\ttarget.keys = [key0, key1, key2];\n}\n\nfunction getByte(target) {\n\tconst temp = target.keys[2] | 2;\n\treturn getInt8(Math.imul(temp, (temp ^ 1)) >>> 8);\n}\n\nfunction getInt8(number) {\n\treturn number & 0xFF;\n}\n\nfunction getInt32(number) {\n\treturn number & 0xFFFFFFFF;\n}","/*\n Copyright (c) 2025 Gildas Lormeau. All rights reserved.\n\n Redistribution and use in source and binary forms, with or without\n modification, are permitted provided that the following conditions are met:\n\n 1. Redistributions of source code must retain the above copyright notice,\n this list of conditions and the following disclaimer.\n\n 2. Redistributions in binary form must reproduce the above copyright \n notice, this list of conditions and the following disclaimer in \n the documentation and/or other materials provided with the distribution.\n\n 3. The names of the authors may not be used to endorse or promote products\n derived from this software without specific prior written permission.\n\n THIS SOFTWARE IS PROVIDED ''AS IS'' AND ANY EXPRESSED OR IMPLIED WARRANTIES,\n INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND\n FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL JCRAFT,\n INC. OR ANY CONTRIBUTORS TO THIS SOFTWARE BE LIABLE FOR ANY DIRECT, INDIRECT,\n INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT\n LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA,\n OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF\n LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING\n NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE,\n EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.\n */\n\n/* global TransformStream */\n// deno-lint-ignore-file no-this-alias\n\nimport { Crc32Stream } from \"./crc32-stream.js\";\nimport {\n\tAESEncryptionStream,\n\tAESDecryptionStream\n} from \"./aes-crypto-stream.js\";\nimport {\n\tZipCryptoEncryptionStream,\n\tZipCryptoDecryptionStream\n} from \"./zip-crypto-stream.js\";\nimport {\n\tERR_INVALID_PASSWORD,\n\tERR_INVALID_SIGNATURE,\n\tERR_ABORT_CHECK_PASSWORD\n} from \"./common-crypto.js\";\n\nconst ERR_INVALID_UNCOMPRESSED_SIZE = \"Invalid uncompressed size\";\nconst FORMAT_DEFLATE_RAW = \"deflate-raw\";\nconst FORMAT_DEFLATE64_RAW = \"deflate64-raw\";\n\nclass DeflateStream extends TransformStream {\n\n\tconstructor(options, { chunkSize, CompressionStreamZlib, CompressionStream }) {\n\t\tsuper({});\n\t\tconst { compressed, encrypted, useCompressionStream, zipCrypto, signed, level } = options;\n\t\tconst stream = this;\n\t\tlet crc32Stream, encryptionStream;\n\t\tlet readable = super.readable;\n\t\tif ((!encrypted || zipCrypto) && signed) {\n\t\t\tcrc32Stream = new Crc32Stream();\n\t\t\treadable = pipeThrough(readable, crc32Stream);\n\t\t}\n\t\tif (compressed) {\n\t\t\treadable = pipeThroughCommpressionStream(readable, useCompressionStream, { level, chunkSize }, CompressionStream, CompressionStreamZlib, CompressionStream);\n\t\t}\n\t\tif (encrypted) {\n\t\t\tif (zipCrypto) {\n\t\t\t\treadable = pipeThrough(readable, new ZipCryptoEncryptionStream(options));\n\t\t\t} else {\n\t\t\t\tencryptionStream = new AESEncryptionStream(options);\n\t\t\t\treadable = pipeThrough(readable, encryptionStream);\n\t\t\t}\n\t\t}\n\t\tsetReadable(stream, readable, () => {\n\t\t\tlet signature;\n\t\t\tif (encrypted && !zipCrypto) {\n\t\t\t\tsignature = encryptionStream.signature;\n\t\t\t}\n\t\t\tif ((!encrypted || zipCrypto) && signed) {\n\t\t\t\tsignature = new DataView(crc32Stream.value.buffer).getUint32(0);\n\t\t\t}\n\t\t\tstream.signature = signature;\n\t\t});\n\t}\n}\n\nclass InflateStream extends TransformStream {\n\n\tconstructor(options, { chunkSize, DecompressionStreamZlib, DecompressionStream }) {\n\t\tsuper({});\n\t\tconst { zipCrypto, encrypted, signed, signature, compressed, useCompressionStream, deflate64 } = options;\n\t\tlet crc32Stream, decryptionStream;\n\t\tlet readable = super.readable;\n\t\tif (encrypted) {\n\t\t\tif (zipCrypto) {\n\t\t\t\treadable = pipeThrough(readable, new ZipCryptoDecryptionStream(options));\n\t\t\t} else {\n\t\t\t\tdecryptionStream = new AESDecryptionStream(options);\n\t\t\t\treadable = pipeThrough(readable, decryptionStream);\n\t\t\t}\n\t\t}\n\t\tif (compressed) {\n\t\t\treadable = pipeThroughCommpressionStream(readable, useCompressionStream, { chunkSize, deflate64 }, DecompressionStream, DecompressionStreamZlib, DecompressionStream);\n\t\t}\n\t\tif ((!encrypted || zipCrypto) && signed) {\n\t\t\tcrc32Stream = new Crc32Stream();\n\t\t\treadable = pipeThrough(readable, crc32Stream);\n\t\t}\n\t\tsetReadable(this, readable, () => {\n\t\t\tif ((!encrypted || zipCrypto) && signed) {\n\t\t\t\tconst dataViewSignature = new DataView(crc32Stream.value.buffer);\n\t\t\t\tif (signature != dataViewSignature.getUint32(0, false)) {\n\t\t\t\t\tthrow new Error(ERR_INVALID_SIGNATURE);\n\t\t\t\t}\n\t\t\t}\n\t\t});\n\t}\n}\n\nexport {\n\tDeflateStream,\n\tInflateStream,\n\tERR_INVALID_PASSWORD,\n\tERR_INVALID_SIGNATURE,\n\tERR_INVALID_UNCOMPRESSED_SIZE,\n\tERR_ABORT_CHECK_PASSWORD\n};\n\nfunction setReadable(stream, readable, flush) {\n\treadable = pipeThrough(readable, new TransformStream({ flush }));\n\tObject.defineProperty(stream, \"readable\", {\n\t\tget() {\n\t\t\treturn readable;\n\t\t}\n\t});\n}\n\nfunction pipeThroughCommpressionStream(readable, useCompressionStream, options, CompressionStreamNative, CompressionStreamZlib, CompressionStream) {\n\tconst Stream = useCompressionStream && CompressionStreamNative ? CompressionStreamNative : CompressionStreamZlib || CompressionStream;\n\tconst format = options.deflate64 ? FORMAT_DEFLATE64_RAW : FORMAT_DEFLATE_RAW;\n\ttry {\n\t\treadable = pipeThrough(readable, new Stream(format, options));\n\t} catch (error) {\n\t\tif (useCompressionStream) {\n\t\t\tif (CompressionStreamZlib) {\n\t\t\t\treadable = pipeThrough(readable, new CompressionStreamZlib(format, options));\n\t\t\t} else if (CompressionStream) {\n\t\t\t\treadable = pipeThrough(readable, new CompressionStream(format, options));\n\t\t\t} else {\n\t\t\t\tthrow error;\n\t\t\t}\n\t\t} else {\n\t\t\tthrow error;\n\t\t}\n\t}\n\treturn readable;\n}\n\nfunction pipeThrough(readable, transformStream) {\n\treturn readable.pipeThrough(transformStream);\n}","/*\n Copyright (c) 2022 Gildas Lormeau. All rights reserved.\n\n Redistribution and use in source and binary forms, with or without\n modification, are permitted provided that the following conditions are met:\n\n 1. Redistributions of source code must retain the above copyright notice,\n this list of conditions and the following disclaimer.\n\n 2. Redistributions in binary form must reproduce the above copyright \n notice, this list of conditions and the following disclaimer in \n the documentation and/or other materials provided with the distribution.\n\n 3. The names of the authors may not be used to endorse or promote products\n derived from this software without specific prior written permission.\n\n THIS SOFTWARE IS PROVIDED ''AS IS'' AND ANY EXPRESSED OR IMPLIED WARRANTIES,\n INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND\n FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL JCRAFT,\n INC. OR ANY CONTRIBUTORS TO THIS SOFTWARE BE LIABLE FOR ANY DIRECT, INDIRECT,\n INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT\n LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA,\n OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF\n LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING\n NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE,\n EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.\n */\n\n/*\n * This program is based on JZlib 1.0.2 ymnk, JCraft,Inc.\n * JZlib is based on zlib-1.1.3, so all credit should go authors\n * Jean-loup Gailly(jloup@gzip.org) and Mark Adler(madler@alumni.caltech.edu)\n * and contributors of zlib.\n */\n\n/* global TransformStream */\n// deno-lint-ignore-file no-this-alias\n\nimport { UNDEFINED_VALUE } from \"../constants.js\";\nimport {\n\tERR_INVALID_PASSWORD,\n\tERR_INVALID_SIGNATURE,\n\tERR_INVALID_UNCOMPRESSED_SIZE,\n\tERR_ABORT_CHECK_PASSWORD,\n\tInflateStream,\n\tDeflateStream\n} from \"./zip-entry-stream.js\";\n\nconst MESSAGE_EVENT_TYPE = \"message\";\nconst MESSAGE_START = \"start\";\nconst MESSAGE_PULL = \"pull\";\nconst MESSAGE_DATA = \"data\";\nconst MESSAGE_ACK_DATA = \"ack\";\nconst MESSAGE_CLOSE = \"close\";\nconst CODEC_DEFLATE = \"deflate\";\nconst CODEC_INFLATE = \"inflate\";\n\nexport {\n\tCODEC_DEFLATE,\n\tCODEC_INFLATE,\n\tMESSAGE_EVENT_TYPE,\n\tMESSAGE_START,\n\tMESSAGE_PULL,\n\tMESSAGE_DATA,\n\tMESSAGE_ACK_DATA,\n\tMESSAGE_CLOSE,\n\tERR_INVALID_PASSWORD,\n\tERR_INVALID_SIGNATURE,\n\tERR_INVALID_UNCOMPRESSED_SIZE,\n\tERR_ABORT_CHECK_PASSWORD,\n\tCodecStream,\n\tChunkStream\n};\n\nclass CodecStream extends TransformStream {\n\n\tconstructor(options, config) {\n\t\tsuper({});\n\t\tconst codec = this;\n\t\tconst { codecType } = options;\n\t\tlet Stream;\n\t\tif (codecType.startsWith(CODEC_DEFLATE)) {\n\t\t\tStream = DeflateStream;\n\t\t} else if (codecType.startsWith(CODEC_INFLATE)) {\n\t\t\tStream = InflateStream;\n\t\t}\n\t\tcodec.outputSize = 0;\n\t\tlet inputSize = 0;\n\t\tconst stream = new Stream(options, config);\n\t\tconst readable = super.readable;\n\t\tconst inputSizeStream = new TransformStream({\n\t\t\ttransform(chunk, controller) {\n\t\t\t\tif (chunk && chunk.length) {\n\t\t\t\t\tinputSize += chunk.length;\n\t\t\t\t\tcontroller.enqueue(chunk);\n\t\t\t\t}\n\t\t\t},\n\t\t\tflush() {\n\t\t\t\tObject.assign(codec, {\n\t\t\t\t\tinputSize\n\t\t\t\t});\n\t\t\t}\n\t\t});\n\t\tconst outputSizeStream = new TransformStream({\n\t\t\ttransform(chunk, controller) {\n\t\t\t\tif (chunk && chunk.length) {\n\t\t\t\t\tcontroller.enqueue(chunk);\n\t\t\t\t\tcodec.outputSize += chunk.length;\n\t\t\t\t\tif (options.outputSize !== UNDEFINED_VALUE && codec.outputSize > options.outputSize) {\n\t\t\t\t\t\tthrow new Error(ERR_INVALID_UNCOMPRESSED_SIZE);\n\t\t\t\t\t}\n\t\t\t\t}\n\t\t\t},\n\t\t\tflush() {\n\t\t\t\tconst { signature } = stream;\n\t\t\t\tObject.assign(codec, {\n\t\t\t\t\tsignature,\n\t\t\t\t\tinputSize\n\t\t\t\t});\n\t\t\t}\n\t\t});\n\t\tObject.defineProperty(codec, \"readable\", {\n\t\t\tget() {\n\t\t\t\treturn readable.pipeThrough(inputSizeStream).pipeThrough(stream).pipeThrough(outputSizeStream);\n\t\t\t}\n\t\t});\n\t}\n}\n\nclass ChunkStream extends TransformStream {\n\n\tconstructor(chunkSize) {\n\t\tlet pendingChunk;\n\t\tsuper({\n\t\t\ttransform,\n\t\t\tflush(controller) {\n\t\t\t\tif (pendingChunk && pendingChunk.length) {\n\t\t\t\t\tcontroller.enqueue(pendingChunk);\n\t\t\t\t}\n\t\t\t}\n\t\t});\n\n\t\tfunction transform(chunk, controller) {\n\t\t\tif (pendingChunk) {\n\t\t\t\tconst newChunk = new Uint8Array(pendingChunk.length + chunk.length);\n\t\t\t\tnewChunk.set(pendingChunk);\n\t\t\t\tnewChunk.set(chunk, pendingChunk.length);\n\t\t\t\tchunk = newChunk;\n\t\t\t\tpendingChunk = null;\n\t\t\t}\n\t\t\tif (chunk.length > chunkSize) {\n\t\t\t\tcontroller.enqueue(chunk.slice(0, chunkSize));\n\t\t\t\ttransform(chunk.slice(chunkSize), controller);\n\t\t\t} else {\n\t\t\t\tpendingChunk = chunk;\n\t\t\t}\n\t\t}\n\t}\n}","/*\n Copyright (c) 2025 Gildas Lormeau. All rights reserved.\n\n Redistribution and use in source and binary forms, with or without\n modification, are permitted provided that the following conditions are met:\n\n 1. Redistributions of source code must retain the above copyright notice,\n this list of conditions and the following disclaimer.\n\n 2. Redistributions in binary form must reproduce the above copyright \n notice, this list of conditions and the following disclaimer in \n the documentation and/or other materials provided with the distribution.\n\n 3. The names of the authors may not be used to endorse or promote products\n derived from this software without specific prior written permission.\n\n THIS SOFTWARE IS PROVIDED ''AS IS'' AND ANY EXPRESSED OR IMPLIED WARRANTIES,\n INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND\n FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL JCRAFT,\n INC. OR ANY CONTRIBUTORS TO THIS SOFTWARE BE LIABLE FOR ANY DIRECT, INDIRECT,\n INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT\n LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA,\n OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF\n LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING\n NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE,\n EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.\n */\n\n/* global Worker, URL, TransformStream, WritableStream */\n\nimport {\n\tUNDEFINED_VALUE,\n\tUNDEFINED_TYPE,\n\tFUNCTION_TYPE\n} from \"./constants.js\";\nimport {\n\tCodecStream,\n\tChunkStream,\n\tMESSAGE_EVENT_TYPE,\n\tMESSAGE_START,\n\tMESSAGE_PULL,\n\tMESSAGE_DATA,\n\tMESSAGE_ACK_DATA,\n\tMESSAGE_CLOSE\n} from \"./streams/codec-stream.js\";\n\nconst MODULE_WORKER_OPTIONS = { type: \"module\" };\n\nlet webWorkerSupported, webWorkerURI, webWorkerOptions;\nlet transferStreamsSupported = true;\ntry {\n\ttransferStreamsSupported = typeof structuredClone == FUNCTION_TYPE && structuredClone(new DOMException(\"\", \"AbortError\")).code !== UNDEFINED_VALUE;\n} catch {\n\t// ignored\n}\nlet initModule = () => { };\n\nexport {\n\tCodecWorker,\n\tconfigureWorker\n};\n\nfunction configureWorker({ initModule: initModuleFunction }) {\n\tinitModule = initModuleFunction;\n}\n\nclass CodecWorker {\n\n\tconstructor(workerData, { readable, writable }, { options, config, streamOptions, useWebWorkers, transferStreams, workerURI }, onTaskFinished) {\n\t\tconst { signal } = streamOptions;\n\t\tObject.assign(workerData, {\n\t\t\tbusy: true,\n\t\t\treadable: readable\n\t\t\t\t.pipeThrough(new ChunkStream(config.chunkSize))\n\t\t\t\t.pipeThrough(new ProgressWatcherStream(streamOptions), { signal }),\n\t\t\twritable,\n\t\t\toptions: Object.assign({}, options),\n\t\t\tworkerURI,\n\t\t\ttransferStreams,\n\t\t\tterminate() {\n\t\t\t\treturn new Promise(resolve => {\n\t\t\t\t\tconst { worker, busy } = workerData;\n\t\t\t\t\tif (worker) {\n\t\t\t\t\t\tif (busy) {\n\t\t\t\t\t\t\tworkerData.resolveTerminated = resolve;\n\t\t\t\t\t\t} else {\n\t\t\t\t\t\t\tworker.terminate();\n\t\t\t\t\t\t\tresolve();\n\t\t\t\t\t\t}\n\t\t\t\t\t\tworkerData.interface = null;\n\t\t\t\t\t} else {\n\t\t\t\t\t\tresolve();\n\t\t\t\t\t}\n\t\t\t\t});\n\t\t\t},\n\t\t\tonTaskFinished() {\n\t\t\t\tconst { resolveTerminated } = workerData;\n\t\t\t\tif (resolveTerminated) {\n\t\t\t\t\tworkerData.resolveTerminated = null;\n\t\t\t\t\tworkerData.terminated = true;\n\t\t\t\t\tworkerData.worker.terminate();\n\t\t\t\t\tresolveTerminated();\n\t\t\t\t}\n\t\t\t\tworkerData.busy = false;\n\t\t\t\tonTaskFinished(workerData);\n\t\t\t}\n\t\t});\n\t\tif (webWorkerSupported === UNDEFINED_VALUE) {\n\t\t\t// deno-lint-ignore valid-typeof\n\t\t\twebWorkerSupported = typeof Worker != UNDEFINED_TYPE;\n\t\t}\n\t\treturn (useWebWorkers && webWorkerSupported ? createWebWorkerInterface : createWorkerInterface)(workerData, config);\n\t}\n}\n\nclass ProgressWatcherStream extends TransformStream {\n\n\tconstructor({ onstart, onprogress, size, onend }) {\n\t\tlet chunkOffset = 0;\n\t\tsuper({\n\t\t\tasync start() {\n\t\t\t\tif (onstart) {\n\t\t\t\t\tawait callHandler(onstart, size);\n\t\t\t\t}\n\t\t\t},\n\t\t\tasync transform(chunk, controller) {\n\t\t\t\tchunkOffset += chunk.length;\n\t\t\t\tif (onprogress) {\n\t\t\t\t\tawait callHandler(onprogress, chunkOffset, size);\n\t\t\t\t}\n\t\t\t\tcontroller.enqueue(chunk);\n\t\t\t},\n\t\t\tasync flush() {\n\t\t\t\tif (onend) {\n\t\t\t\t\tawait callHandler(onend, chunkOffset);\n\t\t\t\t}\n\t\t\t}\n\t\t});\n\t}\n}\n\nasync function callHandler(handler, ...parameters) {\n\ttry {\n\t\tawait handler(...parameters);\n\t} catch {\n\t\t// ignored\n\t}\n}\n\nfunction createWorkerInterface(workerData, config) {\n\treturn {\n\t\trun: () => runWorker(workerData, config)\n\t};\n}\n\nfunction createWebWorkerInterface(workerData, config) {\n\tconst { baseURI, chunkSize } = config;\n\tlet { wasmURI } = config;\n\n\tif (!workerData.interface) {\n\t\t// deno-lint-ignore valid-typeof\n\t\tif (typeof wasmURI == FUNCTION_TYPE) {\n\t\t\twasmURI = wasmURI();\n\t\t}\n\t\tlet worker;\n\t\ttry {\n\t\t\tworker = getWebWorker(workerData.workerURI, baseURI, workerData);\n\t\t} catch {\n\t\t\twebWorkerSupported = false;\n\t\t\treturn createWorkerInterface(workerData, config);\n\t\t}\n\t\tObject.assign(workerData, {\n\t\t\tworker,\n\t\t\tinterface: {\n\t\t\t\trun: () => runWebWorker(workerData, { chunkSize, wasmURI, baseURI })\n\t\t\t}\n\t\t});\n\t}\n\treturn workerData.interface;\n}\n\nasync function runWorker({ options, readable, writable, onTaskFinished }, config) {\n\tlet codecStream;\n\ttry {\n\t\tif (!options.useCompressionStream) {\n\t\t\ttry {\n\t\t\t\tawait initModule(config);\n\t\t\t} catch {\n\t\t\t\toptions.useCompressionStream = true;\n\t\t\t}\n\t\t}\n\t\tcodecStream = new CodecStream(options, config);\n\t\tawait readable.pipeThrough(codecStream).pipeTo(writable, { preventClose: true, preventAbort: true });\n\t\tconst {\n\t\t\tsignature,\n\t\t\tinputSize,\n\t\t\toutputSize\n\t\t} = codecStream;\n\t\treturn {\n\t\t\tsignature,\n\t\t\tinputSize,\n\t\t\toutputSize\n\t\t};\n\t} catch (error) {\n\t\tif (codecStream) {\n\t\t\terror.outputSize = codecStream.outputSize;\n\t\t}\n\t\tthrow error;\n\t} finally {\n\t\tonTaskFinished();\n\t}\n}\n\nasync function runWebWorker(workerData, config) {\n\tlet resolveResult, rejectResult;\n\tconst result = new Promise((resolve, reject) => {\n\t\tresolveResult = resolve;\n\t\trejectResult = reject;\n\t});\n\tObject.assign(workerData, {\n\t\treader: null,\n\t\twriter: null,\n\t\tresolveResult,\n\t\trejectResult,\n\t\tresult\n\t});\n\tconst { readable, options } = workerData;\n\tconst { writable, closed } = watchClosedStream(workerData.writable);\n\tconst streamsTransferred = sendMessage({\n\t\ttype: MESSAGE_START,\n\t\toptions,\n\t\tconfig,\n\t\treadable,\n\t\twritable\n\t}, workerData);\n\tif (!streamsTransferred) {\n\t\tObject.assign(workerData, {\n\t\t\treader: readable.getReader(),\n\t\t\twriter: writable.getWriter()\n\t\t});\n\t}\n\tconst resultValue = await result;\n\tif (!streamsTransferred) {\n\t\tawait writable.getWriter().close();\n\t}\n\tawait closed;\n\treturn resultValue;\n}\n\nfunction watchClosedStream(writableSource) {\n\tconst { writable, readable } = new TransformStream();\n\tconst closed = readable.pipeTo(writableSource, { preventClose: true });\n\treturn { writable, closed };\n}\n\nfunction getWebWorker(url, baseURI, workerData, isModuleType, useBlobURI = true) {\n\tlet worker, resolvedURI, resolvedOptions;\n\tif (webWorkerURI === UNDEFINED_VALUE) {\n\t\t// deno-lint-ignore valid-typeof\n\t\tconst isFunctionURI = typeof url == FUNCTION_TYPE;\n\t\tif (isFunctionURI) {\n\t\t\tresolvedURI = url(useBlobURI);\n\t\t} else {\n\t\t\tresolvedURI = url;\n\t\t}\n\t\tconst isDataURI = resolvedURI.startsWith(\"data:\");\n\t\tconst isBlobURI = resolvedURI.startsWith(\"blob:\");\n\t\tif (isDataURI || isBlobURI) {\n\t\t\tif (isModuleType === UNDEFINED_VALUE) {\n\t\t\t\tisModuleType = false;\n\t\t\t}\n\t\t\tif (isModuleType) {\n\t\t\t\tresolvedOptions = MODULE_WORKER_OPTIONS;\n\t\t\t}\n\t\t\ttry {\n\t\t\t\tworker = new Worker(resolvedURI, resolvedOptions);\n\t\t\t} catch (error) {\n\t\t\t\tif (isBlobURI) {\n\t\t\t\t\ttry {\n\t\t\t\t\t\tURL.revokeObjectURL(resolvedURI);\n\t\t\t\t\t} catch {\n\t\t\t\t\t\t// ignored\n\t\t\t\t\t}\n\t\t\t\t}\n\t\t\t\tif (isFunctionURI && isBlobURI) {\n\t\t\t\t\treturn getWebWorker(url, baseURI, workerData, isModuleType, false);\n\t\t\t\t} else if (!isModuleType) {\n\t\t\t\t\treturn getWebWorker(url, baseURI, workerData, true, false);\n\t\t\t\t} else {\n\t\t\t\t\tthrow error;\n\t\t\t\t}\n\t\t\t}\n\t\t} else {\n\t\t\tif (isModuleType === UNDEFINED_VALUE) {\n\t\t\t\tisModuleType = true;\n\t\t\t}\n\t\t\tif (isModuleType) {\n\t\t\t\tresolvedOptions = MODULE_WORKER_OPTIONS;\n\t\t\t}\n\t\t\ttry {\n\t\t\t\tresolvedURI = new URL(resolvedURI, baseURI);\n\t\t\t} catch {\n\t\t\t\t// ignored\n\t\t\t}\n\t\t\ttry {\n\t\t\t\tworker = new Worker(resolvedURI, resolvedOptions);\n\t\t\t} catch (error) {\n\t\t\t\tif (!isModuleType) {\n\t\t\t\t\treturn getWebWorker(url, baseURI, workerData, false, useBlobURI);\n\t\t\t\t} else {\n\t\t\t\t\tthrow error;\n\t\t\t\t}\n\t\t\t}\n\t\t}\n\t\twebWorkerURI = resolvedURI;\n\t\twebWorkerOptions = resolvedOptions;\n\t} else {\n\t\tworker = new Worker(webWorkerURI, webWorkerOptions);\n\t}\n\tworker.addEventListener(MESSAGE_EVENT_TYPE, event => onMessage(event, workerData));\n\treturn worker;\n}\n\nfunction sendMessage(message, { worker, writer, onTaskFinished, transferStreams }) {\n\ttry {\n\t\tconst { value, readable, writable } = message;\n\t\tconst transferables = [];\n\t\tif (value) {\n\t\t\tmessage.value = value;\n\t\t\ttransferables.push(message.value.buffer);\n\t\t}\n\t\tif (transferStreams && transferStreamsSupported) {\n\t\t\tif (readable) {\n\t\t\t\ttransferables.push(readable);\n\t\t\t}\n\t\t\tif (writable) {\n\t\t\t\ttransferables.push(writable);\n\t\t\t}\n\t\t} else {\n\t\t\tmessage.readable = message.writable = null;\n\t\t}\n\t\tif (transferables.length) {\n\t\t\ttry {\n\t\t\t\tworker.postMessage(message, transferables);\n\t\t\t\treturn true;\n\t\t\t} catch {\n\t\t\t\ttransferStreamsSupported = false;\n\t\t\t\tmessage.readable = message.writable = null;\n\t\t\t\tworker.postMessage(message);\n\t\t\t}\n\t\t} else {\n\t\t\tworker.postMessage(message);\n\t\t}\n\t} catch (error) {\n\t\tif (writer) {\n\t\t\twriter.releaseLock();\n\t\t}\n\t\tonTaskFinished();\n\t\tthrow error;\n\t}\n}\n\nasync function onMessage({ data }, workerData) {\n\tconst { type, value, messageId, result, error } = data;\n\tconst { reader, writer, resolveResult, rejectResult, onTaskFinished } = workerData;\n\ttry {\n\t\tif (error) {\n\t\t\tconst { message, stack, code, name, outputSize } = error;\n\t\t\tconst responseError = new Error(message);\n\t\t\tObject.assign(responseError, { stack, code, name, outputSize });\n\t\t\tclose(responseError);\n\t\t} else {\n\t\t\tif (type == MESSAGE_PULL) {\n\t\t\t\tconst { value, done } = await reader.read();\n\t\t\t\tsendMessage({ type: MESSAGE_DATA, value, done, messageId }, workerData);\n\t\t\t}\n\t\t\tif (type == MESSAGE_DATA) {\n\t\t\t\tawait writer.ready;\n\t\t\t\tawait writer.write(new Uint8Array(value));\n\t\t\t\tsendMessage({ type: MESSAGE_ACK_DATA, messageId }, workerData);\n\t\t\t}\n\t\t\tif (type == MESSAGE_CLOSE) {\n\t\t\t\tclose(null, result);\n\t\t\t}\n\t\t}\n\t} catch (error) {\n\t\tsendMessage({ type: MESSAGE_CLOSE, messageId }, workerData);\n\t\tclose(error);\n\t}\n\n\tfunction close(error, result) {\n\t\tif (error) {\n\t\t\trejectResult(error);\n\t\t} else {\n\t\t\tresolveResult(result);\n\t\t}\n\t\tif (writer) {\n\t\t\twriter.releaseLock();\n\t\t}\n\t\tonTaskFinished();\n\t}\n}","/*\n Copyright (c) 2025 Gildas Lormeau. All rights reserved.\n\n Redistribution and use in source and binary forms, with or without\n modification, are permitted provided that the following conditions are met:\n\n 1. Redistributions of source code must retain the above copyright notice,\n this list of conditions and the following disclaimer.\n\n 2. Redistributions in binary form must reproduce the above copyright \n notice, this list of conditions and the following disclaimer in \n the documentation and/or other materials provided with the distribution.\n\n 3. The names of the authors may not be used to endorse or promote products\n derived from this software without specific prior written permission.\n\n THIS SOFTWARE IS PROVIDED ''AS IS'' AND ANY EXPRESSED OR IMPLIED WARRANTIES,\n INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND\n FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL JCRAFT,\n INC. OR ANY CONTRIBUTORS TO THIS SOFTWARE BE LIABLE FOR ANY DIRECT, INDIRECT,\n INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT\n LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA,\n OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF\n LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING\n NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE,\n EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.\n */\n\n/* global setTimeout, clearTimeout */\n\nimport { UNDEFINED_VALUE } from \"./constants.js\";\nimport {\n\tCODEC_INFLATE,\n\tCODEC_DEFLATE,\n\tERR_INVALID_SIGNATURE,\n\tERR_INVALID_UNCOMPRESSED_SIZE,\n\tERR_INVALID_PASSWORD,\n\tERR_ABORT_CHECK_PASSWORD\n} from \"./streams/codec-stream.js\";\nimport { CodecWorker } from \"./codec-worker.js\";\n\nlet pool = [];\nconst pendingRequests = [];\n\nexport {\n\trunWorker,\n\tterminateWorkers,\n\tCODEC_DEFLATE,\n\tCODEC_INFLATE,\n\tERR_INVALID_SIGNATURE,\n\tERR_INVALID_UNCOMPRESSED_SIZE,\n\tERR_INVALID_PASSWORD,\n\tERR_ABORT_CHECK_PASSWORD\n};\n\nlet indexWorker = 0;\n\nasync function runWorker(stream, workerOptions) {\n\tconst { options, config } = workerOptions;\n\tconst { transferStreams, useWebWorkers, useCompressionStream, compressed, signed, encrypted } = options;\n\tconst { workerURI, maxWorkers } = config;\n\tworkerOptions.transferStreams = transferStreams || transferStreams === UNDEFINED_VALUE;\n\tconst streamCopy = !compressed && !signed && !encrypted && !workerOptions.transferStreams;\n\tworkerOptions.useWebWorkers = !streamCopy && (useWebWorkers || (useWebWorkers === UNDEFINED_VALUE && config.useWebWorkers));\n\tworkerOptions.workerURI = workerOptions.useWebWorkers && workerURI ? workerURI : UNDEFINED_VALUE;\n\toptions.useCompressionStream = useCompressionStream || (useCompressionStream === UNDEFINED_VALUE && config.useCompressionStream);\n\treturn (await getWorker()).run();\n\n\t// deno-lint-ignore require-await\n\tasync function getWorker() {\n\t\tconst workerData = pool.find(workerData => !workerData.busy);\n\t\tif (workerData) {\n\t\t\tclearTerminateTimeout(workerData);\n\t\t\treturn new CodecWorker(workerData, stream, workerOptions, onTaskFinished);\n\t\t} else if (pool.length < maxWorkers) {\n\t\t\tconst workerData = { indexWorker };\n\t\t\tindexWorker++;\n\t\t\tpool.push(workerData);\n\t\t\treturn new CodecWorker(workerData, stream, workerOptions, onTaskFinished);\n\t\t} else {\n\t\t\treturn new Promise(resolve => pendingRequests.push({ resolve, stream, workerOptions }));\n\t\t}\n\t}\n\n\tfunction onTaskFinished(workerData) {\n\t\tif (pendingRequests.length) {\n\t\t\tconst [{ resolve, stream, workerOptions }] = pendingRequests.splice(0, 1);\n\t\t\tresolve(new CodecWorker(workerData, stream, workerOptions, onTaskFinished));\n\t\t} else if (workerData.worker) {\n\t\t\tclearTerminateTimeout(workerData);\n\t\t\tterminateWorker(workerData, workerOptions);\n\t\t} else {\n\t\t\tpool = pool.filter(data => data != workerData);\n\t\t}\n\t}\n}\n\nfunction terminateWorker(workerData, workerOptions) {\n\tconst { config } = workerOptions;\n\tconst { terminateWorkerTimeout } = config;\n\tif (Number.isFinite(terminateWorkerTimeout) && terminateWorkerTimeout >= 0) {\n\t\tif (workerData.terminated) {\n\t\t\tworkerData.terminated = false;\n\t\t} else {\n\t\t\tworkerData.terminateTimeout = setTimeout(async () => {\n\t\t\t\tpool = pool.filter(data => data != workerData);\n\t\t\t\ttry {\n\t\t\t\t\tawait workerData.terminate();\n\t\t\t\t} catch {\n\t\t\t\t\t// ignored\n\t\t\t\t}\n\t\t\t}, terminateWorkerTimeout);\n\t\t}\n\t}\n}\n\nfunction clearTerminateTimeout(workerData) {\n\tconst { terminateTimeout } = workerData;\n\tif (terminateTimeout) {\n\t\tclearTimeout(terminateTimeout);\n\t\tworkerData.terminateTimeout = null;\n\t}\n}\n\nasync function terminateWorkers() {\n\tawait Promise.allSettled(pool.map(workerData => {\n\t\tclearTerminateTimeout(workerData);\n\t\treturn workerData.terminate();\n\t}));\n}","/*\n Copyright (c) 2025 Gildas Lormeau. All rights reserved.\n\n Redistribution and use in source and binary forms, with or without\n modification, are permitted provided that the following conditions are met:\n\n 1. Redistributions of source code must retain the above copyright notice,\n this list of conditions and the following disclaimer.\n\n 2. Redistributions in binary form must reproduce the above copyright \n notice, this list of conditions and the following disclaimer in \n the documentation and/or other materials provided with the distribution.\n\n 3. The names of the authors may not be used to endorse or promote products\n derived from this software without specific prior written permission.\n\n THIS SOFTWARE IS PROVIDED ''AS IS'' AND ANY EXPRESSED OR IMPLIED WARRANTIES,\n INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND\n FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL JCRAFT,\n INC. OR ANY CONTRIBUTORS TO THIS SOFTWARE BE LIABLE FOR ANY DIRECT, INDIRECT,\n INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT\n LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA,\n OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF\n LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING\n NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE,\n EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.\n */\n\n/* global Blob, atob, btoa, XMLHttpRequest, URL, fetch, ReadableStream, WritableStream, FileReader, TransformStream, Response */\n// deno-lint-ignore-file no-this-alias\n\nimport {\n\tUNDEFINED_VALUE,\n\tINFINITY_VALUE,\n\tFUNCTION_TYPE,\n\tEND_OF_CENTRAL_DIR_LENGTH\n} from \"./constants.js\";\nimport { getConfiguration } from \"./configuration.js\";\n\nconst ERR_HTTP_STATUS = \"HTTP error \";\nconst ERR_HTTP_RANGE = \"HTTP Range not supported\";\nconst ERR_ITERATOR_COMPLETED_TOO_SOON = \"Writer iterator completed too soon\";\nconst ERR_WRITER_NOT_INITIALIZED = \"Writer not initialized\";\n\nconst CONTENT_TYPE_TEXT_PLAIN = \"text/plain\";\nconst HTTP_HEADER_CONTENT_LENGTH = \"Content-Length\";\nconst HTTP_HEADER_CONTENT_RANGE = \"Content-Range\";\nconst HTTP_HEADER_ACCEPT_RANGES = \"Accept-Ranges\";\nconst HTTP_HEADER_RANGE = \"Range\";\nconst HTTP_HEADER_CONTENT_TYPE = \"Content-Type\";\nconst HTTP_METHOD_HEAD = \"HEAD\";\nconst HTTP_METHOD_GET = \"GET\";\nconst HTTP_RANGE_UNIT = \"bytes\";\nconst DEFAULT_CHUNK_SIZE = 64 * 1024;\nconst DEFAULT_BUFFER_SIZE = 256 * 1024;\n\nconst PROPERTY_NAME_WRITABLE = \"writable\";\n\nclass Stream {\n\n\tconstructor() {\n\t\tthis.size = 0;\n\t}\n\n\tinit() {\n\t\tthis.initialized = true;\n\t}\n}\n\nclass Reader extends Stream {\n\n\tget readable() {\n\t\tconst reader = this;\n\t\tconst { chunkSize = DEFAULT_CHUNK_SIZE } = reader;\n\t\tconst readable = new ReadableStream({\n\t\t\tstart() {\n\t\t\t\tthis.chunkOffset = 0;\n\t\t\t},\n\t\t\tasync pull(controller) {\n\t\t\t\tconst { offset = 0, size, diskNumberStart } = readable;\n\t\t\t\tconst { chunkOffset } = this;\n\t\t\t\tconst dataSize = size === UNDEFINED_VALUE ? chunkSize : Math.min(chunkSize, size - chunkOffset);\n\t\t\t\tconst data = await readUint8Array(reader, offset + chunkOffset, dataSize, diskNumberStart);\n\t\t\t\tcontroller.enqueue(data);\n\t\t\t\tif ((chunkOffset + chunkSize > size) || (size === UNDEFINED_VALUE && !data.length && dataSize)) {\n\t\t\t\t\tcontroller.close();\n\t\t\t\t} else {\n\t\t\t\t\tthis.chunkOffset += chunkSize;\n\t\t\t\t}\n\t\t\t}\n\t\t});\n\t\treturn readable;\n\t}\n}\n\nclass Writer extends Stream {\n\n\tconstructor() {\n\t\tsuper();\n\t\tconst writer = this;\n\t\tconst writable = new WritableStream({\n\t\t\twrite(chunk) {\n\t\t\t\tif (!writer.initialized) {\n\t\t\t\t\tthrow new Error(ERR_WRITER_NOT_INITIALIZED);\n\t\t\t\t}\n\t\t\t\treturn writer.writeUint8Array(chunk);\n\t\t\t}\n\t\t});\n\t\tObject.defineProperty(writer, PROPERTY_NAME_WRITABLE, {\n\t\t\tget() {\n\t\t\t\treturn writable;\n\t\t\t}\n\t\t});\n\t}\n\n\twriteUint8Array() {\n\t\t// abstract\n\t}\n}\n\nclass Data64URIReader extends Reader {\n\n\tconstructor(dataURI) {\n\t\tsuper();\n\t\tlet dataEnd = dataURI.length;\n\t\twhile (dataURI.charAt(dataEnd - 1) == \"=\") {\n\t\t\tdataEnd--;\n\t\t}\n\t\tconst dataStart = dataURI.indexOf(\",\") + 1;\n\t\tObject.assign(this, {\n\t\t\tdataURI,\n\t\t\tdataStart,\n\t\t\tsize: Math.floor((dataEnd - dataStart) * 0.75)\n\t\t});\n\t}\n\n\treadUint8Array(offset, length) {\n\t\tconst {\n\t\t\tdataStart,\n\t\t\tdataURI\n\t\t} = this;\n\t\tconst dataArray = new Uint8Array(length);\n\t\tconst start = Math.floor(offset / 3) * 4;\n\t\tconst bytes = atob(dataURI.substring(start + dataStart, Math.ceil((offset + length) / 3) * 4 + dataStart));\n\t\tconst delta = offset - Math.floor(start / 4) * 3;\n\t\tlet effectiveLength = 0;\n\t\tfor (let indexByte = delta; indexByte < delta + length && indexByte < bytes.length; indexByte++) {\n\t\t\tdataArray[indexByte - delta] = bytes.charCodeAt(indexByte);\n\t\t\teffectiveLength++;\n\t\t}\n\t\tif (effectiveLength < dataArray.length) {\n\t\t\treturn dataArray.subarray(0, effectiveLength);\n\t\t} else {\n\t\t\treturn dataArray;\n\t\t}\n\t}\n}\n\nclass Data64URIWriter extends Writer {\n\n\tconstructor(contentType) {\n\t\tsuper();\n\t\tObject.assign(this, {\n\t\t\tdata: \"data:\" + (contentType || \"\") + \";base64,\",\n\t\t\tpending: []\n\t\t});\n\t}\n\n\twriteUint8Array(array) {\n\t\tconst writer = this;\n\t\tlet indexArray = 0;\n\t\tlet dataString = writer.pending;\n\t\tconst delta = writer.pending.length;\n\t\twriter.pending = \"\";\n\t\tfor (indexArray = 0; indexArray < (Math.floor((delta + array.length) / 3) * 3) - delta; indexArray++) {\n\t\t\tdataString += String.fromCharCode(array[indexArray]);\n\t\t}\n\t\tfor (; indexArray < array.length; indexArray++) {\n\t\t\twriter.pending += String.fromCharCode(array[indexArray]);\n\t\t}\n\t\tif (dataString.length) {\n\t\t\tif (dataString.length > 2) {\n\t\t\t\twriter.data += btoa(dataString);\n\t\t\t} else {\n\t\t\t\twriter.pending += dataString;\n\t\t\t}\n\t\t}\n\t}\n\n\tgetData() {\n\t\treturn this.data + btoa(this.pending);\n\t}\n}\n\nclass BlobReader extends Reader {\n\n\tconstructor(blob) {\n\t\tsuper();\n\t\tObject.assign(this, {\n\t\t\tblob,\n\t\t\tsize: blob.size\n\t\t});\n\t}\n\n\tasync readUint8Array(offset, length) {\n\t\tconst reader = this;\n\t\tconst offsetEnd = offset + length;\n\t\tconst blob = offset || offsetEnd < reader.size ? reader.blob.slice(offset, offsetEnd) : reader.blob;\n\t\tlet arrayBuffer = await blob.arrayBuffer();\n\t\tif (arrayBuffer.byteLength > length) {\n\t\t\tarrayBuffer = arrayBuffer.slice(offset, offsetEnd);\n\t\t}\n\t\treturn new Uint8Array(arrayBuffer);\n\t}\n}\n\nclass BlobWriter extends Stream {\n\n\tconstructor(contentType) {\n\t\tsuper();\n\t\tconst writer = this;\n\t\tconst transformStream = new TransformStream();\n\t\tconst headers = [];\n\t\tif (contentType) {\n\t\t\theaders.push([HTTP_HEADER_CONTENT_TYPE, contentType]);\n\t\t}\n\t\tObject.defineProperty(writer, PROPERTY_NAME_WRITABLE, {\n\t\t\tget() {\n\t\t\t\treturn transformStream.writable;\n\t\t\t}\n\t\t});\n\t\twriter.blob = new Response(transformStream.readable, { headers }).blob();\n\t}\n\n\tgetData() {\n\t\treturn this.blob;\n\t}\n}\n\nclass TextReader extends BlobReader {\n\n\tconstructor(text) {\n\t\tsuper(new Blob([text], { type: CONTENT_TYPE_TEXT_PLAIN }));\n\t}\n}\n\nclass TextWriter extends BlobWriter {\n\n\tconstructor(encoding) {\n\t\tsuper(encoding);\n\t\tObject.assign(this, {\n\t\t\tencoding,\n\t\t\tutf8: !encoding || encoding.toLowerCase() == \"utf-8\"\n\t\t});\n\t}\n\n\tasync getData() {\n\t\tconst {\n\t\t\tencoding,\n\t\t\tutf8\n\t\t} = this;\n\t\tconst blob = await super.getData();\n\t\tif (blob.text && utf8) {\n\t\t\treturn blob.text();\n\t\t} else {\n\t\t\tconst reader = new FileReader();\n\t\t\treturn new Promise((resolve, reject) => {\n\t\t\t\tObject.assign(reader, {\n\t\t\t\t\tonload: ({ target }) => resolve(target.result),\n\t\t\t\t\tonerror: () => reject(reader.error)\n\t\t\t\t});\n\t\t\t\treader.readAsText(blob, encoding);\n\t\t\t});\n\t\t}\n\t}\n}\n\nclass FetchReader extends Reader {\n\n\tconstructor(url, options) {\n\t\tsuper();\n\t\tcreateHttpReader(this, url, options);\n\t}\n\n\tasync init() {\n\t\tawait initHttpReader(this, sendFetchRequest, getFetchRequestData);\n\t\tsuper.init();\n\t}\n\n\treadUint8Array(index, length) {\n\t\treturn readUint8ArrayHttpReader(this, index, length, sendFetchRequest, getFetchRequestData);\n\t}\n}\n\nclass XHRReader extends Reader {\n\n\tconstructor(url, options) {\n\t\tsuper();\n\t\tcreateHttpReader(this, url, options);\n\t}\n\n\tasync init() {\n\t\tawait initHttpReader(this, sendXMLHttpRequest, getXMLHttpRequestData);\n\t\tsuper.init();\n\t}\n\n\treadUint8Array(index, length) {\n\t\treturn readUint8ArrayHttpReader(this, index, length, sendXMLHttpRequest, getXMLHttpRequestData);\n\t}\n}\n\nfunction createHttpReader(httpReader, url, options) {\n\tconst {\n\t\tpreventHeadRequest,\n\t\tuseRangeHeader,\n\t\tforceRangeRequests,\n\t\tcombineSizeEocd\n\t} = options;\n\toptions = Object.assign({}, options);\n\tdelete options.preventHeadRequest;\n\tdelete options.useRangeHeader;\n\tdelete options.forceRangeRequests;\n\tdelete options.combineSizeEocd;\n\tdelete options.useXHR;\n\tObject.assign(httpReader, {\n\t\turl,\n\t\toptions,\n\t\tpreventHeadRequest,\n\t\tuseRangeHeader,\n\t\tforceRangeRequests,\n\t\tcombineSizeEocd\n\t});\n}\n\nasync function initHttpReader(httpReader, sendRequest, getRequestData) {\n\tconst {\n\t\turl,\n\t\tpreventHeadRequest,\n\t\tuseRangeHeader,\n\t\tforceRangeRequests,\n\t\tcombineSizeEocd\n\t} = httpReader;\n\tif (isHttpFamily(url) && (useRangeHeader || forceRangeRequests) && (typeof preventHeadRequest == \"undefined\" || preventHeadRequest)) {\n\t\tconst response = await sendRequest(HTTP_METHOD_GET, httpReader, getRangeHeaders(httpReader, combineSizeEocd ? -END_OF_CENTRAL_DIR_LENGTH : undefined));\n\t\tconst acceptRanges = response.headers.get(HTTP_HEADER_ACCEPT_RANGES);\n\t\tif (!forceRangeRequests && (!acceptRanges || acceptRanges.toLowerCase() != HTTP_RANGE_UNIT)) {\n\t\t\tthrow new Error(ERR_HTTP_RANGE);\n\t\t} else {\n\t\t\tif (combineSizeEocd) {\n\t\t\t\thttpReader.eocdCache = new Uint8Array(await response.arrayBuffer());\n\t\t\t}\n\t\t\tlet contentSize;\n\t\t\tconst contentRangeHeader = response.headers.get(HTTP_HEADER_CONTENT_RANGE);\n\t\t\tif (contentRangeHeader) {\n\t\t\t\tconst splitHeader = contentRangeHeader.trim().split(/\\s*\\/\\s*/);\n\t\t\t\tif (splitHeader.length) {\n\t\t\t\t\tconst headerValue = splitHeader[1];\n\t\t\t\t\tif (headerValue && headerValue != \"*\") {\n\t\t\t\t\t\tcontentSize = Number(headerValue);\n\t\t\t\t\t}\n\t\t\t\t}\n\t\t\t}\n\t\t\tif (contentSize === UNDEFINED_VALUE) {\n\t\t\t\tawait getContentLength(httpReader, sendRequest, getRequestData);\n\t\t\t} else {\n\t\t\t\thttpReader.size = contentSize;\n\t\t\t}\n\t\t}\n\t} else {\n\t\tawait getContentLength(httpReader, sendRequest, getRequestData);\n\t}\n}\n\nasync function readUint8ArrayHttpReader(httpReader, index, length, sendRequest, getRequestData) {\n\tconst {\n\t\tuseRangeHeader,\n\t\tforceRangeRequests,\n\t\teocdCache,\n\t\tsize,\n\t\toptions\n\t} = httpReader;\n\tif (useRangeHeader || forceRangeRequests) {\n\t\tif (eocdCache && index == size - END_OF_CENTRAL_DIR_LENGTH && length == END_OF_CENTRAL_DIR_LENGTH) {\n\t\t\treturn eocdCache;\n\t\t}\n\t\tif (index >= size || length === 0) {\n\t\t\treturn new Uint8Array();\n\t\t} else {\n\t\t\tif (index + length > size) {\n\t\t\t\tlength = size - index;\n\t\t\t}\n\t\t\tconst response = await sendRequest(HTTP_METHOD_GET, httpReader, getRangeHeaders(httpReader, index, length));\n\t\t\tif (response.status != 206) {\n\t\t\t\tthrow new Error(ERR_HTTP_RANGE);\n\t\t\t}\n\t\t\treturn new Uint8Array(await response.arrayBuffer());\n\t\t}\n\t} else {\n\t\tconst { data } = httpReader;\n\t\tif (!data) {\n\t\t\tawait getRequestData(httpReader, options);\n\t\t}\n\t\treturn new Uint8Array(httpReader.data.subarray(index, index + length));\n\t}\n}\n\nfunction getRangeHeaders(httpReader, index = 0, length = 1) {\n\treturn Object.assign({}, getHeaders(httpReader), { [HTTP_HEADER_RANGE]: HTTP_RANGE_UNIT + \"=\" + (index < 0 ? index : index + \"-\" + (index + length - 1)) });\n}\n\nfunction getHeaders({ options }) {\n\tconst { headers } = options;\n\tif (headers) {\n\t\tif (Symbol.iterator in headers) {\n\t\t\treturn Object.fromEntries(headers);\n\t\t} else {\n\t\t\treturn headers;\n\t\t}\n\t}\n}\n\nasync function getFetchRequestData(httpReader) {\n\tawait getRequestData(httpReader, sendFetchRequest);\n}\n\nasync function getXMLHttpRequestData(httpReader) {\n\tawait getRequestData(httpReader, sendXMLHttpRequest);\n}\n\nasync function getRequestData(httpReader, sendRequest) {\n\tconst response = await sendRequest(HTTP_METHOD_GET, httpReader, getHeaders(httpReader));\n\thttpReader.data = new Uint8Array(await response.arrayBuffer());\n\tif (!httpReader.size) {\n\t\thttpReader.size = httpReader.data.length;\n\t}\n}\n\nasync function getContentLength(httpReader, sendRequest, getRequestData) {\n\tif (httpReader.preventHeadRequest) {\n\t\tawait getRequestData(httpReader, httpReader.options);\n\t} else {\n\t\tconst response = await sendRequest(HTTP_METHOD_HEAD, httpReader, getHeaders(httpReader));\n\t\tconst contentLength = response.headers.get(HTTP_HEADER_CONTENT_LENGTH);\n\t\tif (contentLength) {\n\t\t\thttpReader.size = Number(contentLength);\n\t\t} else {\n\t\t\tawait getRequestData(httpReader, httpReader.options);\n\t\t}\n\t}\n}\n\nasync function sendFetchRequest(method, { options, url }, headers) {\n\tconst response = await fetch(url, Object.assign({}, options, { method, headers }));\n\tif (response.status < 400) {\n\t\treturn response;\n\t} else {\n\t\tthrow response.status == 416 ? new Error(ERR_HTTP_RANGE) : new Error(ERR_HTTP_STATUS + (response.statusText || response.status));\n\t}\n}\n\nfunction sendXMLHttpRequest(method, { url }, headers) {\n\treturn new Promise((resolve, reject) => {\n\t\tconst request = new XMLHttpRequest();\n\t\trequest.addEventListener(\"load\", () => {\n\t\t\tif (request.status < 400) {\n\t\t\t\tconst headers = [];\n\t\t\t\trequest.getAllResponseHeaders().trim().split(/[\\r\\n]+/).forEach(header => {\n\t\t\t\t\tconst splitHeader = header.trim().split(/\\s*:\\s*/);\n\t\t\t\t\tsplitHeader[0] = splitHeader[0].trim().replace(/^[a-z]|-[a-z]/g, value => value.toUpperCase());\n\t\t\t\t\theaders.push(splitHeader);\n\t\t\t\t});\n\t\t\t\tresolve({\n\t\t\t\t\tstatus: request.status,\n\t\t\t\t\tarrayBuffer: () => request.response,\n\t\t\t\t\theaders: new Map(headers)\n\t\t\t\t});\n\t\t\t} else {\n\t\t\t\treject(request.status == 416 ? new Error(ERR_HTTP_RANGE) : new Error(ERR_HTTP_STATUS + (request.statusText || request.status)));\n\t\t\t}\n\t\t}, false);\n\t\trequest.addEventListener(\"error\", event => reject(event.detail ? event.detail.error : new Error(\"Network error\")), false);\n\t\trequest.open(method, url);\n\t\tif (headers) {\n\t\t\tfor (const entry of Object.entries(headers)) {\n\t\t\t\trequest.setRequestHeader(entry[0], entry[1]);\n\t\t\t}\n\t\t}\n\t\trequest.responseType = \"arraybuffer\";\n\t\trequest.send();\n\t});\n}\n\nclass HttpReader extends Reader {\n\n\tconstructor(url, options = {}) {\n\t\tsuper();\n\t\tObject.assign(this, {\n\t\t\turl,\n\t\t\treader: options.useXHR ? new XHRReader(url, options) : new FetchReader(url, options)\n\t\t});\n\t}\n\n\tset size(value) {\n\t\t// ignored\n\t}\n\n\tget size() {\n\t\treturn this.reader.size;\n\t}\n\n\tasync init() {\n\t\tawait this.reader.init();\n\t\tsuper.init();\n\t}\n\n\treadUint8Array(index, length) {\n\t\treturn this.reader.readUint8Array(index, length);\n\t}\n}\n\nclass HttpRangeReader extends HttpReader {\n\n\tconstructor(url, options = {}) {\n\t\toptions.useRangeHeader = true;\n\t\tsuper(url, options);\n\t}\n}\n\n\nclass Uint8ArrayReader extends Reader {\n\n\tconstructor(array) {\n\t\tsuper();\n\t\tarray = new Uint8Array(array.buffer, array.byteOffset, array.byteLength);\n\t\tObject.assign(this, {\n\t\t\tarray,\n\t\t\tsize: array.length\n\t\t});\n\t}\n\n\treadUint8Array(index, length) {\n\t\treturn this.array.slice(index, index + length);\n\t}\n}\n\nclass Uint8ArrayWriter extends Writer {\n\n\tconstructor(defaultBufferSize) {\n\t\tsuper();\n\t\tthis.defaultBufferSize = defaultBufferSize || DEFAULT_BUFFER_SIZE;\n\t}\n\n\tinit(initSize = 0) {\n\t\tObject.assign(this, {\n\t\t\toffset: 0,\n\t\t\tarray: new Uint8Array(initSize > 0 ? initSize : this.defaultBufferSize)\n\t\t});\n\t\tsuper.init();\n\t}\n\n\twriteUint8Array(array) {\n\t\tconst writer = this;\n\t\tconst requiredLength = writer.offset + array.length;\n\t\tif (requiredLength > writer.array.length) {\n\t\t\tlet newLength = writer.array.length ? writer.array.length * 2 : writer.defaultBufferSize;\n\t\t\twhile (newLength < requiredLength) {\n\t\t\t\tnewLength *= 2;\n\t\t\t}\n\t\t\tconst previousArray = writer.array;\n\t\t\twriter.array = new Uint8Array(newLength);\n\t\t\twriter.array.set(previousArray);\n\t\t}\n\t\twriter.array.set(array, writer.offset);\n\t\twriter.offset += array.length;\n\t}\n\n\tgetData() {\n\t\tif (this.offset === this.array.length) {\n\t\t\treturn this.array;\n\t\t} else {\n\t\t\treturn this.array.slice(0, this.offset);\n\t\t}\n\t}\n}\n\nclass SplitDataReader extends Reader {\n\n\tconstructor(readers) {\n\t\tsuper();\n\t\tthis.readers = readers;\n\t}\n\n\tasync init() {\n\t\tconst reader = this;\n\t\tconst { readers } = reader;\n\t\treader.lastDiskNumber = 0;\n\t\treader.lastDiskOffset = 0;\n\t\tawait Promise.all(readers.map(async (diskReader, indexDiskReader) => {\n\t\t\tawait diskReader.init();\n\t\t\tif (indexDiskReader != readers.length - 1) {\n\t\t\t\treader.lastDiskOffset += diskReader.size;\n\t\t\t}\n\t\t\treader.size += diskReader.size;\n\t\t}));\n\t\tsuper.init();\n\t}\n\n\tasync readUint8Array(offset, length, diskNumber = 0) {\n\t\tconst reader = this;\n\t\tconst { readers } = this;\n\t\tlet result;\n\t\tlet currentDiskNumber = diskNumber;\n\t\tif (currentDiskNumber == -1) {\n\t\t\tcurrentDiskNumber = readers.length - 1;\n\t\t}\n\t\tlet currentReaderOffset = offset;\n\t\twhile (readers[currentDiskNumber] && currentReaderOffset >= readers[currentDiskNumber].size) {\n\t\t\tcurrentReaderOffset -= readers[currentDiskNumber].size;\n\t\t\tcurrentDiskNumber++;\n\t\t}\n\t\tconst currentReader = readers[currentDiskNumber];\n\t\tif (currentReader) {\n\t\t\tconst currentReaderSize = currentReader.size;\n\t\t\tif (currentReaderOffset + length <= currentReaderSize) {\n\t\t\t\tresult = await readUint8Array(currentReader, currentReaderOffset, length);\n\t\t\t} else {\n\t\t\t\tconst chunkLength = currentReaderSize - currentReaderOffset;\n\t\t\t\tresult = new Uint8Array(length);\n\t\t\t\tconst firstPart = await readUint8Array(currentReader, currentReaderOffset, chunkLength);\n\t\t\t\tresult.set(firstPart, 0);\n\t\t\t\tconst secondPart = await reader.readUint8Array(offset + chunkLength, length - chunkLength, diskNumber);\n\t\t\t\tresult.set(secondPart, chunkLength);\n\t\t\t\tif (firstPart.length + secondPart.length < length) {\n\t\t\t\t\tresult = result.subarray(0, firstPart.length + secondPart.length);\n\t\t\t\t}\n\t\t\t}\n\t\t} else {\n\t\t\tresult = new Uint8Array();\n\t\t}\n\t\treader.lastDiskNumber = Math.max(currentDiskNumber, reader.lastDiskNumber);\n\t\treturn result;\n\t}\n}\n\nclass SplitDataWriter extends Stream {\n\n\tconstructor(writerGenerator, maxSize = 4294967295) {\n\t\tsuper();\n\t\tconst writer = this;\n\t\tObject.assign(writer, {\n\t\t\tdiskNumber: 0,\n\t\t\tdiskOffset: 0,\n\t\t\tsize: 0,\n\t\t\tmaxSize,\n\t\t\tavailableSize: maxSize\n\t\t});\n\t\tlet diskSourceWriter, diskWritable, diskWriter;\n\t\tconst writable = new WritableStream({\n\t\t\tasync write(chunk) {\n\t\t\t\tconst { availableSize } = writer;\n\t\t\t\tif (!diskWriter) {\n\t\t\t\t\tconst { value, done } = await writerGenerator.next();\n\t\t\t\t\tif (done && !value) {\n\t\t\t\t\t\tthrow new Error(ERR_ITERATOR_COMPLETED_TOO_SOON);\n\t\t\t\t\t} else {\n\t\t\t\t\t\tdiskSourceWriter = value;\n\t\t\t\t\t\tdiskSourceWriter.size = 0;\n\t\t\t\t\t\tif (diskSourceWriter.maxSize) {\n\t\t\t\t\t\t\twriter.maxSize = diskSourceWriter.maxSize;\n\t\t\t\t\t\t}\n\t\t\t\t\t\twriter.availableSize = writer.maxSize;\n\t\t\t\t\t\tawait initStream(diskSourceWriter);\n\t\t\t\t\t\tdiskWritable = value.writable;\n\t\t\t\t\t\tdiskWriter = diskWritable.getWriter();\n\t\t\t\t\t}\n\t\t\t\t\tawait this.write(chunk);\n\t\t\t\t} else if (chunk.length >= availableSize) {\n\t\t\t\t\tawait writeChunk(chunk.subarray(0, availableSize));\n\t\t\t\t\tawait closeDisk();\n\t\t\t\t\twriter.diskOffset += diskSourceWriter.size;\n\t\t\t\t\twriter.diskNumber++;\n\t\t\t\t\tdiskWriter = null;\n\t\t\t\t\tawait this.write(chunk.subarray(availableSize));\n\t\t\t\t} else {\n\t\t\t\t\tawait writeChunk(chunk);\n\t\t\t\t}\n\t\t\t},\n\t\t\tasync close() {\n\t\t\t\tawait diskWriter.ready;\n\t\t\t\tawait closeDisk();\n\t\t\t}\n\t\t});\n\t\tObject.defineProperty(writer, PROPERTY_NAME_WRITABLE, {\n\t\t\tget() {\n\t\t\t\treturn writable;\n\t\t\t}\n\t\t});\n\n\t\tasync function writeChunk(chunk) {\n\t\t\tconst chunkLength = chunk.length;\n\t\t\tif (chunkLength) {\n\t\t\t\tawait diskWriter.ready;\n\t\t\t\tawait diskWriter.write(chunk);\n\t\t\t\tdiskSourceWriter.size += chunkLength;\n\t\t\t\twriter.size += chunkLength;\n\t\t\t\twriter.availableSize -= chunkLength;\n\t\t\t}\n\t\t}\n\n\t\tasync function closeDisk() {\n\t\t\tawait diskWriter.close();\n\t\t}\n\t}\n}\n\nclass GenericReader {\n\n\tconstructor(reader) {\n\t\tif (Array.isArray(reader)) {\n\t\t\treader = new SplitDataReader(reader);\n\t\t}\n\t\tif (reader instanceof ReadableStream) {\n\t\t\treader = {\n\t\t\t\treadable: reader\n\t\t\t};\n\t\t}\n\t\treturn reader;\n\t}\n}\n\nclass GenericWriter {\n\n\tconstructor(writer) {\n\t\tif (writer.writable === UNDEFINED_VALUE && typeof writer.next == FUNCTION_TYPE) {\n\t\t\twriter = new SplitDataWriter(writer);\n\t\t}\n\t\tif (writer instanceof WritableStream) {\n\t\t\twriter = {\n\t\t\t\twritable: writer\n\t\t\t};\n\t\t}\n\t\tif (writer.size === UNDEFINED_VALUE) {\n\t\t\twriter.size = 0;\n\t\t}\n\t\tif (!(writer instanceof SplitDataWriter)) {\n\t\t\tObject.assign(writer, {\n\t\t\t\tdiskNumber: 0,\n\t\t\t\tdiskOffset: 0,\n\t\t\t\tavailableSize: INFINITY_VALUE,\n\t\t\t\tmaxSize: INFINITY_VALUE\n\t\t\t});\n\t\t}\n\t\treturn writer;\n\t}\n}\n\nfunction isHttpFamily(url) {\n\tconst { baseURI } = getConfiguration();\n\tconst { protocol } = new URL(url, baseURI);\n\treturn protocol == \"http:\" || protocol == \"https:\";\n}\n\nasync function initStream(stream, initSize) {\n\tif (stream.init && !stream.initialized) {\n\t\tawait stream.init(initSize);\n\t} else {\n\t\treturn Promise.resolve();\n\t}\n}\n\nfunction readUint8Array(reader, offset, size, diskNumber) {\n\treturn reader.readUint8Array(offset, size, diskNumber);\n}\n\nexport {\n\tinitStream,\n\tGenericReader,\n\tGenericWriter,\n\treadUint8Array,\n\tReader,\n\tWriter,\n\tTextReader,\n\tTextWriter,\n\tData64URIReader,\n\tData64URIWriter,\n\tBlobReader,\n\tBlobWriter,\n\tUint8ArrayReader,\n\tUint8ArrayWriter,\n\tHttpReader,\n\tHttpRangeReader,\n\tSplitDataReader,\n\tSplitDataWriter,\n\tERR_HTTP_RANGE,\n\tERR_ITERATOR_COMPLETED_TOO_SOON,\n\tERR_WRITER_NOT_INITIALIZED\n};","/*\n Copyright (c) 2022 Gildas Lormeau. All rights reserved.\n\n Redistribution and use in source and binary forms, with or without\n modification, are permitted provided that the following conditions are met:\n\n 1. Redistributions of source code must retain the above copyright notice,\n this list of conditions and the following disclaimer.\n\n 2. Redistributions in binary form must reproduce the above copyright \n notice, this list of conditions and the following disclaimer in \n the documentation and/or other materials provided with the distribution.\n\n 3. The names of the authors may not be used to endorse or promote products\n derived from this software without specific prior written permission.\n\n THIS SOFTWARE IS PROVIDED ''AS IS'' AND ANY EXPRESSED OR IMPLIED WARRANTIES,\n INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND\n FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL JCRAFT,\n INC. OR ANY CONTRIBUTORS TO THIS SOFTWARE BE LIABLE FOR ANY DIRECT, INDIRECT,\n INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT\n LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA,\n OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF\n LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING\n NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE,\n EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.\n */\n\n/* global TextDecoder */\n\nconst CP437 = \"\\0☺☻♥♦♣♠•◘○◙♂♀♪♫☼►◄↕‼¶§▬↨↑↓→←∟↔▲▼ !\\\"#$%&'()*+,-./0123456789:;<=>?@ABCDEFGHIJKLMNOPQRSTUVWXYZ[\\\\]^_`abcdefghijklmnopqrstuvwxyz{|}~⌂ÇüéâäàåçêëèïîìÄÅÉæÆôöòûùÿÖÜ¢£¥₧ƒáíóúñѪº¿⌐¬½¼¡«»░▒▓│┤╡╢╖╕╣║╗╝╜╛┐└┴┬├─┼╞╟╚╔╩╦╠═╬╧╨╤╥╙╘╒╓╫╪┘┌█▄▌▐▀αßΓπΣσµτΦΘΩδ∞φε∩≡±≥≤⌠⌡÷≈°∙·√ⁿ²■ \".split(\"\");\nconst VALID_CP437 = CP437.length == 256;\n\nexport {\n\tdecodeCP437\n};\n\nfunction decodeCP437(stringValue) {\n\tif (VALID_CP437) {\n\t\tlet result = \"\";\n\t\tfor (let indexCharacter = 0; indexCharacter < stringValue.length; indexCharacter++) {\n\t\t\tresult += CP437[stringValue[indexCharacter]];\n\t\t}\n\t\treturn result;\n\t} else {\n\t\treturn new TextDecoder().decode(stringValue);\n\t}\n}","/*\n Copyright (c) 2022 Gildas Lormeau. All rights reserved.\n\n Redistribution and use in source and binary forms, with or without\n modification, are permitted provided that the following conditions are met:\n\n 1. Redistributions of source code must retain the above copyright notice,\n this list of conditions and the following disclaimer.\n\n 2. Redistributions in binary form must reproduce the above copyright \n notice, this list of conditions and the following disclaimer in \n the documentation and/or other materials provided with the distribution.\n\n 3. The names of the authors may not be used to endorse or promote products\n derived from this software without specific prior written permission.\n\n THIS SOFTWARE IS PROVIDED ''AS IS'' AND ANY EXPRESSED OR IMPLIED WARRANTIES,\n INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND\n FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL JCRAFT,\n INC. OR ANY CONTRIBUTORS TO THIS SOFTWARE BE LIABLE FOR ANY DIRECT, INDIRECT,\n INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT\n LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA,\n OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF\n LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING\n NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE,\n EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.\n */\n\n/* global TextDecoder */\n\nimport { decodeCP437 } from \"./decode-cp437.js\";\n\nexport {\n\tdecodeText\n};\n\nfunction decodeText(value, encoding) {\n\tif (encoding && encoding.trim().toLowerCase() == \"cp437\") {\n\t\treturn decodeCP437(value);\n\t} else {\n\t\treturn new TextDecoder(encoding).decode(value);\n\t}\n}","/*\n Copyright (c) 2025 Gildas Lormeau. All rights reserved.\n\n Redistribution and use in source and binary forms, with or without\n modification, are permitted provided that the following conditions are met:\n\n 1. Redistributions of source code must retain the above copyright notice,\n this list of conditions and the following disclaimer.\n\n 2. Redistributions in binary form must reproduce the above copyright \n notice, this list of conditions and the following disclaimer in \n the documentation and/or other materials provided with the distribution.\n\n 3. The names of the authors may not be used to endorse or promote products\n derived from this software without specific prior written permission.\n\n THIS SOFTWARE IS PROVIDED ''AS IS'' AND ANY EXPRESSED OR IMPLIED WARRANTIES,\n INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND\n FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL JCRAFT,\n INC. OR ANY CONTRIBUTORS TO THIS SOFTWARE BE LIABLE FOR ANY DIRECT, INDIRECT,\n INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT\n LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA,\n OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF\n LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING\n NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE,\n EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.\n */\n\nconst PROPERTY_NAME_FILENAME = \"filename\";\nconst PROPERTY_NAME_RAW_FILENAME = \"rawFilename\";\nconst PROPERTY_NAME_COMMENT = \"comment\";\nconst PROPERTY_NAME_RAW_COMMENT = \"rawComment\";\nconst PROPERTY_NAME_UNCOMPRESSED_SIZE = \"uncompressedSize\";\nconst PROPERTY_NAME_COMPRESSED_SIZE = \"compressedSize\";\nconst PROPERTY_NAME_OFFSET = \"offset\";\nconst PROPERTY_NAME_DISK_NUMBER_START = \"diskNumberStart\";\nconst PROPERTY_NAME_LAST_MODIFICATION_DATE = \"lastModDate\";\nconst PROPERTY_NAME_RAW_LAST_MODIFICATION_DATE = \"rawLastModDate\";\nconst PROPERTY_NAME_LAST_ACCESS_DATE = \"lastAccessDate\";\nconst PROPERTY_NAME_RAW_LAST_ACCESS_DATE = \"rawLastAccessDate\";\nconst PROPERTY_NAME_CREATION_DATE = \"creationDate\";\nconst PROPERTY_NAME_RAW_CREATION_DATE = \"rawCreationDate\";\nconst PROPERTY_NAME_INTERNAL_FILE_ATTRIBUTES = \"internalFileAttributes\";\nconst PROPERTY_NAME_EXTERNAL_FILE_ATTRIBUTES = \"externalFileAttributes\";\nconst PROPERTY_NAME_MSDOS_ATTRIBUTES_RAW = \"msdosAttributesRaw\";\nconst PROPERTY_NAME_MSDOS_ATTRIBUTES = \"msdosAttributes\";\nconst PROPERTY_NAME_MS_DOS_COMPATIBLE = \"msDosCompatible\";\nconst PROPERTY_NAME_ZIP64 = \"zip64\";\nconst PROPERTY_NAME_ENCRYPTED = \"encrypted\";\nconst PROPERTY_NAME_VERSION = \"version\";\nconst PROPERTY_NAME_VERSION_MADE_BY = \"versionMadeBy\";\nconst PROPERTY_NAME_ZIPCRYPTO = \"zipCrypto\";\nconst PROPERTY_NAME_DIRECTORY = \"directory\";\nconst PROPERTY_NAME_EXECUTABLE = \"executable\";\nconst PROPERTY_NAME_COMPRESSION_METHOD = \"compressionMethod\";\nconst PROPERTY_NAME_SIGNATURE = \"signature\";\nconst PROPERTY_NAME_EXTRA_FIELD = \"extraField\";\nconst PROPERTY_NAME_EXTRA_FIELD_INFOZIP = \"extraFieldInfoZip\";\nconst PROPERTY_NAME_EXTRA_FIELD_UNIX = \"extraFieldUnix\";\nconst PROPERTY_NAME_UID = \"uid\";\nconst PROPERTY_NAME_GID = \"gid\";\nconst PROPERTY_NAME_UNIX_MODE = \"unixMode\";\nconst PROPERTY_NAME_SETUID = \"setuid\";\nconst PROPERTY_NAME_SETGID = \"setgid\";\nconst PROPERTY_NAME_STICKY = \"sticky\";\nconst PROPERTY_NAME_BITFLAG = \"bitFlag\";\nconst PROPERTY_NAME_FILENAME_UTF8 = \"filenameUTF8\";\nconst PROPERTY_NAME_COMMENT_UTF8 = \"commentUTF8\";\nconst PROPERTY_NAME_RAW_EXTRA_FIELD = \"rawExtraField\";\nconst PROPERTY_NAME_EXTRA_FIELD_ZIP64 = \"extraFieldZip64\";\nconst PROPERTY_NAME_EXTRA_FIELD_UNICODE_PATH = \"extraFieldUnicodePath\";\nconst PROPERTY_NAME_EXTRA_FIELD_UNICODE_COMMENT = \"extraFieldUnicodeComment\";\nconst PROPERTY_NAME_EXTRA_FIELD_AES = \"extraFieldAES\";\nconst PROPERTY_NAME_EXTRA_FIELD_NTFS = \"extraFieldNTFS\";\nconst PROPERTY_NAME_EXTRA_FIELD_EXTENDED_TIMESTAMP = \"extraFieldExtendedTimestamp\";\n\nconst PROPERTY_NAMES = [\n\tPROPERTY_NAME_FILENAME,\n\tPROPERTY_NAME_RAW_FILENAME,\n\tPROPERTY_NAME_UNCOMPRESSED_SIZE,\n\tPROPERTY_NAME_COMPRESSED_SIZE,\n\tPROPERTY_NAME_LAST_MODIFICATION_DATE,\n\tPROPERTY_NAME_RAW_LAST_MODIFICATION_DATE,\n\tPROPERTY_NAME_COMMENT,\n\tPROPERTY_NAME_RAW_COMMENT,\n\tPROPERTY_NAME_LAST_ACCESS_DATE,\n\tPROPERTY_NAME_CREATION_DATE,\n\tPROPERTY_NAME_RAW_CREATION_DATE,\n\tPROPERTY_NAME_OFFSET,\n\tPROPERTY_NAME_DISK_NUMBER_START,\n\tPROPERTY_NAME_INTERNAL_FILE_ATTRIBUTES,\n\tPROPERTY_NAME_EXTERNAL_FILE_ATTRIBUTES,\n\tPROPERTY_NAME_MSDOS_ATTRIBUTES_RAW,\n\tPROPERTY_NAME_MSDOS_ATTRIBUTES,\n\tPROPERTY_NAME_MS_DOS_COMPATIBLE,\n\tPROPERTY_NAME_ZIP64,\n\tPROPERTY_NAME_ENCRYPTED,\n\tPROPERTY_NAME_VERSION,\n\tPROPERTY_NAME_VERSION_MADE_BY,\n\tPROPERTY_NAME_ZIPCRYPTO,\n\tPROPERTY_NAME_DIRECTORY,\n\tPROPERTY_NAME_EXECUTABLE,\n\tPROPERTY_NAME_COMPRESSION_METHOD,\n\tPROPERTY_NAME_SIGNATURE,\n\tPROPERTY_NAME_EXTRA_FIELD,\n\tPROPERTY_NAME_EXTRA_FIELD_UNIX,\n\tPROPERTY_NAME_EXTRA_FIELD_INFOZIP,\n\tPROPERTY_NAME_UID,\n\tPROPERTY_NAME_GID,\n\tPROPERTY_NAME_UNIX_MODE,\n\tPROPERTY_NAME_SETUID,\n\tPROPERTY_NAME_SETGID,\n\tPROPERTY_NAME_STICKY,\n\tPROPERTY_NAME_BITFLAG,\n\tPROPERTY_NAME_FILENAME_UTF8,\n\tPROPERTY_NAME_COMMENT_UTF8,\n\tPROPERTY_NAME_RAW_EXTRA_FIELD,\n\tPROPERTY_NAME_EXTRA_FIELD_ZIP64,\n\tPROPERTY_NAME_EXTRA_FIELD_UNICODE_PATH,\n\tPROPERTY_NAME_EXTRA_FIELD_UNICODE_COMMENT,\n\tPROPERTY_NAME_EXTRA_FIELD_AES,\n\tPROPERTY_NAME_EXTRA_FIELD_NTFS,\n\tPROPERTY_NAME_EXTRA_FIELD_EXTENDED_TIMESTAMP\n];\n\nclass Entry {\n\n\tconstructor(data) {\n\t\tPROPERTY_NAMES.forEach(name => this[name] = data[name]);\n\t}\n\n}\n\nexport {\n\tPROPERTY_NAME_FILENAME,\n\tPROPERTY_NAME_RAW_FILENAME,\n\tPROPERTY_NAME_COMMENT,\n\tPROPERTY_NAME_RAW_COMMENT,\n\tPROPERTY_NAME_UNCOMPRESSED_SIZE,\n\tPROPERTY_NAME_COMPRESSED_SIZE,\n\tPROPERTY_NAME_OFFSET,\n\tPROPERTY_NAME_DISK_NUMBER_START,\n\tPROPERTY_NAME_LAST_MODIFICATION_DATE,\n\tPROPERTY_NAME_RAW_LAST_MODIFICATION_DATE,\n\tPROPERTY_NAME_LAST_ACCESS_DATE,\n\tPROPERTY_NAME_RAW_LAST_ACCESS_DATE,\n\tPROPERTY_NAME_CREATION_DATE,\n\tPROPERTY_NAME_RAW_CREATION_DATE,\n\tPROPERTY_NAME_INTERNAL_FILE_ATTRIBUTES,\n\tPROPERTY_NAME_EXTERNAL_FILE_ATTRIBUTES,\n\tPROPERTY_NAME_MSDOS_ATTRIBUTES_RAW,\n\tPROPERTY_NAME_MSDOS_ATTRIBUTES,\n\tPROPERTY_NAME_MS_DOS_COMPATIBLE,\n\tPROPERTY_NAME_ZIP64,\n\tPROPERTY_NAME_ENCRYPTED,\n\tPROPERTY_NAME_VERSION,\n\tPROPERTY_NAME_VERSION_MADE_BY,\n\tPROPERTY_NAME_ZIPCRYPTO,\n\tPROPERTY_NAME_DIRECTORY,\n\tPROPERTY_NAME_EXECUTABLE,\n\tPROPERTY_NAME_COMPRESSION_METHOD,\n\tPROPERTY_NAME_SIGNATURE,\n\tPROPERTY_NAME_EXTRA_FIELD,\n\tPROPERTY_NAME_GID,\n\tPROPERTY_NAME_UID,\n\tPROPERTY_NAME_UNIX_MODE,\n\tPROPERTY_NAME_SETUID,\n\tPROPERTY_NAME_SETGID,\n\tPROPERTY_NAME_STICKY,\n\tEntry\n};","/*\n Copyright (c) 2022 Gildas Lormeau. All rights reserved.\n\n Redistribution and use in source and binary forms, with or without\n modification, are permitted provided that the following conditions are met:\n\n 1. Redistributions of source code must retain the above copyright notice,\n this list of conditions and the following disclaimer.\n\n 2. Redistributions in binary form must reproduce the above copyright \n notice, this list of conditions and the following disclaimer in \n the documentation and/or other materials provided with the distribution.\n\n 3. The names of the authors may not be used to endorse or promote products\n derived from this software without specific prior written permission.\n\n THIS SOFTWARE IS PROVIDED ''AS IS'' AND ANY EXPRESSED OR IMPLIED WARRANTIES,\n INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND\n FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL JCRAFT,\n INC. OR ANY CONTRIBUTORS TO THIS SOFTWARE BE LIABLE FOR ANY DIRECT, INDIRECT,\n INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT\n LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA,\n OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF\n LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING\n NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE,\n EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.\n */\n\nconst OPTION_FILENAME_ENCODING = \"filenameEncoding\";\nconst OPTION_COMMENT_ENCODING = \"commentEncoding\";\nconst OPTION_DECODE_TEXT = \"decodeText\";\nconst OPTION_EXTRACT_PREPENDED_DATA = \"extractPrependedData\";\nconst OPTION_EXTRACT_APPENDED_DATA = \"extractAppendedData\";\nconst OPTION_PASSWORD = \"password\";\nconst OPTION_RAW_PASSWORD = \"rawPassword\";\nconst OPTION_PASS_THROUGH = \"passThrough\";\nconst OPTION_SIGNAL = \"signal\";\nconst OPTION_CHECK_PASSWORD_ONLY = \"checkPasswordOnly\";\nconst OPTION_CHECK_OVERLAPPING_ENTRY_ONLY = \"checkOverlappingEntryOnly\";\nconst OPTION_CHECK_OVERLAPPING_ENTRY = \"checkOverlappingEntry\";\nconst OPTION_CHECK_SIGNATURE = \"checkSignature\";\nconst OPTION_USE_WEB_WORKERS = \"useWebWorkers\";\nconst OPTION_USE_COMPRESSION_STREAM = \"useCompressionStream\";\nconst OPTION_TRANSFER_STREAMS = \"transferStreams\";\nconst OPTION_PREVENT_CLOSE = \"preventClose\";\nconst OPTION_ENCRYPTION_STRENGTH = \"encryptionStrength\";\nconst OPTION_EXTENDED_TIMESTAMP = \"extendedTimestamp\";\nconst OPTION_KEEP_ORDER = \"keepOrder\";\nconst OPTION_LEVEL = \"level\";\nconst OPTION_BUFFERED_WRITE = \"bufferedWrite\";\nconst OPTION_CREATE_TEMP_STREAM = \"createTempStream\";\nconst OPTION_DATA_DESCRIPTOR_SIGNATURE = \"dataDescriptorSignature\";\nconst OPTION_USE_UNICODE_FILE_NAMES = \"useUnicodeFileNames\";\nconst OPTION_DATA_DESCRIPTOR = \"dataDescriptor\";\nconst OPTION_SUPPORT_ZIP64_SPLIT_FILE = \"supportZip64SplitFile\";\nconst OPTION_ENCODE_TEXT = \"encodeText\";\nconst OPTION_OFFSET = \"offset\";\nconst OPTION_USDZ = \"usdz\";\nconst OPTION_UNIX_EXTRA_FIELD_TYPE = \"unixExtraFieldType\";\n\nexport {\n\tOPTION_FILENAME_ENCODING,\n\tOPTION_COMMENT_ENCODING,\n\tOPTION_DECODE_TEXT,\n\tOPTION_EXTRACT_PREPENDED_DATA,\n\tOPTION_EXTRACT_APPENDED_DATA,\n\tOPTION_PASSWORD,\n\tOPTION_RAW_PASSWORD,\n\tOPTION_PASS_THROUGH,\n\tOPTION_SIGNAL,\n\tOPTION_CHECK_PASSWORD_ONLY,\n\tOPTION_CHECK_OVERLAPPING_ENTRY_ONLY,\n\tOPTION_CHECK_OVERLAPPING_ENTRY,\n\tOPTION_CHECK_SIGNATURE,\n\tOPTION_USE_WEB_WORKERS,\n\tOPTION_USE_COMPRESSION_STREAM,\n\tOPTION_TRANSFER_STREAMS,\n\tOPTION_PREVENT_CLOSE,\n\tOPTION_ENCRYPTION_STRENGTH,\n\tOPTION_EXTENDED_TIMESTAMP,\n\tOPTION_KEEP_ORDER,\n\tOPTION_LEVEL,\n\tOPTION_BUFFERED_WRITE,\n\tOPTION_CREATE_TEMP_STREAM,\n\tOPTION_DATA_DESCRIPTOR_SIGNATURE,\n\tOPTION_USE_UNICODE_FILE_NAMES,\n\tOPTION_DATA_DESCRIPTOR,\n\tOPTION_SUPPORT_ZIP64_SPLIT_FILE,\n\tOPTION_ENCODE_TEXT,\n\tOPTION_OFFSET,\n\tOPTION_USDZ,\n\tOPTION_UNIX_EXTRA_FIELD_TYPE\n};","/*\n Copyright (c) 2025 Gildas Lormeau. All rights reserved.\n\n Redistribution and use in source and binary forms, with or without\n modification, are permitted provided that the following conditions are met:\n\n 1. Redistributions of source code must retain the above copyright notice,\n this list of conditions and the following disclaimer.\n\n 2. Redistributions in binary form must reproduce the above copyright\n notice, this list of conditions and the following disclaimer in\n the documentation and/or other materials provided with the distribution.\n\n 3. The names of the authors may not be used to endorse or promote products\n derived from this software without specific prior written permission.\n\n THIS SOFTWARE IS PROVIDED ''AS IS'' AND ANY EXPRESSED OR IMPLIED WARRANTIES,\n INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND\n FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL JCRAFT,\n INC. OR ANY CONTRIBUTORS TO THIS SOFTWARE BE LIABLE FOR ANY DIRECT, INDIRECT,\n INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT\n LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA,\n OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF\n LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING\n NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE,\n EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.\n */\n\n/* global Response, WritableStream, ReadableStream, TransformStream */\n// deno-lint-ignore-file no-this-alias\n\nimport {\n\tMAX_32_BITS,\n\tMAX_16_BITS,\n\tMAX_8_BITS,\n\tCOMPRESSION_METHOD_DEFLATE,\n\tCOMPRESSION_METHOD_STORE,\n\tCOMPRESSION_METHOD_AES,\n\tSPLIT_ZIP_FILE_SIGNATURE,\n\tDATA_DESCRIPTOR_RECORD_SIGNATURE,\n\tDATA_DESCRIPTOR_RECORD_LENGTH,\n\tDATA_DESCRIPTOR_RECORD_ZIP_64_LENGTH,\n\tDATA_DESCRIPTOR_RECORD_SIGNATURE_LENGTH,\n\tLOCAL_FILE_HEADER_SIGNATURE,\n\tCENTRAL_FILE_HEADER_SIGNATURE,\n\tEND_OF_CENTRAL_DIR_SIGNATURE,\n\tZIP64_END_OF_CENTRAL_DIR_LOCATOR_SIGNATURE,\n\tZIP64_END_OF_CENTRAL_DIR_SIGNATURE,\n\tEXTRAFIELD_TYPE_ZIP64,\n\tEXTRAFIELD_TYPE_UNICODE_PATH,\n\tEXTRAFIELD_TYPE_UNICODE_COMMENT,\n\tEXTRAFIELD_TYPE_AES,\n\tEXTRAFIELD_TYPE_NTFS,\n\tEXTRAFIELD_TYPE_NTFS_TAG1,\n\tEXTRAFIELD_TYPE_EXTENDED_TIMESTAMP,\n\tEXTRAFIELD_TYPE_INFOZIP,\n\tEXTRAFIELD_TYPE_UNIX,\n\tEXTRAFIELD_TYPE_USDZ,\n\tEND_OF_CENTRAL_DIR_LENGTH,\n\tZIP64_END_OF_CENTRAL_DIR_LOCATOR_LENGTH,\n\tZIP64_END_OF_CENTRAL_DIR_LENGTH,\n\tBITFLAG_ENCRYPTED,\n\tBITFLAG_LEVEL,\n\tBITFLAG_DATA_DESCRIPTOR,\n\tBITFLAG_LANG_ENCODING_FLAG,\n\tFILE_ATTR_MSDOS_DIR_MASK,\n\tFILE_ATTR_MSDOS_READONLY_MASK,\n\tFILE_ATTR_MSDOS_HIDDEN_MASK,\n\tFILE_ATTR_MSDOS_SYSTEM_MASK,\n\tFILE_ATTR_MSDOS_ARCHIVE_MASK,\n\tFILE_ATTR_UNIX_TYPE_MASK,\n\tFILE_ATTR_UNIX_TYPE_DIR,\n\tFILE_ATTR_UNIX_EXECUTABLE_MASK,\n\tFILE_ATTR_UNIX_DEFAULT_MASK,\n\tDIRECTORY_SIGNATURE,\n\tHEADER_SIZE,\n\tHEADER_OFFSET_SIGNATURE,\n\tHEADER_OFFSET_COMPRESSED_SIZE,\n\tHEADER_OFFSET_UNCOMPRESSED_SIZE,\n\tUNDEFINED_VALUE,\n\tCOMPRESSION_METHOD_DEFLATE_64,\n\tFILE_ATTR_UNIX_SETUID_MASK,\n\tFILE_ATTR_UNIX_SETGID_MASK,\n\tFILE_ATTR_UNIX_STICKY_MASK\n} from \"./constants.js\";\nimport {\n\tgetConfiguration,\n\tgetChunkSize\n} from \"./configuration.js\";\nimport {\n\trunWorker,\n\tCODEC_INFLATE,\n\tERR_INVALID_SIGNATURE,\n\tERR_INVALID_PASSWORD,\n\tERR_INVALID_UNCOMPRESSED_SIZE,\n\tERR_ABORT_CHECK_PASSWORD\n} from \"./codec-pool.js\";\nimport {\n\tinitStream,\n\treadUint8Array,\n\tBlobReader,\n\tGenericReader,\n\tGenericWriter\n} from \"./io.js\";\nimport { decodeText } from \"./util/decode-text.js\";\nimport { Crc32 } from \"./streams/codecs/crc32.js\";\nimport {\n\tPROPERTY_NAME_RAW_FILENAME,\n\tPROPERTY_NAME_FILENAME,\n\tPROPERTY_NAME_RAW_COMMENT,\n\tPROPERTY_NAME_COMMENT,\n\tPROPERTY_NAME_UNCOMPRESSED_SIZE,\n\tPROPERTY_NAME_COMPRESSED_SIZE,\n\tPROPERTY_NAME_OFFSET,\n\tPROPERTY_NAME_DISK_NUMBER_START,\n\tPROPERTY_NAME_LAST_MODIFICATION_DATE,\n\tPROPERTY_NAME_RAW_LAST_MODIFICATION_DATE,\n\tPROPERTY_NAME_LAST_ACCESS_DATE,\n\tPROPERTY_NAME_RAW_LAST_ACCESS_DATE,\n\tPROPERTY_NAME_CREATION_DATE,\n\tPROPERTY_NAME_RAW_CREATION_DATE,\n\tEntry\n} from \"./zip-entry.js\";\nimport {\n\tOPTION_FILENAME_ENCODING,\n\tOPTION_COMMENT_ENCODING,\n\tOPTION_DECODE_TEXT,\n\tOPTION_EXTRACT_PREPENDED_DATA,\n\tOPTION_EXTRACT_APPENDED_DATA,\n\tOPTION_PASSWORD,\n\tOPTION_RAW_PASSWORD,\n\tOPTION_PASS_THROUGH,\n\tOPTION_SIGNAL,\n\tOPTION_CHECK_PASSWORD_ONLY,\n\tOPTION_CHECK_OVERLAPPING_ENTRY_ONLY,\n\tOPTION_CHECK_OVERLAPPING_ENTRY,\n\tOPTION_CHECK_SIGNATURE,\n\tOPTION_USE_WEB_WORKERS,\n\tOPTION_USE_COMPRESSION_STREAM,\n\tOPTION_TRANSFER_STREAMS,\n\tOPTION_PREVENT_CLOSE\n} from \"./options.js\";\n\nconst ERR_BAD_FORMAT = \"File format is not recognized\";\nconst ERR_EOCDR_NOT_FOUND = \"End of central directory not found\";\nconst ERR_EOCDR_LOCATOR_ZIP64_NOT_FOUND = \"End of Zip64 central directory locator not found\";\nconst ERR_CENTRAL_DIRECTORY_NOT_FOUND = \"Central directory header not found\";\nconst ERR_LOCAL_FILE_HEADER_NOT_FOUND = \"Local file header not found\";\nconst ERR_EXTRAFIELD_ZIP64_NOT_FOUND = \"Zip64 extra field not found\";\nconst ERR_ENCRYPTED = \"File contains encrypted entry\";\nconst ERR_UNSUPPORTED_ENCRYPTION = \"Encryption method not supported\";\nconst ERR_UNSUPPORTED_COMPRESSION = \"Compression method not supported\";\nconst ERR_SPLIT_ZIP_FILE = \"Split zip file\";\nconst ERR_OVERLAPPING_ENTRY = \"Overlapping entry found\";\nconst CHARSET_UTF8 = \"utf-8\";\nconst PROPERTY_NAME_UTF8_SUFFIX = \"UTF8\";\nconst CHARSET_CP437 = \"cp437\";\nconst ZIP64_PROPERTIES = [\n\t[PROPERTY_NAME_UNCOMPRESSED_SIZE, MAX_32_BITS],\n\t[PROPERTY_NAME_COMPRESSED_SIZE, MAX_32_BITS],\n\t[PROPERTY_NAME_OFFSET, MAX_32_BITS],\n\t[PROPERTY_NAME_DISK_NUMBER_START, MAX_16_BITS]\n];\nconst ZIP64_EXTRACTION = {\n\t[MAX_16_BITS]: {\n\t\tgetValue: getUint32,\n\t\tbytes: 4\n\t},\n\t[MAX_32_BITS]: {\n\t\tgetValue: getBigUint64,\n\t\tbytes: 8\n\t}\n};\n\nclass ZipReader {\n\n\tconstructor(reader, options = {}) {\n\t\tObject.assign(this, {\n\t\t\treader: new GenericReader(reader),\n\t\t\toptions,\n\t\t\tconfig: getConfiguration(),\n\t\t\treadRanges: []\n\t\t});\n\t}\n\n\tasync* getEntriesGenerator(options = {}) {\n\t\tconst zipReader = this;\n\t\tlet { reader } = zipReader;\n\t\tconst { config } = zipReader;\n\t\tawait initStream(reader);\n\t\tif (reader.size === UNDEFINED_VALUE || !reader.readUint8Array) {\n\t\t\treader = new BlobReader(await new Response(reader.readable).blob());\n\t\t\tawait initStream(reader);\n\t\t}\n\t\tif (reader.size < END_OF_CENTRAL_DIR_LENGTH) {\n\t\t\tthrow new Error(ERR_BAD_FORMAT);\n\t\t}\n\t\treader.chunkSize = getChunkSize(config);\n\t\tconst endOfDirectoryInfo = await seekSignature(reader, END_OF_CENTRAL_DIR_SIGNATURE, reader.size, END_OF_CENTRAL_DIR_LENGTH, MAX_16_BITS * 16);\n\t\tif (!endOfDirectoryInfo) {\n\t\t\tconst signatureArray = await readUint8Array(reader, 0, 4);\n\t\t\tconst signatureView = getDataView(signatureArray);\n\t\t\tif (getUint32(signatureView) == SPLIT_ZIP_FILE_SIGNATURE) {\n\t\t\t\tthrow new Error(ERR_SPLIT_ZIP_FILE);\n\t\t\t} else {\n\t\t\t\tthrow new Error(ERR_EOCDR_NOT_FOUND);\n\t\t\t}\n\t\t}\n\t\tconst endOfDirectoryView = getDataView(endOfDirectoryInfo);\n\t\tlet directoryDataLength = getUint32(endOfDirectoryView, 12);\n\t\tlet directoryDataOffset = getUint32(endOfDirectoryView, 16);\n\t\tconst commentOffset = endOfDirectoryInfo.offset;\n\t\tconst commentLength = getUint16(endOfDirectoryView, 20);\n\t\tconst appendedDataOffset = commentOffset + END_OF_CENTRAL_DIR_LENGTH + commentLength;\n\t\tlet lastDiskNumber = getUint16(endOfDirectoryView, 4);\n\t\tconst expectedLastDiskNumber = reader.lastDiskNumber || 0;\n\t\tlet diskNumber = getUint16(endOfDirectoryView, 6);\n\t\tlet filesLength = getUint16(endOfDirectoryView, 8);\n\t\tlet prependedDataLength = 0;\n\t\tlet startOffset = 0;\n\t\tif (directoryDataOffset == MAX_32_BITS || directoryDataLength == MAX_32_BITS || filesLength == MAX_16_BITS || diskNumber == MAX_16_BITS) {\n\t\t\tconst endOfDirectoryLocatorArray = await readUint8Array(reader, endOfDirectoryInfo.offset - ZIP64_END_OF_CENTRAL_DIR_LOCATOR_LENGTH, ZIP64_END_OF_CENTRAL_DIR_LOCATOR_LENGTH);\n\t\t\tconst endOfDirectoryLocatorView = getDataView(endOfDirectoryLocatorArray);\n\t\t\tif (getUint32(endOfDirectoryLocatorView, 0) == ZIP64_END_OF_CENTRAL_DIR_LOCATOR_SIGNATURE) {\n\t\t\t\tdirectoryDataOffset = getBigUint64(endOfDirectoryLocatorView, 8);\n\t\t\t\tlet endOfDirectoryArray = await readUint8Array(reader, directoryDataOffset, ZIP64_END_OF_CENTRAL_DIR_LENGTH, -1);\n\t\t\t\tlet endOfDirectoryView = getDataView(endOfDirectoryArray);\n\t\t\t\tconst expectedDirectoryDataOffset = endOfDirectoryInfo.offset - ZIP64_END_OF_CENTRAL_DIR_LOCATOR_LENGTH - ZIP64_END_OF_CENTRAL_DIR_LENGTH;\n\t\t\t\tif (getUint32(endOfDirectoryView, 0) != ZIP64_END_OF_CENTRAL_DIR_SIGNATURE && directoryDataOffset != expectedDirectoryDataOffset) {\n\t\t\t\t\tconst originalDirectoryDataOffset = directoryDataOffset;\n\t\t\t\t\tdirectoryDataOffset = expectedDirectoryDataOffset;\n\t\t\t\t\tif (directoryDataOffset > originalDirectoryDataOffset) {\n\t\t\t\t\t\tprependedDataLength = directoryDataOffset - originalDirectoryDataOffset;\n\t\t\t\t\t}\n\t\t\t\t\tendOfDirectoryArray = await readUint8Array(reader, directoryDataOffset, ZIP64_END_OF_CENTRAL_DIR_LENGTH, -1);\n\t\t\t\t\tendOfDirectoryView = getDataView(endOfDirectoryArray);\n\t\t\t\t}\n\t\t\t\tif (getUint32(endOfDirectoryView, 0) != ZIP64_END_OF_CENTRAL_DIR_SIGNATURE) {\n\t\t\t\t\tthrow new Error(ERR_EOCDR_LOCATOR_ZIP64_NOT_FOUND);\n\t\t\t\t}\n\t\t\t\tif (lastDiskNumber == MAX_16_BITS) {\n\t\t\t\t\tlastDiskNumber = getUint32(endOfDirectoryView, 16);\n\t\t\t\t}\n\t\t\t\tif (diskNumber == MAX_16_BITS) {\n\t\t\t\t\tdiskNumber = getUint32(endOfDirectoryView, 20);\n\t\t\t\t}\n\t\t\t\tif (filesLength == MAX_16_BITS) {\n\t\t\t\t\tfilesLength = getBigUint64(endOfDirectoryView, 32);\n\t\t\t\t}\n\t\t\t\tif (directoryDataLength == MAX_32_BITS) {\n\t\t\t\t\tdirectoryDataLength = getBigUint64(endOfDirectoryView, 40);\n\t\t\t\t}\n\t\t\t\tdirectoryDataOffset -= directoryDataLength;\n\t\t\t}\n\t\t}\n\t\tif (directoryDataOffset >= reader.size) {\n\t\t\tprependedDataLength = reader.size - directoryDataOffset - directoryDataLength - END_OF_CENTRAL_DIR_LENGTH;\n\t\t\tdirectoryDataOffset = reader.size - directoryDataLength - END_OF_CENTRAL_DIR_LENGTH;\n\t\t}\n\t\tif (expectedLastDiskNumber != lastDiskNumber) {\n\t\t\tthrow new Error(ERR_SPLIT_ZIP_FILE);\n\t\t}\n\t\tif (directoryDataOffset < 0) {\n\t\t\tthrow new Error(ERR_BAD_FORMAT);\n\t\t}\n\t\tlet offset = 0;\n\t\tlet directoryArray = await readUint8Array(reader, directoryDataOffset, directoryDataLength, diskNumber);\n\t\tlet directoryView = getDataView(directoryArray);\n\t\tif (directoryDataLength) {\n\t\t\tconst expectedDirectoryDataOffset = endOfDirectoryInfo.offset - directoryDataLength;\n\t\t\tif (getUint32(directoryView, offset) != CENTRAL_FILE_HEADER_SIGNATURE && directoryDataOffset != expectedDirectoryDataOffset) {\n\t\t\t\tconst originalDirectoryDataOffset = directoryDataOffset;\n\t\t\t\tdirectoryDataOffset = expectedDirectoryDataOffset;\n\t\t\t\tif (directoryDataOffset > originalDirectoryDataOffset) {\n\t\t\t\t\tprependedDataLength += directoryDataOffset - originalDirectoryDataOffset;\n\t\t\t\t}\n\t\t\t\tdirectoryArray = await readUint8Array(reader, directoryDataOffset, directoryDataLength, diskNumber);\n\t\t\t\tdirectoryView = getDataView(directoryArray);\n\t\t\t}\n\t\t}\n\t\tconst expectedDirectoryDataLength = endOfDirectoryInfo.offset - directoryDataOffset - (reader.lastDiskOffset || 0);\n\t\tif (directoryDataLength != expectedDirectoryDataLength && expectedDirectoryDataLength >= 0) {\n\t\t\tdirectoryDataLength = expectedDirectoryDataLength;\n\t\t\tdirectoryArray = await readUint8Array(reader, directoryDataOffset, directoryDataLength, diskNumber);\n\t\t\tdirectoryView = getDataView(directoryArray);\n\t\t}\n\t\tif (directoryDataOffset < 0 || directoryDataOffset >= reader.size) {\n\t\t\tthrow new Error(ERR_BAD_FORMAT);\n\t\t}\n\t\tconst filenameEncoding = getOptionValue(zipReader, options, OPTION_FILENAME_ENCODING);\n\t\tconst commentEncoding = getOptionValue(zipReader, options, OPTION_COMMENT_ENCODING);\n\t\tfor (let indexFile = 0; indexFile < filesLength; indexFile++) {\n\t\t\tconst fileEntry = new ZipEntry(reader, config, zipReader.options);\n\t\t\tif (getUint32(directoryView, offset) != CENTRAL_FILE_HEADER_SIGNATURE) {\n\t\t\t\tthrow new Error(ERR_CENTRAL_DIRECTORY_NOT_FOUND);\n\t\t\t}\n\t\t\treadCommonHeader(fileEntry, directoryView, offset + 6);\n\t\t\tconst languageEncodingFlag = Boolean(fileEntry.bitFlag.languageEncodingFlag);\n\t\t\tconst filenameOffset = offset + 46;\n\t\t\tconst extraFieldOffset = filenameOffset + fileEntry.filenameLength;\n\t\t\tconst commentOffset = extraFieldOffset + fileEntry.extraFieldLength;\n\t\t\tconst versionMadeBy = getUint16(directoryView, offset + 4);\n\t\t\tconst msDosCompatible = versionMadeBy >> 8 == 0;\n\t\t\tconst unixCompatible = versionMadeBy >> 8 == 3;\n\t\t\tconst rawFilename = directoryArray.subarray(filenameOffset, extraFieldOffset);\n\t\t\tconst commentLength = getUint16(directoryView, offset + 32);\n\t\t\tconst endOffset = commentOffset + commentLength;\n\t\t\tconst rawComment = directoryArray.subarray(commentOffset, endOffset);\n\t\t\tconst filenameUTF8 = languageEncodingFlag;\n\t\t\tconst commentUTF8 = languageEncodingFlag;\n\t\t\tconst externalFileAttributes = getUint32(directoryView, offset + 38);\n\t\t\tconst msdosAttributesRaw = externalFileAttributes & MAX_8_BITS;\n\t\t\tconst msdosAttributes = {\n\t\t\t\treadOnly: Boolean(msdosAttributesRaw & FILE_ATTR_MSDOS_READONLY_MASK),\n\t\t\t\thidden: Boolean(msdosAttributesRaw & FILE_ATTR_MSDOS_HIDDEN_MASK),\n\t\t\t\tsystem: Boolean(msdosAttributesRaw & FILE_ATTR_MSDOS_SYSTEM_MASK),\n\t\t\t\tdirectory: Boolean(msdosAttributesRaw & FILE_ATTR_MSDOS_DIR_MASK),\n\t\t\t\tarchive: Boolean(msdosAttributesRaw & FILE_ATTR_MSDOS_ARCHIVE_MASK)\n\t\t\t};\n\t\t\tconst offsetFileEntry = getUint32(directoryView, offset + 42) + prependedDataLength;\n\t\t\tconst decode = getOptionValue(zipReader, options, OPTION_DECODE_TEXT) || decodeText;\n\t\t\tconst rawFilenameEncoding = filenameUTF8 ? CHARSET_UTF8 : filenameEncoding || CHARSET_CP437;\n\t\t\tconst rawCommentEncoding = commentUTF8 ? CHARSET_UTF8 : commentEncoding || CHARSET_CP437;\n\t\t\tlet filename = decode(rawFilename, rawFilenameEncoding);\n\t\t\tif (filename === UNDEFINED_VALUE) {\n\t\t\t\tfilename = decodeText(rawFilename, rawFilenameEncoding);\n\t\t\t}\n\t\t\tlet comment = decode(rawComment, rawCommentEncoding);\n\t\t\tif (comment === UNDEFINED_VALUE) {\n\t\t\t\tcomment = decodeText(rawComment, rawCommentEncoding);\n\t\t\t}\n\t\t\tObject.assign(fileEntry, {\n\t\t\t\tversionMadeBy,\n\t\t\t\tmsDosCompatible,\n\t\t\t\tcompressedSize: 0,\n\t\t\t\tuncompressedSize: 0,\n\t\t\t\tcommentLength,\n\t\t\t\toffset: offsetFileEntry,\n\t\t\t\tdiskNumberStart: getUint16(directoryView, offset + 34),\n\t\t\t\tinternalFileAttributes: getUint16(directoryView, offset + 36),\n\t\t\t\texternalFileAttributes,\n\t\t\t\tmsdosAttributesRaw,\n\t\t\t\tmsdosAttributes,\n\t\t\t\trawFilename,\n\t\t\t\tfilenameUTF8,\n\t\t\t\tcommentUTF8,\n\t\t\t\trawExtraField: directoryArray.subarray(extraFieldOffset, commentOffset),\n\t\t\t\trawComment,\n\t\t\t\tfilename,\n\t\t\t\tcomment\n\t\t\t});\n\t\t\tstartOffset = Math.max(offsetFileEntry, startOffset);\n\t\t\treadCommonFooter(fileEntry, fileEntry, directoryView, offset + 6);\n\t\t\tconst unixExternalUpper = (fileEntry.externalFileAttributes >> 16) & MAX_16_BITS;\n\t\t\tif (fileEntry.unixMode === UNDEFINED_VALUE && (unixExternalUpper & (FILE_ATTR_UNIX_DEFAULT_MASK | FILE_ATTR_UNIX_EXECUTABLE_MASK | FILE_ATTR_UNIX_TYPE_DIR)) != 0) {\n\t\t\t\tfileEntry.unixMode = unixExternalUpper;\n\t\t\t}\n\t\t\tconst setuid = Boolean(fileEntry.unixMode & FILE_ATTR_UNIX_SETUID_MASK);\n\t\t\tconst setgid = Boolean(fileEntry.unixMode & FILE_ATTR_UNIX_SETGID_MASK);\n\t\t\tconst sticky = Boolean(fileEntry.unixMode & FILE_ATTR_UNIX_STICKY_MASK);\n\t\t\tconst executable = (fileEntry.unixMode !== UNDEFINED_VALUE)\n\t\t\t\t? ((fileEntry.unixMode & FILE_ATTR_UNIX_EXECUTABLE_MASK) != 0)\n\t\t\t\t: (unixCompatible && ((unixExternalUpper & FILE_ATTR_UNIX_EXECUTABLE_MASK) != 0));\n\t\t\tconst modeIsDir = fileEntry.unixMode !== UNDEFINED_VALUE && ((fileEntry.unixMode & FILE_ATTR_UNIX_TYPE_MASK) == FILE_ATTR_UNIX_TYPE_DIR);\n\t\t\tconst upperIsDir = ((unixExternalUpper & FILE_ATTR_UNIX_TYPE_MASK) == FILE_ATTR_UNIX_TYPE_DIR);\n\t\t\tObject.assign(fileEntry, {\n\t\t\t\tsetuid,\n\t\t\t\tsetgid,\n\t\t\t\tsticky,\n\t\t\t\tunixExternalUpper,\n\t\t\t\tinternalFileAttribute: fileEntry.internalFileAttributes,\n\t\t\t\texternalFileAttribute: fileEntry.externalFileAttributes,\n\t\t\t\texecutable,\n\t\t\t\tdirectory: modeIsDir || upperIsDir || (msDosCompatible && msdosAttributes.directory) || (filename.endsWith(DIRECTORY_SIGNATURE) && !fileEntry.uncompressedSize),\n\t\t\t\tzipCrypto: fileEntry.encrypted && !fileEntry.extraFieldAES\n\t\t\t});\n\t\t\tconst entry = new Entry(fileEntry);\n\t\t\tentry.getData = (writer, options) => fileEntry.getData(writer, entry, zipReader.readRanges, options);\n\t\t\tentry.arrayBuffer = async options => {\n\t\t\t\tconst writer = new TransformStream();\n\t\t\t\tconst [arrayBuffer] = await Promise.all([\n\t\t\t\t\tnew Response(writer.readable).arrayBuffer(),\n\t\t\t\t\tfileEntry.getData(writer, entry, zipReader.readRanges, options)]);\n\t\t\t\treturn arrayBuffer;\n\t\t\t};\n\t\t\toffset = endOffset;\n\t\t\tconst { onprogress } = options;\n\t\t\tif (onprogress) {\n\t\t\t\ttry {\n\t\t\t\t\tawait onprogress(indexFile + 1, filesLength, new Entry(fileEntry));\n\t\t\t\t} catch {\n\t\t\t\t\t// ignored\n\t\t\t\t}\n\t\t\t}\n\t\t\tyield entry;\n\t\t}\n\t\tconst extractPrependedData = getOptionValue(zipReader, options, OPTION_EXTRACT_PREPENDED_DATA);\n\t\tconst extractAppendedData = getOptionValue(zipReader, options, OPTION_EXTRACT_APPENDED_DATA);\n\t\tif (extractPrependedData) {\n\t\t\tzipReader.prependedData = startOffset > 0 ? await readUint8Array(reader, 0, startOffset) : new Uint8Array();\n\t\t}\n\t\tzipReader.comment = commentLength ? await readUint8Array(reader, commentOffset + END_OF_CENTRAL_DIR_LENGTH, commentLength) : new Uint8Array();\n\t\tif (extractAppendedData) {\n\t\t\tzipReader.appendedData = appendedDataOffset < reader.size ? await readUint8Array(reader, appendedDataOffset, reader.size - appendedDataOffset) : new Uint8Array();\n\t\t}\n\t\treturn true;\n\t}\n\n\tasync getEntries(options = {}) {\n\t\tconst entries = [];\n\t\tfor await (const entry of this.getEntriesGenerator(options)) {\n\t\t\tentries.push(entry);\n\t\t}\n\t\treturn entries;\n\t}\n\n\tasync close() {\n\t}\n}\n\nclass ZipReaderStream {\n\n\tconstructor(options = {}) {\n\t\tconst { readable, writable } = new TransformStream();\n\t\tconst gen = new ZipReader(readable, options).getEntriesGenerator();\n\t\tthis.readable = new ReadableStream({\n\t\t\tasync pull(controller) {\n\t\t\t\tconst { done, value } = await gen.next();\n\t\t\t\tif (done)\n\t\t\t\t\treturn controller.close();\n\t\t\t\tconst chunk = {\n\t\t\t\t\t...value,\n\t\t\t\t\treadable: (function () {\n\t\t\t\t\t\tconst { readable, writable } = new TransformStream();\n\t\t\t\t\t\tif (value.getData) {\n\t\t\t\t\t\t\tvalue.getData(writable);\n\t\t\t\t\t\t\treturn readable;\n\t\t\t\t\t\t}\n\t\t\t\t\t})()\n\t\t\t\t};\n\t\t\t\tdelete chunk.getData;\n\t\t\t\tcontroller.enqueue(chunk);\n\t\t\t}\n\t\t});\n\t\tthis.writable = writable;\n\t}\n}\n\nexport {\n\tZipReader,\n\tZipReaderStream,\n\tERR_BAD_FORMAT,\n\tERR_EOCDR_NOT_FOUND,\n\tERR_EOCDR_LOCATOR_ZIP64_NOT_FOUND,\n\tERR_CENTRAL_DIRECTORY_NOT_FOUND,\n\tERR_LOCAL_FILE_HEADER_NOT_FOUND,\n\tERR_EXTRAFIELD_ZIP64_NOT_FOUND,\n\tERR_ENCRYPTED,\n\tERR_UNSUPPORTED_ENCRYPTION,\n\tERR_UNSUPPORTED_COMPRESSION,\n\tERR_INVALID_SIGNATURE,\n\tERR_INVALID_PASSWORD,\n\tERR_INVALID_UNCOMPRESSED_SIZE,\n\tERR_SPLIT_ZIP_FILE,\n\tERR_OVERLAPPING_ENTRY\n};\n\nclass ZipEntry {\n\n\tconstructor(reader, config, options) {\n\t\tObject.assign(this, {\n\t\t\treader,\n\t\t\tconfig,\n\t\t\toptions\n\t\t});\n\t}\n\n\tasync getData(writer, fileEntry, readRanges, options = {}) {\n\t\tconst zipEntry = this;\n\t\tconst {\n\t\t\treader,\n\t\t\toffset,\n\t\t\tdiskNumberStart,\n\t\t\textraFieldAES,\n\t\t\textraFieldZip64,\n\t\t\tcompressionMethod,\n\t\t\tconfig,\n\t\t\tbitFlag,\n\t\t\tsignature,\n\t\t\trawLastModDate,\n\t\t\tuncompressedSize,\n\t\t\tcompressedSize\n\t\t} = zipEntry;\n\t\tconst {\n\t\t\tdataDescriptor\n\t\t} = bitFlag;\n\t\tconst localDirectory = fileEntry.localDirectory = {};\n\t\tconst dataArray = await readUint8Array(reader, offset, HEADER_SIZE, diskNumberStart);\n\t\tconst dataView = getDataView(dataArray);\n\t\tlet password = getOptionValue(zipEntry, options, OPTION_PASSWORD);\n\t\tlet rawPassword = getOptionValue(zipEntry, options, OPTION_RAW_PASSWORD);\n\t\tconst passThrough = getOptionValue(zipEntry, options, OPTION_PASS_THROUGH);\n\t\tpassword = password && password.length && password;\n\t\trawPassword = rawPassword && rawPassword.length && rawPassword;\n\t\tif (extraFieldAES) {\n\t\t\tif (extraFieldAES.originalCompressionMethod != COMPRESSION_METHOD_AES) {\n\t\t\t\tthrow new Error(ERR_UNSUPPORTED_COMPRESSION);\n\t\t\t}\n\t\t}\n\t\tif ((compressionMethod != COMPRESSION_METHOD_STORE && compressionMethod != COMPRESSION_METHOD_DEFLATE && compressionMethod != COMPRESSION_METHOD_DEFLATE_64) && !passThrough) {\n\t\t\tthrow new Error(ERR_UNSUPPORTED_COMPRESSION);\n\t\t}\n\t\tif (getUint32(dataView, 0) != LOCAL_FILE_HEADER_SIGNATURE) {\n\t\t\tthrow new Error(ERR_LOCAL_FILE_HEADER_NOT_FOUND);\n\t\t}\n\t\treadCommonHeader(localDirectory, dataView, 4);\n\t\tconst {\n\t\t\textraFieldLength,\n\t\t\tfilenameLength,\n\t\t\tlastAccessDate,\n\t\t\tcreationDate\n\t\t} = localDirectory;\n\t\tlocalDirectory.rawExtraField = extraFieldLength ?\n\t\t\tawait readUint8Array(reader, offset + HEADER_SIZE + filenameLength, extraFieldLength, diskNumberStart) :\n\t\t\tnew Uint8Array();\n\t\treadCommonFooter(zipEntry, localDirectory, dataView, 4, true);\n\t\tObject.assign(fileEntry, { lastAccessDate, creationDate });\n\t\tconst encrypted = zipEntry.encrypted && localDirectory.encrypted && !passThrough;\n\t\tconst zipCrypto = encrypted && !extraFieldAES;\n\t\tif (!passThrough) {\n\t\t\tfileEntry.zipCrypto = zipCrypto;\n\t\t}\n\t\tif (encrypted) {\n\t\t\tif (!zipCrypto && extraFieldAES.strength === UNDEFINED_VALUE) {\n\t\t\t\tthrow new Error(ERR_UNSUPPORTED_ENCRYPTION);\n\t\t\t} else if (!password && !rawPassword) {\n\t\t\t\tthrow new Error(ERR_ENCRYPTED);\n\t\t\t}\n\t\t}\n\t\tconst dataOffset = offset + HEADER_SIZE + filenameLength + extraFieldLength;\n\t\tconst size = compressedSize;\n\t\tconst readable = reader.readable;\n\t\tObject.assign(readable, {\n\t\t\tdiskNumberStart,\n\t\t\toffset: dataOffset,\n\t\t\tsize\n\t\t});\n\t\tconst signal = getOptionValue(zipEntry, options, OPTION_SIGNAL);\n\t\tconst checkPasswordOnly = getOptionValue(zipEntry, options, OPTION_CHECK_PASSWORD_ONLY);\n\t\tlet checkOverlappingEntry = getOptionValue(zipEntry, options, OPTION_CHECK_OVERLAPPING_ENTRY);\n\t\tconst checkOverlappingEntryOnly = getOptionValue(zipEntry, options, OPTION_CHECK_OVERLAPPING_ENTRY_ONLY);\n\t\tif (checkOverlappingEntryOnly) {\n\t\t\tcheckOverlappingEntry = true;\n\t\t}\n\t\tconst { onstart, onprogress, onend } = options;\n\t\tconst deflate64 = compressionMethod == COMPRESSION_METHOD_DEFLATE_64;\n\t\tlet useCompressionStream = getOptionValue(zipEntry, options, OPTION_USE_COMPRESSION_STREAM);\n\t\tif (deflate64) {\n\t\t\tuseCompressionStream = false;\n\t\t}\n\t\tconst workerOptions = {\n\t\t\toptions: {\n\t\t\t\tcodecType: CODEC_INFLATE,\n\t\t\t\tpassword,\n\t\t\t\trawPassword,\n\t\t\t\tzipCrypto,\n\t\t\t\tencryptionStrength: extraFieldAES && extraFieldAES.strength,\n\t\t\t\tsigned: getOptionValue(zipEntry, options, OPTION_CHECK_SIGNATURE) && !passThrough,\n\t\t\t\tpasswordVerification: zipCrypto && (dataDescriptor ? ((rawLastModDate >>> 8) & MAX_8_BITS) : ((signature >>> 24) & MAX_8_BITS)),\n\t\t\t\toutputSize: passThrough ? compressedSize : uncompressedSize,\n\t\t\t\tsignature,\n\t\t\t\tcompressed: compressionMethod != 0 && !passThrough,\n\t\t\t\tencrypted: zipEntry.encrypted && !passThrough,\n\t\t\t\tuseWebWorkers: getOptionValue(zipEntry, options, OPTION_USE_WEB_WORKERS),\n\t\t\t\tuseCompressionStream,\n\t\t\t\ttransferStreams: getOptionValue(zipEntry, options, OPTION_TRANSFER_STREAMS),\n\t\t\t\tdeflate64,\n\t\t\t\tcheckPasswordOnly\n\t\t\t},\n\t\t\tconfig,\n\t\t\tstreamOptions: { signal, size, onstart, onprogress, onend }\n\t\t};\n\t\tif (checkOverlappingEntry) {\n\t\t\tawait detectOverlappingEntry({\n\t\t\t\treader,\n\t\t\t\tfileEntry,\n\t\t\t\toffset,\n\t\t\t\tdiskNumberStart,\n\t\t\t\tsignature,\n\t\t\t\tcompressedSize,\n\t\t\t\tuncompressedSize,\n\t\t\t\tdataOffset,\n\t\t\t\tdataDescriptor: dataDescriptor || localDirectory.bitFlag.dataDescriptor,\n\t\t\t\textraFieldZip64: extraFieldZip64 || localDirectory.extraFieldZip64,\n\t\t\t\treadRanges\n\t\t\t});\n\t\t}\n\t\tlet writable;\n\t\ttry {\n\t\t\tif (!checkOverlappingEntryOnly) {\n\t\t\t\tif (checkPasswordOnly) {\n\t\t\t\t\twriter = new WritableStream();\n\t\t\t\t}\n\t\t\t\twriter = new GenericWriter(writer);\n\t\t\t\tawait initStream(writer, passThrough ? compressedSize : uncompressedSize);\n\t\t\t\t({ writable } = writer);\n\t\t\t\tconst { outputSize } = await runWorker({ readable, writable }, workerOptions);\n\t\t\t\twriter.size += outputSize;\n\t\t\t\tif (outputSize != (passThrough ? compressedSize : uncompressedSize)) {\n\t\t\t\t\tthrow new Error(ERR_INVALID_UNCOMPRESSED_SIZE);\n\t\t\t\t}\n\t\t\t}\n\t\t} catch (error) {\n\t\t\tif (error.outputSize !== UNDEFINED_VALUE) {\n\t\t\t\twriter.size += error.outputSize;\n\t\t\t}\n\t\t\tif (!checkPasswordOnly || error.message != ERR_ABORT_CHECK_PASSWORD) {\n\t\t\t\tthrow error;\n\t\t\t}\n\t\t} finally {\n\t\t\tconst preventClose = getOptionValue(zipEntry, options, OPTION_PREVENT_CLOSE);\n\t\t\tif (!preventClose && writable && !writable.locked) {\n\t\t\t\tawait writable.getWriter().close();\n\t\t\t}\n\t\t}\n\t\treturn checkPasswordOnly || checkOverlappingEntryOnly ? UNDEFINED_VALUE : writer.getData ? writer.getData() : writable;\n\t}\n}\n\nfunction readCommonHeader(directory, dataView, offset) {\n\tconst rawBitFlag = directory.rawBitFlag = getUint16(dataView, offset + 2);\n\tconst encrypted = (rawBitFlag & BITFLAG_ENCRYPTED) == BITFLAG_ENCRYPTED;\n\tconst rawLastModDate = getUint32(dataView, offset + 6);\n\tObject.assign(directory, {\n\t\tencrypted,\n\t\tversion: getUint16(dataView, offset),\n\t\tbitFlag: {\n\t\t\tlevel: (rawBitFlag & BITFLAG_LEVEL) >> 1,\n\t\t\tdataDescriptor: (rawBitFlag & BITFLAG_DATA_DESCRIPTOR) == BITFLAG_DATA_DESCRIPTOR,\n\t\t\tlanguageEncodingFlag: (rawBitFlag & BITFLAG_LANG_ENCODING_FLAG) == BITFLAG_LANG_ENCODING_FLAG\n\t\t},\n\t\trawLastModDate,\n\t\tlastModDate: getDate(rawLastModDate),\n\t\tfilenameLength: getUint16(dataView, offset + 22),\n\t\textraFieldLength: getUint16(dataView, offset + 24)\n\t});\n}\n\nfunction readCommonFooter(fileEntry, directory, dataView, offset, localDirectory) {\n\tconst { rawExtraField } = directory;\n\tconst extraField = directory.extraField = new Map();\n\tconst rawExtraFieldView = getDataView(new Uint8Array(rawExtraField));\n\tlet offsetExtraField = 0;\n\ttry {\n\t\twhile (offsetExtraField < rawExtraField.length) {\n\t\t\tconst type = getUint16(rawExtraFieldView, offsetExtraField);\n\t\t\tconst size = getUint16(rawExtraFieldView, offsetExtraField + 2);\n\t\t\textraField.set(type, {\n\t\t\t\ttype,\n\t\t\t\tdata: rawExtraField.slice(offsetExtraField + 4, offsetExtraField + 4 + size)\n\t\t\t});\n\t\t\toffsetExtraField += 4 + size;\n\t\t}\n\t} catch {\n\t\t// ignored\n\t}\n\tconst compressionMethod = getUint16(dataView, offset + 4);\n\tObject.assign(directory, {\n\t\tsignature: getUint32(dataView, offset + HEADER_OFFSET_SIGNATURE),\n\t\tcompressedSize: getUint32(dataView, offset + HEADER_OFFSET_COMPRESSED_SIZE),\n\t\tuncompressedSize: getUint32(dataView, offset + HEADER_OFFSET_UNCOMPRESSED_SIZE)\n\t});\n\tconst extraFieldZip64 = extraField.get(EXTRAFIELD_TYPE_ZIP64);\n\tif (extraFieldZip64) {\n\t\treadExtraFieldZip64(extraFieldZip64, directory);\n\t\tdirectory.extraFieldZip64 = extraFieldZip64;\n\t}\n\tconst extraFieldUnicodePath = extraField.get(EXTRAFIELD_TYPE_UNICODE_PATH);\n\tif (extraFieldUnicodePath) {\n\t\treadExtraFieldUnicode(extraFieldUnicodePath, PROPERTY_NAME_FILENAME, PROPERTY_NAME_RAW_FILENAME, directory, fileEntry);\n\t\tdirectory.extraFieldUnicodePath = extraFieldUnicodePath;\n\t}\n\tconst extraFieldUnicodeComment = extraField.get(EXTRAFIELD_TYPE_UNICODE_COMMENT);\n\tif (extraFieldUnicodeComment) {\n\t\treadExtraFieldUnicode(extraFieldUnicodeComment, PROPERTY_NAME_COMMENT, PROPERTY_NAME_RAW_COMMENT, directory, fileEntry);\n\t\tdirectory.extraFieldUnicodeComment = extraFieldUnicodeComment;\n\t}\n\tconst extraFieldAES = extraField.get(EXTRAFIELD_TYPE_AES);\n\tif (extraFieldAES) {\n\t\treadExtraFieldAES(extraFieldAES, directory, compressionMethod);\n\t\tdirectory.extraFieldAES = extraFieldAES;\n\t} else {\n\t\tdirectory.compressionMethod = compressionMethod;\n\t}\n\tconst extraFieldNTFS = extraField.get(EXTRAFIELD_TYPE_NTFS);\n\tif (extraFieldNTFS) {\n\t\treadExtraFieldNTFS(extraFieldNTFS, directory);\n\t\tdirectory.extraFieldNTFS = extraFieldNTFS;\n\t}\n\tconst extraFieldUnix = extraField.get(EXTRAFIELD_TYPE_UNIX);\n\tif (extraFieldUnix) {\n\t\treadExtraFieldUnix(extraFieldUnix, directory, false);\n\t\tdirectory.extraFieldUnix = extraFieldUnix;\n\t} else {\n\t\tconst extraFieldInfoZip = extraField.get(EXTRAFIELD_TYPE_INFOZIP);\n\t\tif (extraFieldInfoZip) {\n\t\t\treadExtraFieldUnix(extraFieldInfoZip, directory, true);\n\t\t\tdirectory.extraFieldInfoZip = extraFieldInfoZip;\n\t\t}\n\t}\n\tconst extraFieldExtendedTimestamp = extraField.get(EXTRAFIELD_TYPE_EXTENDED_TIMESTAMP);\n\tif (extraFieldExtendedTimestamp) {\n\t\treadExtraFieldExtendedTimestamp(extraFieldExtendedTimestamp, directory, localDirectory);\n\t\tdirectory.extraFieldExtendedTimestamp = extraFieldExtendedTimestamp;\n\t}\n\tconst extraFieldUSDZ = extraField.get(EXTRAFIELD_TYPE_USDZ);\n\tif (extraFieldUSDZ) {\n\t\tdirectory.extraFieldUSDZ = extraFieldUSDZ;\n\t}\n}\n\nfunction readExtraFieldZip64(extraFieldZip64, directory) {\n\tdirectory.zip64 = true;\n\tconst extraFieldView = getDataView(extraFieldZip64.data);\n\tconst missingProperties = ZIP64_PROPERTIES.filter(([propertyName, max]) => directory[propertyName] == max);\n\tfor (let indexMissingProperty = 0, offset = 0; indexMissingProperty < missingProperties.length; indexMissingProperty++) {\n\t\tconst [propertyName, max] = missingProperties[indexMissingProperty];\n\t\tif (directory[propertyName] == max) {\n\t\t\tconst extraction = ZIP64_EXTRACTION[max];\n\t\t\tdirectory[propertyName] = extraFieldZip64[propertyName] = extraction.getValue(extraFieldView, offset);\n\t\t\toffset += extraction.bytes;\n\t\t} else if (extraFieldZip64[propertyName]) {\n\t\t\tthrow new Error(ERR_EXTRAFIELD_ZIP64_NOT_FOUND);\n\t\t}\n\t}\n}\n\nfunction readExtraFieldUnicode(extraFieldUnicode, propertyName, rawPropertyName, directory, fileEntry) {\n\tconst extraFieldView = getDataView(extraFieldUnicode.data);\n\tconst crc32 = new Crc32();\n\tcrc32.append(fileEntry[rawPropertyName]);\n\tconst dataViewSignature = getDataView(new Uint8Array(4));\n\tdataViewSignature.setUint32(0, crc32.get(), true);\n\tconst signature = getUint32(extraFieldView, 1);\n\tObject.assign(extraFieldUnicode, {\n\t\tversion: getUint8(extraFieldView, 0),\n\t\t[propertyName]: decodeText(extraFieldUnicode.data.subarray(5)),\n\t\tvalid: !fileEntry.bitFlag.languageEncodingFlag && signature == getUint32(dataViewSignature, 0)\n\t});\n\tif (extraFieldUnicode.valid) {\n\t\tdirectory[propertyName] = extraFieldUnicode[propertyName];\n\t\tdirectory[propertyName + PROPERTY_NAME_UTF8_SUFFIX] = true;\n\t}\n}\n\nfunction readExtraFieldAES(extraFieldAES, directory, compressionMethod) {\n\tconst extraFieldView = getDataView(extraFieldAES.data);\n\tconst strength = getUint8(extraFieldView, 4);\n\tObject.assign(extraFieldAES, {\n\t\tvendorVersion: getUint8(extraFieldView, 0),\n\t\tvendorId: getUint8(extraFieldView, 2),\n\t\tstrength,\n\t\toriginalCompressionMethod: compressionMethod,\n\t\tcompressionMethod: getUint16(extraFieldView, 5)\n\t});\n\tdirectory.compressionMethod = extraFieldAES.compressionMethod;\n}\n\nfunction readExtraFieldNTFS(extraFieldNTFS, directory) {\n\tconst extraFieldView = getDataView(extraFieldNTFS.data);\n\tlet offsetExtraField = 4;\n\tlet tag1Data;\n\ttry {\n\t\twhile (offsetExtraField < extraFieldNTFS.data.length && !tag1Data) {\n\t\t\tconst tagValue = getUint16(extraFieldView, offsetExtraField);\n\t\t\tconst attributeSize = getUint16(extraFieldView, offsetExtraField + 2);\n\t\t\tif (tagValue == EXTRAFIELD_TYPE_NTFS_TAG1) {\n\t\t\t\ttag1Data = extraFieldNTFS.data.slice(offsetExtraField + 4, offsetExtraField + 4 + attributeSize);\n\t\t\t}\n\t\t\toffsetExtraField += 4 + attributeSize;\n\t\t}\n\t} catch {\n\t\t// ignored\n\t}\n\ttry {\n\t\tif (tag1Data && tag1Data.length == 24) {\n\t\t\tconst tag1View = getDataView(tag1Data);\n\t\t\tconst rawLastModDate = tag1View.getBigUint64(0, true);\n\t\t\tconst rawLastAccessDate = tag1View.getBigUint64(8, true);\n\t\t\tconst rawCreationDate = tag1View.getBigUint64(16, true);\n\t\t\tObject.assign(extraFieldNTFS, {\n\t\t\t\trawLastModDate,\n\t\t\t\trawLastAccessDate,\n\t\t\t\trawCreationDate\n\t\t\t});\n\t\t\tconst lastModDate = getDateNTFS(rawLastModDate);\n\t\t\tconst lastAccessDate = getDateNTFS(rawLastAccessDate);\n\t\t\tconst creationDate = getDateNTFS(rawCreationDate);\n\t\t\tconst extraFieldData = { lastModDate, lastAccessDate, creationDate };\n\t\t\tObject.assign(extraFieldNTFS, extraFieldData);\n\t\t\tObject.assign(directory, extraFieldData);\n\t\t}\n\t} catch {\n\t\t// ignored\n\t}\n}\n\nfunction readExtraFieldUnix(extraField, directory, isInfoZip) {\n\ttry {\n\t\tconst view = getDataView(new Uint8Array(extraField.data));\n\t\tlet offset = 0;\n\t\tconst version = getUint8(view, offset++);\n\t\tconst uidSize = getUint8(view, offset++);\n\t\tconst uidBytes = extraField.data.subarray(offset, offset + uidSize);\n\t\toffset += uidSize;\n\t\tconst uid = unpackUnixId(uidBytes);\n\t\tconst gidSize = getUint8(view, offset++);\n\t\tconst gidBytes = extraField.data.subarray(offset, offset + gidSize);\n\t\toffset += gidSize;\n\t\tconst gid = unpackUnixId(gidBytes);\n\t\tlet unixMode = UNDEFINED_VALUE;\n\t\tif (!isInfoZip && offset + 2 <= extraField.data.length) {\n\t\t\tconst base = extraField.data;\n\t\t\tconst modeView = new DataView(base.buffer, base.byteOffset + offset, 2);\n\t\t\tunixMode = modeView.getUint16(0, true);\n\t\t}\n\t\tObject.assign(extraField, { version, uid, gid, unixMode });\n\t\tif (uid !== UNDEFINED_VALUE) {\n\t\t\tdirectory.uid = uid;\n\t\t}\n\t\tif (gid !== UNDEFINED_VALUE) {\n\t\t\tdirectory.gid = gid;\n\t\t}\n\t\tif (unixMode !== UNDEFINED_VALUE) {\n\t\t\tdirectory.unixMode = unixMode;\n\t\t}\n\t} catch {\n\t\t// ignored\n\t}\n}\n\nfunction unpackUnixId(bytes) {\n\tconst buffer = new Uint8Array(4);\n\tbuffer.set(bytes, 0);\n\tconst view = new DataView(buffer.buffer, buffer.byteOffset, 4);\n\treturn view.getUint32(0, true);\n}\n\nfunction readExtraFieldExtendedTimestamp(extraFieldExtendedTimestamp, directory, localDirectory) {\n\tconst extraFieldView = getDataView(extraFieldExtendedTimestamp.data);\n\tconst flags = getUint8(extraFieldView, 0);\n\tconst timeProperties = [];\n\tconst timeRawProperties = [];\n\tif (localDirectory) {\n\t\tif ((flags & 0x1) == 0x1) {\n\t\t\ttimeProperties.push(PROPERTY_NAME_LAST_MODIFICATION_DATE);\n\t\t\ttimeRawProperties.push(PROPERTY_NAME_RAW_LAST_MODIFICATION_DATE);\n\t\t}\n\t\tif ((flags & 0x2) == 0x2) {\n\t\t\ttimeProperties.push(PROPERTY_NAME_LAST_ACCESS_DATE);\n\t\t\ttimeRawProperties.push(PROPERTY_NAME_RAW_LAST_ACCESS_DATE);\n\t\t}\n\t\tif ((flags & 0x4) == 0x4) {\n\t\t\ttimeProperties.push(PROPERTY_NAME_CREATION_DATE);\n\t\t\ttimeRawProperties.push(PROPERTY_NAME_RAW_CREATION_DATE);\n\t\t}\n\t} else if (extraFieldExtendedTimestamp.data.length >= 5) {\n\t\ttimeProperties.push(PROPERTY_NAME_LAST_MODIFICATION_DATE);\n\t\ttimeRawProperties.push(PROPERTY_NAME_RAW_LAST_MODIFICATION_DATE);\n\t}\n\tlet offset = 1;\n\ttimeProperties.forEach((propertyName, indexProperty) => {\n\t\tif (extraFieldExtendedTimestamp.data.length >= offset + 4) {\n\t\t\tconst time = getUint32(extraFieldView, offset);\n\t\t\tdirectory[propertyName] = extraFieldExtendedTimestamp[propertyName] = new Date(time * 1000);\n\t\t\tconst rawPropertyName = timeRawProperties[indexProperty];\n\t\t\textraFieldExtendedTimestamp[rawPropertyName] = time;\n\t\t}\n\t\toffset += 4;\n\t});\n}\n\nasync function detectOverlappingEntry({\n\treader,\n\tfileEntry,\n\toffset,\n\tdiskNumberStart,\n\tsignature,\n\tcompressedSize,\n\tuncompressedSize,\n\tdataOffset,\n\tdataDescriptor,\n\textraFieldZip64,\n\treadRanges\n}) {\n\tlet diskOffset = 0;\n\tif (diskNumberStart) {\n\t\tfor (let indexReader = 0; indexReader < diskNumberStart; indexReader++) {\n\t\t\tconst diskReader = reader.readers[indexReader];\n\t\t\tdiskOffset += diskReader.size;\n\t\t}\n\t}\n\tlet dataDescriptorLength = 0;\n\tif (dataDescriptor) {\n\t\tif (extraFieldZip64) {\n\t\t\tdataDescriptorLength = DATA_DESCRIPTOR_RECORD_ZIP_64_LENGTH;\n\t\t} else {\n\t\t\tdataDescriptorLength = DATA_DESCRIPTOR_RECORD_LENGTH;\n\t\t}\n\t}\n\tif (dataDescriptorLength) {\n\t\tconst dataDescriptorArray = await readUint8Array(reader, dataOffset + compressedSize, dataDescriptorLength + DATA_DESCRIPTOR_RECORD_SIGNATURE_LENGTH, diskNumberStart);\n\t\tconst dataDescriptorSignature = getUint32(getDataView(dataDescriptorArray), 0) == DATA_DESCRIPTOR_RECORD_SIGNATURE;\n\t\tif (dataDescriptorSignature) {\n\t\t\tconst readSignature = getUint32(getDataView(dataDescriptorArray), 4);\n\t\t\tlet readCompressedSize;\n\t\t\tlet readUncompressedSize;\n\t\t\tif (extraFieldZip64) {\n\t\t\t\treadCompressedSize = getBigUint64(getDataView(dataDescriptorArray), 8);\n\t\t\t\treadUncompressedSize = getBigUint64(getDataView(dataDescriptorArray), 16);\n\t\t\t} else {\n\t\t\t\treadCompressedSize = getUint32(getDataView(dataDescriptorArray), 8);\n\t\t\t\treadUncompressedSize = getUint32(getDataView(dataDescriptorArray), 12);\n\t\t\t}\n\t\t\tconst matchSignature = (fileEntry.encrypted && !fileEntry.zipCrypto) || readSignature == signature;\n\t\t\tif (matchSignature &&\n\t\t\t\treadCompressedSize == compressedSize &&\n\t\t\t\treadUncompressedSize == uncompressedSize) {\n\t\t\t\tdataDescriptorLength += DATA_DESCRIPTOR_RECORD_SIGNATURE_LENGTH;\n\t\t\t}\n\t\t}\n\t}\n\tconst range = {\n\t\tstart: diskOffset + offset,\n\t\tend: diskOffset + dataOffset + compressedSize + dataDescriptorLength,\n\t\tfileEntry\n\t};\n\tfor (const otherRange of readRanges) {\n\t\tif (otherRange.fileEntry != fileEntry && range.start >= otherRange.start && range.start < otherRange.end) {\n\t\t\tconst error = new Error(ERR_OVERLAPPING_ENTRY);\n\t\t\terror.overlappingEntry = otherRange.fileEntry;\n\t\t\tthrow error;\n\t\t}\n\t}\n\treadRanges.push(range);\n}\n\nasync function seekSignature(reader, signature, startOffset, minimumBytes, maximumLength) {\n\tconst signatureArray = new Uint8Array(4);\n\tconst signatureView = getDataView(signatureArray);\n\tsetUint32(signatureView, 0, signature);\n\tconst maximumBytes = minimumBytes + maximumLength;\n\treturn (await seek(minimumBytes)) || await seek(Math.min(maximumBytes, startOffset));\n\n\tasync function seek(length) {\n\t\tconst offset = startOffset - length;\n\t\tconst bytes = await readUint8Array(reader, offset, length);\n\t\tfor (let indexByte = bytes.length - minimumBytes; indexByte >= 0; indexByte--) {\n\t\t\tif (bytes[indexByte] == signatureArray[0] && bytes[indexByte + 1] == signatureArray[1] &&\n\t\t\t\tbytes[indexByte + 2] == signatureArray[2] && bytes[indexByte + 3] == signatureArray[3]) {\n\t\t\t\treturn {\n\t\t\t\t\toffset: offset + indexByte,\n\t\t\t\t\tbuffer: bytes.slice(indexByte, indexByte + minimumBytes).buffer\n\t\t\t\t};\n\t\t\t}\n\t\t}\n\t}\n}\n\nfunction getOptionValue(zipReader, options, name) {\n\treturn options[name] === UNDEFINED_VALUE ? zipReader.options[name] : options[name];\n}\n\nfunction getDate(timeRaw) {\n\tconst date = (timeRaw & 0xffff0000) >> 16, time = timeRaw & MAX_16_BITS;\n\ttry {\n\t\treturn new Date(1980 + ((date & 0xFE00) >> 9), ((date & 0x01E0) >> 5) - 1, date & 0x001F, (time & 0xF800) >> 11, (time & 0x07E0) >> 5, (time & 0x001F) * 2, 0);\n\t} catch {\n\t\t// ignored\n\t}\n}\n\nfunction getDateNTFS(timeRaw) {\n\treturn new Date((Number((timeRaw / BigInt(10000)) - BigInt(11644473600000))));\n}\n\nfunction getUint8(view, offset) {\n\treturn view.getUint8(offset);\n}\n\nfunction getUint16(view, offset) {\n\treturn view.getUint16(offset, true);\n}\n\nfunction getUint32(view, offset) {\n\treturn view.getUint32(offset, true);\n}\n\nfunction getBigUint64(view, offset) {\n\treturn Number(view.getBigUint64(offset, true));\n}\n\nfunction setUint32(view, offset, value) {\n\tview.setUint32(offset, value, true);\n}\n\nfunction getDataView(array) {\n\treturn new DataView(array.buffer);\n}\n","/*\n Copyright (c) 2025 Gildas Lormeau. All rights reserved.\n\n Redistribution and use in source and binary forms, with or without\n modification, are permitted provided that the following conditions are met:\n\n 1. Redistributions of source code must retain the above copyright notice,\n this list of conditions and the following disclaimer.\n\n 2. Redistributions in binary form must reproduce the above copyright\n notice, this list of conditions and the following disclaimer in\n the documentation and/or other materials provided with the distribution.\n\n 3. The names of the authors may not be used to endorse or promote products\n derived from this software without specific prior written permission.\n\n THIS SOFTWARE IS PROVIDED ''AS IS'' AND ANY EXPRESSED OR IMPLIED WARRANTIES,\n INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND\n FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL JCRAFT,\n INC. OR ANY CONTRIBUTORS TO THIS SOFTWARE BE LIABLE FOR ANY DIRECT, INDIRECT,\n INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT\n LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA,\n OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF\n LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING\n NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE,\n EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.\n */\n\nimport { configure } from \"./core/configuration.js\";\n\ntry {\n\tconfigure({ baseURI: import.meta.url });\n} catch {\n\t// ignored\n}\n\nexport * from \"./zip-core-reader.js\";\nexport * from \"./zip-core-writer.js\";\nexport {\n\tReader,\n\tWriter,\n\tTextReader,\n\tTextWriter,\n\tData64URIReader,\n\tData64URIWriter,\n\tBlobReader,\n\tBlobWriter,\n\tHttpReader,\n\tHttpRangeReader,\n\tUint8ArrayWriter,\n\tUint8ArrayReader,\n\tSplitDataReader,\n\tSplitDataWriter,\n\tERR_HTTP_RANGE\n} from \"./core/io.js\";\nexport {\n\tgetMimeType\n} from \"./core/util/default-mime-type.js\";\nexport {\n\tconfigure\n} from \"./core/configuration.js\";","const A=\"ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/\";function g(g){let B;g({wasmURI:()=>(B||(B=\"data:application/wasm;base64,\"+(g=>{g=(g=>{const B=(g=(g+\"\").replace(/[^A-Za-z0-9+/=]/g,\"\")).length,E=[];for(let I=0;B>I;I+=4){const B=A.indexOf(g[I])<<18|A.indexOf(g[I+1])<<12|(63&A.indexOf(g[I+2]))<<6|63&A.indexOf(g[I+3]);E.push(B>>16&255),\"=\"!==g[I+2]&&E.push(B>>8&255),\"=\"!==g[I+3]&&E.push(255&B)}return new Uint8Array(E)})(g);let B=new Uint8Array(1024),E=0;for(let A=0;A<g.length;){const C=g[A++];if(128&C){const Q=3+(127&C),D=g[A++]<<8|g[A++],o=E-D;I(E+Q);for(let A=0;Q>A;A++)B[E++]=B[o+A]}else{const Q=C;I(E+Q);for(let I=0;Q>I&&A<g.length;I++)B[E++]=g[A++]}}return(g=>{let B=\"\";const E=g.length;let I=0;for(;E>I+2;I+=3){const E=g[I]<<16|g[I+1]<<8|g[I+2];B+=A[E>>18&63]+A[E>>12&63]+A[E>>6&63]+A[63&E]}const C=E-I;if(1===C){const E=g[I]<<16;B+=A[E>>18&63]+A[E>>12&63]+\"==\"}else if(2===C){const E=g[I]<<16|g[I+1]<<8;B+=A[E>>18&63]+A[E>>12&63]+A[E>>6&63]+\"=\"}return B})(new Uint8Array(B.buffer.slice(0,E)));function I(A){if(B.length<A){let g=2*B.length;for(;A>g;)g*=2;const I=new Uint8Array(g);I.set(B.subarray(0,E)),B=I}}})(\"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BAGZgAAEAVmAAAQB2YAABAE5gAAEAbmAAAQBeYAABAH5gAAEAQWAAAQBhYAABAFFgAAEAcWAAAQBJYAABAGlgAAEAWWAAAQB5YAABAEVgAAEAZWAAAQBVYAABAHVgAAEATWAAAQBtYAABAF1gAAEAfWAAAQBDYAABAGNgAAEAU2AAAQBzYAABIARMwIArYAABAFtgAAEAe2AAAQBHYAABAGdgAAEAV2AAAQB3YAABAE9gAAEAb2AAAQBfYAABAH9gAAEAROAAMIFEwEJAJOAAAgBk4AACAFTgAAIAVOAAAgB04AACAHTgAAIATOAAAgBM4AACAGzgAAIAbOAAAgBc4AACAFzgAAIAfOAAAgB84AACAELgAAIgBDagAQCgAAEgAAIAUuAAAgBS4AACAHLgAAIAcuAAAgBK4AACAErgAAIAauAAAgBq4AACAFrgAAIAWuAAAgB64AACAHrgAAIARuAAAgBG4AACAGbgAAIAZuAAAgBW4AACAFbgAAIAduAAAgB24AACAE7gAAIATuAAAgBu4AACAG7gAAIAXuAAAgBe4AACAH7gAAIAfuAAAiBA7YBB4AACAGHgAAIAYeAAAgBR4AACAFHgAAIAceAAAgBx4AACAEngAAIASeAAAgBp4AACAGngAAIAWeAAAgBZ4AACAHngAAIAeeAAAgBF4AACAEXgAAIAZeAAAgBl4AACAFXgAAIAVeAAAgB14AACAHXgAAIATeAAAgBN4AACAG3gAAIAbeAAAgBd4AACAF3gAAIAfeAAAgB94AACAEPgAAIAQ+AAAgBj4AACAGPgAAIAU+AAAgBT4AACAHPgAAIAc+AAAgBL4AACAEvgAAIAa+AAAgBr4AACAFvgAAIAW+AAAgB74AACAHvgAAIAR+AAAgBH4AACAGfgAAIAZ+AAAgBX4AACAFfgAAIAd+AAAgB34AACAE/gAAIAT+AAAgBv4AACAG/gAAIAX+AAAgBf4AACAH/gAAIAf+AAAiBBAoBQIAABAEggAAEAWCAAAQBEIAABAFQgAAEATCAAAQBcIIFVgMHAEiAAAQBKIAABAFogAAEARiAAAQBWIAABAE4gAAEAXiAAAQBBIAABAFEgAAEASSAAAQBZIAABAEUgAAEAVSAAAQBNIAABAF0gAAEAQOAAEIBg4AABAFDgAAEAcOAAAQBI4AABAGjgAAEAWOAAAQB44AABIC+K4AAdIECxgEFgABcAQWCBUoBFIAABAEMgAAEARyAAASAvlaABEQBBYIGBAEaggXqAQWAA9QBBYADuAEFgAOcgE92gAAEARGAAAQBCYAABAEZgAAEgQACARWAAAQBDYAABAEdgAAEgL59gAKkgQZAAQWAAiyBBaYBBYABtAEFgD3fAxsLTYMfuYcABIC+rooABIEHUYkABAEEjAAEAQWKAAQEQbAcC4C9CosAS40AO4UALwEGhAAEgQWIgQAEgQEKgQAEgQGSgQAEgIS2ggAEAQuEAAQBDIQABIAF24FHeQTgHQsjhQBfhQXLAhARgAVtBgcJBgoFC4A6uAQNAg4BgAclBJQeC2mFAJCFAIiFAICFAHiBAGiBAFyBBh8BEIAABAEUgAAEARiAAAQBHIAABAEggAAEASiAAAQBMIAABAE4gAAEAUCAAAQBUIAABIEGvQFwgAAEAYCAAAQBoIAABAHAgAAEAeCAAG8DHwtyjQBvgQBrgQBngQBjgQBfgQBbgQBXgQBTgQBPgQBLgQBHgQBDgQE8AYCvAEGAUc0CC22BAMcBBIAAAgEIgAAEgQEzgQJLARCAAA6DAAyBnqyAqmuEACSBB3OBAE8BCIAACIEAGIUADIEIt4MADAEggQCUgDKEgQBrAYCBCC8BBIMADIA/SAoBABAMAEGRIQv/gCUfgMDAgIKxBQgJCQoKgEk3gAABAQ2AAAEBDoAAAQEPgAABARCEAAEBEYQAAQEShAABAROEAAEBFIwAAQEVjAABARaMAAEBF4wAAQEYnAABARmcAAEBGpwAAQEbmwABARyBffsEBAQFBYHB1QEHgAABAQiEAAGAXSqCAAEBCowAAYAnsooAAYEBMJkAAYEBTJkAAYEBaLkAAYEBpLkAAYIDdYABzoUBvI0BqJ0BkLwBgAIbHLwAAQEdvAABgA9PgH05A9AqAQ==\")),B)})}export{g as configureZlibModule};\n","/*\n Copyright (c) 2025 Gildas Lormeau. All rights reserved.\n\n Redistribution and use in source and binary forms, with or without\n modification, are permitted provided that the following conditions are met:\n\n 1. Redistributions of source code must retain the above copyright notice,\n this list of conditions and the following disclaimer.\n\n 2. Redistributions in binary form must reproduce the above copyright \n notice, this list of conditions and the following disclaimer in \n the documentation and/or other materials provided with the distribution.\n\n 3. The names of the authors may not be used to endorse or promote products\n derived from this software without specific prior written permission.\n\n THIS SOFTWARE IS PROVIDED ''AS IS'' AND ANY EXPRESSED OR IMPLIED WARRANTIES,\n INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND\n FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL JCRAFT,\n INC. OR ANY CONTRIBUTORS TO THIS SOFTWARE BE LIABLE FOR ANY DIRECT, INDIRECT,\n INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT\n LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA,\n OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF\n LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING\n NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE,\n EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.\n */\n\n/* global TransformStream */\n\nlet wasm, malloc, free, memory;\n\nexport function setWasmExports(wasmAPI) {\n\twasm = wasmAPI;\n\t({ malloc, free, memory } = wasm);\n\tif (typeof malloc !== \"function\" || typeof free !== \"function\" || !memory) {\n\t\twasm = malloc = free = memory = null;\n\t\tthrow new Error(\"Invalid WASM module\");\n\t}\n}\n\nfunction _make(isCompress, type, options = {}) {\n\tconst level = (typeof options.level === \"number\") ? options.level : -1;\n\tconst outBufferSize = (typeof options.outBuffer === \"number\") ? options.outBuffer : 64 * 1024;\n\tconst inBufferSize = (typeof options.inBufferSize === \"number\") ? options.inBufferSize : 64 * 1024;\n\n\treturn new TransformStream({\n\t\tstart() {\n\t\t\tlet result;\n\t\t\tthis.out = malloc(outBufferSize);\n\t\t\tthis.in = malloc(inBufferSize);\n\t\t\tthis.inBufferSize = inBufferSize;\n\t\t\tthis._scratch = new Uint8Array(outBufferSize);\n\t\t\tif (isCompress) {\n\t\t\t\tthis._process = wasm.deflate_process;\n\t\t\t\tthis._last_consumed = wasm.deflate_last_consumed;\n\t\t\t\tthis._end = wasm.deflate_end;\n\t\t\t\tthis.streamHandle = wasm.deflate_new();\n\t\t\t\tif (type === \"gzip\") {\n\t\t\t\t\tresult = wasm.deflate_init_gzip(this.streamHandle, level);\n\t\t\t\t} else if (type === \"deflate-raw\") {\n\t\t\t\t\tresult = wasm.deflate_init_raw(this.streamHandle, level);\n\t\t\t\t} else {\n\t\t\t\t\tresult = wasm.deflate_init(this.streamHandle, level);\n\t\t\t\t}\n\t\t\t} else {\n\t\t\t\tif (type === \"deflate64-raw\") {\n\t\t\t\t\tthis._process = wasm.inflate9_process;\n\t\t\t\t\tthis._last_consumed = wasm.inflate9_last_consumed;\n\t\t\t\t\tthis._end = wasm.inflate9_end;\n\t\t\t\t\tthis.streamHandle = wasm.inflate9_new();\n\t\t\t\t\tresult = wasm.inflate9_init_raw(this.streamHandle);\n\t\t\t\t} else {\n\t\t\t\t\tthis._process = wasm.inflate_process;\n\t\t\t\t\tthis._last_consumed = wasm.inflate_last_consumed;\n\t\t\t\t\tthis._end = wasm.inflate_end;\n\t\t\t\t\tthis.streamHandle = wasm.inflate_new();\n\t\t\t\t\tif (type === \"deflate-raw\") {\n\t\t\t\t\t\tresult = wasm.inflate_init_raw(this.streamHandle);\n\t\t\t\t\t} else if (type === \"gzip\") {\n\t\t\t\t\t\tresult = wasm.inflate_init_gzip(this.streamHandle);\n\t\t\t\t\t} else {\n\t\t\t\t\t\tresult = wasm.inflate_init(this.streamHandle);\n\t\t\t\t\t}\n\t\t\t\t}\n\t\t\t}\n\t\t\tif (result !== 0) {\n\t\t\t\tthrow new Error(\"init failed:\" + result);\n\t\t\t}\n\t\t},\n\t\ttransform(chunk, controller) {\n\t\t\ttry {\n\t\t\t\tconst buffer = chunk;\n\t\t\t\tconst heap = new Uint8Array(memory.buffer);\n\t\t\t\tconst process = this._process;\n\t\t\t\tconst last_consumed = this._last_consumed;\n\t\t\t\tconst out = this.out;\n\t\t\t\tconst scratch = this._scratch;\n\t\t\t\tlet offset = 0;\n\t\t\t\twhile (offset < buffer.length) {\n\t\t\t\t\tconst toRead = Math.min(buffer.length - offset, 32 * 1024);\n\t\t\t\t\tif (!this.in || this.inBufferSize < toRead) {\n\t\t\t\t\t\tif (this.in && free) {\n\t\t\t\t\t\t\tfree(this.in);\n\t\t\t\t\t\t}\n\t\t\t\t\t\tthis.in = malloc(toRead);\n\t\t\t\t\t\tthis.inBufferSize = toRead;\n\t\t\t\t\t}\n\t\t\t\t\theap.set(buffer.subarray(offset, offset + toRead), this.in);\n\t\t\t\t\tconst result = process(this.streamHandle, this.in, toRead, out, outBufferSize, 0);\n\t\t\t\t\tconst prod = result & 0x00ffffff;\n\t\t\t\t\tif (prod) {\n\t\t\t\t\t\tscratch.set(heap.subarray(out, out + prod), 0);\n\t\t\t\t\t\tcontroller.enqueue(scratch.slice(0, prod));\n\t\t\t\t\t}\n\t\t\t\t\tif (!isCompress) {\n\t\t\t\t\t\tconst code = (result >> 24) & 0xff;\n\t\t\t\t\t\tconst signedCode = (code & 0x80) ? code - 256 : code;\n\t\t\t\t\t\tif (signedCode < 0) {\n\t\t\t\t\t\t\tthrow new Error(\"process error:\" + signedCode);\n\t\t\t\t\t\t}\n\t\t\t\t\t}\n\t\t\t\t\tconst consumed = last_consumed(this.streamHandle);\n\t\t\t\t\tif (consumed === 0) {\n\t\t\t\t\t\tbreak;\n\t\t\t\t\t}\n\t\t\t\t\toffset += consumed;\n\t\t\t\t}\n\t\t\t} catch (error) {\n\t\t\t\tif (this._end && this.streamHandle) {\n\t\t\t\t\tthis._end(this.streamHandle);\n\t\t\t\t}\n\t\t\t\tif (this.in && free) {\n\t\t\t\t\tfree(this.in);\n\t\t\t\t}\n\t\t\t\tif (this.out && free) {\n\t\t\t\t\tfree(this.out);\n\t\t\t\t}\n\t\t\t\tcontroller.error(error);\n\t\t\t}\n\t\t},\n\t\tflush(controller) {\n\t\t\ttry {\n\t\t\t\tconst heap = new Uint8Array(memory.buffer);\n\t\t\t\tconst process = this._process;\n\t\t\t\tconst out = this.out;\n\t\t\t\tconst scratch = this._scratch;\n\t\t\t\twhile (true) {\n\t\t\t\t\tconst result = process(this.streamHandle, 0, 0, out, outBufferSize, 4);\n\t\t\t\t\tconst produced = result & 0x00ffffff;\n\t\t\t\t\tconst code = (result >> 24) & 0xff;\n\t\t\t\t\tif (!isCompress) {\n\t\t\t\t\t\tconst signedCode = (code & 0x80) ? code - 256 : code;\n\t\t\t\t\t\tif (signedCode < 0) {\n\t\t\t\t\t\t\tthrow new Error(\"process error:\" + signedCode);\n\t\t\t\t\t\t}\n\t\t\t\t\t}\n\t\t\t\t\tif (produced) {\n\t\t\t\t\t\tscratch.set(heap.subarray(out, out + produced), 0);\n\t\t\t\t\t\tcontroller.enqueue(scratch.slice(0, produced));\n\t\t\t\t\t}\n\t\t\t\t\tif (code === 1 || produced === 0) {\n\t\t\t\t\t\tbreak;\n\t\t\t\t\t}\n\t\t\t\t}\n\t\t\t} catch (error) {\n\t\t\t\tcontroller.error(error);\n\t\t\t} finally {\n\t\t\t\tif (this._end && this.streamHandle) {\n\t\t\t\t\tconst result = this._end(this.streamHandle);\n\t\t\t\t\tif (result !== 0) {\n\t\t\t\t\t\tcontroller.error(new Error(\"end error:\" + result));\n\t\t\t\t\t}\n\t\t\t\t}\n\t\t\t\tif (this.in && free) {\n\t\t\t\t\tfree(this.in);\n\t\t\t\t}\n\t\t\t\tif (this.out && free) {\n\t\t\t\t\tfree(this.out);\n\t\t\t\t}\n\t\t\t}\n\t\t}\n\t});\n}\n\nexport class CompressionStreamZlib {\n\tconstructor(type = \"deflate\", options) {\n\t\treturn _make(true, type, options);\n\t}\n}\nexport class DecompressionStreamZlib {\n\tconstructor(type = \"deflate\", options) {\n\t\treturn _make(false, type, options);\n\t}\n}","/*\n Copyright (c) 2025 Gildas Lormeau. All rights reserved.\n\n Redistribution and use in source and binary forms, with or without\n modification, are permitted provided that the following conditions are met:\n\n 1. Redistributions of source code must retain the above copyright notice,\n this list of conditions and the following disclaimer.\n\n 2. Redistributions in binary form must reproduce the above copyright \n notice, this list of conditions and the following disclaimer in \n the documentation and/or other materials provided with the distribution.\n\n 3. The names of the authors may not be used to endorse or promote products\n derived from this software without specific prior written permission.\n\n THIS SOFTWARE IS PROVIDED ''AS IS'' AND ANY EXPRESSED OR IMPLIED WARRANTIES,\n INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND\n FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL JCRAFT,\n INC. OR ANY CONTRIBUTORS TO THIS SOFTWARE BE LIABLE FOR ANY DIRECT, INDIRECT,\n INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT\n LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA,\n OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF\n LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING\n NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE,\n EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.\n */\n\n/* global WebAssembly, URL, fetch, atob */\n\nimport { setWasmExports } from \"./zlib-streams.js\";\n\nlet initializedModule = false;\n\nasync function initModule(wasmURI, { baseURI }) {\n\tif (!initializedModule) {\n\t\tlet arrayBuffer, uri;\n\t\ttry {\n\t\t\ttry {\n\t\t\t\turi = new URL(wasmURI, baseURI);\n\t\t\t} catch {\n\t\t\t\t// ignored\n\t\t\t}\n\t\t\tconst response = await fetch(uri);\n\t\t\tarrayBuffer = await response.arrayBuffer();\n\t\t} catch (error) {\n\t\t\tif (wasmURI.startsWith(\"data:application/wasm;base64,\")) {\n\t\t\t\tarrayBuffer = arrayBufferFromDataURI(wasmURI);\n\t\t\t} else {\n\t\t\t\tthrow error;\n\t\t\t}\n\t\t}\n\t\tconst wasmInstance = await WebAssembly.instantiate(arrayBuffer);\n\t\tsetWasmExports(wasmInstance.instance.exports);\n\t\tinitializedModule = true;\n\t}\n}\n\nfunction resetWasmModule() {\n\tinitializedModule = false;\n}\n\nfunction arrayBufferFromDataURI(dataURI) {\n\tconst base64 = dataURI.split(\",\")[1];\n\tconst binary = atob(base64);\n\tconst len = binary.length;\n\tconst bytes = new Uint8Array(len);\n\tfor (let i = 0; i < len; ++i) {\n\t\tbytes[i] = binary.charCodeAt(i);\n\t}\n\treturn bytes.buffer;\n}\n\nexport {\n\tsetWasmExports,\n\tCompressionStreamZlib,\n\tDecompressionStreamZlib\n} from \"./zlib-streams.js\";\nexport {\n\tinitModule,\n\tresetWasmModule,\n\tinitializedModule\n};","/*\n Copyright (c) 2025 Gildas Lormeau. All rights reserved.\n\n Redistribution and use in source and binary forms, with or without\n modification, are permitted provided that the following conditions are met:\n\n 1. Redistributions of source code must retain the above copyright notice,\n this list of conditions and the following disclaimer.\n\n 2. Redistributions in binary form must reproduce the above copyright\n notice, this list of conditions and the following disclaimer in\n the documentation and/or other materials provided with the distribution.\n\n 3. The names of the authors may not be used to endorse or promote products\n derived from this software without specific prior written permission.\n\n THIS SOFTWARE IS PROVIDED ''AS IS'' AND ANY EXPRESSED OR IMPLIED WARRANTIES,\n INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND\n FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL JCRAFT,\n INC. OR ANY CONTRIBUTORS TO THIS SOFTWARE BE LIABLE FOR ANY DIRECT, INDIRECT,\n INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT\n LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA,\n OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF\n LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING\n NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE,\n EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.\n */\n\nimport { FUNCTION_TYPE } from \"./core/constants.js\";\nimport { configure } from \"./core/configuration.js\";\nimport { configureZlibModule } from \"./core/zlib-streams-inline.js\";\nimport { configureWorker } from \"./core/codec-worker.js\";\nimport { terminateWorkers } from \"./core/codec-pool.js\";\nimport { initModule, resetWasmModule, CompressionStreamZlib, DecompressionStreamZlib } from \"./core/streams/zlib-wasm/zlib-streams-loader.js\";\n\nlet modulePromise;\n\nconfigureZlibModule(configure);\nconfigureWorker({\n\tinitModule: config => {\n\t\tif (!modulePromise) {\n\t\t\tlet { wasmURI } = config;\n\t\t\t// deno-lint-ignore valid-typeof\n\t\t\tif (typeof wasmURI == FUNCTION_TYPE) {\n\t\t\t\twasmURI = wasmURI();\n\t\t\t}\n\t\t\tmodulePromise = initModule(wasmURI, config);\n\n\t\t}\n\t\treturn modulePromise;\n\t}\n});\nconfigure({\n\tCompressionStreamZlib,\n\tDecompressionStreamZlib\n});\n\nexport { terminateWorkersAndModule as terminateWorkers };\n\nfunction terminateWorkersAndModule() {\n\tmodulePromise = null;\n\tterminateWorkers();\n\tresetWasmModule();\n}","/*\n Copyright (c) 2022 Gildas Lormeau. All rights reserved.\n\n Redistribution and use in source and binary forms, with or without\n modification, are permitted provided that the following conditions are met:\n\n 1. Redistributions of source code must retain the above copyright notice,\n this list of conditions and the following disclaimer.\n\n 2. Redistributions in binary form must reproduce the above copyright \n notice, this list of conditions and the following disclaimer in \n the documentation and/or other materials provided with the distribution.\n\n 3. The names of the authors may not be used to endorse or promote products\n derived from this software without specific prior written permission.\n\n THIS SOFTWARE IS PROVIDED ''AS IS'' AND ANY EXPRESSED OR IMPLIED WARRANTIES,\n INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND\n FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL JCRAFT,\n INC. OR ANY CONTRIBUTORS TO THIS SOFTWARE BE LIABLE FOR ANY DIRECT, INDIRECT,\n INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT\n LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA,\n OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF\n LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING\n NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE,\n EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.\n */\n\nimport { getMimeType as getDefaultMimeType } from \"./default-mime-type.js\";\n\nconst table = {\n\t\"application\": {\n\t\t\"andrew-inset\": \"ez\",\n\t\t\"annodex\": \"anx\",\n\t\t\"atom+xml\": \"atom\",\n\t\t\"atomcat+xml\": \"atomcat\",\n\t\t\"atomserv+xml\": \"atomsrv\",\n\t\t\"bbolin\": \"lin\",\n\t\t\"cu-seeme\": \"cu\",\n\t\t\"davmount+xml\": \"davmount\",\n\t\t\"dsptype\": \"tsp\",\n\t\t\"ecmascript\": [\n\t\t\t\"es\",\n\t\t\t\"ecma\"\n\t\t],\n\t\t\"futuresplash\": \"spl\",\n\t\t\"hta\": \"hta\",\n\t\t\"java-archive\": \"jar\",\n\t\t\"java-serialized-object\": \"ser\",\n\t\t\"java-vm\": \"class\",\n\t\t\"m3g\": \"m3g\",\n\t\t\"mac-binhex40\": \"hqx\",\n\t\t\"mathematica\": [\n\t\t\t\"nb\",\n\t\t\t\"ma\",\n\t\t\t\"mb\"\n\t\t],\n\t\t\"msaccess\": \"mdb\",\n\t\t\"msword\": [\n\t\t\t\"doc\",\n\t\t\t\"dot\",\n\t\t\t\"wiz\"\n\t\t],\n\t\t\"mxf\": \"mxf\",\n\t\t\"oda\": \"oda\",\n\t\t\"ogg\": \"ogx\",\n\t\t\"pdf\": \"pdf\",\n\t\t\"pgp-keys\": \"key\",\n\t\t\"pgp-signature\": [\n\t\t\t\"asc\",\n\t\t\t\"sig\"\n\t\t],\n\t\t\"pics-rules\": \"prf\",\n\t\t\"postscript\": [\n\t\t\t\"ps\",\n\t\t\t\"ai\",\n\t\t\t\"eps\",\n\t\t\t\"epsi\",\n\t\t\t\"epsf\",\n\t\t\t\"eps2\",\n\t\t\t\"eps3\"\n\t\t],\n\t\t\"rar\": \"rar\",\n\t\t\"rdf+xml\": \"rdf\",\n\t\t\"rss+xml\": \"rss\",\n\t\t\"rtf\": \"rtf\",\n\t\t\"xhtml+xml\": [\n\t\t\t\"xhtml\",\n\t\t\t\"xht\"\n\t\t],\n\t\t\"xml\": [\n\t\t\t\"xml\",\n\t\t\t\"xsl\",\n\t\t\t\"xsd\",\n\t\t\t\"xpdl\"\n\t\t],\n\t\t\"xspf+xml\": \"xspf\",\n\t\t\"zip\": \"zip\",\n\t\t\"vnd.android.package-archive\": \"apk\",\n\t\t\"vnd.cinderella\": \"cdy\",\n\t\t\"vnd.google-earth.kml+xml\": \"kml\",\n\t\t\"vnd.google-earth.kmz\": \"kmz\",\n\t\t\"vnd.mozilla.xul+xml\": \"xul\",\n\t\t\"vnd.ms-excel\": [\n\t\t\t\"xls\",\n\t\t\t\"xlb\",\n\t\t\t\"xlt\",\n\t\t\t\"xlm\",\n\t\t\t\"xla\",\n\t\t\t\"xlc\",\n\t\t\t\"xlw\"\n\t\t],\n\t\t\"vnd.ms-pki.seccat\": \"cat\",\n\t\t\"vnd.ms-pki.stl\": \"stl\",\n\t\t\"vnd.ms-powerpoint\": [\n\t\t\t\"ppt\",\n\t\t\t\"pps\",\n\t\t\t\"pot\",\n\t\t\t\"ppa\",\n\t\t\t\"pwz\"\n\t\t],\n\t\t\"vnd.oasis.opendocument.chart\": \"odc\",\n\t\t\"vnd.oasis.opendocument.database\": \"odb\",\n\t\t\"vnd.oasis.opendocument.formula\": \"odf\",\n\t\t\"vnd.oasis.opendocument.graphics\": \"odg\",\n\t\t\"vnd.oasis.opendocument.graphics-template\": \"otg\",\n\t\t\"vnd.oasis.opendocument.image\": \"odi\",\n\t\t\"vnd.oasis.opendocument.presentation\": \"odp\",\n\t\t\"vnd.oasis.opendocument.presentation-template\": \"otp\",\n\t\t\"vnd.oasis.opendocument.spreadsheet\": \"ods\",\n\t\t\"vnd.oasis.opendocument.spreadsheet-template\": \"ots\",\n\t\t\"vnd.oasis.opendocument.text\": \"odt\",\n\t\t\"vnd.oasis.opendocument.text-master\": [\n\t\t\t\"odm\",\n\t\t\t\"otm\"\n\t\t],\n\t\t\"vnd.oasis.opendocument.text-template\": \"ott\",\n\t\t\"vnd.oasis.opendocument.text-web\": \"oth\",\n\t\t\"vnd.openxmlformats-officedocument.spreadsheetml.sheet\": \"xlsx\",\n\t\t\"vnd.openxmlformats-officedocument.spreadsheetml.template\": \"xltx\",\n\t\t\"vnd.openxmlformats-officedocument.presentationml.presentation\": \"pptx\",\n\t\t\"vnd.openxmlformats-officedocument.presentationml.slideshow\": \"ppsx\",\n\t\t\"vnd.openxmlformats-officedocument.presentationml.template\": \"potx\",\n\t\t\"vnd.openxmlformats-officedocument.wordprocessingml.document\": \"docx\",\n\t\t\"vnd.openxmlformats-officedocument.wordprocessingml.template\": \"dotx\",\n\t\t\"vnd.smaf\": \"mmf\",\n\t\t\"vnd.stardivision.calc\": \"sdc\",\n\t\t\"vnd.stardivision.chart\": \"sds\",\n\t\t\"vnd.stardivision.draw\": \"sda\",\n\t\t\"vnd.stardivision.impress\": \"sdd\",\n\t\t\"vnd.stardivision.math\": [\n\t\t\t\"sdf\",\n\t\t\t\"smf\"\n\t\t],\n\t\t\"vnd.stardivision.writer\": [\n\t\t\t\"sdw\",\n\t\t\t\"vor\"\n\t\t],\n\t\t\"vnd.stardivision.writer-global\": \"sgl\",\n\t\t\"vnd.sun.xml.calc\": \"sxc\",\n\t\t\"vnd.sun.xml.calc.template\": \"stc\",\n\t\t\"vnd.sun.xml.draw\": \"sxd\",\n\t\t\"vnd.sun.xml.draw.template\": \"std\",\n\t\t\"vnd.sun.xml.impress\": \"sxi\",\n\t\t\"vnd.sun.xml.impress.template\": \"sti\",\n\t\t\"vnd.sun.xml.math\": \"sxm\",\n\t\t\"vnd.sun.xml.writer\": \"sxw\",\n\t\t\"vnd.sun.xml.writer.global\": \"sxg\",\n\t\t\"vnd.sun.xml.writer.template\": \"stw\",\n\t\t\"vnd.symbian.install\": [\n\t\t\t\"sis\",\n\t\t\t\"sisx\"\n\t\t],\n\t\t\"vnd.visio\": [\n\t\t\t\"vsd\",\n\t\t\t\"vst\",\n\t\t\t\"vss\",\n\t\t\t\"vsw\",\n\t\t\t\"vsdx\",\n\t\t\t\"vssx\",\n\t\t\t\"vstx\",\n\t\t\t\"vssm\",\n\t\t\t\"vstm\"\n\t\t],\n\t\t\"vnd.wap.wbxml\": \"wbxml\",\n\t\t\"vnd.wap.wmlc\": \"wmlc\",\n\t\t\"vnd.wap.wmlscriptc\": \"wmlsc\",\n\t\t\"vnd.wordperfect\": \"wpd\",\n\t\t\"vnd.wordperfect5.1\": \"wp5\",\n\t\t\"x-123\": \"wk\",\n\t\t\"x-7z-compressed\": \"7z\",\n\t\t\"x-abiword\": \"abw\",\n\t\t\"x-apple-diskimage\": \"dmg\",\n\t\t\"x-bcpio\": \"bcpio\",\n\t\t\"x-bittorrent\": \"torrent\",\n\t\t\"x-cbr\": [\n\t\t\t\"cbr\",\n\t\t\t\"cba\",\n\t\t\t\"cbt\",\n\t\t\t\"cb7\"\n\t\t],\n\t\t\"x-cbz\": \"cbz\",\n\t\t\"x-cdf\": [\n\t\t\t\"cdf\",\n\t\t\t\"cda\"\n\t\t],\n\t\t\"x-cdlink\": \"vcd\",\n\t\t\"x-chess-pgn\": \"pgn\",\n\t\t\"x-cpio\": \"cpio\",\n\t\t\"x-csh\": \"csh\",\n\t\t\"x-director\": [\n\t\t\t\"dir\",\n\t\t\t\"dxr\",\n\t\t\t\"cst\",\n\t\t\t\"cct\",\n\t\t\t\"cxt\",\n\t\t\t\"w3d\",\n\t\t\t\"fgd\",\n\t\t\t\"swa\"\n\t\t],\n\t\t\"x-dms\": \"dms\",\n\t\t\"x-doom\": \"wad\",\n\t\t\"x-dvi\": \"dvi\",\n\t\t\"x-httpd-eruby\": \"rhtml\",\n\t\t\"x-font\": \"pcf.Z\",\n\t\t\"x-freemind\": \"mm\",\n\t\t\"x-gnumeric\": \"gnumeric\",\n\t\t\"x-go-sgf\": \"sgf\",\n\t\t\"x-graphing-calculator\": \"gcf\",\n\t\t\"x-gtar\": [\n\t\t\t\"gtar\",\n\t\t\t\"taz\"\n\t\t],\n\t\t\"x-hdf\": \"hdf\",\n\t\t\"x-httpd-php\": [\n\t\t\t\"phtml\",\n\t\t\t\"pht\",\n\t\t\t\"php\"\n\t\t],\n\t\t\"x-httpd-php-source\": \"phps\",\n\t\t\"x-httpd-php3\": \"php3\",\n\t\t\"x-httpd-php3-preprocessed\": \"php3p\",\n\t\t\"x-httpd-php4\": \"php4\",\n\t\t\"x-httpd-php5\": \"php5\",\n\t\t\"x-ica\": \"ica\",\n\t\t\"x-info\": \"info\",\n\t\t\"x-internet-signup\": [\n\t\t\t\"ins\",\n\t\t\t\"isp\"\n\t\t],\n\t\t\"x-iphone\": \"iii\",\n\t\t\"x-iso9660-image\": \"iso\",\n\t\t\"x-java-jnlp-file\": \"jnlp\",\n\t\t\"x-jmol\": \"jmz\",\n\t\t\"x-killustrator\": \"kil\",\n\t\t\"x-latex\": \"latex\",\n\t\t\"x-lyx\": \"lyx\",\n\t\t\"x-lzx\": \"lzx\",\n\t\t\"x-maker\": [\n\t\t\t\"frm\",\n\t\t\t\"fb\",\n\t\t\t\"fbdoc\"\n\t\t],\n\t\t\"x-ms-wmd\": \"wmd\",\n\t\t\"x-msdos-program\": [\n\t\t\t\"com\",\n\t\t\t\"exe\",\n\t\t\t\"bat\",\n\t\t\t\"dll\"\n\t\t],\n\t\t\"x-netcdf\": [\n\t\t\t\"nc\"\n\t\t],\n\t\t\"x-ns-proxy-autoconfig\": [\n\t\t\t\"pac\",\n\t\t\t\"dat\"\n\t\t],\n\t\t\"x-nwc\": \"nwc\",\n\t\t\"x-object\": \"o\",\n\t\t\"x-oz-application\": \"oza\",\n\t\t\"x-pkcs7-certreqresp\": \"p7r\",\n\t\t\"x-python-code\": [\n\t\t\t\"pyc\",\n\t\t\t\"pyo\"\n\t\t],\n\t\t\"x-qgis\": [\n\t\t\t\"qgs\",\n\t\t\t\"shp\",\n\t\t\t\"shx\"\n\t\t],\n\t\t\"x-quicktimeplayer\": \"qtl\",\n\t\t\"x-redhat-package-manager\": [\n\t\t\t\"rpm\",\n\t\t\t\"rpa\"\n\t\t],\n\t\t\"x-ruby\": \"rb\",\n\t\t\"x-sh\": \"sh\",\n\t\t\"x-shar\": \"shar\",\n\t\t\"x-shockwave-flash\": [\n\t\t\t\"swf\",\n\t\t\t\"swfl\"\n\t\t],\n\t\t\"x-silverlight\": \"scr\",\n\t\t\"x-stuffit\": \"sit\",\n\t\t\"x-sv4cpio\": \"sv4cpio\",\n\t\t\"x-sv4crc\": \"sv4crc\",\n\t\t\"x-tar\": \"tar\",\n\t\t\"x-tex-gf\": \"gf\",\n\t\t\"x-tex-pk\": \"pk\",\n\t\t\"x-texinfo\": [\n\t\t\t\"texinfo\",\n\t\t\t\"texi\"\n\t\t],\n\t\t\"x-trash\": [\n\t\t\t\"~\",\n\t\t\t\"%\",\n\t\t\t\"bak\",\n\t\t\t\"old\",\n\t\t\t\"sik\"\n\t\t],\n\t\t\"x-ustar\": \"ustar\",\n\t\t\"x-wais-source\": \"src\",\n\t\t\"x-wingz\": \"wz\",\n\t\t\"x-x509-ca-cert\": [\n\t\t\t\"crt\",\n\t\t\t\"der\",\n\t\t\t\"cer\"\n\t\t],\n\t\t\"x-xcf\": \"xcf\",\n\t\t\"x-xfig\": \"fig\",\n\t\t\"x-xpinstall\": \"xpi\",\n\t\t\"applixware\": \"aw\",\n\t\t\"atomsvc+xml\": \"atomsvc\",\n\t\t\"ccxml+xml\": \"ccxml\",\n\t\t\"cdmi-capability\": \"cdmia\",\n\t\t\"cdmi-container\": \"cdmic\",\n\t\t\"cdmi-domain\": \"cdmid\",\n\t\t\"cdmi-object\": \"cdmio\",\n\t\t\"cdmi-queue\": \"cdmiq\",\n\t\t\"docbook+xml\": \"dbk\",\n\t\t\"dssc+der\": \"dssc\",\n\t\t\"dssc+xml\": \"xdssc\",\n\t\t\"emma+xml\": \"emma\",\n\t\t\"epub+zip\": \"epub\",\n\t\t\"exi\": \"exi\",\n\t\t\"font-tdpfr\": \"pfr\",\n\t\t\"gml+xml\": \"gml\",\n\t\t\"gpx+xml\": \"gpx\",\n\t\t\"gxf\": \"gxf\",\n\t\t\"hyperstudio\": \"stk\",\n\t\t\"inkml+xml\": [\n\t\t\t\"ink\",\n\t\t\t\"inkml\"\n\t\t],\n\t\t\"ipfix\": \"ipfix\",\n\t\t\"jsonml+json\": \"jsonml\",\n\t\t\"lost+xml\": \"lostxml\",\n\t\t\"mads+xml\": \"mads\",\n\t\t\"marc\": \"mrc\",\n\t\t\"marcxml+xml\": \"mrcx\",\n\t\t\"mathml+xml\": [\n\t\t\t\"mathml\",\n\t\t\t\"mml\"\n\t\t],\n\t\t\"mbox\": \"mbox\",\n\t\t\"mediaservercontrol+xml\": \"mscml\",\n\t\t\"metalink+xml\": \"metalink\",\n\t\t\"metalink4+xml\": \"meta4\",\n\t\t\"mets+xml\": \"mets\",\n\t\t\"mods+xml\": \"mods\",\n\t\t\"mp21\": [\n\t\t\t\"m21\",\n\t\t\t\"mp21\"\n\t\t],\n\t\t\"mp4\": \"mp4s\",\n\t\t\"oebps-package+xml\": \"opf\",\n\t\t\"omdoc+xml\": \"omdoc\",\n\t\t\"onenote\": [\n\t\t\t\"onetoc\",\n\t\t\t\"onetoc2\",\n\t\t\t\"onetmp\",\n\t\t\t\"onepkg\"\n\t\t],\n\t\t\"oxps\": \"oxps\",\n\t\t\"patch-ops-error+xml\": \"xer\",\n\t\t\"pgp-encrypted\": \"pgp\",\n\t\t\"pkcs10\": \"p10\",\n\t\t\"pkcs7-mime\": [\n\t\t\t\"p7m\",\n\t\t\t\"p7c\"\n\t\t],\n\t\t\"pkcs7-signature\": \"p7s\",\n\t\t\"pkcs8\": \"p8\",\n\t\t\"pkix-attr-cert\": \"ac\",\n\t\t\"pkix-crl\": \"crl\",\n\t\t\"pkix-pkipath\": \"pkipath\",\n\t\t\"pkixcmp\": \"pki\",\n\t\t\"pls+xml\": \"pls\",\n\t\t\"prs.cww\": \"cww\",\n\t\t\"pskc+xml\": \"pskcxml\",\n\t\t\"reginfo+xml\": \"rif\",\n\t\t\"relax-ng-compact-syntax\": \"rnc\",\n\t\t\"resource-lists+xml\": \"rl\",\n\t\t\"resource-lists-diff+xml\": \"rld\",\n\t\t\"rls-services+xml\": \"rs\",\n\t\t\"rpki-ghostbusters\": \"gbr\",\n\t\t\"rpki-manifest\": \"mft\",\n\t\t\"rpki-roa\": \"roa\",\n\t\t\"rsd+xml\": \"rsd\",\n\t\t\"sbml+xml\": \"sbml\",\n\t\t\"scvp-cv-request\": \"scq\",\n\t\t\"scvp-cv-response\": \"scs\",\n\t\t\"scvp-vp-request\": \"spq\",\n\t\t\"scvp-vp-response\": \"spp\",\n\t\t\"sdp\": \"sdp\",\n\t\t\"set-payment-initiation\": \"setpay\",\n\t\t\"set-registration-initiation\": \"setreg\",\n\t\t\"shf+xml\": \"shf\",\n\t\t\"sparql-query\": \"rq\",\n\t\t\"sparql-results+xml\": \"srx\",\n\t\t\"srgs\": \"gram\",\n\t\t\"srgs+xml\": \"grxml\",\n\t\t\"sru+xml\": \"sru\",\n\t\t\"ssdl+xml\": \"ssdl\",\n\t\t\"ssml+xml\": \"ssml\",\n\t\t\"tei+xml\": [\n\t\t\t\"tei\",\n\t\t\t\"teicorpus\"\n\t\t],\n\t\t\"thraud+xml\": \"tfi\",\n\t\t\"timestamped-data\": \"tsd\",\n\t\t\"vnd.3gpp.pic-bw-large\": \"plb\",\n\t\t\"vnd.3gpp.pic-bw-small\": \"psb\",\n\t\t\"vnd.3gpp.pic-bw-var\": \"pvb\",\n\t\t\"vnd.3gpp2.tcap\": \"tcap\",\n\t\t\"vnd.3m.post-it-notes\": \"pwn\",\n\t\t\"vnd.accpac.simply.aso\": \"aso\",\n\t\t\"vnd.accpac.simply.imp\": \"imp\",\n\t\t\"vnd.acucobol\": \"acu\",\n\t\t\"vnd.acucorp\": [\n\t\t\t\"atc\",\n\t\t\t\"acutc\"\n\t\t],\n\t\t\"vnd.adobe.air-application-installer-package+zip\": \"air\",\n\t\t\"vnd.adobe.formscentral.fcdt\": \"fcdt\",\n\t\t\"vnd.adobe.fxp\": [\n\t\t\t\"fxp\",\n\t\t\t\"fxpl\"\n\t\t],\n\t\t\"vnd.adobe.xdp+xml\": \"xdp\",\n\t\t\"vnd.adobe.xfdf\": \"xfdf\",\n\t\t\"vnd.ahead.space\": \"ahead\",\n\t\t\"vnd.airzip.filesecure.azf\": \"azf\",\n\t\t\"vnd.airzip.filesecure.azs\": \"azs\",\n\t\t\"vnd.amazon.ebook\": \"azw\",\n\t\t\"vnd.americandynamics.acc\": \"acc\",\n\t\t\"vnd.amiga.ami\": \"ami\",\n\t\t\"vnd.anser-web-certificate-issue-initiation\": \"cii\",\n\t\t\"vnd.anser-web-funds-transfer-initiation\": \"fti\",\n\t\t\"vnd.antix.game-component\": \"atx\",\n\t\t\"vnd.apple.installer+xml\": \"mpkg\",\n\t\t\"vnd.apple.mpegurl\": \"m3u8\",\n\t\t\"vnd.aristanetworks.swi\": \"swi\",\n\t\t\"vnd.astraea-software.iota\": \"iota\",\n\t\t\"vnd.audiograph\": \"aep\",\n\t\t\"vnd.blueice.multipass\": \"mpm\",\n\t\t\"vnd.bmi\": \"bmi\",\n\t\t\"vnd.businessobjects\": \"rep\",\n\t\t\"vnd.chemdraw+xml\": \"cdxml\",\n\t\t\"vnd.chipnuts.karaoke-mmd\": \"mmd\",\n\t\t\"vnd.claymore\": \"cla\",\n\t\t\"vnd.cloanto.rp9\": \"rp9\",\n\t\t\"vnd.clonk.c4group\": [\n\t\t\t\"c4g\",\n\t\t\t\"c4d\",\n\t\t\t\"c4f\",\n\t\t\t\"c4p\",\n\t\t\t\"c4u\"\n\t\t],\n\t\t\"vnd.cluetrust.cartomobile-config\": \"c11amc\",\n\t\t\"vnd.cluetrust.cartomobile-config-pkg\": \"c11amz\",\n\t\t\"vnd.commonspace\": \"csp\",\n\t\t\"vnd.contact.cmsg\": \"cdbcmsg\",\n\t\t\"vnd.cosmocaller\": \"cmc\",\n\t\t\"vnd.crick.clicker\": \"clkx\",\n\t\t\"vnd.crick.clicker.keyboard\": \"clkk\",\n\t\t\"vnd.crick.clicker.palette\": \"clkp\",\n\t\t\"vnd.crick.clicker.template\": \"clkt\",\n\t\t\"vnd.crick.clicker.wordbank\": \"clkw\",\n\t\t\"vnd.criticaltools.wbs+xml\": \"wbs\",\n\t\t\"vnd.ctc-posml\": \"pml\",\n\t\t\"vnd.cups-ppd\": \"ppd\",\n\t\t\"vnd.curl.car\": \"car\",\n\t\t\"vnd.curl.pcurl\": \"pcurl\",\n\t\t\"vnd.dart\": \"dart\",\n\t\t\"vnd.data-vision.rdz\": \"rdz\",\n\t\t\"vnd.dece.data\": [\n\t\t\t\"uvf\",\n\t\t\t\"uvvf\",\n\t\t\t\"uvd\",\n\t\t\t\"uvvd\"\n\t\t],\n\t\t\"vnd.dece.ttml+xml\": [\n\t\t\t\"uvt\",\n\t\t\t\"uvvt\"\n\t\t],\n\t\t\"vnd.dece.unspecified\": [\n\t\t\t\"uvx\",\n\t\t\t\"uvvx\"\n\t\t],\n\t\t\"vnd.dece.zip\": [\n\t\t\t\"uvz\",\n\t\t\t\"uvvz\"\n\t\t],\n\t\t\"vnd.denovo.fcselayout-link\": \"fe_launch\",\n\t\t\"vnd.dna\": \"dna\",\n\t\t\"vnd.dolby.mlp\": \"mlp\",\n\t\t\"vnd.dpgraph\": \"dpg\",\n\t\t\"vnd.dreamfactory\": \"dfac\",\n\t\t\"vnd.ds-keypoint\": \"kpxx\",\n\t\t\"vnd.dvb.ait\": \"ait\",\n\t\t\"vnd.dvb.service\": \"svc\",\n\t\t\"vnd.dynageo\": \"geo\",\n\t\t\"vnd.ecowin.chart\": \"mag\",\n\t\t\"vnd.enliven\": \"nml\",\n\t\t\"vnd.epson.esf\": \"esf\",\n\t\t\"vnd.epson.msf\": \"msf\",\n\t\t\"vnd.epson.quickanime\": \"qam\",\n\t\t\"vnd.epson.salt\": \"slt\",\n\t\t\"vnd.epson.ssf\": \"ssf\",\n\t\t\"vnd.eszigno3+xml\": [\n\t\t\t\"es3\",\n\t\t\t\"et3\"\n\t\t],\n\t\t\"vnd.ezpix-album\": \"ez2\",\n\t\t\"vnd.ezpix-package\": \"ez3\",\n\t\t\"vnd.fdf\": \"fdf\",\n\t\t\"vnd.fdsn.mseed\": \"mseed\",\n\t\t\"vnd.fdsn.seed\": [\n\t\t\t\"seed\",\n\t\t\t\"dataless\"\n\t\t],\n\t\t\"vnd.flographit\": \"gph\",\n\t\t\"vnd.fluxtime.clip\": \"ftc\",\n\t\t\"vnd.framemaker\": [\n\t\t\t\"fm\",\n\t\t\t\"frame\",\n\t\t\t\"maker\",\n\t\t\t\"book\"\n\t\t],\n\t\t\"vnd.frogans.fnc\": \"fnc\",\n\t\t\"vnd.frogans.ltf\": \"ltf\",\n\t\t\"vnd.fsc.weblaunch\": \"fsc\",\n\t\t\"vnd.fujitsu.oasys\": \"oas\",\n\t\t\"vnd.fujitsu.oasys2\": \"oa2\",\n\t\t\"vnd.fujitsu.oasys3\": \"oa3\",\n\t\t\"vnd.fujitsu.oasysgp\": \"fg5\",\n\t\t\"vnd.fujitsu.oasysprs\": \"bh2\",\n\t\t\"vnd.fujixerox.ddd\": \"ddd\",\n\t\t\"vnd.fujixerox.docuworks\": \"xdw\",\n\t\t\"vnd.fujixerox.docuworks.binder\": \"xbd\",\n\t\t\"vnd.fuzzysheet\": \"fzs\",\n\t\t\"vnd.genomatix.tuxedo\": \"txd\",\n\t\t\"vnd.geogebra.file\": \"ggb\",\n\t\t\"vnd.geogebra.tool\": \"ggt\",\n\t\t\"vnd.geometry-explorer\": [\n\t\t\t\"gex\",\n\t\t\t\"gre\"\n\t\t],\n\t\t\"vnd.geonext\": \"gxt\",\n\t\t\"vnd.geoplan\": \"g2w\",\n\t\t\"vnd.geospace\": \"g3w\",\n\t\t\"vnd.gmx\": \"gmx\",\n\t\t\"vnd.grafeq\": [\n\t\t\t\"gqf\",\n\t\t\t\"gqs\"\n\t\t],\n\t\t\"vnd.groove-account\": \"gac\",\n\t\t\"vnd.groove-help\": \"ghf\",\n\t\t\"vnd.groove-identity-message\": \"gim\",\n\t\t\"vnd.groove-injector\": \"grv\",\n\t\t\"vnd.groove-tool-message\": \"gtm\",\n\t\t\"vnd.groove-tool-template\": \"tpl\",\n\t\t\"vnd.groove-vcard\": \"vcg\",\n\t\t\"vnd.hal+xml\": \"hal\",\n\t\t\"vnd.handheld-entertainment+xml\": \"zmm\",\n\t\t\"vnd.hbci\": \"hbci\",\n\t\t\"vnd.hhe.lesson-player\": \"les\",\n\t\t\"vnd.hp-hpgl\": \"hpgl\",\n\t\t\"vnd.hp-hpid\": \"hpid\",\n\t\t\"vnd.hp-hps\": \"hps\",\n\t\t\"vnd.hp-jlyt\": \"jlt\",\n\t\t\"vnd.hp-pcl\": \"pcl\",\n\t\t\"vnd.hp-pclxl\": \"pclxl\",\n\t\t\"vnd.hydrostatix.sof-data\": \"sfd-hdstx\",\n\t\t\"vnd.ibm.minipay\": \"mpy\",\n\t\t\"vnd.ibm.modcap\": [\n\t\t\t\"afp\",\n\t\t\t\"listafp\",\n\t\t\t\"list3820\"\n\t\t],\n\t\t\"vnd.ibm.rights-management\": \"irm\",\n\t\t\"vnd.ibm.secure-container\": \"sc\",\n\t\t\"vnd.iccprofile\": [\n\t\t\t\"icc\",\n\t\t\t\"icm\"\n\t\t],\n\t\t\"vnd.igloader\": \"igl\",\n\t\t\"vnd.immervision-ivp\": \"ivp\",\n\t\t\"vnd.immervision-ivu\": \"ivu\",\n\t\t\"vnd.insors.igm\": \"igm\",\n\t\t\"vnd.intercon.formnet\": [\n\t\t\t\"xpw\",\n\t\t\t\"xpx\"\n\t\t],\n\t\t\"vnd.intergeo\": \"i2g\",\n\t\t\"vnd.intu.qbo\": \"qbo\",\n\t\t\"vnd.intu.qfx\": \"qfx\",\n\t\t\"vnd.ipunplugged.rcprofile\": \"rcprofile\",\n\t\t\"vnd.irepository.package+xml\": \"irp\",\n\t\t\"vnd.is-xpr\": \"xpr\",\n\t\t\"vnd.isac.fcs\": \"fcs\",\n\t\t\"vnd.jam\": \"jam\",\n\t\t\"vnd.jcp.javame.midlet-rms\": \"rms\",\n\t\t\"vnd.jisp\": \"jisp\",\n\t\t\"vnd.joost.joda-archive\": \"joda\",\n\t\t\"vnd.kahootz\": [\n\t\t\t\"ktz\",\n\t\t\t\"ktr\"\n\t\t],\n\t\t\"vnd.kde.karbon\": \"karbon\",\n\t\t\"vnd.kde.kchart\": \"chrt\",\n\t\t\"vnd.kde.kformula\": \"kfo\",\n\t\t\"vnd.kde.kivio\": \"flw\",\n\t\t\"vnd.kde.kontour\": \"kon\",\n\t\t\"vnd.kde.kpresenter\": [\n\t\t\t\"kpr\",\n\t\t\t\"kpt\"\n\t\t],\n\t\t\"vnd.kde.kspread\": \"ksp\",\n\t\t\"vnd.kde.kword\": [\n\t\t\t\"kwd\",\n\t\t\t\"kwt\"\n\t\t],\n\t\t\"vnd.kenameaapp\": \"htke\",\n\t\t\"vnd.kidspiration\": \"kia\",\n\t\t\"vnd.kinar\": [\n\t\t\t\"kne\",\n\t\t\t\"knp\"\n\t\t],\n\t\t\"vnd.koan\": [\n\t\t\t\"skp\",\n\t\t\t\"skd\",\n\t\t\t\"skt\",\n\t\t\t\"skm\"\n\t\t],\n\t\t\"vnd.kodak-descriptor\": \"sse\",\n\t\t\"vnd.las.las+xml\": \"lasxml\",\n\t\t\"vnd.llamagraphics.life-balance.desktop\": \"lbd\",\n\t\t\"vnd.llamagraphics.life-balance.exchange+xml\": \"lbe\",\n\t\t\"vnd.lotus-1-2-3\": \"123\",\n\t\t\"vnd.lotus-approach\": \"apr\",\n\t\t\"vnd.lotus-freelance\": \"pre\",\n\t\t\"vnd.lotus-notes\": \"nsf\",\n\t\t\"vnd.lotus-organizer\": \"org\",\n\t\t\"vnd.lotus-screencam\": \"scm\",\n\t\t\"vnd.lotus-wordpro\": \"lwp\",\n\t\t\"vnd.macports.portpkg\": \"portpkg\",\n\t\t\"vnd.mcd\": \"mcd\",\n\t\t\"vnd.medcalcdata\": \"mc1\",\n\t\t\"vnd.mediastation.cdkey\": \"cdkey\",\n\t\t\"vnd.mfer\": \"mwf\",\n\t\t\"vnd.mfmp\": \"mfm\",\n\t\t\"vnd.micrografx.flo\": \"flo\",\n\t\t\"vnd.micrografx.igx\": \"igx\",\n\t\t\"vnd.mif\": \"mif\",\n\t\t\"vnd.mobius.daf\": \"daf\",\n\t\t\"vnd.mobius.dis\": \"dis\",\n\t\t\"vnd.mobius.mbk\": \"mbk\",\n\t\t\"vnd.mobius.mqy\": \"mqy\",\n\t\t\"vnd.mobius.msl\": \"msl\",\n\t\t\"vnd.mobius.plc\": \"plc\",\n\t\t\"vnd.mobius.txf\": \"txf\",\n\t\t\"vnd.mophun.application\": \"mpn\",\n\t\t\"vnd.mophun.certificate\": \"mpc\",\n\t\t\"vnd.ms-artgalry\": \"cil\",\n\t\t\"vnd.ms-cab-compressed\": \"cab\",\n\t\t\"vnd.ms-excel.addin.macroenabled.12\": \"xlam\",\n\t\t\"vnd.ms-excel.sheet.binary.macroenabled.12\": \"xlsb\",\n\t\t\"vnd.ms-excel.sheet.macroenabled.12\": \"xlsm\",\n\t\t\"vnd.ms-excel.template.macroenabled.12\": \"xltm\",\n\t\t\"vnd.ms-fontobject\": \"eot\",\n\t\t\"vnd.ms-htmlhelp\": \"chm\",\n\t\t\"vnd.ms-ims\": \"ims\",\n\t\t\"vnd.ms-lrm\": \"lrm\",\n\t\t\"vnd.ms-officetheme\": \"thmx\",\n\t\t\"vnd.ms-powerpoint.addin.macroenabled.12\": \"ppam\",\n\t\t\"vnd.ms-powerpoint.presentation.macroenabled.12\": \"pptm\",\n\t\t\"vnd.ms-powerpoint.slide.macroenabled.12\": \"sldm\",\n\t\t\"vnd.ms-powerpoint.slideshow.macroenabled.12\": \"ppsm\",\n\t\t\"vnd.ms-powerpoint.template.macroenabled.12\": \"potm\",\n\t\t\"vnd.ms-project\": [\n\t\t\t\"mpp\",\n\t\t\t\"mpt\"\n\t\t],\n\t\t\"vnd.ms-word.document.macroenabled.12\": \"docm\",\n\t\t\"vnd.ms-word.template.macroenabled.12\": \"dotm\",\n\t\t\"vnd.ms-works\": [\n\t\t\t\"wps\",\n\t\t\t\"wks\",\n\t\t\t\"wcm\",\n\t\t\t\"wdb\"\n\t\t],\n\t\t\"vnd.ms-wpl\": \"wpl\",\n\t\t\"vnd.ms-xpsdocument\": \"xps\",\n\t\t\"vnd.mseq\": \"mseq\",\n\t\t\"vnd.musician\": \"mus\",\n\t\t\"vnd.muvee.style\": \"msty\",\n\t\t\"vnd.mynfc\": \"taglet\",\n\t\t\"vnd.neurolanguage.nlu\": \"nlu\",\n\t\t\"vnd.nitf\": [\n\t\t\t\"ntf\",\n\t\t\t\"nitf\"\n\t\t],\n\t\t\"vnd.noblenet-directory\": \"nnd\",\n\t\t\"vnd.noblenet-sealer\": \"nns\",\n\t\t\"vnd.noblenet-web\": \"nnw\",\n\t\t\"vnd.nokia.n-gage.data\": \"ngdat\",\n\t\t\"vnd.nokia.n-gage.symbian.install\": \"n-gage\",\n\t\t\"vnd.nokia.radio-preset\": \"rpst\",\n\t\t\"vnd.nokia.radio-presets\": \"rpss\",\n\t\t\"vnd.novadigm.edm\": \"edm\",\n\t\t\"vnd.novadigm.edx\": \"edx\",\n\t\t\"vnd.novadigm.ext\": \"ext\",\n\t\t\"vnd.oasis.opendocument.chart-template\": \"otc\",\n\t\t\"vnd.oasis.opendocument.formula-template\": \"odft\",\n\t\t\"vnd.oasis.opendocument.image-template\": \"oti\",\n\t\t\"vnd.olpc-sugar\": \"xo\",\n\t\t\"vnd.oma.dd2+xml\": \"dd2\",\n\t\t\"vnd.openofficeorg.extension\": \"oxt\",\n\t\t\"vnd.openxmlformats-officedocument.presentationml.slide\": \"sldx\",\n\t\t\"vnd.osgeo.mapguide.package\": \"mgp\",\n\t\t\"vnd.osgi.dp\": \"dp\",\n\t\t\"vnd.osgi.subsystem\": \"esa\",\n\t\t\"vnd.palm\": [\n\t\t\t\"pdb\",\n\t\t\t\"pqa\",\n\t\t\t\"oprc\"\n\t\t],\n\t\t\"vnd.pawaafile\": \"paw\",\n\t\t\"vnd.pg.format\": \"str\",\n\t\t\"vnd.pg.osasli\": \"ei6\",\n\t\t\"vnd.picsel\": \"efif\",\n\t\t\"vnd.pmi.widget\": \"wg\",\n\t\t\"vnd.pocketlearn\": \"plf\",\n\t\t\"vnd.powerbuilder6\": \"pbd\",\n\t\t\"vnd.previewsystems.box\": \"box\",\n\t\t\"vnd.proteus.magazine\": \"mgz\",\n\t\t\"vnd.publishare-delta-tree\": \"qps\",\n\t\t\"vnd.pvi.ptid1\": \"ptid\",\n\t\t\"vnd.quark.quarkxpress\": [\n\t\t\t\"qxd\",\n\t\t\t\"qxt\",\n\t\t\t\"qwd\",\n\t\t\t\"qwt\",\n\t\t\t\"qxl\",\n\t\t\t\"qxb\"\n\t\t],\n\t\t\"vnd.realvnc.bed\": \"bed\",\n\t\t\"vnd.recordare.musicxml\": \"mxl\",\n\t\t\"vnd.recordare.musicxml+xml\": \"musicxml\",\n\t\t\"vnd.rig.cryptonote\": \"cryptonote\",\n\t\t\"vnd.rn-realmedia\": \"rm\",\n\t\t\"vnd.rn-realmedia-vbr\": \"rmvb\",\n\t\t\"vnd.route66.link66+xml\": \"link66\",\n\t\t\"vnd.sailingtracker.track\": \"st\",\n\t\t\"vnd.seemail\": \"see\",\n\t\t\"vnd.sema\": \"sema\",\n\t\t\"vnd.semd\": \"semd\",\n\t\t\"vnd.semf\": \"semf\",\n\t\t\"vnd.shana.informed.formdata\": \"ifm\",\n\t\t\"vnd.shana.informed.formtemplate\": \"itp\",\n\t\t\"vnd.shana.informed.interchange\": \"iif\",\n\t\t\"vnd.shana.informed.package\": \"ipk\",\n\t\t\"vnd.simtech-mindmapper\": [\n\t\t\t\"twd\",\n\t\t\t\"twds\"\n\t\t],\n\t\t\"vnd.smart.teacher\": \"teacher\",\n\t\t\"vnd.solent.sdkm+xml\": [\n\t\t\t\"sdkm\",\n\t\t\t\"sdkd\"\n\t\t],\n\t\t\"vnd.spotfire.dxp\": \"dxp\",\n\t\t\"vnd.spotfire.sfs\": \"sfs\",\n\t\t\"vnd.stepmania.package\": \"smzip\",\n\t\t\"vnd.stepmania.stepchart\": \"sm\",\n\t\t\"vnd.sus-calendar\": [\n\t\t\t\"sus\",\n\t\t\t\"susp\"\n\t\t],\n\t\t\"vnd.svd\": \"svd\",\n\t\t\"vnd.syncml+xml\": \"xsm\",\n\t\t\"vnd.syncml.dm+wbxml\": \"bdm\",\n\t\t\"vnd.syncml.dm+xml\": \"xdm\",\n\t\t\"vnd.tao.intent-module-archive\": \"tao\",\n\t\t\"vnd.tcpdump.pcap\": [\n\t\t\t\"pcap\",\n\t\t\t\"cap\",\n\t\t\t\"dmp\"\n\t\t],\n\t\t\"vnd.tmobile-livetv\": \"tmo\",\n\t\t\"vnd.trid.tpt\": \"tpt\",\n\t\t\"vnd.triscape.mxs\": \"mxs\",\n\t\t\"vnd.trueapp\": \"tra\",\n\t\t\"vnd.ufdl\": [\n\t\t\t\"ufd\",\n\t\t\t\"ufdl\"\n\t\t],\n\t\t\"vnd.uiq.theme\": \"utz\",\n\t\t\"vnd.umajin\": \"umj\",\n\t\t\"vnd.unity\": \"unityweb\",\n\t\t\"vnd.uoml+xml\": \"uoml\",\n\t\t\"vnd.vcx\": \"vcx\",\n\t\t\"vnd.visionary\": \"vis\",\n\t\t\"vnd.vsf\": \"vsf\",\n\t\t\"vnd.webturbo\": \"wtb\",\n\t\t\"vnd.wolfram.player\": \"nbp\",\n\t\t\"vnd.wqd\": \"wqd\",\n\t\t\"vnd.wt.stf\": \"stf\",\n\t\t\"vnd.xara\": \"xar\",\n\t\t\"vnd.xfdl\": \"xfdl\",\n\t\t\"vnd.yamaha.hv-dic\": \"hvd\",\n\t\t\"vnd.yamaha.hv-script\": \"hvs\",\n\t\t\"vnd.yamaha.hv-voice\": \"hvp\",\n\t\t\"vnd.yamaha.openscoreformat\": \"osf\",\n\t\t\"vnd.yamaha.openscoreformat.osfpvg+xml\": \"osfpvg\",\n\t\t\"vnd.yamaha.smaf-audio\": \"saf\",\n\t\t\"vnd.yamaha.smaf-phrase\": \"spf\",\n\t\t\"vnd.yellowriver-custom-menu\": \"cmp\",\n\t\t\"vnd.zul\": [\n\t\t\t\"zir\",\n\t\t\t\"zirz\"\n\t\t],\n\t\t\"vnd.zzazz.deck+xml\": \"zaz\",\n\t\t\"voicexml+xml\": \"vxml\",\n\t\t\"widget\": \"wgt\",\n\t\t\"winhlp\": \"hlp\",\n\t\t\"wsdl+xml\": \"wsdl\",\n\t\t\"wspolicy+xml\": \"wspolicy\",\n\t\t\"x-ace-compressed\": \"ace\",\n\t\t\"x-authorware-bin\": [\n\t\t\t\"aab\",\n\t\t\t\"x32\",\n\t\t\t\"u32\",\n\t\t\t\"vox\"\n\t\t],\n\t\t\"x-authorware-map\": \"aam\",\n\t\t\"x-authorware-seg\": \"aas\",\n\t\t\"x-blorb\": [\n\t\t\t\"blb\",\n\t\t\t\"blorb\"\n\t\t],\n\t\t\"x-bzip\": \"bz\",\n\t\t\"x-bzip2\": [\n\t\t\t\"bz2\",\n\t\t\t\"boz\"\n\t\t],\n\t\t\"x-cfs-compressed\": \"cfs\",\n\t\t\"x-chat\": \"chat\",\n\t\t\"x-conference\": \"nsc\",\n\t\t\"x-dgc-compressed\": \"dgc\",\n\t\t\"x-dtbncx+xml\": \"ncx\",\n\t\t\"x-dtbook+xml\": \"dtb\",\n\t\t\"x-dtbresource+xml\": \"res\",\n\t\t\"x-eva\": \"eva\",\n\t\t\"x-font-bdf\": \"bdf\",\n\t\t\"x-font-ghostscript\": \"gsf\",\n\t\t\"x-font-linux-psf\": \"psf\",\n\t\t\"x-font-pcf\": \"pcf\",\n\t\t\"x-font-snf\": \"snf\",\n\t\t\"x-font-ttf\": [\n\t\t\t\"ttf\",\n\t\t\t\"ttc\"\n\t\t],\n\t\t\"x-font-type1\": [\n\t\t\t\"pfa\",\n\t\t\t\"pfb\",\n\t\t\t\"pfm\",\n\t\t\t\"afm\"\n\t\t],\n\t\t\"x-freearc\": \"arc\",\n\t\t\"x-gca-compressed\": \"gca\",\n\t\t\"x-glulx\": \"ulx\",\n\t\t\"x-gramps-xml\": \"gramps\",\n\t\t\"x-install-instructions\": \"install\",\n\t\t\"x-lzh-compressed\": [\n\t\t\t\"lzh\",\n\t\t\t\"lha\"\n\t\t],\n\t\t\"x-mie\": \"mie\",\n\t\t\"x-mobipocket-ebook\": [\n\t\t\t\"prc\",\n\t\t\t\"mobi\"\n\t\t],\n\t\t\"x-ms-application\": \"application\",\n\t\t\"x-ms-shortcut\": \"lnk\",\n\t\t\"x-ms-xbap\": \"xbap\",\n\t\t\"x-msbinder\": \"obd\",\n\t\t\"x-mscardfile\": \"crd\",\n\t\t\"x-msclip\": \"clp\",\n\t\t\"application/x-ms-installer\": \"msi\",\n\t\t\"x-msmediaview\": [\n\t\t\t\"mvb\",\n\t\t\t\"m13\",\n\t\t\t\"m14\"\n\t\t],\n\t\t\"x-msmetafile\": [\n\t\t\t\"wmf\",\n\t\t\t\"wmz\",\n\t\t\t\"emf\",\n\t\t\t\"emz\"\n\t\t],\n\t\t\"x-msmoney\": \"mny\",\n\t\t\"x-mspublisher\": \"pub\",\n\t\t\"x-msschedule\": \"scd\",\n\t\t\"x-msterminal\": \"trm\",\n\t\t\"x-mswrite\": \"wri\",\n\t\t\"x-nzb\": \"nzb\",\n\t\t\"x-pkcs12\": [\n\t\t\t\"p12\",\n\t\t\t\"pfx\"\n\t\t],\n\t\t\"x-pkcs7-certificates\": [\n\t\t\t\"p7b\",\n\t\t\t\"spc\"\n\t\t],\n\t\t\"x-research-info-systems\": \"ris\",\n\t\t\"x-silverlight-app\": \"xap\",\n\t\t\"x-sql\": \"sql\",\n\t\t\"x-stuffitx\": \"sitx\",\n\t\t\"x-subrip\": \"srt\",\n\t\t\"x-t3vm-image\": \"t3\",\n\t\t\"x-tex-tfm\": \"tfm\",\n\t\t\"x-tgif\": \"obj\",\n\t\t\"x-xliff+xml\": \"xlf\",\n\t\t\"x-xz\": \"xz\",\n\t\t\"x-zmachine\": [\n\t\t\t\"z1\",\n\t\t\t\"z2\",\n\t\t\t\"z3\",\n\t\t\t\"z4\",\n\t\t\t\"z5\",\n\t\t\t\"z6\",\n\t\t\t\"z7\",\n\t\t\t\"z8\"\n\t\t],\n\t\t\"xaml+xml\": \"xaml\",\n\t\t\"xcap-diff+xml\": \"xdf\",\n\t\t\"xenc+xml\": \"xenc\",\n\t\t\"xml-dtd\": \"dtd\",\n\t\t\"xop+xml\": \"xop\",\n\t\t\"xproc+xml\": \"xpl\",\n\t\t\"xslt+xml\": \"xslt\",\n\t\t\"xv+xml\": [\n\t\t\t\"mxml\",\n\t\t\t\"xhvml\",\n\t\t\t\"xvml\",\n\t\t\t\"xvm\"\n\t\t],\n\t\t\"yang\": \"yang\",\n\t\t\"yin+xml\": \"yin\",\n\t\t\"envoy\": \"evy\",\n\t\t\"fractals\": \"fif\",\n\t\t\"internet-property-stream\": \"acx\",\n\t\t\"olescript\": \"axs\",\n\t\t\"vnd.ms-outlook\": \"msg\",\n\t\t\"vnd.ms-pkicertstore\": \"sst\",\n\t\t\"x-compress\": \"z\",\n\t\t\"x-perfmon\": [\n\t\t\t\"pma\",\n\t\t\t\"pmc\",\n\t\t\t\"pmr\",\n\t\t\t\"pmw\"\n\t\t],\n\t\t\"ynd.ms-pkipko\": \"pko\",\n\t\t\"gzip\": [\n\t\t\t\"gz\",\n\t\t\t\"tgz\"\n\t\t],\n\t\t\"smil+xml\": [\n\t\t\t\"smi\",\n\t\t\t\"smil\"\n\t\t],\n\t\t\"vnd.debian.binary-package\": [\n\t\t\t\"deb\",\n\t\t\t\"udeb\"\n\t\t],\n\t\t\"vnd.hzn-3d-crossword\": \"x3d\",\n\t\t\"vnd.sqlite3\": [\n\t\t\t\"db\",\n\t\t\t\"sqlite\",\n\t\t\t\"sqlite3\",\n\t\t\t\"db-wal\",\n\t\t\t\"sqlite-wal\",\n\t\t\t\"db-shm\",\n\t\t\t\"sqlite-shm\"\n\t\t],\n\t\t\"vnd.wap.sic\": \"sic\",\n\t\t\"vnd.wap.slc\": \"slc\",\n\t\t\"x-krita\": [\n\t\t\t\"kra\",\n\t\t\t\"krz\"\n\t\t],\n\t\t\"x-perl\": [\n\t\t\t\"pm\",\n\t\t\t\"pl\"\n\t\t],\n\t\t\"yaml\": [\n\t\t\t\"yaml\",\n\t\t\t\"yml\"\n\t\t]\n\t},\n\t\"audio\": {\n\t\t\"amr\": \"amr\",\n\t\t\"amr-wb\": \"awb\",\n\t\t\"annodex\": \"axa\",\n\t\t\"basic\": [\n\t\t\t\"au\",\n\t\t\t\"snd\"\n\t\t],\n\t\t\"flac\": \"flac\",\n\t\t\"midi\": [\n\t\t\t\"mid\",\n\t\t\t\"midi\",\n\t\t\t\"kar\",\n\t\t\t\"rmi\"\n\t\t],\n\t\t\"mpeg\": [\n\t\t\t\"mpga\",\n\t\t\t\"mpega\",\n\t\t\t\"mp3\",\n\t\t\t\"m4a\",\n\t\t\t\"mp2a\",\n\t\t\t\"m2a\",\n\t\t\t\"m3a\"\n\t\t],\n\t\t\"mpegurl\": \"m3u\",\n\t\t\"ogg\": [\n\t\t\t\"oga\",\n\t\t\t\"ogg\",\n\t\t\t\"spx\"\n\t\t],\n\t\t\"prs.sid\": \"sid\",\n\t\t\"x-aiff\": \"aifc\",\n\t\t\"x-gsm\": \"gsm\",\n\t\t\"x-ms-wma\": \"wma\",\n\t\t\"x-ms-wax\": \"wax\",\n\t\t\"x-pn-realaudio\": \"ram\",\n\t\t\"x-realaudio\": \"ra\",\n\t\t\"x-sd2\": \"sd2\",\n\t\t\"adpcm\": \"adp\",\n\t\t\"mp4\": \"mp4a\",\n\t\t\"s3m\": \"s3m\",\n\t\t\"silk\": \"sil\",\n\t\t\"vnd.dece.audio\": [\n\t\t\t\"uva\",\n\t\t\t\"uvva\"\n\t\t],\n\t\t\"vnd.digital-winds\": \"eol\",\n\t\t\"vnd.dra\": \"dra\",\n\t\t\"vnd.dts\": \"dts\",\n\t\t\"vnd.dts.hd\": \"dtshd\",\n\t\t\"vnd.lucent.voice\": \"lvp\",\n\t\t\"vnd.ms-playready.media.pya\": \"pya\",\n\t\t\"vnd.nuera.ecelp4800\": \"ecelp4800\",\n\t\t\"vnd.nuera.ecelp7470\": \"ecelp7470\",\n\t\t\"vnd.nuera.ecelp9600\": \"ecelp9600\",\n\t\t\"vnd.rip\": \"rip\",\n\t\t\"webm\": \"weba\",\n\t\t\"x-caf\": \"caf\",\n\t\t\"x-matroska\": \"mka\",\n\t\t\"x-pn-realaudio-plugin\": \"rmp\",\n\t\t\"xm\": \"xm\",\n\t\t\"aac\": \"aac\",\n\t\t\"aiff\": [\n\t\t\t\"aiff\",\n\t\t\t\"aif\",\n\t\t\t\"aff\"\n\t\t],\n\t\t\"opus\": \"opus\",\n\t\t\"wav\": \"wav\"\n\t},\n\t\"chemical\": {\n\t\t\"x-alchemy\": \"alc\",\n\t\t\"x-cache\": [\n\t\t\t\"cac\",\n\t\t\t\"cache\"\n\t\t],\n\t\t\"x-cache-csf\": \"csf\",\n\t\t\"x-cactvs-binary\": [\n\t\t\t\"cbin\",\n\t\t\t\"cascii\",\n\t\t\t\"ctab\"\n\t\t],\n\t\t\"x-cdx\": \"cdx\",\n\t\t\"x-chem3d\": \"c3d\",\n\t\t\"x-cif\": \"cif\",\n\t\t\"x-cmdf\": \"cmdf\",\n\t\t\"x-cml\": \"cml\",\n\t\t\"x-compass\": \"cpa\",\n\t\t\"x-crossfire\": \"bsd\",\n\t\t\"x-csml\": [\n\t\t\t\"csml\",\n\t\t\t\"csm\"\n\t\t],\n\t\t\"x-ctx\": \"ctx\",\n\t\t\"x-cxf\": [\n\t\t\t\"cxf\",\n\t\t\t\"cef\"\n\t\t],\n\t\t\"x-embl-dl-nucleotide\": [\n\t\t\t\"emb\",\n\t\t\t\"embl\"\n\t\t],\n\t\t\"x-gamess-input\": [\n\t\t\t\"inp\",\n\t\t\t\"gam\",\n\t\t\t\"gamin\"\n\t\t],\n\t\t\"x-gaussian-checkpoint\": [\n\t\t\t\"fch\",\n\t\t\t\"fchk\"\n\t\t],\n\t\t\"x-gaussian-cube\": \"cub\",\n\t\t\"x-gaussian-input\": [\n\t\t\t\"gau\",\n\t\t\t\"gjc\",\n\t\t\t\"gjf\"\n\t\t],\n\t\t\"x-gaussian-log\": \"gal\",\n\t\t\"x-gcg8-sequence\": \"gcg\",\n\t\t\"x-genbank\": \"gen\",\n\t\t\"x-hin\": \"hin\",\n\t\t\"x-isostar\": [\n\t\t\t\"istr\",\n\t\t\t\"ist\"\n\t\t],\n\t\t\"x-jcamp-dx\": [\n\t\t\t\"jdx\",\n\t\t\t\"dx\"\n\t\t],\n\t\t\"x-kinemage\": \"kin\",\n\t\t\"x-macmolecule\": \"mcm\",\n\t\t\"x-macromodel-input\": \"mmod\",\n\t\t\"x-mdl-molfile\": \"mol\",\n\t\t\"x-mdl-rdfile\": \"rd\",\n\t\t\"x-mdl-rxnfile\": \"rxn\",\n\t\t\"x-mdl-sdfile\": \"sd\",\n\t\t\"x-mdl-tgf\": \"tgf\",\n\t\t\"x-mmcif\": \"mcif\",\n\t\t\"x-mol2\": \"mol2\",\n\t\t\"x-molconn-Z\": \"b\",\n\t\t\"x-mopac-graph\": \"gpt\",\n\t\t\"x-mopac-input\": [\n\t\t\t\"mop\",\n\t\t\t\"mopcrt\",\n\t\t\t\"zmt\"\n\t\t],\n\t\t\"x-mopac-out\": \"moo\",\n\t\t\"x-ncbi-asn1\": \"asn\",\n\t\t\"x-ncbi-asn1-ascii\": [\n\t\t\t\"prt\",\n\t\t\t\"ent\"\n\t\t],\n\t\t\"x-ncbi-asn1-binary\": \"val\",\n\t\t\"x-rosdal\": \"ros\",\n\t\t\"x-swissprot\": \"sw\",\n\t\t\"x-vamas-iso14976\": \"vms\",\n\t\t\"x-vmd\": \"vmd\",\n\t\t\"x-xtel\": \"xtel\",\n\t\t\"x-xyz\": \"xyz\"\n\t},\n\t\"font\": {\n\t\t\"otf\": \"otf\",\n\t\t\"woff\": \"woff\",\n\t\t\"woff2\": \"woff2\"\n\t},\n\t\"image\": {\n\t\t\"gif\": \"gif\",\n\t\t\"ief\": \"ief\",\n\t\t\"jpeg\": [\n\t\t\t\"jpeg\",\n\t\t\t\"jpg\",\n\t\t\t\"jpe\",\n\t\t\t\"jfif\",\n\t\t\t\"jfif-tbnl\",\n\t\t\t\"jif\"\n\t\t],\n\t\t\"pcx\": \"pcx\",\n\t\t\"png\": \"png\",\n\t\t\"svg+xml\": [\n\t\t\t\"svg\",\n\t\t\t\"svgz\"\n\t\t],\n\t\t\"tiff\": [\n\t\t\t\"tiff\",\n\t\t\t\"tif\"\n\t\t],\n\t\t\"vnd.djvu\": [\n\t\t\t\"djvu\",\n\t\t\t\"djv\"\n\t\t],\n\t\t\"vnd.wap.wbmp\": \"wbmp\",\n\t\t\"x-canon-cr2\": \"cr2\",\n\t\t\"x-canon-crw\": \"crw\",\n\t\t\"x-cmu-raster\": \"ras\",\n\t\t\"x-coreldraw\": \"cdr\",\n\t\t\"x-coreldrawpattern\": \"pat\",\n\t\t\"x-coreldrawtemplate\": \"cdt\",\n\t\t\"x-corelphotopaint\": \"cpt\",\n\t\t\"x-epson-erf\": \"erf\",\n\t\t\"x-icon\": \"ico\",\n\t\t\"x-jg\": \"art\",\n\t\t\"x-jng\": \"jng\",\n\t\t\"x-nikon-nef\": \"nef\",\n\t\t\"x-olympus-orf\": \"orf\",\n\t\t\"x-portable-anymap\": \"pnm\",\n\t\t\"x-portable-bitmap\": \"pbm\",\n\t\t\"x-portable-graymap\": \"pgm\",\n\t\t\"x-portable-pixmap\": \"ppm\",\n\t\t\"x-rgb\": \"rgb\",\n\t\t\"x-xbitmap\": \"xbm\",\n\t\t\"x-xpixmap\": \"xpm\",\n\t\t\"x-xwindowdump\": \"xwd\",\n\t\t\"bmp\": \"bmp\",\n\t\t\"cgm\": \"cgm\",\n\t\t\"g3fax\": \"g3\",\n\t\t\"ktx\": \"ktx\",\n\t\t\"prs.btif\": \"btif\",\n\t\t\"sgi\": \"sgi\",\n\t\t\"vnd.dece.graphic\": [\n\t\t\t\"uvi\",\n\t\t\t\"uvvi\",\n\t\t\t\"uvg\",\n\t\t\t\"uvvg\"\n\t\t],\n\t\t\"vnd.dwg\": \"dwg\",\n\t\t\"vnd.dxf\": \"dxf\",\n\t\t\"vnd.fastbidsheet\": \"fbs\",\n\t\t\"vnd.fpx\": \"fpx\",\n\t\t\"vnd.fst\": \"fst\",\n\t\t\"vnd.fujixerox.edmics-mmr\": \"mmr\",\n\t\t\"vnd.fujixerox.edmics-rlc\": \"rlc\",\n\t\t\"vnd.ms-modi\": \"mdi\",\n\t\t\"vnd.ms-photo\": \"wdp\",\n\t\t\"vnd.net-fpx\": \"npx\",\n\t\t\"vnd.xiff\": \"xif\",\n\t\t\"webp\": \"webp\",\n\t\t\"x-3ds\": \"3ds\",\n\t\t\"x-cmx\": \"cmx\",\n\t\t\"x-freehand\": [\n\t\t\t\"fh\",\n\t\t\t\"fhc\",\n\t\t\t\"fh4\",\n\t\t\t\"fh5\",\n\t\t\t\"fh7\"\n\t\t],\n\t\t\"x-pict\": [\n\t\t\t\"pic\",\n\t\t\t\"pct\"\n\t\t],\n\t\t\"x-tga\": \"tga\",\n\t\t\"cis-cod\": \"cod\",\n\t\t\"avif\": \"avifs\",\n\t\t\"heic\": [\n\t\t\t\"heif\",\n\t\t\t\"heic\"\n\t\t],\n\t\t\"pjpeg\": [\n\t\t\t\"pjpg\"\n\t\t],\n\t\t\"vnd.adobe.photoshop\": \"psd\",\n\t\t\"x-adobe-dng\": \"dng\",\n\t\t\"x-fuji-raf\": \"raf\",\n\t\t\"x-icns\": \"icns\",\n\t\t\"x-kodak-dcr\": \"dcr\",\n\t\t\"x-kodak-k25\": \"k25\",\n\t\t\"x-kodak-kdc\": \"kdc\",\n\t\t\"x-minolta-mrw\": \"mrw\",\n\t\t\"x-panasonic-raw\": [\n\t\t\t\"raw\",\n\t\t\t\"rw2\",\n\t\t\t\"rwl\"\n\t\t],\n\t\t\"x-pentax-pef\": [\n\t\t\t\"pef\",\n\t\t\t\"ptx\"\n\t\t],\n\t\t\"x-sigma-x3f\": \"x3f\",\n\t\t\"x-sony-arw\": \"arw\",\n\t\t\"x-sony-sr2\": \"sr2\",\n\t\t\"x-sony-srf\": \"srf\"\n\t},\n\t\"message\": {\n\t\t\"rfc822\": [\n\t\t\t\"eml\",\n\t\t\t\"mime\",\n\t\t\t\"mht\",\n\t\t\t\"mhtml\",\n\t\t\t\"nws\"\n\t\t]\n\t},\n\t\"model\": {\n\t\t\"iges\": [\n\t\t\t\"igs\",\n\t\t\t\"iges\"\n\t\t],\n\t\t\"mesh\": [\n\t\t\t\"msh\",\n\t\t\t\"mesh\",\n\t\t\t\"silo\"\n\t\t],\n\t\t\"vrml\": [\n\t\t\t\"wrl\",\n\t\t\t\"vrml\"\n\t\t],\n\t\t\"x3d+vrml\": [\n\t\t\t\"x3dv\",\n\t\t\t\"x3dvz\"\n\t\t],\n\t\t\"x3d+xml\": \"x3dz\",\n\t\t\"x3d+binary\": [\n\t\t\t\"x3db\",\n\t\t\t\"x3dbz\"\n\t\t],\n\t\t\"vnd.collada+xml\": \"dae\",\n\t\t\"vnd.dwf\": \"dwf\",\n\t\t\"vnd.gdl\": \"gdl\",\n\t\t\"vnd.gtw\": \"gtw\",\n\t\t\"vnd.mts\": \"mts\",\n\t\t\"vnd.usdz+zip\": \"usdz\",\n\t\t\"vnd.vtu\": \"vtu\"\n\t},\n\t\"text\": {\n\t\t\"cache-manifest\": [\n\t\t\t\"manifest\",\n\t\t\t\"appcache\"\n\t\t],\n\t\t\"calendar\": [\n\t\t\t\"ics\",\n\t\t\t\"icz\",\n\t\t\t\"ifb\"\n\t\t],\n\t\t\"css\": \"css\",\n\t\t\"csv\": \"csv\",\n\t\t\"h323\": \"323\",\n\t\t\"html\": [\n\t\t\t\"html\",\n\t\t\t\"htm\",\n\t\t\t\"shtml\",\n\t\t\t\"stm\"\n\t\t],\n\t\t\"iuls\": \"uls\",\n\t\t\"plain\": [\n\t\t\t\"txt\",\n\t\t\t\"text\",\n\t\t\t\"brf\",\n\t\t\t\"conf\",\n\t\t\t\"def\",\n\t\t\t\"list\",\n\t\t\t\"log\",\n\t\t\t\"in\",\n\t\t\t\"bas\",\n\t\t\t\"diff\",\n\t\t\t\"ksh\"\n\t\t],\n\t\t\"richtext\": \"rtx\",\n\t\t\"scriptlet\": [\n\t\t\t\"sct\",\n\t\t\t\"wsc\"\n\t\t],\n\t\t\"texmacs\": \"tm\",\n\t\t\"tab-separated-values\": \"tsv\",\n\t\t\"vnd.sun.j2me.app-descriptor\": \"jad\",\n\t\t\"vnd.wap.wml\": \"wml\",\n\t\t\"vnd.wap.wmlscript\": \"wmls\",\n\t\t\"x-bibtex\": \"bib\",\n\t\t\"x-boo\": \"boo\",\n\t\t\"x-c++hdr\": [\n\t\t\t\"h++\",\n\t\t\t\"hpp\",\n\t\t\t\"hxx\",\n\t\t\t\"hh\"\n\t\t],\n\t\t\"x-c++src\": [\n\t\t\t\"c++\",\n\t\t\t\"cpp\",\n\t\t\t\"cxx\",\n\t\t\t\"cc\"\n\t\t],\n\t\t\"x-component\": \"htc\",\n\t\t\"x-dsrc\": \"d\",\n\t\t\"x-diff\": \"patch\",\n\t\t\"x-haskell\": \"hs\",\n\t\t\"x-java\": \"java\",\n\t\t\"x-literate-haskell\": \"lhs\",\n\t\t\"x-moc\": \"moc\",\n\t\t\"x-pascal\": [\n\t\t\t\"p\",\n\t\t\t\"pas\",\n\t\t\t\"pp\",\n\t\t\t\"inc\"\n\t\t],\n\t\t\"x-pcs-gcd\": \"gcd\",\n\t\t\"x-python\": \"py\",\n\t\t\"x-scala\": \"scala\",\n\t\t\"x-setext\": \"etx\",\n\t\t\"x-tcl\": [\n\t\t\t\"tcl\",\n\t\t\t\"tk\"\n\t\t],\n\t\t\"x-tex\": [\n\t\t\t\"tex\",\n\t\t\t\"ltx\",\n\t\t\t\"sty\",\n\t\t\t\"cls\"\n\t\t],\n\t\t\"x-vcalendar\": \"vcs\",\n\t\t\"x-vcard\": \"vcf\",\n\t\t\"n3\": \"n3\",\n\t\t\"prs.lines.tag\": \"dsc\",\n\t\t\"sgml\": [\n\t\t\t\"sgml\",\n\t\t\t\"sgm\"\n\t\t],\n\t\t\"troff\": [\n\t\t\t\"t\",\n\t\t\t\"tr\",\n\t\t\t\"roff\",\n\t\t\t\"man\",\n\t\t\t\"me\",\n\t\t\t\"ms\"\n\t\t],\n\t\t\"turtle\": \"ttl\",\n\t\t\"uri-list\": [\n\t\t\t\"uri\",\n\t\t\t\"uris\",\n\t\t\t\"urls\"\n\t\t],\n\t\t\"vcard\": \"vcard\",\n\t\t\"vnd.curl\": \"curl\",\n\t\t\"vnd.curl.dcurl\": \"dcurl\",\n\t\t\"vnd.curl.scurl\": \"scurl\",\n\t\t\"vnd.curl.mcurl\": \"mcurl\",\n\t\t\"vnd.dvb.subtitle\": \"sub\",\n\t\t\"vnd.fly\": \"fly\",\n\t\t\"vnd.fmi.flexstor\": \"flx\",\n\t\t\"vnd.graphviz\": \"gv\",\n\t\t\"vnd.in3d.3dml\": \"3dml\",\n\t\t\"vnd.in3d.spot\": \"spot\",\n\t\t\"x-asm\": [\n\t\t\t\"s\",\n\t\t\t\"asm\"\n\t\t],\n\t\t\"x-c\": [\n\t\t\t\"c\",\n\t\t\t\"h\",\n\t\t\t\"dic\"\n\t\t],\n\t\t\"x-fortran\": [\n\t\t\t\"f\",\n\t\t\t\"for\",\n\t\t\t\"f77\",\n\t\t\t\"f90\"\n\t\t],\n\t\t\"x-opml\": \"opml\",\n\t\t\"x-nfo\": \"nfo\",\n\t\t\"x-sfv\": \"sfv\",\n\t\t\"x-uuencode\": \"uu\",\n\t\t\"webviewhtml\": \"htt\",\n\t\t\"javascript\": \"js\",\n\t\t\"json\": \"json\",\n\t\t\"markdown\": [\n\t\t\t\"md\",\n\t\t\t\"markdown\",\n\t\t\t\"mdown\",\n\t\t\t\"markdn\"\n\t\t],\n\t\t\"vnd.wap.si\": \"si\",\n\t\t\"vnd.wap.sl\": \"sl\"\n\t},\n\t\"video\": {\n\t\t\"avif\": \"avif\",\n\t\t\"3gpp\": \"3gp\",\n\t\t\"annodex\": \"axv\",\n\t\t\"dl\": \"dl\",\n\t\t\"dv\": [\n\t\t\t\"dif\",\n\t\t\t\"dv\"\n\t\t],\n\t\t\"fli\": \"fli\",\n\t\t\"gl\": \"gl\",\n\t\t\"mpeg\": [\n\t\t\t\"mpeg\",\n\t\t\t\"mpg\",\n\t\t\t\"mpe\",\n\t\t\t\"m1v\",\n\t\t\t\"m2v\",\n\t\t\t\"mp2\",\n\t\t\t\"mpa\",\n\t\t\t\"mpv2\"\n\t\t],\n\t\t\"mp4\": [\n\t\t\t\"mp4\",\n\t\t\t\"mp4v\",\n\t\t\t\"mpg4\"\n\t\t],\n\t\t\"quicktime\": [\n\t\t\t\"qt\",\n\t\t\t\"mov\"\n\t\t],\n\t\t\"ogg\": \"ogv\",\n\t\t\"vnd.mpegurl\": [\n\t\t\t\"mxu\",\n\t\t\t\"m4u\"\n\t\t],\n\t\t\"x-flv\": \"flv\",\n\t\t\"x-la-asf\": [\n\t\t\t\"lsf\",\n\t\t\t\"lsx\"\n\t\t],\n\t\t\"x-mng\": \"mng\",\n\t\t\"x-ms-asf\": [\n\t\t\t\"asf\",\n\t\t\t\"asx\",\n\t\t\t\"asr\"\n\t\t],\n\t\t\"x-ms-wm\": \"wm\",\n\t\t\"x-ms-wmv\": \"wmv\",\n\t\t\"x-ms-wmx\": \"wmx\",\n\t\t\"x-ms-wvx\": \"wvx\",\n\t\t\"x-msvideo\": \"avi\",\n\t\t\"x-sgi-movie\": \"movie\",\n\t\t\"x-matroska\": [\n\t\t\t\"mpv\",\n\t\t\t\"mkv\",\n\t\t\t\"mk3d\",\n\t\t\t\"mks\"\n\t\t],\n\t\t\"3gpp2\": \"3g2\",\n\t\t\"h261\": \"h261\",\n\t\t\"h263\": \"h263\",\n\t\t\"h264\": \"h264\",\n\t\t\"jpeg\": \"jpgv\",\n\t\t\"jpm\": [\n\t\t\t\"jpm\",\n\t\t\t\"jpgm\"\n\t\t],\n\t\t\"mj2\": [\n\t\t\t\"mj2\",\n\t\t\t\"mjp2\"\n\t\t],\n\t\t\"vnd.dece.hd\": [\n\t\t\t\"uvh\",\n\t\t\t\"uvvh\"\n\t\t],\n\t\t\"vnd.dece.mobile\": [\n\t\t\t\"uvm\",\n\t\t\t\"uvvm\"\n\t\t],\n\t\t\"vnd.dece.pd\": [\n\t\t\t\"uvp\",\n\t\t\t\"uvvp\"\n\t\t],\n\t\t\"vnd.dece.sd\": [\n\t\t\t\"uvs\",\n\t\t\t\"uvvs\"\n\t\t],\n\t\t\"vnd.dece.video\": [\n\t\t\t\"uvv\",\n\t\t\t\"uvvv\"\n\t\t],\n\t\t\"vnd.dvb.file\": \"dvb\",\n\t\t\"vnd.fvt\": \"fvt\",\n\t\t\"vnd.ms-playready.media.pyv\": \"pyv\",\n\t\t\"vnd.uvvu.mp4\": [\n\t\t\t\"uvu\",\n\t\t\t\"uvvu\"\n\t\t],\n\t\t\"vnd.vivo\": \"viv\",\n\t\t\"webm\": \"webm\",\n\t\t\"x-f4v\": \"f4v\",\n\t\t\"x-m4v\": \"m4v\",\n\t\t\"x-ms-vob\": \"vob\",\n\t\t\"x-smv\": \"smv\",\n\t\t\"mp2t\": \"ts\"\n\t},\n\t\"x-conference\": {\n\t\t\"x-cooltalk\": \"ice\"\n\t},\n\t\"x-world\": {\n\t\t\"x-vrml\": [\n\t\t\t\"vrm\",\n\t\t\t\"flr\",\n\t\t\t\"wrz\",\n\t\t\t\"xaf\",\n\t\t\t\"xof\"\n\t\t]\n\t}\n};\n\nconst mimeTypes = (() => {\n\tconst mimeTypes = {};\n\tfor (const type of Object.keys(table)) {\n\t\tfor (const subtype of Object.keys(table[type])) {\n\t\t\tconst value = table[type][subtype];\n\t\t\tif (typeof value == \"string\") {\n\t\t\t\tmimeTypes[value] = type + \"/\" + subtype;\n\t\t\t} else {\n\t\t\t\tfor (let indexMimeType = 0; indexMimeType < value.length; indexMimeType++) {\n\t\t\t\t\tmimeTypes[value[indexMimeType]] = type + \"/\" + subtype;\n\t\t\t\t}\n\t\t\t}\n\t\t}\n\t}\n\treturn mimeTypes;\n})();\n\nexport {\n\tmimeTypes,\n\tgetMimeType\n};\n\nfunction getMimeType(filename) {\n\treturn filename && mimeTypes[filename.split(\".\").pop().toLowerCase()] || getDefaultMimeType();\n}","import { TimeoutError } from \"./errors\";\n\n/**\n * Callback for progress updates while flashing or uploading an image.\n *\n * @callback FlashProgressCallback\n * @param {number} progress - Progress for the current action, between 0 and 1.\n */\nexport type FlashProgressCallback = (progress: number) => void;\n\n/**\n * Callback for factory image flashing progress.\n *\n * @callback FactoryProgressCallback\n * @param {string} action - Action in the flashing process, e.g. unpack/flash.\n * @param {string} item - Item processed by the action, e.g. partition being flashed.\n * @param {number} progress - Progress within the current action between 0 and 1.\n */\nexport type FactoryProgressCallback = (\n action: string,\n item: string,\n progress: number,\n) => void;\n\nfunction waitForFrame() {\n return new Promise((resolve) => {\n window.requestAnimationFrame(resolve);\n });\n}\n\nexport async function runWithTimedProgress<T>(\n onProgress: FactoryProgressCallback,\n action: string,\n item: string,\n duration: number,\n workPromise: Promise<T>,\n) {\n const startTime = new Date().getTime();\n let stop = false;\n\n onProgress(action, item, 0.0);\n const progressPromise = (async () => {\n let now;\n const targetTime = startTime + duration;\n\n do {\n now = new Date().getTime();\n onProgress(action, item, (now - startTime) / duration);\n await waitForFrame();\n } while (!stop && now < targetTime);\n })();\n\n await Promise.race([progressPromise, workPromise]);\n stop = true;\n await progressPromise;\n await workPromise;\n\n onProgress(action, item, 1.0);\n}\n\nexport function runWithTimeout<T>(\n promise: Promise<T>,\n timeout: number,\n): Promise<T> {\n return new Promise((resolve, reject) => {\n // Set up timeout\n let timedOut = false;\n const tid = setTimeout(() => {\n // Set sentinel first to prevent race in promise resolving\n timedOut = true;\n reject(new TimeoutError(timeout));\n }, timeout);\n\n // Passthrough\n promise\n .then((val) => {\n if (!timedOut) {\n resolve(val);\n }\n })\n .catch((err) => {\n if (!timedOut) {\n reject(err);\n }\n })\n .finally(() => {\n if (!timedOut) {\n clearTimeout(tid);\n }\n });\n });\n}\n","function t(t){const e='(t=>{\"function\"==typeof define&&define.amd?define(t):t()})(function(){\"use strict\";const{Array:t,Object:e,Number:n,Math:s,Error:r,Uint8Array:o,Uint16Array:i,Uint32Array:c,Int32Array:a,Map:h,DataView:f,Promise:l,TextEncoder:u,crypto:w,postMessage:p,TransformStream:d,ReadableStream:y,WritableStream:m,CompressionStream:g,DecompressionStream:S}=self,b=void 0,v=\"undefined\",k=\"function\",z=[];for(let t=0;256>t;t++){let e=t;for(let t=0;8>t;t++)1&e?e=e>>>1^3988292384:e>>>=1;z[t]=e}class C{constructor(t){this.t=t||-1}append(t){let e=0|this.t;for(let n=0,s=0|t.length;s>n;n++)e=e>>>8^z[255&(e^t[n])];this.t=e}get(){return~this.t}}class A extends d{constructor(){let t;const e=new C;super({transform(t,n){e.append(t),n.enqueue(t)},flush(){const n=new o(4);new f(n.buffer).setUint32(0,e.get()),t.value=n}}),t=this}}const x={concat(t,e){if(0===t.length||0===e.length)return t.concat(e);const n=t[t.length-1],s=x.o(n);return 32===s?t.concat(e):x.i(e,s,0|n,t.slice(0,t.length-1))},h(t){const e=t.length;if(0===e)return 0;const n=t[e-1];return 32*(e-1)+x.o(n)},l(t,e){if(32*t.length<e)return t;const n=(t=t.slice(0,s.ceil(e/32))).length;return e&=31,n>0&&e&&(t[n-1]=x.u(e,t[n-1]&2147483648>>e-1,1)),t},u:(t,e,n)=>32===t?e:(n?0|e:e<<32-t)+1099511627776*t,o:t=>s.round(t/1099511627776)||32,i(t,e,n,s){for(void 0===s&&(s=[]);e>=32;e-=32)s.push(n),n=0;if(0===e)return s.concat(t);for(let r=0;r<t.length;r++)s.push(n|t[r]>>>e),n=t[r]<<32-e;const r=t.length?t[t.length-1]:0,o=x.o(r);return s.push(x.u(e+o&31,e+o>32?n:s.pop(),1)),s}},I={bytes:{p(t){const e=x.h(t)/8,n=new o(e);let s;for(let r=0;e>r;r++)3&r||(s=t[r/4]),n[r]=s>>>24,s<<=8;return n},m(t){const e=[];let n,s=0;for(n=0;n<t.length;n++)s=s<<8|t[n],3&~n||(e.push(s),s=0);return 3&n&&e.push(x.u(8*(3&n),s)),e}}},R=class{constructor(t){const e=this;e.blockSize=512,e.S=[1732584193,4023233417,2562383102,271733878,3285377520],e.v=[1518500249,1859775393,2400959708,3395469782],t?(e.k=t.k.slice(0),e.C=t.C.slice(0),e.A=t.A):e.reset()}reset(){const t=this;return t.k=t.S.slice(0),t.C=[],t.A=0,t}update(t){const e=this;\"string\"==typeof t&&(t=I.I.m(t));const n=e.C=x.concat(e.C,t),s=e.A,o=e.A=s+x.h(t);if(o>9007199254740991)throw new r(\"Cannot hash more than 2^53 - 1 bits\");const i=new c(n);let a=0;for(let t=e.blockSize+s-(e.blockSize+s&e.blockSize-1);o>=t;t+=e.blockSize)e.R(i.subarray(16*a,16*(a+1))),a+=1;return n.splice(0,16*a),e}P(){const t=this;let e=t.C;const n=t.k;e=x.concat(e,[x.u(1,1)]);for(let t=e.length+2;15&t;t++)e.push(0);for(e.push(s.floor(t.A/4294967296)),e.push(0|t.A);e.length;)t.R(e.splice(0,16));return t.reset(),n}U(t,e,n,s){return t>19?t>39?t>59?t>79?void 0:e^n^s:e&n|e&s|n&s:e^n^s:e&n|~e&s}V(t,e){return e<<t|e>>>32-t}R(e){const n=this,r=n.k,o=t(80);for(let t=0;16>t;t++)o[t]=e[t];let i=r[0],c=r[1],a=r[2],h=r[3],f=r[4];for(let t=0;79>=t;t++){16>t||(o[t]=n.V(1,o[t-3]^o[t-8]^o[t-14]^o[t-16]));const e=n.V(5,i)+n.U(t,c,a,h)+f+o[t]+n.v[s.floor(t/20)]|0;f=h,h=a,a=n.V(30,c),c=i,i=e}r[0]=r[0]+i|0,r[1]=r[1]+c|0,r[2]=r[2]+a|0,r[3]=r[3]+h|0,r[4]=r[4]+f|0}},P={getRandomValues(t){const e=new c(t.buffer),n=t=>{let e=987654321;const n=4294967295;return()=>(e=36969*(65535&e)+(e>>16)&n,(((e<<16)+(t=18e3*(65535&t)+(t>>16)&n)&n)/4294967296+.5)*(s.random()>.5?1:-1))};for(let r,o=0;o<t.length;o+=4){const t=n(4294967296*(r||s.random()));r=987654071*t(),e[o/4]=4294967296*t()|0}return t}},U={importKey:t=>new U.M(I.bytes.m(t)),_(t,e,n,s){if(n=n||1e4,0>s||0>n)throw new r(\"invalid params to pbkdf2\");const o=1+(s>>5)<<2;let i,c,a,h,l;const u=new ArrayBuffer(o),w=new f(u);let p=0;const d=x;for(e=I.bytes.m(e),l=1;(o||1)>p;l++){for(i=c=t.encrypt(d.concat(e,[l])),a=1;n>a;a++)for(c=t.encrypt(c),h=0;h<c.length;h++)i[h]^=c[h];for(a=0;(o||1)>p&&a<i.length;a++)w.setInt32(p,i[a]),p+=4}return u.slice(0,s/8)},M:class{constructor(t){const e=this,n=e.B=R,s=[[],[]];e.D=[new n,new n];const r=e.D[0].blockSize/32;t.length>r&&(t=(new n).update(t).P());for(let e=0;r>e;e++)s[0][e]=909522486^t[e],s[1][e]=1549556828^t[e];e.D[0].update(s[0]),e.D[1].update(s[1]),e.W=new n(e.D[0])}reset(){const t=this;t.W=new t.B(t.D[0]),t.K=!1}update(t){this.K=!0,this.W.update(t)}digest(){const t=this,e=t.W.P(),n=new t.B(t.D[1]).update(e).P();return t.reset(),n}encrypt(t){if(this.K)throw new r(\"encrypt on already updated hmac called!\");return this.update(t),this.digest(t)}}},V=typeof w!=v&&typeof w.getRandomValues==k,M=\"Invalid password\",_=\"Invalid signature\",B=\"zipjs-abort-check-password\";function D(t){return V?w.getRandomValues(t):P.getRandomValues(t)}const W=16,K={name:\"PBKDF2\"},E=e.assign({hash:{name:\"HMAC\"}},K),L=e.assign({iterations:1e3,hash:{name:\"SHA-1\"}},K),O=[\"deriveBits\"],T=[8,12,16],j=[16,24,32],H=10,Z=[0,0,0,0],F=typeof w!=v,N=F&&w.subtle,q=F&&typeof N!=v,G=I.bytes,J=class{constructor(t){const e=this;e.L=[[[],[],[],[],[]],[[],[],[],[],[]]],e.L[0][0][0]||e.O();const n=e.L[0][4],s=e.L[1],o=t.length;let i,c,a,h=1;if(4!==o&&6!==o&&8!==o)throw new r(\"invalid aes key size\");for(e.v=[c=t.slice(0),a=[]],i=o;4*o+28>i;i++){let t=c[i-1];(i%o===0||8===o&&i%o===4)&&(t=n[t>>>24]<<24^n[t>>16&255]<<16^n[t>>8&255]<<8^n[255&t],i%o===0&&(t=t<<8^t>>>24^h<<24,h=h<<1^283*(h>>7))),c[i]=c[i-o]^t}for(let t=0;i;t++,i--){const e=c[3&t?i:i-4];a[t]=4>=i||4>t?e:s[0][n[e>>>24]]^s[1][n[e>>16&255]]^s[2][n[e>>8&255]]^s[3][n[255&e]]}}encrypt(t){return this.T(t,0)}decrypt(t){return this.T(t,1)}O(){const t=this.L[0],e=this.L[1],n=t[4],s=e[4],r=[],o=[];let i,c,a,h;for(let t=0;256>t;t++)o[(r[t]=t<<1^283*(t>>7))^t]=t;for(let f=i=0;!n[f];f^=c||1,i=o[i]||1){let o=i^i<<1^i<<2^i<<3^i<<4;o=o>>8^255&o^99,n[f]=o,s[o]=f,h=r[a=r[c=r[f]]];let l=16843009*h^65537*a^257*c^16843008*f,u=257*r[o]^16843008*o;for(let n=0;4>n;n++)t[n][f]=u=u<<24^u>>>8,e[n][o]=l=l<<24^l>>>8}for(let n=0;5>n;n++)t[n]=t[n].slice(0),e[n]=e[n].slice(0)}T(t,e){if(4!==t.length)throw new r(\"invalid aes block size\");const n=this.v[e],s=n.length/4-2,o=[0,0,0,0],i=this.L[e],c=i[0],a=i[1],h=i[2],f=i[3],l=i[4];let u,w,p,d=t[0]^n[0],y=t[e?3:1]^n[1],m=t[2]^n[2],g=t[e?1:3]^n[3],S=4;for(let t=0;s>t;t++)u=c[d>>>24]^a[y>>16&255]^h[m>>8&255]^f[255&g]^n[S],w=c[y>>>24]^a[m>>16&255]^h[g>>8&255]^f[255&d]^n[S+1],p=c[m>>>24]^a[g>>16&255]^h[d>>8&255]^f[255&y]^n[S+2],g=c[g>>>24]^a[d>>16&255]^h[y>>8&255]^f[255&m]^n[S+3],S+=4,d=u,y=w,m=p;for(let t=0;4>t;t++)o[e?3&-t:t]=l[d>>>24]<<24^l[y>>16&255]<<16^l[m>>8&255]<<8^l[255&g]^n[S++],u=d,d=y,y=m,m=g,g=u;return o}},Q=class{constructor(t,e){this.j=t,this.H=e,this.Z=e}reset(){this.Z=this.H}update(t){return this.F(this.j,t,this.Z)}N(t){if(255&~(t>>24))t+=1<<24;else{let e=t>>16&255,n=t>>8&255,s=255&t;255===e?(e=0,255===n?(n=0,255===s?s=0:++s):++n):++e,t=0,t+=e<<16,t+=n<<8,t+=s}return t}q(t){0===(t[0]=this.N(t[0]))&&(t[1]=this.N(t[1]))}F(t,e,n){let s;if(!(s=e.length))return[];const r=x.h(e);for(let r=0;s>r;r+=4){this.q(n);const s=t.encrypt(n);e[r]^=s[0],e[r+1]^=s[1],e[r+2]^=s[2],e[r+3]^=s[3]}return x.l(e,r)}},X=U.M;let Y=F&&q&&typeof N.importKey==k,$=F&&q&&typeof N.deriveBits==k;class tt extends d{constructor({password:t,rawPassword:n,signed:s,encryptionStrength:i,checkPasswordOnly:c}){super({start(){e.assign(this,{ready:new l(t=>this.G=t),password:rt(t,n),signed:s,J:i-1,pending:new o})},async transform(t,e){const n=this,{password:s,J:i,G:a,ready:h}=n;s?(await(async(t,e,n,s)=>{const o=await st(t,e,n,it(s,0,T[e])),i=it(s,T[e]);if(o[0]!=i[0]||o[1]!=i[1])throw new r(M)})(n,i,s,it(t,0,T[i]+2)),t=it(t,T[i]+2),c?e.error(new r(B)):a()):await h;const f=new o(t.length-H-(t.length-H)%W);e.enqueue(nt(n,t,f,0,H,!0))},async flush(t){const{signed:e,X:n,Y:s,pending:i,ready:c}=this;if(s&&n){await c;const a=it(i,0,i.length-H),h=it(i,i.length-H);let f=new o;if(a.length){const t=at(G,a);s.update(t);const e=n.update(t);f=ct(G,e)}if(e){const t=it(ct(G,s.digest()),0,H);for(let e=0;H>e;e++)if(t[e]!=h[e])throw new r(_)}t.enqueue(f)}}})}}class et extends d{constructor({password:t,rawPassword:n,encryptionStrength:s}){let r;super({start(){e.assign(this,{ready:new l(t=>this.G=t),password:rt(t,n),J:s-1,pending:new o})},async transform(t,e){const n=this,{password:s,J:r,G:i,ready:c}=n;let a=new o;s?(a=await(async(t,e,n)=>{const s=D(new o(T[e]));return ot(s,await st(t,e,n,s))})(n,r,s),i()):await c;const h=new o(a.length+t.length-t.length%W);h.set(a,0),e.enqueue(nt(n,t,h,a.length,0))},async flush(t){const{X:e,Y:n,pending:s,ready:i}=this;if(n&&e){await i;let c=new o;if(s.length){const t=e.update(at(G,s));n.update(t),c=ct(G,t)}r.signature=ct(G,n.digest()).slice(0,H),t.enqueue(ot(c,r.signature))}}}),r=this}}function nt(t,e,n,s,r,i){const{X:c,Y:a,pending:h}=t,f=e.length-r;let l;for(h.length&&(e=ot(h,e),n=((t,e)=>{if(e&&e>t.length){const n=t;(t=new o(e)).set(n,0)}return t})(n,f-f%W)),l=0;f-W>=l;l+=W){const t=at(G,it(e,l,l+W));i&&a.update(t);const r=c.update(t);i||a.update(r),n.set(ct(G,r),l+s)}return t.pending=it(e,l),n}async function st(n,s,r,i){n.password=null;const c=await(async(t,e,n,s,r)=>{if(!Y)return U.importKey(e);try{return await N.importKey(\"raw\",e,n,!1,r)}catch{return Y=!1,U.importKey(e)}})(0,r,E,0,O),a=await(async(t,e,n)=>{if(!$)return U._(e,t.salt,L.iterations,n);try{return await N.deriveBits(t,e,n)}catch{return $=!1,U._(e,t.salt,L.iterations,n)}})(e.assign({salt:i},L),c,8*(2*j[s]+2)),h=new o(a),f=at(G,it(h,0,j[s])),l=at(G,it(h,j[s],2*j[s])),u=it(h,2*j[s]);return e.assign(n,{keys:{key:f,$:l,passwordVerification:u},X:new Q(new J(f),t.from(Z)),Y:new X(l)}),u}function rt(t,e){return e===b?(t=>{if(typeof u==v){const e=new o((t=unescape(encodeURIComponent(t))).length);for(let n=0;n<e.length;n++)e[n]=t.charCodeAt(n);return e}return(new u).encode(t)})(t):e}function ot(t,e){let n=t;return t.length+e.length&&(n=new o(t.length+e.length),n.set(t,0),n.set(e,t.length)),n}function it(t,e,n){return t.subarray(e,n)}function ct(t,e){return t.p(e)}function at(t,e){return t.m(e)}class ht extends d{constructor({password:t,passwordVerification:n,checkPasswordOnly:s}){super({start(){e.assign(this,{password:t,passwordVerification:n}),wt(this,t)},transform(t,e){const n=this;if(n.password){const e=lt(n,t.subarray(0,12));if(n.password=null,e.at(-1)!=n.passwordVerification)throw new r(M);t=t.subarray(12)}s?e.error(new r(B)):e.enqueue(lt(n,t))}})}}class ft extends d{constructor({password:t,passwordVerification:n}){super({start(){e.assign(this,{password:t,passwordVerification:n}),wt(this,t)},transform(t,e){const n=this;let s,r;if(n.password){n.password=null;const e=D(new o(12));e[11]=n.passwordVerification,s=new o(t.length+e.length),s.set(ut(n,e),0),r=12}else s=new o(t.length),r=0;s.set(ut(n,t),r),e.enqueue(s)}})}}function lt(t,e){const n=new o(e.length);for(let s=0;s<e.length;s++)n[s]=dt(t)^e[s],pt(t,n[s]);return n}function ut(t,e){const n=new o(e.length);for(let s=0;s<e.length;s++)n[s]=dt(t)^e[s],pt(t,e[s]);return n}function wt(t,n){const s=[305419896,591751049,878082192];e.assign(t,{keys:s,tt:new C(s[0]),et:new C(s[2])});for(let e=0;e<n.length;e++)pt(t,n.charCodeAt(e))}function pt(t,e){let[n,r,o]=t.keys;t.tt.append([e]),n=~t.tt.get(),r=mt(s.imul(mt(r+yt(n)),134775813)+1),t.et.append([r>>>24]),o=~t.et.get(),t.keys=[n,r,o]}function dt(t){const e=2|t.keys[2];return yt(s.imul(e,1^e)>>>8)}function yt(t){return 255&t}function mt(t){return 4294967295&t}class gt extends d{constructor(t,{chunkSize:e,nt:n,CompressionStream:s}){super({});const{compressed:r,encrypted:o,useCompressionStream:i,zipCrypto:c,signed:a,level:h}=t,l=this;let u,w,p=super.readable;o&&!c||!a||(u=new A,p=kt(p,u)),r&&(p=vt(p,i,{level:h,chunkSize:e},s,n,s)),o&&(c?p=kt(p,new ft(t)):(w=new et(t),p=kt(p,w))),bt(l,p,()=>{let t;o&&!c&&(t=w.signature),o&&!c||!a||(t=new f(u.value.buffer).getUint32(0)),l.signature=t})}}class St extends d{constructor(t,{chunkSize:e,st:n,DecompressionStream:s}){super({});const{zipCrypto:o,encrypted:i,signed:c,signature:a,compressed:h,useCompressionStream:l,rt:u}=t;let w,p,d=super.readable;i&&(o?d=kt(d,new ht(t)):(p=new tt(t),d=kt(d,p))),h&&(d=vt(d,l,{chunkSize:e,rt:u},s,n,s)),i&&!o||!c||(w=new A,d=kt(d,w)),bt(this,d,()=>{if((!i||o)&&c){const t=new f(w.value.buffer);if(a!=t.getUint32(0,!1))throw new r(_)}})}}function bt(t,n,s){n=kt(n,new d({flush:s})),e.defineProperty(t,\"readable\",{get:()=>n})}function vt(t,e,n,s,r,o){const i=e&&s?s:r||o,c=n.rt?\"deflate64-raw\":\"deflate-raw\";try{t=kt(t,new i(c,n))}catch(s){if(!e)throw s;if(r)t=kt(t,new r(c,n));else{if(!o)throw s;t=kt(t,new o(c,n))}}return t}function kt(t,e){return t.pipeThrough(e)}const zt=\"data\",Ct=\"close\";class At extends d{constructor(t,n){super({});const s=this,{codecType:o}=t;let i;o.startsWith(\"deflate\")?i=gt:o.startsWith(\"inflate\")&&(i=St),s.outputSize=0;let c=0;const a=new i(t,n),h=super.readable,f=new d({transform(t,e){t&&t.length&&(c+=t.length,e.enqueue(t))},flush(){e.assign(s,{inputSize:c})}}),l=new d({transform(e,n){if(e&&e.length&&(n.enqueue(e),s.outputSize+=e.length,t.outputSize!==b&&s.outputSize>t.outputSize))throw new r(\"Invalid uncompressed size\")},flush(){const{signature:t}=a;e.assign(s,{signature:t,inputSize:c})}});e.defineProperty(s,\"readable\",{get:()=>h.pipeThrough(f).pipeThrough(a).pipeThrough(l)})}}class xt extends d{constructor(t){let e;super({transform:function n(s,r){if(e){const t=new o(e.length+s.length);t.set(e),t.set(s,e.length),s=t,e=null}s.length>t?(r.enqueue(s.slice(0,t)),n(s.slice(t),r)):e=s},flush(t){e&&e.length&&t.enqueue(e)}})}}const It=new h,Rt=new h;let Pt,Ut,Vt,Mt,_t,Bt=0;async function Dt(t){try{const{options:e,config:s}=t;if(!e.useCompressionStream)try{await self.initModule(t.config)}catch{e.useCompressionStream=!0}s.CompressionStream=self.CompressionStream,s.DecompressionStream=self.DecompressionStream;const r={highWaterMark:1},o=t.readable||new y({async pull(t){const e=new l(t=>It.set(Bt,t));Wt({type:\"pull\",messageId:Bt}),Bt=(Bt+1)%n.MAX_SAFE_INTEGER;const{value:s,done:r}=await e;t.enqueue(s),r&&t.close()}},r),i=t.writable||new m({async write(t){let e;const s=new l(t=>e=t);Rt.set(Bt,e),Wt({type:zt,value:t,messageId:Bt}),Bt=(Bt+1)%n.MAX_SAFE_INTEGER,await s}},r),c=new At(e,s);Pt=new AbortController;const{signal:a}=Pt;await o.pipeThrough(c).pipeThrough(new xt(s.chunkSize)).pipeTo(i,{signal:a,preventClose:!0,preventAbort:!0}),await i.getWriter().close();const{signature:h,inputSize:f,outputSize:u}=c;Wt({type:Ct,result:{signature:h,inputSize:f,outputSize:u}})}catch(t){t.outputSize=0,Kt(t)}}function Wt(t){let{value:e}=t;if(e)if(e.length)try{e=new o(e),t.value=e.buffer,p(t,[t.value])}catch{p(t)}else p(t);else p(t)}function Kt(t=new r(\"Unknown error\")){const{message:e,stack:n,code:s,name:o,outputSize:i}=t;p({error:{message:e,stack:n,code:s,name:o,outputSize:i}})}function Et(t,e,n={}){const i=\"number\"==typeof n.level?n.level:-1,c=\"number\"==typeof n.ot?n.ot:65536,a=\"number\"==typeof n.it?n.it:65536;return new d({start(){let n;if(this.ct=Vt(c),this.in=Vt(a),this.it=a,this.ht=new o(c),t?(this.ft=Ut.deflate_process,this.lt=Ut.deflate_last_consumed,this.ut=Ut.deflate_end,this.wt=Ut.deflate_new(),n=\"gzip\"===e?Ut.deflate_init_gzip(this.wt,i):\"deflate-raw\"===e?Ut.deflate_init_raw(this.wt,i):Ut.deflate_init(this.wt,i)):\"deflate64-raw\"===e?(this.ft=Ut.inflate9_process,this.lt=Ut.inflate9_last_consumed,this.ut=Ut.inflate9_end,this.wt=Ut.inflate9_new(),n=Ut.inflate9_init_raw(this.wt)):(this.ft=Ut.inflate_process,this.lt=Ut.inflate_last_consumed,this.ut=Ut.inflate_end,this.wt=Ut.inflate_new(),n=\"deflate-raw\"===e?Ut.inflate_init_raw(this.wt):\"gzip\"===e?Ut.inflate_init_gzip(this.wt):Ut.inflate_init(this.wt)),0!==n)throw new r(\"init failed:\"+n)},transform(e,n){try{const i=e,a=new o(_t.buffer),h=this.ft,f=this.lt,l=this.ct,u=this.ht;let w=0;for(;w<i.length;){const e=s.min(i.length-w,32768);this.in&&this.it>=e||(this.in&&Mt&&Mt(this.in),this.in=Vt(e),this.it=e),a.set(i.subarray(w,w+e),this.in);const o=h(this.wt,this.in,e,l,c,0),p=16777215&o;if(p&&(u.set(a.subarray(l,l+p),0),n.enqueue(u.slice(0,p))),!t){const t=o>>24&255,e=128&t?t-256:t;if(0>e)throw new r(\"process error:\"+e)}const d=f(this.wt);if(0===d)break;w+=d}}catch(t){this.ut&&this.wt&&this.ut(this.wt),this.in&&Mt&&Mt(this.in),this.ct&&Mt&&Mt(this.ct),n.error(t)}},flush(e){try{const n=new o(_t.buffer),s=this.ft,i=this.ct,a=this.ht;for(;;){const o=s(this.wt,0,0,i,c,4),h=16777215&o,f=o>>24&255;if(!t){const t=128&f?f-256:f;if(0>t)throw new r(\"process error:\"+t)}if(h&&(a.set(n.subarray(i,i+h),0),e.enqueue(a.slice(0,h))),1===f||0===h)break}}catch(t){e.error(t)}finally{if(this.ut&&this.wt){const t=this.ut(this.wt);0!==t&&e.error(new r(\"end error:\"+t))}this.in&&Mt&&Mt(this.in),this.ct&&Mt&&Mt(this.ct)}}})}addEventListener(\"message\",({data:t})=>{const{type:e,messageId:n,value:s,done:r}=t;try{if(\"start\"==e&&Dt(t),e==zt){const t=It.get(n);It.delete(n),t({value:new o(s),done:r})}if(\"ack\"==e){const t=Rt.get(n);Rt.delete(n),t()}e==Ct&&Pt.abort()}catch(t){Kt(t)}});class Lt{constructor(t=\"deflate\",e){return Et(!0,t,e)}}class Ot{constructor(t=\"deflate\",e){return Et(!1,t,e)}}let Tt=!1;self.initModule=async t=>{try{const e=await(async(t,{baseURI:e})=>{if(!Tt){let n,s;try{try{s=new URL(t,e)}catch{}const r=await fetch(s);n=await r.arrayBuffer()}catch(e){if(!t.startsWith(\"data:application/wasm;base64,\"))throw e;n=(t=>{const e=t.split(\",\")[1],n=atob(e),s=n.length,r=new o(s);for(let t=0;s>t;++t)r[t]=n.charCodeAt(t);return r.buffer})(t)}(t=>{if(Ut=t,({malloc:Vt,free:Mt,memory:_t}=Ut),\"function\"!=typeof Vt||\"function\"!=typeof Mt||!_t)throw Ut=Vt=Mt=_t=null,new r(\"Invalid WASM module\")})((await WebAssembly.instantiate(n)).instance.exports),Tt=!0}})(t.wasmURI,t);return t.nt=Lt,t.st=Ot,e}catch{}}});\\n';t({workerURI:t=>{const n=\"text/javascript\";if(t){const t=new Blob([e],{type:n});return URL.createObjectURL(t)}return\"data:\"+n+\",\"+encodeURIComponent(e)}})}export{t as configureWebWorker};\n","/*\n Copyright (c) 2025 Gildas Lormeau. All rights reserved.\n\n Redistribution and use in source and binary forms, with or without\n modification, are permitted provided that the following conditions are met:\n\n 1. Redistributions of source code must retain the above copyright notice,\n this list of conditions and the following disclaimer.\n\n 2. Redistributions in binary form must reproduce the above copyright\n notice, this list of conditions and the following disclaimer in\n the documentation and/or other materials provided with the distribution.\n\n 3. The names of the authors may not be used to endorse or promote products\n derived from this software without specific prior written permission.\n\n THIS SOFTWARE IS PROVIDED ''AS IS'' AND ANY EXPRESSED OR IMPLIED WARRANTIES,\n INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND\n FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL JCRAFT,\n INC. OR ANY CONTRIBUTORS TO THIS SOFTWARE BE LIABLE FOR ANY DIRECT, INDIRECT,\n INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT\n LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA,\n OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF\n LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING\n NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE,\n EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.\n */\n\nimport { configure } from \"./core/configuration.js\";\nimport { configureWebWorker } from \"./core/web-worker-inline-wasm.js\";\n\nconfigureWebWorker(configure);\n\nexport * from \"./zip-fs-core-wasm.js\";\nexport { getMimeType } from \"./core/util/mime-type.js\";","import * as common from \"./common\";\nimport {\n type FileEntry,\n BlobReader,\n BlobWriter,\n TextWriter,\n ZipReader,\n} from \"@zip.js/zip.js\";\nimport type { FastbootDevice, ReconnectCallback } from \"./fastboot\";\nimport { FastbootError } from \"./utils/errors\";\nimport { logDebug } from \"./utils/logger\";\nimport {\n type FactoryProgressCallback,\n runWithTimedProgress,\n} from \"./utils/progress\";\n\n// Images needed for fastbootd\nconst BOOT_CRITICAL_IMAGES = [\n \"boot\",\n \"dt\",\n \"dtbo\",\n \"init_boot\",\n \"pvmfw\",\n \"recovery\",\n \"vbmeta_system\",\n \"vbmeta_vendor\",\n \"vbmeta\",\n \"vendor_boot\",\n \"vendor_kernel_boot\",\n];\n\n// Less critical images to flash after boot-critical ones\nconst SYSTEM_IMAGES = [\n \"odm\",\n \"odm_dlkm\",\n \"product\",\n \"system_dlkm\",\n \"system_ext\",\n \"system\",\n \"vendor_dlkm\",\n \"vendor\",\n];\n\n/**\n * User-friendly action strings for factory image flashing progress.\n * This can be indexed by the action argument in FactoryFlashCallback.\n */\nexport const USER_ACTION_MAP = {\n load: \"Loading\",\n unpack: \"Unpacking\",\n flash: \"Writing\",\n wipe: \"Wiping\",\n reboot: \"Restarting\",\n};\n\nconst BOOTLOADER_REBOOT_TIME = 4000; // ms\nconst FASTBOOTD_REBOOT_TIME = 16000; // ms\nconst USERDATA_ERASE_TIME = 1000; // ms\n\nasync function flashEntryBlob(\n device: FastbootDevice,\n entry: FileEntry,\n onProgress: FactoryProgressCallback,\n partition: string,\n slot: string = \"current\",\n) {\n logDebug(`Unpacking ${partition}`);\n onProgress(\"unpack\", partition, 0.0);\n const blob = await entry.getData<Blob>(\n new BlobWriter(\"application/octet-stream\"),\n {\n onprogress: (bytes: number, len: number) => {\n onProgress(\"unpack\", partition, bytes / len);\n },\n },\n );\n\n logDebug(`Flashing ${partition}`);\n onProgress(\"flash\", partition, 0.0);\n await device.flashBlob(partition, slot, blob, (progress) => {\n onProgress(\"flash\", partition, progress);\n });\n}\n\nasync function tryFlashImages(\n device: FastbootDevice,\n entries: Array<FileEntry>,\n onProgress: FactoryProgressCallback,\n imageNames: Array<string>,\n slot: string = \"current\",\n) {\n for (const imageName of imageNames) {\n const pattern = new RegExp(`${imageName}(?:-.+)?\\\\.img$`);\n const entry = entries.find((entry) => entry.filename.match(pattern));\n if (entry !== undefined) {\n await flashEntryBlob(device, entry, onProgress, imageName, slot);\n }\n }\n}\n\nasync function checkRequirements(device: FastbootDevice, androidInfo: string) {\n // Deal with CRLF just in case\n for (const line of androidInfo.replace(\"\\r\", \"\").split(\"\\n\")) {\n const match = line.match(/^require\\s+(.+?)=(.+)$/);\n if (!match) {\n continue;\n }\n\n let variable = match[1];\n // Historical mismatch that we still need to deal with\n if (variable === \"board\") {\n variable = \"product\";\n }\n\n const expectValue = match[2];\n const expectValues: Array<string | null> = expectValue.split(\"|\");\n\n // Special case: not a real variable at all\n if (variable === \"partition-exists\") {\n // Check whether the partition exists on the device:\n // has-slot = undefined || FAIL => doesn't exist\n // has-slot = yes || no => exists\n const hasSlot = await device.getVariable(`has-slot:${expectValue}`);\n if (hasSlot !== \"yes\" && hasSlot !== \"no\") {\n throw new FastbootError(\n \"FAIL\",\n `Requirement ${variable}=${expectValue} failed, device lacks partition`,\n );\n }\n\n // Check whether we recognize the partition\n if (\n !BOOT_CRITICAL_IMAGES.includes(expectValue) &&\n !SYSTEM_IMAGES.includes(expectValue)\n ) {\n throw new FastbootError(\n \"FAIL\",\n `Requirement ${variable}=${expectValue} failed, unrecognized partition`,\n );\n }\n } else {\n const realValue = await device.getVariable(variable);\n\n if (expectValues.includes(realValue)) {\n logDebug(`Requirement ${variable}=${expectValue} passed`);\n } else {\n const msg = `Requirement ${variable}=${expectValue} failed, value = ${realValue}`;\n logDebug(msg);\n throw new FastbootError(\"FAIL\", msg);\n }\n }\n }\n}\n\nasync function tryRebootWithSlotSwitch(\n device: FastbootDevice,\n target: string,\n onReconnect: ReconnectCallback,\n) {\n try {\n await device.rebootSwitchSlot(target, false);\n } catch {\n /* Failed = device rebooted by itself */\n }\n\n await device.waitForConnect(onReconnect);\n}\n\nexport async function flashZip(\n device: FastbootDevice,\n blob: Blob,\n wipe: boolean,\n onReconnect: ReconnectCallback,\n onProgress: FactoryProgressCallback = () => {},\n) {\n onProgress(\"load\", \"package\", 0.0);\n const reader = new ZipReader(new BlobReader(blob));\n const entries = (await reader.getEntries()).filter(\n (e) => !e.directory,\n ) as FileEntry[];\n\n // Ensure AVB custom key exists as expected.\n const avbCustomKeyEntry = entries.find((e) =>\n e.filename.endsWith(\"avb_custom_key.img\"),\n );\n if (avbCustomKeyEntry === undefined) {\n throw new Error(\n \"avb_custom_key.img not found! bootloader locking would fail.\",\n );\n }\n\n // Bootloader and radio packs can only be flashed in the bare-metal bootloader\n if ((await device.getVariable(\"is-userspace\")) === \"yes\") {\n await device.reboot(\"bootloader\", true, onReconnect);\n }\n\n // 1. Bootloader pack\n await tryFlashImages(device, entries, onProgress, [\"bootloader\"], \"other\");\n await runWithTimedProgress(\n onProgress,\n \"reboot\",\n \"device\",\n BOOTLOADER_REBOOT_TIME,\n tryRebootWithSlotSwitch(device, \"bootloader\", onReconnect),\n );\n // Flash the other slot\n await tryFlashImages(device, entries, onProgress, [\"bootloader\"], \"other\");\n await runWithTimedProgress(\n onProgress,\n \"reboot\",\n \"device\",\n BOOTLOADER_REBOOT_TIME,\n tryRebootWithSlotSwitch(device, \"bootloader\", onReconnect),\n );\n\n // 2. Radio pack\n await tryFlashImages(device, entries, onProgress, [\"radio\"], \"other\");\n await runWithTimedProgress(\n onProgress,\n \"reboot\",\n \"device\",\n BOOTLOADER_REBOOT_TIME,\n tryRebootWithSlotSwitch(device, \"bootloader\", onReconnect),\n );\n // Flash the other slot\n await tryFlashImages(device, entries, onProgress, [\"radio\"], \"other\");\n await runWithTimedProgress(\n onProgress,\n \"reboot\",\n \"device\",\n BOOTLOADER_REBOOT_TIME,\n tryRebootWithSlotSwitch(device, \"bootloader\", onReconnect),\n );\n\n // Cancel snapshot update if in progress\n const snapshotStatus = await device.getVariable(\"snapshot-update-status\");\n if (snapshotStatus !== null && snapshotStatus !== \"none\") {\n await device.runCommand(\"snapshot-update:cancel\");\n }\n\n // Load nested images for the following steps\n logDebug(\"Loading nested images from zip\");\n onProgress(\"unpack\", \"images\", 0.0);\n let entry = entries.find((e) => e.filename.match(/image-.+\\.zip$/));\n const imagesBlob = await entry!.getData<Blob>(\n new BlobWriter(\"application/zip\"),\n {\n onprogress: (bytes: number, len: number) => {\n onProgress(\"unpack\", \"images\", bytes / len);\n },\n },\n );\n const imageReader = new ZipReader(new BlobReader(imagesBlob));\n const imageEntries = (await imageReader.getEntries()).filter(\n (e) => !e.directory,\n ) as FileEntry[];\n\n // 3. Custom AVB key\n await device.runCommand(\"erase:avb_custom_key\");\n await flashEntryBlob(\n device,\n avbCustomKeyEntry,\n onProgress,\n \"avb_custom_key\",\n );\n\n // 4. Check requirements\n entry = imageEntries.find((e) => e.filename === \"android-info.txt\");\n if (entry !== undefined) {\n const reqText = await entry.getData<string>(new TextWriter());\n await checkRequirements(device, reqText);\n }\n\n // 5. Boot-critical images\n await tryFlashImages(\n device,\n imageEntries,\n onProgress,\n BOOT_CRITICAL_IMAGES,\n );\n\n // 6. Super partition template\n // This is also where we reboot to fastbootd.\n entry = imageEntries.find((e) => e.filename === \"super_empty.img\");\n if (entry !== undefined) {\n await runWithTimedProgress(\n onProgress,\n \"reboot\",\n \"device\",\n FASTBOOTD_REBOOT_TIME,\n device.reboot(\"fastboot\", true, onReconnect),\n );\n\n let superName = await device.getVariable(\"super-partition-name\");\n if (!superName) {\n superName = \"super\";\n }\n\n const superAction = wipe ? \"wipe\" : \"flash\";\n onProgress(superAction, \"super\", 0.0);\n const superBlob = await entry.getData<Blob>(\n new BlobWriter(\"application/octet-stream\"),\n );\n await device.upload(\n superName,\n await common.readBlobAsBuffer(superBlob),\n (progress) => {\n onProgress(superAction, \"super\", progress);\n },\n );\n await device.runCommand(\n `update-super:${superName}${wipe ? \":wipe\" : \"\"}`,\n );\n }\n\n // 7. Remaining system images\n await tryFlashImages(device, imageEntries, onProgress, SYSTEM_IMAGES);\n\n // We unconditionally reboot back to the bootloader here if we're in fastbootd,\n // even when there's no custom AVB key, because common follow-up actions like\n // locking the bootloader and wiping data need to be done in the bootloader.\n if ((await device.getVariable(\"is-userspace\")) === \"yes\") {\n await runWithTimedProgress(\n onProgress,\n \"reboot\",\n \"device\",\n BOOTLOADER_REBOOT_TIME,\n device.reboot(\"bootloader\", true, onReconnect),\n );\n }\n\n // 8. Wipe userdata\n if (wipe) {\n await runWithTimedProgress(\n onProgress,\n \"wipe\",\n \"data\",\n USERDATA_ERASE_TIME,\n device.runCommand(\"erase:userdata\"),\n );\n }\n}\n","import * as Sparse from \"./sparse\";\nimport * as Lp from \"./lp\";\nimport * as common from \"./common\";\nimport { flashZip } from \"./factory\";\nimport { FastbootError, UsbError } from \"./utils/errors\";\nimport { logDebug, logVerbose } from \"./utils/logger\";\nimport {\n runWithTimeout,\n type FactoryProgressCallback,\n type FlashProgressCallback,\n} from \"./utils/progress\";\n\nconst FASTBOOT_USB_CLASS = 0xff;\nconst FASTBOOT_USB_SUBCLASS = 0x42;\nconst FASTBOOT_USB_PROTOCOL = 0x03;\n\nconst BULK_TRANSFER_SIZE = 16384;\n\nconst DEFAULT_DOWNLOAD_SIZE = 512 * 1024 * 1024; // 512 MiB\n// To conserve RAM and work around Chromium's ~2 GiB size limit, we limit the\n// max download size even if the bootloader can accept more data.\nconst MAX_DOWNLOAD_SIZE = 1024 * 1024 * 1024; // 1 GiB\n\nconst GETVAR_TIMEOUT = 10000; // ms\n\ninterface CommandResponse {\n text: string;\n // hex string from DATA\n dataSize?: string;\n}\n\n/**\n * Callback for reconnecting to the USB device.\n * This is necessary because some platforms do not support automatic reconnection,\n * and USB connection requests can only be triggered as the result of explicit\n * user action.\n *\n * @callback ReconnectCallback\n */\nexport type ReconnectCallback = () => void;\n\n/**\n * This class is a client for executing fastboot commands and operations on a\n * device connected over USB.\n */\nexport class FastbootDevice {\n device: USBDevice | null;\n epIn: number | null;\n epOut: number | null;\n\n private _registeredUsbListeners: boolean;\n private _connectResolve: ((value: unknown) => void) | null;\n private _connectReject: ((value: unknown) => void) | null;\n private _disconnectResolve: ((value: unknown) => void) | null;\n\n /**\n * Create a new fastboot device instance. This doesn't actually connect to\n * any USB devices; call {@link connect} to do so.\n */\n constructor() {\n this.device = null;\n this.epIn = null;\n this.epOut = null;\n\n this._registeredUsbListeners = false;\n this._connectResolve = null;\n this._connectReject = null;\n this._disconnectResolve = null;\n }\n\n /**\n * Returns whether a USB device is connected and ready for use.\n */\n get isConnected() {\n return (\n this.device !== null &&\n this.device.opened &&\n this.device.configurations[0].interfaces[0].claimed\n );\n }\n\n /**\n * Validate the current USB device's details and connect to it.\n *\n * @private\n */\n private async _validateAndConnectDevice() {\n if (this.device === null) {\n throw new UsbError(\"Attempted to connect to null device\");\n }\n\n // Validate device\n const ife = this.device!.configurations[0].interfaces[0].alternates[0];\n if (ife.endpoints.length !== 2) {\n throw new UsbError(\"Interface has wrong number of endpoints\");\n }\n\n this.epIn = null;\n this.epOut = null;\n for (const endpoint of ife.endpoints) {\n logVerbose(\n `Checking endpoint: ` +\n `endpointNumber=${endpoint.endpointNumber}, ` +\n `direction=${endpoint.direction}, ` +\n `type=${endpoint.type}, ` +\n `packetSize=${endpoint.packetSize}`,\n );\n if (endpoint.type !== \"bulk\") {\n throw new UsbError(\"Interface endpoint is not bulk\");\n }\n\n if (endpoint.direction === \"in\") {\n if (this.epIn === null) {\n this.epIn = endpoint.endpointNumber;\n } else {\n throw new UsbError(\"Interface has multiple IN endpoints\");\n }\n } else if (endpoint.direction === \"out\") {\n if (this.epOut === null) {\n this.epOut = endpoint.endpointNumber;\n } else {\n throw new UsbError(\"Interface has multiple OUT endpoints\");\n }\n }\n }\n logVerbose(`Endpoints: in=${this.epIn}, out=${this.epOut}`);\n\n try {\n await this.device!.open();\n await this.device!.selectConfiguration(1);\n await this.device!.claimInterface(0); // fastboot\n } catch (error) {\n // Propagate exception from waitForConnect()\n if (this._connectReject !== null) {\n this._connectReject(error);\n this._connectResolve = null;\n this._connectReject = null;\n }\n\n throw error;\n }\n\n // Return from waitForConnect()\n if (this._connectResolve !== null) {\n this._connectResolve(undefined);\n this._connectResolve = null;\n this._connectReject = null;\n }\n }\n\n /**\n * Wait for the current USB device to disconnect, if it's still connected.\n * Returns immediately if no device is connected.\n */\n async waitForDisconnect() {\n if (this.device === null) {\n return;\n }\n\n return await new Promise((resolve) => {\n this._disconnectResolve = resolve;\n });\n }\n\n /**\n * Wait for the USB device to connect. Returns at the next connection,\n * regardless of whether the connected USB device matches the previous one.\n *\n * @param {ReconnectCallback} onReconnect - Callback to request device reconnection on Android.\n */\n async waitForConnect(onReconnect: ReconnectCallback = () => {}) {\n // On Android, we need to request the user to reconnect the device manually\n // because there is no support for automatic reconnection.\n if (navigator.userAgent.includes(\"Android\")) {\n await this.waitForDisconnect();\n onReconnect();\n }\n\n return await new Promise((resolve, reject) => {\n this._connectResolve = resolve;\n this._connectReject = reject;\n });\n }\n\n /**\n * Request the user to select a USB device and connect to it using the\n * fastboot protocol.\n *\n * @throws {UsbError}\n */\n async connect() {\n this.device = await navigator.usb.requestDevice({\n filters: [\n {\n classCode: FASTBOOT_USB_CLASS,\n subclassCode: FASTBOOT_USB_SUBCLASS,\n protocolCode: FASTBOOT_USB_PROTOCOL,\n },\n ],\n });\n logDebug(\"Using USB device:\", this.device);\n\n if (!this._registeredUsbListeners) {\n navigator.usb.addEventListener(\"disconnect\", (event) => {\n if (event.device === this.device) {\n logDebug(\"USB device disconnected\");\n if (this._disconnectResolve !== null) {\n this._disconnectResolve(undefined);\n this._disconnectResolve = null;\n }\n }\n });\n\n navigator.usb.addEventListener(\"connect\", async (event) => {\n logDebug(\"USB device connected\");\n this.device = event.device;\n\n // Check whether waitForConnect() is pending and save it for later\n const hasPromiseReject = this._connectReject !== null;\n try {\n await this._validateAndConnectDevice();\n } catch (error) {\n // Only rethrow errors from the event handler if waitForConnect()\n // didn't already handle them\n if (!hasPromiseReject) {\n throw error;\n }\n }\n });\n\n this._registeredUsbListeners = true;\n }\n\n await this._validateAndConnectDevice();\n }\n\n /**\n * Read a raw command response from the bootloader.\n *\n * @private\n * @returns {Promise<CommandResponse>} Object containing response text and data size, if any.\n * @throws {FastbootError}\n */\n private async _readResponse(): Promise<CommandResponse> {\n const respData = {\n text: \"\",\n } as CommandResponse;\n let respStatus;\n\n do {\n const respPacket = await this.device!.transferIn(this.epIn!, 64);\n const response = new TextDecoder().decode(respPacket.data);\n\n respStatus = response.substring(0, 4);\n const respMessage = response.substring(4);\n logDebug(`Response: ${respStatus} ${respMessage}`);\n\n if (respStatus === \"OKAY\") {\n // OKAY = end of response for this command\n respData.text += respMessage;\n } else if (respStatus === \"INFO\") {\n // INFO = additional info line\n respData.text += respMessage + \"\\n\";\n } else if (respStatus === \"DATA\") {\n // DATA = hex string, but it's returned separately for safety\n respData.dataSize = respMessage;\n } else {\n // Assume FAIL or garbage data\n throw new FastbootError(respStatus, respMessage);\n }\n // INFO = more packets are coming\n } while (respStatus === \"INFO\");\n\n return respData;\n }\n\n /**\n * Send a textual command to the bootloader and read the response.\n * This is in raw fastboot format, not AOSP fastboot syntax.\n *\n * @param {string} command - The command to send.\n * @returns {Promise<CommandResponse>} Object containing response text and data size, if any.\n * @throws {FastbootError}\n */\n async runCommand(command: string): Promise<CommandResponse> {\n // Command and response length is always 64 bytes regardless of protocol\n if (command.length > 64) {\n throw new RangeError();\n }\n\n // Send raw UTF-8 command\n const cmdPacket = new TextEncoder().encode(command);\n await this.device!.transferOut(this.epOut!, cmdPacket);\n logDebug(\"Command:\", command);\n\n return this._readResponse();\n }\n\n /**\n * Read the value of a bootloader variable. Returns undefined if the variable\n * does not exist.\n *\n * @param {string} varName - The name of the variable to get.\n * @returns {Promise<string>} Textual content of the variable.\n * @throws {FastbootError}\n */\n async getVariable(varName: string): Promise<string | null> {\n let resp;\n try {\n resp = (\n await runWithTimeout(\n this.runCommand(`getvar:${varName}`),\n GETVAR_TIMEOUT,\n )\n ).text;\n } catch (error) {\n // Some bootloaders return FAIL instead of empty responses, despite\n // what the spec says. Normalize it here.\n if (error instanceof FastbootError && error.status == \"FAIL\") {\n resp = null;\n } else {\n throw error;\n }\n }\n\n // Some bootloaders send whitespace around some variables.\n // According to the spec, non-existent variables should return empty\n // responses\n return resp ? resp.trim() : null;\n }\n\n /**\n * Get the maximum download size for a single payload, in bytes.\n *\n * @private\n * @returns {Promise<number>}\n * @throws {FastbootError}\n */\n private async _getDownloadSize(): Promise<number> {\n try {\n const resp = (await this.getVariable(\n \"max-download-size\",\n ))!.toLowerCase();\n if (resp) {\n // AOSP fastboot requires hex\n return Math.min(parseInt(resp, 16), MAX_DOWNLOAD_SIZE);\n }\n } catch {\n /* Failed = no value, fallthrough */\n }\n\n // FAIL or empty variable means no max, set a reasonable limit to conserve memory\n return DEFAULT_DOWNLOAD_SIZE;\n }\n\n /**\n * Send a raw data payload to the bootloader.\n *\n * @private\n */\n private async _sendRawPayload(\n buffer: ArrayBuffer,\n onProgress: FlashProgressCallback,\n ) {\n let i = 0;\n let remainingBytes = buffer.byteLength;\n while (remainingBytes > 0) {\n const chunk = buffer.slice(\n i * BULK_TRANSFER_SIZE,\n (i + 1) * BULK_TRANSFER_SIZE,\n );\n if (i % 1000 === 0) {\n logVerbose(\n ` Sending ${chunk.byteLength} bytes to endpoint, ${remainingBytes} remaining, i=${i}`,\n );\n }\n if (i % 10 === 0) {\n onProgress(\n (buffer.byteLength - remainingBytes) / buffer.byteLength,\n );\n }\n\n await this.device!.transferOut(this.epOut!, chunk);\n\n remainingBytes -= chunk.byteLength;\n i += 1;\n }\n\n onProgress(1.0);\n }\n\n /**\n * Upload a payload to the bootloader for later use, e.g. flashing.\n * Does not handle raw images, flashing, or splitting.\n *\n * @param {string} partition - Name of the partition the payload is intended for.\n * @param {ArrayBuffer} buffer - Buffer containing the data to upload.\n * @param {FlashProgressCallback} onProgress - Callback for upload progress updates.\n * @throws {FastbootError}\n */\n async upload(\n partition: string,\n buffer: ArrayBuffer,\n onProgress: FlashProgressCallback = () => {},\n ) {\n logDebug(\n `Uploading single sparse to ${partition}: ${buffer.byteLength} bytes`,\n );\n\n // Bootloader requires an 8-digit hex number\n const xferHex = buffer.byteLength.toString(16).padStart(8, \"0\");\n if (xferHex.length !== 8) {\n throw new FastbootError(\n \"FAIL\",\n `Transfer size overflow: ${xferHex} is more than 8 digits`,\n );\n }\n\n // Check with the device and make sure size matches\n const downloadResp = await this.runCommand(`download:${xferHex}`);\n if (downloadResp.dataSize === undefined) {\n throw new FastbootError(\n \"FAIL\",\n `Unexpected response to download command: ${downloadResp.text}`,\n );\n }\n const downloadSize = parseInt(downloadResp.dataSize!, 16);\n if (downloadSize !== buffer.byteLength) {\n throw new FastbootError(\n \"FAIL\",\n `Bootloader wants ${downloadSize} bytes, requested to send ${buffer.byteLength} bytes`,\n );\n }\n\n logDebug(`Sending payload: ${buffer.byteLength} bytes`);\n await this._sendRawPayload(buffer, onProgress);\n\n logDebug(\"Payload sent, waiting for response...\");\n await this._readResponse();\n }\n\n /**\n * Reboot to the given target, and optionally wait for the device to\n * reconnect.\n *\n * @param {string} target - Where to reboot to, i.e. fastboot or bootloader.\n * @param {boolean} wait - Whether to wait for the device to reconnect.\n * @param {ReconnectCallback} onReconnect - Callback to request device reconnection, if wait is enabled.\n */\n async reboot(\n target: string = \"\",\n wait: boolean = false,\n onReconnect: ReconnectCallback = () => {},\n ) {\n if (target.length > 0) {\n await this.runCommand(`reboot-${target}`);\n } else {\n await this.runCommand(\"reboot\");\n }\n\n if (wait) {\n await this.waitForConnect(onReconnect);\n }\n }\n\n /**\n * Reboot to the given target and switch slot, and optionally wait for the device to\n * reconnect.\n *\n * @param {string} target - Where to reboot to, i.e. fastboot or bootloader.\n * @param {boolean} wait - Whether to wait for the device to reconnect.\n * @param {ReconnectCallback} onReconnect - Callback to request device reconnection, if wait is enabled.\n */\n async rebootSwitchSlot(\n target: string = \"\",\n wait: boolean = false,\n onReconnect: ReconnectCallback = () => {},\n ) {\n const otherSlot = await this.getOtherSlot();\n await this.runCommand(`set_active:${otherSlot}`);\n if (target.length > 0) {\n await this.runCommand(`reboot-${target}`);\n } else {\n await this.runCommand(\"reboot\");\n }\n\n if (wait) {\n await this.waitForConnect(onReconnect);\n }\n }\n\n /**\n * Flash the given Blob to the given partition and slot on the device. Any image\n * format supported by the bootloader is allowed, e.g. sparse or raw images.\n * Large raw images will be converted to sparse images automatically, and\n * large sparse images will be split and flashed in multiple passes\n * depending on the bootloader's payload size limit.\n *\n * @param {string} partition - The name of the partition to flash.\n * @param {string} slot - The slot to flash, defaults to current\n * @param {Blob} blob - The Blob to retrieve data from.\n * @param {FlashProgressCallback} onProgress - Callback for flashing progress updates.\n * @throws {FastbootError}\n */\n async flashBlob(\n partition: string,\n slot: string = \"current\",\n blob: Blob,\n onProgress: FlashProgressCallback = () => {},\n ) {\n // Check slot if partition is A/B\n if ((await this.getVariable(`has-slot:${partition}`)) === \"yes\") {\n const currentSlot = await this.getSlot();\n if (slot === \"current\") {\n // Default behavior, flash current slot\n partition += \"_\" + currentSlot;\n } else if (slot === \"other\") {\n // Allow flashing the other slot\n const otherSlot = await this.getOtherSlot();\n partition += \"_\" + otherSlot;\n } else {\n // Allow flashing a particular slot directly\n if (slot === \"a\" || slot === \"b\") {\n partition += \"_\" + slot;\n } else {\n throw new FastbootError(\"FAIL\", `Unknown Slot: ${slot}`);\n }\n }\n }\n logDebug(`Flashing partition ${partition}`);\n\n const maxDlSize = await this._getDownloadSize();\n const fileHeader = await common.readBlobAsBuffer(\n blob.slice(0, Sparse.FILE_HEADER_SIZE),\n );\n\n let totalBytes = blob.size;\n let isSparse = false;\n try {\n const sparseHeader = Sparse.parseFileHeader(fileHeader);\n if (sparseHeader !== null) {\n totalBytes = sparseHeader.blocks * sparseHeader.blockSize;\n isSparse = true;\n }\n } catch {\n // ImageError = invalid, so keep blob.size\n }\n\n // Logical partitions need to be resized before flashing because they're\n // sized perfectly to the payload.\n if ((await this.getVariable(`is-logical:${partition}`)) === \"yes\") {\n // As per AOSP fastboot, we reset the partition to 0 bytes first\n // to optimize extent allocation.\n await this.runCommand(`resize-logical-partition:${partition}:0`);\n // Set the actual size\n await this.runCommand(\n `resize-logical-partition:${partition}:${totalBytes}`,\n );\n }\n\n // Convert image to sparse (for splitting) if it exceeds the size limit\n if (blob.size > maxDlSize && !isSparse) {\n logDebug(`${partition} image is raw, converting to sparse`);\n blob = await Sparse.fromRaw(blob);\n }\n\n logDebug(\n `Flashing ${blob.size} bytes to ${partition}, ${maxDlSize} bytes per split`,\n );\n let splits = 0;\n let sentBytes = 0;\n for await (const split of Sparse.splitBlob(blob, maxDlSize)) {\n await this.upload(partition, split.data, (progress) => {\n onProgress((sentBytes + progress * split.bytes) / totalBytes);\n });\n\n logDebug(\"Flashing payload...\");\n await this.runCommand(`flash:${partition}`);\n\n splits += 1;\n sentBytes += split.bytes;\n }\n\n logDebug(`Flashed ${partition} with ${splits} split(s)`);\n }\n\n /**\n * Boot the given Blob on the device.\n * Equivalent to `fastboot boot boot.img`.\n *\n * @param {Blob} blob - The Blob to retrieve data from.\n * @param {FlashProgressCallback} onProgress - Callback for flashing progress updates.\n * @throws {FastbootError}\n */\n async bootBlob(blob: Blob, onProgress: FlashProgressCallback = () => {}) {\n logDebug(`Booting ${blob.size} bytes image`);\n\n const data = await common.readBlobAsBuffer(blob);\n await this.upload(\"boot.img\", data, onProgress);\n\n logDebug(\"Booting payload...\");\n await this.runCommand(\"boot\");\n\n logDebug(`Booted ${blob.size} bytes image`);\n }\n\n /**\n * Flash the given factory images zip onto the device, with automatic handling\n * of firmware, system, and logical partitions as AOSP fastboot and\n * flash-all.sh would do.\n * Equivalent to `fastboot update name.zip`.\n *\n * @param {Blob} blob - Blob containing the zip file to flash.\n * @param {boolean} wipe - Whether to wipe super and userdata. Equivalent to `fastboot -w`.\n * @param {ReconnectCallback} onReconnect - Callback to request device reconnection.\n * @param {FactoryProgressCallback} onProgress - Progress callback for image flashing.\n */\n async flashFactoryZip(\n blob: Blob,\n wipe: boolean,\n onReconnect: ReconnectCallback,\n onProgress: FactoryProgressCallback = () => {},\n ) {\n return await flashZip(this, blob, wipe, onReconnect, onProgress);\n }\n\n /**\n * Wipe the super partition by flashing a minimal sparse image derived from\n * the LP metadata in the given super_empty.img Blob. This erases all logical\n * partition data and resets the partition table to the empty layout encoded\n * in the image.\n *\n * The device must be in the bootloader (not fastbootd) when this is called.\n *\n * @param {Blob} blob - Blob containing super_empty.img.\n * @param {string} slot - The slot to target (\"current\", \"a\", or \"b\").\n * @param {FlashProgressCallback} onProgress - Callback for flashing progress updates.\n * @throws {FastbootError}\n */\n async wipeSuper(\n blob: Blob,\n slot: string = \"current\",\n onProgress: FlashProgressCallback = () => {},\n ) {\n const metadata = await Lp.readFromImageBlob(blob);\n\n // Resolve slot\n let resolvedSlot = slot;\n if (slot === \"current\") {\n resolvedSlot = (await this.getSlot()) ?? \"a\";\n } else if (slot === \"other\") {\n resolvedSlot = await this.getOtherSlot();\n }\n logDebug(`Targeting slot \"${resolvedSlot}\"`);\n\n const images = await Lp.buildWipeSuperImages(metadata);\n\n // For retrofit devices the primary block device is not named \"super\".\n // Fastboot sends \"oem allow-flash-super\" to allow flashing.\n const superDevice = Lp.getMetadataSuperBlockDevice(metadata);\n if (\n superDevice !== null &&\n Lp.getBlockDevicePartitionName(superDevice) !== \"super\"\n ) {\n try {\n await this.runCommand(\"oem allow-flash-super\");\n } catch {\n // Not all bootloaders support this command\n }\n }\n\n for (const image of images) {\n let flashPartition = image.partitionName;\n\n // Always query has-slot, even when the metadata flag requests slot-suffixing.\n // This matches AOSP do_for_partition: respect the device's own answer for\n // has-slot and only warn when force_slot is set but the partition has no slots.\n const hasSlot = await this.getVariable(\n `has-slot:${image.partitionName}`,\n );\n if (hasSlot === \"yes\") {\n flashPartition = `${image.partitionName}_${resolvedSlot}`;\n } else if (image.forceSlot) {\n logDebug(\n `Warning: ${image.partitionName} does not support slots but slot suffix was requested`,\n );\n }\n\n logDebug(\n `Flashing ${image.data.byteLength} bytes to \"${flashPartition}\"`,\n );\n await this.upload(flashPartition, image.data, onProgress);\n await this.runCommand(`flash:${flashPartition}`);\n }\n }\n\n /**\n * Determine the current slot\n */\n async getSlot() {\n const currentSlot = await this.getVariable(\"current-slot\");\n return currentSlot?.slice(-1);\n }\n\n /**\n * Determine the other slot\n * Hardcoded for A/B currently as that's what we mostly have in the field\n *\n */\n async getOtherSlot() {\n const currentSlot = await this.getSlot();\n if (currentSlot === \"a\") {\n return \"b\";\n } else if (currentSlot === \"b\") {\n return \"a\";\n } else {\n throw new FastbootError(\n \"FAIL\",\n `Unable to determine other slot, current slot: ${currentSlot}`,\n );\n }\n }\n}\n"],"names":["DebugLevel","readBlobAsBuffer","blob","Promise","resolve","reject","reader","FileReader","onload","result","onerror","error","readAsArrayBuffer","FastbootError","Error","status","bootloaderMessage","constructor","message","super","this","name","ImageError","LpError","TimeoutError","timeout","UsbError","debugLevel","Silent","debugLogger","console","log","logDebug","data","logVerbose","FILE_MAGIC","FILE_HEADER_SIZE","CHUNK_HEADER_SIZE","ChunkType","BlobBuilder","type","Blob","append","getBlob","parseFileHeader","buffer","view","DataView","getUint32","major","getUint16","minor","fileHdrSize","chunkHdrSize","blockSize","blocks","chunks","crc32","parseChunkHeader","dataBytes","calcChunksBlockSize","map","chunk","reduce","total","c","calcChunksSize","length","size","calcChunksDataSize","async","createImage","header","blobBuilder","ArrayBuffer","dataView","setUint32","setUint16","arrayView","Uint8Array","chunkArrayView","common.readBlobAsBuffer","set","LP_METADATA_HEADER_MAGIC","LP_SECTOR_SIZE","LP_METADATA_GEOMETRY_SIZE","LP_PARTITION_RESERVED_BYTES","HEADER_V1_0_SIZE","HEADER_V1_2_SIZE","nameFromFixedArray","offset","maxLen","bytes","i","b","getUint8","push","TextDecoder","decode","sha256","digest","crypto","subtle","arraysEqual","a","concatBuffers","buffers","totalLen","acc","byteLength","out","buf","padBuffer","slice","Math","min","parseTableDescriptor","numEntries","entrySize","validateTableBounds","table","tablesSize","tableSize","parsePartition","attributes","firstExtentIndex","numExtents","groupIndex","parseExtent","numSectors","getBigUint64","targetType","targetData","targetSource","parseGroup","flags","maximumSize","parseBlockDevice","firstLogicalSector","alignment","alignmentOffset","partitionName","parseTable","tablesView","descriptor","expectedEntrySize","parser","results","readFromImageBlob","geomBuf","primaryGeometryOffset","geometry","magic","toString","structSize","storedChecksum","forHash","fill","metadataMaxSize","metadataSlotCount","logicalBlockSize","checksum","parseGeometry","headerPeekOffset","headerPeekBuf","peekView","headerSize","headerBuf","tablesBuf","tablesBuffer","majorVersion","minorVersion","tablesChecksum","partitions","extents","groups","blockDevices","headerChecksum","parseHeader","superDevice","validAttributes","LP_PARTITION_ATTRIBUTE_MASK_V0","LP_PARTITION_ATTR_READONLY","partition","end","extent","BigInt","validateParsedMetadata","bd","getMetadataSuperBlockDevice","metadata","getBlockDevicePartitionName","serializeGeometry","serializeTableDescriptor","desc","serializeNameToFixedArray","encoded","TextEncoder","encode","setUint8","serializePartition","serializeExtent","setBigUint64","serializeGroup","group","serializeBlockDevice","serializeMetadata","partitionBufs","extentBufs","groupBufs","blockDevBufs","extentsOffset","s","groupsOffset","blockDevicesOffset","hv","hDescView","buildWipeSuperImages","rawMetaBuf","all","metaBuf","slotCount","allMetadata","Array","metadataBlocks","reservedBlocks","forceSlot","deviceBlocks","Number","sparseBlob","skipBlocks","sparseHeader","Sparse.ChunkType","Fill","Uint32Array","Raw","Skip","Sparse.createImage","MAX_32_BITS","MAX_16_BITS","SPLIT_ZIP_FILE_SIGNATURE","DATA_DESCRIPTOR_RECORD_SIGNATURE","CENTRAL_FILE_HEADER_SIGNATURE","ZIP64_END_OF_CENTRAL_DIR_SIGNATURE","END_OF_CENTRAL_DIR_LENGTH","FILE_ATTR_UNIX_TYPE_DIR","UNDEFINED_VALUE","undefined","INFINITY_VALUE","Infinity","UNDEFINED_TYPE","FUNCTION_TYPE","maxWorkers","navigator","hardwareConcurrency","DEFAULT_CONFIGURATION","workerURI","wasmURI","chunkSize","terminateWorkerTimeout","useWebWorkers","useCompressionStream","CompressionStream","DecompressionStream","config","Object","assign","configure","configuration","baseURI","CompressionStreamZlib","DecompressionStreamZlib","setIfDefined","propertyName","propertyValue","t","j","Crc32","crc","get","Crc32Stream","TransformStream","stream","transform","controller","enqueue","flush","value","bitArray","concat","a1","a2","last","shift","getPartial","_shiftRight","bitLength","l","x","clamp","len","ceil","partial","_end","round","carry","last2","shift2","pop","codec","fromBits","arr","tmp","toBits","hash","sha1","_init","_key","_h","_buffer","_length","reset","update","utf8String","ol","nl","_block","subarray","splice","finalize","h","floor","_f","d","_S","n","words","w","e","cipher","key","aes","_tables","_precompute","sbox","decTable","keyLen","encKey","decKey","rcon","encrypt","_crypt","decrypt","encTable","sboxInv","th","xInv","x2","x4","x8","tDec","tEnc","input","dir","nInnerRounds","t0","t1","t2","t3","b2","c2","kIndex","random","getRandomValues","typedArray","r","m_w","m_z","mask","rcache","_r","mode","prf","iv","_prf","_initIv","_iv","calculate","incWord","word","b1","b3","incCounter","counter","bl","misc","importKey","password","hmacSha1","pbkdf2","salt","count","u","ui","k","arrayBuffer","outLength","setInt32","hmac","Hash","_hash","exKey","_baseHash","bs","_resultHash","_updated","GET_RANDOM_VALUES_SUPPORTED","ERR_INVALID_PASSWORD","ERR_INVALID_SIGNATURE","ERR_ABORT_CHECK_PASSWORD","array","BLOCK_LENGTH","PBKDF2_ALGORITHM","BASE_KEY_ALGORITHM","DERIVED_BITS_ALGORITHM","iterations","DERIVED_BITS_USAGE","SALT_LENGTH","KEY_LENGTH","SIGNATURE_LENGTH","COUNTER_DEFAULT_VALUE","CRYPTO_API_SUPPORTED","SUBTLE_API_SUPPORTED","codecBytes","Aes","CtrGladman","ctrGladman","HmacSha1","IMPORT_KEY_SUPPORTED","DERIVE_BITS_SUPPORTED","deriveBits","AESDecryptionStream","rawPassword","signed","encryptionStrength","checkPasswordOnly","start","ready","resolveReady","encodePassword","strength","pending","aesCrypto","preamble","passwordVerificationKey","createKeys","passwordVerification","createDecryptionKeys","output","ctr","chunkToDecrypt","originalSignature","decryptedChunkArray","encryptedChunk","decryptedChunk","signature","indexSignature","AESEncryptionStream","createEncryptionKeys","encryptedChunkArray","paddingStart","paddingEnd","verifySignature","inputLength","inputArray","expand","inputChunk","outputChunk","baseKey","format","algorithm","extractable","keyUsages","derivedBits","compositeKey","authentication","keys","from","unescape","encodeURIComponent","charCodeAt","encodeText","leftArray","rightArray","begin","ZipCryptoDecryptionStream","zipCrypto","decryptedHeader","at","ZipCryptoEncryptionStream","HEADER_LENGTH","target","index","getByte","updateKeys","crcKey0","crcKey2","byte","key0","key1","key2","getInt32","imul","getInt8","temp","number","ERR_INVALID_UNCOMPRESSED_SIZE","DeflateStream","options","compressed","encrypted","level","crc32Stream","encryptionStream","readable","pipeThrough","pipeThroughCommpressionStream","setReadable","InflateStream","deflate64","decryptionStream","dataViewSignature","defineProperty","CompressionStreamNative","Stream","transformStream","MESSAGE_START","MESSAGE_PULL","MESSAGE_DATA","MESSAGE_CLOSE","CODEC_INFLATE","CodecStream","codecType","startsWith","outputSize","inputSize","inputSizeStream","outputSizeStream","ChunkStream","pendingChunk","newChunk","MODULE_WORKER_OPTIONS","webWorkerSupported","webWorkerURI","webWorkerOptions","transferStreamsSupported","structuredClone","DOMException","code","initModule","CodecWorker","workerData","writable","streamOptions","transferStreams","onTaskFinished","signal","busy","ProgressWatcherStream","terminate","worker","resolveTerminated","interface","terminated","Worker","createWebWorkerInterface","createWorkerInterface","onstart","onprogress","onend","chunkOffset","callHandler","handler","parameters","run","codecStream","pipeTo","preventClose","preventAbort","runWorker","getWebWorker","resolveResult","rejectResult","writer","closed","writableSource","watchClosedStream","streamsTransferred","sendMessage","getReader","getWriter","resultValue","close","runWebWorker","url","isModuleType","useBlobURI","resolvedURI","resolvedOptions","isFunctionURI","isDataURI","isBlobURI","URL","revokeObjectURL","addEventListener","event","messageId","stack","responseError","done","read","write","releaseLock","onMessage","transferables","postMessage","pool","pendingRequests","indexWorker","workerOptions","streamCopy","find","clearTerminateTimeout","getWorker","isFinite","terminateTimeout","setTimeout","filter","terminateWorker","clearTimeout","DEFAULT_CHUNK_SIZE","PROPERTY_NAME_WRITABLE","init","initialized","Reader","ReadableStream","pull","diskNumberStart","dataSize","readUint8Array","BlobReader","offsetEnd","BlobWriter","contentType","headers","Response","getData","TextWriter","encoding","utf8","toLowerCase","text","readAsText","SplitDataReader","readers","lastDiskNumber","lastDiskOffset","diskReader","indexDiskReader","diskNumber","currentDiskNumber","currentReaderOffset","currentReader","currentReaderSize","chunkLength","firstPart","secondPart","max","SplitDataWriter","writerGenerator","maxSize","diskSourceWriter","diskWritable","diskWriter","diskOffset","availableSize","WritableStream","writeChunk","closeDisk","next","initStream","GenericReader","isArray","GenericWriter","initSize","CP437","split","VALID_CP437","decodeText","trim","stringValue","indexCharacter","decodeCP437","PROPERTY_NAME_FILENAME","PROPERTY_NAME_RAW_FILENAME","PROPERTY_NAME_COMMENT","PROPERTY_NAME_RAW_COMMENT","PROPERTY_NAME_UNCOMPRESSED_SIZE","PROPERTY_NAME_COMPRESSED_SIZE","PROPERTY_NAME_OFFSET","PROPERTY_NAME_DISK_NUMBER_START","PROPERTY_NAME_LAST_MODIFICATION_DATE","PROPERTY_NAME_RAW_LAST_MODIFICATION_DATE","PROPERTY_NAME_LAST_ACCESS_DATE","PROPERTY_NAME_RAW_LAST_ACCESS_DATE","PROPERTY_NAME_CREATION_DATE","PROPERTY_NAME_RAW_CREATION_DATE","PROPERTY_NAMES","Entry","forEach","ERR_BAD_FORMAT","ERR_EXTRAFIELD_ZIP64_NOT_FOUND","ERR_UNSUPPORTED_COMPRESSION","ERR_SPLIT_ZIP_FILE","ERR_OVERLAPPING_ENTRY","CHARSET_UTF8","CHARSET_CP437","ZIP64_PROPERTIES","ZIP64_EXTRACTION","getValue","ZipReader","readRanges","getEntriesGenerator","zipReader","getChunkSize","endOfDirectoryInfo","startOffset","minimumBytes","maximumLength","signatureArray","getDataView","maximumBytes","seek","indexByte","seekSignature","endOfDirectoryView","directoryDataLength","directoryDataOffset","commentOffset","commentLength","appendedDataOffset","expectedLastDiskNumber","filesLength","prependedDataLength","endOfDirectoryLocatorView","endOfDirectoryArray","expectedDirectoryDataOffset","originalDirectoryDataOffset","directoryArray","directoryView","expectedDirectoryDataLength","filenameEncoding","getOptionValue","commentEncoding","indexFile","fileEntry","ZipEntry","readCommonHeader","languageEncodingFlag","Boolean","bitFlag","filenameOffset","extraFieldOffset","filenameLength","extraFieldLength","versionMadeBy","msDosCompatible","unixCompatible","rawFilename","endOffset","rawComment","filenameUTF8","commentUTF8","externalFileAttributes","msdosAttributesRaw","msdosAttributes","readOnly","hidden","system","directory","archive","offsetFileEntry","rawFilenameEncoding","rawCommentEncoding","filename","comment","compressedSize","uncompressedSize","internalFileAttributes","rawExtraField","readCommonFooter","unixExternalUpper","unixMode","setuid","setgid","sticky","executable","modeIsDir","upperIsDir","internalFileAttribute","externalFileAttribute","endsWith","extraFieldAES","entry","extractPrependedData","extractAppendedData","prependedData","appendedData","getEntries","entries","zipEntry","extraFieldZip64","compressionMethod","rawLastModDate","dataDescriptor","localDirectory","passThrough","originalCompressionMethod","lastAccessDate","creationDate","dataOffset","checkOverlappingEntry","checkOverlappingEntryOnly","indexReader","dataDescriptorLength","dataDescriptorArray","readSignature","readCompressedSize","readUncompressedSize","range","otherRange","overlappingEntry","detectOverlappingEntry","locked","rawBitFlag","version","lastModDate","getDate","extraField","Map","rawExtraFieldView","offsetExtraField","zip64","extraFieldView","missingProperties","indexMissingProperty","extraction","readExtraFieldZip64","extraFieldUnicodePath","readExtraFieldUnicode","extraFieldUnicodeComment","vendorVersion","vendorId","readExtraFieldAES","extraFieldNTFS","tag1Data","tagValue","attributeSize","tag1View","rawLastAccessDate","rawCreationDate","getDateNTFS","extraFieldData","readExtraFieldNTFS","extraFieldUnix","readExtraFieldUnix","extraFieldInfoZip","extraFieldExtendedTimestamp","timeProperties","timeRawProperties","indexProperty","time","Date","rawPropertyName","readExtraFieldExtendedTimestamp","extraFieldUSDZ","extraFieldUnicode","valid","isInfoZip","uidSize","uidBytes","uid","unpackUnixId","gidSize","gidBytes","gid","base","byteOffset","timeRaw","date","document","require","pathToFileURL","__filename","href","_documentCurrentScript","tagName","toUpperCase","src","A","wasm","malloc","free","memory","_make","isCompress","outBufferSize","outBuffer","inBufferSize","in","_scratch","_process","deflate_process","_last_consumed","deflate_last_consumed","deflate_end","streamHandle","deflate_new","deflate_init_gzip","deflate_init_raw","deflate_init","inflate9_process","inflate9_last_consumed","inflate9_end","inflate9_new","inflate9_init_raw","inflate_process","inflate_last_consumed","inflate_end","inflate_new","inflate_init_raw","inflate_init_gzip","inflate_init","heap","process","last_consumed","scratch","toRead","prod","signedCode","consumed","produced","modulePromise","initializedModule","uri","response","fetch","dataURI","base64","binary","atob","arrayBufferFromDataURI","wasmAPI","setWasmExports","WebAssembly","instantiate","instance","exports","g","B","replace","E","I","indexOf","C","Q","D","o","configureZlibModule","initModuleFunction","configureWorker","application","annodex","bbolin","dsptype","ecmascript","futuresplash","hta","m3g","mathematica","msaccess","msword","mxf","oda","ogg","pdf","postscript","rar","rtf","xml","zip","applixware","exi","gxf","hyperstudio","ipfix","marc","mbox","mp21","mp4","onenote","oxps","pkcs10","pkcs8","pkixcmp","sdp","srgs","widget","winhlp","yang","envoy","fractals","olescript","gzip","yaml","audio","amr","basic","flac","midi","mpeg","mpegurl","adpcm","s3m","silk","webm","xm","aac","aiff","opus","wav","chemical","font","otf","woff","woff2","image","gif","ief","jpeg","pcx","png","tiff","bmp","cgm","g3fax","ktx","sgi","webp","avif","heic","pjpeg","rfc822","model","iges","mesh","vrml","calendar","css","csv","h323","html","iuls","plain","richtext","scriptlet","texmacs","n3","sgml","troff","turtle","vcard","webviewhtml","javascript","json","markdown","video","dl","dv","fli","gl","quicktime","h261","h263","h264","jpm","mj2","mp2t","waitForFrame","window","requestAnimationFrame","runWithTimedProgress","onProgress","action","item","duration","workPromise","startTime","getTime","stop","progressPromise","now","targetTime","race","mimeTypes","subtype","indexMimeType","createObjectURL","configureWebWorker","BOOT_CRITICAL_IMAGES","SYSTEM_IMAGES","BOOTLOADER_REBOOT_TIME","flashEntryBlob","device","slot","flashBlob","progress","tryFlashImages","imageNames","imageName","pattern","RegExp","match","tryRebootWithSlotSwitch","onReconnect","rebootSwitchSlot","waitForConnect","flashZip","wipe","avbCustomKeyEntry","getVariable","reboot","snapshotStatus","runCommand","imagesBlob","imageReader","imageEntries","reqText","androidInfo","line","variable","expectValue","expectValues","hasSlot","includes","realValue","msg","checkRequirements","superName","superAction","superBlob","upload","epIn","epOut","_registeredUsbListeners","_connectResolve","_connectReject","_disconnectResolve","isConnected","opened","configurations","interfaces","claimed","_validateAndConnectDevice","ife","alternates","endpoints","endpoint","endpointNumber","direction","packetSize","open","selectConfiguration","claimInterface","waitForDisconnect","userAgent","connect","usb","requestDevice","filters","classCode","subclassCode","protocolCode","hasPromiseReject","_readResponse","respData","respStatus","respPacket","transferIn","substring","respMessage","command","RangeError","cmdPacket","transferOut","varName","resp","promise","timedOut","tid","then","val","catch","err","finally","_getDownloadSize","parseInt","_sendRawPayload","remainingBytes","xferHex","padStart","downloadResp","downloadSize","wait","otherSlot","getOtherSlot","currentSlot","getSlot","maxDlSize","fileHeader","Sparse.FILE_HEADER_SIZE","totalBytes","isSparse","Sparse.parseFileHeader","Sparse.fromRaw","splits","sentBytes","splitSize","safeSendValue","splitChunks","splitDataBytes","originalChunk","chunksToProcess","originalDataBytes","originalData","toSend","bytesRemaining","splitBlocks","splitImage","Sparse.splitBlob","bootBlob","flashFactoryZip","wipeSuper","Lp.readFromImageBlob","resolvedSlot","images","Lp.buildWipeSuperImages","Lp.getMetadataSuperBlockDevice","Lp.getBlockDevicePartitionName","flashPartition","load","unpack","flash","logger"],"mappings":"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pB,mBAAoB,CACnB,MACA,MACA,MACA,OAED,mBAAoB,MACpB,mBAAoB,MACpB,UAAW,CACV,MACA,SAED,SAAU,KACV,UAAW,CACV,MACA,OAED,mBAAoB,MACpB,SAAU,OACV,eAAgB,MAChB,mBAAoB,MACpB,eAAgB,MAChB,eAAgB,MAChB,oBAAqB,MACrB,QAAS,MACT,aAAc,MACd,qBAAsB,MACtB,mBAAoB,MACpB,aAAc,MACd,aAAc,MACd,aAAc,CACb,MACA,OAED,eAAgB,CACf,MACA,MACA,MACA,OAED,YAAa,MACb,mBAAoB,MACpB,UAAW,MACX,eAAgB,SAChB,yBAA0B,UAC1B,mBAAoB,CACnB,MACA,OAED,QAAS,MACT,qBAAsB,CACrB,MACA,QAED,mBAAoB,cACpB,gBAAiB,MACjB,YAAa,OACb,aAAc,MACd,eAAgB,MAChB,WAAY,MACZ,6BAA8B,MAC9B,gBAAiB,CAChB,MACA,MACA,OAED,eAAgB,CACf,MACA,MACA,MACA,OAED,YAAa,MACb,gBAAiB,MACjB,eAAgB,MAChB,eAAgB,MAChB,YAAa,MACb,QAAS,MACT,WAAY,CACX,MACA,OAED,uBAAwB,CACvB,MACA,OAED,0BAA2B,MAC3B,oBAAqB,MACrB,QAAS,MACT,aAAc,OACd,WAAY,MACZ,eAAgB,KAChB,YAAa,MACb,SAAU,MACV,cAAe,MACf,OAAQ,KACR,aAAc,CACb,KACA,KACA,KACA,KACA,KACA,KACA,KACA,MAED,WAAY,OACZ,gBAAiB,MACjB,WAAY,OACZ,UAAW,MACX,UAAW,MACX,YAAa,MACb,WAAY,OACZ,SAAU,CACT,OACA,QACA,OACA,OAEDC,KAAQ,OACR,UAAW,MACXC,MAAS,MACTC,SAAY,MACZ,2BAA4B,MAC5BC,UAAa,MACb,iBAAkB,MAClB,sBAAuB,MACvB,aAAc,IACd,YAAa,CACZ,MACA,MACA,MACA,OAED,gBAAiB,MACjBC,KAAQ,CACP,KACA,OAED,WAAY,CACX,MACA,QAED,4BAA6B,CAC5B,MACA,QAED,uBAAwB,MACxB,cAAe,CACd,KACA,SACA,UACA,SACA,aACA,SACA,cAED,cAAe,MACf,cAAe,MACf,UAAW,CACV,MACA,OAED,SAAU,CACT,KACA,MAEDC,KAAQ,CACP,OACA,QAGFC,MAAS,CACRC,IAAO,MACP,SAAU,MACV5C,QAAW,MACX6C,MAAS,CACR,KACA,OAEDC,KAAQ,OACRC,KAAQ,CACP,MACA,OACA,MACA,OAEDC,KAAQ,CACP,OACA,QACA,MACA,MACA,OACA,MACA,OAEDC,QAAW,MACXrC,IAAO,CACN,MACA,MACA,OAED,UAAW,MACX,SAAU,OACV,QAAS,MACT,WAAY,MACZ,WAAY,MACZ,iBAAkB,MAClB,cAAe,KACf,QAAS,MACTsC,MAAS,MACTvB,IAAO,OACPwB,IAAO,MACPC,KAAQ,MACR,iBAAkB,CACjB,MACA,QAED,oBAAqB,MACrB,UAAW,MACX,UAAW,MACX,aAAc,QACd,mBAAoB,MACpB,6BAA8B,MAC9B,sBAAuB,YACvB,sBAAuB,YACvB,sBAAuB,YACvB,UAAW,MACXC,KAAQ,OACR,QAAS,MACT,aAAc,MACd,wBAAyB,MACzBC,GAAM,KACNC,IAAO,MACPC,KAAQ,CACP,OACA,MACA,OAEDC,KAAQ,OACRC,IAAO,OAERC,SAAY,CACX,YAAa,MACb,UAAW,CACV,MACA,SAED,cAAe,MACf,kBAAmB,CAClB,OACA,SACA,QAED,QAAS,MACT,WAAY,MACZ,QAAS,MACT,SAAU,OACV,QAAS,MACT,YAAa,MACb,cAAe,MACf,SAAU,CACT,OACA,OAED,QAAS,MACT,QAAS,CACR,MACA,OAED,uBAAwB,CACvB,MACA,QAED,iBAAkB,CACjB,MACA,MACA,SAED,wBAAyB,CACxB,MACA,QAED,kBAAmB,MACnB,mBAAoB,CACnB,MACA,MACA,OAED,iBAAkB,MAClB,kBAAmB,MACnB,YAAa,MACb,QAAS,MACT,YAAa,CACZ,OACA,OAED,aAAc,CACb,MACA,MAED,aAAc,MACd,gBAAiB,MACjB,qBAAsB,OACtB,gBAAiB,MACjB,eAAgB,KAChB,gBAAiB,MACjB,eAAgB,KAChB,YAAa,MACb,UAAW,OACX,SAAU,OACV,cAAe,IACf,gBAAiB,MACjB,gBAAiB,CAChB,MACA,SACA,OAED,cAAe,MACf,cAAe,MACf,oBAAqB,CACpB,MACA,OAED,qBAAsB,MACtB,WAAY,MACZ,cAAe,KACf,mBAAoB,MACpB,QAAS,MACT,SAAU,OACV,QAAS,OAEVC,KAAQ,CACPC,IAAO,MACPC,KAAQ,OACRC,MAAS,SAEVC,MAAS,CACRC,IAAO,MACPC,IAAO,MACPC,KAAQ,CACP,OACA,MACA,MACA,OACA,YACA,OAEDC,IAAO,MACPC,IAAO,MACP,UAAW,CACV,MACA,QAEDC,KAAQ,CACP,OACA,OAED,WAAY,CACX,OACA,OAED,eAAgB,OAChB,cAAe,MACf,cAAe,MACf,eAAgB,MAChB,cAAe,MACf,qBAAsB,MACtB,sBAAuB,MACvB,oBAAqB,MACrB,cAAe,MACf,SAAU,MACV,OAAQ,MACR,QAAS,MACT,cAAe,MACf,gBAAiB,MACjB,oBAAqB,MACrB,oBAAqB,MACrB,qBAAsB,MACtB,oBAAqB,MACrB,QAAS,MACT,YAAa,MACb,YAAa,MACb,gBAAiB,MACjBC,IAAO,MACPC,IAAO,MACPC,MAAS,KACTC,IAAO,MACP,WAAY,OACZC,IAAO,MACP,mBAAoB,CACnB,MACA,OACA,MACA,QAED,UAAW,MACX,UAAW,MACX,mBAAoB,MACpB,UAAW,MACX,UAAW,MACX,2BAA4B,MAC5B,2BAA4B,MAC5B,cAAe,MACf,eAAgB,MAChB,cAAe,MACf,WAAY,MACZC,KAAQ,OACR,QAAS,MACT,QAAS,MACT,aAAc,CACb,KACA,MACA,MACA,MACA,OAED,SAAU,CACT,MACA,OAED,QAAS,MACT,UAAW,MACXC,KAAQ,QACRC,KAAQ,CACP,OACA,QAEDC,MAAS,CACR,QAED,sBAAuB,MACvB,cAAe,MACf,aAAc,MACd,SAAU,OACV,cAAe,MACf,cAAe,MACf,cAAe,MACf,gBAAiB,MACjB,kBAAmB,CAClB,MACA,MACA,OAED,eAAgB,CACf,MACA,OAED,cAAe,MACf,aAAc,MACd,aAAc,MACd,aAAc,OAEfnhC,QAAW,CACVohC,OAAU,CACT,MACA,OACA,MACA,QACA,QAGFC,MAAS,CACRC,KAAQ,CACP,MACA,QAEDC,KAAQ,CACP,MACA,OACA,QAEDC,KAAQ,CACP,MACA,QAED,WAAY,CACX,OACA,SAED,UAAW,OACX,aAAc,CACb,OACA,SAED,kBAAmB,MACnB,UAAW,MACX,UAAW,MACX,UAAW,MACX,UAAW,MACX,eAAgB,OAChB,UAAW,OAEZrZ,KAAQ,CACP,iBAAkB,CACjB,WACA,YAEDsZ,SAAY,CACX,MACA,MACA,OAEDC,IAAO,MACPC,IAAO,MACPC,KAAQ,MACRC,KAAQ,CACP,OACA,MACA,QACA,OAEDC,KAAQ,MACRC,MAAS,CACR,MACA,OACA,MACA,OACA,MACA,OACA,MACA,KACA,MACA,OACA,OAEDC,SAAY,MACZC,UAAa,CACZ,MACA,OAEDC,QAAW,KACX,uBAAwB,MACxB,8BAA+B,MAC/B,cAAe,MACf,oBAAqB,OACrB,WAAY,MACZ,QAAS,MACT,WAAY,CACX,MACA,MACA,MACA,MAED,WAAY,CACX,MACA,MACA,MACA,MAED,cAAe,MACf,SAAU,IACV,SAAU,QACV,YAAa,KACb,SAAU,OACV,qBAAsB,MACtB,QAAS,MACT,WAAY,CACX,IACA,MACA,KACA,OAED,YAAa,MACb,WAAY,KACZ,UAAW,QACX,WAAY,MACZ,QAAS,CACR,MACA,MAED,QAAS,CACR,MACA,MACA,MACA,OAED,cAAe,MACf,UAAW,MACXC,GAAM,KACN,gBAAiB,MACjBC,KAAQ,CACP,OACA,OAEDC,MAAS,CACR,IACA,KACA,OACA,MACA,KACA,MAEDC,OAAU,MACV,WAAY,CACX,MACA,OACA,QAEDC,MAAS,QACT,WAAY,OACZ,iBAAkB,QAClB,iBAAkB,QAClB,iBAAkB,QAClB,mBAAoB,MACpB,UAAW,MACX,mBAAoB,MACpB,eAAgB,KAChB,gBAAiB,OACjB,gBAAiB,OACjB,QAAS,CACR,IACA,OAED,MAAO,CACN,IACA,IACA,OAED,YAAa,CACZ,IACA,MACA,MACA,OAED,SAAU,OACV,QAAS,MACT,QAAS,MACT,aAAc,KACdC,YAAe,MACfC,WAAc,KACdC,KAAQ,OACRC,S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","x_google_ignoreList":[5,6,7,8,9,10,11,12,13,14,15,16,17,18,19,20,21,22,23,24,25,26,27,28,29,31,32]}
|