@aws-cdk/toolkit-lib 0.1.1 → 0.1.3

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 (35) hide show
  1. package/CODE_REGISTRY.md +35 -0
  2. package/README.md +18 -18
  3. package/build-info.json +2 -2
  4. package/lib/actions/deploy/index.d.ts +4 -4
  5. package/lib/actions/deploy/index.js +1 -1
  6. package/lib/actions/diff/private/helpers.js +3 -3
  7. package/lib/api/aws-cdk.d.ts +0 -1
  8. package/lib/api/aws-cdk.js +1676 -1318
  9. package/lib/api/aws-cdk.js.map +4 -4
  10. package/lib/api/cloud-assembly/private/context-aware-source.js +5 -5
  11. package/lib/api/cloud-assembly/private/exec.js +3 -3
  12. package/lib/api/cloud-assembly/private/prepare-source.js +4 -4
  13. package/lib/api/cloud-assembly/private/source-builder.d.ts +2 -2
  14. package/lib/api/cloud-assembly/private/source-builder.js +5 -5
  15. package/lib/api/cloud-assembly/private/stack-assembly.js +7 -7
  16. package/lib/api/io/io-message.d.ts +1 -1
  17. package/lib/api/io/io-message.js +1 -1
  18. package/lib/api/io/private/codes.d.ts +59 -29
  19. package/lib/api/io/private/codes.js +167 -28
  20. package/lib/api/io/private/messages.d.ts +14 -20
  21. package/lib/api/io/private/messages.js +19 -15
  22. package/lib/api/io/private/timer.js +6 -5
  23. package/lib/api/shared-public.d.ts +1 -0
  24. package/lib/api/shared-public.js +100 -0
  25. package/lib/api/shared-public.js.map +7 -0
  26. package/lib/index.d.ts +1 -1
  27. package/lib/index.js +2 -2
  28. package/lib/toolkit/index.d.ts +1 -0
  29. package/lib/toolkit/index.js +2 -1
  30. package/lib/toolkit/toolkit.js +29 -35
  31. package/lib/toolkit/types.d.ts +76 -0
  32. package/lib/toolkit/types.js +3 -0
  33. package/package.json +26 -24
  34. package/lib/api/errors.d.ts +0 -44
  35. package/lib/api/errors.js +0 -82
