@aws-cdk/cloud-assembly-schema 36.1.0 → 36.2.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/.jsii +608 -294
- package/lib/assets/aws-destination.d.ts +0 -12
- package/lib/assets/aws-destination.js +1 -1
- package/lib/cloud-assembly/artifact-schema.d.ts +6 -24
- package/lib/cloud-assembly/artifact-schema.js +1 -1
- package/lib/cloud-assembly/context-queries.d.ts +138 -35
- package/lib/cloud-assembly/context-queries.js +1 -1
- package/lib/manifest.d.ts +0 -5
- package/lib/manifest.js +2 -23
- package/package.json +1 -1
- package/schema/assets.schema.json +0 -10
- package/schema/cloud-assembly.schema.json +80 -173
|
@@ -20,16 +20,4 @@ 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
|
-
};
|
|
35
23
|
}
|
|
@@ -1,3 +1,3 @@
|
|
|
1
1
|
"use strict";
|
|
2
2
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
-
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYXdzLWRlc3RpbmF0aW9uLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiYXdzLWRlc3RpbmF0aW9uLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiIiLCJzb3VyY2VzQ29udGVudCI6WyIvKipcbiAqIERlc3RpbmF0aW9uIGZvciBhc3NldHMgdGhhdCBuZWVkIHRvIGJlIHVwbG9hZGVkIHRvIEFXU1xuICovXG5leHBvcnQgaW50ZXJmYWNlIEF3c0Rlc3RpbmF0aW9uIHtcbiAgLyoqXG4gICAqIFRoZSByZWdpb24gd2hlcmUgdGhpcyBhc3NldCB3aWxsIG5lZWQgdG8gYmUgcHVibGlzaGVkXG4gICAqXG4gICAqIEBkZWZhdWx0IC0gQ3VycmVudCByZWdpb25cbiAgICovXG4gIHJlYWRvbmx5IHJlZ2lvbj86IHN0cmluZztcblxuICAvKipcbiAgICogVGhlIHJvbGUgdGhhdCBuZWVkcyB0byBiZSBhc3N1bWVkIHdoaWxlIHB1Ymxpc2hpbmcgdGhpcyBhc3NldFxuICAgKlxuICAgKiBAZGVmYXVsdCAtIE5vIHJvbGUgd2lsbCBiZSBhc3N1bWVkXG4gICAqL1xuICByZWFkb25seSBhc3N1bWVSb2xlQXJuPzogc3RyaW5nO1xuXG4gIC8qKlxuICAgKiBUaGUgRXh0ZXJuYWxJZCB0aGF0IG5lZWRzIHRvIGJlIHN1cHBsaWVkIHdoaWxlIGFzc3VtaW5nIHRoaXMgcm9sZVxuICAgKlxuICAgKiBAZGVmYXVsdCAtIE5vIEV4dGVybmFsSWQgd2lsbCBiZSBzdXBwbGllZFxuICAgKi9cbiAgcmVhZG9ubHkgYXNzdW1lUm9sZUV4dGVybmFsSWQ/
|
|
3
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYXdzLWRlc3RpbmF0aW9uLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiYXdzLWRlc3RpbmF0aW9uLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiIiLCJzb3VyY2VzQ29udGVudCI6WyIvKipcbiAqIERlc3RpbmF0aW9uIGZvciBhc3NldHMgdGhhdCBuZWVkIHRvIGJlIHVwbG9hZGVkIHRvIEFXU1xuICovXG5leHBvcnQgaW50ZXJmYWNlIEF3c0Rlc3RpbmF0aW9uIHtcbiAgLyoqXG4gICAqIFRoZSByZWdpb24gd2hlcmUgdGhpcyBhc3NldCB3aWxsIG5lZWQgdG8gYmUgcHVibGlzaGVkXG4gICAqXG4gICAqIEBkZWZhdWx0IC0gQ3VycmVudCByZWdpb25cbiAgICovXG4gIHJlYWRvbmx5IHJlZ2lvbj86IHN0cmluZztcblxuICAvKipcbiAgICogVGhlIHJvbGUgdGhhdCBuZWVkcyB0byBiZSBhc3N1bWVkIHdoaWxlIHB1Ymxpc2hpbmcgdGhpcyBhc3NldFxuICAgKlxuICAgKiBAZGVmYXVsdCAtIE5vIHJvbGUgd2lsbCBiZSBhc3N1bWVkXG4gICAqL1xuICByZWFkb25seSBhc3N1bWVSb2xlQXJuPzogc3RyaW5nO1xuXG4gIC8qKlxuICAgKiBUaGUgRXh0ZXJuYWxJZCB0aGF0IG5lZWRzIHRvIGJlIHN1cHBsaWVkIHdoaWxlIGFzc3VtaW5nIHRoaXMgcm9sZVxuICAgKlxuICAgKiBAZGVmYXVsdCAtIE5vIEV4dGVybmFsSWQgd2lsbCBiZSBzdXBwbGllZFxuICAgKi9cbiAgcmVhZG9ubHkgYXNzdW1lUm9sZUV4dGVybmFsSWQ/OiBzdHJpbmc7XG59XG4iXX0=
|
|
@@ -14,18 +14,6 @@ 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
|
-
};
|
|
29
17
|
/**
|
|
30
18
|
* Version of bootstrap stack required to use this role
|
|
31
19
|
*
|
|
@@ -63,6 +51,12 @@ export interface AwsCloudFormationStackProperties {
|
|
|
63
51
|
readonly tags?: {
|
|
64
52
|
[id: string]: string;
|
|
65
53
|
};
|
|
54
|
+
/**
|
|
55
|
+
* SNS Notification ARNs that should receive CloudFormation Stack Events.
|
|
56
|
+
*
|
|
57
|
+
* @default - No notification arns
|
|
58
|
+
*/
|
|
59
|
+
readonly notificationArns?: string[];
|
|
66
60
|
/**
|
|
67
61
|
* The name to use for the CloudFormation stack.
|
|
68
62
|
* @default - name derived from artifact ID
|
|
@@ -86,18 +80,6 @@ export interface AwsCloudFormationStackProperties {
|
|
|
86
80
|
* @default - No external ID
|
|
87
81
|
*/
|
|
88
82
|
readonly assumeRoleExternalId?: string;
|
|
89
|
-
/**
|
|
90
|
-
* Additional options to pass to STS when assuming the role.
|
|
91
|
-
*
|
|
92
|
-
* - `RoleArn` should not be used. Use the dedicated `assumeRoleArn` property instead.
|
|
93
|
-
* - `ExternalId` should not be used. Use the dedicated `assumeRoleExternalId` instead.
|
|
94
|
-
*
|
|
95
|
-
* @see https://docs.aws.amazon.com/AWSJavaScriptSDK/latest/AWS/STS.html#assumeRole-property
|
|
96
|
-
* @default - No additional options.
|
|
97
|
-
*/
|
|
98
|
-
readonly assumeRoleAdditionalOptions?: {
|
|
99
|
-
[key: string]: any;
|
|
100
|
-
};
|
|
101
83
|
/**
|
|
102
84
|
* The role that is passed to CloudFormation to execute the change set
|
|
103
85
|
*
|
|
@@ -1,3 +1,3 @@
|
|
|
1
1
|
"use strict";
|
|
2
2
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
-
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYXJ0aWZhY3Qtc2NoZW1hLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiYXJ0aWZhY3Qtc2NoZW1hLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiIiLCJzb3VyY2VzQ29udGVudCI6WyIvKipcbiAqIEluZm9ybWF0aW9uIG5lZWRlZCB0byBhY2Nlc3MgYW4gSUFNIHJvbGUgY3JlYXRlZFxuICogYXMgcGFydCBvZiB0aGUgYm9vdHN0cmFwIHByb2Nlc3NcbiAqL1xuZXhwb3J0IGludGVyZmFjZSBCb290c3RyYXBSb2xlIHtcbiAgLyoqXG4gICAqIFRoZSBBUk4gb2YgdGhlIElBTSByb2xlIGNyZWF0ZWQgYXMgcGFydCBvZiBib290cmFwcGluZ1xuICAgKiBlLmcuIGxvb2t1cFJvbGVBcm5cbiAgICovXG4gIHJlYWRvbmx5IGFybjogc3RyaW5nO1xuXG4gIC8qKlxuICAgKiBFeHRlcm5hbCBJRCB0byB1c2Ugd2hlbiBhc3N1bWluZyB0aGUgYm9vdHN0cmFwIHJvbGVcbiAgICpcbiAgICogQGRlZmF1bHQgLSBObyBleHRlcm5hbCBJRFxuICAgKi9cbiAgcmVhZG9ubHkgYXNzdW1lUm9sZUV4dGVybmFsSWQ/
|
|
3
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYXJ0aWZhY3Qtc2NoZW1hLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiYXJ0aWZhY3Qtc2NoZW1hLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiIiLCJzb3VyY2VzQ29udGVudCI6WyIvKipcbiAqIEluZm9ybWF0aW9uIG5lZWRlZCB0byBhY2Nlc3MgYW4gSUFNIHJvbGUgY3JlYXRlZFxuICogYXMgcGFydCBvZiB0aGUgYm9vdHN0cmFwIHByb2Nlc3NcbiAqL1xuZXhwb3J0IGludGVyZmFjZSBCb290c3RyYXBSb2xlIHtcbiAgLyoqXG4gICAqIFRoZSBBUk4gb2YgdGhlIElBTSByb2xlIGNyZWF0ZWQgYXMgcGFydCBvZiBib290cmFwcGluZ1xuICAgKiBlLmcuIGxvb2t1cFJvbGVBcm5cbiAgICovXG4gIHJlYWRvbmx5IGFybjogc3RyaW5nO1xuXG4gIC8qKlxuICAgKiBFeHRlcm5hbCBJRCB0byB1c2Ugd2hlbiBhc3N1bWluZyB0aGUgYm9vdHN0cmFwIHJvbGVcbiAgICpcbiAgICogQGRlZmF1bHQgLSBObyBleHRlcm5hbCBJRFxuICAgKi9cbiAgcmVhZG9ubHkgYXNzdW1lUm9sZUV4dGVybmFsSWQ/OiBzdHJpbmc7XG5cbiAgLyoqXG4gICAqIFZlcnNpb24gb2YgYm9vdHN0cmFwIHN0YWNrIHJlcXVpcmVkIHRvIHVzZSB0aGlzIHJvbGVcbiAgICpcbiAgICogQGRlZmF1bHQgLSBObyBib290c3RyYXAgc3RhY2sgcmVxdWlyZWRcbiAgICovXG4gIHJlYWRvbmx5IHJlcXVpcmVzQm9vdHN0cmFwU3RhY2tWZXJzaW9uPzogbnVtYmVyO1xuXG4gIC8qKlxuICAgKiBOYW1lIG9mIFNTTSBwYXJhbWV0ZXIgd2l0aCBib290c3RyYXAgc3RhY2sgdmVyc2lvblxuICAgKlxuICAgKiBAZGVmYXVsdCAtIERpc2NvdmVyIFNTTSBwYXJhbWV0ZXIgYnkgcmVhZGluZyBzdGFja1xuICAgKi9cbiAgcmVhZG9ubHkgYm9vdHN0cmFwU3RhY2tWZXJzaW9uU3NtUGFyYW1ldGVyPzogc3RyaW5nO1xufVxuXG4vKipcbiAqIEFydGlmYWN0IHByb3BlcnRpZXMgZm9yIENsb3VkRm9ybWF0aW9uIHN0YWNrcy5cbiAqL1xuZXhwb3J0IGludGVyZmFjZSBBd3NDbG91ZEZvcm1hdGlvblN0YWNrUHJvcGVydGllcyB7XG4gIC8qKlxuICAgKiBBIGZpbGUgcmVsYXRpdmUgdG8gdGhlIGFzc2VtYmx5IHJvb3Qgd2hpY2ggY29udGFpbnMgdGhlIENsb3VkRm9ybWF0aW9uIHRlbXBsYXRlIGZvciB0aGlzIHN0YWNrLlxuICAgKi9cbiAgcmVhZG9ubHkgdGVtcGxhdGVGaWxlOiBzdHJpbmc7XG5cbiAgLyoqXG4gICAqIFZhbHVlcyBmb3IgQ2xvdWRGb3JtYXRpb24gc3RhY2sgcGFyYW1ldGVycyB0aGF0IHNob3VsZCBiZSBwYXNzZWQgd2hlbiB0aGUgc3RhY2sgaXMgZGVwbG95ZWQuXG4gICAqXG4gICAqIEBkZWZhdWx0IC0gTm8gcGFyYW1ldGVyc1xuICAgKi9cbiAgcmVhZG9ubHkgcGFyYW1ldGVycz86IHsgW2lkOiBzdHJpbmddOiBzdHJpbmcgfTtcblxuICAvKipcbiAgICogVmFsdWVzIGZvciBDbG91ZEZvcm1hdGlvbiBzdGFjayB0YWdzIHRoYXQgc2hvdWxkIGJlIHBhc3NlZCB3aGVuIHRoZSBzdGFjayBpcyBkZXBsb3llZC5cbiAgICpcbiAgICogQGRlZmF1bHQgLSBObyB0YWdzXG4gICAqL1xuICByZWFkb25seSB0YWdzPzogeyBbaWQ6IHN0cmluZ106IHN0cmluZyB9O1xuXG4gIC8qKlxuICAgKiBTTlMgTm90aWZpY2F0aW9uIEFSTnMgdGhhdCBzaG91bGQgcmVjZWl2ZSBDbG91ZEZvcm1hdGlvbiBTdGFjayBFdmVudHMuXG4gICAqXG4gICAqIEBkZWZhdWx0IC0gTm8gbm90aWZpY2F0aW9uIGFybnNcbiAgICovXG4gIHJlYWRvbmx5IG5vdGlmaWNhdGlvbkFybnM/OiBzdHJpbmdbXTtcblxuICAvKipcbiAgICogVGhlIG5hbWUgdG8gdXNlIGZvciB0aGUgQ2xvdWRGb3JtYXRpb24gc3RhY2suXG4gICAqIEBkZWZhdWx0IC0gbmFtZSBkZXJpdmVkIGZyb20gYXJ0aWZhY3QgSURcbiAgICovXG4gIHJlYWRvbmx5IHN0YWNrTmFtZT86IHN0cmluZztcblxuICAvKipcbiAgICogV2hldGhlciB0byBlbmFibGUgdGVybWluYXRpb24gcHJvdGVjdGlvbiBmb3IgdGhpcyBzdGFjay5cbiAgICpcbiAgICogQGRlZmF1bHQgZmFsc2VcbiAgICovXG4gIHJlYWRvbmx5IHRlcm1pbmF0aW9uUHJvdGVjdGlvbj86IGJvb2xlYW47XG5cbiAgLyoqXG4gICAqIFRoZSByb2xlIHRoYXQgbmVlZHMgdG8gYmUgYXNzdW1lZCB0byBkZXBsb3kgdGhlIHN0YWNrXG4gICAqXG4gICAqIEBkZWZhdWx0IC0gTm8gcm9sZSBpcyBhc3N1bWVkIChjdXJyZW50IGNyZWRlbnRpYWxzIGFyZSB1c2VkKVxuICAgKi9cbiAgcmVhZG9ubHkgYXNzdW1lUm9sZUFybj86IHN0cmluZztcblxuICAvKipcbiAgICogRXh0ZXJuYWwgSUQgdG8gdXNlIHdoZW4gYXNzdW1pbmcgcm9sZSBmb3IgY2xvdWRmb3JtYXRpb24gZGVwbG95bWVudHNcbiAgICpcbiAgICogQGRlZmF1bHQgLSBObyBleHRlcm5hbCBJRFxuICAgKi9cbiAgcmVhZG9ubHkgYXNzdW1lUm9sZUV4dGVybmFsSWQ/OiBzdHJpbmc7XG5cbiAgLyoqXG4gICAqIFRoZSByb2xlIHRoYXQgaXMgcGFzc2VkIHRvIENsb3VkRm9ybWF0aW9uIHRvIGV4ZWN1dGUgdGhlIGNoYW5nZSBzZXRcbiAgICpcbiAgICogQGRlZmF1bHQgLSBObyByb2xlIGlzIHBhc3NlZCAoY3VycmVudGx5IGFzc3VtZWQgcm9sZS9jcmVkZW50aWFscyBhcmUgdXNlZClcbiAgICovXG4gIHJlYWRvbmx5IGNsb3VkRm9ybWF0aW9uRXhlY3V0aW9uUm9sZUFybj86IHN0cmluZztcblxuICAvKipcbiAgICogVGhlIHJvbGUgdG8gdXNlIHRvIGxvb2sgdXAgdmFsdWVzIGZyb20gdGhlIHRhcmdldCBBV1MgYWNjb3VudFxuICAgKlxuICAgKiBAZGVmYXVsdCAtIE5vIHJvbGUgaXMgYXNzdW1lZCAoY3VycmVudCBjcmVkZW50aWFscyBhcmUgdXNlZClcbiAgICovXG4gIHJlYWRvbmx5IGxvb2t1cFJvbGU/OiBCb290c3RyYXBSb2xlO1xuXG4gIC8qKlxuICAgKiBJZiB0aGUgc3RhY2sgdGVtcGxhdGUgaGFzIGFscmVhZHkgYmVlbiBpbmNsdWRlZCBpbiB0aGUgYXNzZXQgbWFuaWZlc3QsIGl0cyBhc3NldCBVUkxcbiAgICpcbiAgICogQGRlZmF1bHQgLSBOb3QgdXBsb2FkZWQgeWV0LCB1cGxvYWQganVzdCBiZWZvcmUgZGVwbG95aW5nXG4gICAqL1xuICByZWFkb25seSBzdGFja1RlbXBsYXRlQXNzZXRPYmplY3RVcmw/OiBzdHJpbmc7XG5cbiAgLyoqXG4gICAqIFZlcnNpb24gb2YgYm9vdHN0cmFwIHN0YWNrIHJlcXVpcmVkIHRvIGRlcGxveSB0aGlzIHN0YWNrXG4gICAqXG4gICAqIEBkZWZhdWx0IC0gTm8gYm9vdHN0cmFwIHN0YWNrIHJlcXVpcmVkXG4gICAqL1xuICByZWFkb25seSByZXF1aXJlc0Jvb3RzdHJhcFN0YWNrVmVyc2lvbj86IG51bWJlcjtcblxuICAvKipcbiAgICogU1NNIHBhcmFtZXRlciB3aGVyZSB0aGUgYm9vdHN0cmFwIHN0YWNrIHZlcnNpb24gbnVtYmVyIGNhbiBiZSBmb3VuZFxuICAgKlxuICAgKiBPbmx5IHVzZWQgaWYgYHJlcXVpcmVzQm9vdHN0cmFwU3RhY2tWZXJzaW9uYCBpcyBzZXQuXG4gICAqXG4gICAqIC0gSWYgdGhpcyB2YWx1ZSBpcyBub3Qgc2V0LCB0aGUgYm9vdHN0cmFwIHN0YWNrIG5hbWUgbXVzdCBiZSBrbm93biBhdFxuICAgKiAgIGRlcGxveW1lbnQgdGltZSBzbyB0aGUgc3RhY2sgdmVyc2lvbiBjYW4gYmUgbG9va2VkIHVwIGZyb20gdGhlIHN0YWNrXG4gICAqICAgb3V0cHV0cy5cbiAgICogLSBJZiB0aGlzIHZhbHVlIGlzIHNldCwgdGhlIGJvb3RzdHJhcCBzdGFjayBjYW4gaGF2ZSBhbnkgbmFtZSBiZWNhdXNlXG4gICAqICAgd2Ugd29uJ3QgbmVlZCB0byBsb29rIGl0IHVwLlxuICAgKlxuICAgKiBAZGVmYXVsdCAtIEJvb3RzdHJhcCBzdGFjayB2ZXJzaW9uIG51bWJlciBsb29rZWQgdXBcbiAgICovXG4gIHJlYWRvbmx5IGJvb3RzdHJhcFN0YWNrVmVyc2lvblNzbVBhcmFtZXRlcj86IHN0cmluZztcblxuICAvKipcbiAgICogV2hldGhlciB0aGlzIHN0YWNrIHNob3VsZCBiZSB2YWxpZGF0ZWQgYnkgdGhlIENMSSBhZnRlciBzeW50aGVzaXNcbiAgICpcbiAgICogQGRlZmF1bHQgLSBmYWxzZVxuICAgKi9cbiAgcmVhZG9ubHkgdmFsaWRhdGVPblN5bnRoPzogYm9vbGVhbjtcbn1cblxuLyoqXG4gKiBDb25maWd1cmF0aW9uIG9wdGlvbnMgZm9yIHRoZSBBc3NldCBNYW5pZmVzdFxuICovXG5leHBvcnQgaW50ZXJmYWNlIEFzc2V0TWFuaWZlc3RPcHRpb25zIHtcbiAgLyoqXG4gICAqIFZlcnNpb24gb2YgYm9vdHN0cmFwIHN0YWNrIHJlcXVpcmVkIHRvIGRlcGxveSB0aGlzIHN0YWNrXG4gICAqXG4gICAqIEBkZWZhdWx0IC0gVmVyc2lvbiAxIChiYXNpYyBtb2Rlcm4gYm9vdHN0cmFwIHN0YWNrKVxuICAgKi9cbiAgcmVhZG9ubHkgcmVxdWlyZXNCb290c3RyYXBTdGFja1ZlcnNpb24/OiBudW1iZXI7XG5cbiAgLyoqXG4gICAqIFNTTSBwYXJhbWV0ZXIgd2hlcmUgdGhlIGJvb3RzdHJhcCBzdGFjayB2ZXJzaW9uIG51bWJlciBjYW4gYmUgZm91bmRcbiAgICpcbiAgICogLSBJZiB0aGlzIHZhbHVlIGlzIG5vdCBzZXQsIHRoZSBib290c3RyYXAgc3RhY2sgbmFtZSBtdXN0IGJlIGtub3duIGF0XG4gICAqICAgZGVwbG95bWVudCB0aW1lIHNvIHRoZSBzdGFjayB2ZXJzaW9uIGNhbiBiZSBsb29rZWQgdXAgZnJvbSB0aGUgc3RhY2tcbiAgICogICBvdXRwdXRzLlxuICAgKiAtIElmIHRoaXMgdmFsdWUgaXMgc2V0LCB0aGUgYm9vdHN0cmFwIHN0YWNrIGNhbiBoYXZlIGFueSBuYW1lIGJlY2F1c2VcbiAgICogICB3ZSB3b24ndCBuZWVkIHRvIGxvb2sgaXQgdXAuXG4gICAqXG4gICAqIEBkZWZhdWx0IC0gQm9vdHN0cmFwIHN0YWNrIHZlcnNpb24gbnVtYmVyIGxvb2tlZCB1cFxuICAgKi9cbiAgcmVhZG9ubHkgYm9vdHN0cmFwU3RhY2tWZXJzaW9uU3NtUGFyYW1ldGVyPzogc3RyaW5nO1xufVxuXG4vKipcbiAqIEFydGlmYWN0IHByb3BlcnRpZXMgZm9yIHRoZSBBc3NldCBNYW5pZmVzdFxuICovXG5leHBvcnQgaW50ZXJmYWNlIEFzc2V0TWFuaWZlc3RQcm9wZXJ0aWVzIGV4dGVuZHMgQXNzZXRNYW5pZmVzdE9wdGlvbnMge1xuICAvKipcbiAgICogRmlsZW5hbWUgb2YgdGhlIGFzc2V0IG1hbmlmZXN0XG4gICAqL1xuICByZWFkb25seSBmaWxlOiBzdHJpbmc7XG59XG5cbi8qKlxuICogQXJ0aWZhY3QgcHJvcGVydGllcyBmb3IgdGhlIENvbnN0cnVjdCBUcmVlIEFydGlmYWN0XG4gKi9cbmV4cG9ydCBpbnRlcmZhY2UgVHJlZUFydGlmYWN0UHJvcGVydGllcyB7XG4gIC8qKlxuICAgKiBGaWxlbmFtZSBvZiB0aGUgdHJlZSBhcnRpZmFjdFxuICAgKi9cbiAgcmVhZG9ubHkgZmlsZTogc3RyaW5nO1xufVxuXG4vKipcbiAqIEFydGlmYWN0IHByb3BlcnRpZXMgZm9yIG5lc3RlZCBjbG91ZCBhc3NlbWJsaWVzXG4gKi9cbmV4cG9ydCBpbnRlcmZhY2UgTmVzdGVkQ2xvdWRBc3NlbWJseVByb3BlcnRpZXMge1xuICAvKipcbiAgICogUmVsYXRpdmUgcGF0aCB0byB0aGUgbmVzdGVkIGNsb3VkIGFzc2VtYmx5XG4gICAqL1xuICByZWFkb25seSBkaXJlY3RvcnlOYW1lOiBzdHJpbmc7XG5cbiAgLyoqXG4gICAqIERpc3BsYXkgbmFtZSBmb3IgdGhlIGNsb3VkIGFzc2VtYmx5XG4gICAqXG4gICAqIEBkZWZhdWx0IC0gVGhlIGFydGlmYWN0IElEXG4gICAqL1xuICByZWFkb25seSBkaXNwbGF5TmFtZT86IHN0cmluZztcbn1cblxuLyoqXG4gKiBQcm9wZXJ0aWVzIGZvciBtYW5pZmVzdCBhcnRpZmFjdHNcbiAqL1xuZXhwb3J0IHR5cGUgQXJ0aWZhY3RQcm9wZXJ0aWVzID1cbiAgfCBBd3NDbG91ZEZvcm1hdGlvblN0YWNrUHJvcGVydGllc1xuICB8IEFzc2V0TWFuaWZlc3RQcm9wZXJ0aWVzXG4gIHwgVHJlZUFydGlmYWN0UHJvcGVydGllc1xuICB8IE5lc3RlZENsb3VkQXNzZW1ibHlQcm9wZXJ0aWVzO1xuIl19
|
|
@@ -49,15 +49,15 @@ export declare enum ContextProvider {
|
|
|
49
49
|
PLUGIN = "plugin"
|
|
50
50
|
}
|
|
51
51
|
/**
|
|
52
|
-
*
|
|
52
|
+
* Query to AMI context provider
|
|
53
53
|
*/
|
|
54
|
-
export interface
|
|
54
|
+
export interface AmiContextQuery {
|
|
55
55
|
/**
|
|
56
|
-
*
|
|
56
|
+
* Account to query
|
|
57
57
|
*/
|
|
58
58
|
readonly account: string;
|
|
59
59
|
/**
|
|
60
|
-
*
|
|
60
|
+
* Region to query
|
|
61
61
|
*/
|
|
62
62
|
readonly region: string;
|
|
63
63
|
/**
|
|
@@ -66,29 +66,6 @@ export interface ContextLookupRoleOptions {
|
|
|
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 {
|
|
92
69
|
/**
|
|
93
70
|
* Owners to DescribeImages call
|
|
94
71
|
*
|
|
@@ -105,12 +82,40 @@ export interface AmiContextQuery extends ContextLookupRoleOptions {
|
|
|
105
82
|
/**
|
|
106
83
|
* Query to availability zone context provider
|
|
107
84
|
*/
|
|
108
|
-
export interface AvailabilityZonesContextQuery
|
|
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;
|
|
109
100
|
}
|
|
110
101
|
/**
|
|
111
102
|
* Query to hosted zone context provider
|
|
112
103
|
*/
|
|
113
|
-
export interface HostedZoneContextQuery
|
|
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;
|
|
114
119
|
/**
|
|
115
120
|
* The domain name e.g. example.com to lookup
|
|
116
121
|
*/
|
|
@@ -134,7 +139,21 @@ export interface HostedZoneContextQuery extends ContextLookupRoleOptions {
|
|
|
134
139
|
/**
|
|
135
140
|
* Query to SSM Parameter Context Provider
|
|
136
141
|
*/
|
|
137
|
-
export interface SSMParameterContextQuery
|
|
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;
|
|
138
157
|
/**
|
|
139
158
|
* Parameter name to query
|
|
140
159
|
*/
|
|
@@ -143,7 +162,21 @@ export interface SSMParameterContextQuery extends ContextLookupRoleOptions {
|
|
|
143
162
|
/**
|
|
144
163
|
* Query input for looking up a VPC
|
|
145
164
|
*/
|
|
146
|
-
export interface VpcContextQuery
|
|
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;
|
|
147
180
|
/**
|
|
148
181
|
* Filters to apply to the VPC
|
|
149
182
|
*
|
|
@@ -183,7 +216,21 @@ export interface VpcContextQuery extends ContextLookupRoleOptions {
|
|
|
183
216
|
/**
|
|
184
217
|
* Query to endpoint service context provider
|
|
185
218
|
*/
|
|
186
|
-
export interface EndpointServiceAvailabilityZonesContextQuery
|
|
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;
|
|
187
234
|
/**
|
|
188
235
|
* Query service name
|
|
189
236
|
*/
|
|
@@ -205,7 +252,7 @@ export declare enum LoadBalancerType {
|
|
|
205
252
|
/**
|
|
206
253
|
* Filters for selecting load balancers
|
|
207
254
|
*/
|
|
208
|
-
export interface LoadBalancerFilter
|
|
255
|
+
export interface LoadBalancerFilter {
|
|
209
256
|
/**
|
|
210
257
|
* Filter load balancers by their type
|
|
211
258
|
*/
|
|
@@ -225,6 +272,20 @@ export interface LoadBalancerFilter extends ContextLookupRoleOptions {
|
|
|
225
272
|
* Query input for looking up a load balancer
|
|
226
273
|
*/
|
|
227
274
|
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;
|
|
228
289
|
}
|
|
229
290
|
/**
|
|
230
291
|
* The protocol for connections from clients to the load balancer
|
|
@@ -259,6 +320,20 @@ export declare enum LoadBalancerListenerProtocol {
|
|
|
259
320
|
* Query input for looking up a load balancer listener
|
|
260
321
|
*/
|
|
261
322
|
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;
|
|
262
337
|
/**
|
|
263
338
|
* Find by listener's arn
|
|
264
339
|
* @default - does not find by listener arn
|
|
@@ -278,7 +353,21 @@ export interface LoadBalancerListenerContextQuery extends LoadBalancerFilter {
|
|
|
278
353
|
/**
|
|
279
354
|
* Query input for looking up a security group
|
|
280
355
|
*/
|
|
281
|
-
export interface SecurityGroupContextQuery
|
|
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;
|
|
282
371
|
/**
|
|
283
372
|
* Security group id
|
|
284
373
|
*
|
|
@@ -301,7 +390,21 @@ export interface SecurityGroupContextQuery extends ContextLookupRoleOptions {
|
|
|
301
390
|
/**
|
|
302
391
|
* Query input for looking up a KMS Key
|
|
303
392
|
*/
|
|
304
|
-
export interface KeyContextQuery
|
|
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;
|
|
305
408
|
/**
|
|
306
409
|
* Alias name used to search the Key
|
|
307
410
|
*/
|
|
@@ -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;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"]}
|
|
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"]}
|
package/lib/manifest.d.ts
CHANGED
|
@@ -111,11 +111,6 @@ 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;
|
|
119
114
|
/**
|
|
120
115
|
* See explanation on `patchStackTagsOnRead`
|
|
121
116
|
*
|
package/lib/manifest.js
CHANGED
|
@@ -117,7 +117,6 @@ 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,
|
|
121
120
|
});
|
|
122
121
|
let errors = result.errors;
|
|
123
122
|
if (options?.skipEnumCheck) {
|
|
@@ -172,26 +171,6 @@ class Manifest {
|
|
|
172
171
|
value: diskTag.Value,
|
|
173
172
|
})));
|
|
174
173
|
}
|
|
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
|
-
}
|
|
195
174
|
/**
|
|
196
175
|
* See explanation on `patchStackTagsOnRead`
|
|
197
176
|
*
|
|
@@ -234,7 +213,7 @@ class Manifest {
|
|
|
234
213
|
}
|
|
235
214
|
exports.Manifest = Manifest;
|
|
236
215
|
_a = JSII_RTTI_SYMBOL_1;
|
|
237
|
-
Manifest[_a] = { fqn: "@aws-cdk/cloud-assembly-schema.Manifest", version: "36.
|
|
216
|
+
Manifest[_a] = { fqn: "@aws-cdk/cloud-assembly-schema.Manifest", version: "36.2.0" };
|
|
238
217
|
function mapValues(xs, fn) {
|
|
239
218
|
if (!xs) {
|
|
240
219
|
return undefined;
|
|
@@ -257,4 +236,4 @@ function noUndefined(xs) {
|
|
|
257
236
|
function stripEnumErrors(errors) {
|
|
258
237
|
return errors.filter((e) => typeof e.schema === 'string' || !('enum' in e.schema));
|
|
259
238
|
}
|
|
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"]}
|
|
239
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"manifest.js","sourceRoot":"","sources":["manifest.ts"],"names":[],"mappings":";;;;;AAAA,yBAAyB;AACzB,yCAAyC;AACzC,iCAAiC;AAEjC,6CAA6C;AAG7C,uDAAuD;AACvD,0DAA0D;AAE1D,kEAAkE;AAClE,iEAAiE;AACjE,6BAA6B;AAChB,QAAA,gBAAgB,GAAW,wCAAwC,CAAC;AAEjF,8DAA+D;AAE/D,wEAAyE;AAEzE,4DAA6D;AAE7D;;GAEG;AACH,MAAM,cAAc,GAAG,OAAO,CAAC,iBAAiB,CAAC,CAAC,OAAO,CAAC;AAsC1D;;GAEG;AACH,MAAa,QAAQ;IACnB;;;;;OAKG;IACI,MAAM,CAAC,oBAAoB,CAAC,QAAmC,EAAE,QAAgB;QACtF,QAAQ,CAAC,YAAY,CAAC,QAAQ,EAAE,QAAQ,EAAE,eAAe,EAAE,QAAQ,CAAC,qBAAqB,CAAC,CAAC;IAC7F,CAAC;IAED;;;;OAIG;IACI,MAAM,CAAC,oBAAoB,CAChC,QAAgB,EAChB,OAA6B;QAE7B,OAAO,QAAQ,CAAC,YAAY,CAAC,QAAQ,EAAE,eAAe,EAAE,QAAQ,CAAC,oBAAoB,EAAE,OAAO,CAAC,CAAC;IAClG,CAAC;IAED;;;;;OAKG;IACI,MAAM,CAAC,iBAAiB,CAAC,QAA8B,EAAE,QAAgB;QAC9E,QAAQ,CAAC,YAAY,CAAC,QAAQ,EAAE,QAAQ,EAAE,aAAa,EAAE,QAAQ,CAAC,oBAAoB,CAAC,CAAC;IAC1F,CAAC;IAED;;;;OAIG;IACI,MAAM,CAAC,iBAAiB,CAAC,QAAgB;QAC9C,OAAO,IAAI,CAAC,YAAY,CAAC,QAAQ,EAAE,aAAa,CAAC,CAAC;IACpD,CAAC;IAED;;;;;OAKG;IACI,MAAM,CAAC,iBAAiB,CAAC,QAA6B,EAAE,QAAgB;QAC7E,QAAQ,CAAC,YAAY,CAAC,QAAQ,EAAE,QAAQ,EAAE,YAAY,CAAC,CAAC;IAC1D,CAAC;IAED;;;;OAIG;IACI,MAAM,CAAC,iBAAiB,CAAC,QAAgB;QAC9C,OAAO,IAAI,CAAC,YAAY,CAAC,QAAQ,EAAE,YAAY,CAAC,CAAC;IACnD,CAAC;IAED;;OAEG;IACI,MAAM,CAAC,OAAO;QACnB,OAAO,cAAc,CAAC;IACxB,CAAC;IAED;;;OAGG;IACI,MAAM,CAAC,IAAI,CAAC,QAAmC,EAAE,QAAgB;QACtE,OAAO,IAAI,CAAC,oBAAoB,CAAC,QAAQ,EAAE,QAAQ,CAAC,CAAC;IACvD,CAAC;IAED;;;OAGG;IACI,MAAM,CAAC,IAAI,CAAC,QAAgB;QACjC,OAAO,IAAI,CAAC,oBAAoB,CAAC,QAAQ,CAAC,CAAC;IAC7C,CAAC;IAEO,MAAM,CAAC,QAAQ,CACrB,QAA6B,EAC7B,MAAyB,EACzB,OAA6B;QAE7B,SAAS,YAAY,CAAC,OAAe;YACnC,MAAM,GAAG,GAAG,MAAM,CAAC,KAAK,CAAC,OAAO,CAAC,CAAC;YAClC,IAAI,CAAC,GAAG,EAAE,CAAC;gBACT,MAAM,IAAI,KAAK,CAAC,2BAA2B,OAAO,GAAG,CAAC,CAAC;YACzD,CAAC;YACD,OAAO,GAAG,CAAC;QACb,CAAC;QAED,MAAM,YAAY,GAAG,MAAM,CAAC,KAAK,CAAC,YAAY,CAAC,QAAQ,CAAC,OAAO,EAAE,CAAC,CAAC,CAAC;QACpE,MAAM,MAAM,GAAG,YAAY,CAAC,QAAQ,CAAC,OAAO,CAAC,CAAC;QAE9C,qGAAqG;QACrG,IAAI,YAAY,GAAG,MAAM,CAAC,KAAK,CAAC,MAAM,CAAC,IAAI,CAAC,OAAO,EAAE,gBAAgB,EAAE,CAAC;YACtE,oFAAoF;YACpF,2CAA2C;YAC3C,MAAM,IAAI,KAAK,CACb,GAAG,wBAAgB,yCAAyC,YAAY,mBAAmB,MAAM,EAAE,CACpG,CAAC;QACJ,CAAC;QAED,mCAAmC;QACnC,MAAM,SAAS,GAAG,IAAI,UAAU,CAAC,SAAS,EAAE,CAAC;QAC7C,MAAM,MAAM,GAAG,SAAS,CAAC,QAAQ,CAAC,QAAQ,EAAE,MAAM,EAAE;YAClD,sDAAsD;YACtD,YAAY,EAAE,IAAI;YAElB,sBAAsB,EAAE,KAAK;SACvB,CAAC,CAAC;QAEV,IAAI,MAAM,GAAG,MAAM,CAAC,MAAM,CAAC;QAC3B,IAAI,OAAO,EAAE,aAAa,EAAE,CAAC;YAC3B,sCAAsC;YACtC,MAAM,GAAG,eAAe,CAAC,MAAM,CAAC,CAAC;QACnC,CAAC;QAED,IAAI,MAAM,CAAC,MAAM,GAAG,CAAC,EAAE,CAAC;YACtB,MAAM,IAAI,KAAK,CAAC,+BAA+B,MAAM,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,KAAK,CAAC,CAAC,IAAI,CAAC,IAAI,CAAC,EAAE,CAAC,CAAC;QAC1F,CAAC;IACH,CAAC;IAEO,MAAM,CAAC,YAAY,CACzB,QAAa,EACb,QAAgB,EAChB,MAAyB,EACzB,UAA8B;QAE9B,IAAI,WAAW,GAAG,EAAE,GAAG,QAAQ,EAAE,OAAO,EAAE,QAAQ,CAAC,OAAO,EAAE,EAAE,CAAC;QAC/D,QAAQ,CAAC,QAAQ,CAAC,WAAW,EAAE,MAAM,CAAC,CAAC;QACvC,IAAI,UAAU,EAAE,CAAC;YACf,WAAW,GAAG,UAAU,CAAC,WAAW,CAAC,CAAC;QACxC,CAAC;QACD,EAAE,CAAC,aAAa,CAAC,QAAQ,EAAE,IAAI,CAAC,SAAS,CAAC,WAAW,EAAE,SAAS,EAAE,CAAC,CAAC,CAAC,CAAC;IACxE,CAAC;IAEO,MAAM,CAAC,YAAY,CACzB,QAAgB,EAChB,MAAyB,EACzB,UAA8B,EAC9B,OAA6B;QAE7B,MAAM,QAAQ,GAAG,EAAE,CAAC,YAAY,CAAC,QAAQ,EAAE,EAAE,QAAQ,EAAE,OAAO,EAAE,CAAC,CAAC;QAClE,IAAI,GAAG,CAAC;QACR,IAAI,CAAC;YACH,GAAG,GAAG,IAAI,CAAC,KAAK,CAAC,QAAQ,CAAC,CAAC;QAC7B,CAAC;QAAC,OAAO,CAAM,EAAE,CAAC;YAChB,MAAM,IAAI,KAAK,CAAC,GAAG,CAAC,CAAC,OAAO,mBAAmB,IAAI,CAAC,SAAS,CAAC,QAAQ,CAAC,EAAE,CAAC,CAAC;QAC7E,CAAC;QACD,IAAI,UAAU,EAAE,CAAC;YACf,GAAG,GAAG,UAAU,CAAC,GAAG,CAAC,CAAC;QACxB,CAAC;QACD,QAAQ,CAAC,QAAQ,CAAC,GAAG,EAAE,MAAM,EAAE,OAAO,CAAC,CAAC;QACxC,OAAO,GAAG,CAAC;IACb,CAAC;IAED;;;;;;;;;;;;;;OAcG;IACK,MAAM,CAAC,oBAAoB,CAAC,QAAmC;QACrE,OAAO,QAAQ,CAAC,gBAAgB,CAAC,QAAQ,EAAE,CAAC,IAAI,EAAE,EAAE,CAClD,IAAI,CAAC,GAAG,CAAC,CAAC,OAAY,EAAE,EAAE,CAAC,CAAC;YAC1B,GAAG,EAAE,OAAO,CAAC,GAAG;YAChB,KAAK,EAAE,OAAO,CAAC,KAAK;SACrB,CAAC,CAAC,CACJ,CAAC;IACJ,CAAC;IAED;;;;OAIG;IACK,MAAM,CAAC,qBAAqB,CAAC,QAAmC;QACtE,OAAO,QAAQ,CAAC,gBAAgB,CAAC,QAAQ,EAAE,CAAC,IAAI,EAAE,EAAE,CAClD,IAAI,CAAC,GAAG,CACN,CAAC,MAAM,EAAE,EAAE;QACT,uFAAuF;QACvF,CAAC,KAAK,IAAI,MAAM,CAAC,CAAC,CAAC,MAAM,CAAC,CAAC,CAAC,EAAE,GAAG,EAAE,MAAM,CAAC,GAAG,EAAE,KAAK,EAAE,MAAM,CAAC,KAAK,EAAE,CAAQ,CAC/E,CACF,CAAC;IACJ,CAAC;IAED;;OAEG;IACK,MAAM,CAAC,gBAAgB,CAC7B,QAAmC,EACnC,EAAgD;QAEhD,iGAAiG;QACjG,qGAAqG;QACrG,OAAO,WAAW,CAAC;YACjB,GAAG,QAAQ;YACX,SAAS,EAAE,SAAS,CAAC,QAAQ,CAAC,SAAS,EAAE,CAAC,QAAQ,EAAE,EAAE;gBACpD,IAAI,QAAQ,CAAC,IAAI,KAAK,QAAQ,CAAC,YAAY,CAAC,wBAAwB,EAAE,CAAC;oBACrE,OAAO,QAAQ,CAAC;gBAClB,CAAC;gBACD,OAAO,WAAW,CAAC;oBACjB,GAAG,QAAQ;oBACX,QAAQ,EAAE,SAAS,CAAC,QAAQ,CAAC,QAAQ,EAAE,CAAC,eAAe,EAAE,EAAE,CACzD,eAAe,CAAC,GAAG,CAAC,CAAC,aAAa,EAAE,EAAE;wBACpC,IACE,aAAa,CAAC,IAAI,KAAK,QAAQ,CAAC,yBAAyB,CAAC,UAAU;4BACpE,CAAC,aAAa,CAAC,IAAI,EACnB,CAAC;4BACD,OAAO,aAAa,CAAC;wBACvB,CAAC;wBACD,OAAO;4BACL,GAAG,aAAa;4BAChB,IAAI,EAAE,EAAE,CAAC,aAAa,CAAC,IAAuC,CAAC;yBAChE,CAAC;oBACJ,CAAC,CAAC,CACH;iBAC2B,CAAC,CAAC;YAClC,CAAC,CAAC;SACH,CAAC,CAAC;IACL,CAAC;IAED,gBAAuB,CAAC;;AA9O1B,4BA+OC;;;AAID,SAAS,SAAS,CAChB,EAAiC,EACjC,EAAe;IAEf,IAAI,CAAC,EAAE,EAAE,CAAC;QACR,OAAO,SAAS,CAAC;IACnB,CAAC;IACD,MAAM,GAAG,GAAkC,EAAE,CAAC;IAC9C,KAAK,MAAM,CAAC,CAAC,EAAE,CAAC,CAAC,IAAI,MAAM,CAAC,OAAO,CAAC,EAAE,CAAC,EAAE,CAAC;QACxC,GAAG,CAAC,CAAC,CAAC,GAAG,EAAE,CAAC,CAAC,CAAC,CAAC;IACjB,CAAC;IACD,OAAO,GAAG,CAAC;AACb,CAAC;AAED,SAAS,WAAW,CAAmB,EAAK;IAC1C,MAAM,GAAG,GAAQ,EAAE,CAAC;IACpB,KAAK,MAAM,CAAC,CAAC,EAAE,CAAC,CAAC,IAAI,MAAM,CAAC,OAAO,CAAC,EAAE,CAAC,EAAE,CAAC;QACxC,IAAI,CAAC,KAAK,SAAS,EAAE,CAAC;YACpB,GAAG,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC;QACb,CAAC;IACH,CAAC;IACD,OAAO,GAAG,CAAC;AACb,CAAC;AAED,SAAS,eAAe,CAAC,MAAoC;IAC3D,OAAO,MAAM,CAAC,MAAM,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,OAAO,CAAC,CAAC,MAAM,KAAK,QAAQ,IAAI,CAAC,CAAC,MAAM,IAAI,CAAC,CAAC,MAAM,CAAC,CAAC,CAAC;AACrF,CAAC","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"]}
|
package/package.json
CHANGED
|
@@ -97,11 +97,6 @@
|
|
|
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": {}
|
|
105
100
|
}
|
|
106
101
|
},
|
|
107
102
|
"required": [
|
|
@@ -246,11 +241,6 @@
|
|
|
246
241
|
"assumeRoleExternalId": {
|
|
247
242
|
"description": "The ExternalId that needs to be supplied while assuming this role (Default - No ExternalId will be supplied)",
|
|
248
243
|
"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": {}
|
|
254
244
|
}
|
|
255
245
|
},
|
|
256
246
|
"required": [
|