Socket
Socket
Sign inDemoInstall

@aws-cdk/cloud-assembly-schema

Package Overview
Dependencies
2
Maintainers
5
Versions
444
Alerts
File Explorer

Advanced tools

Install Socket

Detect and block malicious and high-risk dependencies

Install

Comparing version 1.38.0 to 1.39.0

lib/artifact-schema.d.ts

25

lib/context-queries.d.ts

@@ -24,3 +24,7 @@ /**

*/
VPC_PROVIDER = "vpc-provider"
VPC_PROVIDER = "vpc-provider",
/**
* VPC Endpoint Service AZ Provider
*/
ENDPOINT_SERVICE_AVAILABILITY_ZONE_PROVIDER = "endpoint-service-availability-zones"
}

@@ -153,2 +157,19 @@ /**

}
export declare type ContextQueryProperties = AmiContextQuery | AvailabilityZonesContextQuery | HostedZoneContextQuery | SSMParameterContextQuery | VpcContextQuery;
/**
* Query to endpoint service context provider
*/
export interface EndpointServiceAvailabilityZonesContextQuery {
/**
* Query account
*/
readonly account: string;
/**
* Query region
*/
readonly region: string;
/**
* Query service name
*/
readonly serviceName: string;
}
export declare type ContextQueryProperties = AmiContextQuery | AvailabilityZonesContextQuery | HostedZoneContextQuery | SSMParameterContextQuery | VpcContextQuery | EndpointServiceAvailabilityZonesContextQuery;

@@ -28,3 +28,7 @@ "use strict";

