@aws-cdk/toolkit-lib 0.3.0 → 0.3.2
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/README.md +1 -1
- package/build-info.json +2 -2
- package/db.json.gz +0 -0
- package/lib/api/aws-auth/types.d.ts +79 -1
- package/lib/api/aws-auth/types.js +74 -1
- package/lib/api/cloud-assembly/cached-source.d.ts +1 -0
- package/lib/api/cloud-assembly/cached-source.js +2 -1
- package/lib/api/cloud-assembly/private/borrowed-assembly.d.ts +1 -0
- package/lib/api/cloud-assembly/private/borrowed-assembly.js +2 -1
- package/lib/api/cloud-assembly/private/context-aware-source.js +2 -2
- package/lib/api/cloud-assembly/private/prepare-source.d.ts +1 -0
- package/lib/api/cloud-assembly/private/prepare-source.js +2 -1
- package/lib/api/cloud-assembly/private/source-builder.js +3 -3
- package/lib/api/cloud-assembly/private/stack-assembly.d.ts +1 -0
- package/lib/api/cloud-assembly/private/stack-assembly.js +2 -5
- package/lib/api/shared-private.d.ts +1 -0
- package/lib/api/shared-private.js +99 -49
- package/lib/api/shared-private.js.map +2 -2
- package/lib/api/shared-public.d.ts +162 -0
- package/lib/api/shared-public.js +940 -12
- package/lib/api/shared-public.js.map +4 -4
- package/lib/index_bg.wasm +0 -0
- package/lib/toolkit/private/index.d.ts +2 -1
- package/lib/toolkit/private/index.js +1 -1
- package/lib/toolkit/toolkit.d.ts +17 -0
- package/lib/toolkit/toolkit.js +22 -5
- package/package.json +11 -11
|
@@ -1,14 +1,11 @@
|
|
|
1
1
|
"use strict";
|
|
2
2
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
3
|
exports.StackAssembly = void 0;
|
|
4
|
+
require("../../../private/dispose-polyfill");
|
|
4
5
|
const semver_1 = require("semver");
|
|
5
6
|
const shared_private_1 = require("../../shared-private");
|
|
6
7
|
const shared_public_1 = require("../../shared-public");
|
|
7
8
|
const stack_selector_1 = require("../stack-selector");
|
|
8
|
-
if (!Symbol.asyncDispose) {
|
|
9
|
-
// eslint-disable-next-line @cdklabs/no-throw-default-error
|
|
10
|
-
throw new Error('Symbol.asyncDispose is not defined on the current JavaScript platform!');
|
|
11
|
-
}
|
|
12
9
|
/**
|
|
13
10
|
* A single Cloud Assembly wrapped to provide additional stack operations.
|
|
14
11
|
*/
|
|
@@ -109,4 +106,4 @@ function expandToExtendEnum(extend) {
|
|
|
109
106
|
return undefined;
|
|
110
107
|
}
|
|
111
108
|
}
|
|
112
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"stack-assembly.js","sourceRoot":"","sources":["stack-assembly.ts"],"names":[],"mappings":"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","sourcesContent":["import { major } from 'semver';\nimport type { IoHelper } from '../../shared-private';\nimport { BaseStackAssembly, StackCollection, ExtendedStackSelection as CliExtendedStackSelection } from '../../shared-private';\nimport { ToolkitError } from '../../shared-public';\nimport type { StackSelector } from '../stack-selector';\nimport { ExpandStackSelection, StackSelectionStrategy } from '../stack-selector';\nimport type { IReadableCloudAssembly } from '../types';\n\nif (!Symbol.asyncDispose) {\n  // eslint-disable-next-line @cdklabs/no-throw-default-error\n  throw new Error('Symbol.asyncDispose is not defined on the current JavaScript platform!');\n}\n\n/**\n * A single Cloud Assembly wrapped to provide additional stack operations.\n */\nexport class StackAssembly extends BaseStackAssembly implements IReadableCloudAssembly {\n  constructor(private readonly _asm: IReadableCloudAssembly, ioHelper: IoHelper) {\n    super(_asm.cloudAssembly, ioHelper);\n  }\n\n  public get cloudAssembly() {\n    return this._asm.cloudAssembly;\n  }\n\n  public async _unlock() {\n    return this._asm._unlock();\n  }\n\n  public async dispose() {\n    return this._asm.dispose();\n  }\n\n  public async [Symbol.asyncDispose]() {\n    return this.dispose();\n  }\n\n  /**\n   * Improved stack selection interface with a single selector\n   * @throws when the assembly does not contain any stacks, unless `selector.failOnEmpty` is `false`\n   * @throws when individual selection strategies are not satisfied\n   */\n  public async selectStacksV2(selector: StackSelector): Promise<StackCollection> {\n    const asm = this.assembly;\n    const topLevelStacks = asm.stacks;\n    const allStacks = major(asm.version) < 10 ? asm.stacks : asm.stacksRecursively;\n\n    if (allStacks.length === 0 && (selector.failOnEmpty ?? true)) {\n      throw new ToolkitError('This app contains no stacks');\n    }\n\n    const extend = expandToExtendEnum(selector.expand);\n    const patterns = StackAssembly.sanitizePatterns(selector.patterns ?? []);\n\n    switch (selector.strategy) {\n      case StackSelectionStrategy.ALL_STACKS:\n        return new StackCollection(this, allStacks);\n      case StackSelectionStrategy.MAIN_ASSEMBLY:\n        if (topLevelStacks.length < 1) {\n          // @todo text should probably be handled in io host\n          throw new ToolkitError('No stack found in the main cloud assembly. Use \"list\" to print manifest');\n        }\n        return this.extendStacks(topLevelStacks, allStacks, extend);\n      case StackSelectionStrategy.ONLY_SINGLE:\n        if (topLevelStacks.length !== 1) {\n          // @todo text should probably be handled in io host\n          throw new ToolkitError('Since this app includes more than a single stack, specify which stacks to use (wildcards are supported) or specify `--all`\\n' +\n          `Stacks: ${allStacks.map(x => x.hierarchicalId).join(' · ')}`);\n        }\n        return new StackCollection(this, topLevelStacks);\n      default:\n        const matched = await this.selectMatchingStacks(allStacks, patterns, extend);\n        if (\n          selector.strategy === StackSelectionStrategy.PATTERN_MUST_MATCH_SINGLE\n          && matched.stackCount !== 1\n        ) {\n          // @todo text should probably be handled in io host\n          throw new ToolkitError(\n            `Stack selection is ambiguous, please choose a specific stack for import [${allStacks.map(x => x.hierarchicalId).join(',')}]`,\n          );\n        }\n        if (\n          selector.strategy === StackSelectionStrategy.PATTERN_MUST_MATCH\n          && matched.stackCount < 1\n        ) {\n          // @todo text should probably be handled in io host\n          throw new ToolkitError(\n            `Stack selection is ambiguous, please choose a specific stack for import [${allStacks.map(x => x.hierarchicalId).join(',')}]`,\n          );\n        }\n\n        return matched;\n    }\n  }\n\n  /**\n   * Select all stacks.\n   *\n   * This method never throws and can safely be used as a basis for other calculations.\n   *\n   * @returns a `StackCollection` of all stacks\n   */\n  public selectAllStacks() {\n    const allStacks = major(this.assembly.version) < 10 ? this.assembly.stacks : this.assembly.stacksRecursively;\n    return new StackCollection(this, allStacks);\n  }\n\n  /**\n   * Select all stacks that have the validateOnSynth flag et.\n   *\n   * @returns a `StackCollection` of all stacks that needs to be validated\n   */\n  public selectStacksForValidation() {\n    const allStacks = this.selectAllStacks();\n    return allStacks.filter((art) => art.validateOnSynth ?? false);\n  }\n}\n\nfunction expandToExtendEnum(extend?: ExpandStackSelection): CliExtendedStackSelection | undefined {\n  switch (extend) {\n    case ExpandStackSelection.DOWNSTREAM:\n      return CliExtendedStackSelection.Downstream;\n    case ExpandStackSelection.UPSTREAM:\n      return CliExtendedStackSelection.Upstream;\n    case ExpandStackSelection.NONE:\n      return CliExtendedStackSelection.None;\n    default:\n      return undefined;\n  }\n}\n"]}
|
|
109
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"stack-assembly.js","sourceRoot":"","sources":["stack-assembly.ts"],"names":[],"mappings":"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","sourcesContent":["import '../../../private/dispose-polyfill';\nimport { major } from 'semver';\nimport type { IoHelper } from '../../shared-private';\nimport { BaseStackAssembly, StackCollection, ExtendedStackSelection as CliExtendedStackSelection } from '../../shared-private';\nimport { ToolkitError } from '../../shared-public';\nimport type { StackSelector } from '../stack-selector';\nimport { ExpandStackSelection, StackSelectionStrategy } from '../stack-selector';\nimport type { IReadableCloudAssembly } from '../types';\n\n/**\n * A single Cloud Assembly wrapped to provide additional stack operations.\n */\nexport class StackAssembly extends BaseStackAssembly implements IReadableCloudAssembly {\n  constructor(private readonly _asm: IReadableCloudAssembly, ioHelper: IoHelper) {\n    super(_asm.cloudAssembly, ioHelper);\n  }\n\n  public get cloudAssembly() {\n    return this._asm.cloudAssembly;\n  }\n\n  public async _unlock() {\n    return this._asm._unlock();\n  }\n\n  public async dispose() {\n    return this._asm.dispose();\n  }\n\n  public async [Symbol.asyncDispose]() {\n    return this.dispose();\n  }\n\n  /**\n   * Improved stack selection interface with a single selector\n   * @throws when the assembly does not contain any stacks, unless `selector.failOnEmpty` is `false`\n   * @throws when individual selection strategies are not satisfied\n   */\n  public async selectStacksV2(selector: StackSelector): Promise<StackCollection> {\n    const asm = this.assembly;\n    const topLevelStacks = asm.stacks;\n    const allStacks = major(asm.version) < 10 ? asm.stacks : asm.stacksRecursively;\n\n    if (allStacks.length === 0 && (selector.failOnEmpty ?? true)) {\n      throw new ToolkitError('This app contains no stacks');\n    }\n\n    const extend = expandToExtendEnum(selector.expand);\n    const patterns = StackAssembly.sanitizePatterns(selector.patterns ?? []);\n\n    switch (selector.strategy) {\n      case StackSelectionStrategy.ALL_STACKS:\n        return new StackCollection(this, allStacks);\n      case StackSelectionStrategy.MAIN_ASSEMBLY:\n        if (topLevelStacks.length < 1) {\n          // @todo text should probably be handled in io host\n          throw new ToolkitError('No stack found in the main cloud assembly. Use \"list\" to print manifest');\n        }\n        return this.extendStacks(topLevelStacks, allStacks, extend);\n      case StackSelectionStrategy.ONLY_SINGLE:\n        if (topLevelStacks.length !== 1) {\n          // @todo text should probably be handled in io host\n          throw new ToolkitError('Since this app includes more than a single stack, specify which stacks to use (wildcards are supported) or specify `--all`\\n' +\n          `Stacks: ${allStacks.map(x => x.hierarchicalId).join(' · ')}`);\n        }\n        return new StackCollection(this, topLevelStacks);\n      default:\n        const matched = await this.selectMatchingStacks(allStacks, patterns, extend);\n        if (\n          selector.strategy === StackSelectionStrategy.PATTERN_MUST_MATCH_SINGLE\n          && matched.stackCount !== 1\n        ) {\n          // @todo text should probably be handled in io host\n          throw new ToolkitError(\n            `Stack selection is ambiguous, please choose a specific stack for import [${allStacks.map(x => x.hierarchicalId).join(',')}]`,\n          );\n        }\n        if (\n          selector.strategy === StackSelectionStrategy.PATTERN_MUST_MATCH\n          && matched.stackCount < 1\n        ) {\n          // @todo text should probably be handled in io host\n          throw new ToolkitError(\n            `Stack selection is ambiguous, please choose a specific stack for import [${allStacks.map(x => x.hierarchicalId).join(',')}]`,\n          );\n        }\n\n        return matched;\n    }\n  }\n\n  /**\n   * Select all stacks.\n   *\n   * This method never throws and can safely be used as a basis for other calculations.\n   *\n   * @returns a `StackCollection` of all stacks\n   */\n  public selectAllStacks() {\n    const allStacks = major(this.assembly.version) < 10 ? this.assembly.stacks : this.assembly.stacksRecursively;\n    return new StackCollection(this, allStacks);\n  }\n\n  /**\n   * Select all stacks that have the validateOnSynth flag et.\n   *\n   * @returns a `StackCollection` of all stacks that needs to be validated\n   */\n  public selectStacksForValidation() {\n    const allStacks = this.selectAllStacks();\n    return allStacks.filter((art) => art.validateOnSynth ?? false);\n  }\n}\n\nfunction expandToExtendEnum(extend?: ExpandStackSelection): CliExtendedStackSelection | undefined {\n  switch (extend) {\n    case ExpandStackSelection.DOWNSTREAM:\n      return CliExtendedStackSelection.Downstream;\n    case ExpandStackSelection.UPSTREAM:\n      return CliExtendedStackSelection.Upstream;\n    case ExpandStackSelection.NONE:\n      return CliExtendedStackSelection.None;\n    default:\n      return undefined;\n  }\n}\n"]}
|
|
@@ -2,4 +2,5 @@ export * from '../../../tmp-toolkit-helpers/src/api/io/private';
|
|
|
2
2
|
export * from '../../../tmp-toolkit-helpers/src/private';
|
|
3
3
|
export * from '../../../tmp-toolkit-helpers/src/api';
|
|
4
4
|
export * as cfnApi from '../../../tmp-toolkit-helpers/src/api/deployments/cfn-api';
|
|
5
|
+
export { makeRequestHandler } from '../../../tmp-toolkit-helpers/src/api/aws-auth/awscli-compatible';
|
|
5
6
|
export * as contextproviders from '../../../tmp-toolkit-helpers/src/context-providers';
|
|
@@ -156,6 +156,7 @@ __export(shared_private_exports, {
|
|
|
156
156
|
loadTree: () => loadTree,
|
|
157
157
|
loadTreeFromDir: () => loadTreeFromDir,
|
|
158
158
|
makeBodyParameter: () => makeBodyParameter,
|
|
159
|
+
makeRequestHandler: () => makeRequestHandler,
|
|
159
160
|
markTesting: () => markTesting,
|
|
160
161
|
nonHotswappableChange: () => nonHotswappableChange,
|
|
161
162
|
nonHotswappableResource: () => nonHotswappableResource,
|
|
@@ -2468,8 +2469,20 @@ var DEFAULT_CONNECTION_TIMEOUT = 1e4;
|
|
|
2468
2469
|
var DEFAULT_TIMEOUT = 3e5;
|
|
2469
2470
|
var AwsCliCompatible = class {
|
|
2470
2471
|
ioHelper;
|
|
2471
|
-
|
|
2472
|
+
requestHandler;
|
|
2473
|
+
logger;
|
|
2474
|
+
constructor(ioHelper, requestHandler, logger) {
|
|
2472
2475
|
this.ioHelper = ioHelper;
|
|
2476
|
+
this.requestHandler = requestHandler;
|
|
2477
|
+
this.logger = logger;
|
|
2478
|
+
}
|
|
2479
|
+
async baseConfig(profile) {
|
|
2480
|
+
const credentialProvider = await this.credentialChainBuilder({
|
|
2481
|
+
profile,
|
|
2482
|
+
logger: this.logger
|
|
2483
|
+
});
|
|
2484
|
+
const defaultRegion = await this.region(profile);
|
|
2485
|
+
return { credentialProvider, defaultRegion };
|
|
2473
2486
|
}
|
|
2474
2487
|
/**
|
|
2475
2488
|
* Build an AWS CLI-compatible credential chain provider
|
|
@@ -2478,7 +2491,7 @@ var AwsCliCompatible = class {
|
|
|
2478
2491
|
*/
|
|
2479
2492
|
async credentialChainBuilder(options = {}) {
|
|
2480
2493
|
const clientConfig = {
|
|
2481
|
-
requestHandler:
|
|
2494
|
+
requestHandler: this.requestHandler,
|
|
2482
2495
|
customUserAgent: "aws-cdk",
|
|
2483
2496
|
logger: options.logger
|
|
2484
2497
|
};
|
|
@@ -2506,15 +2519,6 @@ var AwsCliCompatible = class {
|
|
|
2506
2519
|
});
|
|
2507
2520
|
return shouldPrioritizeEnv() ? (0, import_credential_providers.createCredentialChain)((0, import_credential_providers.fromEnv)(), nodeProviderChain).expireAfter(60 * 6e4) : nodeProviderChain;
|
|
2508
2521
|
}
|
|
2509
|
-
async requestHandlerBuilder(options = {}) {
|
|
2510
|
-
const agent = await new ProxyAgentProvider(this.ioHelper).create(options);
|
|
2511
|
-
return {
|
|
2512
|
-
connectionTimeout: DEFAULT_CONNECTION_TIMEOUT,
|
|
2513
|
-
requestTimeout: DEFAULT_TIMEOUT,
|
|
2514
|
-
httpsAgent: agent,
|
|
2515
|
-
httpAgent: agent
|
|
2516
|
-
};
|
|
2517
|
-
}
|
|
2518
2522
|
/**
|
|
2519
2523
|
* Attempts to get the region from a number of sources and falls back to us-east-1 if no region can be found,
|
|
2520
2524
|
* as is done in the AWS CLI.
|
|
@@ -2614,17 +2618,24 @@ function shouldPrioritizeEnv() {
|
|
|
2614
2618
|
}
|
|
2615
2619
|
return false;
|
|
2616
2620
|
}
|
|
2621
|
+
async function makeRequestHandler(ioHelper, options = {}) {
|
|
2622
|
+
const agent = await new ProxyAgentProvider(ioHelper).create(options);
|
|
2623
|
+
return {
|
|
2624
|
+
connectionTimeout: DEFAULT_CONNECTION_TIMEOUT,
|
|
2625
|
+
requestTimeout: DEFAULT_TIMEOUT,
|
|
2626
|
+
httpsAgent: agent,
|
|
2627
|
+
httpAgent: agent
|
|
2628
|
+
};
|
|
2629
|
+
}
|
|
2617
2630
|
|
|
2618
2631
|
// ../tmp-toolkit-helpers/src/api/aws-auth/credential-plugins.ts
|
|
2619
2632
|
var import_util9 = require("util");
|
|
2620
2633
|
var CredentialPlugins = class {
|
|
2621
|
-
cache = {};
|
|
2622
|
-
host;
|
|
2623
|
-
ioHelper;
|
|
2624
2634
|
constructor(host, ioHelper) {
|
|
2625
2635
|
this.host = host;
|
|
2626
2636
|
this.ioHelper = ioHelper;
|
|
2627
2637
|
}
|
|
2638
|
+
cache = {};
|
|
2628
2639
|
async fetchCredentialsFor(awsAccountId, mode) {
|
|
2629
2640
|
const key = `${awsAccountId}-${mode}`;
|
|
2630
2641
|
if (!(key in this.cache)) {
|
|
@@ -2731,35 +2742,56 @@ var TESTING = false;
|
|
|
2731
2742
|
function markTesting() {
|
|
2732
2743
|
TESTING = true;
|
|
2733
2744
|
}
|
|
2734
|
-
var PluginHost = class
|
|
2735
|
-
static instance = new _PluginHost();
|
|
2745
|
+
var PluginHost = class {
|
|
2736
2746
|
/**
|
|
2737
2747
|
* Access the currently registered CredentialProviderSources. New sources can
|
|
2738
2748
|
* be registered using the +registerCredentialProviderSource+ method.
|
|
2739
2749
|
*/
|
|
2740
2750
|
credentialProviderSources = new Array();
|
|
2741
2751
|
contextProviderPlugins = {};
|
|
2742
|
-
|
|
2743
|
-
|
|
2744
|
-
throw new ToolkitError("New instances of PluginHost must not be built. Use PluginHost.instance instead!");
|
|
2745
|
-
}
|
|
2746
|
-
}
|
|
2752
|
+
ioHost;
|
|
2753
|
+
alreadyLoaded = /* @__PURE__ */ new Set();
|
|
2747
2754
|
/**
|
|
2748
2755
|
* Loads a plug-in into this PluginHost.
|
|
2749
2756
|
*
|
|
2757
|
+
* Will use `require.resolve()` to get the most accurate representation of what
|
|
2758
|
+
* code will get loaded in error messages. As such, it will not work in
|
|
2759
|
+
* unit tests with Jest virtual modules becauase of <https://github.com/jestjs/jest/issues/9543>.
|
|
2760
|
+
*
|
|
2750
2761
|
* @param moduleSpec the specification (path or name) of the plug-in module to be loaded.
|
|
2762
|
+
* @param ioHost the I/O host to use for printing progress information
|
|
2763
|
+
*/
|
|
2764
|
+
load(moduleSpec, ioHost) {
|
|
2765
|
+
try {
|
|
2766
|
+
const resolved = require.resolve(moduleSpec);
|
|
2767
|
+
if (ioHost) {
|
|
2768
|
+
new IoDefaultMessages(IoHelper.fromIoHost(ioHost, "init")).debug(`Loading plug-in: ${resolved} from ${moduleSpec}`);
|
|
2769
|
+
}
|
|
2770
|
+
return this._doLoad(resolved);
|
|
2771
|
+
} catch (e) {
|
|
2772
|
+
throw new ToolkitError(`Unable to resolve plug-in: Cannot find module '${moduleSpec}': ${e}`);
|
|
2773
|
+
}
|
|
2774
|
+
}
|
|
2775
|
+
/**
|
|
2776
|
+
* Do the loading given an already-resolved module name
|
|
2777
|
+
*
|
|
2778
|
+
* @internal
|
|
2751
2779
|
*/
|
|
2752
|
-
|
|
2780
|
+
_doLoad(resolved) {
|
|
2753
2781
|
try {
|
|
2754
|
-
|
|
2782
|
+
if (this.alreadyLoaded.has(resolved)) {
|
|
2783
|
+
return;
|
|
2784
|
+
}
|
|
2785
|
+
const plugin = require(resolved);
|
|
2755
2786
|
if (!isPlugin(plugin)) {
|
|
2756
|
-
throw new ToolkitError(`Module ${
|
|
2787
|
+
throw new ToolkitError(`Module ${resolved} is not a valid plug-in, or has an unsupported version.`);
|
|
2757
2788
|
}
|
|
2758
2789
|
if (plugin.init) {
|
|
2759
2790
|
plugin.init(this);
|
|
2760
2791
|
}
|
|
2792
|
+
this.alreadyLoaded.add(resolved);
|
|
2761
2793
|
} catch (e) {
|
|
2762
|
-
throw ToolkitError.withCause(`Unable to load plug-in '${
|
|
2794
|
+
throw ToolkitError.withCause(`Unable to load plug-in '${resolved}'`, e);
|
|
2763
2795
|
}
|
|
2764
2796
|
function isPlugin(x) {
|
|
2765
2797
|
return x != null && x.version === "1";
|
|
@@ -2823,14 +2855,6 @@ var Mode = /* @__PURE__ */ ((Mode2) => {
|
|
|
2823
2855
|
// ../tmp-toolkit-helpers/src/api/aws-auth/sdk-provider.ts
|
|
2824
2856
|
var CACHED_ACCOUNT = Symbol("cached_account");
|
|
2825
2857
|
var SdkProvider = class {
|
|
2826
|
-
constructor(defaultCredentialProvider, defaultRegion, requestHandler = {}, ioHelper, logger) {
|
|
2827
|
-
this.defaultCredentialProvider = defaultCredentialProvider;
|
|
2828
|
-
this.defaultRegion = defaultRegion;
|
|
2829
|
-
this.requestHandler = requestHandler;
|
|
2830
|
-
this.ioHelper = ioHelper;
|
|
2831
|
-
this.logger = logger;
|
|
2832
|
-
this.plugins = new CredentialPlugins(PluginHost.instance, ioHelper);
|
|
2833
|
-
}
|
|
2834
2858
|
/**
|
|
2835
2859
|
* Create a new SdkProvider which gets its defaults in a way that behaves like the AWS CLI does
|
|
2836
2860
|
*
|
|
@@ -2838,18 +2862,24 @@ var SdkProvider = class {
|
|
|
2838
2862
|
* class `AwsCliCompatible` for the details.
|
|
2839
2863
|
*/
|
|
2840
2864
|
static async withAwsCliCompatibleDefaults(options) {
|
|
2841
|
-
const builder = new AwsCliCompatible(options.ioHelper);
|
|
2842
2865
|
callTrace(SdkProvider.withAwsCliCompatibleDefaults.name, SdkProvider.constructor.name, options.logger);
|
|
2843
|
-
const
|
|
2844
|
-
|
|
2845
|
-
httpOptions: options.httpOptions,
|
|
2846
|
-
logger: options.logger
|
|
2847
|
-
});
|
|
2848
|
-
const region = await builder.region(options.profile);
|
|
2849
|
-
const requestHandler = await builder.requestHandlerBuilder(options.httpOptions);
|
|
2850
|
-
return new SdkProvider(credentialProvider, region, requestHandler, options.ioHelper, options.logger);
|
|
2866
|
+
const config = await new AwsCliCompatible(options.ioHelper, options.requestHandler ?? {}, options.logger).baseConfig(options.profile);
|
|
2867
|
+
return new SdkProvider(config.credentialProvider, config.defaultRegion, options);
|
|
2851
2868
|
}
|
|
2869
|
+
defaultRegion;
|
|
2870
|
+
defaultCredentialProvider;
|
|
2852
2871
|
plugins;
|
|
2872
|
+
requestHandler;
|
|
2873
|
+
ioHelper;
|
|
2874
|
+
logger;
|
|
2875
|
+
constructor(defaultCredentialProvider, defaultRegion, services) {
|
|
2876
|
+
this.defaultCredentialProvider = defaultCredentialProvider;
|
|
2877
|
+
this.defaultRegion = defaultRegion ?? "us-east-1";
|
|
2878
|
+
this.requestHandler = services.requestHandler ?? {};
|
|
2879
|
+
this.ioHelper = services.ioHelper;
|
|
2880
|
+
this.logger = services.logger;
|
|
2881
|
+
this.plugins = new CredentialPlugins(services.pluginHost ?? new PluginHost(), this.ioHelper);
|
|
2882
|
+
}
|
|
2853
2883
|
/**
|
|
2854
2884
|
* Return an SDK which can do operations in the given environment
|
|
2855
2885
|
*
|
|
@@ -2865,7 +2895,7 @@ var SdkProvider = class {
|
|
|
2865
2895
|
if (baseCreds.source === "incorrectDefault") {
|
|
2866
2896
|
throw new AuthenticationError(fmtObtainCredentialsError(env.account, baseCreds));
|
|
2867
2897
|
}
|
|
2868
|
-
const sdk =
|
|
2898
|
+
const sdk = this._makeSdk(baseCreds.credentials, env.region);
|
|
2869
2899
|
await sdk.validateCredentials();
|
|
2870
2900
|
return { sdk, didAssumeRole: false };
|
|
2871
2901
|
}
|
|
@@ -2889,7 +2919,7 @@ var SdkProvider = class {
|
|
|
2889
2919
|
`${fmtObtainedCredentials(baseCreds)} could not be used to assume '${options.assumeRoleArn}', but are for the right account. Proceeding anyway.`
|
|
2890
2920
|
));
|
|
2891
2921
|
return {
|
|
2892
|
-
sdk:
|
|
2922
|
+
sdk: this._makeSdk(baseCreds.credentials, env.region),
|
|
2893
2923
|
didAssumeRole: false
|
|
2894
2924
|
};
|
|
2895
2925
|
}
|
|
@@ -2907,7 +2937,7 @@ var SdkProvider = class {
|
|
|
2907
2937
|
if (baseCreds.source === "none") {
|
|
2908
2938
|
return void 0;
|
|
2909
2939
|
}
|
|
2910
|
-
return (await
|
|
2940
|
+
return (await this._makeSdk(baseCreds.credentials, env.region).currentAccount()).partition;
|
|
2911
2941
|
}
|
|
2912
2942
|
/**
|
|
2913
2943
|
* Resolve the environment for a stack
|
|
@@ -2949,7 +2979,7 @@ var SdkProvider = class {
|
|
|
2949
2979
|
async defaultAccount() {
|
|
2950
2980
|
return cached(this, CACHED_ACCOUNT, async () => {
|
|
2951
2981
|
try {
|
|
2952
|
-
return await
|
|
2982
|
+
return await this._makeSdk(this.defaultCredentialProvider, this.defaultRegion).currentAccount();
|
|
2953
2983
|
} catch (e) {
|
|
2954
2984
|
if (e.name === "ExpiredToken") {
|
|
2955
2985
|
await this.ioHelper.notify(IO.DEFAULT_SDK_WARN.msg(
|
|
@@ -3026,7 +3056,7 @@ var SdkProvider = class {
|
|
|
3026
3056
|
logger: this.logger
|
|
3027
3057
|
}));
|
|
3028
3058
|
await credentials();
|
|
3029
|
-
return
|
|
3059
|
+
return this._makeSdk(credentials, region);
|
|
3030
3060
|
} catch (err) {
|
|
3031
3061
|
if (err.name === "ExpiredToken") {
|
|
3032
3062
|
throw err;
|
|
@@ -3042,6 +3072,25 @@ var SdkProvider = class {
|
|
|
3042
3072
|
);
|
|
3043
3073
|
}
|
|
3044
3074
|
}
|
|
3075
|
+
/**
|
|
3076
|
+
* Factory function that creates a new SDK instance
|
|
3077
|
+
*
|
|
3078
|
+
* This is a function here, instead of all the places where this is used creating a `new SDK`
|
|
3079
|
+
* instance, so that it is trivial to mock from tests.
|
|
3080
|
+
*
|
|
3081
|
+
* Use like this:
|
|
3082
|
+
*
|
|
3083
|
+
* ```ts
|
|
3084
|
+
* const mockSdk = jest.spyOn(SdkProvider.prototype, '_makeSdk').mockReturnValue(new MockSdk());
|
|
3085
|
+
* // ...
|
|
3086
|
+
* mockSdk.mockRestore();
|
|
3087
|
+
* ```
|
|
3088
|
+
*
|
|
3089
|
+
* @internal
|
|
3090
|
+
*/
|
|
3091
|
+
_makeSdk(credProvider, region) {
|
|
3092
|
+
return new SDK(credProvider, region, this.requestHandler, this.ioHelper, this.logger);
|
|
3093
|
+
}
|
|
3045
3094
|
};
|
|
3046
3095
|
SdkProvider = __decorateClass([
|
|
3047
3096
|
traceMemberMethods
|
|
@@ -12315,13 +12364,13 @@ var ContextProviderMessages = class {
|
|
|
12315
12364
|
}));
|
|
12316
12365
|
}
|
|
12317
12366
|
};
|
|
12318
|
-
async function provideContextValues(missingValues, context, sdk, ioHelper) {
|
|
12367
|
+
async function provideContextValues(missingValues, context, sdk, pluginHost, ioHelper) {
|
|
12319
12368
|
for (const missingContext of missingValues) {
|
|
12320
12369
|
const key = missingContext.key;
|
|
12321
12370
|
const providerName = missingContext.provider === cxschema4.ContextProvider.PLUGIN ? `${PLUGIN_PROVIDER_PREFIX}:${missingContext.props.pluginName}` : missingContext.provider;
|
|
12322
12371
|
let factory;
|
|
12323
12372
|
if (providerName.startsWith(`${PLUGIN_PROVIDER_PREFIX}:`)) {
|
|
12324
|
-
const plugin =
|
|
12373
|
+
const plugin = pluginHost.contextProviderPlugins[providerName.substring(PLUGIN_PROVIDER_PREFIX.length + 1)];
|
|
12325
12374
|
if (!plugin) {
|
|
12326
12375
|
throw new ContextProviderError(`Unrecognized plugin context provider name: ${missingContext.provider}.`);
|
|
12327
12376
|
}
|
|
@@ -12490,6 +12539,7 @@ var availableContextProviders = {
|
|
|
12490
12539
|
loadTree,
|
|
12491
12540
|
loadTreeFromDir,
|
|
12492
12541
|
makeBodyParameter,
|
|
12542
|
+
makeRequestHandler,
|
|
12493
12543
|
markTesting,
|
|
12494
12544
|
nonHotswappableChange,
|
|
12495
12545
|
nonHotswappableResource,
|