pip-services3-components-node
Version:
Component definitions for Pip.Services in Node.js
81 lines (71 loc) • 2.77 kB
text/typescript
/** @module config */
/** @hidden */
let _ = require('lodash');
import { ConfigParams } from 'pip-services3-commons-node';
import { IConfigurable } from 'pip-services3-commons-node';
import { INotifiable } from 'pip-services3-commons-node';
import { MustacheTemplate } from 'pip-services3-expressions-nodex';
/**
* Abstract config reader that supports configuration parameterization.
*
* ### Configuration parameters ###
*
* - __parameters:__ this entire section is used as template parameters
* - ...
*
* @see [[IConfigReader]]
*/
export abstract class ConfigReader implements IConfigurable {
private _parameters: ConfigParams = new ConfigParams();
/**
* Creates a new instance of the config reader.
*/
public constructor() {}
/**
* Configures component by passing configuration parameters.
*
* @param config configuration parameters to be set.
*/
public configure(config: ConfigParams): void {
let parameters = config.getSection("parameters")
if (parameters.length() > 0)
this._parameters = parameters;
}
/**
* Reads configuration and parameterize it with given values.
*
* @param correlationId (optional) transaction id to trace execution through call chain.
* @param parameters values to parameters the configuration or null to skip parameterization.
* @param callback callback function that receives configuration or error.
*/
public abstract readConfig(correlationId: string, parameters: ConfigParams,
callback: (err: any, config: ConfigParams) => void): void;
/**
* Parameterized configuration template given as string with dynamic parameters.
*
* The method uses [[https://handlebarsjs.com Handlebars]] template engine.
*
* @param config a string with configuration template to be parameterized
* @param parameters dynamic parameters to inject into the template
* @returns a parameterized configuration string.
*/
protected parameterize(config: string, parameters: ConfigParams): string {
parameters = this._parameters.override(parameters);
let template = new MustacheTemplate(config);
return template.evaluateWithVariables(parameters);
}
/**
* Adds a listener that will be notified when configuration is changed
* @param listener a listener to be added.
*/
public addChangeListener(listener: INotifiable): void {
// Do nothing...
}
/**
* Remove a previously added change listener.
* @param listener a listener to be removed.
*/
public removeChangeListener(listener: INotifiable): void {
// Do nothing...
}
}