@aws-cdk/cloud-assembly-schema 36.3.0 → 38.0.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.
@@ -20,4 +20,16 @@ export interface AwsDestination {
20
20
  * @default - No ExternalId will be supplied
21
21
  */
22
22
  readonly assumeRoleExternalId?: string;
23
+ /**
24
+ * Additional options to pass to STS when assuming the role.
25
+ *
26
+ * - `RoleArn` should not be used. Use the dedicated `assumeRoleArn` property instead.
27
+ * - `ExternalId` should not be used. Use the dedicated `assumeRoleExternalId` instead.
28
+ *
29
+ * @see https://docs.aws.amazon.com/AWSJavaScriptSDK/latest/AWS/STS.html#assumeRole-property
30
+ * @default - No additional options.
31
+ */
32
+ readonly assumeRoleAdditionalOptions?: {
33
+ [key: string]: any;
34
+ };
23
35
  }
@@ -1,3 +1,3 @@
1
1
  "use strict";
2
2
  Object.defineProperty(exports, "__esModule", { value: true });
3
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYXdzLWRlc3RpbmF0aW9uLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiYXdzLWRlc3RpbmF0aW9uLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiIiLCJzb3VyY2VzQ29udGVudCI6WyIvKipcbiAqIERlc3RpbmF0aW9uIGZvciBhc3NldHMgdGhhdCBuZWVkIHRvIGJlIHVwbG9hZGVkIHRvIEFXU1xuICovXG5leHBvcnQgaW50ZXJmYWNlIEF3c0Rlc3RpbmF0aW9uIHtcbiAgLyoqXG4gICAqIFRoZSByZWdpb24gd2hlcmUgdGhpcyBhc3NldCB3aWxsIG5lZWQgdG8gYmUgcHVibGlzaGVkXG4gICAqXG4gICAqIEBkZWZhdWx0IC0gQ3VycmVudCByZWdpb25cbiAgICovXG4gIHJlYWRvbmx5IHJlZ2lvbj86IHN0cmluZztcblxuICAvKipcbiAgICogVGhlIHJvbGUgdGhhdCBuZWVkcyB0byBiZSBhc3N1bWVkIHdoaWxlIHB1Ymxpc2hpbmcgdGhpcyBhc3NldFxuICAgKlxuICAgKiBAZGVmYXVsdCAtIE5vIHJvbGUgd2lsbCBiZSBhc3N1bWVkXG4gICAqL1xuICByZWFkb25seSBhc3N1bWVSb2xlQXJuPzogc3RyaW5nO1xuXG4gIC8qKlxuICAgKiBUaGUgRXh0ZXJuYWxJZCB0aGF0IG5lZWRzIHRvIGJlIHN1cHBsaWVkIHdoaWxlIGFzc3VtaW5nIHRoaXMgcm9sZVxuICAgKlxuICAgKiBAZGVmYXVsdCAtIE5vIEV4dGVybmFsSWQgd2lsbCBiZSBzdXBwbGllZFxuICAgKi9cbiAgcmVhZG9ubHkgYXNzdW1lUm9sZUV4dGVybmFsSWQ/OiBzdHJpbmc7XG59XG4iXX0=
3
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYXdzLWRlc3RpbmF0aW9uLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiYXdzLWRlc3RpbmF0aW9uLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiIiLCJzb3VyY2VzQ29udGVudCI6WyIvKipcbiAqIERlc3RpbmF0aW9uIGZvciBhc3NldHMgdGhhdCBuZWVkIHRvIGJlIHVwbG9hZGVkIHRvIEFXU1xuICovXG5leHBvcnQgaW50ZXJmYWNlIEF3c0Rlc3RpbmF0aW9uIHtcbiAgLyoqXG4gICAqIFRoZSByZWdpb24gd2hlcmUgdGhpcyBhc3NldCB3aWxsIG5lZWQgdG8gYmUgcHVibGlzaGVkXG4gICAqXG4gICAqIEBkZWZhdWx0IC0gQ3VycmVudCByZWdpb25cbiAgICovXG4gIHJlYWRvbmx5IHJlZ2lvbj86IHN0cmluZztcblxuICAvKipcbiAgICogVGhlIHJvbGUgdGhhdCBuZWVkcyB0byBiZSBhc3N1bWVkIHdoaWxlIHB1Ymxpc2hpbmcgdGhpcyBhc3NldFxuICAgKlxuICAgKiBAZGVmYXVsdCAtIE5vIHJvbGUgd2lsbCBiZSBhc3N1bWVkXG4gICAqL1xuICByZWFkb25seSBhc3N1bWVSb2xlQXJuPzogc3RyaW5nO1xuXG4gIC8qKlxuICAgKiBUaGUgRXh0ZXJuYWxJZCB0aGF0IG5lZWRzIHRvIGJlIHN1cHBsaWVkIHdoaWxlIGFzc3VtaW5nIHRoaXMgcm9sZVxuICAgKlxuICAgKiBAZGVmYXVsdCAtIE5vIEV4dGVybmFsSWQgd2lsbCBiZSBzdXBwbGllZFxuICAgKi9cbiAgcmVhZG9ubHkgYXNzdW1lUm9sZUV4dGVybmFsSWQ/OiBzdHJpbmc7XG5cbiAgLyoqXG4gICAqIEFkZGl0aW9uYWwgb3B0aW9ucyB0byBwYXNzIHRvIFNUUyB3aGVuIGFzc3VtaW5nIHRoZSByb2xlLlxuICAgKlxuICAgKiAtIGBSb2xlQXJuYCBzaG91bGQgbm90IGJlIHVzZWQuIFVzZSB0aGUgZGVkaWNhdGVkIGBhc3N1bWVSb2xlQXJuYCBwcm9wZXJ0eSBpbnN0ZWFkLlxuICAgKiAtIGBFeHRlcm5hbElkYCBzaG91bGQgbm90IGJlIHVzZWQuIFVzZSB0aGUgZGVkaWNhdGVkIGBhc3N1bWVSb2xlRXh0ZXJuYWxJZGAgaW5zdGVhZC5cbiAgICpcbiAgICogQHNlZSBodHRwczovL2RvY3MuYXdzLmFtYXpvbi5jb20vQVdTSmF2YVNjcmlwdFNESy9sYXRlc3QvQVdTL1NUUy5odG1sI2Fzc3VtZVJvbGUtcHJvcGVydHlcbiAgICogQGRlZmF1bHQgLSBObyBhZGRpdGlvbmFsIG9wdGlvbnMuXG4gICAqL1xuICByZWFkb25seSBhc3N1bWVSb2xlQWRkaXRpb25hbE9wdGlvbnM/OiB7IFtrZXk6IHN0cmluZ106IGFueSB9O1xufVxuIl19
@@ -14,6 +14,18 @@ export interface BootstrapRole {
14
14
  * @default - No external ID
15
15
  */
16
16
  readonly assumeRoleExternalId?: string;
17
+ /**
18
+ * Additional options to pass to STS when assuming the role.
19
+ *
20
+ * - `RoleArn` should not be used. Use the dedicated `arn` property instead.
21
+ * - `ExternalId` should not be used. Use the dedicated `assumeRoleExternalId` instead.
22
+ *
23
+ * @see https://docs.aws.amazon.com/AWSJavaScriptSDK/latest/AWS/STS.html#assumeRole-property
24
+ * @default - No additional options.
25
+ */
26
+ readonly assumeRoleAdditionalOptions?: {
27
+ [key: string]: any;
28
+ };
17
29
  /**
18
30
  * Version of bootstrap stack required to use this role
19
31
  *
@@ -51,6 +63,12 @@ export interface AwsCloudFormationStackProperties {
51
63
  readonly tags?: {
52
64
  [id: string]: string;
53
65
  };
66
+ /**
67
+ * SNS Notification ARNs that should receive CloudFormation Stack Events.
68
+ *
69
+ * @default - No notification arns
70
+ */
71
+ readonly notificationArns?: string[];
54
72
  /**
55
73
  * The name to use for the CloudFormation stack.
56
74
  * @default - name derived from artifact ID
@@ -74,6 +92,18 @@ export interface AwsCloudFormationStackProperties {
74
92
  * @default - No external ID
75
93
  */
76
94
  readonly assumeRoleExternalId?: string;
95
+ /**
96
+ * Additional options to pass to STS when assuming the role.
97
+ *
98
+ * - `RoleArn` should not be used. Use the dedicated `assumeRoleArn` property instead.
99
+ * - `ExternalId` should not be used. Use the dedicated `assumeRoleExternalId` instead.
100
+ *
101
+ * @see https://docs.aws.amazon.com/AWSJavaScriptSDK/latest/AWS/STS.html#assumeRole-property
102
+ * @default - No additional options.
103
+ */
104
+ readonly assumeRoleAdditionalOptions?: {
105
+ [key: string]: any;
106
+ };
77
107
  /**
78
108
  * The role that is passed to CloudFormation to execute the change set
79
109
  *
@@ -1,3 +1,3 @@
1
1
  "use strict";
2
2
  Object.defineProperty(exports, "__esModule", { value: true });
3
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYXJ0aWZhY3Qtc2NoZW1hLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiYXJ0aWZhY3Qtc2NoZW1hLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiIiLCJzb3VyY2VzQ29udGVudCI6WyIvKipcbiAqIEluZm9ybWF0aW9uIG5lZWRlZCB0byBhY2Nlc3MgYW4gSUFNIHJvbGUgY3JlYXRlZFxuICogYXMgcGFydCBvZiB0aGUgYm9vdHN0cmFwIHByb2Nlc3NcbiAqL1xuZXhwb3J0IGludGVyZmFjZSBCb290c3RyYXBSb2xlIHtcbiAgLyoqXG4gICAqIFRoZSBBUk4gb2YgdGhlIElBTSByb2xlIGNyZWF0ZWQgYXMgcGFydCBvZiBib290cmFwcGluZ1xuICAgKiBlLmcuIGxvb2t1cFJvbGVBcm5cbiAgICovXG4gIHJlYWRvbmx5IGFybjogc3RyaW5nO1xuXG4gIC8qKlxuICAgKiBFeHRlcm5hbCBJRCB0byB1c2Ugd2hlbiBhc3N1bWluZyB0aGUgYm9vdHN0cmFwIHJvbGVcbiAgICpcbiAgICogQGRlZmF1bHQgLSBObyBleHRlcm5hbCBJRFxuICAgKi9cbiAgcmVhZG9ubHkgYXNzdW1lUm9sZUV4dGVybmFsSWQ/OiBzdHJpbmc7XG5cbiAgLyoqXG4gICAqIFZlcnNpb24gb2YgYm9vdHN0cmFwIHN0YWNrIHJlcXVpcmVkIHRvIHVzZSB0aGlzIHJvbGVcbiAgICpcbiAgICogQGRlZmF1bHQgLSBObyBib290c3RyYXAgc3RhY2sgcmVxdWlyZWRcbiAgICovXG4gIHJlYWRvbmx5IHJlcXVpcmVzQm9vdHN0cmFwU3RhY2tWZXJzaW9uPzogbnVtYmVyO1xuXG4gIC8qKlxuICAgKiBOYW1lIG9mIFNTTSBwYXJhbWV0ZXIgd2l0aCBib290c3RyYXAgc3RhY2sgdmVyc2lvblxuICAgKlxuICAgKiBAZGVmYXVsdCAtIERpc2NvdmVyIFNTTSBwYXJhbWV0ZXIgYnkgcmVhZGluZyBzdGFja1xuICAgKi9cbiAgcmVhZG9ubHkgYm9vdHN0cmFwU3RhY2tWZXJzaW9uU3NtUGFyYW1ldGVyPzogc3RyaW5nO1xufVxuXG4vKipcbiAqIEFydGlmYWN0IHByb3BlcnRpZXMgZm9yIENsb3VkRm9ybWF0aW9uIHN0YWNrcy5cbiAqL1xuZXhwb3J0IGludGVyZmFjZSBBd3NDbG91ZEZvcm1hdGlvblN0YWNrUHJvcGVydGllcyB7XG4gIC8qKlxuICAgKiBBIGZpbGUgcmVsYXRpdmUgdG8gdGhlIGFzc2VtYmx5IHJvb3Qgd2hpY2ggY29udGFpbnMgdGhlIENsb3VkRm9ybWF0aW9uIHRlbXBsYXRlIGZvciB0aGlzIHN0YWNrLlxuICAgKi9cbiAgcmVhZG9ubHkgdGVtcGxhdGVGaWxlOiBzdHJpbmc7XG5cbiAgLyoqXG4gICAqIFZhbHVlcyBmb3IgQ2xvdWRGb3JtYXRpb24gc3RhY2sgcGFyYW1ldGVycyB0aGF0IHNob3VsZCBiZSBwYXNzZWQgd2hlbiB0aGUgc3RhY2sgaXMgZGVwbG95ZWQuXG4gICAqXG4gICAqIEBkZWZhdWx0IC0gTm8gcGFyYW1ldGVyc1xuICAgKi9cbiAgcmVhZG9ubHkgcGFyYW1ldGVycz86IHsgW2lkOiBzdHJpbmddOiBzdHJpbmcgfTtcblxuICAvKipcbiAgICogVmFsdWVzIGZvciBDbG91ZEZvcm1hdGlvbiBzdGFjayB0YWdzIHRoYXQgc2hvdWxkIGJlIHBhc3NlZCB3aGVuIHRoZSBzdGFjayBpcyBkZXBsb3llZC5cbiAgICpcbiAgICogQGRlZmF1bHQgLSBObyB0YWdzXG4gICAqL1xuICByZWFkb25seSB0YWdzPzogeyBbaWQ6IHN0cmluZ106IHN0cmluZyB9O1xuXG4gIC8qKlxuICAgKiBUaGUgbmFtZSB0byB1c2UgZm9yIHRoZSBDbG91ZEZvcm1hdGlvbiBzdGFjay5cbiAgICogQGRlZmF1bHQgLSBuYW1lIGRlcml2ZWQgZnJvbSBhcnRpZmFjdCBJRFxuICAgKi9cbiAgcmVhZG9ubHkgc3RhY2tOYW1lPzogc3RyaW5nO1xuXG4gIC8qKlxuICAgKiBXaGV0aGVyIHRvIGVuYWJsZSB0ZXJtaW5hdGlvbiBwcm90ZWN0aW9uIGZvciB0aGlzIHN0YWNrLlxuICAgKlxuICAgKiBAZGVmYXVsdCBmYWxzZVxuICAgKi9cbiAgcmVhZG9ubHkgdGVybWluYXRpb25Qcm90ZWN0aW9uPzogYm9vbGVhbjtcblxuICAvKipcbiAgICogVGhlIHJvbGUgdGhhdCBuZWVkcyB0byBiZSBhc3N1bWVkIHRvIGRlcGxveSB0aGUgc3RhY2tcbiAgICpcbiAgICogQGRlZmF1bHQgLSBObyByb2xlIGlzIGFzc3VtZWQgKGN1cnJlbnQgY3JlZGVudGlhbHMgYXJlIHVzZWQpXG4gICAqL1xuICByZWFkb25seSBhc3N1bWVSb2xlQXJuPzogc3RyaW5nO1xuXG4gIC8qKlxuICAgKiBFeHRlcm5hbCBJRCB0byB1c2Ugd2hlbiBhc3N1bWluZyByb2xlIGZvciBjbG91ZGZvcm1hdGlvbiBkZXBsb3ltZW50c1xuICAgKlxuICAgKiBAZGVmYXVsdCAtIE5vIGV4dGVybmFsIElEXG4gICAqL1xuICByZWFkb25seSBhc3N1bWVSb2xlRXh0ZXJuYWxJZD86IHN0cmluZztcblxuICAvKipcbiAgICogVGhlIHJvbGUgdGhhdCBpcyBwYXNzZWQgdG8gQ2xvdWRGb3JtYXRpb24gdG8gZXhlY3V0ZSB0aGUgY2hhbmdlIHNldFxuICAgKlxuICAgKiBAZGVmYXVsdCAtIE5vIHJvbGUgaXMgcGFzc2VkIChjdXJyZW50bHkgYXNzdW1lZCByb2xlL2NyZWRlbnRpYWxzIGFyZSB1c2VkKVxuICAgKi9cbiAgcmVhZG9ubHkgY2xvdWRGb3JtYXRpb25FeGVjdXRpb25Sb2xlQXJuPzogc3RyaW5nO1xuXG4gIC8qKlxuICAgKiBUaGUgcm9sZSB0byB1c2UgdG8gbG9vayB1cCB2YWx1ZXMgZnJvbSB0aGUgdGFyZ2V0IEFXUyBhY2NvdW50XG4gICAqXG4gICAqIEBkZWZhdWx0IC0gTm8gcm9sZSBpcyBhc3N1bWVkIChjdXJyZW50IGNyZWRlbnRpYWxzIGFyZSB1c2VkKVxuICAgKi9cbiAgcmVhZG9ubHkgbG9va3VwUm9sZT86IEJvb3RzdHJhcFJvbGU7XG5cbiAgLyoqXG4gICAqIElmIHRoZSBzdGFjayB0ZW1wbGF0ZSBoYXMgYWxyZWFkeSBiZWVuIGluY2x1ZGVkIGluIHRoZSBhc3NldCBtYW5pZmVzdCwgaXRzIGFzc2V0IFVSTFxuICAgKlxuICAgKiBAZGVmYXVsdCAtIE5vdCB1cGxvYWRlZCB5ZXQsIHVwbG9hZCBqdXN0IGJlZm9yZSBkZXBsb3lpbmdcbiAgICovXG4gIHJlYWRvbmx5IHN0YWNrVGVtcGxhdGVBc3NldE9iamVjdFVybD86IHN0cmluZztcblxuICAvKipcbiAgICogVmVyc2lvbiBvZiBib290c3RyYXAgc3RhY2sgcmVxdWlyZWQgdG8gZGVwbG95IHRoaXMgc3RhY2tcbiAgICpcbiAgICogQGRlZmF1bHQgLSBObyBib290c3RyYXAgc3RhY2sgcmVxdWlyZWRcbiAgICovXG4gIHJlYWRvbmx5IHJlcXVpcmVzQm9vdHN0cmFwU3RhY2tWZXJzaW9uPzogbnVtYmVyO1xuXG4gIC8qKlxuICAgKiBTU00gcGFyYW1ldGVyIHdoZXJlIHRoZSBib290c3RyYXAgc3RhY2sgdmVyc2lvbiBudW1iZXIgY2FuIGJlIGZvdW5kXG4gICAqXG4gICAqIE9ubHkgdXNlZCBpZiBgcmVxdWlyZXNCb290c3RyYXBTdGFja1ZlcnNpb25gIGlzIHNldC5cbiAgICpcbiAgICogLSBJZiB0aGlzIHZhbHVlIGlzIG5vdCBzZXQsIHRoZSBib290c3RyYXAgc3RhY2sgbmFtZSBtdXN0IGJlIGtub3duIGF0XG4gICAqICAgZGVwbG95bWVudCB0aW1lIHNvIHRoZSBzdGFjayB2ZXJzaW9uIGNhbiBiZSBsb29rZWQgdXAgZnJvbSB0aGUgc3RhY2tcbiAgICogICBvdXRwdXRzLlxuICAgKiAtIElmIHRoaXMgdmFsdWUgaXMgc2V0LCB0aGUgYm9vdHN0cmFwIHN0YWNrIGNhbiBoYXZlIGFueSBuYW1lIGJlY2F1c2VcbiAgICogICB3ZSB3b24ndCBuZWVkIHRvIGxvb2sgaXQgdXAuXG4gICAqXG4gICAqIEBkZWZhdWx0IC0gQm9vdHN0cmFwIHN0YWNrIHZlcnNpb24gbnVtYmVyIGxvb2tlZCB1cFxuICAgKi9cbiAgcmVhZG9ubHkgYm9vdHN0cmFwU3RhY2tWZXJzaW9uU3NtUGFyYW1ldGVyPzogc3RyaW5nO1xuXG4gIC8qKlxuICAgKiBXaGV0aGVyIHRoaXMgc3RhY2sgc2hvdWxkIGJlIHZhbGlkYXRlZCBieSB0aGUgQ0xJIGFmdGVyIHN5bnRoZXNpc1xuICAgKlxuICAgKiBAZGVmYXVsdCAtIGZhbHNlXG4gICAqL1xuICByZWFkb25seSB2YWxpZGF0ZU9uU3ludGg/OiBib29sZWFuO1xufVxuXG4vKipcbiAqIENvbmZpZ3VyYXRpb24gb3B0aW9ucyBmb3IgdGhlIEFzc2V0IE1hbmlmZXN0XG4gKi9cbmV4cG9ydCBpbnRlcmZhY2UgQXNzZXRNYW5pZmVzdE9wdGlvbnMge1xuICAvKipcbiAgICogVmVyc2lvbiBvZiBib290c3RyYXAgc3RhY2sgcmVxdWlyZWQgdG8gZGVwbG95IHRoaXMgc3RhY2tcbiAgICpcbiAgICogQGRlZmF1bHQgLSBWZXJzaW9uIDEgKGJhc2ljIG1vZGVybiBib290c3RyYXAgc3RhY2spXG4gICAqL1xuICByZWFkb25seSByZXF1aXJlc0Jvb3RzdHJhcFN0YWNrVmVyc2lvbj86IG51bWJlcjtcblxuICAvKipcbiAgICogU1NNIHBhcmFtZXRlciB3aGVyZSB0aGUgYm9vdHN0cmFwIHN0YWNrIHZlcnNpb24gbnVtYmVyIGNhbiBiZSBmb3VuZFxuICAgKlxuICAgKiAtIElmIHRoaXMgdmFsdWUgaXMgbm90IHNldCwgdGhlIGJvb3RzdHJhcCBzdGFjayBuYW1lIG11c3QgYmUga25vd24gYXRcbiAgICogICBkZXBsb3ltZW50IHRpbWUgc28gdGhlIHN0YWNrIHZlcnNpb24gY2FuIGJlIGxvb2tlZCB1cCBmcm9tIHRoZSBzdGFja1xuICAgKiAgIG91dHB1dHMuXG4gICAqIC0gSWYgdGhpcyB2YWx1ZSBpcyBzZXQsIHRoZSBib290c3RyYXAgc3RhY2sgY2FuIGhhdmUgYW55IG5hbWUgYmVjYXVzZVxuICAgKiAgIHdlIHdvbid0IG5lZWQgdG8gbG9vayBpdCB1cC5cbiAgICpcbiAgICogQGRlZmF1bHQgLSBCb290c3RyYXAgc3RhY2sgdmVyc2lvbiBudW1iZXIgbG9va2VkIHVwXG4gICAqL1xuICByZWFkb25seSBib290c3RyYXBTdGFja1ZlcnNpb25Tc21QYXJhbWV0ZXI/OiBzdHJpbmc7XG59XG5cbi8qKlxuICogQXJ0aWZhY3QgcHJvcGVydGllcyBmb3IgdGhlIEFzc2V0IE1hbmlmZXN0XG4gKi9cbmV4cG9ydCBpbnRlcmZhY2UgQXNzZXRNYW5pZmVzdFByb3BlcnRpZXMgZXh0ZW5kcyBBc3NldE1hbmlmZXN0T3B0aW9ucyB7XG4gIC8qKlxuICAgKiBGaWxlbmFtZSBvZiB0aGUgYXNzZXQgbWFuaWZlc3RcbiAgICovXG4gIHJlYWRvbmx5IGZpbGU6IHN0cmluZztcbn1cblxuLyoqXG4gKiBBcnRpZmFjdCBwcm9wZXJ0aWVzIGZvciB0aGUgQ29uc3RydWN0IFRyZWUgQXJ0aWZhY3RcbiAqL1xuZXhwb3J0IGludGVyZmFjZSBUcmVlQXJ0aWZhY3RQcm9wZXJ0aWVzIHtcbiAgLyoqXG4gICAqIEZpbGVuYW1lIG9mIHRoZSB0cmVlIGFydGlmYWN0XG4gICAqL1xuICByZWFkb25seSBmaWxlOiBzdHJpbmc7XG59XG5cbi8qKlxuICogQXJ0aWZhY3QgcHJvcGVydGllcyBmb3IgbmVzdGVkIGNsb3VkIGFzc2VtYmxpZXNcbiAqL1xuZXhwb3J0IGludGVyZmFjZSBOZXN0ZWRDbG91ZEFzc2VtYmx5UHJvcGVydGllcyB7XG4gIC8qKlxuICAgKiBSZWxhdGl2ZSBwYXRoIHRvIHRoZSBuZXN0ZWQgY2xvdWQgYXNzZW1ibHlcbiAgICovXG4gIHJlYWRvbmx5IGRpcmVjdG9yeU5hbWU6IHN0cmluZztcblxuICAvKipcbiAgICogRGlzcGxheSBuYW1lIGZvciB0aGUgY2xvdWQgYXNzZW1ibHlcbiAgICpcbiAgICogQGRlZmF1bHQgLSBUaGUgYXJ0aWZhY3QgSURcbiAgICovXG4gIHJlYWRvbmx5IGRpc3BsYXlOYW1lPzogc3RyaW5nO1xufVxuXG4vKipcbiAqIFByb3BlcnRpZXMgZm9yIG1hbmlmZXN0IGFydGlmYWN0c1xuICovXG5leHBvcnQgdHlwZSBBcnRpZmFjdFByb3BlcnRpZXMgPVxuICB8IEF3c0Nsb3VkRm9ybWF0aW9uU3RhY2tQcm9wZXJ0aWVzXG4gIHwgQXNzZXRNYW5pZmVzdFByb3BlcnRpZXNcbiAgfCBUcmVlQXJ0aWZhY3RQcm9wZXJ0aWVzXG4gIHwgTmVzdGVkQ2xvdWRBc3NlbWJseVByb3BlcnRpZXM7XG4iXX0=
3
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"artifact-schema.js","sourceRoot":"","sources":["artifact-schema.ts"],"names":[],"mappings":"","sourcesContent":["/**\n * Information needed to access an IAM role created\n * as part of the bootstrap process\n */\nexport interface BootstrapRole {\n  /**\n   * The ARN of the IAM role created as part of bootrapping\n   * e.g. lookupRoleArn\n   */\n  readonly arn: string;\n\n  /**\n   * External ID to use when assuming the bootstrap role\n   *\n   * @default - No external ID\n   */\n  readonly assumeRoleExternalId?: string;\n\n  /**\n   * Additional options to pass to STS when assuming the role.\n   *\n   * - `RoleArn` should not be used. Use the dedicated `arn` property instead.\n   * - `ExternalId` should not be used. Use the dedicated `assumeRoleExternalId` instead.\n   *\n   * @see https://docs.aws.amazon.com/AWSJavaScriptSDK/latest/AWS/STS.html#assumeRole-property\n   * @default - No additional options.\n   */\n  readonly assumeRoleAdditionalOptions?: { [key: string]: any };\n\n  /**\n   * Version of bootstrap stack required to use this role\n   *\n   * @default - No bootstrap stack required\n   */\n  readonly requiresBootstrapStackVersion?: number;\n\n  /**\n   * Name of SSM parameter with bootstrap stack version\n   *\n   * @default - Discover SSM parameter by reading stack\n   */\n  readonly bootstrapStackVersionSsmParameter?: string;\n}\n\n/**\n * Artifact properties for CloudFormation stacks.\n */\nexport interface AwsCloudFormationStackProperties {\n  /**\n   * A file relative to the assembly root which contains the CloudFormation template for this stack.\n   */\n  readonly templateFile: string;\n\n  /**\n   * Values for CloudFormation stack parameters that should be passed when the stack is deployed.\n   *\n   * @default - No parameters\n   */\n  readonly parameters?: { [id: string]: string };\n\n  /**\n   * Values for CloudFormation stack tags that should be passed when the stack is deployed.\n   *\n   * @default - No tags\n   */\n  readonly tags?: { [id: string]: string };\n\n  /**\n   * SNS Notification ARNs that should receive CloudFormation Stack Events.\n   *\n   * @default - No notification arns\n   */\n  readonly notificationArns?: string[];\n\n  /**\n   * The name to use for the CloudFormation stack.\n   * @default - name derived from artifact ID\n   */\n  readonly stackName?: string;\n\n  /**\n   * Whether to enable termination protection for this stack.\n   *\n   * @default false\n   */\n  readonly terminationProtection?: boolean;\n\n  /**\n   * The role that needs to be assumed to deploy the stack\n   *\n   * @default - No role is assumed (current credentials are used)\n   */\n  readonly assumeRoleArn?: string;\n\n  /**\n   * External ID to use when assuming role for cloudformation deployments\n   *\n   * @default - No external ID\n   */\n  readonly assumeRoleExternalId?: string;\n\n  /**\n   * Additional options to pass to STS when assuming the role.\n   *\n   * - `RoleArn` should not be used. Use the dedicated `assumeRoleArn` property instead.\n   * - `ExternalId` should not be used. Use the dedicated `assumeRoleExternalId` instead.\n   *\n   * @see https://docs.aws.amazon.com/AWSJavaScriptSDK/latest/AWS/STS.html#assumeRole-property\n   * @default - No additional options.\n   */\n  readonly assumeRoleAdditionalOptions?: { [key: string]: any };\n\n  /**\n   * The role that is passed to CloudFormation to execute the change set\n   *\n   * @default - No role is passed (currently assumed role/credentials are used)\n   */\n  readonly cloudFormationExecutionRoleArn?: string;\n\n  /**\n   * The role to use to look up values from the target AWS account\n   *\n   * @default - No role is assumed (current credentials are used)\n   */\n  readonly lookupRole?: BootstrapRole;\n\n  /**\n   * If the stack template has already been included in the asset manifest, its asset URL\n   *\n   * @default - Not uploaded yet, upload just before deploying\n   */\n  readonly stackTemplateAssetObjectUrl?: string;\n\n  /**\n   * Version of bootstrap stack required to deploy this stack\n   *\n   * @default - No bootstrap stack required\n   */\n  readonly requiresBootstrapStackVersion?: number;\n\n  /**\n   * SSM parameter where the bootstrap stack version number can be found\n   *\n   * Only used if `requiresBootstrapStackVersion` is set.\n   *\n   * - If this value is not set, the bootstrap stack name must be known at\n   *   deployment time so the stack version can be looked up from the stack\n   *   outputs.\n   * - If this value is set, the bootstrap stack can have any name because\n   *   we won't need to look it up.\n   *\n   * @default - Bootstrap stack version number looked up\n   */\n  readonly bootstrapStackVersionSsmParameter?: string;\n\n  /**\n   * Whether this stack should be validated by the CLI after synthesis\n   *\n   * @default - false\n   */\n  readonly validateOnSynth?: boolean;\n}\n\n/**\n * Configuration options for the Asset Manifest\n */\nexport interface AssetManifestOptions {\n  /**\n   * Version of bootstrap stack required to deploy this stack\n   *\n   * @default - Version 1 (basic modern bootstrap stack)\n   */\n  readonly requiresBootstrapStackVersion?: number;\n\n  /**\n   * SSM parameter where the bootstrap stack version number can be found\n   *\n   * - If this value is not set, the bootstrap stack name must be known at\n   *   deployment time so the stack version can be looked up from the stack\n   *   outputs.\n   * - If this value is set, the bootstrap stack can have any name because\n   *   we won't need to look it up.\n   *\n   * @default - Bootstrap stack version number looked up\n   */\n  readonly bootstrapStackVersionSsmParameter?: string;\n}\n\n/**\n * Artifact properties for the Asset Manifest\n */\nexport interface AssetManifestProperties extends AssetManifestOptions {\n  /**\n   * Filename of the asset manifest\n   */\n  readonly file: string;\n}\n\n/**\n * Artifact properties for the Construct Tree Artifact\n */\nexport interface TreeArtifactProperties {\n  /**\n   * Filename of the tree artifact\n   */\n  readonly file: string;\n}\n\n/**\n * Artifact properties for nested cloud assemblies\n */\nexport interface NestedCloudAssemblyProperties {\n  /**\n   * Relative path to the nested cloud assembly\n   */\n  readonly directoryName: string;\n\n  /**\n   * Display name for the cloud assembly\n   *\n   * @default - The artifact ID\n   */\n  readonly displayName?: string;\n}\n\n/**\n * Properties for manifest artifacts\n */\nexport type ArtifactProperties =\n  | AwsCloudFormationStackProperties\n  | AssetManifestProperties\n  | TreeArtifactProperties\n  | NestedCloudAssemblyProperties;\n"]}
@@ -49,15 +49,15 @@ export declare enum ContextProvider {
49
49
  PLUGIN = "plugin"
50
50
  }
51
51
  /**
52
- * Query to AMI context provider
52
+ * Options for context lookup roles.
53
53
  */
54
- export interface AmiContextQuery {
54
+ export interface ContextLookupRoleOptions {
55
55
  /**
56
- * Account to query
56
+ * Query account
57
57
  */
58
58
  readonly account: string;
59
59
  /**
60
- * Region to query
60
+ * Query region
61
61
  */
62
62
  readonly region: string;
63
63
  /**
@@ -66,6 +66,29 @@ export interface AmiContextQuery {
66
66
  * @default - None
67
67
  */
68
68
  readonly lookupRoleArn?: string;
69
+ /**
70
+ * The ExternalId that needs to be supplied while assuming this role
71
+ *
72
+ * @default - No ExternalId will be supplied
73
+ */
74
+ readonly lookupRoleExternalId?: string;
75
+ /**
76
+ * Additional options to pass to STS when assuming the lookup role.
77
+ *
78
+ * - `RoleArn` should not be used. Use the dedicated `lookupRoleArn` property instead.
79
+ * - `ExternalId` should not be used. Use the dedicated `lookupRoleExternalId` instead.
80
+ *
81
+ * @see https://docs.aws.amazon.com/AWSJavaScriptSDK/latest/AWS/STS.html#assumeRole-property
82
+ * @default - No additional options.
83
+ */
84
+ readonly assumeRoleAdditionalOptions?: {
85
+ [key: string]: any;
86
+ };
87
+ }
88
+ /**
89
+ * Query to AMI context provider
90
+ */
91
+ export interface AmiContextQuery extends ContextLookupRoleOptions {
69
92
  /**
70
93
  * Owners to DescribeImages call
71
94
  *
@@ -82,40 +105,12 @@ export interface AmiContextQuery {
82
105
  /**
83
106
  * Query to availability zone context provider
84
107
  */
85
- export interface AvailabilityZonesContextQuery {
86
- /**
87
- * Query account
88
- */
89
- readonly account: string;
90
- /**
91
- * Query region
92
- */
93
- readonly region: string;
94
- /**
95
- * The ARN of the role that should be used to look up the missing values
96
- *
97
- * @default - None
98
- */
99
- readonly lookupRoleArn?: string;
108
+ export interface AvailabilityZonesContextQuery extends ContextLookupRoleOptions {
100
109
  }
101
110
  /**
102
111
  * Query to hosted zone context provider
103
112
  */
104
- export interface HostedZoneContextQuery {
105
- /**
106
- * Query account
107
- */
108
- readonly account: string;
109
- /**
110
- * Query region
111
- */
112
- readonly region: string;
113
- /**
114
- * The ARN of the role that should be used to look up the missing values
115
- *
116
- * @default - None
117
- */
118
- readonly lookupRoleArn?: string;
113
+ export interface HostedZoneContextQuery extends ContextLookupRoleOptions {
119
114
  /**
120
115
  * The domain name e.g. example.com to lookup
121
116
  */
@@ -139,21 +134,7 @@ export interface HostedZoneContextQuery {
139
134
  /**
140
135
  * Query to SSM Parameter Context Provider
141
136
  */
142
- export interface SSMParameterContextQuery {
143
- /**
144
- * Query account
145
- */
146
- readonly account: string;
147
- /**
148
- * Query region
149
- */
150
- readonly region: string;
151
- /**
152
- * The ARN of the role that should be used to look up the missing values
153
- *
154
- * @default - None
155
- */
156
- readonly lookupRoleArn?: string;
137
+ export interface SSMParameterContextQuery extends ContextLookupRoleOptions {
157
138
  /**
158
139
  * Parameter name to query
159
140
  */
@@ -162,21 +143,7 @@ export interface SSMParameterContextQuery {
162
143
  /**
163
144
  * Query input for looking up a VPC
164
145
  */
165
- export interface VpcContextQuery {
166
- /**
167
- * Query account
168
- */
169
- readonly account: string;
170
- /**
171
- * Query region
172
- */
173
- readonly region: string;
174
- /**
175
- * The ARN of the role that should be used to look up the missing values
176
- *
177
- * @default - None
178
- */
179
- readonly lookupRoleArn?: string;
146
+ export interface VpcContextQuery extends ContextLookupRoleOptions {
180
147
  /**
181
148
  * Filters to apply to the VPC
182
149
  *
@@ -216,21 +183,7 @@ export interface VpcContextQuery {
216
183
  /**
217
184
  * Query to endpoint service context provider
218
185
  */
219
- export interface EndpointServiceAvailabilityZonesContextQuery {
220
- /**
221
- * Query account
222
- */
223
- readonly account: string;
224
- /**
225
- * Query region
226
- */
227
- readonly region: string;
228
- /**
229
- * The ARN of the role that should be used to look up the missing values
230
- *
231
- * @default - None
232
- */
233
- readonly lookupRoleArn?: string;
186
+ export interface EndpointServiceAvailabilityZonesContextQuery extends ContextLookupRoleOptions {
234
187
  /**
235
188
  * Query service name
236
189
  */
@@ -252,7 +205,7 @@ export declare enum LoadBalancerType {
252
205
  /**
253
206
  * Filters for selecting load balancers
254
207
  */
255
- export interface LoadBalancerFilter {
208
+ export interface LoadBalancerFilter extends ContextLookupRoleOptions {
256
209
  /**
257
210
  * Filter load balancers by their type
258
211
  */
@@ -272,20 +225,6 @@ export interface LoadBalancerFilter {
272
225
  * Query input for looking up a load balancer
273
226
  */
274
227
  export interface LoadBalancerContextQuery extends LoadBalancerFilter {
275
- /**
276
- * Query account
277
- */
278
- readonly account: string;
279
- /**
280
- * Query region
281
- */
282
- readonly region: string;
283
- /**
284
- * The ARN of the role that should be used to look up the missing values
285
- *
286
- * @default - None
287
- */
288
- readonly lookupRoleArn?: string;
289
228
  }
290
229
  /**
291
230
  * The protocol for connections from clients to the load balancer
@@ -320,20 +259,6 @@ export declare enum LoadBalancerListenerProtocol {
320
259
  * Query input for looking up a load balancer listener
321
260
  */
322
261
  export interface LoadBalancerListenerContextQuery extends LoadBalancerFilter {
323
- /**
324
- * Query account
325
- */
326
- readonly account: string;
327
- /**
328
- * Query region
329
- */
330
- readonly region: string;
331
- /**
332
- * The ARN of the role that should be used to look up the missing values
333
- *
334
- * @default - None
335
- */
336
- readonly lookupRoleArn?: string;
337
262
  /**
338
263
  * Find by listener's arn
339
264
  * @default - does not find by listener arn
@@ -353,21 +278,7 @@ export interface LoadBalancerListenerContextQuery extends LoadBalancerFilter {
353
278
  /**
354
279
  * Query input for looking up a security group
355
280
  */
356
- export interface SecurityGroupContextQuery {
357
- /**
358
- * Query account
359
- */
360
- readonly account: string;
361
- /**
362
- * Query region
363
- */
364
- readonly region: string;
365
- /**
366
- * The ARN of the role that should be used to look up the missing values
367
- *
368
- * @default - None
369
- */
370
- readonly lookupRoleArn?: string;
281
+ export interface SecurityGroupContextQuery extends ContextLookupRoleOptions {
371
282
  /**
372
283
  * Security group id
373
284
  *
@@ -390,21 +301,7 @@ export interface SecurityGroupContextQuery {
390
301
  /**
391
302
  * Query input for looking up a KMS Key
392
303
  */
393
- export interface KeyContextQuery {
394
- /**
395
- * Query account
396
- */
397
- readonly account: string;
398
- /**
399
- * Query region
400
- */
401
- readonly region: string;
402
- /**
403
- * The ARN of the role that should be used to look up the missing values
404
- *
405
- * @default - None
406
- */
407
- readonly lookupRoleArn?: string;
304
+ export interface KeyContextQuery extends ContextLookupRoleOptions {
408
305
  /**
409
306
  * Alias name used to search the Key
410
307
  */
@@ -95,4 +95,4 @@ var LoadBalancerListenerProtocol;
95
95
  * */
96
96
  LoadBalancerListenerProtocol["TCP_UDP"] = "TCP_UDP";
97
97
  })(LoadBalancerListenerProtocol || (exports.LoadBalancerListenerProtocol = LoadBalancerListenerProtocol = {}));
98
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"context-queries.js","sourceRoot":"","sources":["context-queries.ts"],"names":[],"mappings":";;;AAEA;;GAEG;AACH,IAAY,eAuDX;AAvDD,WAAY,eAAe;IACzB;;OAEG;IACH,uCAAoB,CAAA;IAEpB;;OAEG;IACH,oEAAiD,CAAA;IAEjD;;OAEG;IACH,uDAAoC,CAAA;IAEpC;;OAEG;IACH,iDAA8B,CAAA;IAE9B;;OAEG;IACH,gDAA6B,CAAA;IAE7B;;OAEG;IACH,sGAAmF,CAAA;IAEnF;;OAEG;IACH,2DAAwC,CAAA;IAExC;;OAEG;IACH,6EAA0D,CAAA;IAE1D;;OAEG;IACH,6DAA0C,CAAA;IAE1C;;OAEG;IACH,gDAA6B,CAAA;IAE7B;;OAEG;IACH,oCAAiB,CAAA;AACnB,CAAC,EAvDW,eAAe,+BAAf,eAAe,QAuD1B;AAuND;;GAEG;AACH,IAAY,gBAUX;AAVD,WAAY,gBAAgB;IAC1B;;OAEG;IACH,uCAAmB,CAAA;IAEnB;;OAEG;IACH,+CAA2B,CAAA;AAC7B,CAAC,EAVW,gBAAgB,gCAAhB,gBAAgB,QAU3B;AA8CD;;GAEG;AACH,IAAY,4BA8BX;AA9BD,WAAY,4BAA4B;IACtC;;OAEG;IACH,6CAAa,CAAA;IAEb;;OAEG;IACH,+CAAe,CAAA;IAEf;;OAEG;IACH,2CAAW,CAAA;IAEX;;OAEG;IACH,2CAAW,CAAA;IAEX;;SAEK;IACL,2CAAW,CAAA;IAEX;;SAEK;IACL,mDAAmB,CAAA;AACrB,CAAC,EA9BW,4BAA4B,4CAA5B,4BAA4B,QA8BvC","sourcesContent":["import { Tag } from './metadata-schema';\n\n/**\n * Identifier for the context provider\n */\nexport enum ContextProvider {\n  /**\n   * AMI provider\n   */\n  AMI_PROVIDER = 'ami',\n\n  /**\n   * AZ provider\n   */\n  AVAILABILITY_ZONE_PROVIDER = 'availability-zones',\n\n  /**\n   * Route53 Hosted Zone provider\n   */\n  HOSTED_ZONE_PROVIDER = 'hosted-zone',\n\n  /**\n   * SSM Parameter Provider\n   */\n  SSM_PARAMETER_PROVIDER = 'ssm',\n\n  /**\n   * VPC Provider\n   */\n  VPC_PROVIDER = 'vpc-provider',\n\n  /**\n   * VPC Endpoint Service AZ Provider\n   */\n  ENDPOINT_SERVICE_AVAILABILITY_ZONE_PROVIDER = 'endpoint-service-availability-zones',\n\n  /**\n   * Load balancer provider\n   */\n  LOAD_BALANCER_PROVIDER = 'load-balancer',\n\n  /**\n   * Load balancer listener provider\n   */\n  LOAD_BALANCER_LISTENER_PROVIDER = 'load-balancer-listener',\n\n  /**\n   * Security group provider\n   */\n  SECURITY_GROUP_PROVIDER = 'security-group',\n\n  /**\n   * KMS Key Provider\n   */\n  KEY_PROVIDER = 'key-provider',\n\n  /**\n   * A plugin provider (the actual plugin name will be in the properties)\n   */\n  PLUGIN = 'plugin',\n}\n\n/**\n * Query to AMI context provider\n */\nexport interface AmiContextQuery {\n  /**\n   * Account to query\n   */\n  readonly account: string;\n\n  /**\n   * Region to query\n   */\n  readonly region: string;\n\n  /**\n   * The ARN of the role that should be used to look up the missing values\n   *\n   * @default - None\n   */\n  readonly lookupRoleArn?: string;\n\n  /**\n   * Owners to DescribeImages call\n   *\n   * @default - All owners\n   */\n  readonly owners?: string[];\n\n  /**\n   * Filters to DescribeImages call\n   */\n  readonly filters: { [key: string]: string[] };\n}\n\n/**\n * Query to availability zone context provider\n */\nexport interface AvailabilityZonesContextQuery {\n  /**\n   * Query account\n   */\n  readonly account: string;\n\n  /**\n   * Query region\n   */\n  readonly region: string;\n\n  /**\n   * The ARN of the role that should be used to look up the missing values\n   *\n   * @default - None\n   */\n  readonly lookupRoleArn?: string;\n}\n\n/**\n * Query to hosted zone context provider\n */\nexport interface HostedZoneContextQuery {\n  /**\n   * Query account\n   */\n  readonly account: string;\n\n  /**\n   * Query region\n   */\n  readonly region: string;\n\n  /**\n   * The ARN of the role that should be used to look up the missing values\n   *\n   * @default - None\n   */\n  readonly lookupRoleArn?: string;\n\n  /**\n   * The domain name e.g. example.com to lookup\n   */\n  readonly domainName: string;\n\n  /**\n   * True if the zone you want to find is a private hosted zone\n   *\n   * @default false\n   */\n  readonly privateZone?: boolean;\n\n  /**\n   * The VPC ID to that the private zone must be associated with\n   *\n   * If you provide VPC ID and privateZone is false, this will return no results\n   * and raise an error.\n   *\n   * @default - Required if privateZone=true\n   */\n  readonly vpcId?: string;\n}\n\n/**\n * Query to SSM Parameter Context Provider\n */\nexport interface SSMParameterContextQuery {\n  /**\n   * Query account\n   */\n  readonly account: string;\n\n  /**\n   * Query region\n   */\n  readonly region: string;\n\n  /**\n   * The ARN of the role that should be used to look up the missing values\n   *\n   * @default - None\n   */\n  readonly lookupRoleArn?: string;\n\n  /**\n   * Parameter name to query\n   */\n  readonly parameterName: string;\n}\n\n/**\n * Query input for looking up a VPC\n */\nexport interface VpcContextQuery {\n  /**\n   * Query account\n   */\n  readonly account: string;\n\n  /**\n   * Query region\n   */\n  readonly region: string;\n\n  /**\n   * The ARN of the role that should be used to look up the missing values\n   *\n   * @default - None\n   */\n  readonly lookupRoleArn?: string;\n\n  /**\n   * Filters to apply to the VPC\n   *\n   * Filter parameters are the same as passed to DescribeVpcs.\n   *\n   * @see https://docs.aws.amazon.com/AWSEC2/latest/APIReference/API_DescribeVpcs.html\n   */\n  readonly filter: { [key: string]: string };\n\n  /**\n   * Whether to populate the subnetGroups field of the `VpcContextResponse`,\n   * which contains potentially asymmetric subnet groups.\n   *\n   * @default false\n   */\n  readonly returnAsymmetricSubnets?: boolean;\n\n  /**\n   * Optional tag for subnet group name.\n   * If not provided, we'll look at the aws-cdk:subnet-name tag.\n   * If the subnet does not have the specified tag,\n   * we'll use its type as the name.\n   *\n   * @default 'aws-cdk:subnet-name'\n   */\n  readonly subnetGroupNameTag?: string;\n\n  /**\n   * Whether to populate the `vpnGatewayId` field of the `VpcContextResponse`,\n   * which contains the VPN Gateway ID, if one exists. You can explicitly\n   * disable this in order to avoid the lookup if you know the VPC does not have\n   * a VPN Gatway attached.\n   *\n   * @default true\n   */\n  readonly returnVpnGateways?: boolean;\n}\n\n/**\n * Query to endpoint service context provider\n */\nexport interface EndpointServiceAvailabilityZonesContextQuery {\n  /**\n   * Query account\n   */\n  readonly account: string;\n\n  /**\n   * Query region\n   */\n  readonly region: string;\n\n  /**\n   * The ARN of the role that should be used to look up the missing values\n   *\n   * @default - None\n   */\n  readonly lookupRoleArn?: string;\n\n  /**\n   * Query service name\n   */\n  readonly serviceName: string;\n}\n\n/**\n * Type of load balancer\n */\nexport enum LoadBalancerType {\n  /**\n   * Network load balancer\n   */\n  NETWORK = 'network',\n\n  /**\n   * Application load balancer\n   */\n  APPLICATION = 'application',\n}\n\n/**\n * Filters for selecting load balancers\n */\nexport interface LoadBalancerFilter {\n  /**\n   * Filter load balancers by their type\n   */\n  readonly loadBalancerType: LoadBalancerType;\n\n  /**\n   * Find by load balancer's ARN\n   * @default - does not search by load balancer arn\n   */\n  readonly loadBalancerArn?: string;\n\n  /**\n   * Match load balancer tags\n   * @default - does not match load balancers by tags\n   */\n  readonly loadBalancerTags?: Tag[];\n}\n\n/**\n * Query input for looking up a load balancer\n */\nexport interface LoadBalancerContextQuery extends LoadBalancerFilter {\n  /**\n   * Query account\n   */\n  readonly account: string;\n\n  /**\n   * Query region\n   */\n  readonly region: string;\n\n  /**\n   * The ARN of the role that should be used to look up the missing values\n   *\n   * @default - None\n   */\n  readonly lookupRoleArn?: string;\n}\n\n/**\n * The protocol for connections from clients to the load balancer\n */\nexport enum LoadBalancerListenerProtocol {\n  /**\n   * HTTP protocol\n   */\n  HTTP = 'HTTP',\n\n  /**\n   * HTTPS protocol\n   */\n  HTTPS = 'HTTPS',\n\n  /**\n   * TCP protocol\n   */\n  TCP = 'TCP',\n\n  /**\n   * TLS protocol\n   */\n  TLS = 'TLS',\n\n  /**\n   * UDP protocol\n   * */\n  UDP = 'UDP',\n\n  /**\n   * TCP and UDP protocol\n   * */\n  TCP_UDP = 'TCP_UDP',\n}\n\n/**\n * Query input for looking up a load balancer listener\n */\nexport interface LoadBalancerListenerContextQuery extends LoadBalancerFilter {\n  /**\n   * Query account\n   */\n  readonly account: string;\n\n  /**\n   * Query region\n   */\n  readonly region: string;\n\n  /**\n   * The ARN of the role that should be used to look up the missing values\n   *\n   * @default - None\n   */\n  readonly lookupRoleArn?: string;\n\n  /**\n   * Find by listener's arn\n   * @default - does not find by listener arn\n   */\n  readonly listenerArn?: string;\n\n  /**\n   * Filter by listener protocol\n   * @default - does not filter by listener protocol\n   */\n  readonly listenerProtocol?: LoadBalancerListenerProtocol;\n\n  /**\n   * Filter listeners by listener port\n   * @default - does not filter by a listener port\n   */\n  readonly listenerPort?: number;\n}\n\n/**\n * Query input for looking up a security group\n */\nexport interface SecurityGroupContextQuery {\n  /**\n   * Query account\n   */\n  readonly account: string;\n\n  /**\n   * Query region\n   */\n  readonly region: string;\n\n  /**\n   * The ARN of the role that should be used to look up the missing values\n   *\n   * @default - None\n   */\n  readonly lookupRoleArn?: string;\n\n  /**\n   * Security group id\n   *\n   * @default - None\n   */\n  readonly securityGroupId?: string;\n\n  /**\n   * Security group name\n   *\n   * @default - None\n   */\n  readonly securityGroupName?: string;\n\n  /**\n   * VPC ID\n   *\n   * @default - None\n   */\n  readonly vpcId?: string;\n}\n\n/**\n * Query input for looking up a KMS Key\n */\nexport interface KeyContextQuery {\n  /**\n   * Query account\n   */\n  readonly account: string;\n\n  /**\n   * Query region\n   */\n  readonly region: string;\n\n  /**\n   * The ARN of the role that should be used to look up the missing values\n   *\n   * @default - None\n   */\n  readonly lookupRoleArn?: string;\n\n  /**\n   * Alias name used to search the Key\n   */\n  readonly aliasName: string;\n}\n\n/**\n * Query input for plugins\n *\n * This alternate branch is necessary because it needs to be able to escape all type checking\n * we do on on the cloud assembly -- we cannot know the properties that will be used a priori.\n */\nexport interface PluginContextQuery {\n  /**\n   * The name of the plugin\n   */\n  readonly pluginName: string;\n\n  /**\n   * Arbitrary other arguments for the plugin.\n   *\n   * This index signature is not usable in non-TypeScript/JavaScript languages.\n   *\n   * @jsii ignore\n   */\n  [key: string]: any;\n}\n\nexport type ContextQueryProperties =\n  | AmiContextQuery\n  | AvailabilityZonesContextQuery\n  | HostedZoneContextQuery\n  | SSMParameterContextQuery\n  | VpcContextQuery\n  | EndpointServiceAvailabilityZonesContextQuery\n  | LoadBalancerContextQuery\n  | LoadBalancerListenerContextQuery\n  | SecurityGroupContextQuery\n  | KeyContextQuery\n  | PluginContextQuery;\n"]}
98
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"context-queries.js","sourceRoot":"","sources":["context-queries.ts"],"names":[],"mappings":";;;AAEA;;GAEG;AACH,IAAY,eAuDX;AAvDD,WAAY,eAAe;IACzB;;OAEG;IACH,uCAAoB,CAAA;IAEpB;;OAEG;IACH,oEAAiD,CAAA;IAEjD;;OAEG;IACH,uDAAoC,CAAA;IAEpC;;OAEG;IACH,iDAA8B,CAAA;IAE9B;;OAEG;IACH,gDAA6B,CAAA;IAE7B;;OAEG;IACH,sGAAmF,CAAA;IAEnF;;OAEG;IACH,2DAAwC,CAAA;IAExC;;OAEG;IACH,6EAA0D,CAAA;IAE1D;;OAEG;IACH,6DAA0C,CAAA;IAE1C;;OAEG;IACH,gDAA6B,CAAA;IAE7B;;OAEG;IACH,oCAAiB,CAAA;AACnB,CAAC,EAvDW,eAAe,+BAAf,eAAe,QAuD1B;AAyJD;;GAEG;AACH,IAAY,gBAUX;AAVD,WAAY,gBAAgB;IAC1B;;OAEG;IACH,uCAAmB,CAAA;IAEnB;;OAEG;IACH,+CAA2B,CAAA;AAC7B,CAAC,EAVW,gBAAgB,gCAAhB,gBAAgB,QAU3B;AA6BD;;GAEG;AACH,IAAY,4BA8BX;AA9BD,WAAY,4BAA4B;IACtC;;OAEG;IACH,6CAAa,CAAA;IAEb;;OAEG;IACH,+CAAe,CAAA;IAEf;;OAEG;IACH,2CAAW,CAAA;IAEX;;OAEG;IACH,2CAAW,CAAA;IAEX;;SAEK;IACL,2CAAW,CAAA;IAEX;;SAEK;IACL,mDAAmB,CAAA;AACrB,CAAC,EA9BW,4BAA4B,4CAA5B,4BAA4B,QA8BvC","sourcesContent":["import { Tag } from './metadata-schema';\n\n/**\n * Identifier for the context provider\n */\nexport enum ContextProvider {\n  /**\n   * AMI provider\n   */\n  AMI_PROVIDER = 'ami',\n\n  /**\n   * AZ provider\n   */\n  AVAILABILITY_ZONE_PROVIDER = 'availability-zones',\n\n  /**\n   * Route53 Hosted Zone provider\n   */\n  HOSTED_ZONE_PROVIDER = 'hosted-zone',\n\n  /**\n   * SSM Parameter Provider\n   */\n  SSM_PARAMETER_PROVIDER = 'ssm',\n\n  /**\n   * VPC Provider\n   */\n  VPC_PROVIDER = 'vpc-provider',\n\n  /**\n   * VPC Endpoint Service AZ Provider\n   */\n  ENDPOINT_SERVICE_AVAILABILITY_ZONE_PROVIDER = 'endpoint-service-availability-zones',\n\n  /**\n   * Load balancer provider\n   */\n  LOAD_BALANCER_PROVIDER = 'load-balancer',\n\n  /**\n   * Load balancer listener provider\n   */\n  LOAD_BALANCER_LISTENER_PROVIDER = 'load-balancer-listener',\n\n  /**\n   * Security group provider\n   */\n  SECURITY_GROUP_PROVIDER = 'security-group',\n\n  /**\n   * KMS Key Provider\n   */\n  KEY_PROVIDER = 'key-provider',\n\n  /**\n   * A plugin provider (the actual plugin name will be in the properties)\n   */\n  PLUGIN = 'plugin',\n}\n\n/**\n * Options for context lookup roles.\n */\nexport interface ContextLookupRoleOptions {\n  /**\n   * Query account\n   */\n  readonly account: string;\n\n  /**\n   * Query region\n   */\n  readonly region: string;\n\n  /**\n   * The ARN of the role that should be used to look up the missing values\n   *\n   * @default - None\n   */\n  readonly lookupRoleArn?: string;\n\n  /**\n   * The ExternalId that needs to be supplied while assuming this role\n   *\n   * @default - No ExternalId will be supplied\n   */\n  readonly lookupRoleExternalId?: string;\n\n  /**\n   * Additional options to pass to STS when assuming the lookup role.\n   *\n   * - `RoleArn` should not be used. Use the dedicated `lookupRoleArn` property instead.\n   * - `ExternalId` should not be used. Use the dedicated `lookupRoleExternalId` instead.\n   *\n   * @see https://docs.aws.amazon.com/AWSJavaScriptSDK/latest/AWS/STS.html#assumeRole-property\n   * @default - No additional options.\n   */\n  readonly assumeRoleAdditionalOptions?: { [key: string]: any };\n}\n\n/**\n * Query to AMI context provider\n */\nexport interface AmiContextQuery extends ContextLookupRoleOptions {\n  /**\n   * Owners to DescribeImages call\n   *\n   * @default - All owners\n   */\n  readonly owners?: string[];\n\n  /**\n   * Filters to DescribeImages call\n   */\n  readonly filters: { [key: string]: string[] };\n}\n\n/**\n * Query to availability zone context provider\n */\nexport interface AvailabilityZonesContextQuery extends ContextLookupRoleOptions {}\n\n/**\n * Query to hosted zone context provider\n */\nexport interface HostedZoneContextQuery extends ContextLookupRoleOptions {\n  /**\n   * The domain name e.g. example.com to lookup\n   */\n  readonly domainName: string;\n\n  /**\n   * True if the zone you want to find is a private hosted zone\n   *\n   * @default false\n   */\n  readonly privateZone?: boolean;\n\n  /**\n   * The VPC ID to that the private zone must be associated with\n   *\n   * If you provide VPC ID and privateZone is false, this will return no results\n   * and raise an error.\n   *\n   * @default - Required if privateZone=true\n   */\n  readonly vpcId?: string;\n}\n\n/**\n * Query to SSM Parameter Context Provider\n */\nexport interface SSMParameterContextQuery extends ContextLookupRoleOptions {\n  /**\n   * Parameter name to query\n   */\n  readonly parameterName: string;\n}\n\n/**\n * Query input for looking up a VPC\n */\nexport interface VpcContextQuery extends ContextLookupRoleOptions {\n  /**\n   * Filters to apply to the VPC\n   *\n   * Filter parameters are the same as passed to DescribeVpcs.\n   *\n   * @see https://docs.aws.amazon.com/AWSEC2/latest/APIReference/API_DescribeVpcs.html\n   */\n  readonly filter: { [key: string]: string };\n\n  /**\n   * Whether to populate the subnetGroups field of the `VpcContextResponse`,\n   * which contains potentially asymmetric subnet groups.\n   *\n   * @default false\n   */\n  readonly returnAsymmetricSubnets?: boolean;\n\n  /**\n   * Optional tag for subnet group name.\n   * If not provided, we'll look at the aws-cdk:subnet-name tag.\n   * If the subnet does not have the specified tag,\n   * we'll use its type as the name.\n   *\n   * @default 'aws-cdk:subnet-name'\n   */\n  readonly subnetGroupNameTag?: string;\n\n  /**\n   * Whether to populate the `vpnGatewayId` field of the `VpcContextResponse`,\n   * which contains the VPN Gateway ID, if one exists. You can explicitly\n   * disable this in order to avoid the lookup if you know the VPC does not have\n   * a VPN Gatway attached.\n   *\n   * @default true\n   */\n  readonly returnVpnGateways?: boolean;\n}\n\n/**\n * Query to endpoint service context provider\n */\nexport interface EndpointServiceAvailabilityZonesContextQuery extends ContextLookupRoleOptions {\n  /**\n   * Query service name\n   */\n  readonly serviceName: string;\n}\n\n/**\n * Type of load balancer\n */\nexport enum LoadBalancerType {\n  /**\n   * Network load balancer\n   */\n  NETWORK = 'network',\n\n  /**\n   * Application load balancer\n   */\n  APPLICATION = 'application',\n}\n\n/**\n * Filters for selecting load balancers\n */\nexport interface LoadBalancerFilter extends ContextLookupRoleOptions {\n  /**\n   * Filter load balancers by their type\n   */\n  readonly loadBalancerType: LoadBalancerType;\n\n  /**\n   * Find by load balancer's ARN\n   * @default - does not search by load balancer arn\n   */\n  readonly loadBalancerArn?: string;\n\n  /**\n   * Match load balancer tags\n   * @default - does not match load balancers by tags\n   */\n  readonly loadBalancerTags?: Tag[];\n}\n\n/**\n * Query input for looking up a load balancer\n */\nexport interface LoadBalancerContextQuery extends LoadBalancerFilter {}\n\n/**\n * The protocol for connections from clients to the load balancer\n */\nexport enum LoadBalancerListenerProtocol {\n  /**\n   * HTTP protocol\n   */\n  HTTP = 'HTTP',\n\n  /**\n   * HTTPS protocol\n   */\n  HTTPS = 'HTTPS',\n\n  /**\n   * TCP protocol\n   */\n  TCP = 'TCP',\n\n  /**\n   * TLS protocol\n   */\n  TLS = 'TLS',\n\n  /**\n   * UDP protocol\n   * */\n  UDP = 'UDP',\n\n  /**\n   * TCP and UDP protocol\n   * */\n  TCP_UDP = 'TCP_UDP',\n}\n\n/**\n * Query input for looking up a load balancer listener\n */\nexport interface LoadBalancerListenerContextQuery extends LoadBalancerFilter {\n  /**\n   * Find by listener's arn\n   * @default - does not find by listener arn\n   */\n  readonly listenerArn?: string;\n\n  /**\n   * Filter by listener protocol\n   * @default - does not filter by listener protocol\n   */\n  readonly listenerProtocol?: LoadBalancerListenerProtocol;\n\n  /**\n   * Filter listeners by listener port\n   * @default - does not filter by a listener port\n   */\n  readonly listenerPort?: number;\n}\n\n/**\n * Query input for looking up a security group\n */\nexport interface SecurityGroupContextQuery extends ContextLookupRoleOptions {\n  /**\n   * Security group id\n   *\n   * @default - None\n   */\n  readonly securityGroupId?: string;\n\n  /**\n   * Security group name\n   *\n   * @default - None\n   */\n  readonly securityGroupName?: string;\n\n  /**\n   * VPC ID\n   *\n   * @default - None\n   */\n  readonly vpcId?: string;\n}\n\n/**\n * Query input for looking up a KMS Key\n */\nexport interface KeyContextQuery extends ContextLookupRoleOptions {\n  /**\n   * Alias name used to search the Key\n   */\n  readonly aliasName: string;\n}\n\n/**\n * Query input for plugins\n *\n * This alternate branch is necessary because it needs to be able to escape all type checking\n * we do on on the cloud assembly -- we cannot know the properties that will be used a priori.\n */\nexport interface PluginContextQuery {\n  /**\n   * The name of the plugin\n   */\n  readonly pluginName: string;\n\n  /**\n   * Arbitrary other arguments for the plugin.\n   *\n   * This index signature is not usable in non-TypeScript/JavaScript languages.\n   *\n   * @jsii ignore\n   */\n  [key: string]: any;\n}\n\nexport type ContextQueryProperties =\n  | AmiContextQuery\n  | AvailabilityZonesContextQuery\n  | HostedZoneContextQuery\n  | SSMParameterContextQuery\n  | VpcContextQuery\n  | EndpointServiceAvailabilityZonesContextQuery\n  | LoadBalancerContextQuery\n  | LoadBalancerListenerContextQuery\n  | SecurityGroupContextQuery\n  | KeyContextQuery\n  | PluginContextQuery;\n"]}
package/lib/manifest.d.ts CHANGED
@@ -111,6 +111,11 @@ export declare class Manifest {
111
111
  * backwards-compatibility code and it just doesn't seem to be worth the effort.
112
112
  */
113
113
  private static patchStackTagsOnRead;
114
+ /**
115
+ * Validates that `assumeRoleAdditionalOptions` doesn't contain nor `ExternalId` neither `RoleArn`, as they
116
+ * should have dedicated properties preceding this (e.g `assumeRoleArn` and `assumeRoleExternalId`).
117
+ */
118
+ private static validateAssumeRoleAdditionalOptions;
114
119
  /**
115
120
  * See explanation on `patchStackTagsOnRead`
116
121
  *
package/lib/manifest.js CHANGED
@@ -117,6 +117,7 @@ class Manifest {
117
117
  // does exist but is not in the TypeScript definitions
118
118
  nestedErrors: true,
119
119
  allowUnknownAttributes: false,
120
+ preValidateProperty: Manifest.validateAssumeRoleAdditionalOptions,
120
121
  });
121
122
  let errors = result.errors;
122
123
  if (options?.skipEnumCheck) {
@@ -171,6 +172,26 @@ class Manifest {
171
172
  value: diskTag.Value,
172
173
  })));
173
174
  }
175
+ /**
176
+ * Validates that `assumeRoleAdditionalOptions` doesn't contain nor `ExternalId` neither `RoleArn`, as they
177
+ * should have dedicated properties preceding this (e.g `assumeRoleArn` and `assumeRoleExternalId`).
178
+ */
179
+ static validateAssumeRoleAdditionalOptions(instance, key, _schema, _options, _ctx) {
180
+ if (key !== 'assumeRoleAdditionalOptions') {
181
+ // note that this means that if we happen to have a property named like this, but that
182
+ // does want to allow 'RoleArn' or 'ExternalId', this code will have to change to consider the full schema path.
183
+ // I decided to make this less granular for now on purpose because it fits our needs and avoids having messy
184
+ // validation logic due to various schema paths.
185
+ return;
186
+ }
187
+ const assumeRoleOptions = instance[key];
188
+ if (assumeRoleOptions?.RoleArn) {
189
+ throw new Error(`RoleArn is not allowed inside '${key}'`);
190
+ }
191
+ if (assumeRoleOptions?.ExternalId) {
192
+ throw new Error(`ExternalId is not allowed inside '${key}'`);
193
+ }
194
+ }
174
195
  /**
175
196
  * See explanation on `patchStackTagsOnRead`
176
197
  *
@@ -213,7 +234,7 @@ class Manifest {
213
234
  }
214
235
  exports.Manifest = Manifest;
215
236
  _a = JSII_RTTI_SYMBOL_1;
216
- Manifest[_a] = { fqn: "@aws-cdk/cloud-assembly-schema.Manifest", version: "36.3.0" };
237
+ Manifest[_a] = { fqn: "@aws-cdk/cloud-assembly-schema.Manifest", version: "38.0.0" };
217
238
  function mapValues(xs, fn) {
218
239
  if (!xs) {
219
240
  return undefined;
@@ -236,4 +257,4 @@ function noUndefined(xs) {
236
257
  function stripEnumErrors(errors) {
237
258
  return errors.filter((e) => typeof e.schema === 'string' || !('enum' in e.schema));
238
259
  }
239
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"manifest.js","sourceRoot":"","sources":["manifest.ts"],"names":[],"mappings":"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","sourcesContent":["import * as fs from 'fs';\nimport * as jsonschema from 'jsonschema';\nimport * as semver from 'semver';\nimport * as assets from './assets';\nimport * as assembly from './cloud-assembly';\nimport * as integ from './integ-tests';\n\n/* eslint-disable @typescript-eslint/no-var-requires */\n/* eslint-disable @typescript-eslint/no-require-imports */\n\n// this prefix is used by the CLI to identify this specific error.\n// in which case we want to instruct the user to upgrade his CLI.\n// see exec.ts#createAssembly\nexport const VERSION_MISMATCH: string = 'Cloud assembly schema version mismatch';\n\nimport ASSETS_SCHEMA = require('../schema/assets.schema.json');\n\nimport ASSEMBLY_SCHEMA = require('../schema/cloud-assembly.schema.json');\n\nimport INTEG_SCHEMA = require('../schema/integ.schema.json');\n\n/**\n * Version is shared for both manifests\n */\nconst SCHEMA_VERSION = require('../package.json').version;\n\n/**\n * Options for the loadManifest operation\n */\nexport interface LoadManifestOptions {\n  /**\n   * Skip the version check\n   *\n   * This means you may read a newer cloud assembly than the CX API is designed\n   * to support, and your application may not be aware of all features that in use\n   * in the Cloud Assembly.\n   *\n   * @default false\n   */\n  readonly skipVersionCheck?: boolean;\n\n  /**\n   * Skip enum checks\n   *\n   * This means you may read enum values you don't know about yet. Make sure to always\n   * check the values of enums you encounter in the manifest.\n   *\n   * @default false\n   */\n  readonly skipEnumCheck?: boolean;\n\n  /**\n   * Topologically sort all artifacts\n   *\n   * This parameter is only respected by the constructor of `CloudAssembly`. The\n   * property lives here for backwards compatibility reasons.\n   *\n   * @default true\n   */\n  readonly topoSort?: boolean;\n}\n\n/**\n * Protocol utility class.\n */\nexport class Manifest {\n  /**\n   * Validates and saves the cloud assembly manifest to file.\n   *\n   * @param manifest - manifest.\n   * @param filePath - output file path.\n   */\n  public static saveAssemblyManifest(manifest: assembly.AssemblyManifest, filePath: string) {\n    Manifest.saveManifest(manifest, filePath, ASSEMBLY_SCHEMA, Manifest.patchStackTagsOnWrite);\n  }\n\n  /**\n   * Load and validates the cloud assembly manifest from file.\n   *\n   * @param filePath - path to the manifest file.\n   */\n  public static loadAssemblyManifest(\n    filePath: string,\n    options?: LoadManifestOptions\n  ): assembly.AssemblyManifest {\n    return Manifest.loadManifest(filePath, ASSEMBLY_SCHEMA, Manifest.patchStackTagsOnRead, options);\n  }\n\n  /**\n   * Validates and saves the asset manifest to file.\n   *\n   * @param manifest - manifest.\n   * @param filePath - output file path.\n   */\n  public static saveAssetManifest(manifest: assets.AssetManifest, filePath: string) {\n    Manifest.saveManifest(manifest, filePath, ASSETS_SCHEMA, Manifest.patchStackTagsOnRead);\n  }\n\n  /**\n   * Load and validates the asset manifest from file.\n   *\n   * @param filePath - path to the manifest file.\n   */\n  public static loadAssetManifest(filePath: string): assets.AssetManifest {\n    return this.loadManifest(filePath, ASSETS_SCHEMA);\n  }\n\n  /**\n   * Validates and saves the integ manifest to file.\n   *\n   * @param manifest - manifest.\n   * @param filePath - output file path.\n   */\n  public static saveIntegManifest(manifest: integ.IntegManifest, filePath: string) {\n    Manifest.saveManifest(manifest, filePath, INTEG_SCHEMA);\n  }\n\n  /**\n   * Load and validates the integ manifest from file.\n   *\n   * @param filePath - path to the manifest file.\n   */\n  public static loadIntegManifest(filePath: string): integ.IntegManifest {\n    return this.loadManifest(filePath, INTEG_SCHEMA);\n  }\n\n  /**\n   * Fetch the current schema version number.\n   */\n  public static version(): string {\n    return SCHEMA_VERSION;\n  }\n\n  /**\n   * Deprecated\n   * @deprecated use `saveAssemblyManifest()`\n   */\n  public static save(manifest: assembly.AssemblyManifest, filePath: string) {\n    return this.saveAssemblyManifest(manifest, filePath);\n  }\n\n  /**\n   * Deprecated\n   * @deprecated use `loadAssemblyManifest()`\n   */\n  public static load(filePath: string): assembly.AssemblyManifest {\n    return this.loadAssemblyManifest(filePath);\n  }\n\n  private static validate(\n    manifest: { version: string },\n    schema: jsonschema.Schema,\n    options?: LoadManifestOptions\n  ) {\n    function parseVersion(version: string) {\n      const ver = semver.valid(version);\n      if (!ver) {\n        throw new Error(`Invalid semver string: \"${version}\"`);\n      }\n      return ver;\n    }\n\n    const maxSupported = semver.major(parseVersion(Manifest.version()));\n    const actual = parseVersion(manifest.version);\n\n    // first validate the version should be accepted. all versions within the same minor version are fine\n    if (maxSupported < semver.major(actual) && !options?.skipVersionCheck) {\n      // we use a well known error prefix so that the CLI can identify this specific error\n      // and print some more context to the user.\n      throw new Error(\n        `${VERSION_MISMATCH}: Maximum schema version supported is ${maxSupported}.x.x, but found ${actual}`\n      );\n    }\n\n    // now validate the format is good.\n    const validator = new jsonschema.Validator();\n    const result = validator.validate(manifest, schema, {\n      // does exist but is not in the TypeScript definitions\n      nestedErrors: true,\n\n      allowUnknownAttributes: false,\n    } as any);\n\n    let errors = result.errors;\n    if (options?.skipEnumCheck) {\n      // Enum validations aren't useful when\n      errors = stripEnumErrors(errors);\n    }\n\n    if (errors.length > 0) {\n      throw new Error(`Invalid assembly manifest:\\n${errors.map((e) => e.stack).join('\\n')}`);\n    }\n  }\n\n  private static saveManifest(\n    manifest: any,\n    filePath: string,\n    schema: jsonschema.Schema,\n    preprocess?: (obj: any) => any\n  ) {\n    let withVersion = { ...manifest, version: Manifest.version() };\n    Manifest.validate(withVersion, schema);\n    if (preprocess) {\n      withVersion = preprocess(withVersion);\n    }\n    fs.writeFileSync(filePath, JSON.stringify(withVersion, undefined, 2));\n  }\n\n  private static loadManifest(\n    filePath: string,\n    schema: jsonschema.Schema,\n    preprocess?: (obj: any) => any,\n    options?: LoadManifestOptions\n  ) {\n    const contents = fs.readFileSync(filePath, { encoding: 'utf-8' });\n    let obj;\n    try {\n      obj = JSON.parse(contents);\n    } catch (e: any) {\n      throw new Error(`${e.message}, while parsing ${JSON.stringify(contents)}`);\n    }\n    if (preprocess) {\n      obj = preprocess(obj);\n    }\n    Manifest.validate(obj, schema, options);\n    return obj;\n  }\n\n  /**\n   * This requires some explaining...\n   *\n   * We previously used `{ Key, Value }` for the object that represents a stack tag. (Notice the casing)\n   * @link https://github.com/aws/aws-cdk/blob/v1.27.0/packages/aws-cdk/lib/api/cxapp/stacks.ts#L427.\n   *\n   * When that object moved to this package, it had to be JSII compliant, which meant the property\n   * names must be `camelCased`, and not `PascalCased`. This meant it no longer matches the structure in the `manifest.json` file.\n   * In order to support current manifest files, we have to translate the `PascalCased` representation to the new `camelCased` one.\n   *\n   * Note that the serialization itself still writes `PascalCased` because it relates to how CloudFormation expects it.\n   *\n   * Ideally, we would start writing the `camelCased` and translate to how CloudFormation expects it when needed. But this requires nasty\n   * backwards-compatibility code and it just doesn't seem to be worth the effort.\n   */\n  private static patchStackTagsOnRead(manifest: assembly.AssemblyManifest) {\n    return Manifest.replaceStackTags(manifest, (tags) =>\n      tags.map((diskTag: any) => ({\n        key: diskTag.Key,\n        value: diskTag.Value,\n      }))\n    );\n  }\n\n  /**\n   * See explanation on `patchStackTagsOnRead`\n   *\n   * Translate stack tags metadata if it has the \"right\" casing.\n   */\n  private static patchStackTagsOnWrite(manifest: assembly.AssemblyManifest) {\n    return Manifest.replaceStackTags(manifest, (tags) =>\n      tags.map(\n        (memTag) =>\n          // Might already be uppercased (because stack synthesis generates it in final form yet)\n          ('Key' in memTag ? memTag : { Key: memTag.key, Value: memTag.value }) as any\n      )\n    );\n  }\n\n  /**\n   * Recursively replace stack tags in the stack metadata\n   */\n  private static replaceStackTags(\n    manifest: assembly.AssemblyManifest,\n    fn: Endofunctor<assembly.StackTagsMetadataEntry>\n  ): assembly.AssemblyManifest {\n    // Need to add in the `noUndefined`s because otherwise jest snapshot tests are going to freak out\n    // about the keys with values that are `undefined` (even though they would never be JSON.stringified)\n    return noUndefined({\n      ...manifest,\n      artifacts: mapValues(manifest.artifacts, (artifact) => {\n        if (artifact.type !== assembly.ArtifactType.AWS_CLOUDFORMATION_STACK) {\n          return artifact;\n        }\n        return noUndefined({\n          ...artifact,\n          metadata: mapValues(artifact.metadata, (metadataEntries) =>\n            metadataEntries.map((metadataEntry) => {\n              if (\n                metadataEntry.type !== assembly.ArtifactMetadataEntryType.STACK_TAGS ||\n                !metadataEntry.data\n              ) {\n                return metadataEntry;\n              }\n              return {\n                ...metadataEntry,\n                data: fn(metadataEntry.data as assembly.StackTagsMetadataEntry),\n              };\n            })\n          ),\n        } as assembly.ArtifactManifest);\n      }),\n    });\n  }\n\n  private constructor() {}\n}\n\ntype Endofunctor<A> = (x: A) => A;\n\nfunction mapValues<A, B>(\n  xs: Record<string, A> | undefined,\n  fn: (x: A) => B\n): Record<string, B> | undefined {\n  if (!xs) {\n    return undefined;\n  }\n  const ret: Record<string, B> | undefined = {};\n  for (const [k, v] of Object.entries(xs)) {\n    ret[k] = fn(v);\n  }\n  return ret;\n}\n\nfunction noUndefined<A extends object>(xs: A): A {\n  const ret: any = {};\n  for (const [k, v] of Object.entries(xs)) {\n    if (v !== undefined) {\n      ret[k] = v;\n    }\n  }\n  return ret;\n}\n\nfunction stripEnumErrors(errors: jsonschema.ValidationError[]) {\n  return errors.filter((e) => typeof e.schema === 'string' || !('enum' in e.schema));\n}\n"]}
260
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"manifest.js","sourceRoot":"","sources":["manifest.ts"],"names":[],"mappings":"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","sourcesContent":["import * as fs from 'fs';\nimport * as jsonschema from 'jsonschema';\nimport * as semver from 'semver';\nimport * as assets from './assets';\nimport * as assembly from './cloud-assembly';\nimport * as integ from './integ-tests';\n\n/* eslint-disable @typescript-eslint/no-var-requires */\n/* eslint-disable @typescript-eslint/no-require-imports */\n\n// this prefix is used by the CLI to identify this specific error.\n// in which case we want to instruct the user to upgrade his CLI.\n// see exec.ts#createAssembly\nexport const VERSION_MISMATCH: string = 'Cloud assembly schema version mismatch';\n\nimport ASSETS_SCHEMA = require('../schema/assets.schema.json');\n\nimport ASSEMBLY_SCHEMA = require('../schema/cloud-assembly.schema.json');\n\nimport INTEG_SCHEMA = require('../schema/integ.schema.json');\n\n/**\n * Version is shared for both manifests\n */\nconst SCHEMA_VERSION = require('../package.json').version;\n\n/**\n * Options for the loadManifest operation\n */\nexport interface LoadManifestOptions {\n  /**\n   * Skip the version check\n   *\n   * This means you may read a newer cloud assembly than the CX API is designed\n   * to support, and your application may not be aware of all features that in use\n   * in the Cloud Assembly.\n   *\n   * @default false\n   */\n  readonly skipVersionCheck?: boolean;\n\n  /**\n   * Skip enum checks\n   *\n   * This means you may read enum values you don't know about yet. Make sure to always\n   * check the values of enums you encounter in the manifest.\n   *\n   * @default false\n   */\n  readonly skipEnumCheck?: boolean;\n\n  /**\n   * Topologically sort all artifacts\n   *\n   * This parameter is only respected by the constructor of `CloudAssembly`. The\n   * property lives here for backwards compatibility reasons.\n   *\n   * @default true\n   */\n  readonly topoSort?: boolean;\n}\n\n/**\n * Protocol utility class.\n */\nexport class Manifest {\n  /**\n   * Validates and saves the cloud assembly manifest to file.\n   *\n   * @param manifest - manifest.\n   * @param filePath - output file path.\n   */\n  public static saveAssemblyManifest(manifest: assembly.AssemblyManifest, filePath: string) {\n    Manifest.saveManifest(manifest, filePath, ASSEMBLY_SCHEMA, Manifest.patchStackTagsOnWrite);\n  }\n\n  /**\n   * Load and validates the cloud assembly manifest from file.\n   *\n   * @param filePath - path to the manifest file.\n   */\n  public static loadAssemblyManifest(\n    filePath: string,\n    options?: LoadManifestOptions\n  ): assembly.AssemblyManifest {\n    return Manifest.loadManifest(filePath, ASSEMBLY_SCHEMA, Manifest.patchStackTagsOnRead, options);\n  }\n\n  /**\n   * Validates and saves the asset manifest to file.\n   *\n   * @param manifest - manifest.\n   * @param filePath - output file path.\n   */\n  public static saveAssetManifest(manifest: assets.AssetManifest, filePath: string) {\n    Manifest.saveManifest(manifest, filePath, ASSETS_SCHEMA, Manifest.patchStackTagsOnRead);\n  }\n\n  /**\n   * Load and validates the asset manifest from file.\n   *\n   * @param filePath - path to the manifest file.\n   */\n  public static loadAssetManifest(filePath: string): assets.AssetManifest {\n    return this.loadManifest(filePath, ASSETS_SCHEMA);\n  }\n\n  /**\n   * Validates and saves the integ manifest to file.\n   *\n   * @param manifest - manifest.\n   * @param filePath - output file path.\n   */\n  public static saveIntegManifest(manifest: integ.IntegManifest, filePath: string) {\n    Manifest.saveManifest(manifest, filePath, INTEG_SCHEMA);\n  }\n\n  /**\n   * Load and validates the integ manifest from file.\n   *\n   * @param filePath - path to the manifest file.\n   */\n  public static loadIntegManifest(filePath: string): integ.IntegManifest {\n    return this.loadManifest(filePath, INTEG_SCHEMA);\n  }\n\n  /**\n   * Fetch the current schema version number.\n   */\n  public static version(): string {\n    return SCHEMA_VERSION;\n  }\n\n  /**\n   * Deprecated\n   * @deprecated use `saveAssemblyManifest()`\n   */\n  public static save(manifest: assembly.AssemblyManifest, filePath: string) {\n    return this.saveAssemblyManifest(manifest, filePath);\n  }\n\n  /**\n   * Deprecated\n   * @deprecated use `loadAssemblyManifest()`\n   */\n  public static load(filePath: string): assembly.AssemblyManifest {\n    return this.loadAssemblyManifest(filePath);\n  }\n\n  private static validate(manifest: any, schema: jsonschema.Schema, options?: LoadManifestOptions) {\n    function parseVersion(version: string) {\n      const ver = semver.valid(version);\n      if (!ver) {\n        throw new Error(`Invalid semver string: \"${version}\"`);\n      }\n      return ver;\n    }\n\n    const maxSupported = semver.major(parseVersion(Manifest.version()));\n    const actual = parseVersion(manifest.version);\n\n    // first validate the version should be accepted. all versions within the same minor version are fine\n    if (maxSupported < semver.major(actual) && !options?.skipVersionCheck) {\n      // we use a well known error prefix so that the CLI can identify this specific error\n      // and print some more context to the user.\n      throw new Error(\n        `${VERSION_MISMATCH}: Maximum schema version supported is ${maxSupported}.x.x, but found ${actual}`\n      );\n    }\n\n    // now validate the format is good.\n    const validator = new jsonschema.Validator();\n    const result = validator.validate(manifest, schema, {\n      // does exist but is not in the TypeScript definitions\n      nestedErrors: true,\n\n      allowUnknownAttributes: false,\n      preValidateProperty: Manifest.validateAssumeRoleAdditionalOptions,\n    });\n\n    let errors = result.errors;\n    if (options?.skipEnumCheck) {\n      // Enum validations aren't useful when\n      errors = stripEnumErrors(errors);\n    }\n\n    if (errors.length > 0) {\n      throw new Error(`Invalid assembly manifest:\\n${errors.map((e) => e.stack).join('\\n')}`);\n    }\n  }\n\n  private static saveManifest(\n    manifest: any,\n    filePath: string,\n    schema: jsonschema.Schema,\n    preprocess?: (obj: any) => any\n  ) {\n    let withVersion = { ...manifest, version: Manifest.version() };\n    Manifest.validate(withVersion, schema);\n    if (preprocess) {\n      withVersion = preprocess(withVersion);\n    }\n    fs.writeFileSync(filePath, JSON.stringify(withVersion, undefined, 2));\n  }\n\n  private static loadManifest(\n    filePath: string,\n    schema: jsonschema.Schema,\n    preprocess?: (obj: any) => any,\n    options?: LoadManifestOptions\n  ) {\n    const contents = fs.readFileSync(filePath, { encoding: 'utf-8' });\n    let obj;\n    try {\n      obj = JSON.parse(contents);\n    } catch (e: any) {\n      throw new Error(`${e.message}, while parsing ${JSON.stringify(contents)}`);\n    }\n    if (preprocess) {\n      obj = preprocess(obj);\n    }\n    Manifest.validate(obj, schema, options);\n    return obj;\n  }\n\n  /**\n   * This requires some explaining...\n   *\n   * We previously used `{ Key, Value }` for the object that represents a stack tag. (Notice the casing)\n   * @link https://github.com/aws/aws-cdk/blob/v1.27.0/packages/aws-cdk/lib/api/cxapp/stacks.ts#L427.\n   *\n   * When that object moved to this package, it had to be JSII compliant, which meant the property\n   * names must be `camelCased`, and not `PascalCased`. This meant it no longer matches the structure in the `manifest.json` file.\n   * In order to support current manifest files, we have to translate the `PascalCased` representation to the new `camelCased` one.\n   *\n   * Note that the serialization itself still writes `PascalCased` because it relates to how CloudFormation expects it.\n   *\n   * Ideally, we would start writing the `camelCased` and translate to how CloudFormation expects it when needed. But this requires nasty\n   * backwards-compatibility code and it just doesn't seem to be worth the effort.\n   */\n  private static patchStackTagsOnRead(manifest: assembly.AssemblyManifest) {\n    return Manifest.replaceStackTags(manifest, (tags) =>\n      tags.map((diskTag: any) => ({\n        key: diskTag.Key,\n        value: diskTag.Value,\n      }))\n    );\n  }\n\n  /**\n   * Validates that `assumeRoleAdditionalOptions` doesn't contain nor `ExternalId` neither `RoleArn`, as they\n   * should have dedicated properties preceding this (e.g `assumeRoleArn` and `assumeRoleExternalId`).\n   */\n  private static validateAssumeRoleAdditionalOptions(\n    instance: any,\n    key: string,\n    _schema: jsonschema.Schema,\n    _options: jsonschema.Options,\n    _ctx: jsonschema.SchemaContext\n  ) {\n    if (key !== 'assumeRoleAdditionalOptions') {\n      // note that this means that if we happen to have a property named like this, but that\n      // does want to allow 'RoleArn' or 'ExternalId', this code will have to change to consider the full schema path.\n      // I decided to make this less granular for now on purpose because it fits our needs and avoids having messy\n      // validation logic due to various schema paths.\n      return;\n    }\n\n    const assumeRoleOptions = instance[key];\n    if (assumeRoleOptions?.RoleArn) {\n      throw new Error(`RoleArn is not allowed inside '${key}'`);\n    }\n    if (assumeRoleOptions?.ExternalId) {\n      throw new Error(`ExternalId is not allowed inside '${key}'`);\n    }\n  }\n\n  /**\n   * See explanation on `patchStackTagsOnRead`\n   *\n   * Translate stack tags metadata if it has the \"right\" casing.\n   */\n  private static patchStackTagsOnWrite(manifest: assembly.AssemblyManifest) {\n    return Manifest.replaceStackTags(manifest, (tags) =>\n      tags.map(\n        (memTag) =>\n          // Might already be uppercased (because stack synthesis generates it in final form yet)\n          ('Key' in memTag ? memTag : { Key: memTag.key, Value: memTag.value }) as any\n      )\n    );\n  }\n\n  /**\n   * Recursively replace stack tags in the stack metadata\n   */\n  private static replaceStackTags(\n    manifest: assembly.AssemblyManifest,\n    fn: Endofunctor<assembly.StackTagsMetadataEntry>\n  ): assembly.AssemblyManifest {\n    // Need to add in the `noUndefined`s because otherwise jest snapshot tests are going to freak out\n    // about the keys with values that are `undefined` (even though they would never be JSON.stringified)\n    return noUndefined({\n      ...manifest,\n      artifacts: mapValues(manifest.artifacts, (artifact) => {\n        if (artifact.type !== assembly.ArtifactType.AWS_CLOUDFORMATION_STACK) {\n          return artifact;\n        }\n        return noUndefined({\n          ...artifact,\n          metadata: mapValues(artifact.metadata, (metadataEntries) =>\n            metadataEntries.map((metadataEntry) => {\n              if (\n                metadataEntry.type !== assembly.ArtifactMetadataEntryType.STACK_TAGS ||\n                !metadataEntry.data\n              ) {\n                return metadataEntry;\n              }\n              return {\n                ...metadataEntry,\n                data: fn(metadataEntry.data as assembly.StackTagsMetadataEntry),\n              };\n            })\n          ),\n        } as assembly.ArtifactManifest);\n      }),\n    });\n  }\n\n  private constructor() {}\n}\n\ntype Endofunctor<A> = (x: A) => A;\n\nfunction mapValues<A, B>(\n  xs: Record<string, A> | undefined,\n  fn: (x: A) => B\n): Record<string, B> | undefined {\n  if (!xs) {\n    return undefined;\n  }\n  const ret: Record<string, B> | undefined = {};\n  for (const [k, v] of Object.entries(xs)) {\n    ret[k] = fn(v);\n  }\n  return ret;\n}\n\nfunction noUndefined<A extends object>(xs: A): A {\n  const ret: any = {};\n  for (const [k, v] of Object.entries(xs)) {\n    if (v !== undefined) {\n      ret[k] = v;\n    }\n  }\n  return ret;\n}\n\nfunction stripEnumErrors(errors: jsonschema.ValidationError[]) {\n  return errors.filter((e) => typeof e.schema === 'string' || !('enum' in e.schema));\n}\n"]}
package/package.json CHANGED
@@ -82,7 +82,7 @@
82
82
  "main": "lib/index.js",
83
83
  "license": "Apache-2.0",
84
84
  "homepage": "https://github.com/cdklabs/cloud-assembly-schema",
85
- "version": "36.3.0",
85
+ "version": "38.0.0",
86
86
  "types": "lib/index.d.ts",
87
87
  "stability": "stable",
88
88
  "jsii": {
@@ -97,6 +97,11 @@
97
97
  "assumeRoleExternalId": {
98
98
  "description": "The ExternalId that needs to be supplied while assuming this role (Default - No ExternalId will be supplied)",
99
99
  "type": "string"
100
+ },
101
+ "assumeRoleAdditionalOptions": {
102
+ "description": "Additional options to pass to STS when assuming the role.\n\n- `RoleArn` should not be used. Use the dedicated `assumeRoleArn` property instead.\n- `ExternalId` should not be used. Use the dedicated `assumeRoleExternalId` instead. (Default - No additional options.)",
103
+ "type": "object",
104
+ "additionalProperties": {}
100
105
  }
101
106
  },
102
107
  "required": [
@@ -241,6 +246,11 @@
241
246
  "assumeRoleExternalId": {
242
247
  "description": "The ExternalId that needs to be supplied while assuming this role (Default - No ExternalId will be supplied)",
243
248
  "type": "string"
249
+ },
250
+ "assumeRoleAdditionalOptions": {
251
+ "description": "Additional options to pass to STS when assuming the role.\n\n- `RoleArn` should not be used. Use the dedicated `assumeRoleArn` property instead.\n- `ExternalId` should not be used. Use the dedicated `assumeRoleExternalId` instead. (Default - No additional options.)",
252
+ "type": "object",
253
+ "additionalProperties": {}
244
254
  }
245
255
  },
246
256
  "required": [