configuru
v1.0.0
Published
Manage the configuration of your Nodejs application with multiple environments and custom preferences, utilizing Configuru in CI and development as well!
Downloads
2,834
Maintainers
Readme
Manage the configuration of your Nodejs application with multiple environments and custom preferences, utilizing Configuru in CI and development as well!
Features
Configuru is a library for configuration management. Merge default project configuration with your user config, you can link yo your project. Atop of that, override your configuration with system environment variables.
- :relieved: Tailored for multi-developer comfort
- :sparkles: Cast and transforms inputs to correct type
- :blue_heart: Typescript friendly
- :muscle: Designed for multi-environment apps
- :see_no_evil: Anonymized configuration for logger
- 💬 JSONC support
Getting started
- Install
npm install configuru
- Create
.env.jsonc
in root of your project, add defaults or placeholders.
{
// HTTP server
"SERVER_PORT": 3000 // port the server will be listening on
}
(optional) As a developer (or environment), create a custom override file (e.g.
~/.env/my-project.jsonc
) and save the path in yourCFG_JSON_PATH
.Create a configuration module (e.g.
config.ts
)
import { createLoader, values } from 'configuru'
// create loader that cascades overrides and creates a config storage
const loader = createLoader()
// Pass configuration schema to `values` transformer to get configuration
export default values({
server: {
// use loader accessors, place them in custom structure
// loader parses correct type from store
port: loader.number('SERVER_PORT'),
},
})
- Use your configuration params throughout your app
import config from './config' // e.g. { server: { port: 3000 } }
console.log(config.server.port) // 3000
Docs
See also
config
- Simple JSON config loader using NODE_ENVdotenv
- Load your configuration file to process.ENVcosmiconfig
- Traverse your filesystem to load find your lost configuration fileconfigstore
- KV storage for configurationfiggy-pudding
- Config object builder / storage
Know other popular projects that solve the same issue? Open a PR to help people find what they need!
License
This project is licensed under MIT.