Skip to content

Releases: loarca/declarative-db

Refactor to Typescript

27 Nov 21:23
Compare
Choose a tag to compare

1.0.3 - 2019-11-26

Fixed

  • Refactor to use Typescript.

Important issue fixed

16 Aug 17:06
Compare
Choose a tag to compare

1.0.2 - 2018-08-16

Fixed

  • initialState now works as intended, it was always the initial state whether there was already a file or not (issue #7).

Smart scheduled saving

13 Aug 22:38
Compare
Choose a tag to compare

1.0.1 - 2018-08-13

Added

  • Mutex protection to saving to disk.
  • Smart scheduled saving.

First release

13 Aug 21:08
Compare
Choose a tag to compare

declarative-db

An easy-to-use declarative json-based database for Node

Installation

npm install declarative-db

Usage

const path = require('path');
const declare = require('declarative-db');

// Declare json-based database
declare({
  filename: path.join(__dirname, './db.json'),
}).then(db => {
  // Use it as you would normally use an object (or array)
  db.users = [{
    username: 'loarca',
  }];

  // It will automatically save to disk asynchronously when appropriate
});

Since it's Promise based you can also use async-await

const path = require('path');
const declare = require('declarative-db');

(async () => {
  // Declare json-based database
  let db = await declare({
    filename: path.join(__dirname, './db.json'),
  });

  // Use it as you would normally use an object (or array)
  db.users = [{
    username: 'loarca',
  }];

  // It will automatically save to disk asynchronously when appropriate
})();

You should declare() only once per file and share declared objects/arrays across all modules, as every declared object/array is... exactly that... an object/array in memory that automatically saves to disk when appropriate

Options

{
  filename: path.join(__dirname, './db.json'),
  initialState: {},
  compression: 0,
}

filename

File to store data

initialState (default = {})

When no database file exists initialState is used,
it may be an object or array

compression (default = 0)

Compression level ranging from 0 to 9

Level 0 outputs database to readable json

{
  "users": [
    {
      "username": "loarca"
    }
  ]
}

Levels from 1 to 9 match DEFLATE compression levels