UNPKG

aws-cdk

Version:

AWS CDK CLI, the command line tool for CDK apps

64 lines (63 loc) 2.25 kB
import type { CredentialProviderSource, IPluginHost } from '@aws-cdk/cli-plugin-contract'; import { type ContextProviderPlugin } from './context-provider-plugin'; export declare let TESTING: boolean; export declare function markTesting(): void; /** * A utility to manage plug-ins. * */ export declare class PluginHost implements IPluginHost { static instance: PluginHost; /** * Access the currently registered CredentialProviderSources. New sources can * be registered using the +registerCredentialProviderSource+ method. */ readonly credentialProviderSources: CredentialProviderSource[]; readonly contextProviderPlugins: Record<string, ContextProviderPlugin>; constructor(); /** * Loads a plug-in into this PluginHost. * * @param moduleSpec the specification (path or name) of the plug-in module to be loaded. */ load(moduleSpec: string): void; /** * Allows plug-ins to register new CredentialProviderSources. * * @param source a new CredentialProviderSource to register. */ registerCredentialProviderSource(source: CredentialProviderSource): void; /** * (EXPERIMENTAL) Allow plugins to register context providers * * Context providers are objects with the following method: * * ```ts * getValue(args: {[key: string]: any}): Promise<any>; * ``` * * Currently, they cannot reuse the CDK's authentication mechanisms, so they * must be prepared to either not make AWS calls or use their own source of * AWS credentials. * * This feature is experimental, and only intended to be used internally at Amazon * as a trial. * * After registering with 'my-plugin-name', the provider must be addressed as follows: * * ```ts * const value = ContextProvider.getValue(this, { * providerName: 'plugin', * props: { * pluginName: 'my-plugin-name', * myParameter1: 'xyz', * }, * includeEnvironment: true | false, * dummyValue: 'what-to-return-on-the-first-pass', * }) * ``` * * @experimental */ registerContextProviderAlpha(pluginProviderName: string, provider: ContextProviderPlugin): void; }