lowdb = function (source) {
var opts = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : {};
// Create a fresh copy of lodash
var _ = lodash.runInContext();
var db = _.chain({});
// Expose _ for mixins
db._ = _;
// Add write function to lodash
// Calls save before returning result
_.prototype.write = _.wrap(_.prototype.value, function (func) {
var dest = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : source;
var funcRes = func.apply(this);
return db.write(dest, funcRes);
});
return common.init(db, '__wrapped__', source, opts);
}n/a
function browserRead(source) {
var deserialize = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : JSON.parse;
var data = localStorage.getItem(source);
if (data) {
return deserialize(data);
} else {
localStorage.setItem(source, '{}');
return {};
}
}...
```js
const db = low('db.json')
db.write() // writes to db.json
db.write('copy.json') // writes to copy.json
```
__db.read([source])__
Reads source using `storage.read` option. Depending on the storage, it may return a promise.
```js
const db = low('db.json')
db.read() // reads db.json
db.read('copy.json') // reads copy.json
...function browserWrite(dest, obj) {
var serialize = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : stringify;
localStorage.setItem(dest, serialize(obj));
}...
> A small local database powered by lodash API
```js
const db = low('db.json')
// Set some defaults if your JSON file is empty
db.defaults({ posts: [], user: {} })
.write()
// Add a post
db.get('posts')
.push({ id: 1, title: 'lowdb is awesome'})
.write()
// Set a user
...function init(db, key, source) {
var _ref = arguments.length > 3 && arguments[3] !== undefined ? arguments[3] : {},
_ref$storage = _ref.storage,
storage = _ref$storage === undefined ? defaultStorage : _ref$storage,
_ref$format = _ref.format,
format = _ref$format === undefined ? {} : _ref$format;
db.source = source;
// Set storage
// In-memory only if no source is provided
db.storage = _extends({}, memory, db.source && storage);
db.read = function () {
var s = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : source;
var r = db.storage.read(s, format.deserialize);
return isPromise(r) ? r.then(db.plant) : db.plant(r);
};
db.write = function () {
var dest = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : source;
var value = (arguments.length <= 1 ? 0 : arguments.length - 1) ? arguments.length <= 1 ? undefined : arguments[1] : db.getState
();
var w = db.storage.write(dest, db.getState(), format.serialize);
return isPromise(w) ? w.then(function () {
return value;
}) : value;
};
db.plant = function (state) {
db[key] = state;
return db;
};
db.getState = function () {
return db[key];
};
db.setState = function (state) {
db.plant(state);
return db.write();
};
return db.read();
}...
set(db.getState(), path, result);
return db.write(source, result);
};
return getValue;
}
return common.init(db, '__state__', source, opts);
};
...function fileSyncRead(source) {
var deserialize = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : JSON.parse;
if (fs.existsSync(source)) {
// Read database
var data = fs.readFileSync(source, 'utf-8').trim() || '{}';
try {
return deserialize(data);
} catch (e) {
if (e instanceof SyntaxError) {
e.message = 'Malformed JSON in file: ' + source + '\n' + e.message;
}
throw e;
}
} else {
// Initialize empty database
fs.writeFileSync(source, '{}');
return {};
}
}...
```js
const db = low('db.json')
db.write() // writes to db.json
db.write('copy.json') // writes to copy.json
```
__db.read([source])__
Reads source using `storage.read` option. Depending on the storage, it may return a promise.
```js
const db = low('db.json')
db.read() // reads db.json
db.read('copy.json') // reads copy.json
...function fileAsyncWrite(dest, obj) {
var serialize = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : stringify;
return new Promise(function (resolve, reject) {
var data = serialize(obj);
steno.writeFile(dest, data, function (err) {
if (err) return reject(err);
resolve();
});
});
}...
> A small local database powered by lodash API
```js
const db = low('db.json')
// Set some defaults if your JSON file is empty
db.defaults({ posts: [], user: {} })
.write()
// Add a post
db.get('posts')
.push({ id: 1, title: 'lowdb is awesome'})
.write()
// Set a user
...function fileSyncRead(source) {
var deserialize = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : JSON.parse;
if (fs.existsSync(source)) {
// Read database
var data = fs.readFileSync(source, 'utf-8').trim() || '{}';
try {
return deserialize(data);
} catch (e) {
if (e instanceof SyntaxError) {
e.message = 'Malformed JSON in file: ' + source + '\n' + e.message;
}
throw e;
}
} else {
// Initialize empty database
fs.writeFileSync(source, '{}');
return {};
}
}...
```js
const db = low('db.json')
db.write() // writes to db.json
db.write('copy.json') // writes to copy.json
```
__db.read([source])__
Reads source using `storage.read` option. Depending on the storage, it may return a promise.
```js
const db = low('db.json')
db.read() // reads db.json
db.read('copy.json') // reads copy.json
...function fileSyncWrite(dest, obj) {
var serialize = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : stringify;
var data = serialize(obj);
fs.writeFileSync(dest, data);
}...
> A small local database powered by lodash API
```js
const db = low('db.json')
// Set some defaults if your JSON file is empty
db.defaults({ posts: [], user: {} })
.write()
// Add a post
db.get('posts')
.push({ id: 1, title: 'lowdb is awesome'})
.write()
// Set a user
...function memoryRead() {
return {};
}...
```js
const db = low('db.json')
db.write() // writes to db.json
db.write('copy.json') // writes to copy.json
```
__db.read([source])__
Reads source using `storage.read` option. Depending on the storage, it may return a promise.
```js
const db = low('db.json')
db.read() // reads db.json
db.read('copy.json') // reads copy.json
...function memoryWrite() {
return {};
}...
> A small local database powered by lodash API
```js
const db = low('db.json')
// Set some defaults if your JSON file is empty
db.defaults({ posts: [], user: {} })
.write()
// Add a post
db.get('posts')
.push({ id: 1, title: 'lowdb is awesome'})
.write()
// Set a user
...