ContextProvider["VPC_PROVIDER"] = "vpc-provider";
/**
* VPC Endpoint Service AZ Provider
*/
ContextProvider["ENDPOINT_SERVICE_AVAILABILITY_ZONE_PROVIDER"] = "endpoint-service-availability-zones";
})(ContextProvider = exports.ContextProvider || (exports.ContextProvider = {}));
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY29udGV4dC1xdWVyaWVzLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiY29udGV4dC1xdWVyaWVzLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7O0FBQ0E7O0dBRUc7QUFDSCxJQUFZLGVBeUJYO0FBekJELFdBQVksZUFBZTtJQUN6Qjs7T0FFRztJQUNILHVDQUFvQixDQUFBO0lBRXBCOztPQUVHO0lBQ0gsb0VBQWlELENBQUE7SUFFakQ7O09BRUc7SUFDSCx1REFBb0MsQ0FBQTtJQUVwQzs7T0FFRztJQUNILGlEQUE4QixDQUFBO0lBRTlCOztPQUVHO0lBQ0gsZ0RBQTZCLENBQUE7QUFDL0IsQ0FBQyxFQXpCVyxlQUFlLEdBQWYsdUJBQWUsS0FBZix1QkFBZSxRQXlCMUIiLCJzb3VyY2VzQ29udGVudCI6WyJcbi8qKlxuICogSWRlbnRpZmllciBmb3IgdGhlIGNvbnRleHQgcHJvdmlkZXJcbiAqL1xuZXhwb3J0IGVudW0gQ29udGV4dFByb3ZpZGVyIHtcbiAgLyoqXG4gICAqIEFNSSBwcm92aWRlclxuICAgKi9cbiAgQU1JX1BST1ZJREVSID0gJ2FtaScsXG5cbiAgLyoqXG4gICAqIEFaIHByb3ZpZGVyXG4gICAqL1xuICBBVkFJTEFCSUxJVFlfWk9ORV9QUk9WSURFUiA9ICdhdmFpbGFiaWxpdHktem9uZXMnLFxuXG4gIC8qKlxuICAgKiBSb3V0ZTUzIEhvc3RlZCBab25lIHByb3ZpZGVyXG4gICAqL1xuICBIT1NURURfWk9ORV9QUk9WSURFUiA9ICdob3N0ZWQtem9uZScsXG5cbiAgLyoqXG4gICAqIFNTTSBQYXJhbWV0ZXIgUHJvdmlkZXJcbiAgICovXG4gIFNTTV9QQVJBTUVURVJfUFJPVklERVIgPSAnc3NtJyxcblxuICAvKipcbiAgICogVlBDIFByb3ZpZGVyXG4gICAqL1xuICBWUENfUFJPVklERVIgPSAndnBjLXByb3ZpZGVyJyxcbn1cblxuLyoqXG4gKiBRdWVyeSB0byBBTUkgY29udGV4dCBwcm92aWRlclxuICovXG5leHBvcnQgaW50ZXJmYWNlIEFtaUNvbnRleHRRdWVyeSB7XG4gIC8qKlxuICAgKiBBY2NvdW50IHRvIHF1ZXJ5XG4gICAqL1xuICByZWFkb25seSBhY2NvdW50OiBzdHJpbmc7XG5cbiAgLyoqXG4gICAqIFJlZ2lvbiB0byBxdWVyeVxuICAgKi9cbiAgcmVhZG9ubHkgcmVnaW9uOiBzdHJpbmc7XG5cbiAgLyoqXG4gICAqIE93bmVycyB0byBEZXNjcmliZUltYWdlcyBjYWxsXG4gICAqXG4gICAqIEBkZWZhdWx0IC0gQWxsIG93bmVyc1xuICAgKi9cbiAgcmVhZG9ubHkgb3duZXJzPzogc3RyaW5nW107XG5cbiAgLyoqXG4gICAqIEZpbHRlcnMgdG8gRGVzY3JpYmVJbWFnZXMgY2FsbFxuICAgKi9cbiAgcmVhZG9ubHkgZmlsdGVyczoge1trZXk6IHN0cmluZ106IHN0cmluZ1tdfTtcbn1cblxuLyoqXG4gKiBRdWVyeSB0byBhdmFpbGFiaWxpdHkgem9uZSBjb250ZXh0IHByb3ZpZGVyXG4gKi9cbmV4cG9ydCBpbnRlcmZhY2UgQXZhaWxhYmlsaXR5Wm9uZXNDb250ZXh0UXVlcnkge1xuICAvKipcbiAgICogUXVlcnkgYWNjb3VudFxuICAgKi9cbiAgcmVhZG9ubHkgYWNjb3VudDogc3RyaW5nO1xuXG4gIC8qKlxuICAgKiBRdWVyeSByZWdpb25cbiAgICovXG4gIHJlYWRvbmx5IHJlZ2lvbjogc3RyaW5nO1xufVxuXG4vKipcbiAqIFF1ZXJ5IHRvIGhvc3RlZCB6b25lIGNvbnRleHQgcHJvdmlkZXJcbiAqL1xuZXhwb3J0IGludGVyZmFjZSBIb3N0ZWRab25lQ29udGV4dFF1ZXJ5IHtcbiAgLyoqXG4gICAqIFF1ZXJ5IGFjY291bnRcbiAgICovXG4gIHJlYWRvbmx5IGFjY291bnQ6IHN0cmluZztcblxuICAvKipcbiAgICogUXVlcnkgcmVnaW9uXG4gICAqL1xuICByZWFkb25seSByZWdpb246IHN0cmluZztcblxuICAvKipcbiAgICogVGhlIGRvbWFpbiBuYW1lIGUuZy4gZXhhbXBsZS5jb20gdG8gbG9va3VwXG4gICAqL1xuICByZWFkb25seSBkb21haW5OYW1lOiBzdHJpbmc7XG5cbiAgLyoqXG4gICAqIFRydWUgaWYgdGhlIHpvbmUgeW91IHdhbnQgdG8gZmluZCBpcyBhIHByaXZhdGUgaG9zdGVkIHpvbmVcbiAgICpcbiAgICogQGRlZmF1bHQgZmFsc2VcbiAgICovXG4gIHJlYWRvbmx5IHByaXZhdGVab25lPzogYm9vbGVhbjtcblxuICAvKipcbiAgICogVGhlIFZQQyBJRCB0byB0aGF0IHRoZSBwcml2YXRlIHpvbmUgbXVzdCBiZSBhc3NvY2lhdGVkIHdpdGhcbiAgICpcbiAgICogSWYgeW91IHByb3ZpZGUgVlBDIElEIGFuZCBwcml2YXRlWm9uZSBpcyBmYWxzZSwgdGhpcyB3aWxsIHJldHVybiBubyByZXN1bHRzXG4gICAqIGFuZCByYWlzZSBhbiBlcnJvci5cbiAgICpcbiAgICogQGRlZmF1bHQgLSBSZXF1aXJlZCBpZiBwcml2YXRlWm9uZT10cnVlXG4gICAqL1xuICByZWFkb25seSB2cGNJZD86IHN0cmluZztcbn1cblxuLyoqXG4gKiBRdWVyeSB0byBTU00gUGFyYW1ldGVyIENvbnRleHQgUHJvdmlkZXJcbiAqL1xuZXhwb3J0IGludGVyZmFjZSBTU01QYXJhbWV0ZXJDb250ZXh0UXVlcnkge1xuICAvKipcbiAgICogUXVlcnkgYWNjb3VudFxuICAgKi9cbiAgcmVhZG9ubHkgYWNjb3VudDogc3RyaW5nO1xuXG4gIC8qKlxuICAgKiBRdWVyeSByZWdpb25cbiAgICovXG4gIHJlYWRvbmx5IHJlZ2lvbjogc3RyaW5nO1xuXG4gIC8qKlxuICAgKiBQYXJhbWV0ZXIgbmFtZSB0byBxdWVyeVxuICAgKi9cbiAgcmVhZG9ubHkgcGFyYW1ldGVyTmFtZTogc3RyaW5nO1xufVxuXG4vKipcbiAqIFF1ZXJ5IGlucHV0IGZvciBsb29raW5nIHVwIGEgVlBDXG4gKi9cbmV4cG9ydCBpbnRlcmZhY2UgVnBjQ29udGV4dFF1ZXJ5IHtcbiAgLyoqXG4gICAqIFF1ZXJ5IGFjY291bnRcbiAgICovXG4gIHJlYWRvbmx5IGFjY291bnQ6IHN0cmluZztcblxuICAvKipcbiAgICogUXVlcnkgcmVnaW9uXG4gICAqL1xuICByZWFkb25seSByZWdpb246IHN0cmluZztcblxuICAvKipcbiAgICogRmlsdGVycyB0byBhcHBseSB0byB0aGUgVlBDXG4gICAqXG4gICAqIEZpbHRlciBwYXJhbWV0ZXJzIGFyZSB0aGUgc2FtZSBhcyBwYXNzZWQgdG8gRGVzY3JpYmVWcGNzLlxuICAgKlxuICAgKiBAc2VlIGh0dHBzOi8vZG9jcy5hd3MuYW1hem9uLmNvbS9BV1NFQzIvbGF0ZXN0L0FQSVJlZmVyZW5jZS9BUElfRGVzY3JpYmVWcGNzLmh0bWxcbiAgICovXG4gIHJlYWRvbmx5IGZpbHRlcjoge1trZXk6IHN0cmluZ106IHN0cmluZ307XG5cbiAgLyoqXG4gICAqIFdoZXRoZXIgdG8gcG9wdWxhdGUgdGhlIHN1Ym5ldEdyb3VwcyBmaWVsZCBvZiB0aGUge0BsaW5rIFZwY0NvbnRleHRSZXNwb25zZX0sXG4gICAqIHdoaWNoIGNvbnRhaW5zIHBvdGVudGlhbGx5IGFzeW1tZXRyaWMgc3VibmV0IGdyb3Vwcy5cbiAgICpcbiAgICogQGRlZmF1bHQgZmFsc2VcbiAgICovXG4gIHJlYWRvbmx5IHJldHVybkFzeW1tZXRyaWNTdWJuZXRzPzogYm9vbGVhbjtcblxuICAvKipcbiAgICogT3B0aW9uYWwgdGFnIGZvciBzdWJuZXQgZ3JvdXAgbmFtZS5cbiAgICogSWYgbm90IHByb3ZpZGVkLCB3ZSdsbCBsb29rIGF0IHRoZSBhd3MtY2RrOnN1Ym5ldC1uYW1lIHRhZy5cbiAgICogSWYgdGhlIHN1Ym5ldCBkb2VzIG5vdCBoYXZlIHRoZSBzcGVjaWZpZWQgdGFnLFxuICAgKiB3ZSdsbCB1c2UgaXRzIHR5cGUgYXMgdGhlIG5hbWUuXG4gICAqXG4gICAqIEBkZWZhdWx0ICdhd3MtY2RrOnN1Ym5ldC1uYW1lJ1xuICAgKi9cbiAgcmVhZG9ubHkgc3VibmV0R3JvdXBOYW1lVGFnPzogc3RyaW5nO1xufVxuXG5leHBvcnQgdHlwZSBDb250ZXh0UXVlcnlQcm9wZXJ0aWVzID0gQW1pQ29udGV4dFF1ZXJ5XG58IEF2YWlsYWJpbGl0eVpvbmVzQ29udGV4dFF1ZXJ5XG58IEhvc3RlZFpvbmVDb250ZXh0UXVlcnlcbnwgU1NNUGFyYW1ldGVyQ29udGV4dFF1ZXJ5XG58IFZwY0NvbnRleHRRdWVyeTtcbiJdfQ==
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY29udGV4dC1xdWVyaWVzLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiY29udGV4dC1xdWVyaWVzLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7O0FBQ0E7O0dBRUc7QUFDSCxJQUFZLGVBK0JYO0FBL0JELFdBQVksZUFBZTtJQUN6Qjs7T0FFRztJQUNILHVDQUFvQixDQUFBO0lBRXBCOztPQUVHO0lBQ0gsb0VBQWlELENBQUE7SUFFakQ7O09BRUc7SUFDSCx1REFBb0MsQ0FBQTtJQUVwQzs7T0FFRztJQUNILGlEQUE4QixDQUFBO0lBRTlCOztPQUVHO0lBQ0gsZ0RBQTZCLENBQUE7SUFFN0I7O09BRUc7SUFDSCxzR0FBbUYsQ0FBQTtBQUVyRixDQUFDLEVBL0JXLGVBQWUsR0FBZix1QkFBZSxLQUFmLHVCQUFlLFFBK0IxQiIsInNvdXJjZXNDb250ZW50IjpbIlxuLyoqXG4gKiBJZGVudGlmaWVyIGZvciB0aGUgY29udGV4dCBwcm92aWRlclxuICovXG5leHBvcnQgZW51bSBDb250ZXh0UHJvdmlkZXIge1xuICAvKipcbiAgICogQU1JIHByb3ZpZGVyXG4gICAqL1xuICBBTUlfUFJPVklERVIgPSAnYW1pJyxcblxuICAvKipcbiAgICogQVogcHJvdmlkZXJcbiAgICovXG4gIEFWQUlMQUJJTElUWV9aT05FX1BST1ZJREVSID0gJ2F2YWlsYWJpbGl0eS16b25lcycsXG5cbiAgLyoqXG4gICAqIFJvdXRlNTMgSG9zdGVkIFpvbmUgcHJvdmlkZXJcbiAgICovXG4gIEhPU1RFRF9aT05FX1BST1ZJREVSID0gJ2hvc3RlZC16b25lJyxcblxuICAvKipcbiAgICogU1NNIFBhcmFtZXRlciBQcm92aWRlclxuICAgKi9cbiAgU1NNX1BBUkFNRVRFUl9QUk9WSURFUiA9ICdzc20nLFxuXG4gIC8qKlxuICAgKiBWUEMgUHJvdmlkZXJcbiAgICovXG4gIFZQQ19QUk9WSURFUiA9ICd2cGMtcHJvdmlkZXInLFxuXG4gIC8qKlxuICAgKiBWUEMgRW5kcG9pbnQgU2VydmljZSBBWiBQcm92aWRlclxuICAgKi9cbiAgRU5EUE9JTlRfU0VSVklDRV9BVkFJTEFCSUxJVFlfWk9ORV9QUk9WSURFUiA9ICdlbmRwb2ludC1zZXJ2aWNlLWF2YWlsYWJpbGl0eS16b25lcycsXG5cbn1cblxuLyoqXG4gKiBRdWVyeSB0byBBTUkgY29udGV4dCBwcm92aWRlclxuICovXG5leHBvcnQgaW50ZXJmYWNlIEFtaUNvbnRleHRRdWVyeSB7XG4gIC8qKlxuICAgKiBBY2NvdW50IHRvIHF1ZXJ5XG4gICAqL1xuICByZWFkb25seSBhY2NvdW50OiBzdHJpbmc7XG5cbiAgLyoqXG4gICAqIFJlZ2lvbiB0byBxdWVyeVxuICAgKi9cbiAgcmVhZG9ubHkgcmVnaW9uOiBzdHJpbmc7XG5cbiAgLyoqXG4gICAqIE93bmVycyB0byBEZXNjcmliZUltYWdlcyBjYWxsXG4gICAqXG4gICAqIEBkZWZhdWx0IC0gQWxsIG93bmVyc1xuICAgKi9cbiAgcmVhZG9ubHkgb3duZXJzPzogc3RyaW5nW107XG5cbiAgLyoqXG4gICAqIEZpbHRlcnMgdG8gRGVzY3JpYmVJbWFnZXMgY2FsbFxuICAgKi9cbiAgcmVhZG9ubHkgZmlsdGVyczoge1trZXk6IHN0cmluZ106IHN0cmluZ1tdfTtcbn1cblxuLyoqXG4gKiBRdWVyeSB0byBhdmFpbGFiaWxpdHkgem9uZSBjb250ZXh0IHByb3ZpZGVyXG4gKi9cbmV4cG9ydCBpbnRlcmZhY2UgQXZhaWxhYmlsaXR5Wm9uZXNDb250ZXh0UXVlcnkge1xuICAvKipcbiAgICogUXVlcnkgYWNjb3VudFxuICAgKi9cbiAgcmVhZG9ubHkgYWNjb3VudDogc3RyaW5nO1xuXG4gIC8qKlxuICAgKiBRdWVyeSByZWdpb25cbiAgICovXG4gIHJlYWRvbmx5IHJlZ2lvbjogc3RyaW5nO1xufVxuXG4vKipcbiAqIFF1ZXJ5IHRvIGhvc3RlZCB6b25lIGNvbnRleHQgcHJvdmlkZXJcbiAqL1xuZXhwb3J0IGludGVyZmFjZSBIb3N0ZWRab25lQ29udGV4dFF1ZXJ5IHtcbiAgLyoqXG4gICAqIFF1ZXJ5IGFjY291bnRcbiAgICovXG4gIHJlYWRvbmx5IGFjY291bnQ6IHN0cmluZztcblxuICAvKipcbiAgICogUXVlcnkgcmVnaW9uXG4gICAqL1xuICByZWFkb25seSByZWdpb246IHN0cmluZztcblxuICAvKipcbiAgICogVGhlIGRvbWFpbiBuYW1lIGUuZy4gZXhhbXBsZS5jb20gdG8gbG9va3VwXG4gICAqL1xuICByZWFkb25seSBkb21haW5OYW1lOiBzdHJpbmc7XG5cbiAgLyoqXG4gICAqIFRydWUgaWYgdGhlIHpvbmUgeW91IHdhbnQgdG8gZmluZCBpcyBhIHByaXZhdGUgaG9zdGVkIHpvbmVcbiAgICpcbiAgICogQGRlZmF1bHQgZmFsc2VcbiAgICovXG4gIHJlYWRvbmx5IHByaXZhdGVab25lPzogYm9vbGVhbjtcblxuICAvKipcbiAgICogVGhlIFZQQyBJRCB0byB0aGF0IHRoZSBwcml2YXRlIHpvbmUgbXVzdCBiZSBhc3NvY2lhdGVkIHdpdGhcbiAgICpcbiAgICogSWYgeW91IHByb3ZpZGUgVlBDIElEIGFuZCBwcml2YXRlWm9uZSBpcyBmYWxzZSwgdGhpcyB3aWxsIHJldHVybiBubyByZXN1bHRzXG4gICAqIGFuZCByYWlzZSBhbiBlcnJvci5cbiAgICpcbiAgICogQGRlZmF1bHQgLSBSZXF1aXJlZCBpZiBwcml2YXRlWm9uZT10cnVlXG4gICAqL1xuICByZWFkb25seSB2cGNJZD86IHN0cmluZztcbn1cblxuLyoqXG4gKiBRdWVyeSB0byBTU00gUGFyYW1ldGVyIENvbnRleHQgUHJvdmlkZXJcbiAqL1xuZXhwb3J0IGludGVyZmFjZSBTU01QYXJhbWV0ZXJDb250ZXh0UXVlcnkge1xuICAvKipcbiAgICogUXVlcnkgYWNjb3VudFxuICAgKi9cbiAgcmVhZG9ubHkgYWNjb3VudDogc3RyaW5nO1xuXG4gIC8qKlxuICAgKiBRdWVyeSByZWdpb25cbiAgICovXG4gIHJlYWRvbmx5IHJlZ2lvbjogc3RyaW5nO1xuXG4gIC8qKlxuICAgKiBQYXJhbWV0ZXIgbmFtZSB0byBxdWVyeVxuICAgKi9cbiAgcmVhZG9ubHkgcGFyYW1ldGVyTmFtZTogc3RyaW5nO1xufVxuXG4vKipcbiAqIFF1ZXJ5IGlucHV0IGZvciBsb29raW5nIHVwIGEgVlBDXG4gKi9cbmV4cG9ydCBpbnRlcmZhY2UgVnBjQ29udGV4dFF1ZXJ5IHtcbiAgLyoqXG4gICAqIFF1ZXJ5IGFjY291bnRcbiAgICovXG4gIHJlYWRvbmx5IGFjY291bnQ6IHN0cmluZztcblxuICAvKipcbiAgICogUXVlcnkgcmVnaW9uXG4gICAqL1xuICByZWFkb25seSByZWdpb246IHN0cmluZztcblxuICAvKipcbiAgICogRmlsdGVycyB0byBhcHBseSB0byB0aGUgVlBDXG4gICAqXG4gICAqIEZpbHRlciBwYXJhbWV0ZXJzIGFyZSB0aGUgc2FtZSBhcyBwYXNzZWQgdG8gRGVzY3JpYmVWcGNzLlxuICAgKlxuICAgKiBAc2VlIGh0dHBzOi8vZG9jcy5hd3MuYW1hem9uLmNvbS9BV1NFQzIvbGF0ZXN0L0FQSVJlZmVyZW5jZS9BUElfRGVzY3JpYmVWcGNzLmh0bWxcbiAgICovXG4gIHJlYWRvbmx5IGZpbHRlcjoge1trZXk6IHN0cmluZ106IHN0cmluZ307XG5cbiAgLyoqXG4gICAqIFdoZXRoZXIgdG8gcG9wdWxhdGUgdGhlIHN1Ym5ldEdyb3VwcyBmaWVsZCBvZiB0aGUge0BsaW5rIFZwY0NvbnRleHRSZXNwb25zZX0sXG4gICAqIHdoaWNoIGNvbnRhaW5zIHBvdGVudGlhbGx5IGFzeW1tZXRyaWMgc3VibmV0IGdyb3Vwcy5cbiAgICpcbiAgICogQGRlZmF1bHQgZmFsc2VcbiAgICovXG4gIHJlYWRvbmx5IHJldHVybkFzeW1tZXRyaWNTdWJuZXRzPzogYm9vbGVhbjtcblxuICAvKipcbiAgICogT3B0aW9uYWwgdGFnIGZvciBzdWJuZXQgZ3JvdXAgbmFtZS5cbiAgICogSWYgbm90IHByb3ZpZGVkLCB3ZSdsbCBsb29rIGF0IHRoZSBhd3MtY2RrOnN1Ym5ldC1uYW1lIHRhZy5cbiAgICogSWYgdGhlIHN1Ym5ldCBkb2VzIG5vdCBoYXZlIHRoZSBzcGVjaWZpZWQgdGFnLFxuICAgKiB3ZSdsbCB1c2UgaXRzIHR5cGUgYXMgdGhlIG5hbWUuXG4gICAqXG4gICAqIEBkZWZhdWx0ICdhd3MtY2RrOnN1Ym5ldC1uYW1lJ1xuICAgKi9cbiAgcmVhZG9ubHkgc3VibmV0R3JvdXBOYW1lVGFnPzogc3RyaW5nO1xufVxuXG4vKipcbiAqIFF1ZXJ5IHRvIGVuZHBvaW50IHNlcnZpY2UgY29udGV4dCBwcm92aWRlclxuICovXG5leHBvcnQgaW50ZXJmYWNlIEVuZHBvaW50U2VydmljZUF2YWlsYWJpbGl0eVpvbmVzQ29udGV4dFF1ZXJ5IHtcbiAgLyoqXG4gICAqIFF1ZXJ5IGFjY291bnRcbiAgICovXG4gIHJlYWRvbmx5IGFjY291bnQ6IHN0cmluZztcblxuICAvKipcbiAgICogUXVlcnkgcmVnaW9uXG4gICAqL1xuICByZWFkb25seSByZWdpb246IHN0cmluZztcblxuICAvKipcbiAgICogUXVlcnkgc2VydmljZSBuYW1lXG4gICAqL1xuICByZWFkb25seSBzZXJ2aWNlTmFtZTogc3RyaW5nO1xufVxuXG5leHBvcnQgdHlwZSBDb250ZXh0UXVlcnlQcm9wZXJ0aWVzID0gQW1pQ29udGV4dFF1ZXJ5XG58IEF2YWlsYWJpbGl0eVpvbmVzQ29udGV4dFF1ZXJ5XG58IEhvc3RlZFpvbmVDb250ZXh0UXVlcnlcbnwgU1NNUGFyYW1ldGVyQ29udGV4dFF1ZXJ5XG58IFZwY0NvbnRleHRRdWVyeVxufCBFbmRwb2ludFNlcnZpY2VBdmFpbGFiaWxpdHlab25lc0NvbnRleHRRdWVyeTtcbiJdfQ==
export * from './manifest';
export * from './schema';
export * from './metadata-schema';
export * from './artifact-schema';
export * from './context-queries';

