New Case Study:See how Anthropic automated 95% of dependency reviews with Socket.Learn More
Socket
Sign inDemoInstall
Socket

confabulous

Package Overview
Dependencies
Maintainers
1
Versions
27
Alerts
File Explorer

Advanced tools

Socket logo

Install Socket

Detect and block malicious and high-risk dependencies

Install

confabulous

A pluggable, hierarchical, asynchronous config loader and post processor with support for environment variables, command line arguments, json, javascript, http, vault, etcd and postgres

  • 1.4.0
  • Source
  • npm
  • Socket score

Version published
Weekly downloads
996
decreased by-16.86%
Maintainers
1
Weekly downloads
 
Created
Source

Confabulous

Confabulous is a hierarchical, asynchronous config loader and post processor. It can load config from command line arguments, environment variables, files, web servers, databases, and even scm systems. It's easy to extend too. You can watch config sources for changes and apply post processors to do things like decrypt secrets or unflatten key/value pairs into structured objects.

NPM version NPM downloads Build Status Code Climate Test Coverage Code Style Dependency Status devDependencies Status

TL;DR

const Confabulous = require('confabulous')
const loaders = Confabulous.loaders

new Confabulous()
    .add(config => loaders.require({ path: './conf/defaults.js' }))
    .add(config => loaders.require({ path: './conf/production.js' }))
    .end((err, config) => {
        // Your code goes here
    })

Loaders

Loaders are used to load config. Out of the box you can load config from command line parameters, environment variables and files. The following loaders are proviced as separate modules

args

Loads config from command line arguments

new Confabulous().add(config => {
    return loaders.args()
})

You cannot watch command line arguments

env

Loads config from envrionment variables

new Confabulous().add(config => {
    return loaders.env()
})

You cannot watch environment variables

require

Loads config from a .js or .json file

new Confabulous().add(config => {
    return loaders.require({ path: './conf/defaults.js' })
})
OptionTypeDefaultNotes
pathstringundefinedThe javascript or json config file to be required
mandatorybooleantrueCauses an error/reload_error to be emitted if the configuration does not exist
watchbooleanundefinedWatching implemented via fs.watch. Be sure to read the caveats section if you encounter problems.

file

Loads config from the specified file. Files are read using the specified encoding (defaults to 'utf8'). Use a post processor if you want to convert them to json.

new Confabulous().add(config => {
    return loaders.file({ path: './conf/defaults.js' }, [
        processors.json()
    ])
})
OptionTypeDefaultNotes
pathstringundefinedThe config file to be read
mandatorybooleantrueCauses an error/reload_error to be emitted if the configuration does not exist
watchbooleanundefinedWatching implemented via fs.watch. Be sure to read the caveats section if you encounter problems.
encodingstringutf8Specified the file encoding

Post Processors

Post processes can be used to transform or validate your configuration after it's been loaded. Out of the box you can unflatten config into structured documents, parse json and decrypt content.

mount

Mounts the configuration at the specified key

new Confabulous().add(config => {
    return loaders.require({ path: './extra.json' }), [
        processors.mount({ key: 'move.to.here' })
    ])
})
unflatten

Unflattens config into structured documents. Useful for command line arguments and environment variables.

new Confabulous().add(config => {
    return loaders.env(), [
        processors.unflatten()
    ])
})
envToProp

Converts environment variables in the form NODE_ENV=test to nested properties in the form { node: { env: "test" } }

new Confabulous().add(config => {
    return loaders.env(), [
        processors.envToProp()
    ])
})

If you want to prefix your environment variables with an application discriminator you can also strip the prefix.

new Confabulous().add(config => {
    return loaders.env(), [
        processors.envToProp({ prefix: 'GS_' }) // GS_SERVER_PORT => server.port
    ])
})

You can also filter environment variables to include only those you want

new Confabulous().add(config => {
    return loaders.env(), [
        processors.envToProp({ filter: /^GS_/ }) // Only include environment variables starting with GS_
    ])
})
envToCamelCaseProp

Converts environment variables in the form USER__FIRST_NAME=fred to nested properties in the form { user: { firstName: "fred" } }

new Confabulous().add(config => {
    return loaders.env(), [
        processors.envToCamelCaseProp()
    ])
})

If you want to prefix your environment variables with an application discriminator you can also strip the prefix.

new Confabulous().add(config => {
    return loaders.env(), [
        processors.envToCamelCaseProp({ prefix: 'GS_' }) // GS_SERVER_PORT => server.port
    ])
})

You can also filter environment variables to include only those you want

new Confabulous().add(config => {
    return loaders.env(), [
        processors.envToCamelCaseProp({ filter: /^GS_/ }) // Only include environment variables starting with GS_
    ])
})
json

Parses text into JSON. Useful when you have more than one post processor

new Confabulous().add(config => {
    return loaders.file({ path: './config.json.encrypted' }, [
        processors.json()
    ])
})
decrypt

Decrypts encrypted configuration.

new Confabulous().add(config => {
    return loaders.file({ path: './config.json.encrypted' }, [
        processors.decrypt({ algorithm: 'aes192', password: process.env.SECRET }),
        processors.json()
    ])
})

Events

loaded

Emitted when loading config for the first time. Deprecated. Pass a callback to the end function instead.

error

Emitted when an error occurs loading config for the first time. Deprecated. Pass a callback to the end function instead.

reloaded

Emitted when confabulous successfully reloads a watched config.

reload_error

Emitted when confabulous encounters an error reloading a watched config

FAQ

Q. Why doesn't Confabulous notice new files.
A. Because fs.watch doesn't notice them either. You can workaround by modifying some configuration watched by a different loader higher up in the confabulous stack

Keywords

FAQs

Package last updated on 20 Jul 2017

Did you know?

Socket

Socket for GitHub automatically highlights issues in each pull request and monitors the health of all your open source dependencies. Discover the contents of your packages and block harmful activity before you install or update your dependencies.

Install

Related posts

SocketSocket SOC 2 Logo

Product

  • Package Alerts
  • Integrations
  • Docs
  • Pricing
  • FAQ
  • Roadmap
  • Changelog

Packages

npm

Stay in touch

Get open source security insights delivered straight into your inbox.


  • Terms
  • Privacy
  • Security

Made with ⚡️ by Socket Inc