data-store
Easily get, set and persist config data.
TOC
Install
Install with npm:
$ npm install data-store --save
Usage example
var store = require('data-store')('app', {cwd: 'actual'});
store
.set('a', 'b')
.set({c: 'd'})
.set('e.f', 'g')
console.log(store.get('e.f'));
console.log(store.get());
console.log(store.data);
API
Initialize a new Store
with the given name
and options
.
Params
name
{String}: Store name to use for the basename of the .json
file.options
{Object}options.cwd
{String}: Current working directory for storage. If not defined, the user home directory is used, based on OS. This is the only option currently, other may be added in the future.options.indent
{Number}: Number passed to JSON.stringify
when saving the data. Defaults to 2
if null
or undefined
Example
var store = require('data-store')('abc');
var store = require('data-store')('abc', {
cwd: 'test/fixtures'
});
Create a namespaced "sub-store" that persists data to its file in a sub-folder of the same directory as the "parent" store.
Params
name
{String}: The name of the sub-store.options
{Object}returns
{Object}: Returns the sub-store instance.
Example
store.create('foo');
store.foo.set('a', 'b');
console.log(store.foo.get('a'));
Assign value
to key
and save to disk. Can be a key-value pair or an object.
Params
key
{String}val
{any}: The value to save to key
. Must be a valid JSON type: String, Number, Array or Object.returns
{Object} Store
: for chaining
Example
store.set('a', 'b');
store.set({a: 'b'});
store.set('a', {b: 'c'});
store.set('a', {d: 'e'}, true);
store.set('a', {b: 'c'});
store.set('a', {d: 'e'});
Add or append an array of unique values to the given key
.
Params
key
{String}returns
{any}: The array to add or append for key
.
Example
store.union('a', ['a']);
store.union('a', ['b']);
store.union('a', ['c']);
store.get('a');
Get the stored value
of key
, or return the entire store if no key
is defined.
Params
key
{String}returns
{any}: The value to store for key
.
Example
store.set('a', {b: 'c'});
store.get('a');
store.get();
Returns true
if the specified key
has truthy value.
Params
key
{String}returns
{Boolean}: Returns true if key
has
Example
store.set('a', 'b');
store.set('c', null);
store.has('a');
store.has('c');
store.has('d');
Returns true
if the specified key
exists.
Params
key
{String}returns
{Boolean}: Returns true if key
exists
Example
store.set('a', 'b');
store.set('b', false);
store.set('c', null);
store.set('d', true);
store.hasOwn('a');
store.hasOwn('b');
store.hasOwn('c');
store.hasOwn('d');
store.hasOwn('foo');
Persist the store to disk.
Params
dest
{String}: Optionally define an alternate destination file path.
Example
store.save();
Clear in-memory store cache.
Example
store.clear();
Delete keys
from the store, or delete the entire store if no keys are passed. A del
event is also emitted for each key deleted.
Note that to delete the entire store you must pass {force: true}
Params
keys
{String|Array|Object}: Keys to remove, or options.options
{Object}
Example
store.del();
store.del({force: true});
Define a non-enumerable property on the instance.
Params
key
{String}value
{any}returns
{Object}: Returns the instance for chaining.
Related projects
- base: base is the foundation for creating modular, unit testable and highly pluggable node.js applications, starting… more | homepage
- base-store: Plugin for getting and persisting config values with your base-methods application. Adds a 'store' object… more | homepage
- cache-base: Basic object cache with
get
, set
, del
, and has
methods for node.js/javascript projects. | homepage - get-value: Use property paths (
a.b.c
) to get a nested value from an object. | homepage - set-value: Create nested values and any intermediaries using dot notation (
'a.b.c'
) paths. | homepage - union-value: Set an array of unique values as the property of an object. Supports setting deeply… more | homepage
Contributing
Pull requests and stars are always welcome. For bugs and feature requests, please create an issue.
Building docs
Generate readme and API documentation with verb:
$ npm install verb && npm run docs
Or, if verb is installed globally:
$ verb
Running tests
Install dev dependencies:
$ npm install -d && npm test
Author
Jon Schlinkert
License
Copyright © 2016 Jon Schlinkert
Released under the MIT license.
This file was generated by verb, v0.9.0, on February 27, 2016.