@@ -0,0 +1,35 @@
1
+ ## Toolkit Code Registry
2
+
3
+ | Code | Description | Level | Data Interface |
4
+ |------|-------------|-------|----------------|
5
+ | CDK_TOOLKIT_I1000 | Provides synthesis times. | info | n/a |
6
+ | CDK_TOOLKIT_I1901 | Provides stack data | result | [StackData](https://docs.aws.amazon.com/cdk/api/toolkit-lib/interfaces/StackData.html) |
7
+ | CDK_TOOLKIT_I1902 | Successfully deployed stacks | result | [AssemblyData](https://docs.aws.amazon.com/cdk/api/toolkit-lib/interfaces/AssemblyData.html) |
8
+ | CDK_TOOLKIT_I2901 | Provides details on the selected stacks and their dependencies | result | n/a |
9
+ | CDK_TOOLKIT_E3900 | Resource import failed | error | n/a |
10
+ | CDK_TOOLKIT_I5000 | Provides deployment times | info | n/a |
11
+ | CDK_TOOLKIT_I5001 | Provides total time in deploy action, including synth and rollback | info | [Duration](https://docs.aws.amazon.com/cdk/api/toolkit-lib/interfaces/Duration.html) |
12
+ | CDK_TOOLKIT_I5002 | Provides time for resource migration | info | n/a |
13
+ | CDK_TOOLKIT_I5031 | Informs about any log groups that are traced as part of the deployment | info | n/a |
14
+ | CDK_TOOLKIT_I5050 | Confirm rollback during deployment | info | n/a |
15
+ | CDK_TOOLKIT_I5060 | Confirm deploy security sensitive changes | info | n/a |
16
+ | CDK_TOOLKIT_I5501 | Stack Monitoring: Start monitoring of a single stack | info | [StackMonitoringControlEvent](https://docs.aws.amazon.com/cdk/api/toolkit-lib/interfaces/StackMonitoringControlEvent.html) |
17
+ | CDK_TOOLKIT_I5502 | Stack Monitoring: Activity event for a single stack | info | [StackActivity](https://docs.aws.amazon.com/cdk/api/toolkit-lib/interfaces/StackActivity.html) |
18
+ | CDK_TOOLKIT_I5503 | Stack Monitoring: Finished monitoring of a single stack | info | [StackMonitoringControlEvent](https://docs.aws.amazon.com/cdk/api/toolkit-lib/interfaces/StackMonitoringControlEvent.html) |
19
+ | CDK_TOOLKIT_I5900 | Deployment results on success | result | [SuccessfulDeployStackResult](https://docs.aws.amazon.com/cdk/api/toolkit-lib/interfaces/SuccessfulDeployStackResult.html) |
20
+ | CDK_TOOLKIT_E5001 | No stacks found | error | n/a |
21
+ | CDK_TOOLKIT_E5500 | Stack Monitoring error | error | [ErrorPayload](https://docs.aws.amazon.com/cdk/api/toolkit-lib/interfaces/ErrorPayload.html) |
22
+ | CDK_TOOLKIT_I6000 | Provides rollback times | info | n/a |
23
+ | CDK_TOOLKIT_E6001 | No stacks found | error | n/a |
24
+ | CDK_TOOLKIT_E6900 | Rollback failed | error | n/a |
25
+ | CDK_TOOLKIT_I7000 | Provides destroy times | info | n/a |
26
+ | CDK_TOOLKIT_I7010 | Confirm destroy stacks | info | n/a |
27
+ | CDK_TOOLKIT_E7010 | Action was aborted due to negative confirmation of request | error | n/a |
28
+ | CDK_TOOLKIT_E7900 | Stack deletion failed | error | n/a |
29
+ | CDK_ASSEMBLY_I0042 | Writing updated context | debug | n/a |
30
+ | CDK_ASSEMBLY_I0241 | Fetching missing context | debug | n/a |
31
+ | CDK_ASSEMBLY_I1000 | Cloud assembly output starts | debug | n/a |
32
+ | CDK_ASSEMBLY_I1001 | Output lines emitted by the cloud assembly to stdout | info | n/a |
33
+ | CDK_ASSEMBLY_E1002 | Output lines emitted by the cloud assembly to stderr | error | n/a |
34
+ | CDK_ASSEMBLY_I1003 | Cloud assembly output finished | info | n/a |
35
+ | CDK_ASSEMBLY_E1111 | Incompatible CDK CLI version. Upgrade needed. | error | n/a |
package/README.md CHANGED
@@ -62,12 +62,12 @@ import * as core from 'aws-cdk-lib/core';
62
62
  declare const cdk: Toolkit;
63
63
 
64
64
  const cx = cdk.fromAssemblyBuilder(async () => {
65
- const app = new core.App();
65
+ const app = new core.App();
66
66
 
67
- // Define your stacks here
68
- new MyStack(app, 'MyStack');
67
+ // Define your stacks here
68
+ new MyStack(app, 'MyStack');
69
69
 
70
- return app.synth();
70
+ return app.synth();
71
71
  });
72
72
  ```
73
73
 
@@ -82,11 +82,11 @@ The following is a basic example that creates a deployment of the `MyStack` stac
82
82
  declare const cdk: Toolkit;
83
83
  declare const cx: ICloudAssemblySource;
84
84
 
85
- await toolkit.deploy(cloudAssembly, {
86
- stacks: {
87
- strategy: StackSelectionStrategy.PATTERN_MUST_MATCH,
88
- patterns: ["MyStack"],
89
- },
85
+ await cdk.deploy(cx, {
86
+ stacks: {
87
+ strategy: StackSelectionStrategy.PATTERN_MUST_MATCH,
88
+ patterns: ["MyStack"],
89
+ },
90
90
  });
91
91
  ```
92
92
 
@@ -231,9 +231,9 @@ The following is an example implementation that simply logs all message objects
231
231
 
232
232
  ```ts
233
233
  const toolkit = new toolkitLib.Toolkit({
234
- ioHost: {
234
+ ioHost: {
235
235
  notify: async function (msg) {
236
- console.log(msg);
236
+ console.log(msg);
237
237
  },
238
238
  requestResponse: async function (msg) {
239
239
  console.log(msg);
@@ -322,12 +322,12 @@ Alternatively a inline `AssemblyBuilder` function can be used to build a CDK app
322
322
  declare const cdk: Toolkit;
323
323
 
324
324
  const cx = cdk.fromAssemblyBuilder(async () => {
325
- const app = new core.App();
325
+ const app = new core.App();
326
326
 
327
- // Define your stacks here
328
- new MyStack(app, 'MyStack');
327
+ // Define your stacks here
328
+ new MyStack(app, 'MyStack');
329
329
 
330
- return app.synth();
330
+ return app.synth();
331
331
  });
332
332
  ```
333
333
 
@@ -403,7 +403,7 @@ declare const cx: ICloudAssemblySource;
403
403
  try {
404
404
  // Attempt a CDK Toolkit operation
405
405
  const deployment = await cdk.deploy(cloudAssembly, {
406
- stacks: ['MyStack']
406
+ stacks: ['MyStack']
407
407
  });
408
408
 
409
409
  } catch (error) {
@@ -425,8 +425,8 @@ try {
425
425
  console.error('Generic Toolkit error:', error.message);
426
426
 
427
427
  } else {
428
- // Handle unexpected errors
429
- console.error('Unexpected error:', error);
428
+ // Handle unexpected errors
429
+ console.error('Unexpected error:', error);
430
430
  }
431
431
  }
432
432
  ```
package/build-info.json CHANGED
@@ -1,4 +1,4 @@
1
1
  {
2
- "comment": "Generated at 2025-02-25T00:50:08Z by generate.sh",
3
- "commit": "321a46a"
2
+ "comment": "Generated at 2025-03-03T10:07:58Z by generate.sh",
3
+ "commit": "09ef5a0"
4
4
  }
@@ -1,5 +1,5 @@
1
1
  import type { BaseDeployOptions } from './private/deploy-options';
2
- import type { StackActivityProgress, Tag } from '../../api/aws-cdk';
2
+ import type { Tag } from '../../api/aws-cdk';
3
3
  export type DeploymentMethod = DirectDeploymentMethod | ChangeSetDeploymentMethod;
4
4
  export interface DirectDeploymentMethod {
5
5
  /**
@@ -135,15 +135,15 @@ export interface DeployOptions extends BaseDeployOptions {
135
135
  /**
136
136
  * Change stack watcher output to CI mode.
137
137
  *
138
- * @deprecated Implement in IoHost instead
138
+ * @deprecated has no functionality, please implement in your IoHost
139
139
  */
140
140
  readonly ci?: boolean;
141
141
  /**
142
142
  * Display mode for stack deployment progress.
143
143
  *
144
- * @deprecated Implement in IoHost instead
144
+ * @deprecated has no functionality, please implement in your IoHost
145
145
  */
146
- readonly progress?: StackActivityProgress;
146
+ readonly progress?: any;
147
147
  /**
148
148
  * Represents configuration property overrides for hotswap deployments.
149
149
  * Currently only supported by ECS.
@@ -75,4 +75,4 @@ class StackParameters {
75
75
  }
76
76
  }
77
77
  exports.StackParameters = StackParameters;
78
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"index.js","sourceRoot":"","sources":["index.ts"],"names":[],"mappings":";;;AAgCA;;GAEG;AACH,IAAY,cAaX;AAbD,WAAY,cAAc;IACxB;;;;;OAKG;IACH,yDAAuC,CAAA;IAEvC;;OAEG;IACH,+CAA6B,CAAA;AAC/B,CAAC,EAbW,cAAc,8BAAd,cAAc,QAazB;AAED,IAAY,eAaX;AAbD,WAAY,eAAe;IACzB;;OAEG;IACH,kCAAe,CAAA;IACf;;OAEG;IACH,4CAAyB,CAAA;IACzB;;OAEG;IACH,4CAAyB,CAAA;AAC3B,CAAC,EAbW,eAAe,+BAAf,eAAe,QAa1B;AAED,IAAY,WAeX;AAfD,WAAY,WAAW;IACrB;;OAEG;IACH,sCAAuB,CAAA;IAEvB;;OAEG;IACH,4CAA6B,CAAA;IAE7B;;OAEG;IACH,kDAAmC,CAAA;AACrC,CAAC,EAfW,WAAW,2BAAX,WAAW,QAetB;AAED,MAAa,eAAe;IAC1B;;OAEG;IACI,MAAM,CAAC,YAAY;QACxB,OAAO,IAAI,eAAe,CAAC,EAAE,EAAE,IAAI,CAAC,CAAC;IACvC,CAAC;IAED;;OAEG;IACI,MAAM,CAAC,OAAO,CAAC,MAA8C;QAClE,OAAO,IAAI,eAAe,CAAC,MAAM,EAAE,KAAK,CAAC,CAAC;IAC5C,CAAC;IAED;;OAEG;IACI,MAAM,CAAC,YAAY,CAAC,MAA8C;QACvE,OAAO,IAAI,eAAe,CAAC,MAAM,EAAE,IAAI,CAAC,CAAC;IAC3C,CAAC;IAEe,UAAU,CAAkC;IAC5C,sBAAsB,CAAU;IAEhD,YAAoB,MAA8C,EAAE,qBAAqB,GAAG,IAAI;QAC9F,IAAI,CAAC,sBAAsB,GAAG,qBAAqB,CAAC;QACpD,IAAI,CAAC,UAAU,GAAG,IAAI,GAAG,CAAC,MAAM,CAAC,OAAO,CAAC,MAAM,CAAC,CAAC,CAAC;IACpD,CAAC;CACF;AA7BD,0CA6BC","sourcesContent":["import type { BaseDeployOptions } from './private/deploy-options';\nimport type { StackActivityProgress, Tag } from '../../api/aws-cdk';\n\nexport type DeploymentMethod = DirectDeploymentMethod | ChangeSetDeploymentMethod;\n\nexport interface DirectDeploymentMethod {\n  /**\n   * Use stack APIs to the deploy stack changes\n   */\n  readonly method: 'direct';\n}\n\nexport interface ChangeSetDeploymentMethod {\n  /**\n   * Use change-set APIS to deploy a stack changes\n   */\n  readonly method: 'change-set';\n\n  /**\n   * Whether to execute the changeset or leave it in review.\n   *\n   * @default true\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  readonly changeSetName?: string;\n}\n\n/**\n * When to build assets\n */\nexport enum AssetBuildTime {\n  /**\n   * Build all assets before deploying the first stack\n   *\n   * This is intended for expensive Docker image builds; so that if the Docker image build\n   * fails, no stacks are unnecessarily deployed (with the attendant wait time).\n   */\n  ALL_BEFORE_DEPLOY = 'all-before-deploy',\n\n  /**\n   * Build assets just-in-time, before publishing\n   */\n  JUST_IN_TIME = 'just-in-time',\n}\n\nexport enum RequireApproval {\n  /**\n   * Never require any security approvals\n   */\n  NEVER = 'never',\n  /**\n   * Any security changes require an approval\n   */\n  ANY_CHANGE = 'any-change',\n  /**\n   * Require approval only for changes that are access broadening\n   */\n  BROADENING = 'broadening',\n}\n\nexport enum HotswapMode {\n  /**\n   * Will fall back to CloudFormation when a non-hotswappable change is detected\n   */\n  FALL_BACK = 'fall-back',\n\n  /**\n   * Will not fall back to CloudFormation when a non-hotswappable change is detected\n   */\n  HOTSWAP_ONLY = 'hotswap-only',\n\n  /**\n   * Will not attempt to hotswap anything and instead go straight to CloudFormation\n   */\n  FULL_DEPLOYMENT = 'full-deployment',\n}\n\nexport class StackParameters {\n  /**\n   * Use only existing parameters on the stack.\n   */\n  public static onlyExisting() {\n    return new StackParameters({}, true);\n  }\n\n  /**\n   * Use exactly these parameters and remove any other existing parameters from the stack.\n   */\n  public static exactly(params: { [name: string]: string | undefined }) {\n    return new StackParameters(params, false);\n  }\n\n  /**\n   * Define additional parameters for the stack, while keeping existing parameters for unspecified values.\n   */\n  public static withExisting(params: { [name: string]: string | undefined }) {\n    return new StackParameters(params, true);\n  }\n\n  public readonly parameters: Map<string, string | undefined>;\n  public readonly keepExistingParameters: boolean;\n\n  private constructor(params: { [name: string]: string | undefined }, usePreviousParameters = true) {\n    this.keepExistingParameters = usePreviousParameters;\n    this.parameters = new Map(Object.entries(params));\n  }\n}\n\nexport interface DeployOptions extends BaseDeployOptions {\n  /**\n   * ARNs of SNS topics that CloudFormation will notify with stack related events\n   */\n  readonly notificationArns?: string[];\n\n  /**\n   * Require a confirmation for security relevant changes before continuing with the deployment\n   *\n   * @default RequireApproval.NEVER\n   * @deprecated in future a message containing the full diff will be emitted and a response requested.\n   * Approval workflows should be implemented in the `IIoHost`.\n   */\n  readonly requireApproval?: RequireApproval;\n\n  /**\n   * Tags to pass to CloudFormation for deployment\n   */\n  readonly tags?: Tag[];\n\n  /**\n   * Stack parameters for CloudFormation used at deploy time\n   * @default StackParameters.onlyExisting()\n   */\n  readonly parameters?: StackParameters;\n\n  /**\n   * Path to file where stack outputs will be written after a successful deploy as JSON\n   * @default - Outputs are not written to any file\n   */\n  readonly outputsFile?: string;\n\n  /**\n   * Build/publish assets for a single stack in parallel\n   *\n   * Independent of whether stacks are being done in parallel or no.\n   *\n   * @default true\n   */\n  readonly assetParallelism?: boolean;\n\n  /**\n   * When to build assets\n   *\n   * The default is the Docker-friendly default.\n   *\n   * @default AssetBuildTime.ALL_BEFORE_DEPLOY\n   */\n  readonly assetBuildTime?: AssetBuildTime;\n\n  /**\n   * Change stack watcher output to CI mode.\n   *\n   * @deprecated Implement in IoHost instead\n   */\n  readonly ci?: boolean;\n\n  /**\n   * Display mode for stack deployment progress.\n   *\n   * @deprecated Implement in IoHost instead\n   */\n  readonly progress?: StackActivityProgress;\n\n  /**\n   * Represents configuration property overrides for hotswap deployments.\n   * Currently only supported by ECS.\n   *\n   * @default - no overrides\n   */\n  readonly hotswapProperties?: HotswapProperties;\n}\n\n/**\n * Property overrides for ECS hotswaps\n */\nexport interface EcsHotswapProperties {\n  /**\n   * The lower limit on the number of your service's tasks that must remain\n   * in the RUNNING state during a deployment, as a percentage of the desiredCount.\n   */\n  readonly minimumHealthyPercent: number;\n\n  /**\n   * The upper limit on the number of your service's tasks that are allowed\n   * in the RUNNING or PENDING state during a deployment, as a percentage of the desiredCount.\n   */\n  readonly maximumHealthyPercent: number;\n}\n\n/**\n * Property overrides for hotswap deployments.\n */\nexport interface HotswapProperties {\n  /**\n   * ECS specific hotswap property overrides\n   */\n  readonly ecs: EcsHotswapProperties;\n}\n"]}
78
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"index.js","sourceRoot":"","sources":["index.ts"],"names":[],"mappings":";;;AAgCA;;GAEG;AACH,IAAY,cAaX;AAbD,WAAY,cAAc;IACxB;;;;;OAKG;IACH,yDAAuC,CAAA;IAEvC;;OAEG;IACH,+CAA6B,CAAA;AAC/B,CAAC,EAbW,cAAc,8BAAd,cAAc,QAazB;AAED,IAAY,eAaX;AAbD,WAAY,eAAe;IACzB;;OAEG;IACH,kCAAe,CAAA;IACf;;OAEG;IACH,4CAAyB,CAAA;IACzB;;OAEG;IACH,4CAAyB,CAAA;AAC3B,CAAC,EAbW,eAAe,+BAAf,eAAe,QAa1B;AAED,IAAY,WAeX;AAfD,WAAY,WAAW;IACrB;;OAEG;IACH,sCAAuB,CAAA;IAEvB;;OAEG;IACH,4CAA6B,CAAA;IAE7B;;OAEG;IACH,kDAAmC,CAAA;AACrC,CAAC,EAfW,WAAW,2BAAX,WAAW,QAetB;AAED,MAAa,eAAe;IAC1B;;OAEG;IACI,MAAM,CAAC,YAAY;QACxB,OAAO,IAAI,eAAe,CAAC,EAAE,EAAE,IAAI,CAAC,CAAC;IACvC,CAAC;IAED;;OAEG;IACI,MAAM,CAAC,OAAO,CAAC,MAA8C;QAClE,OAAO,IAAI,eAAe,CAAC,MAAM,EAAE,KAAK,CAAC,CAAC;IAC5C,CAAC;IAED;;OAEG;IACI,MAAM,CAAC,YAAY,CAAC,MAA8C;QACvE,OAAO,IAAI,eAAe,CAAC,MAAM,EAAE,IAAI,CAAC,CAAC;IAC3C,CAAC;IAEe,UAAU,CAAkC;IAC5C,sBAAsB,CAAU;IAEhD,YAAoB,MAA8C,EAAE,qBAAqB,GAAG,IAAI;QAC9F,IAAI,CAAC,sBAAsB,GAAG,qBAAqB,CAAC;QACpD,IAAI,CAAC,UAAU,GAAG,IAAI,GAAG,CAAC,MAAM,CAAC,OAAO,CAAC,MAAM,CAAC,CAAC,CAAC;IACpD,CAAC;CACF;AA7BD,0CA6BC","sourcesContent":["import type { BaseDeployOptions } from './private/deploy-options';\nimport type { Tag } from '../../api/aws-cdk';\n\nexport type DeploymentMethod = DirectDeploymentMethod | ChangeSetDeploymentMethod;\n\nexport interface DirectDeploymentMethod {\n  /**\n   * Use stack APIs to the deploy stack changes\n   */\n  readonly method: 'direct';\n}\n\nexport interface ChangeSetDeploymentMethod {\n  /**\n   * Use change-set APIS to deploy a stack changes\n   */\n  readonly method: 'change-set';\n\n  /**\n   * Whether to execute the changeset or leave it in review.\n   *\n   * @default true\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  readonly changeSetName?: string;\n}\n\n/**\n * When to build assets\n */\nexport enum AssetBuildTime {\n  /**\n   * Build all assets before deploying the first stack\n   *\n   * This is intended for expensive Docker image builds; so that if the Docker image build\n   * fails, no stacks are unnecessarily deployed (with the attendant wait time).\n   */\n  ALL_BEFORE_DEPLOY = 'all-before-deploy',\n\n  /**\n   * Build assets just-in-time, before publishing\n   */\n  JUST_IN_TIME = 'just-in-time',\n}\n\nexport enum RequireApproval {\n  /**\n   * Never require any security approvals\n   */\n  NEVER = 'never',\n  /**\n   * Any security changes require an approval\n   */\n  ANY_CHANGE = 'any-change',\n  /**\n   * Require approval only for changes that are access broadening\n   */\n  BROADENING = 'broadening',\n}\n\nexport enum HotswapMode {\n  /**\n   * Will fall back to CloudFormation when a non-hotswappable change is detected\n   */\n  FALL_BACK = 'fall-back',\n\n  /**\n   * Will not fall back to CloudFormation when a non-hotswappable change is detected\n   */\n  HOTSWAP_ONLY = 'hotswap-only',\n\n  /**\n   * Will not attempt to hotswap anything and instead go straight to CloudFormation\n   */\n  FULL_DEPLOYMENT = 'full-deployment',\n}\n\nexport class StackParameters {\n  /**\n   * Use only existing parameters on the stack.\n   */\n  public static onlyExisting() {\n    return new StackParameters({}, true);\n  }\n\n  /**\n   * Use exactly these parameters and remove any other existing parameters from the stack.\n   */\n  public static exactly(params: { [name: string]: string | undefined }) {\n    return new StackParameters(params, false);\n  }\n\n  /**\n   * Define additional parameters for the stack, while keeping existing parameters for unspecified values.\n   */\n  public static withExisting(params: { [name: string]: string | undefined }) {\n    return new StackParameters(params, true);\n  }\n\n  public readonly parameters: Map<string, string | undefined>;\n  public readonly keepExistingParameters: boolean;\n\n  private constructor(params: { [name: string]: string | undefined }, usePreviousParameters = true) {\n    this.keepExistingParameters = usePreviousParameters;\n    this.parameters = new Map(Object.entries(params));\n  }\n}\n\nexport interface DeployOptions extends BaseDeployOptions {\n  /**\n   * ARNs of SNS topics that CloudFormation will notify with stack related events\n   */\n  readonly notificationArns?: string[];\n\n  /**\n   * Require a confirmation for security relevant changes before continuing with the deployment\n   *\n   * @default RequireApproval.NEVER\n   * @deprecated in future a message containing the full diff will be emitted and a response requested.\n   * Approval workflows should be implemented in the `IIoHost`.\n   */\n  readonly requireApproval?: RequireApproval;\n\n  /**\n   * Tags to pass to CloudFormation for deployment\n   */\n  readonly tags?: Tag[];\n\n  /**\n   * Stack parameters for CloudFormation used at deploy time\n   * @default StackParameters.onlyExisting()\n   */\n  readonly parameters?: StackParameters;\n\n  /**\n   * Path to file where stack outputs will be written after a successful deploy as JSON\n   * @default - Outputs are not written to any file\n   */\n  readonly outputsFile?: string;\n\n  /**\n   * Build/publish assets for a single stack in parallel\n   *\n   * Independent of whether stacks are being done in parallel or no.\n   *\n   * @default true\n   */\n  readonly assetParallelism?: boolean;\n\n  /**\n   * When to build assets\n   *\n   * The default is the Docker-friendly default.\n   *\n   * @default AssetBuildTime.ALL_BEFORE_DEPLOY\n   */\n  readonly assetBuildTime?: AssetBuildTime;\n\n  /**\n   * Change stack watcher output to CI mode.\n   *\n   * @deprecated has no functionality, please implement in your IoHost\n   */\n  readonly ci?: boolean;\n\n  /**\n   * Display mode for stack deployment progress.\n   *\n   * @deprecated has no functionality, please implement in your IoHost\n   */\n  readonly progress?: any;\n\n  /**\n   * Represents configuration property overrides for hotswap deployments.\n   * Currently only supported by ECS.\n   *\n   * @default - no overrides\n   */\n  readonly hotswapProperties?: HotswapProperties;\n}\n\n/**\n * Property overrides for ECS hotswaps\n */\nexport interface EcsHotswapProperties {\n  /**\n   * The lower limit on the number of your service's tasks that must remain\n   * in the RUNNING state during a deployment, as a percentage of the desiredCount.\n   */\n  readonly minimumHealthyPercent: number;\n\n  /**\n   * The upper limit on the number of your service's tasks that are allowed\n   * in the RUNNING or PENDING state during a deployment, as a percentage of the desiredCount.\n   */\n  readonly maximumHealthyPercent: number;\n}\n\n/**\n * Property overrides for hotswap deployments.\n */\nexport interface HotswapProperties {\n  /**\n   * ECS specific hotswap property overrides\n   */\n  readonly ecs: EcsHotswapProperties;\n}\n"]}
@@ -2,7 +2,7 @@
2
2
  Object.defineProperty(exports, "__esModule", { value: true });
3
3
  exports.diffRequiresApproval = diffRequiresApproval;
4
4
  const cloudformation_diff_1 = require("@aws-cdk/cloudformation-diff");
5
- const errors_1 = require("../../../api/errors");
5
+ const shared_public_1 = require("../../../api/shared-public");
6
6
  const deploy_1 = require("../../deploy");
7
7
  /**
8
8
  * Return whether the diff has security-impacting changes that need confirmation
@@ -14,7 +14,7 @@ function diffRequiresApproval(oldTemplate, newTemplate, requireApproval, changeS
14
14
  case deploy_1.RequireApproval.NEVER: return false;
15
15
  case deploy_1.RequireApproval.ANY_CHANGE: return diff.permissionsAnyChanges;
16
16
  case deploy_1.RequireApproval.BROADENING: return diff.permissionsBroadened;
17
- default: throw new errors_1.ToolkitError(`Unrecognized approval level: ${requireApproval}`);
17
+ default: throw new shared_public_1.ToolkitError(`Unrecognized approval level: ${requireApproval}`);
18
18
  }
19
19
  }
20
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaGVscGVycy5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbImhlbHBlcnMudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7QUFRQSxvREFlQztBQXZCRCxzRUFBaUY7QUFFakYsZ0RBQW1EO0FBQ25ELHlDQUErQztBQUUvQzs7R0FFRztBQUNILFNBQWdCLG9CQUFvQixDQUNsQyxXQUFnQixFQUNoQixXQUE4QyxFQUM5QyxlQUFnQyxFQUNoQyxTQUFtQztJQUVuQyx1Q0FBdUM7SUFDdkMsTUFBTSxJQUFJLEdBQUcsSUFBQSw4QkFBUSxFQUFDLFdBQVcsRUFBRSxXQUFXLENBQUMsUUFBUSxFQUFFLFNBQVMsQ0FBQyxDQUFDO0lBRXBFLFFBQVEsZUFBZSxFQUFFLENBQUM7UUFDeEIsS0FBSyx3QkFBZSxDQUFDLEtBQUssQ0FBQyxDQUFDLE9BQU8sS0FBSyxDQUFDO1FBQ3pDLEtBQUssd0JBQWUsQ0FBQyxVQUFVLENBQUMsQ0FBQyxPQUFPLElBQUksQ0FBQyxxQkFBcUIsQ0FBQztRQUNuRSxLQUFLLHdCQUFlLENBQUMsVUFBVSxDQUFDLENBQUMsT0FBTyxJQUFJLENBQUMsb0JBQW9CLENBQUM7UUFDbEUsT0FBTyxDQUFDLENBQUMsTUFBTSxJQUFJLHFCQUFZLENBQUMsZ0NBQWdDLGVBQWUsRUFBRSxDQUFDLENBQUM7SUFDckYsQ0FBQztBQUNILENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBEZXNjcmliZUNoYW5nZVNldE91dHB1dCwgZnVsbERpZmYgfSBmcm9tICdAYXdzLWNkay9jbG91ZGZvcm1hdGlvbi1kaWZmJztcbmltcG9ydCAqIGFzIGN4YXBpIGZyb20gJ0Bhd3MtY2RrL2N4LWFwaSc7XG5pbXBvcnQgeyBUb29sa2l0RXJyb3IgfSBmcm9tICcuLi8uLi8uLi9hcGkvZXJyb3JzJztcbmltcG9ydCB7IFJlcXVpcmVBcHByb3ZhbCB9IGZyb20gJy4uLy4uL2RlcGxveSc7XG5cbi8qKlxuICogUmV0dXJuIHdoZXRoZXIgdGhlIGRpZmYgaGFzIHNlY3VyaXR5LWltcGFjdGluZyBjaGFuZ2VzIHRoYXQgbmVlZCBjb25maXJtYXRpb25cbiAqL1xuZXhwb3J0IGZ1bmN0aW9uIGRpZmZSZXF1aXJlc0FwcHJvdmFsKFxuICBvbGRUZW1wbGF0ZTogYW55LFxuICBuZXdUZW1wbGF0ZTogY3hhcGkuQ2xvdWRGb3JtYXRpb25TdGFja0FydGlmYWN0LFxuICByZXF1aXJlQXBwcm92YWw6IFJlcXVpcmVBcHByb3ZhbCxcbiAgY2hhbmdlU2V0PzogRGVzY3JpYmVDaGFuZ2VTZXRPdXRwdXQsXG4pOiBib29sZWFuIHtcbiAgLy8gQHRvZG8gcmV0dXJuIG9yIHByaW50IHRoZSBmdWxsIGRpZmYuXG4gIGNvbnN0IGRpZmYgPSBmdWxsRGlmZihvbGRUZW1wbGF0ZSwgbmV3VGVtcGxhdGUudGVtcGxhdGUsIGNoYW5nZVNldCk7XG5cbiAgc3dpdGNoIChyZXF1aXJlQXBwcm92YWwpIHtcbiAgICBjYXNlIFJlcXVpcmVBcHByb3ZhbC5ORVZFUjogcmV0dXJuIGZhbHNlO1xuICAgIGNhc2UgUmVxdWlyZUFwcHJvdmFsLkFOWV9DSEFOR0U6IHJldHVybiBkaWZmLnBlcm1pc3Npb25zQW55Q2hhbmdlcztcbiAgICBjYXNlIFJlcXVpcmVBcHByb3ZhbC5CUk9BREVOSU5HOiByZXR1cm4gZGlmZi5wZXJtaXNzaW9uc0Jyb2FkZW5lZDtcbiAgICBkZWZhdWx0OiB0aHJvdyBuZXcgVG9vbGtpdEVycm9yKGBVbnJlY29nbml6ZWQgYXBwcm92YWwgbGV2ZWw6ICR7cmVxdWlyZUFwcHJvdmFsfWApO1xuICB9XG59XG4iXX0=
20
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaGVscGVycy5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbImhlbHBlcnMudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7QUFRQSxvREFlQztBQXZCRCxzRUFBaUY7QUFFakYsOERBQTBEO0FBQzFELHlDQUErQztBQUUvQzs7R0FFRztBQUNILFNBQWdCLG9CQUFvQixDQUNsQyxXQUFnQixFQUNoQixXQUE4QyxFQUM5QyxlQUFnQyxFQUNoQyxTQUFtQztJQUVuQyx1Q0FBdUM7SUFDdkMsTUFBTSxJQUFJLEdBQUcsSUFBQSw4QkFBUSxFQUFDLFdBQVcsRUFBRSxXQUFXLENBQUMsUUFBUSxFQUFFLFNBQVMsQ0FBQyxDQUFDO0lBRXBFLFFBQVEsZUFBZSxFQUFFLENBQUM7UUFDeEIsS0FBSyx3QkFBZSxDQUFDLEtBQUssQ0FBQyxDQUFDLE9BQU8sS0FBSyxDQUFDO1FBQ3pDLEtBQUssd0JBQWUsQ0FBQyxVQUFVLENBQUMsQ0FBQyxPQUFPLElBQUksQ0FBQyxxQkFBcUIsQ0FBQztRQUNuRSxLQUFLLHdCQUFlLENBQUMsVUFBVSxDQUFDLENBQUMsT0FBTyxJQUFJLENBQUMsb0JBQW9CLENBQUM7UUFDbEUsT0FBTyxDQUFDLENBQUMsTUFBTSxJQUFJLDRCQUFZLENBQUMsZ0NBQWdDLGVBQWUsRUFBRSxDQUFDLENBQUM7SUFDckYsQ0FBQztBQUNILENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBEZXNjcmliZUNoYW5nZVNldE91dHB1dCwgZnVsbERpZmYgfSBmcm9tICdAYXdzLWNkay9jbG91ZGZvcm1hdGlvbi1kaWZmJztcbmltcG9ydCAqIGFzIGN4YXBpIGZyb20gJ0Bhd3MtY2RrL2N4LWFwaSc7XG5pbXBvcnQgeyBUb29sa2l0RXJyb3IgfSBmcm9tICcuLi8uLi8uLi9hcGkvc2hhcmVkLXB1YmxpYyc7XG5pbXBvcnQgeyBSZXF1aXJlQXBwcm92YWwgfSBmcm9tICcuLi8uLi9kZXBsb3knO1xuXG4vKipcbiAqIFJldHVybiB3aGV0aGVyIHRoZSBkaWZmIGhhcyBzZWN1cml0eS1pbXBhY3RpbmcgY2hhbmdlcyB0aGF0IG5lZWQgY29uZmlybWF0aW9uXG4gKi9cbmV4cG9ydCBmdW5jdGlvbiBkaWZmUmVxdWlyZXNBcHByb3ZhbChcbiAgb2xkVGVtcGxhdGU6IGFueSxcbiAgbmV3VGVtcGxhdGU6IGN4YXBpLkNsb3VkRm9ybWF0aW9uU3RhY2tBcnRpZmFjdCxcbiAgcmVxdWlyZUFwcHJvdmFsOiBSZXF1aXJlQXBwcm92YWwsXG4gIGNoYW5nZVNldD86IERlc2NyaWJlQ2hhbmdlU2V0T3V0cHV0LFxuKTogYm9vbGVhbiB7XG4gIC8vIEB0b2RvIHJldHVybiBvciBwcmludCB0aGUgZnVsbCBkaWZmLlxuICBjb25zdCBkaWZmID0gZnVsbERpZmYob2xkVGVtcGxhdGUsIG5ld1RlbXBsYXRlLnRlbXBsYXRlLCBjaGFuZ2VTZXQpO1xuXG4gIHN3aXRjaCAocmVxdWlyZUFwcHJvdmFsKSB7XG4gICAgY2FzZSBSZXF1aXJlQXBwcm92YWwuTkVWRVI6IHJldHVybiBmYWxzZTtcbiAgICBjYXNlIFJlcXVpcmVBcHByb3ZhbC5BTllfQ0hBTkdFOiByZXR1cm4gZGlmZi5wZXJtaXNzaW9uc0FueUNoYW5nZXM7XG4gICAgY2FzZSBSZXF1aXJlQXBwcm92YWwuQlJPQURFTklORzogcmV0dXJuIGRpZmYucGVybWlzc2lvbnNCcm9hZGVuZWQ7XG4gICAgZGVmYXVsdDogdGhyb3cgbmV3IFRvb2xraXRFcnJvcihgVW5yZWNvZ25pemVkIGFwcHJvdmFsIGxldmVsOiAke3JlcXVpcmVBcHByb3ZhbH1gKTtcbiAgfVxufVxuIl19
@@ -5,7 +5,6 @@ export { Settings } from '../../../../aws-cdk/lib/api/settings';
5
5
  export { tagsForStack, Tag } from '../../../../aws-cdk/lib/api/tags';
6
6
  export { DEFAULT_TOOLKIT_STACK_NAME } from '../../../../aws-cdk/lib/api/toolkit-info';
7
7
  export { ResourceMigrator } from '../../../../aws-cdk/lib/api/resource-import';
8
- export { StackActivityProgress } from '../../../../aws-cdk/lib/api/stack-events';
9
8
  export { CloudWatchLogEventMonitor, findCloudWatchLogGroups } from '../../../../aws-cdk/lib/api/logs';
10
9
  export { type WorkGraph, WorkGraphBuilder, AssetBuildNode, AssetPublishNode, StackNode, Concurrency } from '../../../../aws-cdk/lib/api/work-graph';
11
10
  export * as contextproviders from '../../../../aws-cdk/lib/context-providers';