dotless-conf

Simple dotless config handling for your app or module


Keywords
config, store, app, storage, conf, configuration, settings, preferences, json, data, persist, persistent, save, load, read, write
License
MIT
Install
npm install dotless-conf@0.0.0

Documentation

dotless-conf Build Status: Linux and macOS

Hard fork of sindresorhus's "conf" in order to remove dot props

Simple config handling for your app or module

All you have to care about is what to persist. This module will handle all the dull details like where and how.

Install

$ npm install --save dotless-conf

Usage

const Conf = require('dotless-conf');
const config = new Conf();

config.set('unicorn', '🦄');
console.log(config.get('unicorn'));
//=> '🦄'

// use dot-notation to access nested properties
config.set('foo.bar', true);
console.log(config.get('foo'));
//=> {bar: true}

config.delete('unicorn');
console.log(config.get('unicorn'));
//=> undefined

Why diverge from conf?

When reading and writing an object to a file, you don't always want to support nested object properties

// with "conf"
// use dot-notation to access nested properties
config.set('foo.bar', true);
console.log(config.get('foo'));
//=> {bar: true}

// with "dotless-conf"
config.set('foo.bar', true);
console.log(config.get('foo'));
//=> undefined
console.log(config.get('foo.bar'));
//=> true

API

Conf([options])

Returns a new instance.

options

defaults

Type: Object

Default config.

configName

Type: string
Default: config

Name of the config file (without extension).

Useful if you need multiple config files for your app or module. For example, different config files between two major versions.

projectName

Type: string
Default: The name field in your package.json

You only need to specify this if you don't have a package.json file in your project.

cwd

Type: string
Default: System default user config directory

You most likely don't need this.

Overrides projectName.

The only use-case I can think of is having the config located in the app directory or on some external storage.

Instance

The instance is iterable so you can use it directly in a for…of loop.

.set(key, value)

Set an item.

.set(object)

Set multiple items at once.

.get(key)

Get an item.

.has(key)

Check if an item exists.

.delete(key)

Delete an item.

.clear()

Delete all items.

.size

Get the item count.

.store

Get all the config as an object or replace the current config with an object:

conf.store = {
	hello: 'world'
};

.path

Get the path to the config file.

Related

License

MIT © Dawson Botsford