From f8127c2ed4555603a5be11296d3bf5650713b9a6 Mon Sep 17 00:00:00 2001 From: Matt Edelman Date: Fri, 23 Dec 2016 12:12:13 -0800 Subject: [PATCH] add feature for ignoring environment variables --- README.md | 1 + lib/factory.js | 5 +++-- lib/provider.js | 4 ++-- test/confit-test.js | 23 +++++++++++++++++++++++ test/provider-test.js | 2 +- 5 files changed, 30 insertions(+), 5 deletions(-) diff --git a/README.md b/README.md index ded3f93..c89562d 100644 --- a/README.md +++ b/README.md @@ -70,6 +70,7 @@ These protocols will be used to process the config data prior to registration. If using an array of handler implementations, each handler is run in series (see [`Multiple handlers` in the shortstop README](https://github.com/krakenjs/shortstop#multiple-handlers)). * `defaults` (*String*) - the name of the file containing all default values. Defaults to `config.json`. +* `envignore` (*Array*) - any properties found in `process.env` that should be ignored ```javascript 'use strict'; diff --git a/lib/factory.js b/lib/factory.js index c8b7ee5..a74276b 100644 --- a/lib/factory.js +++ b/lib/factory.js @@ -27,7 +27,8 @@ const debug = debuglog('confit'); export default class Factory { - constructor({ basedir, protocols = {}, defaults = 'config.json' }) { + constructor({ basedir, protocols = {}, defaults = 'config.json', envignore = []}) { + this.envignore = envignore.push('env'); this.basedir = basedir; this.protocols = protocols; this.promise = Promise.resolve({}) @@ -42,7 +43,7 @@ export default class Factory { return Handlers.resolveImport(shush(file), this.basedir) .then(data => Common.merge(shush(file), store)); })) - .then(store => Common.merge(Provider.env(), store)) + .then(store => Common.merge(Provider.env(envignore), store)) .then(store => Common.merge(Provider.argv(), store)); } diff --git a/lib/provider.js b/lib/provider.js index b2c8331..384d338 100644 --- a/lib/provider.js +++ b/lib/provider.js @@ -41,7 +41,7 @@ export default { return result; }, - env() { + env(ignore) { let result = {}; // process.env is not a normal object, so we @@ -49,7 +49,7 @@ export default { for (let env of Object.keys(process.env)) { //env:env is decided by process.env.NODE_ENV. //Not allowing process.env.env to override the env:env value. - if (env !== 'env') { + if (ignore.indexOf(env) < 0) { result[env] = process.env[env]; } } diff --git a/test/confit-test.js b/test/confit-test.js index ba42728..fd95afe 100644 --- a/test/confit-test.js +++ b/test/confit-test.js @@ -527,5 +527,28 @@ test('confit', function (t) { t.end(); }); }); + t.test('env ignore', function (t) { + var basedir, options; + + var env = process.env = { + NODE_ENV: 'development', + fromlocal: 'config:local', + local: 'motion', + ignoreme: 'file:./path/to/mindyourbusiness' + }; + basedir = path.join(__dirname, 'fixtures', 'defaults'); + options = { + basedir: basedir, + envignore: ['ignoreme'] + }; + + confit(options).create(function (err, config) { + t.error(err); + // Ensure env is read except for the desired ignored property + t.equal(config.get('fromlocal'), env.local); + t.equal(config.get('ignoreme'), undefined); + t.end(); + }); + }); }); diff --git a/test/provider-test.js b/test/provider-test.js index 2b205a1..a698408 100644 --- a/test/provider-test.js +++ b/test/provider-test.js @@ -19,7 +19,7 @@ test('env', function (t) { env: 'development' }; - val = provider.env(); + val = provider.env(['env']); t.equal(val.foo, 'bar'); //env() provider ignores process.env.env t.equal(val.env, undefined);