conev-source-json is an implementation of conev's source to get configuration from json.
# with npm
npm install conev-source-json
# or with Yarn
yarn add conev-source-json
Get ConfigBuilder from conev and Sources to use.
import { ConfigBuilder } from 'conev';
import JsonSource from 'conev-source-json';
And create Source and set up.
const jsonSource = new JsonSource();
jsonSource
.setConfig('basic', basic) // basic is JSON
.setConfig('dev', dev) // dev is JSON
.setConfig('prd', prd); // prd is JSON
Create ConfigBuilder and set Environment, add source. (highest priority is added first).
const builder = new ConfigBuilder();
builder
.setEnv('dev', 'basic')
.addSource(jsonSource);
Build configuration
const config = await builder.build(); // This is the result of combining dev and basic.
Use configuration
config.get() // The whole configuration created comes out
config.get('a.b.c'); // Is same as config.get().a.b.c
class JsonSource {
constructor(map?: Map<string, object>);
setConfig(env: string, ...values: object[]): JsonSource
addConfig(env: string, ...values: object[]): JsonSource;
removeConfig(env: string): JsonSource;
export(): Promise<Map<string, object>>;
}
JsonSource
defines the source from JSON. Use setConfig
to add a configuration for a new environment or removeConfig
to delete a configuration. Map is returned as the result value of export
. The key of this map is environment and the value is the configuration when environment.