Configure your node apps in a clear, easy and type safe way. Just define the configuration
values with the types you want to have, and set them using environment variables or
setting them on an .env
file.
Install it:
npm install @miroculus/config
Somewhere on your project, create a file where you define and load your configuration
values, for example on src/config.js
:
const loadConfig = require('@miroculus/config')
module.exports = loadConfig({
PORT: { type: 'number', default: 3000 },
TLS_ENABLED: 'boolean',
MONGODB_URI: { type: 'string', default: 'mongodb://localhost/database' },
PASSWORD_SALT: { type: 'string', required: true },
AUTH: { type: 'json', default: () => ({ user: 'admin', password: 'admin' }) }
})
Then, you can set you configs using environment variables, or creating a file on the
root of you project named .env
(Thanks dotenv
):
PORT=8080
TLS_ENABLED=true
MONGODB_URI=mongodb://localhost/myCustomName
PASSWORD_SALT=somethingreallylongplease
AUTH={ "user": "admin", "password": "some-complicated-password" }
Then, just use it:
const config = require('./src/config')
config.PORT === 8080 // true
!!config.TLS_ENABLED // true
config.MONGODB_URI === 'mongodb://localhost/myCustomName' // true
config.AUTH.user === 'admin' // true
config.AUTH.password === 'some-complicated-password' // true
For each configuration value you can define it's type
, if it is required
, or if
it has a default
value. This are all the possible options:
string
- All string values will be parsed as is.
- The value will be trimmed
- e.g.:
BAR= value foo
=>config.BAR === 'value foo'
- e.g.:
number
- Number values will be coerced to
Number
- e.g.:
PORT=3000
=>config.PORT === 3000
- e.g.:
- Only Integer values are allowed (If you set
NUMBER=3.2
it will throw an error) - Negative numbers are allowed, e.g.:
NUMBER=-32
- Numbers must be "well written", e.g.:
0
✅00
❌0123
❌12300
✅-123
✅-0
✅
- Number values will be coerced to
boolean
- Can be setted using the words
true
orfalse
- Can have uppercase letters, e.g.:
True
orTRUE
- When a boolean is not setted and is not
required
, its value will beundefined
, unless it has adefault
value.
- Can be setted using the words
json
- Json values will be parsed using
JSON.parse
- Examples:
VAL={"some": "json-value"}
VAL=["an", "array", "of", "strings"]
VAL={}
VAL=[]
- Json values will be parsed using
array
- Array values are a custom type for defining an array of
string
s. - Is the same as defining
type: 'string'
but the value will be splitted, trimmed, and empty values filtered using:val.split(',').map((str) => str.trim()).filter((v) => !!v)
- For exmple
VAL=a, b, c
will be parsed toconfig.VAL = ['a', 'b', 'c']
- Array values are a custom type for defining an array of
The default config is to set a value when something is not configured, it can take any value to set, or a function that will be executed and the result setted. e.g.:
PORT: { type: 'number', default: 3000 }
PORT: { type: 'number', default: () => randomNumberBetween(3000, 8000) }
You can set your value as required: true
if you want to throw an error when a
value is not setted, or its setted to an empty value.
This props serves to add a custom validation for the given value. It can be a function
that should return true
or false
, or a RegExp
. e.g. both of the following validations
check that the configured value is 1
, 2
or 3
:
module.exports = loadConfig({
STRING_VALIDATE: { type: 'number', validate: (val, key, config) => [1, 2, 3].includes(val)},
REGEXP_VALIDATE: { type: 'number', validate: /^(1|2|3)$/ }
})
The enum property allows you to set a finite set of value that the given configuration can have. e.g.:
module.exports = loadConfig({
LOG_LEVEL: { type: 'string', enum: ['debug', 'info', 'warn', 'error'] }
})
npm run test
npm run test:watch # for development purposes
MIT