aws-cdk 2.178.2 → 2.179.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 +256 -234
- package/build-info.json +2 -2
- package/lib/api/cxapp/cloud-assembly.d.ts +18 -1
- package/lib/api/cxapp/cloud-assembly.js +38 -5
- package/lib/api/deployments/asset-publishing.d.ts +4 -27
- package/lib/api/deployments/asset-publishing.js +8 -34
- package/lib/api/deployments/cloudformation.d.ts +1 -0
- package/lib/api/deployments/cloudformation.js +9 -1
- package/lib/api/deployments/deployments.d.ts +0 -22
- package/lib/api/deployments/deployments.js +1 -29
- package/lib/api/garbage-collection/garbage-collector.js +3 -3
- package/lib/api/garbage-collection/progress-printer.js +8 -1
- package/lib/{import.d.ts → api/resource-import/importer.d.ts} +55 -12
- package/lib/api/resource-import/importer.js +332 -0
- package/lib/api/resource-import/index.d.ts +2 -0
- package/lib/api/resource-import/index.js +19 -0
- package/lib/{migrator.d.ts → api/resource-import/migrator.d.ts} +9 -6
- package/lib/api/resource-import/migrator.js +74 -0
- package/lib/cli/cdk-toolkit.d.ts +7 -0
- package/lib/cli/cdk-toolkit.js +20 -9
- package/lib/cli/cli.js +4 -3
- package/lib/cli/convert-to-user-input.js +1 -1
- package/lib/cli/messages.d.ts +30 -0
- package/lib/cli/messages.js +112 -0
- package/lib/cli/parse-command-line-arguments.js +1 -1
- package/lib/cli/user-configuration.js +2 -1
- package/lib/cli/user-input.js +1 -1
- package/lib/cli/util/yargs-helpers.js +2 -2
- package/lib/cli/version.d.ts +1 -1
- package/lib/cli/version.js +6 -3
- package/lib/commands/doctor.js +2 -2
- package/lib/index.js +126 -197
- package/lib/init-templates/.init-version.json +1 -1
- package/lib/init-templates/app/javascript/package.json +1 -1
- package/lib/init-templates/app/typescript/package.json +1 -1
- package/lib/init-templates/sample-app/javascript/package.json +1 -1
- package/lib/init-templates/sample-app/typescript/package.json +1 -1
- package/lib/init.d.ts +13 -1
- package/lib/init.js +37 -32
- package/lib/list-stacks.d.ts +1 -17
- package/lib/list-stacks.js +2 -37
- package/package.json +10 -10
- package/test/api/deployments/cloudformation-deployments.test.js +27 -3
- package/test/api/garbage-collection.test.js +23 -1
- package/test/api/resource-import/import.test.js +373 -0
- package/test/init.test.js +14 -1
- package/test/toolkit/cli-io-host.test.js +18 -10
- package/lib/import.js +0 -329
- package/lib/migrator.js +0 -67
- package/test/_helpers/prompts.d.ts +0 -11
- package/test/_helpers/prompts.js +0 -22
- package/test/import.test.js +0 -364
- /package/test/{import.test.d.ts → api/resource-import/import.test.d.ts} +0 -0
|
@@ -0,0 +1,74 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.ResourceMigrator = void 0;
|
|
4
|
+
const chalk = require("chalk");
|
|
5
|
+
const fs = require("fs-extra");
|
|
6
|
+
const importer_1 = require("./importer");
|
|
7
|
+
const messages_1 = require("../../cli/messages");
|
|
8
|
+
const string_manipulation_1 = require("../util/string-manipulation");
|
|
9
|
+
class ResourceMigrator {
|
|
10
|
+
constructor(props) {
|
|
11
|
+
this.props = props;
|
|
12
|
+
this.ioHost = props.ioHost;
|
|
13
|
+
this.action = props.action;
|
|
14
|
+
}
|
|
15
|
+
/**
|
|
16
|
+
* Checks to see if a migrate.json file exists. If it does and the source is either `filepath` or
|
|
17
|
+
* is in the same environment as the stack deployment, a new stack is created and the resources are
|
|
18
|
+
* migrated to the stack using an IMPORT changeset. The normal deployment will resume after this is complete
|
|
19
|
+
* to add back in any outputs and the CDKMetadata.
|
|
20
|
+
*/
|
|
21
|
+
async tryMigrateResources(stacks, options) {
|
|
22
|
+
const stack = stacks.stackArtifacts[0];
|
|
23
|
+
const migrateDeployment = new importer_1.ResourceImporter(stack, {
|
|
24
|
+
deployments: this.props.deployments,
|
|
25
|
+
ioHost: this.ioHost,
|
|
26
|
+
action: this.action,
|
|
27
|
+
});
|
|
28
|
+
const resourcesToImport = await this.tryGetResources(await migrateDeployment.resolveEnvironment());
|
|
29
|
+
if (resourcesToImport) {
|
|
30
|
+
await this.ioHost.notify((0, messages_1.info)(this.action, `${chalk.bold(stack.displayName)}: creating stack for resource migration...`));
|
|
31
|
+
await this.ioHost.notify((0, messages_1.info)(this.action, `${chalk.bold(stack.displayName)}: importing resources into stack...`));
|
|
32
|
+
await this.performResourceMigration(migrateDeployment, resourcesToImport, options);
|
|
33
|
+
fs.rmSync('migrate.json');
|
|
34
|
+
await this.ioHost.notify((0, messages_1.info)(this.action, `${chalk.bold(stack.displayName)}: applying CDKMetadata and Outputs to stack (if applicable)...`));
|
|
35
|
+
}
|
|
36
|
+
}
|
|
37
|
+
/**
|
|
38
|
+
* Creates a new stack with just the resources to be migrated
|
|
39
|
+
*/
|
|
40
|
+
async performResourceMigration(migrateDeployment, resourcesToImport, options) {
|
|
41
|
+
const startDeployTime = new Date().getTime();
|
|
42
|
+
let elapsedDeployTime = 0;
|
|
43
|
+
// Initial Deployment
|
|
44
|
+
await migrateDeployment.importResourcesFromMigrate(resourcesToImport, {
|
|
45
|
+
roleArn: options.roleArn,
|
|
46
|
+
deploymentMethod: options.deploymentMethod,
|
|
47
|
+
usePreviousParameters: true,
|
|
48
|
+
progress: options.progress,
|
|
49
|
+
rollback: options.rollback,
|
|
50
|
+
});
|
|
51
|
+
elapsedDeployTime = new Date().getTime() - startDeployTime;
|
|
52
|
+
await this.ioHost.notify((0, messages_1.info)(this.action, `'\n✨ Resource migration time: ${(0, string_manipulation_1.formatTime)(elapsedDeployTime)}s\n'`, 'CDK_TOOLKIT_I5002', {
|
|
53
|
+
duration: elapsedDeployTime,
|
|
54
|
+
}));
|
|
55
|
+
}
|
|
56
|
+
async tryGetResources(environment) {
|
|
57
|
+
try {
|
|
58
|
+
const migrateFile = fs.readJsonSync('migrate.json', {
|
|
59
|
+
encoding: 'utf-8',
|
|
60
|
+
});
|
|
61
|
+
const sourceEnv = migrateFile.Source.split(':');
|
|
62
|
+
if (sourceEnv[0] === 'localfile' ||
|
|
63
|
+
(sourceEnv[4] === environment.account && sourceEnv[3] === environment.region)) {
|
|
64
|
+
return migrateFile.Resources;
|
|
65
|
+
}
|
|
66
|
+
}
|
|
67
|
+
catch (e) {
|
|
68
|
+
// Nothing to do
|
|
69
|
+
}
|
|
70
|
+
return undefined;
|
|
71
|
+
}
|
|
72
|
+
}
|
|
73
|
+
exports.ResourceMigrator = ResourceMigrator;
|
|
74
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"migrator.js","sourceRoot":"","sources":["migrator.ts"],"names":[],"mappings":"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","sourcesContent":["import type * as cxapi from '@aws-cdk/cx-api';\nimport * as chalk from 'chalk';\nimport * as fs from 'fs-extra';\nimport { ImportDeploymentOptions, ResourceImporter } from './importer';\nimport { info } from '../../cli/messages';\nimport type { IIoHost, ToolkitAction } from '../../toolkit/cli-io-host';\nimport { StackCollection } from '../cxapp/cloud-assembly';\nimport { Deployments, ResourcesToImport } from '../deployments';\nimport { formatTime } from '../util/string-manipulation';\n\nexport interface ResourceMigratorProps {\n  deployments: Deployments;\n  ioHost: IIoHost;\n  action: ToolkitAction;\n}\n\nexport class ResourceMigrator {\n  private readonly props: ResourceMigratorProps;\n  private readonly ioHost: IIoHost;\n  private readonly action: ToolkitAction;\n\n  public constructor(props: ResourceMigratorProps) {\n    this.props = props;\n    this.ioHost = props.ioHost;\n    this.action = props.action;\n  }\n\n  /**\n   * Checks to see if a migrate.json file exists. If it does and the source is either `filepath` or\n   * is in the same environment as the stack deployment, a new stack is created and the resources are\n   * migrated to the stack using an IMPORT changeset. The normal deployment will resume after this is complete\n   * to add back in any outputs and the CDKMetadata.\n   */\n  public async tryMigrateResources(stacks: StackCollection, options: ImportDeploymentOptions): Promise<void> {\n    const stack = stacks.stackArtifacts[0];\n    const migrateDeployment = new ResourceImporter(stack, {\n      deployments: this.props.deployments,\n      ioHost: this.ioHost,\n      action: this.action,\n    });\n    const resourcesToImport = await this.tryGetResources(await migrateDeployment.resolveEnvironment());\n\n    if (resourcesToImport) {\n      await this.ioHost.notify(info(this.action, `${chalk.bold(stack.displayName)}: creating stack for resource migration...`));\n      await this.ioHost.notify(info(this.action, `${chalk.bold(stack.displayName)}: importing resources into stack...`));\n\n      await this.performResourceMigration(migrateDeployment, resourcesToImport, options);\n\n      fs.rmSync('migrate.json');\n      await this.ioHost.notify(info(this.action, `${chalk.bold(stack.displayName)}: applying CDKMetadata and Outputs to stack (if applicable)...`));\n    }\n  }\n\n  /**\n   * Creates a new stack with just the resources to be migrated\n   */\n  private async performResourceMigration(\n    migrateDeployment: ResourceImporter,\n    resourcesToImport: ResourcesToImport,\n    options: ImportDeploymentOptions,\n  ) {\n    const startDeployTime = new Date().getTime();\n    let elapsedDeployTime = 0;\n\n    // Initial Deployment\n    await migrateDeployment.importResourcesFromMigrate(resourcesToImport, {\n      roleArn: options.roleArn,\n      deploymentMethod: options.deploymentMethod,\n      usePreviousParameters: true,\n      progress: options.progress,\n      rollback: options.rollback,\n    });\n\n    elapsedDeployTime = new Date().getTime() - startDeployTime;\n    await this.ioHost.notify(info(this.action, `'\\n✨  Resource migration time: ${formatTime(elapsedDeployTime)}s\\n'`, 'CDK_TOOLKIT_I5002', {\n      duration: elapsedDeployTime,\n    }));\n  }\n\n  public async tryGetResources(environment: cxapi.Environment): Promise<ResourcesToImport | undefined> {\n    try {\n      const migrateFile = fs.readJsonSync('migrate.json', {\n        encoding: 'utf-8',\n      });\n      const sourceEnv = (migrateFile.Source as string).split(':');\n      if (\n        sourceEnv[0] === 'localfile' ||\n        (sourceEnv[4] === environment.account && sourceEnv[3] === environment.region)\n      ) {\n        return migrateFile.Resources;\n      }\n    } catch (e) {\n      // Nothing to do\n    }\n\n    return undefined;\n  }\n}\n\n"]}
|
package/lib/cli/cdk-toolkit.d.ts
CHANGED
|
@@ -25,6 +25,12 @@ export interface CdkToolkitProps {
|
|
|
25
25
|
* The CliIoHost that's used for I/O operations
|
|
26
26
|
*/
|
|
27
27
|
ioHost?: CliIoHost;
|
|
28
|
+
/**
|
|
29
|
+
* Name of the toolkit stack to use/deploy
|
|
30
|
+
*
|
|
31
|
+
* @default CDKToolkit
|
|
32
|
+
*/
|
|
33
|
+
toolkitStackName?: string;
|
|
28
34
|
/**
|
|
29
35
|
* Whether to be verbose
|
|
30
36
|
*
|
|
@@ -77,6 +83,7 @@ export declare enum AssetBuildTime {
|
|
|
77
83
|
export declare class CdkToolkit {
|
|
78
84
|
private readonly props;
|
|
79
85
|
private ioHost;
|
|
86
|
+
private toolkitStackName;
|
|
80
87
|
constructor(props: CdkToolkitProps);
|
|
81
88
|
metadata(stackName: string, json: boolean): Promise<void>;
|
|
82
89
|
acknowledge(noticeId: string): Promise<void>;
|