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.
Files changed (53) hide show
  1. package/THIRD_PARTY_LICENSES +256 -234
  2. package/build-info.json +2 -2
  3. package/lib/api/cxapp/cloud-assembly.d.ts +18 -1
  4. package/lib/api/cxapp/cloud-assembly.js +38 -5
  5. package/lib/api/deployments/asset-publishing.d.ts +4 -27
  6. package/lib/api/deployments/asset-publishing.js +8 -34
  7. package/lib/api/deployments/cloudformation.d.ts +1 -0
  8. package/lib/api/deployments/cloudformation.js +9 -1
  9. package/lib/api/deployments/deployments.d.ts +0 -22
  10. package/lib/api/deployments/deployments.js +1 -29
  11. package/lib/api/garbage-collection/garbage-collector.js +3 -3
  12. package/lib/api/garbage-collection/progress-printer.js +8 -1
  13. package/lib/{import.d.ts → api/resource-import/importer.d.ts} +55 -12
  14. package/lib/api/resource-import/importer.js +332 -0
  15. package/lib/api/resource-import/index.d.ts +2 -0
  16. package/lib/api/resource-import/index.js +19 -0
  17. package/lib/{migrator.d.ts → api/resource-import/migrator.d.ts} +9 -6
  18. package/lib/api/resource-import/migrator.js +74 -0
  19. package/lib/cli/cdk-toolkit.d.ts +7 -0
  20. package/lib/cli/cdk-toolkit.js +20 -9
  21. package/lib/cli/cli.js +4 -3
  22. package/lib/cli/convert-to-user-input.js +1 -1
  23. package/lib/cli/messages.d.ts +30 -0
  24. package/lib/cli/messages.js +112 -0
  25. package/lib/cli/parse-command-line-arguments.js +1 -1
  26. package/lib/cli/user-configuration.js +2 -1
  27. package/lib/cli/user-input.js +1 -1
  28. package/lib/cli/util/yargs-helpers.js +2 -2
  29. package/lib/cli/version.d.ts +1 -1
  30. package/lib/cli/version.js +6 -3
  31. package/lib/commands/doctor.js +2 -2
  32. package/lib/index.js +126 -197
  33. package/lib/init-templates/.init-version.json +1 -1
  34. package/lib/init-templates/app/javascript/package.json +1 -1
  35. package/lib/init-templates/app/typescript/package.json +1 -1
  36. package/lib/init-templates/sample-app/javascript/package.json +1 -1
  37. package/lib/init-templates/sample-app/typescript/package.json +1 -1
  38. package/lib/init.d.ts +13 -1
  39. package/lib/init.js +37 -32
  40. package/lib/list-stacks.d.ts +1 -17
  41. package/lib/list-stacks.js +2 -37
  42. package/package.json +10 -10
  43. package/test/api/deployments/cloudformation-deployments.test.js +27 -3
  44. package/test/api/garbage-collection.test.js +23 -1
  45. package/test/api/resource-import/import.test.js +373 -0
  46. package/test/init.test.js +14 -1
  47. package/test/toolkit/cli-io-host.test.js +18 -10
  48. package/lib/import.js +0 -329
  49. package/lib/migrator.js +0 -67
  50. package/test/_helpers/prompts.d.ts +0 -11
  51. package/test/_helpers/prompts.js +0 -22
  52. package/test/import.test.js +0 -364
  53. /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"]}
@@ -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>;