concurrent-file-store
Multi-process safe simple data store, using the filesystem for storage
Usage
; const store = ; // Create a new objectstore // Object with id field ; // Read an objectstore // object ; // Update an objectstore ; // Delete an objectstore ; // List object idsstore // Array of ids ; // Filter the storestore // Array of Objects ;
Install
npm install concurrent-file-store --save
API
-
const store = new cfs(storePath[, options])
- Creates a store instancestorePath
Path to a filesystem directory to contain the store's files
Options
idField
:id
Property to use for the Identity property of each stored objectidFunction
:shortid.generate
Function used to generate a unique id for each object added to the store.function(object)
lockTimeout
:30000
How long (in miliseconds) an operation with wait to acquire a lock on an object. Locks are assumed to have expired after 10 *lockTimeout
Returns a store instance (see below)
-
store.create(object)
- Creates an object in the store, giving it a unique Identity propertyobject
A JSON serialisable object to save in the store
Returns a Promise with the stored object with the added Identity property
-
store.read(id)
- Reads an object from the storeid
The Identity property value for the object to retrive
Returns a Promise with the stored object
-
store.update(id)
- Update an object in the storeid
The Identity property value for the object to update
Returns a Promise with the stored object, to be used with
save
orfree
-
store.save(object)
- Used withupdate
to save an updated objectobject
A JSON serialisable object to save in the store
Returns a Promise with the stored object
-
store.free(id)
- Used withupdate
to release a lock on an objectid
The Identity property value for the object to free
Returns a Promise
-
store.delete(id)
- Delete an object from the storeid
The Identity property value for the object to delete
Returns a Promise
-
store.list()
- List the Identity values of all the objects in the storeReturns a Promise with an array of object Indentities
-
store.filter(func)
- Filter the store and return an array of matching objectsfunc
- Function to filter the objects by
Returns a Promsie with an array of matching objects
Test
npm installnpm test