Web File System API to Node fs promises API.
Learn more about: File System API
Note
This library was originally implemented for use with isomorphic-git. But the actual test found that the performance was so bad and there were inexplicable problems, so I gave up.
# npm
npm install @tsuk1ko/fsa-promises
# yarn
yarn add @tsuk1ko/fsa-promises
# bun
bun add @tsuk1ko/fsa-promises
import { FsaPromises } from 'fsa-promises';
// Use `navigator.storage.getDirectory()` as root
const fs = new FsaPromises();
// Use directory "path/to/some/dir" of `navigator.storage.getDirectory()` as root,
// will be create recursively if not exists
const fs = new FsaPromises('path/to/some/dir');
// Use `showDirectoryPicker()` to select a directory as root
const fs = new FsaPromises(showDirectoryPicker({ mode: 'readwrite' }));
// Use almost the same way as node fsPromises module
await fs.writeFile('file.txt', 'hello world');
options
can be string
, FileSystemDirectoryHandle
, Promise<FileSystemDirectoryHandle>
or an FsaPromisesOptions
object.
interface FsaPromisesOptions {
root?: string | FileSystemDirectoryHandle | Promise<FileSystemDirectoryHandle>;
useSyncAccessHandleForFile?: boolean;
}
When it is true
, the library will use createSyncAccessHandle()
instead of createWritable()
to write file.
It is only usable inside dedicated Web Workers with the origin private file system.
For more information, please check here.
Refer to fsPromises.readFile.
flag
and signal
are not supported.
Refer to fsPromises.writeFile.
mode
is not supported.
flush
is usable only when useSyncAccessHandleForFile
is true
.
signal
is not usable when useSyncAccessHandleForFile
is true
.
Refer to fsPromises.unlink.
Refer to fsPromises.readdir.
encoding
only support undefine
, null
or "buffer"
.
Refer to fsPromises.mkdir.
mode
is not supported.
Refer to fsPromises.rmdir.
maxRetries
and retryDelay
are not supported.
This API does not exist in node fsPromises. It is provided for convenience.
Refer to fsPromises.stat.
Same as stat()
because symlink isn't implemented.
Not implemented, don't use.
Not implemented, don't use.
Do nothing, just for compatibility.