3

lib/index.js

@@ -8,3 +8,4 @@ "use strict";

__export(require("./schema"));
__export(require("./metadata-schema"));
__export(require("./context-queries"));
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyJpbmRleC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOzs7OztBQUFBLGdDQUEyQjtBQUMzQiw4QkFBeUI7QUFDekIsdUNBQWtDIiwic291cmNlc0NvbnRlbnQiOlsiZXhwb3J0ICogZnJvbSAnLi9tYW5pZmVzdCc7XG5leHBvcnQgKiBmcm9tICcuL3NjaGVtYSc7XG5leHBvcnQgKiBmcm9tICcuL2NvbnRleHQtcXVlcmllcyc7XG4iXX0=
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyJpbmRleC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOzs7OztBQUFBLGdDQUEyQjtBQUMzQiw4QkFBeUI7QUFDekIsdUNBQWtDO0FBRWxDLHVDQUFrQyIsInNvdXJjZXNDb250ZW50IjpbImV4cG9ydCAqIGZyb20gJy4vbWFuaWZlc3QnO1xuZXhwb3J0ICogZnJvbSAnLi9zY2hlbWEnO1xuZXhwb3J0ICogZnJvbSAnLi9tZXRhZGF0YS1zY2hlbWEnO1xuZXhwb3J0ICogZnJvbSAnLi9hcnRpZmFjdC1zY2hlbWEnO1xuZXhwb3J0ICogZnJvbSAnLi9jb250ZXh0LXF1ZXJpZXMnO1xuIl19

@@ -6,2 +6,3 @@ "use strict";

const semver = require("semver");
const metadata_schema_1 = require("./metadata-schema");
const assembly = require("./schema");

@@ -90,3 +91,3 @@ // this prefix is used by the CLI to identify this specific error.

