aws-cdk 2.1002.0 → 2.1004.0
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/THIRD_PARTY_LICENSES +2 -9
- package/build-info.json +2 -2
- package/db.json.gz +0 -0
- package/lib/api/aws-auth/account-cache.js +3 -3
- package/lib/api/aws-auth/credential-plugins.js +4 -4
- package/lib/api/aws-auth/sdk-logger.d.ts +3 -3
- package/lib/api/aws-auth/sdk-logger.js +7 -12
- package/lib/api/aws-auth/sdk-provider.js +3 -3
- package/lib/api/aws-auth/sdk.js +3 -3
- package/lib/api/aws-auth/user-agent.js +3 -3
- package/lib/api/bootstrap/bootstrap-environment.d.ts +3 -3
- package/lib/api/bootstrap/bootstrap-environment.js +13 -14
- package/lib/api/bootstrap/bootstrap-template.yaml +14 -1
- package/lib/api/bootstrap/deploy-bootstrap.d.ts +4 -4
- package/lib/api/bootstrap/deploy-bootstrap.js +11 -11
- package/lib/api/cxapp/cloud-assembly.d.ts +1 -16
- package/lib/api/cxapp/cloud-assembly.js +3 -3
- package/lib/api/cxapp/exec.js +3 -3
- package/lib/api/deployments/asset-publishing.d.ts +5 -5
- package/lib/api/deployments/asset-publishing.js +7 -8
- package/lib/api/deployments/assets.d.ts +2 -2
- package/lib/api/deployments/assets.js +9 -9
- package/lib/api/deployments/checks.d.ts +2 -2
- package/lib/api/deployments/checks.js +4 -4
- package/lib/api/deployments/cloudformation.d.ts +7 -7
- package/lib/api/deployments/cloudformation.js +30 -31
- package/lib/api/deployments/deploy-stack.d.ts +3 -5
- package/lib/api/deployments/deploy-stack.js +55 -58
- package/lib/api/deployments/deployments.d.ts +9 -8
- package/lib/api/deployments/deployments.js +27 -31
- package/lib/api/deployments/hotswap-deployments.d.ts +2 -2
- package/lib/api/deployments/hotswap-deployments.js +14 -14
- package/lib/api/deployments/nested-stack-helpers.js +3 -3
- package/lib/api/environment/environment-access.d.ts +3 -4
- package/lib/api/environment/environment-access.js +7 -8
- package/lib/api/environment/environment-resources.d.ts +5 -5
- package/lib/api/environment/environment-resources.js +13 -13
- package/lib/api/garbage-collection/garbage-collector.d.ts +3 -4
- package/lib/api/garbage-collection/garbage-collector.js +37 -38
- package/lib/api/garbage-collection/progress-printer.d.ts +3 -4
- package/lib/api/garbage-collection/progress-printer.js +5 -6
- package/lib/api/garbage-collection/stack-refresh.d.ts +3 -3
- package/lib/api/garbage-collection/stack-refresh.js +7 -7
- package/lib/api/logs/find-cloudwatch-logs.d.ts +2 -2
- package/lib/api/logs/find-cloudwatch-logs.js +6 -6
- package/lib/api/logs/logs-monitor.d.ts +27 -4
- package/lib/api/logs/logs-monitor.js +53 -32
- package/lib/api/resource-import/importer.d.ts +3 -5
- package/lib/api/resource-import/importer.js +12 -13
- package/lib/api/resource-import/migrator.d.ts +3 -5
- package/lib/api/resource-import/migrator.js +8 -10
- package/lib/api/settings.js +2 -2
- package/lib/api/stack-events/stack-activity-monitor.d.ts +5 -63
- package/lib/api/stack-events/stack-activity-monitor.js +7 -8
- package/lib/api/stack-events/stack-event-poller.js +3 -3
- package/lib/api/stack-events/stack-progress-monitor.d.ts +1 -14
- package/lib/api/stack-events/stack-progress-monitor.js +4 -4
- package/lib/api/toolkit-info.d.ts +2 -2
- package/lib/api/toolkit-info.js +5 -5
- package/lib/api/util/placeholders.d.ts +1 -1
- package/lib/api/util/placeholders.js +1 -1
- package/lib/api/util/template-body-parameter.js +4 -5
- package/lib/api/work-graph/work-graph-builder.d.ts +3 -4
- package/lib/api/work-graph/work-graph-builder.js +10 -11
- package/lib/api/work-graph/work-graph.d.ts +3 -8
- package/lib/api/work-graph/work-graph.js +8 -9
- package/lib/cli/activity-printer/base.d.ts +3 -4
- package/lib/cli/activity-printer/base.js +6 -5
- package/lib/cli/activity-printer/current.js +1 -1
- package/lib/cli/activity-printer/history.d.ts +1 -1
- package/lib/cli/activity-printer/history.js +1 -1
- package/lib/cli/cdk-toolkit.d.ts +0 -6
- package/lib/cli/cdk-toolkit.js +30 -40
- package/lib/cli/cli.d.ts +0 -1
- package/lib/cli/cli.js +6 -8
- package/lib/cli/messages.d.ts +11 -9
- package/lib/cli/messages.js +7 -14
- package/lib/cli/root-dir.d.ts +10 -0
- package/lib/cli/root-dir.js +23 -0
- package/lib/cli/version.js +6 -5
- package/lib/commands/migrate.js +3 -3
- package/lib/context-providers/cc-api-provider.js +5 -5
- package/lib/context-providers/index.js +3 -3
- package/lib/index.js +6962 -6363
- package/lib/init-hooks.js +3 -3
- package/lib/init-templates/.init-version.json +1 -1
- package/lib/init.js +8 -9
- package/lib/legacy-exports-source.d.ts +2 -5
- package/lib/legacy-exports-source.js +7 -10
- package/lib/list-stacks.d.ts +1 -2
- package/lib/list-stacks.js +1 -2
- package/lib/logging.d.ts +3 -1
- package/lib/logging.js +2 -1
- package/lib/notices.js +6 -7
- package/lib/toolkit/cli-io-host.d.ts +37 -125
- package/lib/toolkit/cli-io-host.js +44 -74
- package/lib/util.d.ts +1 -0
- package/lib/util.js +18 -0
- package/package.json +8 -15
- package/lib/util/archive.d.ts +0 -1
- package/lib/util/archive.js +0 -86
- package/lib/util/arrays.d.ts +0 -14
- package/lib/util/arrays.js +0 -36
- package/lib/util/bool.d.ts +0 -7
- package/lib/util/bool.js +0 -13
- package/lib/util/bytes.d.ts +0 -8
- package/lib/util/bytes.js +0 -21
- package/lib/util/cloudformation.d.ts +0 -16
- package/lib/util/cloudformation.js +0 -36
- package/lib/util/content-hash.d.ts +0 -5
- package/lib/util/content-hash.js +0 -43
- package/lib/util/directories.d.ts +0 -23
- package/lib/util/directories.js +0 -58
- package/lib/util/format-error.d.ts +0 -9
- package/lib/util/format-error.js +0 -22
- package/lib/util/index.d.ts +0 -15
- package/lib/util/index.js +0 -32
- package/lib/util/json.d.ts +0 -48
- package/lib/util/json.js +0 -68
- package/lib/util/objects.d.ts +0 -52
- package/lib/util/objects.js +0 -183
- package/lib/util/parallel.d.ts +0 -6
- package/lib/util/parallel.js +0 -48
- package/lib/util/serialize.d.ts +0 -27
- package/lib/util/serialize.js +0 -86
- package/lib/util/string-manipulation.d.ts +0 -14
- package/lib/util/string-manipulation.js +0 -39
- package/lib/util/type-brands.d.ts +0 -39
- package/lib/util/type-brands.js +0 -38
- package/lib/util/types.d.ts +0 -27
- package/lib/util/types.js +0 -25
- package/lib/util/version-range.d.ts +0 -2
- package/lib/util/version-range.js +0 -36
- package/lib/util/yaml-cfn.d.ts +0 -15
- package/lib/util/yaml-cfn.js +0 -58
|
@@ -4,7 +4,7 @@ import { type ResourceIdentifierSummaries, ResourcesToImport, Template } from '.
|
|
|
4
4
|
import { DeploymentMethod } from './deployment-method';
|
|
5
5
|
import { DeployStackResult } from './deployment-result';
|
|
6
6
|
import { type RootTemplateWithNestedStacks } from './nested-stack-helpers';
|
|
7
|
-
import {
|
|
7
|
+
import { IoHelper } from '../../../../@aws-cdk/tmp-toolkit-helpers/src/api/io/private';
|
|
8
8
|
import type { SdkProvider } from '../aws-auth/sdk-provider';
|
|
9
9
|
import { EnvironmentAccess } from '../environment';
|
|
10
10
|
import { HotswapMode, HotswapPropertyOverrides } from '../hotswap/common';
|
|
@@ -205,14 +205,17 @@ interface PublishStackAssetsOptions extends AssetOptions {
|
|
|
205
205
|
* Stack name this asset is for
|
|
206
206
|
*/
|
|
207
207
|
readonly stackName?: string;
|
|
208
|
+
/**
|
|
209
|
+
* Always publish, even if it already exists
|
|
210
|
+
*
|
|
211
|
+
* @default false
|
|
212
|
+
*/
|
|
213
|
+
readonly forcePublish?: boolean;
|
|
208
214
|
}
|
|
209
215
|
export interface DestroyStackOptions {
|
|
210
216
|
stack: cxapi.CloudFormationStackArtifact;
|
|
211
217
|
deployName?: string;
|
|
212
218
|
roleArn?: string;
|
|
213
|
-
quiet?: boolean;
|
|
214
|
-
force?: boolean;
|
|
215
|
-
ci?: boolean;
|
|
216
219
|
}
|
|
217
220
|
export interface StackExistsOptions {
|
|
218
221
|
stack: cxapi.CloudFormationStackArtifact;
|
|
@@ -222,8 +225,7 @@ export interface StackExistsOptions {
|
|
|
222
225
|
export interface DeploymentsProps {
|
|
223
226
|
readonly sdkProvider: SdkProvider;
|
|
224
227
|
readonly toolkitStackName?: string;
|
|
225
|
-
readonly
|
|
226
|
-
readonly action: ToolkitAction;
|
|
228
|
+
readonly ioHelper: IoHelper;
|
|
227
229
|
}
|
|
228
230
|
/**
|
|
229
231
|
* Scope for a single set of deployments from a set of Cloud Assembly Artifacts
|
|
@@ -253,8 +255,7 @@ export declare class Deployments {
|
|
|
253
255
|
private readonly deployStackSdkProvider;
|
|
254
256
|
private readonly publisherCache;
|
|
255
257
|
private _allowCrossAccountAssetPublishing;
|
|
256
|
-
private readonly
|
|
257
|
-
private readonly action;
|
|
258
|
+
private readonly ioHelper;
|
|
258
259
|
constructor(props: DeploymentsProps);
|
|
259
260
|
/**
|
|
260
261
|
* Resolves the environment for a stack.
|
|
@@ -12,7 +12,7 @@ const deploy_stack_1 = require("./deploy-stack");
|
|
|
12
12
|
const nested_stack_helpers_1 = require("./nested-stack-helpers");
|
|
13
13
|
const messages_1 = require("../../cli/messages");
|
|
14
14
|
const error_1 = require("../../toolkit/error");
|
|
15
|
-
const
|
|
15
|
+
const util_1 = require("../../util");
|
|
16
16
|
const environment_1 = require("../environment");
|
|
17
17
|
const stack_events_1 = require("../stack-events");
|
|
18
18
|
const toolkit_info_1 = require("../toolkit-info");
|
|
@@ -30,9 +30,8 @@ class Deployments {
|
|
|
30
30
|
this.publisherCache = new Map();
|
|
31
31
|
this.assetSdkProvider = props.sdkProvider;
|
|
32
32
|
this.deployStackSdkProvider = props.sdkProvider;
|
|
33
|
-
this.
|
|
34
|
-
this.
|
|
35
|
-
this.envs = new environment_1.EnvironmentAccess(props.sdkProvider, (_a = props.toolkitStackName) !== null && _a !== void 0 ? _a : toolkit_info_1.DEFAULT_TOOLKIT_STACK_NAME, { ioHost: this.ioHost, action: this.action });
|
|
33
|
+
this.ioHelper = props.ioHelper;
|
|
34
|
+
this.envs = new environment_1.EnvironmentAccess(props.sdkProvider, (_a = props.toolkitStackName) !== null && _a !== void 0 ? _a : toolkit_info_1.DEFAULT_TOOLKIT_STACK_NAME, this.ioHelper);
|
|
36
35
|
}
|
|
37
36
|
/**
|
|
38
37
|
* Resolves the environment for a stack.
|
|
@@ -45,13 +44,13 @@ class Deployments {
|
|
|
45
44
|
return (0, nested_stack_helpers_1.loadCurrentTemplateWithNestedStacks)(rootStackArtifact, env.sdk, retrieveProcessedTemplate);
|
|
46
45
|
}
|
|
47
46
|
async readCurrentTemplate(stackArtifact) {
|
|
48
|
-
await this.
|
|
47
|
+
await this.ioHelper.notify((0, messages_1.debug)(`Reading existing template for stack ${stackArtifact.displayName}.`));
|
|
49
48
|
const env = await this.envs.accessStackForLookupBestEffort(stackArtifact);
|
|
50
49
|
return (0, nested_stack_helpers_1.loadCurrentTemplate)(stackArtifact, env.sdk);
|
|
51
50
|
}
|
|
52
51
|
async resourceIdentifierSummaries(stackArtifact) {
|
|
53
52
|
var _a;
|
|
54
|
-
await this.
|
|
53
|
+
await this.ioHelper.notify((0, messages_1.debug)(`Retrieving template summary for stack ${stackArtifact.displayName}.`));
|
|
55
54
|
// Currently, needs to use `deploy-role` since it may need to read templates in the staging
|
|
56
55
|
// bucket which have been encrypted with a KMS key (and lookup-role may not read encrypted things)
|
|
57
56
|
const env = await this.envs.accessStackForReadOnlyStackOperations(stackArtifact);
|
|
@@ -73,7 +72,7 @@ class Deployments {
|
|
|
73
72
|
}
|
|
74
73
|
const response = await cfn.getTemplateSummary(cfnParam);
|
|
75
74
|
if (!response.ResourceIdentifierSummaries) {
|
|
76
|
-
await this.
|
|
75
|
+
await this.ioHelper.notify((0, messages_1.debug)('GetTemplateSummary API call did not return "ResourceIdentifierSummaries"'));
|
|
77
76
|
}
|
|
78
77
|
return (_a = response.ResourceIdentifierSummaries) !== null && _a !== void 0 ? _a : [];
|
|
79
78
|
}
|
|
@@ -116,7 +115,7 @@ class Deployments {
|
|
|
116
115
|
resourcesToImport: options.resourcesToImport,
|
|
117
116
|
overrideTemplate: options.overrideTemplate,
|
|
118
117
|
assetParallelism: options.assetParallelism,
|
|
119
|
-
},
|
|
118
|
+
}, this.ioHelper);
|
|
120
119
|
}
|
|
121
120
|
async rollbackStack(options) {
|
|
122
121
|
var _a, _b, _c;
|
|
@@ -138,10 +137,10 @@ class Deployments {
|
|
|
138
137
|
const executionRoleArn = await env.replacePlaceholders((_c = options.roleArn) !== null && _c !== void 0 ? _c : options.stack.cloudFormationExecutionRoleArn);
|
|
139
138
|
switch (cloudFormationStack.stackStatus.rollbackChoice) {
|
|
140
139
|
case stack_events_1.RollbackChoice.NONE:
|
|
141
|
-
await this.
|
|
140
|
+
await this.ioHelper.notify((0, messages_1.warn)(`Stack ${deployName} does not need a rollback: ${cloudFormationStack.stackStatus}`));
|
|
142
141
|
return { notInRollbackableState: true };
|
|
143
142
|
case stack_events_1.RollbackChoice.START_ROLLBACK:
|
|
144
|
-
await this.
|
|
143
|
+
await this.ioHelper.notify((0, messages_1.debug)(`Initiating rollback of stack ${deployName}`));
|
|
145
144
|
await cfn.rollbackStack({
|
|
146
145
|
StackName: deployName,
|
|
147
146
|
RoleARN: executionRoleArn,
|
|
@@ -165,7 +164,7 @@ class Deployments {
|
|
|
165
164
|
.map((r) => { var _a; return (_a = r.event.LogicalResourceId) !== null && _a !== void 0 ? _a : ''; });
|
|
166
165
|
}
|
|
167
166
|
const skipDescription = resourcesToSkip.length > 0 ? ` (orphaning: ${resourcesToSkip.join(', ')})` : '';
|
|
168
|
-
await this.
|
|
167
|
+
await this.ioHelper.notify((0, messages_1.warn)(`Continuing rollback of stack ${deployName}${skipDescription}`));
|
|
169
168
|
await cfn.continueUpdateRollback({
|
|
170
169
|
StackName: deployName,
|
|
171
170
|
ClientRequestToken: (0, crypto_1.randomUUID)(),
|
|
@@ -174,7 +173,7 @@ class Deployments {
|
|
|
174
173
|
});
|
|
175
174
|
break;
|
|
176
175
|
case stack_events_1.RollbackChoice.ROLLBACK_FAILED:
|
|
177
|
-
await this.
|
|
176
|
+
await this.ioHelper.notify((0, messages_1.warn)(`Stack ${deployName} failed creation and rollback. This state cannot be rolled back. You can recreate this stack by running 'cdk deploy'.`));
|
|
178
177
|
return { notInRollbackableState: true };
|
|
179
178
|
default:
|
|
180
179
|
throw new error_1.ToolkitError(`Unexpected rollback choice: ${cloudFormationStack.stackStatus.rollbackChoice}`);
|
|
@@ -183,14 +182,13 @@ class Deployments {
|
|
|
183
182
|
cfn,
|
|
184
183
|
stack: options.stack,
|
|
185
184
|
stackName: deployName,
|
|
186
|
-
|
|
187
|
-
action: this.action,
|
|
185
|
+
ioHelper: this.ioHelper,
|
|
188
186
|
});
|
|
189
187
|
await monitor.start();
|
|
190
188
|
let stackErrorMessage = undefined;
|
|
191
189
|
let finalStackState = cloudFormationStack;
|
|
192
190
|
try {
|
|
193
|
-
const successStack = await (0, cloudformation_1.stabilizeStack)(cfn,
|
|
191
|
+
const successStack = await (0, cloudformation_1.stabilizeStack)(cfn, this.ioHelper, deployName);
|
|
194
192
|
// This shouldn't really happen, but catch it anyway. You never know.
|
|
195
193
|
if (!successStack) {
|
|
196
194
|
throw new error_1.ToolkitError('Stack deploy failed (the stack disappeared while we were rolling it back)');
|
|
@@ -202,7 +200,7 @@ class Deployments {
|
|
|
202
200
|
}
|
|
203
201
|
}
|
|
204
202
|
catch (e) {
|
|
205
|
-
stackErrorMessage = suffixWithErrors((0,
|
|
203
|
+
stackErrorMessage = suffixWithErrors((0, util_1.formatErrorMessage)(e), monitor.errors);
|
|
206
204
|
}
|
|
207
205
|
finally {
|
|
208
206
|
await monitor.stop();
|
|
@@ -228,9 +226,7 @@ class Deployments {
|
|
|
228
226
|
roleArn: executionRoleArn,
|
|
229
227
|
stack: options.stack,
|
|
230
228
|
deployName: options.deployName,
|
|
231
|
-
|
|
232
|
-
ci: options.ci,
|
|
233
|
-
}, { ioHost: this.ioHost, action: this.action });
|
|
229
|
+
}, this.ioHelper);
|
|
234
230
|
}
|
|
235
231
|
async stackExists(options) {
|
|
236
232
|
var _a;
|
|
@@ -261,7 +257,7 @@ class Deployments {
|
|
|
261
257
|
const publisher = this.cachedPublisher(assetManifest, resolvedEnvironment, options.stackName);
|
|
262
258
|
await publisher.buildEntry(asset);
|
|
263
259
|
if (publisher.hasFailures) {
|
|
264
|
-
throw new error_1.ToolkitError(`Failed to build asset ${asset.
|
|
260
|
+
throw new error_1.ToolkitError(`Failed to build asset ${asset.displayName(false)}`);
|
|
265
261
|
}
|
|
266
262
|
}
|
|
267
263
|
/**
|
|
@@ -271,18 +267,18 @@ class Deployments {
|
|
|
271
267
|
const stackEnv = await this.envs.resolveStackEnvironment(options.stack);
|
|
272
268
|
// No need to validate anymore, we already did that during build
|
|
273
269
|
const publisher = this.cachedPublisher(assetManifest, stackEnv, options.stackName);
|
|
274
|
-
await publisher.publishEntry(asset, {
|
|
270
|
+
await publisher.publishEntry(asset, {
|
|
271
|
+
allowCrossAccount: await this.allowCrossAccountAssetPublishingForEnv(options.stack),
|
|
272
|
+
force: options.forcePublish,
|
|
273
|
+
});
|
|
275
274
|
if (publisher.hasFailures) {
|
|
276
|
-
throw new error_1.ToolkitError(`Failed to publish asset ${asset.
|
|
275
|
+
throw new error_1.ToolkitError(`Failed to publish asset ${asset.displayName(true)}`);
|
|
277
276
|
}
|
|
278
277
|
}
|
|
279
278
|
async allowCrossAccountAssetPublishingForEnv(stack) {
|
|
280
279
|
if (this._allowCrossAccountAssetPublishing === undefined) {
|
|
281
280
|
const env = await this.envs.accessStackForReadOnlyStackOperations(stack);
|
|
282
|
-
this._allowCrossAccountAssetPublishing = await (0, checks_1.determineAllowCrossAccountAssetPublishing)(env.sdk,
|
|
283
|
-
ioHost: this.ioHost,
|
|
284
|
-
action: this.action,
|
|
285
|
-
}, this.props.toolkitStackName);
|
|
281
|
+
this._allowCrossAccountAssetPublishing = await (0, checks_1.determineAllowCrossAccountAssetPublishing)(env.sdk, this.ioHelper, this.props.toolkitStackName);
|
|
286
282
|
}
|
|
287
283
|
return this._allowCrossAccountAssetPublishing;
|
|
288
284
|
}
|
|
@@ -304,7 +300,7 @@ class Deployments {
|
|
|
304
300
|
await envResources.validateVersion(requiresBootstrapStackVersion, bootstrapStackVersionSsmParameter);
|
|
305
301
|
}
|
|
306
302
|
catch (e) {
|
|
307
|
-
throw new error_1.ToolkitError(`${stackName}: ${(0,
|
|
303
|
+
throw new error_1.ToolkitError(`${stackName}: ${(0, util_1.formatErrorMessage)(e)}`);
|
|
308
304
|
}
|
|
309
305
|
}
|
|
310
306
|
cachedPublisher(assetManifest, env, stackName) {
|
|
@@ -317,7 +313,7 @@ class Deployments {
|
|
|
317
313
|
// The AssetPublishing class takes care of role assuming etc, so it's okay to
|
|
318
314
|
// give it a direct `SdkProvider`.
|
|
319
315
|
aws: new asset_publishing_1.PublishingAws(this.assetSdkProvider, env),
|
|
320
|
-
progressListener: new ParallelSafeAssetProgress(prefix,
|
|
316
|
+
progressListener: new ParallelSafeAssetProgress(prefix, this.ioHelper),
|
|
321
317
|
});
|
|
322
318
|
this.publisherCache.set(assetManifest, publisher);
|
|
323
319
|
return publisher;
|
|
@@ -328,8 +324,8 @@ exports.Deployments = Deployments;
|
|
|
328
324
|
* Asset progress that doesn't do anything with percentages (currently)
|
|
329
325
|
*/
|
|
330
326
|
class ParallelSafeAssetProgress extends asset_publishing_1.BasePublishProgressListener {
|
|
331
|
-
constructor(prefix,
|
|
332
|
-
super(
|
|
327
|
+
constructor(prefix, ioHelper) {
|
|
328
|
+
super(ioHelper);
|
|
333
329
|
this.prefix = prefix;
|
|
334
330
|
}
|
|
335
331
|
getMessage(type, event) {
|
|
@@ -339,4 +335,4 @@ class ParallelSafeAssetProgress extends asset_publishing_1.BasePublishProgressLi
|
|
|
339
335
|
function suffixWithErrors(msg, errors) {
|
|
340
336
|
return errors && errors.length > 0 ? `${msg}: ${errors.join(', ')}` : msg;
|
|
341
337
|
}
|
|
342
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"deployments.js","sourceRoot":"","sources":["deployments.ts"],"names":[],"mappings":"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","sourcesContent":["import { randomUUID } from 'crypto';\nimport * as cxapi from '@aws-cdk/cx-api';\nimport * as cdk_assets from 'cdk-assets';\nimport * as chalk from 'chalk';\nimport { AssetManifestBuilder } from './asset-manifest-builder';\nimport {\n  BasePublishProgressListener,\n  PublishingAws,\n} from './asset-publishing';\nimport { determineAllowCrossAccountAssetPublishing } from './checks';\nimport {\n  CloudFormationStack,\n  type ResourceIdentifierSummaries,\n  ResourcesToImport,\n  stabilizeStack,\n  Template,\n  uploadStackTemplateAssets,\n} from './cloudformation';\nimport { deployStack, destroyStack } from './deploy-stack';\nimport { DeploymentMethod } from './deployment-method';\nimport { DeployStackResult } from './deployment-result';\nimport {\n  loadCurrentTemplate,\n  loadCurrentTemplateWithNestedStacks,\n  type RootTemplateWithNestedStacks,\n} from './nested-stack-helpers';\nimport { debug, warn } from '../../cli/messages';\nimport { IIoHost, IoMessaging, ToolkitAction } from '../../toolkit/cli-io-host';\nimport { ToolkitError } from '../../toolkit/error';\nimport { formatErrorMessage } from '../../util/format-error';\nimport type { SdkProvider } from '../aws-auth/sdk-provider';\nimport { type EnvironmentResources, EnvironmentAccess } from '../environment';\nimport { HotswapMode, HotswapPropertyOverrides } from '../hotswap/common';\nimport { StackActivityMonitor, StackEventPoller, RollbackChoice } from '../stack-events';\nimport type { Tag } from '../tags';\nimport { DEFAULT_TOOLKIT_STACK_NAME } from '../toolkit-info';\nimport { makeBodyParameter } from '../util/template-body-parameter';\n\nconst BOOTSTRAP_STACK_VERSION_FOR_ROLLBACK = 23;\n\nexport interface DeployStackOptions {\n  /**\n   * Stack to deploy\n   */\n  readonly stack: cxapi.CloudFormationStackArtifact;\n\n  /**\n   * Execution role for the deployment (pass through to CloudFormation)\n   *\n   * @default - Current role\n   */\n  readonly roleArn?: string;\n\n  /**\n   * Topic ARNs to send a message when deployment finishes (pass through to CloudFormation)\n   *\n   * @default - No notifications\n   */\n  readonly notificationArns?: string[];\n\n  /**\n   * Override name under which stack will be deployed\n   *\n   * @default - Use artifact default\n   */\n  readonly deployName?: string;\n\n  /**\n   * Name of the toolkit stack, if not the default name\n   *\n   * @default 'CDKToolkit'\n   */\n  readonly toolkitStackName?: string;\n\n  /**\n   * List of asset IDs which should NOT be built or uploaded\n   *\n   * @default - Build all assets\n   */\n  readonly reuseAssets?: string[];\n\n  /**\n   * Stack tags (pass through to CloudFormation)\n   */\n  readonly tags?: Tag[];\n\n  /**\n   * Stage the change set but don't execute it\n   *\n   * @default - true\n   * @deprecated Use 'deploymentMethod' instead\n   */\n  readonly execute?: boolean;\n\n  /**\n   * Optional name to use for the CloudFormation change set.\n   * If not provided, a name will be generated automatically.\n   *\n   * @deprecated Use 'deploymentMethod' instead\n   */\n  readonly changeSetName?: string;\n\n  /**\n   * Select the deployment method (direct or using a change set)\n   *\n   * @default - Change set with default options\n   */\n  readonly deploymentMethod?: DeploymentMethod;\n\n  /**\n   * Force deployment, even if the deployed template is identical to the one we are about to deploy.\n   * @default false deployment will be skipped if the template is identical\n   */\n  readonly force?: boolean;\n\n  /**\n   * Extra parameters for CloudFormation\n   * @default - no additional parameters will be passed to the template\n   */\n  readonly parameters?: { [name: string]: string | undefined };\n\n  /**\n   * Use previous values for unspecified parameters\n   *\n   * If not set, all parameters must be specified for every deployment.\n   *\n   * @default true\n   */\n  readonly usePreviousParameters?: boolean;\n\n  /**\n   * Rollback failed deployments\n   *\n   * @default true\n   */\n  readonly rollback?: boolean;\n\n  /*\n   * Whether to perform a 'hotswap' deployment.\n   * A 'hotswap' deployment will attempt to short-circuit CloudFormation\n   * and update the affected resources like Lambda functions directly.\n   *\n   * @default - `HotswapMode.FULL_DEPLOYMENT` for regular deployments, `HotswapMode.HOTSWAP_ONLY` for 'watch' deployments\n   */\n  readonly hotswap?: HotswapMode;\n\n  /**\n   * Properties that configure hotswap behavior\n   */\n  readonly hotswapPropertyOverrides?: HotswapPropertyOverrides;\n\n  /**\n   * The extra string to append to the User-Agent header when performing AWS SDK calls.\n   *\n   * @default - nothing extra is appended to the User-Agent header\n   */\n  readonly extraUserAgent?: string;\n\n  /**\n   * List of existing resources to be IMPORTED into the stack, instead of being CREATED\n   */\n  readonly resourcesToImport?: ResourcesToImport;\n\n  /**\n   * If present, use this given template instead of the stored one\n   *\n   * @default - Use the stored template\n   */\n  readonly overrideTemplate?: any;\n\n  /**\n   * Whether to build/publish assets in parallel\n   *\n   * @default true To remain backward compatible.\n   */\n  readonly assetParallelism?: boolean;\n\n  /**\n   * Whether to deploy if the app contains no stacks.\n   *\n   * @default false\n   */\n  ignoreNoStacks?: boolean;\n}\n\nexport interface RollbackStackOptions {\n  /**\n   * Stack to roll back\n   */\n  readonly stack: cxapi.CloudFormationStackArtifact;\n\n  /**\n   * Execution role for the deployment (pass through to CloudFormation)\n   *\n   * @default - Current role\n   */\n  readonly roleArn?: string;\n\n  /**\n   * Don't show stack deployment events, just wait\n   *\n   * @default false\n   */\n  readonly quiet?: boolean;\n\n  /**\n   * Whether we are on a CI system\n   *\n   * @default false\n   */\n  readonly ci?: boolean;\n\n  /**\n   * Name of the toolkit stack, if not the default name\n   *\n   * @default 'CDKToolkit'\n   */\n  readonly toolkitStackName?: string;\n\n  /**\n   * Whether to force a rollback or not\n   *\n   * Forcing a rollback will orphan all undeletable resources.\n   *\n   * @default false\n   */\n  readonly force?: boolean;\n\n  /**\n   * Orphan the resources with the given logical IDs\n   *\n   * @default - No orphaning\n   */\n  readonly orphanLogicalIds?: string[];\n\n  /**\n   * Whether to validate the version of the bootstrap stack permissions\n   *\n   * @default true\n   */\n  readonly validateBootstrapStackVersion?: boolean;\n}\n\nexport interface RollbackStackResult {\n  readonly notInRollbackableState?: boolean;\n  readonly success?: boolean;\n}\n\ninterface AssetOptions {\n  /**\n   * Stack with assets to build.\n   */\n  readonly stack: cxapi.CloudFormationStackArtifact;\n\n  /**\n   * Execution role for the building.\n   *\n   * @default - Current role\n   */\n  readonly roleArn?: string;\n}\n\nexport interface BuildStackAssetsOptions extends AssetOptions {\n  /**\n   * Stack name this asset is for\n   */\n  readonly stackName?: string;\n}\n\ninterface PublishStackAssetsOptions extends AssetOptions {\n  /**\n   * Stack name this asset is for\n   */\n  readonly stackName?: string;\n}\n\nexport interface DestroyStackOptions {\n  stack: cxapi.CloudFormationStackArtifact;\n  deployName?: string;\n  roleArn?: string;\n  quiet?: boolean;\n  force?: boolean;\n  ci?: boolean;\n}\n\nexport interface StackExistsOptions {\n  stack: cxapi.CloudFormationStackArtifact;\n  deployName?: string;\n  tryLookupRole?: boolean;\n}\n\nexport interface DeploymentsProps {\n  readonly sdkProvider: SdkProvider;\n  readonly toolkitStackName?: string;\n  readonly ioHost: IIoHost;\n  readonly action: ToolkitAction;\n}\n\n/**\n * Scope for a single set of deployments from a set of Cloud Assembly Artifacts\n *\n * Manages lookup of SDKs, Bootstrap stacks, etc.\n */\nexport class Deployments {\n  public readonly envs: EnvironmentAccess;\n\n  /**\n   * SDK provider for asset publishing (do not use for anything else).\n   *\n   * This SDK provider is only allowed to be used for that purpose, nothing else.\n   *\n   * It's not a different object, but the field name should imply that this\n   * object should not be used directly, except to pass to asset handling routines.\n   */\n  private readonly assetSdkProvider: SdkProvider;\n\n  /**\n   * SDK provider for passing to deployStack\n   *\n   * This SDK provider is only allowed to be used for that purpose, nothing else.\n   *\n   * It's not a different object, but the field name should imply that this\n   * object should not be used directly, except to pass to `deployStack`.\n   */\n  private readonly deployStackSdkProvider: SdkProvider;\n\n  private readonly publisherCache = new Map<cdk_assets.AssetManifest, cdk_assets.AssetPublishing>();\n\n  private _allowCrossAccountAssetPublishing: boolean | undefined;\n\n  private readonly ioHost: IIoHost;\n  private readonly action: ToolkitAction;\n\n  constructor(private readonly props: DeploymentsProps) {\n    this.assetSdkProvider = props.sdkProvider;\n    this.deployStackSdkProvider = props.sdkProvider;\n    this.ioHost = props.ioHost;\n    this.action = props.action;\n    this.envs = new EnvironmentAccess(\n      props.sdkProvider,\n      props.toolkitStackName ?? DEFAULT_TOOLKIT_STACK_NAME,\n      { ioHost: this.ioHost, action: this.action },\n    );\n  }\n\n  /**\n   * Resolves the environment for a stack.\n   */\n  public async resolveEnvironment(stack: cxapi.CloudFormationStackArtifact): Promise<cxapi.Environment> {\n    return this.envs.resolveStackEnvironment(stack);\n  }\n\n  public async readCurrentTemplateWithNestedStacks(\n    rootStackArtifact: cxapi.CloudFormationStackArtifact,\n    retrieveProcessedTemplate: boolean = false,\n  ): Promise<RootTemplateWithNestedStacks> {\n    const env = await this.envs.accessStackForLookupBestEffort(rootStackArtifact);\n    return loadCurrentTemplateWithNestedStacks(rootStackArtifact, env.sdk, retrieveProcessedTemplate);\n  }\n\n  public async readCurrentTemplate(stackArtifact: cxapi.CloudFormationStackArtifact): Promise<Template> {\n    await this.ioHost.notify(debug(this.action, `Reading existing template for stack ${stackArtifact.displayName}.`));\n    const env = await this.envs.accessStackForLookupBestEffort(stackArtifact);\n    return loadCurrentTemplate(stackArtifact, env.sdk);\n  }\n\n  public async resourceIdentifierSummaries(\n    stackArtifact: cxapi.CloudFormationStackArtifact,\n  ): Promise<ResourceIdentifierSummaries> {\n    await this.ioHost.notify(debug(this.action, `Retrieving template summary for stack ${stackArtifact.displayName}.`));\n    // Currently, needs to use `deploy-role` since it may need to read templates in the staging\n    // bucket which have been encrypted with a KMS key (and lookup-role may not read encrypted things)\n    const env = await this.envs.accessStackForReadOnlyStackOperations(stackArtifact);\n    const cfn = env.sdk.cloudFormation();\n\n    await uploadStackTemplateAssets(stackArtifact, this);\n\n    // Upload the template, if necessary, before passing it to CFN\n    const builder = new AssetManifestBuilder();\n    const cfnParam = await makeBodyParameter(\n      stackArtifact,\n      env.resolvedEnvironment,\n      builder,\n      env.resources);\n\n    // If the `makeBodyParameter` before this added assets, make sure to publish them before\n    // calling the API.\n    const addedAssets = builder.toManifest(stackArtifact.assembly.directory);\n    for (const entry of addedAssets.entries) {\n      await this.buildSingleAsset('no-version-validation', addedAssets, entry, {\n        stack: stackArtifact,\n      });\n      await this.publishSingleAsset(addedAssets, entry, {\n        stack: stackArtifact,\n      });\n    }\n\n    const response = await cfn.getTemplateSummary(cfnParam);\n    if (!response.ResourceIdentifierSummaries) {\n      await this.ioHost.notify(debug(this.action, 'GetTemplateSummary API call did not return \"ResourceIdentifierSummaries\"'));\n    }\n    return response.ResourceIdentifierSummaries ?? [];\n  }\n\n  public async deployStack(options: DeployStackOptions): Promise<DeployStackResult> {\n    let deploymentMethod = options.deploymentMethod;\n    if (options.changeSetName || options.execute !== undefined) {\n      if (deploymentMethod) {\n        throw new ToolkitError(\n          \"You cannot supply both 'deploymentMethod' and 'changeSetName/execute'. Supply one or the other.\",\n        );\n      }\n      deploymentMethod = {\n        method: 'change-set',\n        changeSetName: options.changeSetName,\n        execute: options.execute,\n      };\n    }\n\n    const env = await this.envs.accessStackForMutableStackOperations(options.stack);\n\n    // Do a verification of the bootstrap stack version\n    await this.validateBootstrapStackVersion(\n      options.stack.stackName,\n      options.stack.requiresBootstrapStackVersion,\n      options.stack.bootstrapStackVersionSsmParameter,\n      env.resources);\n\n    const executionRoleArn = await env.replacePlaceholders(options.roleArn ?? options.stack.cloudFormationExecutionRoleArn);\n\n    return deployStack({\n      stack: options.stack,\n      resolvedEnvironment: env.resolvedEnvironment,\n      deployName: options.deployName,\n      notificationArns: options.notificationArns,\n      sdk: env.sdk,\n      sdkProvider: this.deployStackSdkProvider,\n      roleArn: executionRoleArn,\n      reuseAssets: options.reuseAssets,\n      envResources: env.resources,\n      tags: options.tags,\n      deploymentMethod,\n      force: options.force,\n      parameters: options.parameters,\n      usePreviousParameters: options.usePreviousParameters,\n      rollback: options.rollback,\n      hotswap: options.hotswap,\n      hotswapPropertyOverrides: options.hotswapPropertyOverrides,\n      extraUserAgent: options.extraUserAgent,\n      resourcesToImport: options.resourcesToImport,\n      overrideTemplate: options.overrideTemplate,\n      assetParallelism: options.assetParallelism,\n    }, { ioHost: this.ioHost, action: this.action });\n  }\n\n  public async rollbackStack(options: RollbackStackOptions): Promise<RollbackStackResult> {\n    let resourcesToSkip: string[] = options.orphanLogicalIds ?? [];\n    if (options.force && resourcesToSkip.length > 0) {\n      throw new ToolkitError('Cannot combine --force with --orphan');\n    }\n\n    const env = await this.envs.accessStackForMutableStackOperations(options.stack);\n\n    if (options.validateBootstrapStackVersion ?? true) {\n      // Do a verification of the bootstrap stack version\n      await this.validateBootstrapStackVersion(\n        options.stack.stackName,\n        BOOTSTRAP_STACK_VERSION_FOR_ROLLBACK,\n        options.stack.bootstrapStackVersionSsmParameter,\n        env.resources);\n    }\n\n    const cfn = env.sdk.cloudFormation();\n    const deployName = options.stack.stackName;\n\n    // We loop in case of `--force` and the stack ends up in `CONTINUE_UPDATE_ROLLBACK`.\n    let maxLoops = 10;\n    while (maxLoops--) {\n      let cloudFormationStack = await CloudFormationStack.lookup(cfn, deployName);\n\n      const executionRoleArn = await env.replacePlaceholders(options.roleArn ?? options.stack.cloudFormationExecutionRoleArn);\n\n      switch (cloudFormationStack.stackStatus.rollbackChoice) {\n        case RollbackChoice.NONE:\n          await this.ioHost.notify(warn(this.action, `Stack ${deployName} does not need a rollback: ${cloudFormationStack.stackStatus}`));\n          return { notInRollbackableState: true };\n\n        case RollbackChoice.START_ROLLBACK:\n          await this.ioHost.notify(debug(this.action, `Initiating rollback of stack ${deployName}`));\n          await cfn.rollbackStack({\n            StackName: deployName,\n            RoleARN: executionRoleArn,\n            ClientRequestToken: randomUUID(),\n            // Enabling this is just the better overall default, the only reason it isn't the upstream default is backwards compatibility\n            RetainExceptOnCreate: true,\n          });\n          break;\n\n        case RollbackChoice.CONTINUE_UPDATE_ROLLBACK:\n          if (options.force) {\n            // Find the failed resources from the deployment and automatically skip them\n            // (Using deployment log because we definitely have `DescribeStackEvents` permissions, and we might not have\n            // `DescribeStackResources` permissions).\n            const poller = new StackEventPoller(cfn, {\n              stackName: deployName,\n              stackStatuses: ['ROLLBACK_IN_PROGRESS', 'UPDATE_ROLLBACK_IN_PROGRESS'],\n            });\n            await poller.poll();\n            resourcesToSkip = poller.resourceErrors\n              .filter((r) => !r.isStackEvent && r.parentStackLogicalIds.length === 0)\n              .map((r) => r.event.LogicalResourceId ?? '');\n          }\n\n          const skipDescription = resourcesToSkip.length > 0 ? ` (orphaning: ${resourcesToSkip.join(', ')})` : '';\n          await this.ioHost.notify(warn(this.action, `Continuing rollback of stack ${deployName}${skipDescription}`));\n          await cfn.continueUpdateRollback({\n            StackName: deployName,\n            ClientRequestToken: randomUUID(),\n            RoleARN: executionRoleArn,\n            ResourcesToSkip: resourcesToSkip,\n          });\n          break;\n\n        case RollbackChoice.ROLLBACK_FAILED:\n          await this.ioHost.notify(warn(\n            this.action,\n            `Stack ${deployName} failed creation and rollback. This state cannot be rolled back. You can recreate this stack by running 'cdk deploy'.`,\n          ));\n          return { notInRollbackableState: true };\n\n        default:\n          throw new ToolkitError(`Unexpected rollback choice: ${cloudFormationStack.stackStatus.rollbackChoice}`);\n      }\n\n      const monitor = new StackActivityMonitor({\n        cfn,\n        stack: options.stack,\n        stackName: deployName,\n        ioHost: this.ioHost,\n        action: this.action,\n      });\n      await monitor.start();\n\n      let stackErrorMessage: string | undefined = undefined;\n      let finalStackState = cloudFormationStack;\n      try {\n        const successStack = await stabilizeStack(cfn, { ioHost: this.ioHost, action: this.action }, deployName);\n\n        // This shouldn't really happen, but catch it anyway. You never know.\n        if (!successStack) {\n          throw new ToolkitError('Stack deploy failed (the stack disappeared while we were rolling it back)');\n        }\n        finalStackState = successStack;\n\n        const errors = monitor.errors.join(', ');\n        if (errors) {\n          stackErrorMessage = errors;\n        }\n      } catch (e: any) {\n        stackErrorMessage = suffixWithErrors(formatErrorMessage(e), monitor.errors);\n      } finally {\n        await monitor.stop();\n      }\n\n      if (finalStackState.stackStatus.isRollbackSuccess || !stackErrorMessage) {\n        return { success: true };\n      }\n\n      // Either we need to ignore some resources to continue the rollback, or something went wrong\n      if (finalStackState.stackStatus.rollbackChoice === RollbackChoice.CONTINUE_UPDATE_ROLLBACK && options.force) {\n        // Do another loop-de-loop\n        continue;\n      }\n\n      throw new ToolkitError(\n        `${stackErrorMessage} (fix problem and retry, or orphan these resources using --orphan or --force)`,\n      );\n    }\n    throw new ToolkitError(\n      \"Rollback did not finish after a large number of iterations; stopping because it looks like we're not making progress anymore. You can retry if rollback was progressing as expected.\",\n    );\n  }\n\n  public async destroyStack(options: DestroyStackOptions): Promise<void> {\n    const env = await this.envs.accessStackForMutableStackOperations(options.stack);\n    const executionRoleArn = await env.replacePlaceholders(options.roleArn ?? options.stack.cloudFormationExecutionRoleArn);\n\n    return destroyStack({\n      sdk: env.sdk,\n      roleArn: executionRoleArn,\n      stack: options.stack,\n      deployName: options.deployName,\n      quiet: options.quiet,\n      ci: options.ci,\n    }, { ioHost: this.ioHost, action: this.action });\n  }\n\n  public async stackExists(options: StackExistsOptions): Promise<boolean> {\n    let env;\n    if (options.tryLookupRole) {\n      env = await this.envs.accessStackForLookupBestEffort(options.stack);\n    } else {\n      env = await this.envs.accessStackForReadOnlyStackOperations(options.stack);\n    }\n    const stack = await CloudFormationStack.lookup(env.sdk.cloudFormation(), options.deployName ?? options.stack.stackName);\n    return stack.exists;\n  }\n\n  /**\n   * Build a single asset from an asset manifest\n   *\n   * If an assert manifest artifact is given, the bootstrap stack version\n   * will be validated according to the constraints in that manifest artifact.\n   * If that is not necessary, `'no-version-validation'` can be passed.\n   */\n  // eslint-disable-next-line max-len\n  public async buildSingleAsset(\n    assetArtifact: cxapi.AssetManifestArtifact | 'no-version-validation',\n    assetManifest: cdk_assets.AssetManifest,\n    asset: cdk_assets.IManifestEntry,\n    options: BuildStackAssetsOptions,\n  ) {\n    if (assetArtifact !== 'no-version-validation') {\n      const env = await this.envs.accessStackForReadOnlyStackOperations(options.stack);\n      await this.validateBootstrapStackVersion(\n        options.stack.stackName,\n        assetArtifact.requiresBootstrapStackVersion,\n        assetArtifact.bootstrapStackVersionSsmParameter,\n        env.resources);\n    }\n\n    const resolvedEnvironment = await this.envs.resolveStackEnvironment(options.stack);\n\n    const publisher = this.cachedPublisher(assetManifest, resolvedEnvironment, options.stackName);\n    await publisher.buildEntry(asset);\n    if (publisher.hasFailures) {\n      throw new ToolkitError(`Failed to build asset ${asset.id}`);\n    }\n  }\n\n  /**\n   * Publish a single asset from an asset manifest\n   */\n  public async publishSingleAsset(\n    assetManifest: cdk_assets.AssetManifest,\n    asset: cdk_assets.IManifestEntry,\n    options: PublishStackAssetsOptions,\n  ) {\n    const stackEnv = await this.envs.resolveStackEnvironment(options.stack);\n\n    // No need to validate anymore, we already did that during build\n    const publisher = this.cachedPublisher(assetManifest, stackEnv, options.stackName);\n    await publisher.publishEntry(asset, { allowCrossAccount: await this.allowCrossAccountAssetPublishingForEnv(options.stack) });\n    if (publisher.hasFailures) {\n      throw new ToolkitError(`Failed to publish asset ${asset.id}`);\n    }\n  }\n\n  private async allowCrossAccountAssetPublishingForEnv(stack: cxapi.CloudFormationStackArtifact): Promise<boolean> {\n    if (this._allowCrossAccountAssetPublishing === undefined) {\n      const env = await this.envs.accessStackForReadOnlyStackOperations(stack);\n      this._allowCrossAccountAssetPublishing = await determineAllowCrossAccountAssetPublishing(env.sdk, {\n        ioHost: this.ioHost,\n        action: this.action,\n      }, this.props.toolkitStackName);\n    }\n    return this._allowCrossAccountAssetPublishing;\n  }\n\n  /**\n   * Return whether a single asset has been published already\n   */\n  public async isSingleAssetPublished(\n    assetManifest: cdk_assets.AssetManifest,\n    asset: cdk_assets.IManifestEntry,\n    options: PublishStackAssetsOptions,\n  ) {\n    const stackEnv = await this.envs.resolveStackEnvironment(options.stack);\n    const publisher = this.cachedPublisher(assetManifest, stackEnv, options.stackName);\n    return publisher.isEntryPublished(asset);\n  }\n\n  /**\n   * Validate that the bootstrap stack has the right version for this stack\n   *\n   * Call into envResources.validateVersion, but prepend the stack name in case of failure.\n   */\n  private async validateBootstrapStackVersion(\n    stackName: string,\n    requiresBootstrapStackVersion: number | undefined,\n    bootstrapStackVersionSsmParameter: string | undefined,\n    envResources: EnvironmentResources,\n  ) {\n    try {\n      await envResources.validateVersion(requiresBootstrapStackVersion, bootstrapStackVersionSsmParameter);\n    } catch (e: any) {\n      throw new ToolkitError(`${stackName}: ${formatErrorMessage(e)}`);\n    }\n  }\n\n  private cachedPublisher(assetManifest: cdk_assets.AssetManifest, env: cxapi.Environment, stackName?: string) {\n    const existing = this.publisherCache.get(assetManifest);\n    if (existing) {\n      return existing;\n    }\n    const prefix = stackName ? `${chalk.bold(stackName)}: ` : '';\n    const publisher = new cdk_assets.AssetPublishing(assetManifest, {\n      // The AssetPublishing class takes care of role assuming etc, so it's okay to\n      // give it a direct `SdkProvider`.\n      aws: new PublishingAws(this.assetSdkProvider, env),\n      progressListener: new ParallelSafeAssetProgress(prefix, { ioHost: this.ioHost, action: this.action }),\n    });\n    this.publisherCache.set(assetManifest, publisher);\n    return publisher;\n  }\n}\n\n/**\n * Asset progress that doesn't do anything with percentages (currently)\n */\nclass ParallelSafeAssetProgress extends BasePublishProgressListener {\n  private readonly prefix: string;\n\n  constructor(prefix: string, { ioHost, action }: IoMessaging) {\n    super({ ioHost, action });\n    this.prefix = prefix;\n  }\n\n  protected getMessage(type: cdk_assets.EventType, event: cdk_assets.IPublishProgress): string {\n    return `${this.prefix}${type}: ${event.message}`;\n  }\n}\n\nfunction suffixWithErrors(msg: string, errors?: string[]) {\n  return errors && errors.length > 0 ? `${msg}: ${errors.join(', ')}` : msg;\n}\n"]}
|
|
338
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"deployments.js","sourceRoot":"","sources":["deployments.ts"],"names":[],"mappings":"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","sourcesContent":["import { randomUUID } from 'crypto';\nimport * as cxapi from '@aws-cdk/cx-api';\nimport * as cdk_assets from 'cdk-assets';\nimport * as chalk from 'chalk';\nimport { AssetManifestBuilder } from './asset-manifest-builder';\nimport {\n  BasePublishProgressListener,\n  PublishingAws,\n} from './asset-publishing';\nimport { determineAllowCrossAccountAssetPublishing } from './checks';\nimport {\n  CloudFormationStack,\n  type ResourceIdentifierSummaries,\n  ResourcesToImport,\n  stabilizeStack,\n  Template,\n  uploadStackTemplateAssets,\n} from './cloudformation';\nimport { deployStack, destroyStack } from './deploy-stack';\nimport { DeploymentMethod } from './deployment-method';\nimport { DeployStackResult } from './deployment-result';\nimport {\n  loadCurrentTemplate,\n  loadCurrentTemplateWithNestedStacks,\n  type RootTemplateWithNestedStacks,\n} from './nested-stack-helpers';\nimport { IoHelper } from '../../../../@aws-cdk/tmp-toolkit-helpers/src/api/io/private';\nimport { debug, warn } from '../../cli/messages';\nimport { ToolkitError } from '../../toolkit/error';\nimport { formatErrorMessage } from '../../util';\nimport type { SdkProvider } from '../aws-auth/sdk-provider';\nimport { type EnvironmentResources, EnvironmentAccess } from '../environment';\nimport { HotswapMode, HotswapPropertyOverrides } from '../hotswap/common';\nimport { StackActivityMonitor, StackEventPoller, RollbackChoice } from '../stack-events';\nimport type { Tag } from '../tags';\nimport { DEFAULT_TOOLKIT_STACK_NAME } from '../toolkit-info';\nimport { makeBodyParameter } from '../util/template-body-parameter';\n\nconst BOOTSTRAP_STACK_VERSION_FOR_ROLLBACK = 23;\n\nexport interface DeployStackOptions {\n  /**\n   * Stack to deploy\n   */\n  readonly stack: cxapi.CloudFormationStackArtifact;\n\n  /**\n   * Execution role for the deployment (pass through to CloudFormation)\n   *\n   * @default - Current role\n   */\n  readonly roleArn?: string;\n\n  /**\n   * Topic ARNs to send a message when deployment finishes (pass through to CloudFormation)\n   *\n   * @default - No notifications\n   */\n  readonly notificationArns?: string[];\n\n  /**\n   * Override name under which stack will be deployed\n   *\n   * @default - Use artifact default\n   */\n  readonly deployName?: string;\n\n  /**\n   * Name of the toolkit stack, if not the default name\n   *\n   * @default 'CDKToolkit'\n   */\n  readonly toolkitStackName?: string;\n\n  /**\n   * List of asset IDs which should NOT be built or uploaded\n   *\n   * @default - Build all assets\n   */\n  readonly reuseAssets?: string[];\n\n  /**\n   * Stack tags (pass through to CloudFormation)\n   */\n  readonly tags?: Tag[];\n\n  /**\n   * Stage the change set but don't execute it\n   *\n   * @default - true\n   * @deprecated Use 'deploymentMethod' instead\n   */\n  readonly execute?: boolean;\n\n  /**\n   * Optional name to use for the CloudFormation change set.\n   * If not provided, a name will be generated automatically.\n   *\n   * @deprecated Use 'deploymentMethod' instead\n   */\n  readonly changeSetName?: string;\n\n  /**\n   * Select the deployment method (direct or using a change set)\n   *\n   * @default - Change set with default options\n   */\n  readonly deploymentMethod?: DeploymentMethod;\n\n  /**\n   * Force deployment, even if the deployed template is identical to the one we are about to deploy.\n   * @default false deployment will be skipped if the template is identical\n   */\n  readonly force?: boolean;\n\n  /**\n   * Extra parameters for CloudFormation\n   * @default - no additional parameters will be passed to the template\n   */\n  readonly parameters?: { [name: string]: string | undefined };\n\n  /**\n   * Use previous values for unspecified parameters\n   *\n   * If not set, all parameters must be specified for every deployment.\n   *\n   * @default true\n   */\n  readonly usePreviousParameters?: boolean;\n\n  /**\n   * Rollback failed deployments\n   *\n   * @default true\n   */\n  readonly rollback?: boolean;\n\n  /*\n   * Whether to perform a 'hotswap' deployment.\n   * A 'hotswap' deployment will attempt to short-circuit CloudFormation\n   * and update the affected resources like Lambda functions directly.\n   *\n   * @default - `HotswapMode.FULL_DEPLOYMENT` for regular deployments, `HotswapMode.HOTSWAP_ONLY` for 'watch' deployments\n   */\n  readonly hotswap?: HotswapMode;\n\n  /**\n   * Properties that configure hotswap behavior\n   */\n  readonly hotswapPropertyOverrides?: HotswapPropertyOverrides;\n\n  /**\n   * The extra string to append to the User-Agent header when performing AWS SDK calls.\n   *\n   * @default - nothing extra is appended to the User-Agent header\n   */\n  readonly extraUserAgent?: string;\n\n  /**\n   * List of existing resources to be IMPORTED into the stack, instead of being CREATED\n   */\n  readonly resourcesToImport?: ResourcesToImport;\n\n  /**\n   * If present, use this given template instead of the stored one\n   *\n   * @default - Use the stored template\n   */\n  readonly overrideTemplate?: any;\n\n  /**\n   * Whether to build/publish assets in parallel\n   *\n   * @default true To remain backward compatible.\n   */\n  readonly assetParallelism?: boolean;\n\n  /**\n   * Whether to deploy if the app contains no stacks.\n   *\n   * @default false\n   */\n  ignoreNoStacks?: boolean;\n}\n\nexport interface RollbackStackOptions {\n  /**\n   * Stack to roll back\n   */\n  readonly stack: cxapi.CloudFormationStackArtifact;\n\n  /**\n   * Execution role for the deployment (pass through to CloudFormation)\n   *\n   * @default - Current role\n   */\n  readonly roleArn?: string;\n\n  /**\n   * Don't show stack deployment events, just wait\n   *\n   * @default false\n   */\n  readonly quiet?: boolean;\n\n  /**\n   * Whether we are on a CI system\n   *\n   * @default false\n   */\n  readonly ci?: boolean;\n\n  /**\n   * Name of the toolkit stack, if not the default name\n   *\n   * @default 'CDKToolkit'\n   */\n  readonly toolkitStackName?: string;\n\n  /**\n   * Whether to force a rollback or not\n   *\n   * Forcing a rollback will orphan all undeletable resources.\n   *\n   * @default false\n   */\n  readonly force?: boolean;\n\n  /**\n   * Orphan the resources with the given logical IDs\n   *\n   * @default - No orphaning\n   */\n  readonly orphanLogicalIds?: string[];\n\n  /**\n   * Whether to validate the version of the bootstrap stack permissions\n   *\n   * @default true\n   */\n  readonly validateBootstrapStackVersion?: boolean;\n}\n\nexport interface RollbackStackResult {\n  readonly notInRollbackableState?: boolean;\n  readonly success?: boolean;\n}\n\ninterface AssetOptions {\n  /**\n   * Stack with assets to build.\n   */\n  readonly stack: cxapi.CloudFormationStackArtifact;\n\n  /**\n   * Execution role for the building.\n   *\n   * @default - Current role\n   */\n  readonly roleArn?: string;\n}\n\nexport interface BuildStackAssetsOptions extends AssetOptions {\n  /**\n   * Stack name this asset is for\n   */\n  readonly stackName?: string;\n}\n\ninterface PublishStackAssetsOptions extends AssetOptions {\n  /**\n   * Stack name this asset is for\n   */\n  readonly stackName?: string;\n\n  /**\n   * Always publish, even if it already exists\n   *\n   * @default false\n   */\n  readonly forcePublish?: boolean;\n}\n\nexport interface DestroyStackOptions {\n  stack: cxapi.CloudFormationStackArtifact;\n  deployName?: string;\n  roleArn?: string;\n}\n\nexport interface StackExistsOptions {\n  stack: cxapi.CloudFormationStackArtifact;\n  deployName?: string;\n  tryLookupRole?: boolean;\n}\n\nexport interface DeploymentsProps {\n  readonly sdkProvider: SdkProvider;\n  readonly toolkitStackName?: string;\n  readonly ioHelper: IoHelper;\n}\n\n/**\n * Scope for a single set of deployments from a set of Cloud Assembly Artifacts\n *\n * Manages lookup of SDKs, Bootstrap stacks, etc.\n */\nexport class Deployments {\n  public readonly envs: EnvironmentAccess;\n\n  /**\n   * SDK provider for asset publishing (do not use for anything else).\n   *\n   * This SDK provider is only allowed to be used for that purpose, nothing else.\n   *\n   * It's not a different object, but the field name should imply that this\n   * object should not be used directly, except to pass to asset handling routines.\n   */\n  private readonly assetSdkProvider: SdkProvider;\n\n  /**\n   * SDK provider for passing to deployStack\n   *\n   * This SDK provider is only allowed to be used for that purpose, nothing else.\n   *\n   * It's not a different object, but the field name should imply that this\n   * object should not be used directly, except to pass to `deployStack`.\n   */\n  private readonly deployStackSdkProvider: SdkProvider;\n\n  private readonly publisherCache = new Map<cdk_assets.AssetManifest, cdk_assets.AssetPublishing>();\n\n  private _allowCrossAccountAssetPublishing: boolean | undefined;\n\n  private readonly ioHelper: IoHelper;\n\n  constructor(private readonly props: DeploymentsProps) {\n    this.assetSdkProvider = props.sdkProvider;\n    this.deployStackSdkProvider = props.sdkProvider;\n    this.ioHelper = props.ioHelper;\n    this.envs = new EnvironmentAccess(\n      props.sdkProvider,\n      props.toolkitStackName ?? DEFAULT_TOOLKIT_STACK_NAME,\n      this.ioHelper,\n    );\n  }\n\n  /**\n   * Resolves the environment for a stack.\n   */\n  public async resolveEnvironment(stack: cxapi.CloudFormationStackArtifact): Promise<cxapi.Environment> {\n    return this.envs.resolveStackEnvironment(stack);\n  }\n\n  public async readCurrentTemplateWithNestedStacks(\n    rootStackArtifact: cxapi.CloudFormationStackArtifact,\n    retrieveProcessedTemplate: boolean = false,\n  ): Promise<RootTemplateWithNestedStacks> {\n    const env = await this.envs.accessStackForLookupBestEffort(rootStackArtifact);\n    return loadCurrentTemplateWithNestedStacks(rootStackArtifact, env.sdk, retrieveProcessedTemplate);\n  }\n\n  public async readCurrentTemplate(stackArtifact: cxapi.CloudFormationStackArtifact): Promise<Template> {\n    await this.ioHelper.notify(debug(`Reading existing template for stack ${stackArtifact.displayName}.`));\n    const env = await this.envs.accessStackForLookupBestEffort(stackArtifact);\n    return loadCurrentTemplate(stackArtifact, env.sdk);\n  }\n\n  public async resourceIdentifierSummaries(\n    stackArtifact: cxapi.CloudFormationStackArtifact,\n  ): Promise<ResourceIdentifierSummaries> {\n    await this.ioHelper.notify(debug(`Retrieving template summary for stack ${stackArtifact.displayName}.`));\n    // Currently, needs to use `deploy-role` since it may need to read templates in the staging\n    // bucket which have been encrypted with a KMS key (and lookup-role may not read encrypted things)\n    const env = await this.envs.accessStackForReadOnlyStackOperations(stackArtifact);\n    const cfn = env.sdk.cloudFormation();\n\n    await uploadStackTemplateAssets(stackArtifact, this);\n\n    // Upload the template, if necessary, before passing it to CFN\n    const builder = new AssetManifestBuilder();\n    const cfnParam = await makeBodyParameter(\n      stackArtifact,\n      env.resolvedEnvironment,\n      builder,\n      env.resources);\n\n    // If the `makeBodyParameter` before this added assets, make sure to publish them before\n    // calling the API.\n    const addedAssets = builder.toManifest(stackArtifact.assembly.directory);\n    for (const entry of addedAssets.entries) {\n      await this.buildSingleAsset('no-version-validation', addedAssets, entry, {\n        stack: stackArtifact,\n      });\n      await this.publishSingleAsset(addedAssets, entry, {\n        stack: stackArtifact,\n      });\n    }\n\n    const response = await cfn.getTemplateSummary(cfnParam);\n    if (!response.ResourceIdentifierSummaries) {\n      await this.ioHelper.notify(debug('GetTemplateSummary API call did not return \"ResourceIdentifierSummaries\"'));\n    }\n    return response.ResourceIdentifierSummaries ?? [];\n  }\n\n  public async deployStack(options: DeployStackOptions): Promise<DeployStackResult> {\n    let deploymentMethod = options.deploymentMethod;\n    if (options.changeSetName || options.execute !== undefined) {\n      if (deploymentMethod) {\n        throw new ToolkitError(\n          \"You cannot supply both 'deploymentMethod' and 'changeSetName/execute'. Supply one or the other.\",\n        );\n      }\n      deploymentMethod = {\n        method: 'change-set',\n        changeSetName: options.changeSetName,\n        execute: options.execute,\n      };\n    }\n\n    const env = await this.envs.accessStackForMutableStackOperations(options.stack);\n\n    // Do a verification of the bootstrap stack version\n    await this.validateBootstrapStackVersion(\n      options.stack.stackName,\n      options.stack.requiresBootstrapStackVersion,\n      options.stack.bootstrapStackVersionSsmParameter,\n      env.resources);\n\n    const executionRoleArn = await env.replacePlaceholders(options.roleArn ?? options.stack.cloudFormationExecutionRoleArn);\n\n    return deployStack({\n      stack: options.stack,\n      resolvedEnvironment: env.resolvedEnvironment,\n      deployName: options.deployName,\n      notificationArns: options.notificationArns,\n      sdk: env.sdk,\n      sdkProvider: this.deployStackSdkProvider,\n      roleArn: executionRoleArn,\n      reuseAssets: options.reuseAssets,\n      envResources: env.resources,\n      tags: options.tags,\n      deploymentMethod,\n      force: options.force,\n      parameters: options.parameters,\n      usePreviousParameters: options.usePreviousParameters,\n      rollback: options.rollback,\n      hotswap: options.hotswap,\n      hotswapPropertyOverrides: options.hotswapPropertyOverrides,\n      extraUserAgent: options.extraUserAgent,\n      resourcesToImport: options.resourcesToImport,\n      overrideTemplate: options.overrideTemplate,\n      assetParallelism: options.assetParallelism,\n    }, this.ioHelper);\n  }\n\n  public async rollbackStack(options: RollbackStackOptions): Promise<RollbackStackResult> {\n    let resourcesToSkip: string[] = options.orphanLogicalIds ?? [];\n    if (options.force && resourcesToSkip.length > 0) {\n      throw new ToolkitError('Cannot combine --force with --orphan');\n    }\n\n    const env = await this.envs.accessStackForMutableStackOperations(options.stack);\n\n    if (options.validateBootstrapStackVersion ?? true) {\n      // Do a verification of the bootstrap stack version\n      await this.validateBootstrapStackVersion(\n        options.stack.stackName,\n        BOOTSTRAP_STACK_VERSION_FOR_ROLLBACK,\n        options.stack.bootstrapStackVersionSsmParameter,\n        env.resources);\n    }\n\n    const cfn = env.sdk.cloudFormation();\n    const deployName = options.stack.stackName;\n\n    // We loop in case of `--force` and the stack ends up in `CONTINUE_UPDATE_ROLLBACK`.\n    let maxLoops = 10;\n    while (maxLoops--) {\n      let cloudFormationStack = await CloudFormationStack.lookup(cfn, deployName);\n\n      const executionRoleArn = await env.replacePlaceholders(options.roleArn ?? options.stack.cloudFormationExecutionRoleArn);\n\n      switch (cloudFormationStack.stackStatus.rollbackChoice) {\n        case RollbackChoice.NONE:\n          await this.ioHelper.notify(warn(`Stack ${deployName} does not need a rollback: ${cloudFormationStack.stackStatus}`));\n          return { notInRollbackableState: true };\n\n        case RollbackChoice.START_ROLLBACK:\n          await this.ioHelper.notify(debug(`Initiating rollback of stack ${deployName}`));\n          await cfn.rollbackStack({\n            StackName: deployName,\n            RoleARN: executionRoleArn,\n            ClientRequestToken: randomUUID(),\n            // Enabling this is just the better overall default, the only reason it isn't the upstream default is backwards compatibility\n            RetainExceptOnCreate: true,\n          });\n          break;\n\n        case RollbackChoice.CONTINUE_UPDATE_ROLLBACK:\n          if (options.force) {\n            // Find the failed resources from the deployment and automatically skip them\n            // (Using deployment log because we definitely have `DescribeStackEvents` permissions, and we might not have\n            // `DescribeStackResources` permissions).\n            const poller = new StackEventPoller(cfn, {\n              stackName: deployName,\n              stackStatuses: ['ROLLBACK_IN_PROGRESS', 'UPDATE_ROLLBACK_IN_PROGRESS'],\n            });\n            await poller.poll();\n            resourcesToSkip = poller.resourceErrors\n              .filter((r) => !r.isStackEvent && r.parentStackLogicalIds.length === 0)\n              .map((r) => r.event.LogicalResourceId ?? '');\n          }\n\n          const skipDescription = resourcesToSkip.length > 0 ? ` (orphaning: ${resourcesToSkip.join(', ')})` : '';\n          await this.ioHelper.notify(warn(`Continuing rollback of stack ${deployName}${skipDescription}`));\n          await cfn.continueUpdateRollback({\n            StackName: deployName,\n            ClientRequestToken: randomUUID(),\n            RoleARN: executionRoleArn,\n            ResourcesToSkip: resourcesToSkip,\n          });\n          break;\n\n        case RollbackChoice.ROLLBACK_FAILED:\n          await this.ioHelper.notify(warn(\n            `Stack ${deployName} failed creation and rollback. This state cannot be rolled back. You can recreate this stack by running 'cdk deploy'.`,\n          ));\n          return { notInRollbackableState: true };\n\n        default:\n          throw new ToolkitError(`Unexpected rollback choice: ${cloudFormationStack.stackStatus.rollbackChoice}`);\n      }\n\n      const monitor = new StackActivityMonitor({\n        cfn,\n        stack: options.stack,\n        stackName: deployName,\n        ioHelper: this.ioHelper,\n      });\n      await monitor.start();\n\n      let stackErrorMessage: string | undefined = undefined;\n      let finalStackState = cloudFormationStack;\n      try {\n        const successStack = await stabilizeStack(cfn, this.ioHelper, deployName);\n\n        // This shouldn't really happen, but catch it anyway. You never know.\n        if (!successStack) {\n          throw new ToolkitError('Stack deploy failed (the stack disappeared while we were rolling it back)');\n        }\n        finalStackState = successStack;\n\n        const errors = monitor.errors.join(', ');\n        if (errors) {\n          stackErrorMessage = errors;\n        }\n      } catch (e: any) {\n        stackErrorMessage = suffixWithErrors(formatErrorMessage(e), monitor.errors);\n      } finally {\n        await monitor.stop();\n      }\n\n      if (finalStackState.stackStatus.isRollbackSuccess || !stackErrorMessage) {\n        return { success: true };\n      }\n\n      // Either we need to ignore some resources to continue the rollback, or something went wrong\n      if (finalStackState.stackStatus.rollbackChoice === RollbackChoice.CONTINUE_UPDATE_ROLLBACK && options.force) {\n        // Do another loop-de-loop\n        continue;\n      }\n\n      throw new ToolkitError(\n        `${stackErrorMessage} (fix problem and retry, or orphan these resources using --orphan or --force)`,\n      );\n    }\n    throw new ToolkitError(\n      \"Rollback did not finish after a large number of iterations; stopping because it looks like we're not making progress anymore. You can retry if rollback was progressing as expected.\",\n    );\n  }\n\n  public async destroyStack(options: DestroyStackOptions): Promise<void> {\n    const env = await this.envs.accessStackForMutableStackOperations(options.stack);\n    const executionRoleArn = await env.replacePlaceholders(options.roleArn ?? options.stack.cloudFormationExecutionRoleArn);\n\n    return destroyStack({\n      sdk: env.sdk,\n      roleArn: executionRoleArn,\n      stack: options.stack,\n      deployName: options.deployName,\n    }, this.ioHelper);\n  }\n\n  public async stackExists(options: StackExistsOptions): Promise<boolean> {\n    let env;\n    if (options.tryLookupRole) {\n      env = await this.envs.accessStackForLookupBestEffort(options.stack);\n    } else {\n      env = await this.envs.accessStackForReadOnlyStackOperations(options.stack);\n    }\n    const stack = await CloudFormationStack.lookup(env.sdk.cloudFormation(), options.deployName ?? options.stack.stackName);\n    return stack.exists;\n  }\n\n  /**\n   * Build a single asset from an asset manifest\n   *\n   * If an assert manifest artifact is given, the bootstrap stack version\n   * will be validated according to the constraints in that manifest artifact.\n   * If that is not necessary, `'no-version-validation'` can be passed.\n   */\n  // eslint-disable-next-line max-len\n  public async buildSingleAsset(\n    assetArtifact: cxapi.AssetManifestArtifact | 'no-version-validation',\n    assetManifest: cdk_assets.AssetManifest,\n    asset: cdk_assets.IManifestEntry,\n    options: BuildStackAssetsOptions,\n  ) {\n    if (assetArtifact !== 'no-version-validation') {\n      const env = await this.envs.accessStackForReadOnlyStackOperations(options.stack);\n      await this.validateBootstrapStackVersion(\n        options.stack.stackName,\n        assetArtifact.requiresBootstrapStackVersion,\n        assetArtifact.bootstrapStackVersionSsmParameter,\n        env.resources);\n    }\n\n    const resolvedEnvironment = await this.envs.resolveStackEnvironment(options.stack);\n\n    const publisher = this.cachedPublisher(assetManifest, resolvedEnvironment, options.stackName);\n    await publisher.buildEntry(asset);\n    if (publisher.hasFailures) {\n      throw new ToolkitError(`Failed to build asset ${asset.displayName(false)}`);\n    }\n  }\n\n  /**\n   * Publish a single asset from an asset manifest\n   */\n  public async publishSingleAsset(\n    assetManifest: cdk_assets.AssetManifest,\n    asset: cdk_assets.IManifestEntry,\n    options: PublishStackAssetsOptions,\n  ) {\n    const stackEnv = await this.envs.resolveStackEnvironment(options.stack);\n\n    // No need to validate anymore, we already did that during build\n    const publisher = this.cachedPublisher(assetManifest, stackEnv, options.stackName);\n    await publisher.publishEntry(asset, {\n      allowCrossAccount: await this.allowCrossAccountAssetPublishingForEnv(options.stack),\n      force: options.forcePublish,\n    });\n    if (publisher.hasFailures) {\n      throw new ToolkitError(`Failed to publish asset ${asset.displayName(true)}`);\n    }\n  }\n\n  private async allowCrossAccountAssetPublishingForEnv(stack: cxapi.CloudFormationStackArtifact): Promise<boolean> {\n    if (this._allowCrossAccountAssetPublishing === undefined) {\n      const env = await this.envs.accessStackForReadOnlyStackOperations(stack);\n      this._allowCrossAccountAssetPublishing = await determineAllowCrossAccountAssetPublishing(env.sdk, this.ioHelper, this.props.toolkitStackName);\n    }\n    return this._allowCrossAccountAssetPublishing;\n  }\n\n  /**\n   * Return whether a single asset has been published already\n   */\n  public async isSingleAssetPublished(\n    assetManifest: cdk_assets.AssetManifest,\n    asset: cdk_assets.IManifestEntry,\n    options: PublishStackAssetsOptions,\n  ) {\n    const stackEnv = await this.envs.resolveStackEnvironment(options.stack);\n    const publisher = this.cachedPublisher(assetManifest, stackEnv, options.stackName);\n    return publisher.isEntryPublished(asset);\n  }\n\n  /**\n   * Validate that the bootstrap stack has the right version for this stack\n   *\n   * Call into envResources.validateVersion, but prepend the stack name in case of failure.\n   */\n  private async validateBootstrapStackVersion(\n    stackName: string,\n    requiresBootstrapStackVersion: number | undefined,\n    bootstrapStackVersionSsmParameter: string | undefined,\n    envResources: EnvironmentResources,\n  ) {\n    try {\n      await envResources.validateVersion(requiresBootstrapStackVersion, bootstrapStackVersionSsmParameter);\n    } catch (e: any) {\n      throw new ToolkitError(`${stackName}: ${formatErrorMessage(e)}`);\n    }\n  }\n\n  private cachedPublisher(assetManifest: cdk_assets.AssetManifest, env: cxapi.Environment, stackName?: string) {\n    const existing = this.publisherCache.get(assetManifest);\n    if (existing) {\n      return existing;\n    }\n    const prefix = stackName ? `${chalk.bold(stackName)}: ` : '';\n    const publisher = new cdk_assets.AssetPublishing(assetManifest, {\n      // The AssetPublishing class takes care of role assuming etc, so it's okay to\n      // give it a direct `SdkProvider`.\n      aws: new PublishingAws(this.assetSdkProvider, env),\n      progressListener: new ParallelSafeAssetProgress(prefix, this.ioHelper),\n    });\n    this.publisherCache.set(assetManifest, publisher);\n    return publisher;\n  }\n}\n\n/**\n * Asset progress that doesn't do anything with percentages (currently)\n */\nclass ParallelSafeAssetProgress extends BasePublishProgressListener {\n  private readonly prefix: string;\n\n  constructor(prefix: string, ioHelper: IoHelper) {\n    super(ioHelper);\n    this.prefix = prefix;\n  }\n\n  protected getMessage(type: cdk_assets.EventType, event: cdk_assets.IPublishProgress): string {\n    return `${this.prefix}${type}: ${event.message}`;\n  }\n}\n\nfunction suffixWithErrors(msg: string, errors?: string[]) {\n  return errors && errors.length > 0 ? `${msg}: ${errors.join(', ')}` : msg;\n}\n"]}
|
|
@@ -3,13 +3,13 @@ import type { SdkProvider } from '../aws-auth';
|
|
|
3
3
|
import type { CloudFormationStack } from './cloudformation';
|
|
4
4
|
import { HotswapMode, HotswapPropertyOverrides } from '../hotswap/common';
|
|
5
5
|
import { SuccessfulDeployStackResult } from './deployment-result';
|
|
6
|
-
import {
|
|
6
|
+
import { IoHelper } from '../../../../@aws-cdk/tmp-toolkit-helpers/src/api/io/private';
|
|
7
7
|
/**
|
|
8
8
|
* Perform a hotswap deployment, short-circuiting CloudFormation if possible.
|
|
9
9
|
* If it's not possible to short-circuit the deployment
|
|
10
10
|
* (because the CDK Stack contains changes that cannot be deployed without CloudFormation),
|
|
11
11
|
* returns `undefined`.
|
|
12
12
|
*/
|
|
13
|
-
export declare function tryHotswapDeployment(sdkProvider: SdkProvider,
|
|
13
|
+
export declare function tryHotswapDeployment(sdkProvider: SdkProvider, ioHelper: IoHelper, assetParams: {
|
|
14
14
|
[key: string]: string;
|
|
15
15
|
}, cloudFormationStack: CloudFormationStack, stackArtifact: cxapi.CloudFormationStackArtifact, hotswapMode: HotswapMode, hotswapPropertyOverrides: HotswapPropertyOverrides): Promise<SuccessfulDeployStackResult | undefined>;
|