/******************************************************************************* * Copyright (c) 2021. Rex Isaac Raphael * * Permission is hereby granted, free of charge, to any person obtaining a copy of this software and associated documentation files * (the "Software"), to deal in the Software without restriction, including without limitation the rights to use, copy, modify, merge, * publish, distribute, sublicense, and/or sell copies of the Software, and to permit persons to whom the Software is furnished to do so, * subject to the following conditions: * * The above copyright notice and this permission notice shall be included in all copies or substantial portions of the Software. * * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO * THE WARRANTIES OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL * THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF * CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER * DEALINGS IN THE SOFTWARE. * * File name: config.interface.ts * Last modified: 07/02/2021, 13:00 ******************************************************************************/ export declare enum ConfigSource { Env = 0, File = 1, Etcd = 2, Consul = 3, Kubernetes = 4, Zookeeper = 5 } export interface IConfigStore { watch(path: string, callback: (value: any) => void): void; /** * @description get data */ cache: T; /** * Get a configuration by key path. It will return default value if path is missing * @param path * @param defaultValue */ get(path: string, defaultValue: T): T | Promise | undefined; /** * Get a configuration by key path. * @param path */ get(path: string): T | Promise | undefined; /** * merge config object * @param path */ merge(data: any): void | Promise; /** * Update config by path * @param path */ update(path: string, value: T): void | Promise; } export interface ConfigData { source: ConfigSource; data: Map; } export interface BaseConfigOptions { enableCache?: boolean; } export interface IConfigSource { watch(path: string, callback: (value: any) => void): void; /** * Get a configuration by key path. It will return default value if path is missing * @param path * @param defaultValue */ get(path: string, defaultValue: T): T | Promise | undefined; /** * Get a configuration by key path. * @param path */ get(path: string): T | Promise | undefined; /** * Set config value by key path * @param path * @param value * @param forceUpdate */ set(path: string, value: any, forceUpdate?: boolean): Promise; }