for (const metadataEntry of metadataEntries) {
if (metadataEntry.type === assembly.ArtifactMetadataEntryType.STACK_TAGS && metadataEntry.data) {
if (metadataEntry.type === metadata_schema_1.ArtifactMetadataEntryType.STACK_TAGS && metadataEntry.data) {
const metadataAny = metadataEntry;

@@ -106,2 +107,2 @@ metadataAny.data = metadataAny.data.map((t) => {

Manifest.schema = require('../schema/cloud-assembly.schema.json');
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"manifest.js","sourceRoot":"","sources":["manifest.ts"],"names":[],"mappings":";;AAAA,yBAAyB;AACzB,yCAAyC;AACzC,iCAAiC;AACjC,qCAAqC;AAErC,kEAAkE;AAClE,iEAAiE;AACjE,6BAA6B;AAChB,QAAA,gBAAgB,GAAW,wCAAwC,CAAC;AAEjF;;GAEG;AACH,MAAa,QAAQ;IAuGnB,gBAAuB,CAAC;IAtGxB;;;;OAIG;IACI,MAAM,CAAC,IAAI,CAAC,QAAmC,EAAE,QAAgB;QACtE,EAAE,CAAC,aAAa,CAAC,QAAQ,EAAE,IAAI,CAAC,SAAS,CAAC,QAAQ,EAAE,SAAS,EAAE,CAAC,CAAC,CAAC,CAAC;IACrE,CAAC;IAED;;;;OAIG;IACI,MAAM,CAAC,IAAI,CAAC,QAAgB;QACjC,MAAM,GAAG,GAA8B,IAAI,CAAC,KAAK,CAAC,EAAE,CAAC,YAAY,CAAC,QAAQ,EAAE,OAAO,CAAC,CAAC,CAAC;QACtF,QAAQ,CAAC,cAAc,CAAC,GAAG,CAAC,CAAC;QAC7B,QAAQ,CAAC,QAAQ,CAAC,GAAG,CAAC,CAAC;QACvB,OAAO,GAAG,CAAC;IACb,CAAC;IAED;;OAEG;IACI,MAAM,CAAC,OAAO;QACnB,iEAAiE;QACjE,OAAO,OAAO,CAAC,uCAAuC,CAAC,CAAC,OAAO,CAAC;IAClE,CAAC;IAKO,MAAM,CAAC,QAAQ,CAAC,QAAmC;QAEzD,SAAS,YAAY,CAAC,OAAe;YACnC,MAAM,GAAG,GAAG,MAAM,CAAC,KAAK,CAAC,OAAO,CAAC,CAAC;YAClC,IAAI,CAAC,GAAG,EAAE;gBACR,MAAM,IAAI,KAAK,CAAC,2BAA2B,OAAO,GAAG,CAAC,CAAC;aACxD;YACD,OAAO,GAAG,CAAC;QACb,CAAC;QAED,MAAM,YAAY,GAAG,YAAY,CAAC,QAAQ,CAAC,OAAO,EAAE,CAAC,CAAC;QACtD,MAAM,MAAM,GAAG,YAAY,CAAC,QAAQ,CAAC,OAAO,CAAC,CAAC;QAE9C,iDAAiD;QACjD,IAAI,MAAM,CAAC,EAAE,CAAC,MAAM,EAAE,YAAY,CAAC,EAAE;YACnC,oFAAoF;YACpF,2CAA2C;YAC3C,MAAM,IAAI,KAAK,CAAC,GAAG,wBAAgB,yCAAyC,YAAY,eAAe,MAAM,EAAE,CAAC,CAAC;SAClH;QAED,mCAAmC;QACnC,MAAM,SAAS,GAAG,IAAI,UAAU,CAAC,SAAS,EAAE,CAAC;QAC7C,MAAM,MAAM,GAAG,SAAS,CAAC,QAAQ,CAAC,QAAQ,EAAE,QAAQ,CAAC,MAAM,EAAE;YAE3D,sDAAsD;YACtD,YAAY,EAAE,IAAI;YAElB,sBAAsB,EAAE,KAAK;SAEvB,CAAC,CAAC;QACV,IAAI,CAAC,MAAM,CAAC,KAAK,EAAE;YACjB,MAAM,IAAI,KAAK,CAAC,+BAA+B,MAAM,EAAE,CAAC,CAAC;SAC1D;IAEH,CAAC;IAED;;;;;;;;;;;;;;OAcG;IACK,MAAM,CAAC,cAAc,CAAC,QAAmC;QAC/D,KAAK,MAAM,QAAQ,IAAI,MAAM,CAAC,MAAM,CAAC,QAAQ,CAAC,SAAS,IAAI,EAAE,CAAC,EAAE;YAC9D,IAAI,QAAQ,CAAC,IAAI,KAAK,QAAQ,CAAC,YAAY,CAAC,wBAAwB,EAAE;gBACpE,KAAK,MAAM,eAAe,IAAI,MAAM,CAAC,MAAM,CAAC,QAAQ,CAAC,QAAQ,IAAI,EAAE,CAAC,EAAE;oBACpE,KAAK,MAAM,aAAa,IAAI,eAAe,EAAE;wBAC3C,IAAI,aAAa,CAAC,IAAI,KAAK,QAAQ,CAAC,yBAAyB,CAAC,UAAU,IAAI,aAAa,CAAC,IAAI,EAAE;4BAE9F,MAAM,WAAW,GAAG,aAAoB,CAAC;4BAEzC,WAAW,CAAC,IAAI,GAAG,WAAW,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC,CAAM,EAAE,EAAE;gCACjD,OAAO,EAAE,GAAG,EAAE,CAAC,CAAC,GAAG,EAAE,KAAK,EAAE,CAAC,CAAC,KAAK,EAAE,CAAC;4BACxC,CAAC,CAAC,CAAC;yBACJ;qBACF;iBACF;aACF;SACF;IACH,CAAC;;AArGH,4BAyGC;AA3EC,iEAAiE;AAClD,eAAM,GAAsB,OAAO,CAAC,sCAAsC,CAAC,CAAC","sourcesContent":["import * as fs from 'fs';\nimport * as jsonschema from 'jsonschema';\nimport * as semver from 'semver';\nimport * as assembly from './schema';\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\n/**\n * Protocol utility class.\n */\nexport class Manifest {\n  /**\n   * Save manifest to file.\n   *\n   * @param manifest - manifest.\n   */\n  public static save(manifest: assembly.AssemblyManifest, filePath: string) {\n    fs.writeFileSync(filePath, JSON.stringify(manifest, undefined, 2));\n  }\n\n  /**\n   * Load manifest from file.\n   *\n   * @param filePath - path to the manifest file.\n   */\n  public static load(filePath: string): assembly.AssemblyManifest {\n    const raw: assembly.AssemblyManifest = JSON.parse(fs.readFileSync(filePath, 'UTF-8'));\n    Manifest.patchStackTags(raw);\n    Manifest.validate(raw);\n    return raw;\n  }\n\n  /**\n   * Fetch the current schema version number.\n   */\n  public static version(): string {\n    // eslint-disable-next-line @typescript-eslint/no-require-imports\n    return require('../schema/cloud-assembly.version.json').version;\n  }\n\n  // eslint-disable-next-line @typescript-eslint/no-require-imports\n  private static schema: jsonschema.Schema = require('../schema/cloud-assembly.schema.json');\n\n  private static validate(manifest: assembly.AssemblyManifest) {\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 = parseVersion(Manifest.version());\n    const actual = parseVersion(manifest.version);\n\n    // first validate the version should be accepted.\n    if (semver.gt(actual, maxSupported)) {\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(`${VERSION_MISMATCH}: Maximum schema version supported is ${maxSupported}, but found ${actual}`);\n    }\n\n    // now validate the format is good.\n    const validator = new jsonschema.Validator();\n    const result = validator.validate(manifest, Manifest.schema, {\n\n      // does exist but is not in the TypeScript definitions\n      nestedErrors: true,\n\n      allowUnknownAttributes: false,\n\n    } as any);\n    if (!result.valid) {\n      throw new Error(`Invalid assembly manifest:\\n${result}`);\n    }\n\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 patchStackTags(manifest: assembly.AssemblyManifest) {\n    for (const artifact of Object.values(manifest.artifacts || [])) {\n      if (artifact.type === assembly.ArtifactType.AWS_CLOUDFORMATION_STACK) {\n        for (const metadataEntries of Object.values(artifact.metadata || [])) {\n          for (const metadataEntry of metadataEntries) {\n            if (metadataEntry.type === assembly.ArtifactMetadataEntryType.STACK_TAGS && metadataEntry.data) {\n\n              const metadataAny = metadataEntry as any;\n\n              metadataAny.data = metadataAny.data.map((t: any) => {\n                return { key: t.Key, value: t.Value };\n              });\n            }\n          }\n        }\n      }\n    }\n  }\n\n  private constructor() {}\n\n}\n"]}
//# 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 { ArtifactMetadataEntryType } from './metadata-schema';\nimport * as assembly from './schema';\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\n/**\n * Protocol utility class.\n */\nexport class Manifest {\n  /**\n   * Save manifest to file.\n   *\n   * @param manifest - manifest.\n   */\n  public static save(manifest: assembly.AssemblyManifest, filePath: string) {\n    fs.writeFileSync(filePath, JSON.stringify(manifest, undefined, 2));\n  }\n\n  /**\n   * Load manifest from file.\n   *\n   * @param filePath - path to the manifest file.\n   */\n  public static load(filePath: string): assembly.AssemblyManifest {\n    const raw: assembly.AssemblyManifest = JSON.parse(fs.readFileSync(filePath, 'UTF-8'));\n    Manifest.patchStackTags(raw);\n    Manifest.validate(raw);\n    return raw;\n  }\n\n  /**\n   * Fetch the current schema version number.\n   */\n  public static version(): string {\n    // eslint-disable-next-line @typescript-eslint/no-require-imports\n    return require('../schema/cloud-assembly.version.json').version;\n  }\n\n  // eslint-disable-next-line @typescript-eslint/no-require-imports\n  private static schema: jsonschema.Schema = require('../schema/cloud-assembly.schema.json');\n\n  private static validate(manifest: assembly.AssemblyManifest) {\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 = parseVersion(Manifest.version());\n    const actual = parseVersion(manifest.version);\n\n    // first validate the version should be accepted.\n    if (semver.gt(actual, maxSupported)) {\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(`${VERSION_MISMATCH}: Maximum schema version supported is ${maxSupported}, but found ${actual}`);\n    }\n\n    // now validate the format is good.\n    const validator = new jsonschema.Validator();\n    const result = validator.validate(manifest, Manifest.schema, {\n\n      // does exist but is not in the TypeScript definitions\n      nestedErrors: true,\n\n      allowUnknownAttributes: false,\n\n    } as any);\n    if (!result.valid) {\n      throw new Error(`Invalid assembly manifest:\\n${result}`);\n    }\n\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 patchStackTags(manifest: assembly.AssemblyManifest) {\n    for (const artifact of Object.values(manifest.artifacts || [])) {\n      if (artifact.type === assembly.ArtifactType.AWS_CLOUDFORMATION_STACK) {\n        for (const metadataEntries of Object.values(artifact.metadata || [])) {\n          for (const metadataEntry of metadataEntries) {\n            if (metadataEntry.type === ArtifactMetadataEntryType.STACK_TAGS && metadataEntry.data) {\n\n              const metadataAny = metadataEntry as any;\n\n              metadataAny.data = metadataAny.data.map((t: any) => {\n                return { key: t.Key, value: t.Value };\n              });\n            }\n          }\n        }\n      }\n    }\n  }\n\n  private constructor() {}\n\n}\n"]}

@@ -0,166 +1,5 @@

import { ArtifactProperties } from './artifact-schema';
import { ContextProvider, ContextQueryProperties } from './context-queries';
import { MetadataEntry } from './metadata-schema';
/**
* Common properties for asset metadata.
*/
interface BaseAssetMetadataEntry {
/**
* Requested packaging style
*/
readonly packaging: string;
/**
* Logical identifier for the asset
*/
readonly id: string;
/**
* The hash of the asset source.
*/
readonly sourceHash: string;
/**
* Path on disk to the asset
*/
readonly path: string;
}
/**
* Metadata Entry spec for files.
*/
export interface FileAssetMetadataEntry extends BaseAssetMetadataEntry {
/**
* Requested packaging style
*/
readonly packaging: 'zip' | 'file';
/**
* Name of parameter where S3 bucket should be passed in
*/
readonly s3BucketParameter: string;
/**
* Name of parameter where S3 key should be passed in
*/
readonly s3KeyParameter: string;
/**
* The name of the parameter where the hash of the bundled asset should be passed in.
*/
readonly artifactHashParameter: string;
}
/**
* Metadata Entry spec for container images.
*/
export interface ContainerImageAssetMetadataEntry extends BaseAssetMetadataEntry {
/**
* Type of asset
*/
readonly packaging: 'container-image';
/**
* ECR Repository name and repo digest (separated by "@sha256:") where this
* image is stored.
*
* @default undefined If not specified, `repositoryName` and `imageTag` are
* required because otherwise how will the stack know where to find the asset,
* ha?
* @deprecated specify `repositoryName` and `imageTag` instead, and then you
* know where the image will go.
*/
readonly imageNameParameter?: string;
/**
* ECR repository name, if omitted a default name based on the asset's ID is
* used instead. Specify this property if you need to statically address the
* image, e.g. from a Kubernetes Pod. Note, this is only the repository name,
* without the registry and the tag parts.
*
* @default - this parameter is REQUIRED after 1.21.0
*/
readonly repositoryName?: string;
/**
* The docker image tag to use for tagging pushed images. This field is
* required if `imageParameterName` is ommited (otherwise, the app won't be
* able to find the image).
*
* @default - this parameter is REQUIRED after 1.21.0
*/
readonly imageTag?: string;
/**
* Build args to pass to the `docker build` command
*
* @default no build args are passed
*/
readonly buildArgs?: {
[key: string]: string;
};
/**
* Docker target to build to
*
* @default no build target
*/
readonly target?: string;
/**
* Path to the Dockerfile (relative to the directory).
*
* @default - no file is passed
*/
readonly file?: string;
}
/**
* Metadata Entry spec for stack tag.
*/
export interface Tag {
/**
* Tag key.
*/
readonly key: string;
/**
* Tag value.
*/
readonly value: string;
}
/**
* @see ArtifactMetadataEntryType.ASSET
*/
export declare type AssetMetadataEntry = FileAssetMetadataEntry | ContainerImageAssetMetadataEntry;
/**
* @see ArtifactMetadataEntryType.INFO
* @see ArtifactMetadataEntryType.WARN
* @see ArtifactMetadataEntryType.ERROR
*/
export declare type LogMessageMetadataEntry = string;
/**
* @see ArtifactMetadataEntryType.LOGICAL_ID
*/
export declare type LogicalIdMetadataEntry = string;
/**
* @see ArtifactMetadataEntryType.STACK_TAGS
*/
export declare type StackTagsMetadataEntry = Tag[];
/**
* Union type for all metadata entries that might exist in the manifest.
*/
export declare type MetadataEntryData = AssetMetadataEntry | LogMessageMetadataEntry | LogicalIdMetadataEntry | StackTagsMetadataEntry;
/**
* Type of artifact metadata entry.
*/
export declare enum ArtifactMetadataEntryType {
/**
* Asset in metadata.
*/
ASSET = "aws:cdk:asset",
/**
* Metadata key used to print INFO-level messages by the toolkit when an app is syntheized.
*/
INFO = "aws:cdk:info",
/**
* Metadata key used to print WARNING-level messages by the toolkit when an app is syntheized.
*/
WARN = "aws:cdk:warning",
/**
* Metadata key used to print ERROR-level messages by the toolkit when an app is syntheized.
*/
ERROR = "aws:cdk:error",
/**
* Represents the CloudFormation logical ID of a resource at a certain path.
*/
LOGICAL_ID = "aws:cdk:logicalId",
/**
* Represents tags of a stack.
*/
STACK_TAGS = "aws:cdk:stack-tags"
}
/**
* Type of cloud artifact.

@@ -180,24 +19,7 @@ */

*/
CDK_TREE = "cdk:tree"
}
/**
* A metadata entry in a cloud assembly artifact.
*/
export interface MetadataEntry {
CDK_TREE = "cdk:tree",
/**
* The type of the metadata entry.
* Manifest for all assets in the Cloud Assembly
*/
readonly type: string;
/**
* The data.
*
* @default - no data.
*/
readonly data?: MetadataEntryData;
/**
* A stack trace for when the entry was created.
*
* @default - no trace.
*/
readonly trace?: string[];
ASSET_MANIFEST = "cdk:asset-manifest"
}

@@ -265,5 +87,3 @@ /**

*/
readonly properties?: {
[name: string]: any;
};
readonly properties?: ArtifactProperties;
}

@@ -300,2 +120,1 @@ /**

}
export {};
"use strict";
Object.defineProperty(exports, "__esModule", { value: true });
/**
* Type of artifact metadata entry.
*/
var ArtifactMetadataEntryType;
(function (ArtifactMetadataEntryType) {
/**
* Asset in metadata.
*/
ArtifactMetadataEntryType["ASSET"] = "aws:cdk:asset";
/**
* Metadata key used to print INFO-level messages by the toolkit when an app is syntheized.
*/
ArtifactMetadataEntryType["INFO"] = "aws:cdk:info";
/**
* Metadata key used to print WARNING-level messages by the toolkit when an app is syntheized.
*/
ArtifactMetadataEntryType["WARN"] = "aws:cdk:warning";
/**
* Metadata key used to print ERROR-level messages by the toolkit when an app is syntheized.
*/
ArtifactMetadataEntryType["ERROR"] = "aws:cdk:error";
/**
* Represents the CloudFormation logical ID of a resource at a certain path.
*/
ArtifactMetadataEntryType["LOGICAL_ID"] = "aws:cdk:logicalId";
/**
* Represents tags of a stack.
*/
ArtifactMetadataEntryType["STACK_TAGS"] = "aws:cdk:stack-tags";
})(ArtifactMetadataEntryType = exports.ArtifactMetadataEntryType || (exports.ArtifactMetadataEntryType = {}));
/**
* Type of cloud artifact.

@@ -50,3 +20,7 @@ */

ArtifactType["CDK_TREE"] = "cdk:tree";
/**
* Manifest for all assets in the Cloud Assembly
*/
ArtifactType["ASSET_MANIFEST"] = "cdk:asset-manifest";
})(ArtifactType = exports.ArtifactType || (exports.ArtifactType = {}));
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"schema.js","sourceRoot":"","sources":["schema.ts"],"names":[],"mappings":";;AA+JA;;GAEG;AACH,IAAY,yBA8BX;AA9BD,WAAY,yBAAyB;IACnC;;OAEG;IACH,oDAAuB,CAAA;IAEvB;;OAEG;IACH,kDAAqB,CAAA;IAErB;;OAEG;IACH,qDAAwB,CAAA;IAExB;;OAEG;IACH,oDAAuB,CAAA;IAEvB;;OAEG;IACH,6DAAgC,CAAA;IAEhC;;OAEG;IACH,8DAAiC,CAAA;AACnC,CAAC,EA9BW,yBAAyB,GAAzB,iCAAyB,KAAzB,iCAAyB,QA8BpC;AAED;;GAEG;AACH,IAAY,YAeX;AAfD,WAAY,YAAY;IACtB;;OAEG;IACH,6BAAa,CAAA;IAEb;;OAEG;IACH,qEAAqD,CAAA;IAErD;;OAEG;IACH,qCAAqB,CAAA;AACvB,CAAC,EAfW,YAAY,GAAZ,oBAAY,KAAZ,oBAAY,QAevB","sourcesContent":["import { ContextProvider, ContextQueryProperties } from './context-queries';\n\n/**\n * Common properties for asset metadata.\n */\ninterface BaseAssetMetadataEntry {\n  /**\n   * Requested packaging style\n   */\n  readonly packaging: string;\n\n  /**\n   * Logical identifier for the asset\n   */\n  readonly id: string;\n\n  /**\n   * The hash of the asset source.\n   */\n  readonly sourceHash: string;\n\n  /**\n   * Path on disk to the asset\n   */\n  readonly path: string;\n}\n\n/**\n * Metadata Entry spec for files.\n */\nexport interface FileAssetMetadataEntry extends BaseAssetMetadataEntry {\n  /**\n   * Requested packaging style\n   */\n  readonly packaging: 'zip' | 'file';\n\n  /**\n   * Name of parameter where S3 bucket should be passed in\n   */\n  readonly s3BucketParameter: string;\n\n  /**\n   * Name of parameter where S3 key should be passed in\n   */\n  readonly s3KeyParameter: string;\n\n  /**\n   * The name of the parameter where the hash of the bundled asset should be passed in.\n   */\n  readonly artifactHashParameter: string;\n}\n\n/**\n * Metadata Entry spec for container images.\n */\nexport interface ContainerImageAssetMetadataEntry extends BaseAssetMetadataEntry {\n  /**\n   * Type of asset\n   */\n  readonly packaging: 'container-image';\n\n  /**\n   * ECR Repository name and repo digest (separated by \"@sha256:\") where this\n   * image is stored.\n   *\n   * @default undefined If not specified, `repositoryName` and `imageTag` are\n   * required because otherwise how will the stack know where to find the asset,\n   * ha?\n   * @deprecated specify `repositoryName` and `imageTag` instead, and then you\n   * know where the image will go.\n   */\n  readonly imageNameParameter?: string;\n\n  /**\n   * ECR repository name, if omitted a default name based on the asset's ID is\n   * used instead. Specify this property if you need to statically address the\n   * image, e.g. from a Kubernetes Pod. Note, this is only the repository name,\n   * without the registry and the tag parts.\n   *\n   * @default - this parameter is REQUIRED after 1.21.0\n   */\n  readonly repositoryName?: string;\n\n  /**\n   * The docker image tag to use for tagging pushed images. This field is\n   * required if `imageParameterName` is ommited (otherwise, the app won't be\n   * able to find the image).\n   *\n   * @default - this parameter is REQUIRED after 1.21.0\n   */\n  readonly imageTag?: string;\n\n  /**\n   * Build args to pass to the `docker build` command\n   *\n   * @default no build args are passed\n   */\n  readonly buildArgs?: { [key: string]: string };\n\n  /**\n   * Docker target to build to\n   *\n   * @default no build target\n   */\n  readonly target?: string;\n\n  /**\n   * Path to the Dockerfile (relative to the directory).\n   *\n   * @default - no file is passed\n   */\n  readonly file?: string;\n}\n\n/**\n * Metadata Entry spec for stack tag.\n */\nexport interface Tag {\n  /**\n   * Tag key.\n   */\n  readonly key: string\n\n  /**\n   * Tag value.\n   */\n  readonly value: string\n}\n\n/**\n * @see ArtifactMetadataEntryType.ASSET\n */\nexport type AssetMetadataEntry = FileAssetMetadataEntry | ContainerImageAssetMetadataEntry;\n\n// Type aliases for metadata entries.\n// Used simply to assign names to data types for more clearity.\n\n/**\n * @see ArtifactMetadataEntryType.INFO\n * @see ArtifactMetadataEntryType.WARN\n * @see ArtifactMetadataEntryType.ERROR\n */\nexport type LogMessageMetadataEntry = string;\n\n/**\n * @see ArtifactMetadataEntryType.LOGICAL_ID\n */\nexport type LogicalIdMetadataEntry = string;\n\n/**\n * @see ArtifactMetadataEntryType.STACK_TAGS\n */\nexport type StackTagsMetadataEntry = Tag[];\n\n/**\n * Union type for all metadata entries that might exist in the manifest.\n */\nexport type MetadataEntryData = AssetMetadataEntry | LogMessageMetadataEntry | LogicalIdMetadataEntry | StackTagsMetadataEntry;\n\n/**\n * Type of artifact metadata entry.\n */\nexport enum ArtifactMetadataEntryType {\n  /**\n   * Asset in metadata.\n   */\n  ASSET = 'aws:cdk:asset',\n\n  /**\n   * Metadata key used to print INFO-level messages by the toolkit when an app is syntheized.\n   */\n  INFO = 'aws:cdk:info',\n\n  /**\n   * Metadata key used to print WARNING-level messages by the toolkit when an app is syntheized.\n   */\n  WARN = 'aws:cdk:warning',\n\n  /**\n   * Metadata key used to print ERROR-level messages by the toolkit when an app is syntheized.\n   */\n  ERROR = 'aws:cdk:error',\n\n  /**\n   * Represents the CloudFormation logical ID of a resource at a certain path.\n   */\n  LOGICAL_ID = 'aws:cdk:logicalId',\n\n  /**\n   * Represents tags of a stack.\n   */\n  STACK_TAGS = 'aws:cdk:stack-tags'\n}\n\n/**\n * Type of cloud artifact.\n */\nexport enum ArtifactType {\n  /**\n   * Stub required because of JSII.\n   */\n  NONE = 'none', // required due to a jsii bug\n\n  /**\n   * The artifact is an AWS CloudFormation stack.\n   */\n  AWS_CLOUDFORMATION_STACK = 'aws:cloudformation:stack',\n\n  /**\n   * The artifact contains the CDK application's construct tree.\n   */\n  CDK_TREE = 'cdk:tree',\n}\n\n/**\n * A metadata entry in a cloud assembly artifact.\n */\nexport interface MetadataEntry {\n  /**\n   * The type of the metadata entry.\n   */\n  readonly type: string;\n\n  /**\n   * The data.\n   *\n   * @default - no data.\n   */\n  readonly data?: MetadataEntryData;\n\n  /**\n   * A stack trace for when the entry was created.\n   *\n   * @default - no trace.\n   */\n  readonly trace?: string[];\n}\n\n/**\n * Information about the application's runtime components.\n */\nexport interface RuntimeInfo {\n  /**\n   * The list of libraries loaded in the application, associated with their versions.\n   */\n  readonly libraries: { [name: string]: string };\n}\n\n/**\n * Represents a missing piece of context.\n */\nexport interface MissingContext {\n  /**\n   * The missing context key.\n   */\n  readonly key: string;\n\n  /**\n   * The provider from which we expect this context key to be obtained.\n   */\n  readonly provider: ContextProvider;\n\n  /**\n   * A set of provider-specific options.\n   */\n  readonly props: ContextQueryProperties;\n}\n\n/**\n * A manifest for a single artifact within the cloud assembly.\n */\nexport interface ArtifactManifest {\n  /**\n   * The type of artifact.\n   */\n  readonly type: ArtifactType;\n\n  /**\n   * The environment into which this artifact is deployed.\n   *\n   * @default - no envrionment.\n   */\n  readonly environment?: string; // format: aws://account/region\n\n  /**\n   * Associated metadata.\n   *\n   * @default - no metadata.\n   */\n  readonly metadata?: { [path: string]: MetadataEntry[] };\n\n  /**\n   * IDs of artifacts that must be deployed before this artifact.\n   *\n   * @default - no dependencies.\n   */\n  readonly dependencies?: string[];\n\n  /**\n   * The set of properties for this artifact (depends on type)\n   *\n   * @default - no properties.\n   */\n  readonly properties?: { [name: string]: any };\n}\n\n/**\n * A manifest which describes the cloud assembly.\n */\nexport interface AssemblyManifest {\n  /**\n   * Protocol version\n   */\n  readonly version: string;\n\n  /**\n   * The set of artifacts in this assembly.\n   *\n   * @default - no artifacts.\n   */\n  readonly artifacts?: { [id: string]: ArtifactManifest };\n\n  /**\n   * Missing context information. If this field has values, it means that the\n   * cloud assembly is not complete and should not be deployed.\n   *\n   * @default - no missing context.\n   */\n  readonly missing?: MissingContext[];\n\n  /**\n   * Runtime information.\n   *\n   * @default - no info.\n   */\n  readonly runtime?: RuntimeInfo;\n}\n"]}
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic2NoZW1hLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsic2NoZW1hLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7O0FBSUE7O0dBRUc7QUFDSCxJQUFZLFlBb0JYO0FBcEJELFdBQVksWUFBWTtJQUN0Qjs7T0FFRztJQUNILDZCQUFhLENBQUE7SUFFYjs7T0FFRztJQUNILHFFQUFxRCxDQUFBO0lBRXJEOztPQUVHO0lBQ0gscUNBQXFCLENBQUE7SUFFckI7O09BRUc7SUFDSCxxREFBcUMsQ0FBQTtBQUN2QyxDQUFDLEVBcEJXLFlBQVksR0FBWixvQkFBWSxLQUFaLG9CQUFZLFFBb0J2QiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IEFydGlmYWN0UHJvcGVydGllcyB9IGZyb20gJy4vYXJ0aWZhY3Qtc2NoZW1hJztcbmltcG9ydCB7IENvbnRleHRQcm92aWRlciwgQ29udGV4dFF1ZXJ5UHJvcGVydGllcyB9IGZyb20gJy4vY29udGV4dC1xdWVyaWVzJztcbmltcG9ydCB7IE1ldGFkYXRhRW50cnkgfSBmcm9tICcuL21ldGFkYXRhLXNjaGVtYSc7XG5cbi8qKlxuICogVHlwZSBvZiBjbG91ZCBhcnRpZmFjdC5cbiAqL1xuZXhwb3J0IGVudW0gQXJ0aWZhY3RUeXBlIHtcbiAgLyoqXG4gICAqIFN0dWIgcmVxdWlyZWQgYmVjYXVzZSBvZiBKU0lJLlxuICAgKi9cbiAgTk9ORSA9ICdub25lJywgLy8gcmVxdWlyZWQgZHVlIHRvIGEganNpaSBidWdcblxuICAvKipcbiAgICogVGhlIGFydGlmYWN0IGlzIGFuIEFXUyBDbG91ZEZvcm1hdGlvbiBzdGFjay5cbiAgICovXG4gIEFXU19DTE9VREZPUk1BVElPTl9TVEFDSyA9ICdhd3M6Y2xvdWRmb3JtYXRpb246c3RhY2snLFxuXG4gIC8qKlxuICAgKiBUaGUgYXJ0aWZhY3QgY29udGFpbnMgdGhlIENESyBhcHBsaWNhdGlvbidzIGNvbnN0cnVjdCB0cmVlLlxuICAgKi9cbiAgQ0RLX1RSRUUgPSAnY2RrOnRyZWUnLFxuXG4gIC8qKlxuICAgKiBNYW5pZmVzdCBmb3IgYWxsIGFzc2V0cyBpbiB0aGUgQ2xvdWQgQXNzZW1ibHlcbiAgICovXG4gIEFTU0VUX01BTklGRVNUID0gJ2Nkazphc3NldC1tYW5pZmVzdCcsXG59XG5cbi8qKlxuICogSW5mb3JtYXRpb24gYWJvdXQgdGhlIGFwcGxpY2F0aW9uJ3MgcnVudGltZSBjb21wb25lbnRzLlxuICovXG5leHBvcnQgaW50ZXJmYWNlIFJ1bnRpbWVJbmZvIHtcbiAgLyoqXG4gICAqIFRoZSBsaXN0IG9mIGxpYnJhcmllcyBsb2FkZWQgaW4gdGhlIGFwcGxpY2F0aW9uLCBhc3NvY2lhdGVkIHdpdGggdGhlaXIgdmVyc2lvbnMuXG4gICAqL1xuICByZWFkb25seSBsaWJyYXJpZXM6IHsgW25hbWU6IHN0cmluZ106IHN0cmluZyB9O1xufVxuXG4vKipcbiAqIFJlcHJlc2VudHMgYSBtaXNzaW5nIHBpZWNlIG9mIGNvbnRleHQuXG4gKi9cbmV4cG9ydCBpbnRlcmZhY2UgTWlzc2luZ0NvbnRleHQge1xuICAvKipcbiAgICogVGhlIG1pc3NpbmcgY29udGV4dCBrZXkuXG4gICAqL1xuICByZWFkb25seSBrZXk6IHN0cmluZztcblxuICAvKipcbiAgICogVGhlIHByb3ZpZGVyIGZyb20gd2hpY2ggd2UgZXhwZWN0IHRoaXMgY29udGV4dCBrZXkgdG8gYmUgb2J0YWluZWQuXG4gICAqL1xuICByZWFkb25seSBwcm92aWRlcjogQ29udGV4dFByb3ZpZGVyO1xuXG4gIC8qKlxuICAgKiBBIHNldCBvZiBwcm92aWRlci1zcGVjaWZpYyBvcHRpb25zLlxuICAgKi9cbiAgcmVhZG9ubHkgcHJvcHM6IENvbnRleHRRdWVyeVByb3BlcnRpZXM7XG59XG5cbi8qKlxuICogQSBtYW5pZmVzdCBmb3IgYSBzaW5nbGUgYXJ0aWZhY3Qgd2l0aGluIHRoZSBjbG91ZCBhc3NlbWJseS5cbiAqL1xuZXhwb3J0IGludGVyZmFjZSBBcnRpZmFjdE1hbmlmZXN0IHtcbiAgLyoqXG4gICAqIFRoZSB0eXBlIG9mIGFydGlmYWN0LlxuICAgKi9cbiAgcmVhZG9ubHkgdHlwZTogQXJ0aWZhY3RUeXBlO1xuXG4gIC8qKlxuICAgKiBUaGUgZW52aXJvbm1lbnQgaW50byB3aGljaCB0aGlzIGFydGlmYWN0IGlzIGRlcGxveWVkLlxuICAgKlxuICAgKiBAZGVmYXVsdCAtIG5vIGVudnJpb25tZW50LlxuICAgKi9cbiAgcmVhZG9ubHkgZW52aXJvbm1lbnQ/OiBzdHJpbmc7IC8vIGZvcm1hdDogYXdzOi8vYWNjb3VudC9yZWdpb25cblxuICAvKipcbiAgICogQXNzb2NpYXRlZCBtZXRhZGF0YS5cbiAgICpcbiAgICogQGRlZmF1bHQgLSBubyBtZXRhZGF0YS5cbiAgICovXG4gIHJlYWRvbmx5IG1ldGFkYXRhPzogeyBbcGF0aDogc3RyaW5nXTogTWV0YWRhdGFFbnRyeVtdIH07XG5cbiAgLyoqXG4gICAqIElEcyBvZiBhcnRpZmFjdHMgdGhhdCBtdXN0IGJlIGRlcGxveWVkIGJlZm9yZSB0aGlzIGFydGlmYWN0LlxuICAgKlxuICAgKiBAZGVmYXVsdCAtIG5vIGRlcGVuZGVuY2llcy5cbiAgICovXG4gIHJlYWRvbmx5IGRlcGVuZGVuY2llcz86IHN0cmluZ1tdO1xuXG4gIC8qKlxuICAgKiBUaGUgc2V0IG9mIHByb3BlcnRpZXMgZm9yIHRoaXMgYXJ0aWZhY3QgKGRlcGVuZHMgb24gdHlwZSlcbiAgICpcbiAgICogQGRlZmF1bHQgLSBubyBwcm9wZXJ0aWVzLlxuICAgKi9cbiAgcmVhZG9ubHkgcHJvcGVydGllcz86IEFydGlmYWN0UHJvcGVydGllcztcbn1cblxuLyoqXG4gKiBBIG1hbmlmZXN0IHdoaWNoIGRlc2NyaWJlcyB0aGUgY2xvdWQgYXNzZW1ibHkuXG4gKi9cbmV4cG9ydCBpbnRlcmZhY2UgQXNzZW1ibHlNYW5pZmVzdCB7XG4gIC8qKlxuICAgKiBQcm90b2NvbCB2ZXJzaW9uXG4gICAqL1xuICByZWFkb25seSB2ZXJzaW9uOiBzdHJpbmc7XG5cbiAgLyoqXG4gICAqIFRoZSBzZXQgb2YgYXJ0aWZhY3RzIGluIHRoaXMgYXNzZW1ibHkuXG4gICAqXG4gICAqIEBkZWZhdWx0IC0gbm8gYXJ0aWZhY3RzLlxuICAgKi9cbiAgcmVhZG9ubHkgYXJ0aWZhY3RzPzogeyBbaWQ6IHN0cmluZ106IEFydGlmYWN0TWFuaWZlc3QgfTtcblxuICAvKipcbiAgICogTWlzc2luZyBjb250ZXh0IGluZm9ybWF0aW9uLiBJZiB0aGlzIGZpZWxkIGhhcyB2YWx1ZXMsIGl0IG1lYW5zIHRoYXQgdGhlXG4gICAqIGNsb3VkIGFzc2VtYmx5IGlzIG5vdCBjb21wbGV0ZSBhbmQgc2hvdWxkIG5vdCBiZSBkZXBsb3llZC5cbiAgICpcbiAgICogQGRlZmF1bHQgLSBubyBtaXNzaW5nIGNvbnRleHQuXG4gICAqL1xuICByZWFkb25seSBtaXNzaW5nPzogTWlzc2luZ0NvbnRleHRbXTtcblxuICAvKipcbiAgICogUnVudGltZSBpbmZvcm1hdGlvbi5cbiAgICpcbiAgICogQGRlZmF1bHQgLSBubyBpbmZvLlxuICAgKi9cbiAgcmVhZG9ubHkgcnVudGltZT86IFJ1bnRpbWVJbmZvO1xufVxuIl19
{
"name": "@aws-cdk/cloud-assembly-schema",
"version": "1.38.0",
"version": "1.39.0",
"description": "Cloud Assembly Schema",

@@ -48,11 +48,10 @@ "main": "lib/index.js",

},
"jest": {},
"license": "Apache-2.0",
"devDependencies": {
"@types/jest": "^25.2.1",
"@types/jest": "^25.2.2",
"@types/mock-fs": "^4.10.0",
"cdk-build-tools": "1.38.0",
"cdk-build-tools": "1.39.0",
"jest": "^25.5.4",
"mock-fs": "^4.12.0",
"pkglint": "1.38.0",
"pkglint": "1.39.0",
"typescript-json-schema": "^0.42.0"

@@ -75,3 +74,3 @@ },

