UNPKG

hivessh

Version:

HiveSsh is an innovative library designed to streamline SSH2 connections and simplify task execution on Linux servers.

100 lines 22.9 kB
export function convertFileEntryState(path, stats) { return { path: path, filename: stats.filename, mode: stats.attrs.mode, uid: stats.attrs.uid, gid: stats.attrs.gid, size: stats.attrs.size, atime: stats.attrs.atime, mtime: stats.attrs.mtime, isDirectory: stats.attrs.isDirectory(), isFile: stats.attrs.isFile(), isBlockDevice: stats.attrs.isBlockDevice(), isCharacterDevice: stats.attrs.isCharacterDevice(), isSymbolicLink: stats.attrs.isSymbolicLink(), isFIFO: stats.attrs.isFIFO(), isSocket: stats.attrs.isSocket(), }; } const voidMethods = [ "fastGet", "fastPut", "writeFile", "appendFile", "write", "fsetstat", "futimes", "fchown", "fchmod", "unlink", "rename", "mkdir", "mkdir", "rmdir", "setstat", "utimes", "chown", "chmod", "symlink", "ext_openssh_rename", "ext_openssh_hardlink", "ext_openssh_lsetstat", "ext_openssh_lsetstat", ]; const bufferMethods = [ "readFile", "open", "opendir", ]; const stringMethods = [ "readlink", "realpath", "ext_openssh_expandPath", ]; const statsMethods = [ "fstat", "lstat", "stat", ]; const anyMethods = [ "ext_openssh_statvfs", "ext_openssh_fstatvfs", "ext_openssh_fsync", ]; const booleanMethods = [ "exists", ]; const singleValueErrorCallbacks = [ ...bufferMethods, ...stringMethods, ...statsMethods, ...anyMethods, ...booleanMethods, ]; const fsStatsMethods = [ "readdir", ]; const otherMethods = [ "read" ]; export function createSFTPPromiseWrapper(sourceWrapper) { // promisify methods const ret = sourceWrapper; for (const voidMethod of voidMethods) { const altName = voidMethod + "2"; ret[altName] = ret[voidMethod]; ret[voidMethod] = (...params) => new Promise((res) => ret[altName](...params, res)); } for (const bufferMethod of singleValueErrorCallbacks) { const altName = bufferMethod + "2"; ret[altName] = ret[bufferMethod]; ret[bufferMethod] = (...params) => new Promise((res, rej) => ret[altName](...params, (err, value) => err ? rej(err) : res(value))); } ret.readdir2 = ret.readdir; ret.readdir = (...params) => new Promise((res, rej) => ret.readdir2(...params, (err, value) => err ? rej(err) : res(value.map((v) => convertFileEntryState(params[0], v))))); ret.read2 = ret.read; ret.read = (...params) => new Promise((res, rej) => ret.read2(...params, (err, read, buf, pos) => err ? rej(err) : res([read, buf, pos]))); return ret; } //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"SftpPromiseWrapper.js","sourceRoot":"","sources":["../../src/essentials/SftpPromiseWrapper.ts"],"names":[],"mappings":"AAoBA,MAAM,UAAU,qBAAqB,CACjC,IAAY,EACZ,KAAyB;IAEzB,OAAO;QACH,IAAI,EAAE,IAAI;QACV,QAAQ,EAAE,KAAK,CAAC,QAAQ;QACxB,IAAI,EAAE,KAAK,CAAC,KAAK,CAAC,IAAI;QACtB,GAAG,EAAE,KAAK,CAAC,KAAK,CAAC,GAAG;QACpB,GAAG,EAAE,KAAK,CAAC,KAAK,CAAC,GAAG;QACpB,IAAI,EAAE,KAAK,CAAC,KAAK,CAAC,IAAI;QACtB,KAAK,EAAE,KAAK,CAAC,KAAK,CAAC,KAAK;QACxB,KAAK,EAAE,KAAK,CAAC,KAAK,CAAC,KAAK;QACxB,WAAW,EAAE,KAAK,CAAC,KAAK,CAAC,WAAW,EAAE;QACtC,MAAM,EAAE,KAAK,CAAC,KAAK,CAAC,MAAM,EAAE;QAC5B,aAAa,EAAE,KAAK,CAAC,KAAK,CAAC,aAAa,EAAE;QAC1C,iBAAiB,EAAE,KAAK,CAAC,KAAK,CAAC,iBAAiB,EAAE;QAClD,cAAc,EAAE,KAAK,CAAC,KAAK,CAAC,cAAc,EAAE;QAC5C,MAAM,EAAE,KAAK,CAAC,KAAK,CAAC,MAAM,EAAE;QAC5B,QAAQ,EAAE,KAAK,CAAC,KAAK,CAAC,QAAQ,EAAE;KACnC,CAAA;AACL,CAAC;AA6RD,MAAM,WAAW,GAAG;IAChB,SAAS;IACT,SAAS;IACT,WAAW;IACX,YAAY;IACZ,OAAO;IACP,UAAU;IACV,SAAS;IACT,QAAQ;IACR,QAAQ;IACR,QAAQ;IACR,QAAQ;IACR,OAAO;IACP,OAAO;IACP,OAAO;IACP,SAAS;IACT,QAAQ;IACR,OAAO;IACP,OAAO;IACP,SAAS;IACT,oBAAoB;IACpB,sBAAsB;IACtB,sBAAsB;IACtB,sBAAsB;CACzB,CAAA;AAED,MAAM,aAAa,GAAG;IAClB,UAAU;IACV,MAAM;IACN,SAAS;CACZ,CAAA;AAED,MAAM,aAAa,GAAG;IAClB,UAAU;IACV,UAAU;IACV,wBAAwB;CAC3B,CAAA;AAED,MAAM,YAAY,GAAG;IACjB,OAAO;IACP,OAAO;IACP,MAAM;CACT,CAAA;AAED,MAAM,UAAU,GAAG;IACf,qBAAqB;IACrB,sBAAsB;IACtB,mBAAmB;CACtB,CAAA;AAED,MAAM,cAAc,GAAG;IACnB,QAAQ;CACX,CAAA;AAED,MAAM,yBAAyB,GAAG;IAC9B,GAAG,aAAa;IAChB,GAAG,aAAa;IAChB,GAAG,YAAY;IACf,GAAG,UAAU;IACb,GAAG,cAAc;CACpB,CAAA;AAED,MAAM,cAAc,GAAG;IACnB,SAAS;CACZ,CAAA;AAED,MAAM,YAAY,GAAG;IACjB,MAAM;CACT,CAAA;AAKD,MAAM,UAAU,wBAAwB,CACpC,aAA0B;IAE1B,oBAAoB;IAEpB,MAAM,GAAG,GAAQ,aAAa,CAAA;IAE9B,KAAK,MAAM,UAAU,IAAI,WAAW,EAAE,CAAC;QACnC,MAAM,OAAO,GAAG,UAAU,GAAG,GAAG,CAAA;QAChC,GAAG,CAAC,OAAO,CAAC,GAAG,GAAG,CAAC,UAAU,CAAC,CAAA;QAC9B,GAAG,CAAC,UAAU,CAAC,GAAG,CAAC,GAAG,MAAa,EAAE,EAAE,CAAC,IAAI,OAAO,CAC/C,CAAC,GAAG,EAAE,EAAE,CAAC,GAAG,CAAC,OAAO,CAAC,CACjB,GAAG,MAAM,EACT,GAAG,CACN,CACJ,CAAA;IACL,CAAC;IAED,KAAK,MAAM,YAAY,IAAI,yBAAyB,EAAE,CAAC;QACnD,MAAM,OAAO,GAAG,YAAY,GAAG,GAAG,CAAA;QAClC,GAAG,CAAC,OAAO,CAAC,GAAG,GAAG,CAAC,YAAY,CAAC,CAAA;QAChC,GAAG,CAAC,YAAY,CAAC,GAAG,CAAC,GAAG,MAAa,EAAE,EAAE,CAAC,IAAI,OAAO,CACjD,CAAC,GAAG,EAAE,GAAG,EAAE,EAAE,CAAC,GAAG,CAAC,OAAO,CAAC,CACtB,GAAG,MAAM,EACT,CAAC,GAAQ,EAAE,KAAU,EAAE,EAAE,CAAC,GAAG,CAAC,CAAC,CAAC,GAAG,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,GAAG,CAAC,KAAK,CAAC,CACxD,CACJ,CAAA;IACL,CAAC;IAED,GAAG,CAAC,QAAQ,GAAG,GAAG,CAAC,OAAO,CAAA;IAC1B,GAAG,CAAC,OAAO,GAAG,CAAC,GAAG,MAAa,EAAE,EAAE,CAAC,IAAI,OAAO,CAC3C,CAAC,GAAG,EAAE,GAAG,EAAE,EAAE,CAAC,GAAG,CAAC,QAAQ,CACtB,GAAG,MAAM,EACT,CAAC,GAAQ,EAAE,KAA2B,EAAE,EAAE,CAAC,GAAG,CAAC,CAAC,CAAC,GAAG,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,GAAG,CAC3D,KAAK,CAAC,GAAG,CACL,CAAC,CAAC,EAAE,EAAE,CAAC,qBAAqB,CAAC,MAAM,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAC7C,CACJ,CACJ,CACJ,CAAA;IAED,GAAG,CAAC,KAAK,GAAG,GAAG,CAAC,IAAI,CAAA;IACpB,GAAG,CAAC,IAAI,GAAG,CAAC,GAAG,MAAa,EAAE,EAAE,CAAC,IAAI,OAAO,CACxC,CAAC,GAAG,EAAE,GAAG,EAAE,EAAE,CAAC,GAAG,CAAC,KAAK,CACnB,GAAG,MAAM,EACT,CAAC,GAAsB,EAAE,IAAY,EAAE,GAAW,EAAE,GAAW,EAAE,EAAE,CAAC,GAAG,CAAC,CAAC,CAAC,GAAG,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,IAAI,EAAE,GAAG,EAAE,GAAG,CAAC,CAAC,CAC7G,CACJ,CAAA;IAED,OAAO,GAAG,CAAA;AACd,CAAC","sourcesContent":["import { FileEntryWithStats, InputAttributes, OpenMode, ReadFileOptions, SFTPWrapper, Stats, TransferOptions, WriteFileOptions } from \"ssh2\"\n\nexport interface FileStat {\n    path: string,\n    filename: string,\n    mode: number,\n    uid: number,\n    gid: number,\n    size: number,\n    atime: number,\n    mtime: number,\n    isDirectory: boolean\n    isFile: boolean\n    isBlockDevice: boolean\n    isCharacterDevice: boolean\n    isSymbolicLink: boolean\n    isFIFO: boolean\n    isSocket: boolean\n}\n\nexport function convertFileEntryState(\n    path: string,\n    stats: FileEntryWithStats\n): FileStat {\n    return {\n        path: path,\n        filename: stats.filename,\n        mode: stats.attrs.mode,\n        uid: stats.attrs.uid,\n        gid: stats.attrs.gid,\n        size: stats.attrs.size,\n        atime: stats.attrs.atime,\n        mtime: stats.attrs.mtime,\n        isDirectory: stats.attrs.isDirectory(),\n        isFile: stats.attrs.isFile(),\n        isBlockDevice: stats.attrs.isBlockDevice(),\n        isCharacterDevice: stats.attrs.isCharacterDevice(),\n        isSymbolicLink: stats.attrs.isSymbolicLink(),\n        isFIFO: stats.attrs.isFIFO(),\n        isSocket: stats.attrs.isSocket(),\n    }\n}\n\nexport interface SFTPPromiseInterface {\n    /**\n     * (Client-only)\n     * Downloads a file at `remotePath` to `localPath` using parallel reads for faster throughput.\n     */\n    fastGet(remotePath: string, localPath: string, options?: TransferOptions): Promise<void>\n\n    /**\n     * (Client-only)\n     * Uploads a file from `localPath` to `remotePath` using parallel reads for faster throughput.\n     */\n    fastPut(localPath: string, remotePath: string, options?: TransferOptions): Promise<void>\n\n    /**\n     * (Client-only)\n     * Reads a file in memory and returns its contents\n     */\n    readFile<\n        O extends ReadFileOptions | BufferEncoding\n    >(\n        remotePath: string,\n        options?: O,\n    ): Promise<\n        O extends BufferEncoding ?\n        string :\n        O extends { encodeing: BufferEncoding } ?\n        string :\n        Buffer\n    >\n\n    /**\n     * (Client-only)\n     * Writes data to a file\n     */\n    writeFile<\n        O extends WriteFileOptions | BufferEncoding,\n    >(\n        remotePath: string,\n        data: (\n            O extends BufferEncoding ?\n            string :\n            O extends { encodeing: BufferEncoding } ?\n            string :\n            Buffer\n        ),\n        options?: WriteFileOptions | BufferEncoding\n    ): Promise<void>\n\n    /**\n     * (Client-only)\n     * Appends data to a file\n     */\n    appendFile<\n        O extends WriteFileOptions | BufferEncoding,\n    >(\n        remotePath: string,\n        data: (\n            O extends BufferEncoding ?\n            string :\n            O extends { encodeing: BufferEncoding } ?\n            string :\n            Buffer\n        ),\n        options?: WriteFileOptions\n    ): Promise<void>\n\n    /**\n     * (Client-only)\n     * Opens a file `filename` for `mode` with optional `attributes`.\n     */\n    open(\n        filename: string,\n        mode: number | OpenMode,\n        attributes: InputAttributes | string | number,\n    ): Promise<Buffer>\n\n    /**\n     * (Client-only)\n     * Reads `length` bytes from the resource associated with `handle` starting at `position`\n     * and stores the bytes in `buffer` starting at `offset`.\n     */\n    read(\n        handle: Buffer,\n        buffer: Buffer,\n        offset: number,\n        length: number,\n        position: number,\n    ): Promise<[number, Buffer, number]>\n\n    /**\n     * (Client-only)\n     */\n    write(handle: Buffer, buffer: Buffer, offset: number, length: number, position: number): Promise<void>\n\n    /**\n     * (Client-only)\n     * Retrieves attributes for the resource associated with `handle`.\n     */\n    fstat(handle: Buffer): Promise<Stats>\n\n    /**\n     * (Client-only)\n     * Sets the attributes defined in `attributes` for the resource associated with `handle`.\n     */\n    fsetstat(handle: Buffer, attributes: InputAttributes): Promise<void>\n\n    /**\n     * (Client-only)\n     * Sets the access time and modified time for the resource associated with `handle`.\n     */\n    futimes(handle: Buffer, atime: number | Date, mtime: number | Date): Promise<void>\n\n    /**\n     * (Client-only)\n     * Sets the owner for the resource associated with `handle`.\n     */\n    fchown(handle: Buffer, uid: number, gid: number): Promise<void>\n\n    /**\n     * (Client-only)\n     * Sets the mode for the resource associated with `handle`.\n     */\n    fchmod(handle: Buffer, mode: number | string): Promise<void>\n\n    /**\n     * (Client-only)\n     * Opens a directory `path`.\n     */\n    opendir(path: string): Promise<Buffer>\n\n    /**\n     * (Client-only)\n     * Retrieves a directory listing.\n     */\n    readdir(location: string | Buffer): Promise<FileStat[]>\n\n    /**\n     * (Client-only)\n     * Removes the file/symlink at `path`.\n     */\n    unlink(path: string): Promise<void>\n\n    /**\n     * (Client-only)\n     * Renames/moves `srcPath` to `destPath`.\n     */\n    rename(srcPath: string, destPath: string): Promise<void>\n\n    /**\n     * (Client-only)\n     * Creates a new directory `path`.\n     */\n    mkdir(path: string, attributes: InputAttributes): Promise<void>\n\n    /**\n     * (Client-only)\n     * Creates a new directory `path`.\n     */\n    mkdir(path: string): Promise<void>\n\n    /**\n     * (Client-only)\n     * Removes the directory at `path`.\n     */\n    rmdir(path: string): Promise<void>\n\n    /**\n     * (Client-only)\n     * Retrieves attributes for `path`.\n     */\n    stat(path: string): Promise<Stats>\n\n    /**\n     * (Client-only)\n     * `path` exists.\n     */\n    exists(path: string): Promise<boolean>\n\n    /**\n     * (Client-only)\n     * Retrieves attributes for `path`. If `path` is a symlink, the link itself is stat'ed\n     * instead of the resource it refers to.\n     */\n    lstat(path: string): Promise<Stats>\n\n    /**\n     * (Client-only)\n     * Sets the attributes defined in `attributes` for `path`.\n     */\n    setstat(path: string, attributes: InputAttributes): Promise<void>\n\n    /**\n     * (Client-only)\n     * Sets the access time and modified time for `path`.\n     */\n    utimes(path: string, atime: number | Date, mtime: number | Date): Promise<void>\n\n    /**\n     * (Client-only)\n     * Sets the owner for `path`.\n     */\n    chown(path: string, uid: number, gid: number): Promise<void>\n\n    /**\n     * (Client-only)\n     * Sets the mode for `path`.\n     */\n    chmod(path: string, mode: number | string): Promise<void>\n\n    /**\n     * (Client-only)\n     * Retrieves the target for a symlink at `path`.\n     */\n    readlink(path: string): Promise<string>\n\n    /**\n     * (Client-only)\n     * Creates a symlink at `linkPath` to `targetPath`.\n     */\n    symlink(targetPath: string, linkPath: string): Promise<void>\n\n    /**\n     * (Client-only)\n     * Resolves `path` to an absolute path.\n     */\n    realpath(path: string): Promise<string>\n\n    /**\n     * (Client-only, OpenSSH extension)\n     * Performs POSIX rename(3) from `srcPath` to `destPath`.\n     */\n    ext_openssh_rename(srcPath: string, destPath: string): Promise<void>\n\n    /**\n     * (Client-only, OpenSSH extension)\n     * Performs POSIX statvfs(2) on `path`.\n     */\n    ext_openssh_statvfs(path: string): Promise<any>\n\n    /**\n     * (Client-only, OpenSSH extension)\n     * Performs POSIX fstatvfs(2) on open handle `handle`.\n     */\n    ext_openssh_fstatvfs(handle: Buffer): Promise<any>\n\n    /**\n     * (Client-only, OpenSSH extension)\n     * Performs POSIX link(2) to create a hard link to `targetPath` at `linkPath`.\n     */\n    ext_openssh_hardlink(targetPath: string, linkPath: string): Promise<void>\n\n    /**\n     * (Client-only, OpenSSH extension)\n     * Performs POSIX fsync(3) on the open handle `handle`.\n     */\n    ext_openssh_fsync(handle: Buffer): Promise<any>\n\n    /**\n     * (Client-only, OpenSSH extension)\n     * Similar to setstat(), but instead sets attributes on symlinks.\n     */\n    ext_openssh_lsetstat(path: string, attrs: InputAttributes): Promise<void>\n    ext_openssh_lsetstat(path: string): Promise<void>\n\n    /**\n     * (Client-only, OpenSSH extension)\n     * Similar to realpath(), but supports tilde-expansion, i.e. \"~\", \"~/...\" and \"~user/...\". These paths are expanded using shell-like rules.\n     */\n    ext_openssh_expandPath(path: string): Promise<string>\n\n    /**\n     * (Client-only)\n     * Performs a remote file copy. If length is 0, then the server will read from srcHandle until EOF is reached.\n     */\n    ext_copy_data(\n        handle: Buffer,\n        srcOffset: number,\n        len: number,\n        dstHandle: Buffer,\n        dstOffset: number,\n    ): Promise<void>\n}\n\nconst voidMethods = [\n    \"fastGet\",\n    \"fastPut\",\n    \"writeFile\",\n    \"appendFile\",\n    \"write\",\n    \"fsetstat\",\n    \"futimes\",\n    \"fchown\",\n    \"fchmod\",\n    \"unlink\",\n    \"rename\",\n    \"mkdir\",\n    \"mkdir\",\n    \"rmdir\",\n    \"setstat\",\n    \"utimes\",\n    \"chown\",\n    \"chmod\",\n    \"symlink\",\n    \"ext_openssh_rename\",\n    \"ext_openssh_hardlink\",\n    \"ext_openssh_lsetstat\",\n    \"ext_openssh_lsetstat\",\n]\n\nconst bufferMethods = [\n    \"readFile\",\n    \"open\",\n    \"opendir\",\n]\n\nconst stringMethods = [\n    \"readlink\",\n    \"realpath\",\n    \"ext_openssh_expandPath\",\n]\n\nconst statsMethods = [\n    \"fstat\",\n    \"lstat\",\n    \"stat\",\n]\n\nconst anyMethods = [\n    \"ext_openssh_statvfs\",\n    \"ext_openssh_fstatvfs\",\n    \"ext_openssh_fsync\",\n]\n\nconst booleanMethods = [\n    \"exists\",\n]\n\nconst singleValueErrorCallbacks = [\n    ...bufferMethods,\n    ...stringMethods,\n    ...statsMethods,\n    ...anyMethods,\n    ...booleanMethods,\n]\n\nconst fsStatsMethods = [\n    \"readdir\",\n]\n\nconst otherMethods = [\n    \"read\"\n]\n\n\nexport type SFTPPromiseWrapper = SFTPPromiseInterface & Omit<SFTPWrapper, keyof SFTPPromiseInterface>\n\nexport function createSFTPPromiseWrapper(\n    sourceWrapper: SFTPWrapper\n): SFTPPromiseWrapper {\n    // promisify methods\n\n    const ret: any = sourceWrapper\n    \n    for (const voidMethod of voidMethods) {\n        const altName = voidMethod + \"2\"\n        ret[altName] = ret[voidMethod]\n        ret[voidMethod] = (...params: any[]) => new Promise<void>(\n            (res) => ret[altName](\n                ...params,\n                res\n            )\n        )\n    }\n\n    for (const bufferMethod of singleValueErrorCallbacks) {\n        const altName = bufferMethod + \"2\"\n        ret[altName] = ret[bufferMethod]\n        ret[bufferMethod] = (...params: any[]) => new Promise<any>(\n            (res, rej) => ret[altName](\n                ...params,\n                (err: any, value: any) => err ? rej(err) : res(value)\n            )\n        )\n    }\n\n    ret.readdir2 = ret.readdir\n    ret.readdir = (...params: any[]) => new Promise<FileStat[]>(\n        (res, rej) => ret.readdir2(\n            ...params,\n            (err: any, value: FileEntryWithStats[]) => err ? rej(err) : res(\n                value.map(\n                    (v) => convertFileEntryState(params[0], v)\n                )\n            )\n        )\n    )\n\n    ret.read2 = ret.read\n    ret.read = (...params: any[]) => new Promise<[number, Buffer, number]>(\n        (res, rej) => ret.read2(\n            ...params,\n            (err: Error | undefined, read: number, buf: Buffer, pos: number) => err ? rej(err) : res([read, buf, pos])\n        )\n    )\n\n    return ret\n}"]}