cnn-config-client
v0.1.8
Published
A module that gets data from a config server and set environment variables.
Downloads
14
Readme
CNN Server Configuration Client
A module that gets data from a config server and set environment variables.
Contents
- Documentation
- Local development
- Generate local docs
- Contributing
- Project Owner
- Current Project Team Members
Documentation
- ESDoc documentation can be generated. See below for details.
Local development
Requirements
nvm - a reasonably current version
nvm
will be used to manage the node versions installed on your
localhost.
node - The version specified by .nvmrc
and package.json
You should install this with nvm. Make sure you are in the root of the
project directory and do the following. There is a .nvmrc
file that tells
nvm
what version to install and use. The first nvm install
command is only
needed the first time you try to use a version that has not been installed on
your system yet.
$ nvm install
$ node --version
v5.5.0
Local install
Clone this repository, install the above requirements, then:
$ cd cnn-config-client
$ nvm use
$ npm install
How to test
Run the following.
$ npm test
Environment variables
- CONFIG_HOST - REQUIRED - The configuration host that the client should interface with for the config values.
Exported methods
register(options)
update(options)
getConfig(options, callback)
Example 1: Config update
const client = require('../index.js'),
config = {
product: 'test',
environment: 'test',
token: '35e6c81b5a764404eac05f0c556d7cb3f4549c00',
data: {
timeout: 9
}
};
client.update(config);
UPDATE RESPONSE: {"product":"test","environment":"test","data":{"timeout":9},"message":"Config updated"}
Example 2: Set the environment
const client = require('../index.js'),
config = {
product: 'test',
environment: 'test',
token: '35e6c81b5a764404eac05f0c556d7cb3f4549c00'
};
client.getConfig(config, function (error, data) {
if (error) {
console.log(error);
} else {
console.log('data: %j', data);
console.log('Environment variables have been set');
}
});
set process.env.TIMEOUT = 9
Environment variables have been set
Generate Local Docs
$ npm run generate-docs
$ open docs/index.html
Contributing
If you would like to contribute, just fork and submit a pull request. Please review the contributing guidelines first.
Project Owner
A.D. Slaton [email protected] (@adslaton) is the current Project Owner of this repository. The project owner is responsible for the implementation of this project.
Current Project Team Members
This is a list of people directly responsible for the implementation of this project. For more information about the governance of this project, see GOVERNANCE.md.
- A.D. Slaton [email protected] (@adslaton) - Applications Architect
Collaborators follow the COLLABORATOR_GUIDE.md in maintaining this project.