pip-services3-components-node
Version:
Component definitions for Pip.Services in Node.js
153 lines (152 loc) • 6.71 kB
TypeScript
import { IReferenceable } from 'pip-services3-commons-node';
import { IReferences } from 'pip-services3-commons-node';
import { IConfigurable } from 'pip-services3-commons-node';
import { ConfigParams } from 'pip-services3-commons-node';
import { CredentialParams } from '../auth/CredentialParams';
import { CredentialResolver } from '../auth/CredentialResolver';
import { ConnectionParams } from './ConnectionParams';
import { ConnectionResolver } from './ConnectionResolver';
/**
* Helper class that resolves connection and credential parameters,
* validates them and generates connection options.
*
* ### Configuration parameters ###
*
* - connection(s):
* - discovery_key: (optional) a key to retrieve the connection from [[https://pip-services3-node.github.io/pip-services3-components-node/interfaces/connect.idiscovery.html IDiscovery]]
* - protocol: communication protocol
* - host: host name or IP address
* - port: port number
* - uri: resource URI or connection string with all parameters in it
* - credential(s):
* - store_key: (optional) a key to retrieve the credentials from [[https://pip-services3-node.github.io/pip-services3-components-node/interfaces/auth.icredentialstore.html ICredentialStore]]
* - username: user name
* - password: user password
*
* ### References ###
*
* - <code>\*:discovery:\*:\*:1.0</code> (optional) [[https://pip-services3-node.github.io/pip-services3-components-node/interfaces/connect.idiscovery.html IDiscovery]] services to resolve connections
* - <code>\*:credential-store:\*:\*:1.0</code> (optional) Credential stores to resolve credentials
*/
export declare class CompositeConnectionResolver implements IReferenceable, IConfigurable {
/**
* The connection options
*/
protected _options: ConfigParams;
/**
* The connections resolver.
*/
protected _connectionResolver: ConnectionResolver;
/**
* The credentials resolver.
*/
protected _credentialResolver: CredentialResolver;
/**
* The cluster support (multiple connections)
*/
protected _clusterSupported: boolean;
/**
* The default protocol
*/
protected _defaultProtocol: string;
/**
* The default port number
*/
protected _defaultPort: number;
/**
* The list of supported protocols
*/
protected _supportedProtocols: string[];
/**
* Configures component by passing configuration parameters.
*
* @param config configuration parameters to be set.
*/
configure(config: ConfigParams): void;
/**
* Sets references to dependent components.
*
* @param references references to locate the component dependencies.
*/
setReferences(references: IReferences): void;
/**
* Resolves connection options from connection and credential parameters.
*
* @param correlationId (optional) transaction id to trace execution through call chain.
* @param callback callback function that receives resolved options or error.
*/
resolve(correlationId: string, callback: (err: any, options: ConfigParams) => void): void;
/**
* Composes Composite connection options from connection and credential parameters.
*
* @param correlationId (optional) transaction id to trace execution through call chain.
* @param connections connection parameters
* @param credential credential parameters
* @param parameters optional parameters
* @param callback callback function that receives resolved options or error.
*/
compose(correlationId: string, connections: ConnectionParams[], credential: CredentialParams, parameters: ConfigParams, callback: (err: any, options: any) => void): void;
/**
* Validates connection parameters.
* This method can be overriden in child classes.
*
* @param correlationId (optional) transaction id to trace execution through call chain.
* @param connection connection parameters to be validated
* @returns error or <code>null</code> if validation was successful
*/
protected validateConnection(correlationId: string, connection: ConnectionParams): any;
/**
* Validates credential parameters.
* This method can be overriden in child classes.
*
* @param correlationId (optional) transaction id to trace execution through call chain.
* @param credential credential parameters to be validated
* @returns error or <code>null</code> if validation was successful
*/
protected validateCredential(correlationId: string, credential: CredentialParams): any;
/**
* Composes connection and credential parameters into connection options.
* This method can be overriden in child classes.
*
* @param connections a list of connection parameters
* @param credential credential parameters
* @param parameters optional parameters
* @returns a composed connection options.
*/
protected composeOptions(connections: ConnectionParams[], credential: CredentialParams, parameters: ConfigParams): ConfigParams;
/**
* Merges connection options with connection parameters
* This method can be overriden in child classes.
*
* @param options connection options
* @param connection connection parameters to be merged
* @returns merged connection options.
*/
protected mergeConnection(options: ConfigParams, connection: ConnectionParams): ConfigParams;
/**
* Merges connection options with credential parameters
* This method can be overriden in child classes.
*
* @param options connection options
* @param credential credential parameters to be merged
* @returns merged connection options.
*/
protected mergeCredential(options: ConfigParams, credential: CredentialParams): ConfigParams;
/**
* Merges connection options with optional parameters
* This method can be overriden in child classes.
*
* @param options connection options
* @param parameters optional parameters to be merged
* @returns merged connection options.
*/
protected mergeOptional(options: ConfigParams, parameters: ConfigParams): ConfigParams;
/**
* Finalize merged options
* This method can be overriden in child classes.
*
* @param options connection options
* @returns finalized connection options
*/
protected finalizeOptions(options: ConfigParams): ConfigParams;
}