tspace-nfs
![NPM downloads](https://img.shields.io/npm/dm/tspace-nfs.svg)
tspace-nfs is a NFS stands for Network File System and provides both server and client capabilities for accessing files over a network.
Install
Install with npm:
npm install tspace-nfs --save
Basic Usage
Server
import { NfsServer } from "tspace-nfs";
new NfsServer()
.bucketLists(async () => {
return ['dev']
})
.onCredentials(async ({ token , secret , bucket }) => {
const lists = [
{
token: 'token-dev',
secret: 'secret-dev',
bucket : 'dev'
}
]
return lists.every(list => list.bucket === bucket && list.secret === secret && list.token === token)
})
.progress()
.defaultPage(`<b> hello nfs-server! </b>`)
.directory('upload')
.credentials({
expired : 60 * 60 * 24,
secret : 'credential-secret'
})
.fileExpired(60 * 15)
.listen(8000 , ({ port }) => console.log(`Server is running on port http://localhost:${port}`))
Client
import { NfsClient } from "tspace-nfs";
const nfs = new NfsClient({
token : '<YOUR TOKEN>',
secret : '<YOUR SECRET>',
bucket : '<YOUR BUCKET>',
url : '<YOUR URL>'
})
.default('_default/uploads')
.onError((err, nfs) => {
console.log('nfs client failed to connect')
console.log(err.message)
nfs.quit()
})
.onConnect((nfs) => {
console.log('nfs client connected')
})
(async () => {
const fileDirectory = 'my-folder/my-cat.png'
const url = await nfs.toURL(fileDirectory , {
download : false,
expired : 60 * 60
exists : true
})
const base64 = await nfs.toBase64(fileDirectory)
const stream = await nfs.toStream(fileDirectory)
const file = req.files.file[0]
const { path , size , name , url } = await nfs.save({
file : file.tempFilePath,
name : 'my-video.mp4',
folder : 'my-folder'
})
await nfs.saveAs({
base64 : Buffer.from(file.tempFilePath).toString('base64'),
name : 'my-video.mp4',
extension : 'mp4',
folder : 'my-folder'
})
const deleted = await nfs.delete(fileDirectory)
const folders = await nfs.folders()
const storage = await nfs.storage()
})()