SDK to interact with Filen for Node.JS, Browsers and React Native.
Explore the docs »
The SDK is still a work in progress. DO NOT USE IT IN PRODUCTION YET. Class names, function names, types, definitions, constants etc. are subject to change until we release a fully tested and stable version.
- Install using NPM
npm install @filen/filen-sdk@latest
- Initialize the SDK.
import FilenSDK from "@filen/filen-sdk"
import path from "path"
type FilenSDKConfig = {
email?: string
password?: string
twoFactorCode?: string
masterKeys?: string[]
apiKey?: string
publicKey?: string
privateKey?: string
authVersion?: AuthVersion
baseFolderUUID?: string
userId?: number
metadataCache?: boolean // Cache decrypted metadata in memory. Recommended.
tmpPath?: string // Temporary local path used to store metadata and chunks. Only available in Node.JS.
}
// You can either directly supply all needed config parameters to the constructor or call the .login() function to fetch them using your login information.
const filen = new FilenSDK({
metadataCache: true,
tmpPath: path.join(os.tmpdir(), "filen-sdk")
})
await filen.login({
email: "your@email.com",
password: "supersecret123",
twoFactorCode: "123456"
})
- Interact with the cloud
// Create a directory
await filen.fs().mkdir({
path: "/Pictures"
})
// Upload a file
await filen.fs().upload({
path: "/Pictures",
source: "/Local/path/to/a/file.jpg"
})
// Read contents of the directory
await filen.fs().readdir({
path: "/Pictures"
})
// Stat a file
await filen.fs().stat({
path: "/Pictures/file.jpg"
})
Distributed under the AGPL-3.0 License. See LICENSE for more information.