Skip to main content
Module

x/zipjs/index.d.ts

JavaScript library to zip and unzip files supporting multi-core compression, compression streams, zip64, split files and encryption.
Go to Latest
File
1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889909192939495969798991001011021031041051061071081091101111121131141151161171181191201211221231241251261271281291301311321331341351361371381391401411421431441451461471481491501511521531541551561571581591601611621631641651661671681691701711721731741751761771781791801811821831841851861871881891901911921931941951961971981992002012022032042052062072082092102112122132142152162172182192202212222232242252262272282292302312322332342352362372382392402412422432442452462472482492502512522532542552562572582592602612622632642652662672682692702712722732742752762772782792802812822832842852862872882892902912922932942952962972982993003013023033043053063073083093103113123133143153163173183193203213223233243253263273283293303313323333343353363373383393403413423433443453463473483493503513523533543553563573583593603613623633643653663673683693703713723733743753763773783793803813823833843853863873883893903913923933943953963973983994004014024034044054064074084094104114124134144154164174184194204214224234244254264274284294304314324334344354364374384394404414424434444454464474484494504514524534544554564574584594604614624634644654664674684694704714724734744754764774784794804814824834844854864874884894904914924934944954964974984995005015025035045055065075085095105115125135145155165175185195205215225235245255265275285295305315325335345355365375385395405415425435445455465475485495505515525535545555565575585595605615625635645655665675685695705715725735745755765775785795805815825835845855865875885895905915925935945955965975985996006016026036046056066076086096106116126136146156166176186196206216226236246256266276286296306316326336346356366376386396406416426436446456466476486496506516526536546556566576586596606616626636646656666676686696706716726736746756766776786796806816826836846856866876886896906916926936946956966976986997007017027037047057067077087097107117127137147157167177187197207217227237247257267277287297307317327337347357367377387397407417427437447457467477487497507517527537547557567577587597607617627637647657667677687697707717727737747757767777787797807817827837847857867877887897907917927937947957967977987998008018028038048058068078088098108118128138148158168178188198208218228238248258268278288298308318328338348358368378388398408418428438448458468478488498508518528538548558568578588598608618628638648658668678688698708718728738748758768778788798808818828838848858868878888898908918928938948958968978988999009019029039049059069079089099109119129139149159169179189199209219229239249259269279289299309319329339349359369379389399409419429439449459469479489499509519529539549559569579589599609619629639649659669679689699709719729739749759769779789799809819829839849859869879889899909919929939949959969979989991000100110021003100410051006100710081009101010111012101310141015101610171018101910201021102210231024102510261027102810291030103110321033103410351036103710381039104010411042104310441045104610471048104910501051105210531054105510561057105810591060106110621063106410651066106710681069107010711072107310741075107610771078107910801081108210831084108510861087108810891090109110921093109410951096109710981099110011011102110311041105110611071108110911101111111211131114111511161117111811191120112111221123112411251126112711281129113011311132113311341135113611371138113911401141114211431144114511461147114811491150115111521153115411551156115711581159116011611162116311641165116611671168116911701171117211731174117511761177117811791180118111821183118411851186118711881189119011911192119311941195119611971198119912001201120212031204120512061207120812091210121112121213121412151216121712181219122012211222122312241225122612271228122912301231123212331234123512361237123812391240124112421243124412451246124712481249125012511252125312541255125612571258125912601261126212631264126512661267126812691270127112721273127412751276127712781279128012811282128312841285128612871288128912901291129212931294129512961297129812991300130113021303130413051306130713081309131013111312131313141315131613171318131913201321132213231324132513261327132813291330133113321333133413351336133713381339134013411342134313441345134613471348134913501351135213531354135513561357135813591360136113621363136413651366136713681369137013711372137313741375137613771378137913801381138213831384138513861387138813891390139113921393139413951396139713981399140014011402140314041405140614071408140914101411141214131414141514161417141814191420142114221423142414251426142714281429143014311432143314341435143614371438143914401441144214431444144514461447144814491450145114521453145414551456145714581459146014611462146314641465146614671468146914701471147214731474147514761477147814791480148114821483148414851486148714881489149014911492149314941495149614971498149915001501150215031504150515061507150815091510151115121513151415151516151715181519152015211522152315241525152615271528152915301531153215331534153515361537153815391540154115421543154415451546154715481549155015511552155315541555155615571558155915601561156215631564156515661567156815691570157115721573157415751576157715781579158015811582158315841585158615871588158915901591159215931594159515961597159815991600160116021603160416051606160716081609161016111612161316141615161616171618161916201621162216231624162516261627162816291630163116321633163416351636163716381639164016411642164316441645164616471648164916501651165216531654165516561657165816591660166116621663166416651666166716681669167016711672167316741675167616771678167916801681168216831684168516861687168816891690169116921693169416951696169716981699170017011702170317041705170617071708170917101711171217131714171517161717171817191720172117221723172417251726172717281729173017311732173317341735173617371738173917401741174217431744174517461747174817491750175117521753175417551756175717581759176017611762176317641765176617671768176917701771177217731774177517761777177817791780178117821783178417851786178717881789179017911792179317941795179617971798179918001801180218031804180518061807180818091810181118121813181418151816181718181819182018211822182318241825182618271828182918301831183218331834183518361837183818391840184118421843184418451846184718481849185018511852185318541855185618571858185918601861186218631864186518661867186818691870187118721873187418751876187718781879188018811882188318841885188618871888188918901891189218931894189518961897189818991900190119021903190419051906190719081909191019111912191319141915191619171918191919201921192219231924192519261927192819291930193119321933193419351936193719381939194019411942194319441945194619471948194919501951195219531954195519561957195819591960196119621963196419651966196719681969197019711972197319741975197619771978197919801981198219831984198519861987198819891990199119921993199419951996199719981999200020012002200320042005200620072008200920102011201220132014201520162017201820192020202120222023202420252026202720282029203020312032
/** * Represents the `FileSystemEntry` class. * * @see {@link https://wicg.github.io/entries-api/#api-entry|specification} */// deno-lint-ignore no-empty-interfaceinterface FileSystemEntryLike {}
/** * Represents the `FileSystemHandle` class. * * @see {@link https://fs.spec.whatwg.org/#api-filesystemhandle} */// deno-lint-ignore no-empty-interfaceinterface FileSystemHandleLike {}
/** * Represents a generic `TransformStream` class. * * @see {@link https://streams.spec.whatwg.org/#generictransformstream|specification} */declare class TransformStreamLike { /** * The readable stream. */ readable: ReadableStream; /** * The writable stream. */ writable: WritableStream;}
/** * Configures zip.js * * @param configuration The configuration. */export function configure(configuration: Configuration): void;
/** * Represents the configuration passed to {@link configure}. */export interface Configuration extends WorkerConfiguration { /** * The maximum number of web workers used to compress/decompress data simultaneously. * * @defaultValue `navigator.hardwareConcurrency` */ maxWorkers?: number; /** * The delay in milliseconds before idle web workers are automatically terminated. You can call `terminateWorkers()` to terminate idle workers. * * @defaultValue 5000 */ terminateWorkerTimeout?: number; /** * The URIs of the compression/decompression scripts run in web workers. * * It allows using alternative deflate implementations or specifying a URL to the worker script if the CSP of the page blocks scripts imported from a Blob URI. * The properties `deflate` and `inflate` must specify arrays of URLs to import the deflate/inflate web workers, respectively. * The first URL is relative to the base URI of the document. The other URLs are relative to the URL of the first script. Scripts in the array are executed in order. * If you only use deflation or inflation, the unused `deflate`/`inflate` property can be omitted. * * Here is an example: * ``` * configure({ * workerScripts: { * deflate: ["library_path/custom-worker.js", "./custom-deflate.js"], * inflate: ["library_path/custom-worker.js", "./custom-inflate.js"] * } * }); * ``` * * If the CSP of the page blocks scripts imported from a Blob URI you can use `z-worker.js` from https://github.com/gildas-lormeau/zip.js/tree/master/dist and specify the URL where it can be found. * * Here is an example: * ``` * configure({ * workerScripts: { * deflate: ["library_path/z-worker.js"], * inflate: ["library_path/z-worker.js"] * } * }); * ``` */ workerScripts?: { /** * The URIs of the scripts implementing used for compression. */ deflate?: string[]; /** * The URIs of the scripts implementing used for decompression. */ inflate?: string[]; }; /** * The size of the chunks in bytes during data compression/decompression. * * @defaultValue 524288 */ chunkSize?: number; /** * The codec implementation used to compress data. * * @defaultValue {@link ZipDeflate} */ Deflate?: typeof ZipDeflate; /** * The codec implementation used to decompress data. * * @defaultValue {@link ZipInflate} */ Inflate?: typeof ZipInflate; /** * The stream implementation used to compress data when `useCompressionStream` is set to `false`. * * @defaultValue {@link CodecStream} */ CompressionStream?: typeof TransformStreamLike; /** * The stream implementation used to decompress data when `useCompressionStream` is set to `false`. * * @defaultValue {@link CodecStream} */ DecompressionStream?: typeof TransformStreamLike;}
/** * Represents configuration passed to {@link configure}, the constructor of {@link ZipReader}, {@link Entry#getData}, the constructor of {@link ZipWriter}, and {@link ZipWriter#add}. */export interface WorkerConfiguration { /** * `true` to use web workers to compress/decompress data in non-blocking background processes. * * @defaultValue true */ useWebWorkers?: boolean; /** * `true` to use the native API `CompressionStream`/`DecompressionStream` to compress/decompress data. * * @defaultValue true */ useCompressionStream?: boolean;}
/** * Transforms event-based third-party codec implementations into implementations compatible with zip.js * * @param library The third-party codec implementations. * @param constructorOptions The options passed to the third-party implementations when building instances. * @param registerDataHandler The function called to handle the `data` events triggered by a third-party codec implementation. * @returns An instance containing classes compatible with {@link ZipDeflate} and {@link ZipInflate}. */export function initShimAsyncCodec( library: EventBasedZipLibrary, constructorOptions: unknown | null, registerDataHandler: registerDataHandler,): ZipLibrary;
/** * Represents the callback function used to register the `data` event handler. */export interface registerDataHandler { /** * @param codec The third-party codec instance. * @param onData The `data` event handler. */ (codec: EventBasedCodec, onData: dataHandler): void;}
/** * Represents the callback function used to handle `data` events. */export interface dataHandler { /** * @param data The processed chunk of data. */ (data: Uint8Array): void;}
/** * Terminates all the web workers */export function terminateWorkers(): Promise<void>;
/** * Represents event-based implementations used to compress/decompress data. */export interface EventBasedZipLibrary { /** * The class used to compress data. */ Deflate: typeof EventBasedCodec; /** * The class used to decompress data. */ Inflate: typeof EventBasedCodec;}
/** * Represents an event-based implementation of a third-party codec. */declare class EventBasedCodec { /** * Appends a chunk of data to compress/decompress * * @param data The chunk of data to append. */ push(data: Uint8Array): void; /** * The function called when a chunk of data has been compressed/decompressed. * * @param data The chunk of compressed/decompressed data. */ ondata(data?: Uint8Array): void;}
/** * Represents the implementations zip.js uses to compress/decompress data. */export interface ZipLibrary { /** * The class used to compress data. * * @defaultValue {@link ZipDeflate} */ Deflate: typeof ZipDeflate; /** * The class used to decompress data. * * @defaultValue {@link ZipInflate} */ Inflate: typeof ZipInflate;}
declare class SyncCodec { /** * Appends a chunk of decompressed data to compress * * @param data The chunk of decompressed data to append. * @returns A chunk of compressed data. */ append(data: Uint8Array): Uint8Array;}
/** * Represents an instance used to compress data. */declare class ZipDeflate extends SyncCodec { /** * Flushes the data * * @returns A chunk of compressed data. */ flush(): Uint8Array;}
/** * Represents a codec used to decompress data. */declare class ZipInflate extends SyncCodec { /** * Flushes the data */ flush(): void;}
/** * Represents a class implementing `CompressionStream` or `DecompressionStream` interfaces. */declare class CodecStream extends TransformStream {}
/** * Returns the MIME type corresponding to a filename extension. * * @param fileExtension the extension of the filename. * @returns The corresponding MIME type. */export function getMimeType(fileExtension: string): string;
/** * Represents an instance used to read or write unknown type of data. * * zip.js can handle multiple types of data thanks to a generic API. This feature is based on 2 abstract constructors: {@link Reader} and {@link Writer}. * The classes inheriting from {@link Reader} help to read data from a source of data. The classes inheriting from {@link Writer} help to write data into a destination. */export interface Initializable { /** * Initializes the instance asynchronously */ init?(): Promise<void>;}
/** * Represents an instance used to read data from a `ReadableStream` instance. */export interface ReadableReader { /** * The `ReadableStream` instance. */ readable: ReadableStream;}
/** * Represents an instance used to read unknown type of data. * * @example * Here is an example of custom {@link Reader} class used to read binary strings: * ``` * class BinaryStringReader extends Reader { * * constructor(binaryString) { * super(); * this.binaryString = binaryString; * } * * init() { * super.init(); * this.size = this.binaryString.length; * } * * readUint8Array(offset, length) { * const result = new Uint8Array(length); * for (let indexCharacter = 0; indexCharacter < length; indexCharacter++) { * result[indexCharacter] = this.binaryString.charCodeAt(indexCharacter + offset) & 0xFF; * } * return result; * } * } * ``` */export class Reader<Type> implements Initializable, ReadableReader { /** * Creates the {@link Reader} instance * * @param value The data to read. */ constructor(value: Type); /** * The `ReadableStream` instance. */ readable: ReadableStream; /** * The total size of the data in bytes. */ size: number; /** * Initializes the instance asynchronously */ init?(): Promise<void>; /** * Reads a chunk of data * * @param index The byte index of the data to read. * @param length The length of the data to read in bytes. * @returns A promise resolving to a chunk of data. */ readUint8Array(index: number, length: number): Promise<Uint8Array>;}
/** * Represents a {@link Reader} instance used to read data provided as a `string`. */export class TextReader extends Reader<string> {}
/** * Represents a {@link Reader} instance used to read data provided as a `Blob` instance. */export class BlobReader extends Reader<Blob> {}
/** * Represents a {@link Reader} instance used to read data provided as a Data URI `string` encoded in Base64. */export class Data64URIReader extends Reader<string> {}
/** * Represents a {@link Reader} instance used to read data provided as a `Uint8Array` instance. */export class Uint8ArrayReader extends Reader<Uint8Array> {}
/** * Represents a {@link Reader} instance used to read data provided as an array of {@link ReadableReader} instances (e.g. split zip files). * * @deprecated Use {@link SplitDataReader} instead. */export class SplitZipReader extends SplitDataReader {}
/** * Represents a {@link Reader} instance used to read data provided as an array of {@link ReadableReader} instances (e.g. split zip files). */export class SplitDataReader extends Reader<Reader<unknown>[] | ReadableReader[] | ReadableStream[]> {}
/** * Represents a URL stored into a `string`. */// deno-lint-ignore no-empty-interfaceinterface URLString extends String {}
/** * Represents a {@link Reader} instance used to fetch data from a URL. */export class HttpReader extends Reader<URLString> { /** * Creates the {@link HttpReader} instance * * @param url The URL of the data. * @param options The options. */ constructor(url: URLString, options?: HttpOptions);}
/** * Represents a {@link Reader} instance used to fetch data from servers returning `Accept-Ranges` headers. */export class HttpRangeReader extends HttpReader { /** * Creates the {@link HttpRangeReader} instance * * @param url The URL of the data. * @param options The options. */ constructor(url: URLString, options?: HttpRangeOptions);}
/** * Represents the options passed to the constructor of {@link HttpReader}. */export interface HttpOptions extends HttpRangeOptions { /** * `true` to use `Range` headers when fetching data from servers returning `Accept-Ranges` headers. * * @defaultValue false */ useRangeHeader?: boolean; /** * `true` to always use `Range` headers when fetching data. * * @defaultValue false */ forceRangeRequests?: boolean; /** * `true` to prevent using `HEAD` HTTP request in order the get the size of the content. * `false` to explicitly use `HEAD`, this is useful in case of CORS where `Access-Control-Expose-Headers: Content-Range` is not returned by the server. * * @defaultValue false */ preventHeadRequest?: boolean; /** * `true` to use `Range: bytes=-22` on the first request and cache the EOCD, make sure beforehand that the server supports a suffix range request. * * @defaultValue false */ combineSizeEocd?: boolean;}
/** * Represents options passed to the constructor of {@link HttpRangeReader} and {@link HttpReader}. */export interface HttpRangeOptions { /** * `true` to rely `XMLHttpRequest` instead of `fetch` to fetch data. * * @defaultValue false */ useXHR?: boolean; /** * The HTTP headers. */ headers?: Iterable<[string, string]> | Map<string, string>;}
/** * Represents an instance used to write data into a `WritableStream` instance. */export interface WritableWriter { /** * The `WritableStream` instance. */ writable: WritableStream; /** * The maximum size of split data when creating a {@link ZipWriter} instance or when calling {@link Entry#getData} with a generator of {@link WritableWriter} instances. */ maxSize?: number;}
/** * Represents an instance used to write unknown type of data. * * @example * Here is an example of custom {@link Writer} class used to write binary strings: * ``` * class BinaryStringWriter extends Writer { * * constructor() { * super(); * this.binaryString = ""; * } * * writeUint8Array(array) { * for (let indexCharacter = 0; indexCharacter < array.length; indexCharacter++) { * this.binaryString += String.fromCharCode(array[indexCharacter]); * } * } * * getData() { * return this.binaryString; * } * } * ``` */export class Writer<Type> implements Initializable, WritableWriter { /** * The `WritableStream` instance. */ writable: WritableStream; /** * Initializes the instance asynchronously * * @param size the total size of the written data in bytes. */ init?(size?: number): Promise<void>; /** * Appends a chunk of data * * @param array The chunk data to append. * * @virtual */ writeUint8Array(array: Uint8Array): Promise<void>; /** * Retrieves all the written data * * @returns A promise resolving to the written data. */ getData(): Promise<Type>;}
/** * Represents a {@link Writer} instance used to retrieve the written data as a `string`. */export class TextWriter extends Writer<string> { /** * Creates the {@link TextWriter} instance * * @param encoding The encoding of the text. */ constructor(encoding?: string);}
/** * Represents a {@link WritableWriter} instance used to retrieve the written data as a `Blob` instance. */export class BlobWriter implements Initializable, WritableWriter { /** * The `WritableStream` instance. */ writable: WritableStream; /** * Initializes the instance asynchronously */ init(): Promise<void>; /** * Creates the {@link BlobWriter} instance * * @param mimeString The MIME type of the content. */ constructor(mimeString?: string); /** * Retrieves all the written data * * @returns A promise resolving to the written data. */ getData(): Promise<Blob>;}
/** * Represents a {@link Writer} instance used to retrieve the written data as a Data URI `string` encoded in Base64. */export class Data64URIWriter extends Writer<string> { /** * Creates the {@link Data64URIWriter} instance * * @param mimeString The MIME type of the content. */ constructor(mimeString?: string);}
/** * Represents a {@link Writer} instance used to retrieve the written data from a generator of {@link WritableWriter} instances (i.e. split zip files). * * @deprecated Use {@link SplitDataWriter} instead. */export class SplitZipWriter extends SplitDataWriter {}
/** * Represents a {@link Writer} instance used to retrieve the written data from a generator of {@link WritableWriter} instances (i.e. split zip files). */export class SplitDataWriter implements Initializable, WritableWriter { /** * The `WritableStream` instance. */ writable: WritableStream; /** * Initializes the instance asynchronously */ init(): Promise<void>; /** * Creates the {@link SplitDataWriter} instance * * @param writerGenerator A generator of Writer instances. * @param maxSize The maximum size of the data written into {@link Writer} instances (default: 4GB). */ constructor( writerGenerator: AsyncGenerator< Writer<unknown> | WritableWriter | WritableStream, boolean >, maxSize?: number, );}
/** * Represents a {@link Writer} instance used to retrieve the written data as a `Uint8Array` instance. */export class Uint8ArrayWriter extends Writer<Uint8Array> {}
/** * Represents an instance used to create an unzipped stream. * * @example * This example will take a zip file, decompress it and then recompress each file in it, saving it to disk. * ``` * for await (const entry of (await fetch(urlToZippedFile)).body.pipeThrough(new ZipWriterStream())) * if (entry.readable) { * console.log(entry.filename) * entry.readable * .pipeThrough(ZipReaderStream().transform(entry.filename)) * .pipeTo((await Deno.create(entry.filename + '.zip')).writable) * } * ``` */export class ZipReaderStream<T> { /** * Creates the stream. * * @param options The options. */ constructor(options?: ZipReaderConstructorOptions);
/** * The readable stream. */ readable: ReadableStream< Omit<Entry, "getData"> & { readable?: ReadableStream<Uint8Array> } >;
/** * The writable stream. */ writable: WritableStream<T>;}
/** * Represents an instance used to read a zip file. * * @example * Here is an example showing how to read the text data of the first entry from a zip file: * ``` * // create a BlobReader to read with a ZipReader the zip from a Blob object * const reader = new zip.ZipReader(new zip.BlobReader(blob)); * * // get all entries from the zip * const entries = await reader.getEntries(); * if (entries.length) { * * // get first entry content as text by using a TextWriter * const text = await entries[0].getData( * // writer * new zip.TextWriter(), * // options * { * onprogress: (index, max) => { * // onprogress callback * } * } * ); * // text contains the entry data as a String * console.log(text); * } * * // close the ZipReader * await reader.close(); * ``` */export class ZipReader<Type> { /** * Creates the instance * * @param reader The {@link Reader} instance used to read data. * @param options The options. */ constructor( reader: | Reader<Type> | ReadableReader | ReadableStream | Reader<unknown>[] | ReadableReader[] | ReadableStream[], options?: ZipReaderConstructorOptions, ); /** * The global comment of the zip file. */ comment: Uint8Array; /** * The data prepended before the zip file. */ prependedData?: Uint8Array; /** * The data appended after the zip file. */ appendedData?: Uint8Array; /** * Returns all the entries in the zip file * * @param options The options. * @returns A promise resolving to an `array` of {@link Entry} instances. */ getEntries(options?: ZipReaderGetEntriesOptions): Promise<Entry[]>; /** * Returns a generator used to iterate on all the entries in the zip file * * @param options The options. * @returns An asynchronous generator of {@link Entry} instances. */ getEntriesGenerator( options?: ZipReaderGetEntriesOptions, ): AsyncGenerator<Entry, boolean>; /** * Closes the zip file */ close(): Promise<void>;}
/** * Represents the options passed to the constructor of {@link ZipReader}, and `{@link ZipDirectory}#import*`. */export interface ZipReaderConstructorOptions extends ZipReaderOptions, GetEntriesOptions, WorkerConfiguration { /** * `true` to extract the prepended data into {@link ZipReader#prependedData}. * * @defaultValue false */ extractPrependedData?: boolean; /** * `true` to extract the appended data into {@link ZipReader#appendedData}. * * @defaultValue false */ extractAppendedData?: boolean;}
/** * Represents the options passed to {@link ZipReader#getEntries} and {@link ZipReader#getEntriesGenerator}. */export interface ZipReaderGetEntriesOptions extends GetEntriesOptions, EntryOnprogressOptions {}
/** * Represents options passed to the constructor of {@link ZipReader}, {@link ZipReader#getEntries} and {@link ZipReader#getEntriesGenerator}. */export interface GetEntriesOptions { /** * The encoding of the filename of the entry. */ filenameEncoding?: string; /** * The encoding of the comment of the entry. */ commentEncoding?: string;}
/** * Represents options passed to the constructor of {@link ZipReader} and {@link Entry#getData}. */export interface ZipReaderCheckPasswordOptions { /** * `true` to check only if the password is valid. * * @defaultValue false */ checkPasswordOnly: boolean;}
/** * Represents options passed to the constructor of {@link ZipReader} and {@link Entry#getData}. */export interface ZipReaderOptions { /** * `true` to check the signature of the entry. * * @defaultValue false */ checkSignature?: boolean; /** * The password used to decrypt the content of the entry. */ password?: string; /** * The password used to encrypt the content of the entry (raw). */ rawPassword?: Uint8Array; /** * The `AbortSignal` instance used to cancel the decompression. */ signal?: AbortSignal; /** * `true` to prevent closing of {@link Writer#writable} when calling {@link Entry#getData}. * * @defaultValue false */ preventClose?: boolean; /** * `true` to transfer streams to web workers when decompressing data. * * @defaultValue true */ transferStreams?: boolean;}
/** * Represents the metadata of an entry in a zip file (Core API). */export interface EntryMetaData { /** * The byte offset of the entry. */ offset: number; /** * The filename of the entry. */ filename: string; /** * The filename of the entry (raw). */ rawFilename: Uint8Array; /** * `true` if the filename is encoded in UTF-8. */ filenameUTF8: boolean; /** * `true` if the entry is a directory. */ directory: boolean; /** * `true` if the content of the entry is encrypted. */ encrypted: boolean; /** * The size of the compressed data in bytes. */ compressedSize: number; /** * The size of the decompressed data in bytes. */ uncompressedSize: number; /** * The last modification date. */ lastModDate: Date; /** * The last access date. */ lastAccessDate?: Date; /** * The creation date. */ creationDate?: Date; /** * The last modification date (raw). */ rawLastModDate: number | bigint; /** * The last access date (raw). */ rawLastAccessDate?: number | bigint; /** * The creation date (raw). */ rawCreationDate?: number | bigint; /** * The comment of the entry. */ comment: string; /** * The comment of the entry (raw). */ rawComment: Uint8Array; /** * `true` if the comment is encoded in UTF-8. */ commentUTF8: boolean; /** * The signature (CRC32 checksum) of the content. */ signature: number; /** * The extra field. */ extraField?: Map<number, Uint8Array>; /** * The extra field (raw). */ rawExtraField: Uint8Array; /** * `true` if the entry is using Zip64. */ zip64: boolean; /** * The "Version" field. */ version: number; /** * The "Version made by" field. */ versionMadeBy: number; /** * `true` if `internalFileAttribute` and `externalFileAttribute` are compatible with MS-DOS format. */ msDosCompatible: boolean; /** * The internal file attribute (raw). */ internalFileAttribute: number; /** * The external file attribute (raw). */ externalFileAttribute: number; /** * The number of the disk where the entry data starts. */ diskNumberStart: number;}
/** * Represents an entry with its data and metadata in a zip file (Core API). */export interface Entry extends EntryMetaData { /** * Returns the content of the entry * * @param writer The {@link Writer} instance used to write the content of the entry. * @param options The options. * @returns A promise resolving to the type to data associated to `writer`. */ getData?<Type>( writer: | Writer<Type> | WritableWriter | WritableStream | AsyncGenerator< Writer<unknown> | WritableWriter | WritableStream, boolean >, options?: EntryGetDataOptions, ): Promise<Type>;
/** * Tests if the password is valid. * * @param writer `undefined` or `null`. * @param options The options with `checkPasswordOnly` set to `true`. */ getData?( writer: undefined | null, options: EntryGetDataCheckPasswordOptions, ): Promise<void>;}
/** * Represents the options passed to {@link Entry#getData} and `{@link ZipFileEntry}.get*`. */export interface EntryGetDataOptions extends EntryDataOnprogressOptions, ZipReaderOptions, WorkerConfiguration {}
/** * Represents the options passed to {@link Entry#getData} and `{@link ZipFileEntry}.get*`. */export interface EntryGetDataCheckPasswordOptions extends EntryGetDataOptions, ZipReaderCheckPasswordOptions {}
/** * Represents an instance used to create a zipped stream. * * @example * This example creates a zipped file called numbers.txt.zip containing the numbers 0 - 1000 each on their own line. * ``` * const readable = ReadableStream.from((function* () { * for (let i = 0; i < 1000; ++i) * yield i + '\n' * })()) * * readable * .pipeThrough(new ZipWriterStream().transform('numbers.txt')) * .pipeTo((await Deno.create('numbers.txt.zip')).writable) * ``` * * @example * This example creates a zipped file called Archive.zip containing two files called numbers.txt and letters.txt * ``` * const readable1 = ReadableStream.from((function* () { * for (let i = 0; i < 1000; ++i) * yield i + '\n' * })()) * const readable2 = ReadableStream.from((function* () { * const letters = 'abcdefghijklmnopqrstuvwxyz'.split('') * while (letters.length) * yield letters.shift() + '\n' * })()) * * const zipper = new ZipWriterStream() * zipper.readable.pipeTo((await Deno.create('Archive.zip')).writable) * readable1.pipeTo(zipper.writable('numbers.txt')) * readable2.pipeTo(zipper.writable('letters.txt')) * zipper.close() * ``` */export class ZipWriterStream { /** * Creates the stream. * * @param options The options. */ constructor(options?: ZipWriterConstructorOptions);
/** * The readable stream. */ readable: ReadableStream<Uint8Array>;
/** * The ZipWriter property. */ zipWriter: ZipWriter<unknown>;
/** * Returns an object containing a readable and writable property for the .pipeThrough method * * @param path The name of the stream when unzipped. * @returns An object containing readable and writable properties */ transform<T>( path: string, ): { readable: ReadableStream<T>; writable: WritableStream<T> };
/** * Returns a WritableStream for the .pipeTo method * * @param path The directory path of where the stream should exist in the zipped stream. * @returns A WritableStream. */ writable<T>(path: string): WritableStream<T>;
/** * Writes the entries directory, writes the global comment, and returns the content of the zipped file. * * @param comment The global comment of the zip file. * @param options The options. * @returns The content of the zip file. */ close( comment?: Uint8Array, options?: ZipWriterCloseOptions, ): Promise<unknown>;}
/** * Represents an instance used to create a zip file. * * @example * Here is an example showing how to create a zip file containing a compressed text file: * ``` * // use a BlobWriter to store with a ZipWriter the zip into a Blob object * const blobWriter = new zip.BlobWriter("application/zip"); * const writer = new zip.ZipWriter(blobWriter); * * // use a TextReader to read the String to add * await writer.add("filename.txt", new zip.TextReader("test!")); * * // close the ZipReader * await writer.close(); * * // get the zip file as a Blob * const blob = await blobWriter.getData(); * ``` */export class ZipWriter<Type> { /** * Creates the {@link ZipWriter} instance * * @param writer The {@link Writer} instance where the zip content will be written. * @param options The options. */ constructor( writer: | Writer<Type> | WritableWriter | WritableStream | AsyncGenerator< Writer<unknown> | WritableWriter | WritableStream, boolean >, options?: ZipWriterConstructorOptions, ); /** * `true` if the zip contains at least one entry that has been partially written. */ readonly hasCorruptedEntries?: boolean; /** * Adds an entry into the zip file * * @param filename The filename of the entry. * @param reader The {@link Reader} instance used to read the content of the entry. * @param options The options. * @returns A promise resolving to an {@link EntryMetaData} instance. */ add<ReaderType>( filename: string, reader?: | Reader<ReaderType> | ReadableReader | ReadableStream | Reader<unknown>[] | ReadableReader[] | ReadableStream[], options?: ZipWriterAddDataOptions, ): Promise<EntryMetaData>; /** * Writes the entries directory, writes the global comment, and returns the content of the zip file * * @param comment The global comment of the zip file. * @param options The options. * @returns The content of the zip file. */ close(comment?: Uint8Array, options?: ZipWriterCloseOptions): Promise<Type>;}
/** * Represents the options passed to {@link ZipWriter#add}. */export interface ZipWriterAddDataOptions extends ZipWriterConstructorOptions, EntryDataOnprogressOptions, WorkerConfiguration { /** * `true` if the entry is a directory. * * @defaultValue false */ directory?: boolean; /** * The comment of the entry. */ comment?: string; /** * The extra field of the entry. */ extraField?: Map<number, Uint8Array>;}
/** * Represents the options passed to {@link ZipWriter#close}. */export interface ZipWriterCloseOptions extends EntryOnprogressOptions { /** * `true` to use Zip64 to write the entries directory. * * @defaultValue false */ zip64?: boolean; /** * `true` to prevent closing of {@link WritableWriter#writable}. * * @defaultValue false */ preventClose?: boolean;}
/** * Represents options passed to the constructor of {@link ZipWriter}, {@link ZipWriter#add} and `{@link ZipDirectoryEntry}#export*`. */export interface ZipWriterConstructorOptions { /** * `true` to use Zip64 to store the entry. * * `zip64` is automatically set to `true` when necessary (e.g. compressed data larger than 4GB or with unknown size). * * @defaultValue false */ zip64?: boolean; /** * `true` to prevent closing of {@link WritableWriter#writable}. * * @defaultValue false */ preventClose?: boolean; /** * The level of compression. * * The minimum value is 0 and means that no compression is applied. The maximum value is 9. * * @defaultValue 5 */ level?: number; /** * `true` to write entry data in a buffer before appending it to the zip file. * * `bufferedWrite` is automatically set to `true` when compressing more than one entry in parallel. * * @defaultValue false */ bufferedWrite?: boolean; /** * `true` to keep the order of the entry physically in the zip file. * * When set to `true`, the use of web workers will be improved. However, it also prevents files larger than 4GB from being created without setting the `zip54` option to `true` explicitly. * Another solution to improve the use of web workers is to add entries from smallest to largest in uncompressed size. * * @defaultValue true */ keepOrder?: boolean; /** * The password used to encrypt the content of the entry. */ password?: string; /** * The password used to encrypt the content of the entry (raw). */ rawPassword?: Uint8Array; /** * The encryption strength (AES). * * @defaultValue 3 */ encryptionStrength?: 1 | 2 | 3; /** * The `AbortSignal` instance used to cancel the compression. */ signal?: AbortSignal; /** * The last modification date. * * @defaultValue The current date. */ lastModDate?: Date; /** * The last access date. * * This option is ignored if the {@link ZipWriterConstructorOptions#extendedTimestamp} option is set to `false`. * * @defaultValue The current date. */ lastAccessDate?: Date; /** * The creation date. * * This option is ignored if the {@link ZipWriterConstructorOptions#extendedTimestamp} option is set to `false`. * * @defaultValue The current date. */ creationDate?: Date; /** * `true` to store extended timestamp extra fields. * * When set to `false`, the maximum last modification date cannot exceed November 31, 2107 and the maximum accuracy is 2 seconds. * * @defaultValue true */ extendedTimestamp?: boolean; /** * `true` to use the ZipCrypto algorithm to encrypt the content of the entry. * * It is not recommended to set `zipCrypto` to `true` because the ZipCrypto encryption can be easily broken. * * @defaultValue false */ zipCrypto?: boolean; /** * The "Version" field. */ version?: number; /** * The "Version made by" field. * * @defaultValue 20 */ versionMadeBy?: number; /** * `true` to to add a data descriptor. * * When set to `false`, the {@link ZipWriterConstructorOptions#bufferedWrite} option will automatically be set to `true`. * * @defaultValue true */ dataDescriptor?: boolean; /** * `true` to add the signature of the data descriptor. * * @defaultValue false */ dataDescriptorSignature?: boolean; /** * `true` to write {@link EntryMetaData#externalFileAttribute} in MS-DOS format for folder entries. * * @defaultValue true */ msDosCompatible?: boolean; /** * The external file attribute. * * @defaultValue 0 */ externalFileAttribute?: number; /** * The internal file attribute. * * @defaultValue 0 */ internalFileAttribute?: number; /** * `false` to never write disk numbers in zip64 data. * * @defaultValue true */ supportZip64SplitFile?: boolean; /** * `true`to produce zip files compatible with the USDZ specification. * * @defaultValue false */ usdz?: boolean;}
/** * Represents options passed to {@link Entry#getData}, {@link ZipWriter.add} and `{@link ZipDirectory}.export*`. */export interface EntryDataOnprogressOptions { /** * The function called when starting compression/decompression. * * @param total The total number of bytes. * @returns An empty promise or `undefined`. */ onstart?(total: number): Promise<void> | undefined; /** * The function called during compression/decompression. * * @param progress The current progress in bytes. * @param total The total number of bytes. * @returns An empty promise or `undefined`. */ onprogress?(progress: number, total: number): Promise<void> | undefined; /** * The function called when ending compression/decompression. * * @param computedSize The total number of bytes (computed). * @returns An empty promise or `undefined`. */ onend?(computedSize: number): Promise<void> | undefined;}
/** * Represents options passed to {@link ZipReader#getEntries}, {@link ZipReader#getEntriesGenerator}, and {@link ZipWriter#close}. */export interface EntryOnprogressOptions { /** * The function called each time an entry is read/written. * * @param progress The entry index. * @param total The total number of entries. * @param entry The entry being read/written. * @returns An empty promise or `undefined`. */ onprogress?( progress: number, total: number, entry: EntryMetaData, ): Promise<void> | undefined;}
/** * Represents an entry in a zip file (Filesystem API). */declare class ZipEntry { /** * The relative filename of the entry. */ name: string; /** * The underlying {@link EntryMetaData} instance. */ data?: EntryMetaData; /** * The ID of the instance. */ id: number; /** * The parent directory of the entry. */ parent?: ZipEntry; /** * The uncompressed size of the content. */ uncompressedSize: number; /** * The children of the entry. */ children: ZipEntry[]; /** * Clones the entry * * @param deepClone `true` to clone all the descendants. */ clone(deepClone?: boolean): ZipEntry; /** * Returns the full filename of the entry */ getFullname(): string; /** * Returns the filename of the entry relative to a parent directory */ getRelativeName(ancestor: ZipDirectoryEntry): string; /** * Tests if a {@link ZipDirectoryEntry} instance is an ancestor of the entry * * @param ancestor The {@link ZipDirectoryEntry} instance. */ isDescendantOf(ancestor: ZipDirectoryEntry): boolean; /** * Tests if the entry or any of its children is password protected */ isPasswordProtected(): boolean; /** * Tests the password on the entry and all children if any, returns `true` if the entry is not password protected */ checkPassword( password: string, options?: EntryGetDataOptions, ): Promise<boolean>; /** * Set the name of the entry * * @param name The new name of the entry. */ rename(name: string): void;}
/** * Represents a file entry in the zip (Filesystem API). */export class ZipFileEntry<ReaderType, WriterType> extends ZipEntry { /** * `void` for {@link ZipFileEntry} instances. */ directory: void; /** * The {@link Reader} instance used to read the content of the entry. */ reader: | Reader<ReaderType> | ReadableReader | ReadableStream | Reader<unknown>[] | ReadableReader[] | ReadableStream[]; /** * The {@link Writer} instance used to write the content of the entry. */ writer: | Writer<WriterType> | WritableWriter | WritableStream | AsyncGenerator<Writer<unknown> | WritableWriter | WritableStream>; /** * Retrieves the text content of the entry as a `string` * * @param encoding The encoding of the text. * @param options The options. * @returns A promise resolving to a `string`. */ getText(encoding?: string, options?: EntryGetDataOptions): Promise<string>; /** * Retrieves the content of the entry as a `Blob` instance * * @param mimeType The MIME type of the content. * @param options The options. * @returns A promise resolving to a `Blob` instance. */ getBlob(mimeType?: string, options?: EntryGetDataOptions): Promise<Blob>; /** * Retrieves the content of the entry as as a Data URI `string` encoded in Base64 * * @param mimeType The MIME type of the content. * @param options The options. * @returns A promise resolving to a Data URI `string` encoded in Base64. */ getData64URI( mimeType?: string, options?: EntryGetDataOptions, ): Promise<string>; /** * Retrieves the content of the entry as a `Uint8Array` instance * * @param options The options. * @returns A promise resolving to a `Uint8Array` instance. */ getUint8Array(options?: EntryGetDataOptions): Promise<Uint8Array>; /** * Retrieves the content of the entry via a `WritableStream` instance * * @param writable The `WritableStream` instance. * @param options The options. * @returns A promise resolving to the `WritableStream` instance. */ getWritable( writable?: WritableStream, options?: EntryGetDataOptions, ): Promise<WritableStream>; /** * Retrieves the content of the entry via a {@link Writer} instance * * @param writer The {@link Writer} instance. * @param options The options. * @returns A promise resolving to data associated to the {@link Writer} instance. */ getData( writer: | Writer<unknown> | WritableWriter | WritableStream | AsyncGenerator<Writer<unknown> | WritableWriter | WritableStream>, options?: EntryGetDataOptions, ): Promise<unknown>; /** * Replaces the content of the entry with a `Blob` instance * * @param blob The `Blob` instance. */ replaceBlob(blob: Blob): void; /** * Replaces the content of the entry with a `string` * * @param text The `string`. */ replaceText(text: string): void; /** * Replaces the content of the entry with a Data URI `string` encoded in Base64 * * @param dataURI The Data URI `string` encoded in Base64. */ replaceData64URI(dataURI: string): void; /** * Replaces the content of the entry with a `Uint8Array` instance * * @param array The `Uint8Array` instance. */ replaceUint8Array(array: Uint8Array): void; /** * Replaces the content of the entry with a `ReadableStream` instance * * @param readable The `ReadableStream` instance. */ replaceReadable(readable: ReadableStream): void;}
/** * Represents a directory entry in the zip (Filesystem API). */export class ZipDirectoryEntry extends ZipEntry { /** * `true` for {@link ZipDirectoryEntry} instances. */ directory: true; /** * Gets a {@link ZipEntry} child instance from its relative filename * * @param name The relative filename. * @returns A {@link ZipFileEntry} or a {@link ZipDirectoryEntry} instance (use the {@link ZipFileEntry#directory} and {@link ZipDirectoryEntry#directory} properties to differentiate entries). */ getChildByName(name: string): ZipEntry | undefined; /** * Adds a directory * * @param name The relative filename of the directory. * @param options The options. * @returns A {@link ZipDirectoryEntry} instance. */ addDirectory( name: string, options?: ZipWriterAddDataOptions, ): ZipDirectoryEntry; /** * Adds an entry with content provided as text * * @param name The relative filename of the entry. * @param text The text. * @param options The options. * @returns A {@link ZipFileEntry} instance. */ addText( name: string, text: string, options?: ZipWriterAddDataOptions, ): ZipFileEntry<string, string>; /** * Adds a entry entry with content provided as a `Blob` instance * * @param name The relative filename of the entry. * @param blob The `Blob` instance. * @param options The options. * @returns A {@link ZipFileEntry} instance. */ addBlob( name: string, blob: Blob, options?: ZipWriterAddDataOptions, ): ZipFileEntry<Blob, Blob>; /** * Adds a entry entry with content provided as a Data URI `string` encoded in Base64 * * @param name The relative filename of the entry. * @param dataURI The Data URI `string` encoded in Base64. * @param options The options. * @returns A {@link ZipFileEntry} instance. */ addData64URI( name: string, dataURI: string, options?: ZipWriterAddDataOptions, ): ZipFileEntry<string, string>; /** * Adds an entry with content provided as a `Uint8Array` instance * * @param name The relative filename of the entry. * @param array The `Uint8Array` instance. * @param options The options. * @returns A {@link ZipFileEntry} instance. */ addUint8Array( name: string, array: Uint8Array, options?: ZipWriterAddDataOptions, ): ZipFileEntry<Uint8Array, Uint8Array>; /** * Adds an entry with content fetched from a URL * * @param name The relative filename of the entry. * @param url The URL. * @param options The options. * @returns A {@link ZipFileEntry} instance. */ addHttpContent( name: string, url: string, options?: HttpOptions & ZipWriterAddDataOptions, ): ZipFileEntry<string, void>; /** * Adds a entry entry with content provided via a `ReadableStream` instance * * @param name The relative filename of the entry. * @param readable The `ReadableStream` instance. * @param options The options. * @returns A {@link ZipFileEntry} instance. */ addReadable( name: string, readable: ReadableStream, options?: ZipWriterAddDataOptions, ): ZipFileEntry<ReadableStream, void>; /** * Adds an entry with content provided via a `File` instance * * @param file The `File` instance. * @param options The options. * @returns A promise resolving to a {@link ZipFileEntry} or a {@link ZipDirectoryEntry} instance. */ addFile( file: File, options?: ZipWriterAddDataOptions, ): Promise<ZipEntry>; /** * Adds an entry with content provided via a `FileSystemEntry` instance * * @param fileSystemEntry The `FileSystemEntry` instance. * @param options The options. * @returns A promise resolving to an array of {@link ZipFileEntry} or a {@link ZipDirectoryEntry} instances. */ addFileSystemEntry( fileSystemEntry: FileSystemEntryLike, options?: ZipWriterAddDataOptions, ): Promise<ZipEntry[]>; /** * Adds an entry with content provided via a `FileSystemHandle` instance * * @param fileSystemHandle The `fileSystemHandle` instance. * @param options The options. * @returns A promise resolving to an array of {@link ZipFileEntry} or a {@link ZipDirectoryEntry} instances. */ addFileSystemHandle( fileSystemHandle: FileSystemHandleLike, options?: ZipWriterAddDataOptions, ): Promise<ZipEntry[]>; /** * Extracts a zip file provided as a `Blob` instance into the entry * * @param blob The `Blob` instance. * @param options The options. */ importBlob( blob: Blob, options?: ZipReaderConstructorOptions, ): Promise<[ZipEntry]>; /** * Extracts a zip file provided as a Data URI `string` encoded in Base64 into the entry * * @param dataURI The Data URI `string` encoded in Base64. * @param options The options. */ importData64URI( dataURI: string, options?: ZipReaderConstructorOptions, ): Promise<[ZipEntry]>; /** * Extracts a zip file provided as a `Uint8Array` instance into the entry * * @param array The `Uint8Array` instance. * @param options The options. */ importUint8Array( array: Uint8Array, options?: ZipReaderConstructorOptions, ): Promise<[ZipEntry]>; /** * Extracts a zip file fetched from a URL into the entry * * @param url The URL. * @param options The options. */ importHttpContent( url: string, options?: ZipDirectoryEntryImportHttpOptions, ): Promise<[ZipEntry]>; /** * Extracts a zip file provided via a `ReadableStream` instance into the entry * * @param readable The `ReadableStream` instance. * @param options The options. */ importReadable( readable: ReadableStream, options?: ZipReaderConstructorOptions, ): Promise<[ZipEntry]>; /** * Extracts a zip file provided via a custom {@link Reader} instance into the entry * * @param reader The {@link Reader} instance. * @param options The options. */ importZip( reader: | Reader<unknown> | ReadableReader | ReadableStream | Reader<unknown>[] | ReadableReader[] | ReadableStream[], options?: ZipReaderConstructorOptions, ): Promise<[ZipEntry]>; /** * Returns a `Blob` instance containing a zip file of the entry and its descendants * * @param options The options. * @returns A promise resolving to the `Blob` instance. */ exportBlob(options?: ZipDirectoryEntryExportOptions): Promise<Blob>; /** * Returns a Data URI `string` encoded in Base64 containing a zip file of the entry and its descendants * * @param options The options. * @returns A promise resolving to the Data URI `string` encoded in Base64. */ exportData64URI(options?: ZipDirectoryEntryExportOptions): Promise<string>; /** * Returns a `Uint8Array` instance containing a zip file of the entry and its descendants * * @param options The options. * @returns A promise resolving to the `Uint8Array` instance. */ exportUint8Array( options?: ZipDirectoryEntryExportOptions, ): Promise<Uint8Array>; /** * Creates a zip file via a `WritableStream` instance containing the entry and its descendants * * @param writable The `WritableStream` instance. * @param options The options. * @returns A promise resolving to the `Uint8Array` instance. */ exportWritable( writable?: WritableStream, options?: ZipDirectoryEntryExportOptions, ): Promise<WritableStream>; /** * Creates a zip file via a custom {@link Writer} instance containing the entry and its descendants * * @param writer The {@link Writer} instance. * @param options The options. * @returns A promise resolving to the data. */ exportZip( writer: | Writer<unknown> | WritableWriter | WritableStream | AsyncGenerator<Writer<unknown> | WritableWriter | WritableStream>, options?: ZipDirectoryEntryExportOptions, ): Promise<unknown>;}
/** * Represents the options passed to {@link ZipDirectoryEntry#importHttpContent}. */export interface ZipDirectoryEntryImportHttpOptions extends ZipReaderConstructorOptions, HttpOptions {}
/** * Represents the options passed to `{@link ZipDirectoryEntry}#export*()`. */export interface ZipDirectoryEntryExportOptions extends ZipWriterConstructorOptions, EntryDataOnprogressOptions { /** * `true` to use filenames relative to the entry instead of full filenames. */ relativePath?: boolean; /** * The MIME type of the exported data when relevant. */ mimeType?: string; /** * The options passed to the Reader instances */ readerOptions?: ZipReaderConstructorOptions;}
/** * Represents a Filesystem instance. * * @example * Here is an example showing how to create and read a zip file containing a compressed text file: * ``` * const TEXT_CONTENT = "Lorem ipsum dolor sit amet, consectetuer adipiscing elit, sed diam nonummy nibh euismod tincidunt ut laoreet dolore magna aliquam erat volutpat."; * const FILENAME = "lorem.txt"; * const BLOB = new Blob([TEXT_CONTENT], { type: zip.getMimeType(FILENAME) }); * let zipFs = new zip.fs.FS(); * zipFs.addBlob("lorem.txt", BLOB); * const zippedBlob = await zipFs.exportBlob(); * zipFs = new zip.fs.FS(); * await zipFs.importBlob(zippedBlob); * const firstEntry = zipFs.children[0]; * const unzippedBlob = await firstEntry.getBlob(zip.getMimeType(firstEntry.name)); * ``` */export class FS extends ZipDirectoryEntry { /** * The root directory. */ root: ZipDirectoryEntry; /** * Removes a {@link ZipEntry} instance and its children * * @param entry The {@link ZipEntry} instance to remove. */ remove(entry: ZipEntry): void; /** * Moves a {@link ZipEntry} instance and its children into a {@link ZipDirectoryEntry} instance * * @param entry The {@link ZipEntry} instance to move. * @param destination The {@link ZipDirectoryEntry} instance. */ move(entry: ZipEntry, destination: ZipDirectoryEntry): void; /** * Returns a {@link ZipEntry} instance from its full filename * * @param fullname The full filename. * @returns The {@link ZipEntry} instance. */ find(fullname: string): ZipEntry | undefined; /** * Returns a {@link ZipEntry} instance from the value of {@link ZipEntry#id} * * @param id The id of the {@link ZipEntry} instance. * @returns The {@link ZipEntry} instance. */ getById(id: number): ZipEntry | undefined;}
/** * The Filesystem API. */export const fs: { /** * The Filesystem constructor. * * @defaultValue {@link FS} */ FS: typeof FS; /** * The {@link ZipDirectoryEntry} constructor. * * @defaultValue {@link ZipDirectoryEntry} */ ZipDirectoryEntry: typeof ZipDirectoryEntry; /** * The {@link ZipFileEntry} constructor. * * @defaultValue {@link ZipFileEntry} */ ZipFileEntry: typeof ZipFileEntry;};
// The error messages./** * HTTP range error */export const ERR_HTTP_RANGE: string;/** * Zip format error */export const ERR_BAD_FORMAT: string;/** * End of Central Directory Record not found error */export const ERR_EOCDR_NOT_FOUND: string;/** * Zip64 End of Central Directory Record not found error */export const ERR_EOCDR_ZIP64_NOT_FOUND: string;/** * Zip64 End of Central Directory Locator not found error */export const ERR_EOCDR_LOCATOR_ZIP64_NOT_FOUND: string;/** * Central Directory not found error */export const ERR_CENTRAL_DIRECTORY_NOT_FOUND: string;/** * Local file header not found error */export const ERR_LOCAL_FILE_HEADER_NOT_FOUND: string;/** * Extra field Zip64 not found error */export const ERR_EXTRAFIELD_ZIP64_NOT_FOUND: string;/** * Encrypted entry error */export const ERR_ENCRYPTED: string;/** * Unsupported encryption error */export const ERR_UNSUPPORTED_ENCRYPTION: string;/** * Unsupported compression error */export const ERR_UNSUPPORTED_COMPRESSION: string;/** * Invalid signature error */export const ERR_INVALID_SIGNATURE: string;/** * Invalid password error */export const ERR_INVALID_PASSWORD: string;/** * Duplicate entry error */export const ERR_DUPLICATED_NAME: string;/** * Invalid comment error */export const ERR_INVALID_COMMENT: string;/** * Invalid entry name error */export const ERR_INVALID_ENTRY_NAME: string;/** * Invalid entry comment error */export const ERR_INVALID_ENTRY_COMMENT: string;/** * Invalid version error */export const ERR_INVALID_VERSION: string;/** * Invalid extra field type error */export const ERR_INVALID_EXTRAFIELD_TYPE: string;/** * Invalid extra field data error */export const ERR_INVALID_EXTRAFIELD_DATA: string;/** * Invalid encryption strength error */export const ERR_INVALID_ENCRYPTION_STRENGTH: string;/** * Invalid format error */export const ERR_UNSUPPORTED_FORMAT: string;/** * Split zip file error */export const ERR_SPLIT_ZIP_FILE: string;/** * Iteration completed too soon error */export const ERR_ITERATOR_COMPLETED_TOO_SOON: string;