"engines": {
"node": ">= 10.13.0"
"node": ">= 10.13.0 <13 || >=13.7.0"
},

@@ -89,3 +88,6 @@ "stability": "stable",

},
"maturity": "stable"
"maturity": "stable",
"cdk-build": {
"jest": true
}
}

@@ -66,4 +66,13 @@ {

"description": "The set of properties for this artifact (depends on type) (Default - no properties.)",
"type": "object",
"additionalProperties": {}
"anyOf": [
{
"$ref": "#/definitions/AwsCloudFormationStackProperties"
},
{
"$ref": "#/definitions/AssetManifestProperties"
},
{
"$ref": "#/definitions/TreeArtifactProperties"
}
]
}

@@ -79,2 +88,3 @@ },

"aws:cloudformation:stack",
"cdk:asset-manifest",
"cdk:tree",

@@ -251,2 +261,77 @@ "none"

},
"AwsCloudFormationStackProperties": {
"description": "Artifact properties for CloudFormation stacks.",
"type": "object",
"properties": {
"templateFile": {
"description": "A file relative to the assembly root which contains the CloudFormation template for this stack.",
"type": "string"
},
"parameters": {
"description": "Values for CloudFormation stack parameters that should be passed when the stack is deployed. (Default - No parameters)",
"type": "object",
"additionalProperties": {
"type": "string"
}
},
"stackName": {
"description": "The name to use for the CloudFormation stack. (Default - name derived from artifact ID)",
"type": "string"
},
"terminationProtection": {
"description": "Whether to enable termination protection for this stack.",
"default": false,
"type": "boolean"
},
"assumeRoleArn": {
"description": "The role that needs to be assumed to deploy the stack (Default - No role is assumed (current credentials are used))",
"type": "string"
},
"cloudFormationExecutionRoleArn": {
"description": "The role that is passed to CloudFormation to execute the change set (Default - No role is passed (currently assumed role/credentials are used))",
"type": "string"
},
"stackTemplateAssetObjectUrl": {
"description": "If the stack template has already been included in the asset manifest, its asset URL (Default - Not uploaded yet, upload just before deploying)",
"type": "string"
},
"requiresBootstrapStackVersion": {
"description": "Version of bootstrap stack required to deploy this stack (Default - No bootstrap stack required)",
"type": "number"
}
},
"required": [
"templateFile"
]
},
"AssetManifestProperties": {
"description": "Artifact properties for the Asset Manifest",
"type": "object",
"properties": {
"file": {
"description": "Filename of the asset manifest",
"type": "string"
},
"requiresBootstrapStackVersion": {
"description": "Version of bootstrap stack required to deploy this stack (Default - Version 1 (basic modern bootstrap stack))",
"type": "number"
}
},
"required": [
"file"
]
},
"TreeArtifactProperties": {
"description": "Artifact properties for the Construct Tree Artifact",
"type": "object",
"properties": {
"file": {
"description": "Filename of the tree artifact",
"type": "string"
}
},
"required": [
"file"
]
},
"MissingContext": {

@@ -281,2 +366,5 @@ "description": "Represents a missing piece of context.",

"$ref": "#/definitions/VpcContextQuery"
},
{
"$ref": "#/definitions/EndpointServiceAvailabilityZonesContextQuery"
}

