export type ArchiveKind = "tar" | "zip"; export type ArchiveLogger = { info?: (message: string) => void; warn?: (message: string) => void; }; export type ArchiveExtractLimits = { /** * Max archive file bytes (compressed). */ maxArchiveBytes?: number; /** Max number of extracted entries (files + dirs). */ maxEntries?: number; /** Max extracted bytes (sum of all files). */ maxExtractedBytes?: number; /** Max extracted bytes for a single file entry. */ maxEntryBytes?: number; }; export type ArchiveSecurityErrorCode = "destination-not-directory" | "destination-symlink" | "destination-symlink-traversal"; export declare class ArchiveSecurityError extends Error { code: ArchiveSecurityErrorCode; constructor(code: ArchiveSecurityErrorCode, message: string, options?: ErrorOptions); } /** @internal */ export declare const DEFAULT_MAX_ARCHIVE_BYTES_ZIP: number; /** @internal */ export declare const DEFAULT_MAX_ENTRIES = 50000; /** @internal */ export declare const DEFAULT_MAX_EXTRACTED_BYTES: number; /** @internal */ export declare const DEFAULT_MAX_ENTRY_BYTES: number; export declare function resolveArchiveKind(filePath: string): ArchiveKind | null; export declare function resolvePackedRootDir(extractDir: string): Promise; export declare function withTimeout(promise: Promise, timeoutMs: number, label: string): Promise; export type TarEntryInfo = { path: string; type: string; size: number; }; export declare function createTarEntrySafetyChecker(params: { rootDir: string; stripComponents?: number; limits?: ArchiveExtractLimits; escapeLabel?: string; }): (entry: TarEntryInfo) => void; export declare function extractArchive(params: { archivePath: string; destDir: string; timeoutMs: number; kind?: ArchiveKind; stripComponents?: number; tarGzip?: boolean; limits?: ArchiveExtractLimits; logger?: ArchiveLogger; }): Promise; export declare function fileExists(filePath: string): Promise; export declare function readJsonFile(filePath: string): Promise;