@@ -297,2 +385,3 @@ ]

"availability-zones",
"endpoint-service-availability-zones",
"hosted-zone",

@@ -341,3 +430,3 @@ "ssm",

"AvailabilityZonesContextQuery": {
"description": "Query to hosted zone context provider",
"description": "Query to availability zone context provider",
"type": "object",

@@ -392,3 +481,3 @@ "properties": {

"SSMParameterContextQuery": {
"description": "Query to hosted zone context provider",
"description": "Query to SSM Parameter Context Provider",
"type": "object",

@@ -450,2 +539,25 @@ "properties": {

},
"EndpointServiceAvailabilityZonesContextQuery": {
"description": "Query to endpoint service context provider",
"type": "object",
"properties": {
"account": {
"description": "Query account",
"type": "string"
},
"region": {
"description": "Query region",
"type": "string"
},
"serviceName": {
"description": "Query service name",
"type": "string"
}
},
"required": [
"account",
"region",
"serviceName"
]
},
"RuntimeInfo": {

@@ -452,0 +564,0 @@ "description": "Information about the application's runtime components.",

@@ -1,1 +0,1 @@

{"version":"2.0.0"}
{"version":"3.0.0"}

@@ -40,3 +40,3 @@ "use strict";

});
test('cloud-assembly.json.schema is correct', () => {
test('if this test fails, run "yarn update-schema"', () => {
// when we compare schemas we ignore changes the

@@ -138,2 +138,2 @@ // description that is generated from the ts docstrings.

});
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"manifest.test.js","sourceRoot":"","sources":["manifest.test.ts"],"names":[],"mappings":"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","sourcesContent":["import * as fs from 'fs';\nimport * as os from 'os';\nimport * as path from 'path';\nimport * as semver from 'semver';\nimport { AssemblyManifest, Manifest, StackTagsMetadataEntry } from '../lib';\n\nconst FIXTURES = path.join(__dirname, 'fixtures');\n\nfunction fixture(name: string) {\n  return path.join(FIXTURES, name, 'manifest.json');\n}\n\nfunction clone(obj: any) {\n  return JSON.parse(JSON.stringify(obj));\n}\n\nfunction removeStringKeys(obj: any, keys: string[]) {\n\n  function _recurse(o: any) {\n    for (const prop in o) {\n      if (keys.includes(prop) && typeof o[prop] === 'string') {\n        delete o[prop];\n      } else if (typeof o[prop] === 'object') {\n        _recurse(o[prop]);\n      }\n    }\n  }\n\n  const cloned = clone(obj);\n  _recurse(cloned);\n\n  return cloned;\n\n}\n\ntest('manifest save', () => {\n\n  const outdir = fs.mkdtempSync(path.join(os.tmpdir(), 'schema-tests'));\n  const manifestFile = path.join(outdir, 'manifest.json');\n\n  const assemblyManifest: AssemblyManifest = {\n    version: 'version',\n  };\n\n  Manifest.save(assemblyManifest, manifestFile);\n\n  const saved = JSON.parse(fs.readFileSync(manifestFile, 'UTF-8'));\n\n  expect(saved).toEqual(assemblyManifest);\n\n});\n\ntest('cloud-assembly.json.schema is correct', () => {\n\n  // when we compare schemas we ignore changes the\n  // description that is generated from the ts docstrings.\n  const docStringFields = [\n    'description',\n  ];\n\n  // eslint-disable-next-line @typescript-eslint/no-require-imports\n  const schema = require('../scripts/update-schema.js');\n\n  const expected = removeStringKeys(schema.generate(), docStringFields);\n\n  // eslint-disable-next-line @typescript-eslint/no-require-imports\n  const actual = removeStringKeys(require('../schema/cloud-assembly.schema.json'), docStringFields);\n\n  try {\n    expect(actual).toEqual(expected);\n  } catch (err) {\n    // I couldn't for the life of me figure out how to provide additional error message\n    // to jest...any ideas?\n    err.message = `Whoops, Looks like the schema has changed. Did you forget to run 'yarn update-schema'?\\n\\n${err.message}`;\n    throw err;\n  }\n});\n\ntest('manifest load', () => {\n  const loaded = Manifest.load(fixture('only-version'));\n  expect(loaded).toMatchSnapshot();\n});\n\ntest('manifest load fails for invalid nested property', () => {\n  expect(() => Manifest.load(fixture('invalid-nested-property'))).toThrow(/Invalid assembly manifest/);\n});\n\ntest('manifest load fails for invalid artifact type', () => {\n  expect(() => Manifest.load(fixture('invalid-artifact-type'))).toThrow(/Invalid assembly manifest/);\n});\n\ntest('manifest load fails on higher major version', () => {\n  expect(() => Manifest.load(fixture('high-version'))).toThrow(/Cloud assembly schema version mismatch/);\n});\n\n// once we start introducing minor version bumps that are considered\n// non breaking, this test can be removed.\ntest('manifest load fails on higher minor version', () => {\n\n  const outdir = fs.mkdtempSync(path.join(os.tmpdir(), 'schema-tests'));\n  const manifestFile = path.join(outdir, 'manifest.json');\n\n  const newVersion = semver.inc(Manifest.version(), 'minor');\n  expect(newVersion).toBeTruthy();\n\n  if (newVersion) {\n    const assemblyManifest: AssemblyManifest = {\n      version: newVersion,\n    };\n\n    Manifest.save(assemblyManifest, manifestFile);\n\n    expect(() => Manifest.load(manifestFile)).toThrow(/Cloud assembly schema version mismatch/);\n  }\n});\n\n// once we start introducing patch version bumps that are considered\n// non breaking, this test can be removed.\ntest('manifest load fails on higher patch version', () => {\n\n  const outdir = fs.mkdtempSync(path.join(os.tmpdir(), 'schema-tests'));\n  const manifestFile = path.join(outdir, 'manifest.json');\n\n  const newVersion = semver.inc(Manifest.version(), 'patch');\n  expect(newVersion).toBeTruthy();\n\n  if (newVersion) {\n    const assemblyManifest: AssemblyManifest = {\n      version: newVersion,\n    };\n\n    Manifest.save(assemblyManifest, manifestFile);\n\n    expect(() => Manifest.load(manifestFile)).toThrow(/Cloud assembly schema version mismatch/);\n  }\n});\n\ntest('manifest load fails on invalid version', () => {\n  expect(() => Manifest.load(fixture('invalid-version'))).toThrow(/Invalid semver string/);\n});\n\ntest('manifest load succeeds on unknown properties', () => {\n  const manifest = Manifest.load(fixture('unknown-property'));\n  expect(manifest.version).toEqual('0.0.0');\n});\n\ntest('stack-tags are deserialized properly', () => {\n\n  const m: AssemblyManifest = Manifest.load(fixture('with-stack-tags'));\n\n  if (m.artifacts?.stack?.metadata?.AwsCdkPlaygroundBatch[0].data) {\n    const entry = m.artifacts.stack.metadata.AwsCdkPlaygroundBatch[0].data as StackTagsMetadataEntry;\n    expect(entry[0].key).toEqual('hello');\n    expect(entry[0].value).toEqual('world');\n  }\n  expect(m.version).toEqual('0.0.0');\n\n});\n\ntest('can access random metadata', () => {\n\n  const loaded = Manifest.load(fixture('random-metadata'));\n  const randomArray = loaded.artifacts?.stack.metadata?.AwsCdkPlaygroundBatch[0].data;\n  const randomNumber = loaded.artifacts?.stack.metadata?.AwsCdkPlaygroundBatch[1].data;\n  const randomMap = loaded.artifacts?.stack.metadata?.AwsCdkPlaygroundBatch[2].data;\n\n  expect(randomArray).toEqual(['42']);\n  expect(randomNumber).toEqual(42);\n  expect(randomMap).toEqual({\n    key: 'value',\n  });\n\n  expect(randomMap).toBeTruthy();\n\n  if (randomMap) {\n    expect((randomMap as any).key).toEqual('value');\n  }\n\n});\n"]}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"manifest.test.js","sourceRoot":"","sources":["manifest.test.ts"],"names":[],"mappings":"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","sourcesContent":["import * as fs from 'fs';\nimport * as os from 'os';\nimport * as path from 'path';\nimport * as semver from 'semver';\nimport { AssemblyManifest, Manifest, StackTagsMetadataEntry } from '../lib';\n\nconst FIXTURES = path.join(__dirname, 'fixtures');\n\nfunction fixture(name: string) {\n  return path.join(FIXTURES, name, 'manifest.json');\n}\n\nfunction clone(obj: any) {\n  return JSON.parse(JSON.stringify(obj));\n}\n\nfunction removeStringKeys(obj: any, keys: string[]) {\n\n  function _recurse(o: any) {\n    for (const prop in o) {\n      if (keys.includes(prop) && typeof o[prop] === 'string') {\n        delete o[prop];\n      } else if (typeof o[prop] === 'object') {\n        _recurse(o[prop]);\n      }\n    }\n  }\n\n  const cloned = clone(obj);\n  _recurse(cloned);\n\n  return cloned;\n\n}\n\ntest('manifest save', () => {\n\n  const outdir = fs.mkdtempSync(path.join(os.tmpdir(), 'schema-tests'));\n  const manifestFile = path.join(outdir, 'manifest.json');\n\n  const assemblyManifest: AssemblyManifest = {\n    version: 'version',\n  };\n\n  Manifest.save(assemblyManifest, manifestFile);\n\n  const saved = JSON.parse(fs.readFileSync(manifestFile, 'UTF-8'));\n\n  expect(saved).toEqual(assemblyManifest);\n\n});\n\ntest('if this test fails, run \"yarn update-schema\"', () => {\n\n  // when we compare schemas we ignore changes the\n  // description that is generated from the ts docstrings.\n  const docStringFields = [\n    'description',\n  ];\n\n  // eslint-disable-next-line @typescript-eslint/no-require-imports\n  const schema = require('../scripts/update-schema.js');\n\n  const expected = removeStringKeys(schema.generate(), docStringFields);\n\n  // eslint-disable-next-line @typescript-eslint/no-require-imports\n  const actual = removeStringKeys(require('../schema/cloud-assembly.schema.json'), docStringFields);\n\n  try {\n    expect(actual).toEqual(expected);\n  } catch (err) {\n    // I couldn't for the life of me figure out how to provide additional error message\n    // to jest...any ideas?\n    err.message = `Whoops, Looks like the schema has changed. Did you forget to run 'yarn update-schema'?\\n\\n${err.message}`;\n    throw err;\n  }\n});\n\ntest('manifest load', () => {\n  const loaded = Manifest.load(fixture('only-version'));\n  expect(loaded).toMatchSnapshot();\n});\n\ntest('manifest load fails for invalid nested property', () => {\n  expect(() => Manifest.load(fixture('invalid-nested-property'))).toThrow(/Invalid assembly manifest/);\n});\n\ntest('manifest load fails for invalid artifact type', () => {\n  expect(() => Manifest.load(fixture('invalid-artifact-type'))).toThrow(/Invalid assembly manifest/);\n});\n\ntest('manifest load fails on higher major version', () => {\n  expect(() => Manifest.load(fixture('high-version'))).toThrow(/Cloud assembly schema version mismatch/);\n});\n\n// once we start introducing minor version bumps that are considered\n// non breaking, this test can be removed.\ntest('manifest load fails on higher minor version', () => {\n\n  const outdir = fs.mkdtempSync(path.join(os.tmpdir(), 'schema-tests'));\n  const manifestFile = path.join(outdir, 'manifest.json');\n\n  const newVersion = semver.inc(Manifest.version(), 'minor');\n  expect(newVersion).toBeTruthy();\n\n  if (newVersion) {\n    const assemblyManifest: AssemblyManifest = {\n      version: newVersion,\n    };\n\n    Manifest.save(assemblyManifest, manifestFile);\n\n    expect(() => Manifest.load(manifestFile)).toThrow(/Cloud assembly schema version mismatch/);\n  }\n});\n\n// once we start introducing patch version bumps that are considered\n// non breaking, this test can be removed.\ntest('manifest load fails on higher patch version', () => {\n\n  const outdir = fs.mkdtempSync(path.join(os.tmpdir(), 'schema-tests'));\n  const manifestFile = path.join(outdir, 'manifest.json');\n\n  const newVersion = semver.inc(Manifest.version(), 'patch');\n  expect(newVersion).toBeTruthy();\n\n  if (newVersion) {\n    const assemblyManifest: AssemblyManifest = {\n      version: newVersion,\n    };\n\n    Manifest.save(assemblyManifest, manifestFile);\n\n    expect(() => Manifest.load(manifestFile)).toThrow(/Cloud assembly schema version mismatch/);\n  }\n});\n\ntest('manifest load fails on invalid version', () => {\n  expect(() => Manifest.load(fixture('invalid-version'))).toThrow(/Invalid semver string/);\n});\n\ntest('manifest load succeeds on unknown properties', () => {\n  const manifest = Manifest.load(fixture('unknown-property'));\n  expect(manifest.version).toEqual('0.0.0');\n});\n\ntest('stack-tags are deserialized properly', () => {\n\n  const m: AssemblyManifest = Manifest.load(fixture('with-stack-tags'));\n\n  if (m.artifacts?.stack?.metadata?.AwsCdkPlaygroundBatch[0].data) {\n    const entry = m.artifacts.stack.metadata.AwsCdkPlaygroundBatch[0].data as StackTagsMetadataEntry;\n    expect(entry[0].key).toEqual('hello');\n    expect(entry[0].value).toEqual('world');\n  }\n  expect(m.version).toEqual('0.0.0');\n\n});\n\ntest('can access random metadata', () => {\n\n  const loaded = Manifest.load(fixture('random-metadata'));\n  const randomArray = loaded.artifacts?.stack.metadata?.AwsCdkPlaygroundBatch[0].data;\n  const randomNumber = loaded.artifacts?.stack.metadata?.AwsCdkPlaygroundBatch[1].data;\n  const randomMap = loaded.artifacts?.stack.metadata?.AwsCdkPlaygroundBatch[2].data;\n\n  expect(randomArray).toEqual(['42']);\n  expect(randomNumber).toEqual(42);\n  expect(randomMap).toEqual({\n    key: 'value',\n  });\n\n  expect(randomMap).toBeTruthy();\n\n  if (randomMap) {\n    expect((randomMap as any).key).toEqual('value');\n  }\n\n});\n"]}

Sorry, the diff of this file is not supported yet

SocketSocket SOC 2 Logo

Product

  • Package Alerts
  • Integrations
  • Docs
  • Pricing
  • FAQ
  • Roadmap

Packages

Stay in touch

Get open source security insights delivered straight into your inbox.


  • Terms
  • Privacy
  • Security

Made with ⚡️ by Socket Inc