Socket
Socket
Sign inDemoInstall

@aws-cdk/cdk

Package Overview
Dependencies
Maintainers
4
Versions
42
Alerts
File Explorer

Advanced tools

Socket logo

Install Socket

Detect and block malicious and high-risk dependencies

Install

@aws-cdk/cdk - npm Package Compare versions

Comparing version 0.9.1 to 0.9.2

71

lib/cloudformation/arn.d.ts

@@ -6,23 +6,56 @@ import { Token } from '..';

*/
export declare class Arn extends Token {
export declare class ArnUtils {
/**
* Creates an ARN from components.
* If any component is the empty string,
* an empty string will be inserted into the generated ARN
* at the location that component corresponds to.
*
* If `partition`, `region` or `account` are not specified, the stack's
* partition, region and account will be used.
*
* If any component is the empty string, an empty string will be inserted
* into the generated ARN at the location that component corresponds to.
*
* The ARN will be formatted as follows:
*
* arn:{partition}:{service}:{region}:{account}:{resource}{sep}}{resource-name}
*
*/
static fromComponents(components: ArnComponents): Arn;
static fromComponents(components: ArnComponents): string;
/**
* Given an ARN, parses it and returns components.
*
* The ARN it will be parsed and validated. The separator (`sep`) will be
* set to '/' if the 6th component includes a '/', in which case, `resource`
* will be set to the value before the '/' and `resourceName` will be the
* rest. In case there is no '/', `resource` will be set to the 6th
* components and `resourceName` will be set to the rest of the string.
* If the ARN is a concrete string, it will be parsed and validated. The
* separator (`sep`) will be set to '/' if the 6th component includes a '/',
* in which case, `resource` will be set to the value before the '/' and
* `resourceName` will be the rest. In case there is no '/', `resource` will
* be set to the 6th components and `resourceName` will be set to the rest
* of the string.
*
* If the ARN includes tokens (or is a token), the ARN cannot be validated,
* since we don't have the actual value yet at the time of this function
* call. You will have to know the separator and the type of ARN. The
* resulting `ArnComponents` object will contain tokens for the
* subexpressions of the ARN, not string literals. In this case this
* function cannot properly parse the complete final resourceName (path) out
* of ARNs that use '/' to both separate the 'resource' from the
* 'resourceName' AND to subdivide the resourceName further. For example, in
* S3 ARNs:
*
* arn:aws:s3:::my_corporate_bucket/path/to/exampleobject.png
*
* After parsing the resourceName will not contain
* 'path/to/exampleobject.png' but simply 'path'. This is a limitation
* because there is no slicing functionality in CloudFormation templates.
*
* @param sep The separator used to separate resource from resourceName
* @param hasName Whether there is a name component in the ARN at all. For
* example, SNS Topics ARNs have the 'resource' component contain the topic
* name, and no 'resourceName' component.
*
* @returns an ArnComponents object which allows access to the various
* components of the ARN.
*
* @returns an ArnComponents object which allows access to the various
* components of the ARN.
*/
static parse(arn: string): ArnComponents;
static parse(arn: string, sepIfToken?: string, hasName?: boolean): ArnComponents;
/**

@@ -61,7 +94,7 @@ * Given a Token evaluating to ARN, parses it and returns components.

*/
resourceComponent(sep?: string): Token;
static resourceComponent(arn: string, sep?: string): string;
/**
* Return a Token that represents the resource Name component of the ARN
*/
resourceNameComponent(sep?: string): Token;
static resourceNameComponent(arn: string, sep?: string): string;
}

@@ -77,3 +110,3 @@ export interface ArnComponents {

*/
partition?: any;
partition?: string;
/**

@@ -83,3 +116,3 @@ * The service namespace that identifies the AWS product (for example,

*/
service: any;
service: string;
/**

@@ -91,3 +124,3 @@ * The region the resource resides in. Note that the ARNs for some resources

*/
region?: any;
region?: string;
/**

@@ -100,3 +133,3 @@ * The ID of the AWS account that owns the resource, without the hyphens.

*/
account?: any;
account?: string;
/**

@@ -106,3 +139,3 @@ * Resource type (e.g. "table", "autoScalingGroup", "certificate").

*/
resource: any;
resource: string;
/**

@@ -119,3 +152,3 @@ * Separator between resource type and the resource.

*/
resourceName?: any;
resourceName?: string;
}

@@ -5,2 +5,4 @@ "use strict";

const fn_1 = require("../cloudformation/fn");
const tokens_1 = require("../core/tokens");
const cloudformation_token_1 = require("./cloudformation-token");
/**

@@ -10,8 +12,16 @@ * An Amazon Resource Name (ARN).

*/
class Arn extends __1.Token {
class ArnUtils {
/**
* Creates an ARN from components.
* If any component is the empty string,
* an empty string will be inserted into the generated ARN
* at the location that component corresponds to.
*
* If `partition`, `region` or `account` are not specified, the stack's
* partition, region and account will be used.
*
* If any component is the empty string, an empty string will be inserted
* into the generated ARN at the location that component corresponds to.
*
* The ARN will be formatted as follows:
*
* arn:{partition}:{service}:{region}:{account}:{resource}{sep}}{resource-name}
*
*/

@@ -37,3 +47,3 @@ static fromComponents(components) {

}
return new Arn(new __1.FnConcat(...values));
return new __1.FnConcat(...values).toString();
}

@@ -43,12 +53,40 @@ /**

*
* The ARN it will be parsed and validated. The separator (`sep`) will be
* set to '/' if the 6th component includes a '/', in which case, `resource`
* will be set to the value before the '/' and `resourceName` will be the
* rest. In case there is no '/', `resource` will be set to the 6th
* components and `resourceName` will be set to the rest of the string.
* If the ARN is a concrete string, it will be parsed and validated. The
* separator (`sep`) will be set to '/' if the 6th component includes a '/',
* in which case, `resource` will be set to the value before the '/' and
* `resourceName` will be the rest. In case there is no '/', `resource` will
* be set to the 6th components and `resourceName` will be set to the rest
* of the string.
*
* If the ARN includes tokens (or is a token), the ARN cannot be validated,
* since we don't have the actual value yet at the time of this function
* call. You will have to know the separator and the type of ARN. The
* resulting `ArnComponents` object will contain tokens for the
* subexpressions of the ARN, not string literals. In this case this
* function cannot properly parse the complete final resourceName (path) out
* of ARNs that use '/' to both separate the 'resource' from the
* 'resourceName' AND to subdivide the resourceName further. For example, in
* S3 ARNs:
*
* arn:aws:s3:::my_corporate_bucket/path/to/exampleobject.png
*
* After parsing the resourceName will not contain
* 'path/to/exampleobject.png' but simply 'path'. This is a limitation
* because there is no slicing functionality in CloudFormation templates.
*
* @param sep The separator used to separate resource from resourceName
* @param hasName Whether there is a name component in the ARN at all. For
* example, SNS Topics ARNs have the 'resource' component contain the topic
* name, and no 'resourceName' component.
*
* @returns an ArnComponents object which allows access to the various
* components of the ARN.
*
* @returns an ArnComponents object which allows access to the various
* components of the ARN.
*/
static parse(arn) {
static parse(arn, sepIfToken = '/', hasName = true) {
if (tokens_1.unresolved(arn)) {
return ArnUtils.parseToken(new cloudformation_token_1.CloudFormationToken(arn), sepIfToken, hasName);
}
const components = arn.split(':');

@@ -150,9 +188,9 @@ if (components.length < 6) {

const components = new fn_1.FnSplit(':', arn);
const partition = new fn_1.FnSelect(1, components);
const service = new fn_1.FnSelect(2, components);
const region = new fn_1.FnSelect(3, components);
const account = new fn_1.FnSelect(4, components);
const partition = new fn_1.FnSelect(1, components).toString();
const service = new fn_1.FnSelect(2, components).toString();
const region = new fn_1.FnSelect(3, components).toString();
const account = new fn_1.FnSelect(4, components).toString();
if (sep === ':') {
const resource = new fn_1.FnSelect(5, components);
const resourceName = hasName ? new fn_1.FnSelect(6, components) : undefined;
const resource = new fn_1.FnSelect(5, components).toString();
const resourceName = hasName ? new fn_1.FnSelect(6, components).toString() : undefined;
return { partition, service, region, account, resource, resourceName, sep };

@@ -162,4 +200,4 @@ }

const lastComponents = new fn_1.FnSplit(sep, new fn_1.FnSelect(5, components));
const resource = new fn_1.FnSelect(0, lastComponents);
const resourceName = hasName ? new fn_1.FnSelect(1, lastComponents) : undefined;
const resource = new fn_1.FnSelect(0, lastComponents).toString();
const resourceName = hasName ? new fn_1.FnSelect(1, lastComponents).toString() : undefined;
return { partition, service, region, account, resource, resourceName, sep };

@@ -171,4 +209,4 @@ }

*/
resourceComponent(sep = '/') {
return Arn.parseToken(this, sep).resource;
static resourceComponent(arn, sep = '/') {
return ArnUtils.parseToken(new __1.Token(arn), sep).resource;
}

@@ -178,7 +216,7 @@ /**

*/
resourceNameComponent(sep = '/') {
return Arn.parseToken(this, sep, true).resourceName;
static resourceNameComponent(arn, sep = '/') {
return ArnUtils.parseToken(new __1.Token(arn), sep, true).resourceName;
}
}
exports.Arn = Arn;
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"arn.js","sourceRoot":"","sources":["arn.ts"],"names":[],"mappings":"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","sourcesContent":["import { AwsAccountId, AwsPartition, AwsRegion, FnConcat, Token } from '..';\nimport { FnSelect, FnSplit } from '../cloudformation/fn';\n\n/**\n * An Amazon Resource Name (ARN).\n * http://docs.aws.amazon.com/general/latest/gr/aws-arns-and-namespaces.html\n */\nexport class Arn extends Token {\n    /**\n     * Creates an ARN from components.\n     * If any component is the empty string,\n     * an empty string will be inserted into the generated ARN\n     * at the location that component corresponds to.\n     */\n    public static fromComponents(components: ArnComponents) {\n        const partition = components.partition == null\n            ? new AwsPartition()\n            : components.partition;\n        const region = components.region == null\n            ? new AwsRegion()\n            : components.region;\n        const account = components.account == null\n            ? new AwsAccountId()\n            : components.account;\n\n        const values = [ 'arn', ':', partition, ':', components.service, ':', region, ':', account, ':', components.resource ];\n\n        const sep = components.sep || '/';\n        if (sep !== '/' && sep !== ':') {\n            throw new Error('resourcePathSep may only be \":\" or \"/\"');\n        }\n\n        if (components.resourceName != null) {\n            values.push(sep);\n            values.push(components.resourceName);\n        }\n\n        return new Arn(new FnConcat(...values));\n    }\n\n    /**\n     * Given an ARN, parses it and returns components.\n     *\n     * The ARN it will be parsed and validated. The separator (`sep`) will be\n     * set to '/' if the 6th component includes a '/', in which case, `resource`\n     * will be set to the value before the '/' and `resourceName` will be the\n     * rest. In case there is no '/', `resource` will be set to the 6th\n     * components and `resourceName` will be set to the rest of the string.\n     *\n     * @returns an ArnComponents object which allows access to the various\n     *          components of the ARN.\n     */\n    public static parse(arn: string): ArnComponents {\n        const components = arn.split(':') as Array<string | undefined>;\n\n        if (components.length < 6) {\n            throw new Error('ARNs must have at least 6 components: ' + arn);\n        }\n\n        const [ arnPrefix, partition, service, region, account, sixth, ...rest ] = components;\n\n        if (arnPrefix !== 'arn') {\n            throw new Error('ARNs must start with \"arn:\": ' + arn);\n        }\n\n        if (!service) {\n            throw new Error('The `service` component (3rd component) is required: ' + arn);\n        }\n\n        if (!sixth) {\n            throw new Error('The `resource` component (6th component) is required: ' + arn);\n        }\n\n        let resource: string;\n        let resourceName: string | undefined;\n        let sep: string | undefined;\n\n        let sepIndex = sixth.indexOf('/');\n        if (sepIndex !== -1) {\n            sep = '/';\n        } else if (rest.length > 0) {\n            sep = ':';\n            sepIndex = -1;\n        }\n\n        if (sepIndex !== -1) {\n            resource = sixth.substr(0, sepIndex);\n            resourceName = sixth.substr(sepIndex + 1);\n        } else {\n            resource = sixth;\n        }\n\n        if (rest.length > 0) {\n            if (!resourceName) {\n                resourceName = '';\n            } else {\n                resourceName += ':';\n            }\n\n            resourceName += rest.join(':');\n        }\n\n        const result: ArnComponents = { service, resource };\n        if (partition) {\n            result.partition = partition;\n        }\n\n        if (region) {\n            result.region = region;\n        }\n\n        if (account) {\n            result.account = account;\n        }\n\n        if (resourceName) {\n            result.resourceName = resourceName;\n        }\n\n        if (sep) {\n            result.sep = sep;\n        }\n\n        return result;\n    }\n\n    /**\n     * Given a Token evaluating to ARN, parses it and returns components.\n     *\n     * The ARN cannot be validated, since we don't have the actual value yet\n     * at the time of this function call. You will have to know the separator\n     * and the type of ARN.\n     *\n     * The resulting `ArnComponents` object will contain tokens for the\n     * subexpressions of the ARN, not string literals.\n     *\n     * WARNING: this function cannot properly parse the complete final\n     * resourceName (path) out of ARNs that use '/' to both separate the\n     * 'resource' from the 'resourceName' AND to subdivide the resourceName\n     * further. For example, in S3 ARNs:\n     *\n     *      arn:aws:s3:::my_corporate_bucket/path/to/exampleobject.png\n     *\n     * After parsing the resourceName will not contain 'path/to/exampleobject.png'\n     * but simply 'path'. This is a limitation because there is no slicing\n     * functionality in CloudFormation templates.\n     *\n     * @param arn The input token that contains an ARN\n     * @param sep The separator used to separate resource from resourceName\n     * @param hasName Whether there is a name component in the ARN at all.\n     * For example, SNS Topics ARNs have the 'resource' component contain the\n     * topic name, and no 'resourceName' component.\n     * @returns an ArnComponents object which allows access to the various\n     * components of the ARN.\n     */\n    public static parseToken(arn: Token, sep: string = '/', hasName: boolean = true): ArnComponents {\n        // Arn ARN looks like:\n        // arn:partition:service:region:account-id:resource\n        // arn:partition:service:region:account-id:resourcetype/resource\n        // arn:partition:service:region:account-id:resourcetype:resource\n\n        // We need the 'hasName' argument because {Fn::Select}ing a nonexistent field\n        // throws an error.\n\n        const components = new FnSplit(':', arn);\n\n        const partition = new FnSelect(1, components);\n        const service = new FnSelect(2, components);\n        const region = new FnSelect(3, components);\n        const account = new FnSelect(4, components);\n\n        if (sep === ':') {\n            const resource = new FnSelect(5, components);\n            const resourceName = hasName ? new FnSelect(6, components) : undefined;\n\n            return { partition, service, region, account, resource, resourceName, sep };\n        } else {\n            const lastComponents = new FnSplit(sep, new FnSelect(5, components));\n\n            const resource = new FnSelect(0, lastComponents);\n            const resourceName = hasName ? new FnSelect(1, lastComponents) : undefined;\n\n            return { partition, service, region, account, resource, resourceName, sep };\n        }\n    }\n\n    /**\n     * Return a Token that represents the resource component of the ARN\n     */\n    public resourceComponent(sep: string = '/'): Token {\n        return Arn.parseToken(this, sep).resource;\n    }\n\n    /**\n     * Return a Token that represents the resource Name component of the ARN\n     */\n    public resourceNameComponent(sep: string = '/'): Token {\n        return Arn.parseToken(this, sep, true).resourceName!;\n    }\n}\n\nexport interface ArnComponents {\n    /**\n     * The partition that the resource is in. For standard AWS regions, the\n     * partition is aws. If you have resources in other partitions, the\n     * partition is aws-partitionname. For example, the partition for resources\n     * in the China (Beijing) region is aws-cn.\n     *\n     * @default The AWS partition the stack is deployed to.\n     */\n    partition?: any;\n\n    /**\n     * The service namespace that identifies the AWS product (for example,\n     * 's3', 'iam', 'codepipline').\n     */\n    service: any;\n\n    /**\n     * The region the resource resides in. Note that the ARNs for some resources\n     * do not require a region, so this component might be omitted.\n     *\n     * @default The region the stack is deployed to.\n     */\n    region?: any;\n\n    /**\n     * The ID of the AWS account that owns the resource, without the hyphens.\n     * For example, 123456789012. Note that the ARNs for some resources don't\n     * require an account number, so this component might be omitted.\n     *\n     * @default The account the stack is deployed to.\n     */\n    account?: any;\n\n    /**\n     * Resource type (e.g. \"table\", \"autoScalingGroup\", \"certificate\").\n     * For some resource types, e.g. S3 buckets, this field defines the bucket name.\n     */\n    resource: any;\n\n    /**\n     * Separator between resource type and the resource.\n     *\n     * Can be either '/' or ':'. Will only be used if path is defined.\n     * @default '/'\n     */\n    sep?: string;\n\n    /**\n     * Resource name or path within the resource (i.e. S3 bucket object key) or\n     * a wildcard such as ``\"*\"``. This is service-dependent.\n     */\n    resourceName?: any;\n}\n"]}
exports.ArnUtils = ArnUtils;
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"arn.js","sourceRoot":"","sources":["arn.ts"],"names":[],"mappings":"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","sourcesContent":["import { AwsAccountId, AwsPartition, AwsRegion, FnConcat, Token } from '..';\nimport { FnSelect, FnSplit } from '../cloudformation/fn';\nimport { unresolved } from '../core/tokens';\nimport { CloudFormationToken } from './cloudformation-token';\n\n/**\n * An Amazon Resource Name (ARN).\n * http://docs.aws.amazon.com/general/latest/gr/aws-arns-and-namespaces.html\n */\nexport class ArnUtils {\n    /**\n     * Creates an ARN from components.\n     *\n     * If `partition`, `region` or `account` are not specified, the stack's\n     * partition, region and account will be used.\n     *\n     * If any component is the empty string, an empty string will be inserted\n     * into the generated ARN at the location that component corresponds to.\n     *\n     * The ARN will be formatted as follows:\n     *\n     *     arn:{partition}:{service}:{region}:{account}:{resource}{sep}}{resource-name}\n     *\n     */\n    public static fromComponents(components: ArnComponents): string {\n        const partition = components.partition == null\n            ? new AwsPartition()\n            : components.partition;\n        const region = components.region == null\n            ? new AwsRegion()\n            : components.region;\n        const account = components.account == null\n            ? new AwsAccountId()\n            : components.account;\n\n        const values = [ 'arn', ':', partition, ':', components.service, ':', region, ':', account, ':', components.resource ];\n\n        const sep = components.sep || '/';\n        if (sep !== '/' && sep !== ':') {\n            throw new Error('resourcePathSep may only be \":\" or \"/\"');\n        }\n\n        if (components.resourceName != null) {\n            values.push(sep);\n            values.push(components.resourceName);\n        }\n\n        return new FnConcat(...values).toString();\n    }\n\n    /**\n     * Given an ARN, parses it and returns components.\n     *\n     * If the ARN is a concrete string, it will be parsed and validated. The\n     * separator (`sep`) will be set to '/' if the 6th component includes a '/',\n     * in which case, `resource` will be set to the value before the '/' and\n     * `resourceName` will be the rest. In case there is no '/', `resource` will\n     * be set to the 6th components and `resourceName` will be set to the rest\n     * of the string.\n     *\n     * If the ARN includes tokens (or is a token), the ARN cannot be validated,\n     * since we don't have the actual value yet at the time of this function\n     * call. You will have to know the separator and the type of ARN. The\n     * resulting `ArnComponents` object will contain tokens for the\n     * subexpressions of the ARN, not string literals. In this case this\n     * function cannot properly parse the complete final resourceName (path) out\n     * of ARNs that use '/' to both separate the 'resource' from the\n     * 'resourceName' AND to subdivide the resourceName further. For example, in\n     * S3 ARNs:\n     *\n     *      arn:aws:s3:::my_corporate_bucket/path/to/exampleobject.png\n     *\n     * After parsing the resourceName will not contain\n     * 'path/to/exampleobject.png' but simply 'path'. This is a limitation\n     * because there is no slicing functionality in CloudFormation templates.\n     *\n     * @param sep The separator used to separate resource from resourceName\n     * @param hasName Whether there is a name component in the ARN at all. For\n     * example, SNS Topics ARNs have the 'resource' component contain the topic\n     * name, and no 'resourceName' component.\n     *\n     * @returns an ArnComponents object which allows access to the various\n     * components of the ARN.\n     *\n     * @returns an ArnComponents object which allows access to the various\n     *          components of the ARN.\n     */\n    public static parse(arn: string, sepIfToken: string = '/', hasName: boolean = true): ArnComponents {\n        if (unresolved(arn)) {\n            return ArnUtils.parseToken(new CloudFormationToken(arn), sepIfToken, hasName);\n        }\n\n        const components = arn.split(':') as Array<string | undefined>;\n\n        if (components.length < 6) {\n            throw new Error('ARNs must have at least 6 components: ' + arn);\n        }\n\n        const [ arnPrefix, partition, service, region, account, sixth, ...rest ] = components;\n\n        if (arnPrefix !== 'arn') {\n            throw new Error('ARNs must start with \"arn:\": ' + arn);\n        }\n\n        if (!service) {\n            throw new Error('The `service` component (3rd component) is required: ' + arn);\n        }\n\n        if (!sixth) {\n            throw new Error('The `resource` component (6th component) is required: ' + arn);\n        }\n\n        let resource: string;\n        let resourceName: string | undefined;\n        let sep: string | undefined;\n\n        let sepIndex = sixth.indexOf('/');\n        if (sepIndex !== -1) {\n            sep = '/';\n        } else if (rest.length > 0) {\n            sep = ':';\n            sepIndex = -1;\n        }\n\n        if (sepIndex !== -1) {\n            resource = sixth.substr(0, sepIndex);\n            resourceName = sixth.substr(sepIndex + 1);\n        } else {\n            resource = sixth;\n        }\n\n        if (rest.length > 0) {\n            if (!resourceName) {\n                resourceName = '';\n            } else {\n                resourceName += ':';\n            }\n\n            resourceName += rest.join(':');\n        }\n\n        const result: ArnComponents = { service, resource };\n        if (partition) {\n            result.partition = partition;\n        }\n\n        if (region) {\n            result.region = region;\n        }\n\n        if (account) {\n            result.account = account;\n        }\n\n        if (resourceName) {\n            result.resourceName = resourceName;\n        }\n\n        if (sep) {\n            result.sep = sep;\n        }\n\n        return result;\n    }\n\n    /**\n     * Given a Token evaluating to ARN, parses it and returns components.\n     *\n     * The ARN cannot be validated, since we don't have the actual value yet\n     * at the time of this function call. You will have to know the separator\n     * and the type of ARN.\n     *\n     * The resulting `ArnComponents` object will contain tokens for the\n     * subexpressions of the ARN, not string literals.\n     *\n     * WARNING: this function cannot properly parse the complete final\n     * resourceName (path) out of ARNs that use '/' to both separate the\n     * 'resource' from the 'resourceName' AND to subdivide the resourceName\n     * further. For example, in S3 ARNs:\n     *\n     *      arn:aws:s3:::my_corporate_bucket/path/to/exampleobject.png\n     *\n     * After parsing the resourceName will not contain 'path/to/exampleobject.png'\n     * but simply 'path'. This is a limitation because there is no slicing\n     * functionality in CloudFormation templates.\n     *\n     * @param arn The input token that contains an ARN\n     * @param sep The separator used to separate resource from resourceName\n     * @param hasName Whether there is a name component in the ARN at all.\n     * For example, SNS Topics ARNs have the 'resource' component contain the\n     * topic name, and no 'resourceName' component.\n     * @returns an ArnComponents object which allows access to the various\n     * components of the ARN.\n     */\n    public static parseToken(arn: Token, sep: string = '/', hasName: boolean = true): ArnComponents {\n        // Arn ARN looks like:\n        // arn:partition:service:region:account-id:resource\n        // arn:partition:service:region:account-id:resourcetype/resource\n        // arn:partition:service:region:account-id:resourcetype:resource\n\n        // We need the 'hasName' argument because {Fn::Select}ing a nonexistent field\n        // throws an error.\n\n        const components = new FnSplit(':', arn);\n\n        const partition = new FnSelect(1, components).toString();\n        const service = new FnSelect(2, components).toString();\n        const region = new FnSelect(3, components).toString();\n        const account = new FnSelect(4, components).toString();\n\n        if (sep === ':') {\n            const resource = new FnSelect(5, components).toString();\n            const resourceName = hasName ? new FnSelect(6, components).toString() : undefined;\n\n            return { partition, service, region, account, resource, resourceName, sep };\n        } else {\n            const lastComponents = new FnSplit(sep, new FnSelect(5, components));\n\n            const resource = new FnSelect(0, lastComponents).toString();\n            const resourceName = hasName ? new FnSelect(1, lastComponents).toString() : undefined;\n\n            return { partition, service, region, account, resource, resourceName, sep };\n        }\n    }\n\n    /**\n     * Return a Token that represents the resource component of the ARN\n     */\n    public static resourceComponent(arn: string, sep: string = '/'): string {\n        return ArnUtils.parseToken(new Token(arn), sep).resource;\n    }\n\n    /**\n     * Return a Token that represents the resource Name component of the ARN\n     */\n    public static resourceNameComponent(arn: string, sep: string = '/'): string {\n        return ArnUtils.parseToken(new Token(arn), sep, true).resourceName!;\n    }\n}\n\nexport interface ArnComponents {\n    /**\n     * The partition that the resource is in. For standard AWS regions, the\n     * partition is aws. If you have resources in other partitions, the\n     * partition is aws-partitionname. For example, the partition for resources\n     * in the China (Beijing) region is aws-cn.\n     *\n     * @default The AWS partition the stack is deployed to.\n     */\n    partition?: string;\n\n    /**\n     * The service namespace that identifies the AWS product (for example,\n     * 's3', 'iam', 'codepipline').\n     */\n    service: string;\n\n    /**\n     * The region the resource resides in. Note that the ARNs for some resources\n     * do not require a region, so this component might be omitted.\n     *\n     * @default The region the stack is deployed to.\n     */\n    region?: string;\n\n    /**\n     * The ID of the AWS account that owns the resource, without the hyphens.\n     * For example, 123456789012. Note that the ARNs for some resources don't\n     * require an account number, so this component might be omitted.\n     *\n     * @default The account the stack is deployed to.\n     */\n    account?: string;\n\n    /**\n     * Resource type (e.g. \"table\", \"autoScalingGroup\", \"certificate\").\n     * For some resource types, e.g. S3 buckets, this field defines the bucket name.\n     */\n    resource: string;\n\n    /**\n     * Separator between resource type and the resource.\n     *\n     * Can be either '/' or ':'. Will only be used if path is defined.\n     * @default '/'\n     */\n    sep?: string;\n\n    /**\n     * Resource name or path within the resource (i.e. S3 bucket object key) or\n     * a wildcard such as ``\"*\"``. This is service-dependent.\n     */\n    resourceName?: string;\n}\n"]}

@@ -76,3 +76,3 @@ import { Construct } from '../core/construct';

toCloudFormation(): object;
readonly ref: Token;
readonly ref: string;
}

@@ -79,0 +79,0 @@ /**

@@ -88,2 +88,2 @@ "use strict";

exports.StringListOutput = StringListOutput;
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"output.js","sourceRoot":"","sources":["output.ts"],"names":[],"mappings":"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","sourcesContent":["import { Construct } from '../core/construct';\nimport { Token } from '../core/tokens';\nimport { Condition } from './condition';\nimport { FnImportValue, FnJoin, FnSelect, FnSplit } from './fn';\nimport { Stack, StackElement } from './stack';\n\nexport interface OutputProps {\n    /**\n     * A String type that describes the output value.\n     * The description can be a maximum of 4 K in length.\n     */\n    description?: string;\n\n    /**\n     * The value of the property returned by the aws cloudformation describe-stacks command.\n     * The value of an output can include literals, parameter references, pseudo-parameters,\n     * a mapping value, or intrinsic functions.\n     */\n    value?: any;\n\n    /**\n     * The name used to export the value of this output across stacks. To import\n     * the value from another stack, use `FnImportValue(export)`. You can create\n     * an import value token by calling `output.makeImportValue()`.\n     *\n     * @default The default behavior is to automatically allocate an export name\n     * for outputs based on the stack name and the output's logical ID. To\n     * create an output without an export, set `disableExport: true`.\n     */\n    export?: string;\n\n    /**\n     * Disables the automatic allocation of an export name for this output.\n     *\n     * @default false, which means that an export name is either explicitly\n     * specified or allocated based on the output's logical ID and stack name.\n     */\n    disableExport?: boolean;\n\n    /**\n     * A condition from the \"Conditions\" section to associate with this output\n     * value. If the condition evaluates to `false`, this output value will not\n     * be included in the stack.\n     */\n    condition?: Condition;\n}\n\nexport class Output extends StackElement {\n    /**\n     * A String type that describes the output value.\n     * The description can be a maximum of 4 K in length.\n     */\n    public readonly description?: string;\n\n    /**\n     * The value of the property returned by the aws cloudformation describe-stacks command.\n     * The value of an output can include literals, parameter references, pseudo-parameters,\n     * a mapping value, or intrinsic functions.\n     */\n    public readonly value?: any;\n\n    /**\n     * The name of the resource output to be exported for a cross-stack reference.\n     * By default, the logical ID of the Output element is used as it's export name.\n     */\n    public readonly export?: string;\n\n    /**\n     * A condition from the \"Conditions\" section to associate with this output\n     * value. If the condition evaluates to `false`, this output value will not\n     * be included in the stack.\n     */\n    public readonly condition?: Condition;\n\n    /**\n     * Creates an Output value for this stack.\n     * @param parent The parent construct.\n     * @param props Output properties.\n     */\n    constructor(parent: Construct, name: string, props: OutputProps = {}) {\n        super(parent, name);\n\n        this.description = props.description;\n        this.value = props.value;\n        this.condition = props.condition;\n\n        if (props.export) {\n            if (props.disableExport) {\n                throw new Error('Cannot set `disableExport` and specify an export name');\n            }\n            this.export = props.export;\n        } else if (!props.disableExport) {\n            // prefix export name with stack name since exports are global within account + region.\n            const stackName = Stack.find(this).id;\n            this.export = stackName ? stackName + ':' : '';\n            this.export += this.logicalId;\n        }\n    }\n\n    /**\n     * Returns an FnImportValue bound to this export name.\n     */\n    public makeImportValue() {\n        if (!this.export) {\n            throw new Error('Cannot create an ImportValue without an export name');\n        }\n        return new FnImportValue(this.export);\n    }\n\n    public toCloudFormation(): object {\n        return {\n            Outputs: {\n                [this.logicalId]: {\n                    Description: this.description,\n                    Value: this.value,\n                    Export: this.export != null ? { Name: this.export } : undefined,\n                    Condition: this.condition ? this.condition.logicalId : undefined\n                }\n            }\n        };\n    }\n\n    public get ref(): Token {\n        throw new Error('Outputs cannot be referenced');\n    }\n}\n\n/**\n * Properties for ListOutput\n */\nexport interface StringListOutputProps {\n    /**\n     * A String type that describes the output value.\n     * The description can be a maximum of 4 K in length.\n     */\n    readonly description?: string;\n\n    /**\n     * The list of primitives to export\n     */\n    readonly values: any[];\n\n    /**\n     * The separator to use to separate stringified values\n     *\n     * @default \",\"\n     */\n    readonly separator?: string;\n\n    /**\n     * The name used to export the value of this output across stacks. To import\n     * the value from another stack, use `FnImportValue(export)`. You can create\n     * an import value token by calling `output.makeImportValue()`.\n     *\n     * @default The default behavior is to automatically allocate an export name\n     * for outputs based on the stack name and the output's logical ID. To\n     * create an output without an export, set `disableExport: true`.\n     */\n    readonly export?: string;\n\n    /**\n     * Disables the automatic allocation of an export name for this output.\n     *\n     * @default false, which means that an export name is either explicitly\n     * specified or allocated based on the output's logical ID and stack name.\n     */\n    readonly disableExport?: boolean;\n\n    /**\n     * A condition from the \"Conditions\" section to associate with this output\n     * value. If the condition evaluates to `false`, this output value will not\n     * be included in the stack.\n     */\n    readonly condition?: Condition;\n}\n\n/**\n * An output for a list of strings.\n *\n * Exports a list of Tokens via an Output variable, and return a list of Tokens\n * that selects the imported values for them.\n */\nexport class StringListOutput extends Construct {\n    /**\n     * Number of elements in the stringlist\n     */\n    public readonly length: number;\n\n    /**\n     * The separator used to combine the string values\n     */\n    private readonly separator: string;\n\n    /**\n     * The Output object that was created\n     */\n    private readonly output: Output;\n\n    constructor(parent: Construct, name: string, props: StringListOutputProps) {\n        super(parent, name);\n\n        this.separator = props.separator || ',';\n        this.length = props.values.length;\n\n        this.output = new Output(this, 'Resource', {\n            description: props.description,\n            condition: props.condition,\n            disableExport: props.disableExport,\n            export: props.export,\n            value: new FnJoin(this.separator, props.values)\n        });\n    }\n\n    /**\n     * Return an array of imported values for this Output\n     */\n    public makeImportValues(): Token[] {\n        const combined = this.output.makeImportValue();\n\n        const ret = [];\n        for (let i = 0; i < this.length; i++) {\n            ret.push(new FnSelect(i, new FnSplit(this.separator, combined)));\n        }\n\n        return ret;\n    }\n}\n"]}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"output.js","sourceRoot":"","sources":["output.ts"],"names":[],"mappings":"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","sourcesContent":["import { Construct } from '../core/construct';\nimport { Token } from '../core/tokens';\nimport { Condition } from './condition';\nimport { FnImportValue, FnJoin, FnSelect, FnSplit } from './fn';\nimport { Stack, StackElement } from './stack';\n\nexport interface OutputProps {\n    /**\n     * A String type that describes the output value.\n     * The description can be a maximum of 4 K in length.\n     */\n    description?: string;\n\n    /**\n     * The value of the property returned by the aws cloudformation describe-stacks command.\n     * The value of an output can include literals, parameter references, pseudo-parameters,\n     * a mapping value, or intrinsic functions.\n     */\n    value?: any;\n\n    /**\n     * The name used to export the value of this output across stacks. To import\n     * the value from another stack, use `FnImportValue(export)`. You can create\n     * an import value token by calling `output.makeImportValue()`.\n     *\n     * @default The default behavior is to automatically allocate an export name\n     * for outputs based on the stack name and the output's logical ID. To\n     * create an output without an export, set `disableExport: true`.\n     */\n    export?: string;\n\n    /**\n     * Disables the automatic allocation of an export name for this output.\n     *\n     * @default false, which means that an export name is either explicitly\n     * specified or allocated based on the output's logical ID and stack name.\n     */\n    disableExport?: boolean;\n\n    /**\n     * A condition from the \"Conditions\" section to associate with this output\n     * value. If the condition evaluates to `false`, this output value will not\n     * be included in the stack.\n     */\n    condition?: Condition;\n}\n\nexport class Output extends StackElement {\n    /**\n     * A String type that describes the output value.\n     * The description can be a maximum of 4 K in length.\n     */\n    public readonly description?: string;\n\n    /**\n     * The value of the property returned by the aws cloudformation describe-stacks command.\n     * The value of an output can include literals, parameter references, pseudo-parameters,\n     * a mapping value, or intrinsic functions.\n     */\n    public readonly value?: any;\n\n    /**\n     * The name of the resource output to be exported for a cross-stack reference.\n     * By default, the logical ID of the Output element is used as it's export name.\n     */\n    public readonly export?: string;\n\n    /**\n     * A condition from the \"Conditions\" section to associate with this output\n     * value. If the condition evaluates to `false`, this output value will not\n     * be included in the stack.\n     */\n    public readonly condition?: Condition;\n\n    /**\n     * Creates an Output value for this stack.\n     * @param parent The parent construct.\n     * @param props Output properties.\n     */\n    constructor(parent: Construct, name: string, props: OutputProps = {}) {\n        super(parent, name);\n\n        this.description = props.description;\n        this.value = props.value;\n        this.condition = props.condition;\n\n        if (props.export) {\n            if (props.disableExport) {\n                throw new Error('Cannot set `disableExport` and specify an export name');\n            }\n            this.export = props.export;\n        } else if (!props.disableExport) {\n            // prefix export name with stack name since exports are global within account + region.\n            const stackName = Stack.find(this).id;\n            this.export = stackName ? stackName + ':' : '';\n            this.export += this.logicalId;\n        }\n    }\n\n    /**\n     * Returns an FnImportValue bound to this export name.\n     */\n    public makeImportValue() {\n        if (!this.export) {\n            throw new Error('Cannot create an ImportValue without an export name');\n        }\n        return new FnImportValue(this.export);\n    }\n\n    public toCloudFormation(): object {\n        return {\n            Outputs: {\n                [this.logicalId]: {\n                    Description: this.description,\n                    Value: this.value,\n                    Export: this.export != null ? { Name: this.export } : undefined,\n                    Condition: this.condition ? this.condition.logicalId : undefined\n                }\n            }\n        };\n    }\n\n    public get ref(): string {\n        throw new Error('Outputs cannot be referenced');\n    }\n}\n\n/**\n * Properties for ListOutput\n */\nexport interface StringListOutputProps {\n    /**\n     * A String type that describes the output value.\n     * The description can be a maximum of 4 K in length.\n     */\n    readonly description?: string;\n\n    /**\n     * The list of primitives to export\n     */\n    readonly values: any[];\n\n    /**\n     * The separator to use to separate stringified values\n     *\n     * @default \",\"\n     */\n    readonly separator?: string;\n\n    /**\n     * The name used to export the value of this output across stacks. To import\n     * the value from another stack, use `FnImportValue(export)`. You can create\n     * an import value token by calling `output.makeImportValue()`.\n     *\n     * @default The default behavior is to automatically allocate an export name\n     * for outputs based on the stack name and the output's logical ID. To\n     * create an output without an export, set `disableExport: true`.\n     */\n    readonly export?: string;\n\n    /**\n     * Disables the automatic allocation of an export name for this output.\n     *\n     * @default false, which means that an export name is either explicitly\n     * specified or allocated based on the output's logical ID and stack name.\n     */\n    readonly disableExport?: boolean;\n\n    /**\n     * A condition from the \"Conditions\" section to associate with this output\n     * value. If the condition evaluates to `false`, this output value will not\n     * be included in the stack.\n     */\n    readonly condition?: Condition;\n}\n\n/**\n * An output for a list of strings.\n *\n * Exports a list of Tokens via an Output variable, and return a list of Tokens\n * that selects the imported values for them.\n */\nexport class StringListOutput extends Construct {\n    /**\n     * Number of elements in the stringlist\n     */\n    public readonly length: number;\n\n    /**\n     * The separator used to combine the string values\n     */\n    private readonly separator: string;\n\n    /**\n     * The Output object that was created\n     */\n    private readonly output: Output;\n\n    constructor(parent: Construct, name: string, props: StringListOutputProps) {\n        super(parent, name);\n\n        this.separator = props.separator || ',';\n        this.length = props.values.length;\n\n        this.output = new Output(this, 'Resource', {\n            description: props.description,\n            condition: props.condition,\n            disableExport: props.disableExport,\n            export: props.export,\n            value: new FnJoin(this.separator, props.values)\n        });\n    }\n\n    /**\n     * Return an array of imported values for this Output\n     */\n    public makeImportValues(): Token[] {\n        const combined = this.output.makeImportValue();\n\n        const ret = [];\n        for (let i = 0; i < this.length; i++) {\n            ret.push(new FnSelect(i, new FnSplit(this.separator, combined)));\n        }\n\n        return ret;\n    }\n}\n"]}

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

this.properties = props;
this.value = this.ref;
this.value = new stack_1.Ref(this);
}

@@ -52,2 +52,2 @@ toCloudFormation() {

exports.Parameter = Parameter;
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicGFyYW1ldGVyLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsicGFyYW1ldGVyLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7O0FBRUEsbUNBQXdDO0FBaUV4Qzs7OztHQUlHO0FBQ0gsTUFBYSxTQUFVLFNBQVEscUJBQWE7SUFReEM7Ozs7Ozs7T0FPRztJQUNILFlBQVksTUFBaUIsRUFBRSxJQUFZLEVBQUUsS0FBcUI7UUFDOUQsS0FBSyxDQUFDLE1BQU0sRUFBRSxJQUFJLENBQUMsQ0FBQztRQUNwQixJQUFJLENBQUMsVUFBVSxHQUFHLEtBQUssQ0FBQztRQUN4QixJQUFJLENBQUMsS0FBSyxHQUFHLElBQUksQ0FBQyxHQUFHLENBQUM7SUFDMUIsQ0FBQztJQUVNLGdCQUFnQjtRQUNuQixPQUFPO1lBQ0gsVUFBVSxFQUFFO2dCQUNSLENBQUMsSUFBSSxDQUFDLFNBQVMsQ0FBQyxFQUFFO29CQUNkLElBQUksRUFBRSxJQUFJLENBQUMsVUFBVSxDQUFDLElBQUk7b0JBQzFCLE9BQU8sRUFBRSxJQUFJLENBQUMsVUFBVSxDQUFDLE9BQU87b0JBQ2hDLGNBQWMsRUFBRSxJQUFJLENBQUMsVUFBVSxDQUFDLGNBQWM7b0JBQzlDLGFBQWEsRUFBRSxJQUFJLENBQUMsVUFBVSxDQUFDLGFBQWE7b0JBQzVDLHFCQUFxQixFQUFFLElBQUksQ0FBQyxVQUFVLENBQUMscUJBQXFCO29CQUM1RCxXQUFXLEVBQUUsSUFBSSxDQUFDLFVBQVUsQ0FBQyxXQUFXO29CQUN4QyxTQUFTLEVBQUUsSUFBSSxDQUFDLFVBQVUsQ0FBQyxTQUFTO29CQUNwQyxRQUFRLEVBQUUsSUFBSSxDQUFDLFVBQVUsQ0FBQyxRQUFRO29CQUNsQyxTQUFTLEVBQUUsSUFBSSxDQUFDLFVBQVUsQ0FBQyxTQUFTO29CQUNwQyxRQUFRLEVBQUUsSUFBSSxDQUFDLFVBQVUsQ0FBQyxRQUFRO29CQUNsQyxNQUFNLEVBQUUsSUFBSSxDQUFDLFVBQVUsQ0FBQyxNQUFNO2lCQUNqQzthQUNKO1NBQ0osQ0FBQztJQUNOLENBQUM7SUFFRDs7O09BR0c7SUFDSSxPQUFPO1FBQ1YsT0FBTyxJQUFJLENBQUMsS0FBSyxDQUFDO0lBQ3RCLENBQUM7Q0FDSjtBQWpERCw4QkFpREMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBDb25zdHJ1Y3QgfSBmcm9tICcuLi9jb3JlL2NvbnN0cnVjdCc7XG5pbXBvcnQgeyBUb2tlbiB9IGZyb20gJy4uL2NvcmUvdG9rZW5zJztcbmltcG9ydCB7IFJlZmVyZW5jZWFibGUgfSBmcm9tICcuL3N0YWNrJztcblxuZXhwb3J0IGludGVyZmFjZSBQYXJhbWV0ZXJQcm9wcyB7XG4gICAgLyoqXG4gICAgICogVGhlIGRhdGEgdHlwZSBmb3IgdGhlIHBhcmFtZXRlciAoRGF0YVR5cGUpLlxuICAgICAqL1xuICAgIHR5cGU6IHN0cmluZztcblxuICAgIC8qKlxuICAgICAqIEEgdmFsdWUgb2YgdGhlIGFwcHJvcHJpYXRlIHR5cGUgZm9yIHRoZSB0ZW1wbGF0ZSB0byB1c2UgaWYgbm8gdmFsdWUgaXMgc3BlY2lmaWVkXG4gICAgICogd2hlbiBhIHN0YWNrIGlzIGNyZWF0ZWQuIElmIHlvdSBkZWZpbmUgY29uc3RyYWludHMgZm9yIHRoZSBwYXJhbWV0ZXIsIHlvdSBtdXN0IHNwZWNpZnlcbiAgICAgKiBhIHZhbHVlIHRoYXQgYWRoZXJlcyB0byB0aG9zZSBjb25zdHJhaW50cy5cbiAgICAgKi9cbiAgICBkZWZhdWx0PzogYW55O1xuXG4gICAgLyoqXG4gICAgICogQSByZWd1bGFyIGV4cHJlc3Npb24gdGhhdCByZXByZXNlbnRzIHRoZSBwYXR0ZXJucyB0byBhbGxvdyBmb3IgU3RyaW5nIHR5cGVzLlxuICAgICAqL1xuICAgIGFsbG93ZWRQYXR0ZXJuPzogc3RyaW5nO1xuXG4gICAgLyoqXG4gICAgICogQW4gYXJyYXkgY29udGFpbmluZyB0aGUgbGlzdCBvZiB2YWx1ZXMgYWxsb3dlZCBmb3IgdGhlIHBhcmFtZXRlci5cbiAgICAgKi9cbiAgICBhbGxvd2VkVmFsdWVzPzogc3RyaW5nW107XG5cbiAgICAvKipcbiAgICAgKiBBIHN0cmluZyB0aGF0IGV4cGxhaW5zIGEgY29uc3RyYWludCB3aGVuIHRoZSBjb25zdHJhaW50IGlzIHZpb2xhdGVkLlxuICAgICAqIEZvciBleGFtcGxlLCB3aXRob3V0IGEgY29uc3RyYWludCBkZXNjcmlwdGlvbiwgYSBwYXJhbWV0ZXIgdGhhdCBoYXMgYW4gYWxsb3dlZFxuICAgICAqIHBhdHRlcm4gb2YgW0EtWmEtejAtOV0rIGRpc3BsYXlzIHRoZSBmb2xsb3dpbmcgZXJyb3IgbWVzc2FnZSB3aGVuIHRoZSB1c2VyIHNwZWNpZmllc1xuICAgICAqIGFuIGludmFsaWQgdmFsdWU6XG4gICAgICovXG4gICAgY29uc3RyYWludERlc2NyaXB0aW9uPzogc3RyaW5nO1xuXG4gICAgLyoqXG4gICAgICogQSBzdHJpbmcgb2YgdXAgdG8gNDAwMCBjaGFyYWN0ZXJzIHRoYXQgZGVzY3JpYmVzIHRoZSBwYXJhbWV0ZXIuXG4gICAgICovXG4gICAgZGVzY3JpcHRpb24/OiBzdHJpbmc7XG5cbiAgICAvKipcbiAgICAgKiBBbiBpbnRlZ2VyIHZhbHVlIHRoYXQgZGV0ZXJtaW5lcyB0aGUgbGFyZ2VzdCBudW1iZXIgb2YgY2hhcmFjdGVycyB5b3Ugd2FudCB0byBhbGxvdyBmb3IgU3RyaW5nIHR5cGVzLlxuICAgICAqL1xuICAgIG1heExlbmd0aD86IG51bWJlcjtcblxuICAgIC8qKlxuICAgICAqIEEgbnVtZXJpYyB2YWx1ZSB0aGF0IGRldGVybWluZXMgdGhlIGxhcmdlc3QgbnVtZXJpYyB2YWx1ZSB5b3Ugd2FudCB0byBhbGxvdyBmb3IgTnVtYmVyIHR5cGVzLlxuICAgICAqL1xuICAgIG1heFZhbHVlPzogbnVtYmVyO1xuXG4gICAgLyoqXG4gICAgICogQW4gaW50ZWdlciB2YWx1ZSB0aGF0IGRldGVybWluZXMgdGhlIHNtYWxsZXN0IG51bWJlciBvZiBjaGFyYWN0ZXJzIHlvdSB3YW50IHRvIGFsbG93IGZvciBTdHJpbmcgdHlwZXMuXG4gICAgICovXG4gICAgbWluTGVuZ3RoPzogbnVtYmVyO1xuXG4gICAgLyoqXG4gICAgICogQSBudW1lcmljIHZhbHVlIHRoYXQgZGV0ZXJtaW5lcyB0aGUgc21hbGxlc3QgbnVtZXJpYyB2YWx1ZSB5b3Ugd2FudCB0byBhbGxvdyBmb3IgTnVtYmVyIHR5cGVzLlxuICAgICAqL1xuICAgIG1pblZhbHVlPzogbnVtYmVyO1xuXG4gICAgLyoqXG4gICAgICogV2hldGhlciB0byBtYXNrIHRoZSBwYXJhbWV0ZXIgdmFsdWUgd2hlbiBhbnlvbmUgbWFrZXMgYSBjYWxsIHRoYXQgZGVzY3JpYmVzIHRoZSBzdGFjay5cbiAgICAgKiBJZiB5b3Ugc2V0IHRoZSB2YWx1ZSB0byBgYHRydWVgYCwgdGhlIHBhcmFtZXRlciB2YWx1ZSBpcyBtYXNrZWQgd2l0aCBhc3Rlcmlza3MgKGBgKioqKipgYCkuXG4gICAgICovXG4gICAgbm9FY2hvPzogYm9vbGVhbjtcbn1cblxuLyoqXG4gKiBVc2UgdGhlIG9wdGlvbmFsIFBhcmFtZXRlcnMgc2VjdGlvbiB0byBjdXN0b21pemUgeW91ciB0ZW1wbGF0ZXMuXG4gKiBQYXJhbWV0ZXJzIGVuYWJsZSB5b3UgdG8gaW5wdXQgY3VzdG9tIHZhbHVlcyB0byB5b3VyIHRlbXBsYXRlIGVhY2ggdGltZSB5b3UgY3JlYXRlIG9yXG4gKiB1cGRhdGUgYSBzdGFjay5cbiAqL1xuZXhwb3J0IGNsYXNzIFBhcmFtZXRlciBleHRlbmRzIFJlZmVyZW5jZWFibGUge1xuICAgIC8qKlxuICAgICAqIEEgdG9rZW4gdGhhdCByZXByZXNlbnRzIHRoZSBhY3R1YWwgdmFsdWUgb2YgdGhpcyBwYXJhbWV0ZXIuXG4gICAgICovXG4gICAgcHVibGljIHZhbHVlOiBUb2tlbjtcblxuICAgIHByaXZhdGUgcHJvcGVydGllczogUGFyYW1ldGVyUHJvcHM7XG5cbiAgICAvKipcbiAgICAgKiBDcmVhdGVzIGEgcGFyYW1ldGVyIGNvbnN0cnVjdC5cbiAgICAgKiBOb3RlIHRoYXQgdGhlIG5hbWUgKGxvZ2ljYWwgSUQpIG9mIHRoZSBwYXJhbWV0ZXIgd2lsbCBkZXJpdmUgZnJvbSBpdCdzIGBjb25hbWVgIGFuZCBsb2NhdGlvblxuICAgICAqIHdpdGhpbiB0aGUgc3RhY2suIFRoZXJlZm9yZSwgaXQgaXMgcmVjb21tZW5kZWQgdGhhdCBwYXJhbWV0ZXJzIGFyZSBkZWZpbmVkIGF0IHRoZSBzdGFjayBsZXZlbC5cbiAgICAgKlxuICAgICAqIEBwYXJhbSBwYXJlbnQgVGhlIHBhcmVudCBjb25zdHJ1Y3QuXG4gICAgICogQHBhcmFtIHByb3BzIFRoZSBwYXJhbWV0ZXIgcHJvcGVydGllcy5cbiAgICAgKi9cbiAgICBjb25zdHJ1Y3RvcihwYXJlbnQ6IENvbnN0cnVjdCwgbmFtZTogc3RyaW5nLCBwcm9wczogUGFyYW1ldGVyUHJvcHMpIHtcbiAgICAgICAgc3VwZXIocGFyZW50LCBuYW1lKTtcbiAgICAgICAgdGhpcy5wcm9wZXJ0aWVzID0gcHJvcHM7XG4gICAgICAgIHRoaXMudmFsdWUgPSB0aGlzLnJlZjtcbiAgICB9XG5cbiAgICBwdWJsaWMgdG9DbG91ZEZvcm1hdGlvbigpOiBvYmplY3Qge1xuICAgICAgICByZXR1cm4ge1xuICAgICAgICAgICAgUGFyYW1ldGVyczoge1xuICAgICAgICAgICAgICAgIFt0aGlzLmxvZ2ljYWxJZF06IHtcbiAgICAgICAgICAgICAgICAgICAgVHlwZTogdGhpcy5wcm9wZXJ0aWVzLnR5cGUsXG4gICAgICAgICAgICAgICAgICAgIERlZmF1bHQ6IHRoaXMucHJvcGVydGllcy5kZWZhdWx0LFxuICAgICAgICAgICAgICAgICAgICBBbGxvd2VkUGF0dGVybjogdGhpcy5wcm9wZXJ0aWVzLmFsbG93ZWRQYXR0ZXJuLFxuICAgICAgICAgICAgICAgICAgICBBbGxvd2VkVmFsdWVzOiB0aGlzLnByb3BlcnRpZXMuYWxsb3dlZFZhbHVlcyxcbiAgICAgICAgICAgICAgICAgICAgQ29uc3RyYWludERlc2NyaXB0aW9uOiB0aGlzLnByb3BlcnRpZXMuY29uc3RyYWludERlc2NyaXB0aW9uLFxuICAgICAgICAgICAgICAgICAgICBEZXNjcmlwdGlvbjogdGhpcy5wcm9wZXJ0aWVzLmRlc2NyaXB0aW9uLFxuICAgICAgICAgICAgICAgICAgICBNYXhMZW5ndGg6IHRoaXMucHJvcGVydGllcy5tYXhMZW5ndGgsXG4gICAgICAgICAgICAgICAgICAgIE1heFZhbHVlOiB0aGlzLnByb3BlcnRpZXMubWF4VmFsdWUsXG4gICAgICAgICAgICAgICAgICAgIE1pbkxlbmd0aDogdGhpcy5wcm9wZXJ0aWVzLm1pbkxlbmd0aCxcbiAgICAgICAgICAgICAgICAgICAgTWluVmFsdWU6IHRoaXMucHJvcGVydGllcy5taW5WYWx1ZSxcbiAgICAgICAgICAgICAgICAgICAgTm9FY2hvOiB0aGlzLnByb3BlcnRpZXMubm9FY2hvXG4gICAgICAgICAgICAgICAgfVxuICAgICAgICAgICAgfVxuICAgICAgICB9O1xuICAgIH1cblxuICAgIC8qKlxuICAgICAqIEFsbG93cyB1c2luZyBwYXJhbWV0ZXJzIGFzIHRva2VucyB3aXRob3V0IHRoZSBuZWVkIHRvIGRlcmVmZXJlbmNlIHRoZW0uXG4gICAgICogVGhpcyBpbXBsaWNpdGx5IGltcGxlbWVudHMgVG9rZW4sIHVudGlsIHdlIG1ha2UgaXQgYW4gaW50ZXJmYWNlLlxuICAgICAqL1xuICAgIHB1YmxpYyByZXNvbHZlKCk6IGFueSB7XG4gICAgICAgIHJldHVybiB0aGlzLnZhbHVlO1xuICAgIH1cbn1cbiJdfQ==
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicGFyYW1ldGVyLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsicGFyYW1ldGVyLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7O0FBRUEsbUNBQTZDO0FBaUU3Qzs7OztHQUlHO0FBQ0gsTUFBYSxTQUFVLFNBQVEscUJBQWE7SUFReEM7Ozs7Ozs7T0FPRztJQUNILFlBQVksTUFBaUIsRUFBRSxJQUFZLEVBQUUsS0FBcUI7UUFDOUQsS0FBSyxDQUFDLE1BQU0sRUFBRSxJQUFJLENBQUMsQ0FBQztRQUNwQixJQUFJLENBQUMsVUFBVSxHQUFHLEtBQUssQ0FBQztRQUN4QixJQUFJLENBQUMsS0FBSyxHQUFHLElBQUksV0FBRyxDQUFDLElBQUksQ0FBQyxDQUFDO0lBQy9CLENBQUM7SUFFTSxnQkFBZ0I7UUFDbkIsT0FBTztZQUNILFVBQVUsRUFBRTtnQkFDUixDQUFDLElBQUksQ0FBQyxTQUFTLENBQUMsRUFBRTtvQkFDZCxJQUFJLEVBQUUsSUFBSSxDQUFDLFVBQVUsQ0FBQyxJQUFJO29CQUMxQixPQUFPLEVBQUUsSUFBSSxDQUFDLFVBQVUsQ0FBQyxPQUFPO29CQUNoQyxjQUFjLEVBQUUsSUFBSSxDQUFDLFVBQVUsQ0FBQyxjQUFjO29CQUM5QyxhQUFhLEVBQUUsSUFBSSxDQUFDLFVBQVUsQ0FBQyxhQUFhO29CQUM1QyxxQkFBcUIsRUFBRSxJQUFJLENBQUMsVUFBVSxDQUFDLHFCQUFxQjtvQkFDNUQsV0FBVyxFQUFFLElBQUksQ0FBQyxVQUFVLENBQUMsV0FBVztvQkFDeEMsU0FBUyxFQUFFLElBQUksQ0FBQyxVQUFVLENBQUMsU0FBUztvQkFDcEMsUUFBUSxFQUFFLElBQUksQ0FBQyxVQUFVLENBQUMsUUFBUTtvQkFDbEMsU0FBUyxFQUFFLElBQUksQ0FBQyxVQUFVLENBQUMsU0FBUztvQkFDcEMsUUFBUSxFQUFFLElBQUksQ0FBQyxVQUFVLENBQUMsUUFBUTtvQkFDbEMsTUFBTSxFQUFFLElBQUksQ0FBQyxVQUFVLENBQUMsTUFBTTtpQkFDakM7YUFDSjtTQUNKLENBQUM7SUFDTixDQUFDO0lBRUQ7OztPQUdHO0lBQ0ksT0FBTztRQUNWLE9BQU8sSUFBSSxDQUFDLEtBQUssQ0FBQztJQUN0QixDQUFDO0NBQ0o7QUFqREQsOEJBaURDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgQ29uc3RydWN0IH0gZnJvbSAnLi4vY29yZS9jb25zdHJ1Y3QnO1xuaW1wb3J0IHsgVG9rZW4gfSBmcm9tICcuLi9jb3JlL3Rva2Vucyc7XG5pbXBvcnQgeyBSZWYsIFJlZmVyZW5jZWFibGUgfSBmcm9tICcuL3N0YWNrJztcblxuZXhwb3J0IGludGVyZmFjZSBQYXJhbWV0ZXJQcm9wcyB7XG4gICAgLyoqXG4gICAgICogVGhlIGRhdGEgdHlwZSBmb3IgdGhlIHBhcmFtZXRlciAoRGF0YVR5cGUpLlxuICAgICAqL1xuICAgIHR5cGU6IHN0cmluZztcblxuICAgIC8qKlxuICAgICAqIEEgdmFsdWUgb2YgdGhlIGFwcHJvcHJpYXRlIHR5cGUgZm9yIHRoZSB0ZW1wbGF0ZSB0byB1c2UgaWYgbm8gdmFsdWUgaXMgc3BlY2lmaWVkXG4gICAgICogd2hlbiBhIHN0YWNrIGlzIGNyZWF0ZWQuIElmIHlvdSBkZWZpbmUgY29uc3RyYWludHMgZm9yIHRoZSBwYXJhbWV0ZXIsIHlvdSBtdXN0IHNwZWNpZnlcbiAgICAgKiBhIHZhbHVlIHRoYXQgYWRoZXJlcyB0byB0aG9zZSBjb25zdHJhaW50cy5cbiAgICAgKi9cbiAgICBkZWZhdWx0PzogYW55O1xuXG4gICAgLyoqXG4gICAgICogQSByZWd1bGFyIGV4cHJlc3Npb24gdGhhdCByZXByZXNlbnRzIHRoZSBwYXR0ZXJucyB0byBhbGxvdyBmb3IgU3RyaW5nIHR5cGVzLlxuICAgICAqL1xuICAgIGFsbG93ZWRQYXR0ZXJuPzogc3RyaW5nO1xuXG4gICAgLyoqXG4gICAgICogQW4gYXJyYXkgY29udGFpbmluZyB0aGUgbGlzdCBvZiB2YWx1ZXMgYWxsb3dlZCBmb3IgdGhlIHBhcmFtZXRlci5cbiAgICAgKi9cbiAgICBhbGxvd2VkVmFsdWVzPzogc3RyaW5nW107XG5cbiAgICAvKipcbiAgICAgKiBBIHN0cmluZyB0aGF0IGV4cGxhaW5zIGEgY29uc3RyYWludCB3aGVuIHRoZSBjb25zdHJhaW50IGlzIHZpb2xhdGVkLlxuICAgICAqIEZvciBleGFtcGxlLCB3aXRob3V0IGEgY29uc3RyYWludCBkZXNjcmlwdGlvbiwgYSBwYXJhbWV0ZXIgdGhhdCBoYXMgYW4gYWxsb3dlZFxuICAgICAqIHBhdHRlcm4gb2YgW0EtWmEtejAtOV0rIGRpc3BsYXlzIHRoZSBmb2xsb3dpbmcgZXJyb3IgbWVzc2FnZSB3aGVuIHRoZSB1c2VyIHNwZWNpZmllc1xuICAgICAqIGFuIGludmFsaWQgdmFsdWU6XG4gICAgICovXG4gICAgY29uc3RyYWludERlc2NyaXB0aW9uPzogc3RyaW5nO1xuXG4gICAgLyoqXG4gICAgICogQSBzdHJpbmcgb2YgdXAgdG8gNDAwMCBjaGFyYWN0ZXJzIHRoYXQgZGVzY3JpYmVzIHRoZSBwYXJhbWV0ZXIuXG4gICAgICovXG4gICAgZGVzY3JpcHRpb24/OiBzdHJpbmc7XG5cbiAgICAvKipcbiAgICAgKiBBbiBpbnRlZ2VyIHZhbHVlIHRoYXQgZGV0ZXJtaW5lcyB0aGUgbGFyZ2VzdCBudW1iZXIgb2YgY2hhcmFjdGVycyB5b3Ugd2FudCB0byBhbGxvdyBmb3IgU3RyaW5nIHR5cGVzLlxuICAgICAqL1xuICAgIG1heExlbmd0aD86IG51bWJlcjtcblxuICAgIC8qKlxuICAgICAqIEEgbnVtZXJpYyB2YWx1ZSB0aGF0IGRldGVybWluZXMgdGhlIGxhcmdlc3QgbnVtZXJpYyB2YWx1ZSB5b3Ugd2FudCB0byBhbGxvdyBmb3IgTnVtYmVyIHR5cGVzLlxuICAgICAqL1xuICAgIG1heFZhbHVlPzogbnVtYmVyO1xuXG4gICAgLyoqXG4gICAgICogQW4gaW50ZWdlciB2YWx1ZSB0aGF0IGRldGVybWluZXMgdGhlIHNtYWxsZXN0IG51bWJlciBvZiBjaGFyYWN0ZXJzIHlvdSB3YW50IHRvIGFsbG93IGZvciBTdHJpbmcgdHlwZXMuXG4gICAgICovXG4gICAgbWluTGVuZ3RoPzogbnVtYmVyO1xuXG4gICAgLyoqXG4gICAgICogQSBudW1lcmljIHZhbHVlIHRoYXQgZGV0ZXJtaW5lcyB0aGUgc21hbGxlc3QgbnVtZXJpYyB2YWx1ZSB5b3Ugd2FudCB0byBhbGxvdyBmb3IgTnVtYmVyIHR5cGVzLlxuICAgICAqL1xuICAgIG1pblZhbHVlPzogbnVtYmVyO1xuXG4gICAgLyoqXG4gICAgICogV2hldGhlciB0byBtYXNrIHRoZSBwYXJhbWV0ZXIgdmFsdWUgd2hlbiBhbnlvbmUgbWFrZXMgYSBjYWxsIHRoYXQgZGVzY3JpYmVzIHRoZSBzdGFjay5cbiAgICAgKiBJZiB5b3Ugc2V0IHRoZSB2YWx1ZSB0byBgYHRydWVgYCwgdGhlIHBhcmFtZXRlciB2YWx1ZSBpcyBtYXNrZWQgd2l0aCBhc3Rlcmlza3MgKGBgKioqKipgYCkuXG4gICAgICovXG4gICAgbm9FY2hvPzogYm9vbGVhbjtcbn1cblxuLyoqXG4gKiBVc2UgdGhlIG9wdGlvbmFsIFBhcmFtZXRlcnMgc2VjdGlvbiB0byBjdXN0b21pemUgeW91ciB0ZW1wbGF0ZXMuXG4gKiBQYXJhbWV0ZXJzIGVuYWJsZSB5b3UgdG8gaW5wdXQgY3VzdG9tIHZhbHVlcyB0byB5b3VyIHRlbXBsYXRlIGVhY2ggdGltZSB5b3UgY3JlYXRlIG9yXG4gKiB1cGRhdGUgYSBzdGFjay5cbiAqL1xuZXhwb3J0IGNsYXNzIFBhcmFtZXRlciBleHRlbmRzIFJlZmVyZW5jZWFibGUge1xuICAgIC8qKlxuICAgICAqIEEgdG9rZW4gdGhhdCByZXByZXNlbnRzIHRoZSBhY3R1YWwgdmFsdWUgb2YgdGhpcyBwYXJhbWV0ZXIuXG4gICAgICovXG4gICAgcHVibGljIHZhbHVlOiBUb2tlbjtcblxuICAgIHByaXZhdGUgcHJvcGVydGllczogUGFyYW1ldGVyUHJvcHM7XG5cbiAgICAvKipcbiAgICAgKiBDcmVhdGVzIGEgcGFyYW1ldGVyIGNvbnN0cnVjdC5cbiAgICAgKiBOb3RlIHRoYXQgdGhlIG5hbWUgKGxvZ2ljYWwgSUQpIG9mIHRoZSBwYXJhbWV0ZXIgd2lsbCBkZXJpdmUgZnJvbSBpdCdzIGBjb25hbWVgIGFuZCBsb2NhdGlvblxuICAgICAqIHdpdGhpbiB0aGUgc3RhY2suIFRoZXJlZm9yZSwgaXQgaXMgcmVjb21tZW5kZWQgdGhhdCBwYXJhbWV0ZXJzIGFyZSBkZWZpbmVkIGF0IHRoZSBzdGFjayBsZXZlbC5cbiAgICAgKlxuICAgICAqIEBwYXJhbSBwYXJlbnQgVGhlIHBhcmVudCBjb25zdHJ1Y3QuXG4gICAgICogQHBhcmFtIHByb3BzIFRoZSBwYXJhbWV0ZXIgcHJvcGVydGllcy5cbiAgICAgKi9cbiAgICBjb25zdHJ1Y3RvcihwYXJlbnQ6IENvbnN0cnVjdCwgbmFtZTogc3RyaW5nLCBwcm9wczogUGFyYW1ldGVyUHJvcHMpIHtcbiAgICAgICAgc3VwZXIocGFyZW50LCBuYW1lKTtcbiAgICAgICAgdGhpcy5wcm9wZXJ0aWVzID0gcHJvcHM7XG4gICAgICAgIHRoaXMudmFsdWUgPSBuZXcgUmVmKHRoaXMpO1xuICAgIH1cblxuICAgIHB1YmxpYyB0b0Nsb3VkRm9ybWF0aW9uKCk6IG9iamVjdCB7XG4gICAgICAgIHJldHVybiB7XG4gICAgICAgICAgICBQYXJhbWV0ZXJzOiB7XG4gICAgICAgICAgICAgICAgW3RoaXMubG9naWNhbElkXToge1xuICAgICAgICAgICAgICAgICAgICBUeXBlOiB0aGlzLnByb3BlcnRpZXMudHlwZSxcbiAgICAgICAgICAgICAgICAgICAgRGVmYXVsdDogdGhpcy5wcm9wZXJ0aWVzLmRlZmF1bHQsXG4gICAgICAgICAgICAgICAgICAgIEFsbG93ZWRQYXR0ZXJuOiB0aGlzLnByb3BlcnRpZXMuYWxsb3dlZFBhdHRlcm4sXG4gICAgICAgICAgICAgICAgICAgIEFsbG93ZWRWYWx1ZXM6IHRoaXMucHJvcGVydGllcy5hbGxvd2VkVmFsdWVzLFxuICAgICAgICAgICAgICAgICAgICBDb25zdHJhaW50RGVzY3JpcHRpb246IHRoaXMucHJvcGVydGllcy5jb25zdHJhaW50RGVzY3JpcHRpb24sXG4gICAgICAgICAgICAgICAgICAgIERlc2NyaXB0aW9uOiB0aGlzLnByb3BlcnRpZXMuZGVzY3JpcHRpb24sXG4gICAgICAgICAgICAgICAgICAgIE1heExlbmd0aDogdGhpcy5wcm9wZXJ0aWVzLm1heExlbmd0aCxcbiAgICAgICAgICAgICAgICAgICAgTWF4VmFsdWU6IHRoaXMucHJvcGVydGllcy5tYXhWYWx1ZSxcbiAgICAgICAgICAgICAgICAgICAgTWluTGVuZ3RoOiB0aGlzLnByb3BlcnRpZXMubWluTGVuZ3RoLFxuICAgICAgICAgICAgICAgICAgICBNaW5WYWx1ZTogdGhpcy5wcm9wZXJ0aWVzLm1pblZhbHVlLFxuICAgICAgICAgICAgICAgICAgICBOb0VjaG86IHRoaXMucHJvcGVydGllcy5ub0VjaG9cbiAgICAgICAgICAgICAgICB9XG4gICAgICAgICAgICB9XG4gICAgICAgIH07XG4gICAgfVxuXG4gICAgLyoqXG4gICAgICogQWxsb3dzIHVzaW5nIHBhcmFtZXRlcnMgYXMgdG9rZW5zIHdpdGhvdXQgdGhlIG5lZWQgdG8gZGVyZWZlcmVuY2UgdGhlbS5cbiAgICAgKiBUaGlzIGltcGxpY2l0bHkgaW1wbGVtZW50cyBUb2tlbiwgdW50aWwgd2UgbWFrZSBpdCBhbiBpbnRlcmZhY2UuXG4gICAgICovXG4gICAgcHVibGljIHJlc29sdmUoKTogYW55IHtcbiAgICAgICAgcmV0dXJuIHRoaXMudmFsdWU7XG4gICAgfVxufVxuIl19
import { Token } from '../core/tokens';
import { Arn } from './arn';
export declare class PolicyDocument extends Token {

@@ -50,4 +49,4 @@ private readonly baseDocument?;

export declare class ArnPrincipal extends PolicyPrincipal {
readonly arn: Arn;
constructor(arn: Arn);
readonly arn: string;
constructor(arn: string);
policyFragment(): PrincipalPolicyFragment;

@@ -131,3 +130,3 @@ }

addPrincipal(principal: PolicyPrincipal): PolicyStatement;
addAwsPrincipal(arn: Arn): PolicyStatement;
addAwsPrincipal(arn: string): PolicyStatement;
addAwsAccountPrincipal(accountId: string): PolicyStatement;

@@ -139,3 +138,3 @@ addServicePrincipal(service: string): PolicyStatement;

addAccountRootPrincipal(): PolicyStatement;
addResource(resource: Arn): PolicyStatement;
addResource(arn: string): PolicyStatement;
/**

@@ -145,3 +144,3 @@ * Adds a ``"*"`` resource to this statement.

addAllResources(): PolicyStatement;
addResources(...resources: Arn[]): PolicyStatement;
addResources(...arns: string[]): PolicyStatement;
/**

@@ -148,0 +147,0 @@ * Indicates if this permission as at least one resource associated with it.

"use strict";
Object.defineProperty(exports, "__esModule", { value: true });
const tokens_1 = require("../core/tokens");
const arn_1 = require("./arn");
const fn_1 = require("./fn");
const pseudo_1 = require("./pseudo");

@@ -81,3 +79,3 @@ class PolicyDocument extends tokens_1.Token {

constructor(accountId) {
super(new arn_1.Arn(new fn_1.FnConcat('arn:', new pseudo_1.AwsPartition(), ':iam::', accountId, ':root')));
super(`arn:${new pseudo_1.AwsPartition()}:iam::${accountId}:root`);
this.accountId = accountId;

@@ -217,4 +215,4 @@ }

//
addResource(resource) {
this.resource.push(resource);
addResource(arn) {
this.resource.push(arn);
return this;

@@ -226,6 +224,6 @@ }

addAllResources() {
return this.addResource(new arn_1.Arn('*'));
return this.addResource('*');
}
addResources(...resources) {
resources.forEach(r => this.addResource(r));
addResources(...arns) {
arns.forEach(r => this.addResource(r));
return this;

@@ -335,2 +333,2 @@ }

})(PolicyStatementEffect = exports.PolicyStatementEffect || (exports.PolicyStatementEffect = {}));
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"permission.js","sourceRoot":"","sources":["permission.ts"],"names":[],"mappings":"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","sourcesContent":["import { Token } from '../core/tokens';\nimport { Arn } from './arn';\nimport { FnConcat } from './fn';\nimport { AwsAccountId, AwsPartition } from './pseudo';\n\nexport class PolicyDocument extends Token {\n    private statements = new Array<PolicyStatement>();\n\n    /**\n     * Creates a new IAM policy document.\n     * @param defaultDocument An IAM policy document to use as an initial\n     * policy. All statements of this document will be copied in.\n     */\n    constructor(private readonly baseDocument?: any) {\n        super();\n    }\n\n    public resolve(): any {\n        if (this.isEmpty) {\n            return undefined;\n        }\n\n        const doc = this.baseDocument || { };\n        doc.Statement = doc.Statement || [ ];\n        doc.Version = doc.Version || '2012-10-17';\n        doc.Statement = doc.Statement.concat(this.statements);\n        return doc;\n    }\n\n    get isEmpty(): boolean {\n        return this.statements.length === 0;\n    }\n\n    /**\n     * The number of statements already added to this policy.\n     * Can be used, for example, to generate uniuqe \"sid\"s within the policy.\n     */\n    get statementCount(): number {\n        return this.statements.length;\n    }\n\n    public addStatement(statement: PolicyStatement): PolicyDocument {\n        this.statements.push(statement);\n        return this;\n    }\n}\n\n/**\n * Represents an IAM principal.\n */\nexport abstract class PolicyPrincipal {\n    /**\n     * When this Principal is used in an AssumeRole policy, the action to use.\n     */\n    public readonly assumeRoleAction: string = 'sts:AssumeRole';\n\n    /**\n     * Return the policy fragment that identifies this principal in a Policy.\n     */\n    public abstract policyFragment(): PrincipalPolicyFragment;\n}\n\n/**\n * A collection of the fields in a PolicyStatement that can be used to identify a principal.\n *\n * This consists of the JSON used in the \"Principal\" field, and optionally a\n * set of \"Condition\"s that need to be applied to the policy.\n */\nexport class PrincipalPolicyFragment {\n    constructor(\n        public readonly principalJson: any,\n        public readonly conditions: {[key: string]: any} = {}) {\n    }\n}\n\nexport class ArnPrincipal extends PolicyPrincipal {\n    constructor(public readonly arn: Arn) {\n        super();\n    }\n\n    public policyFragment(): PrincipalPolicyFragment {\n        return new PrincipalPolicyFragment({ AWS: this.arn });\n    }\n}\n\nexport class AccountPrincipal extends ArnPrincipal {\n    constructor(public readonly accountId: any) {\n        super(new Arn(new FnConcat('arn:', new AwsPartition(), ':iam::', accountId, ':root')));\n    }\n}\n\n/**\n * An IAM principal that represents an AWS service (i.e. sqs.amazonaws.com).\n */\nexport class ServicePrincipal extends PolicyPrincipal {\n    constructor(public readonly service: string) {\n        super();\n    }\n\n    public policyFragment(): PrincipalPolicyFragment {\n        return new PrincipalPolicyFragment({ Service: this.service });\n    }\n}\n\n/**\n * A policy prinicipal for canonicalUserIds - useful for S3 bucket policies that use\n * Origin Access identities.\n *\n * See https://docs.aws.amazon.com/general/latest/gr/acct-identifiers.html\n *\n * and\n *\n * https://docs.aws.amazon.com/AmazonCloudFront/latest/DeveloperGuide/private-content-restricting-access-to-s3.html\n *\n * for more details.\n *\n */\nexport class CanonicalUserPrincipal extends PolicyPrincipal {\n    constructor(public readonly canonicalUserId: any) {\n        super();\n    }\n\n    public policyFragment(): PrincipalPolicyFragment {\n        return new PrincipalPolicyFragment({ CanonicalUser: this.canonicalUserId });\n    }\n}\n\nexport class FederatedPrincipal extends PolicyPrincipal {\n    constructor(\n        public readonly federated: any,\n        public readonly conditions: {[key: string]: any},\n        public readonly assumeRoleAction: string = 'sts:AssumeRole') {\n        super();\n    }\n\n    public policyFragment(): PrincipalPolicyFragment {\n        return new PrincipalPolicyFragment({ Federated: this.federated }, this.conditions);\n    }\n}\n\nexport class AccountRootPrincipal extends AccountPrincipal {\n    constructor() {\n        super(new AwsAccountId());\n    }\n}\n\n/**\n * A principal representing all identities in all accounts\n */\nexport class Anyone extends PolicyPrincipal {\n    /**\n     * Interface compatibility with AccountPrincipal for the purposes of the Lambda library\n     *\n     * The Lambda's addPermission() call works differently from regular\n     * statements, and will use the value of this property directly if present\n     * (which leads to the correct statement ultimately).\n     */\n    public readonly accountId = '*';\n\n    public policyFragment(): PrincipalPolicyFragment {\n        return new PrincipalPolicyFragment('*');\n    }\n}\n\n/**\n * Represents a statement in an IAM policy document.\n */\nexport class PolicyStatement extends Token {\n    private action = new Array<any>();\n    private principal = new Array<any>();\n    private resource = new Array<any>();\n    private condition: { [key: string]: any } = { };\n    private effect?: PolicyStatementEffect;\n    private sid?: any;\n\n    constructor(effect: PolicyStatementEffect = PolicyStatementEffect.Allow) {\n        super();\n        this.effect = effect;\n    }\n\n    //\n    // Actions\n    //\n\n    public addAction(action: string): PolicyStatement {\n        this.action.push(action);\n        return this;\n    }\n\n    public addActions(...actions: string[]): PolicyStatement {\n        actions.forEach(action => this.addAction(action));\n        return this;\n    }\n\n    //\n    // Principal\n    //\n\n    /**\n     * Indicates if this permission has a \"Principal\" section.\n     */\n    public get hasPrincipal() {\n        return this.principal && this.principal.length > 0;\n    }\n\n    public addPrincipal(principal: PolicyPrincipal): PolicyStatement {\n        const fragment = principal.policyFragment();\n        this.principal.push(fragment.principalJson);\n        this.addConditions(fragment.conditions);\n        return this;\n    }\n\n    public addAwsPrincipal(arn: Arn): PolicyStatement {\n        return this.addPrincipal(new ArnPrincipal(arn));\n    }\n\n    public addAwsAccountPrincipal(accountId: string): PolicyStatement {\n        return this.addPrincipal(new AccountPrincipal(accountId));\n    }\n\n    public addServicePrincipal(service: string): PolicyStatement {\n        return this.addPrincipal(new ServicePrincipal(service));\n    }\n\n    public addFederatedPrincipal(federated: any, conditions: {[key: string]: any}): PolicyStatement {\n        return this.addPrincipal(new FederatedPrincipal(federated, conditions));\n    }\n\n    public addAccountRootPrincipal(): PolicyStatement {\n        return this.addPrincipal(new AccountRootPrincipal());\n    }\n\n    //\n    // Resources\n    //\n\n    public addResource(resource: Arn): PolicyStatement {\n        this.resource.push(resource);\n        return this;\n    }\n\n    /**\n     * Adds a ``\"*\"`` resource to this statement.\n     */\n    public addAllResources(): PolicyStatement {\n        return this.addResource(new Arn('*'));\n    }\n\n    public addResources(...resources: Arn[]): PolicyStatement {\n        resources.forEach(r => this.addResource(r));\n        return this;\n    }\n\n    /**\n     * Indicates if this permission as at least one resource associated with it.\n     */\n    public get hasResource() {\n        return this.resource && this.resource.length > 0;\n    }\n\n    public describe(sid: string): PolicyStatement {\n        this.sid = sid;\n        return this;\n    }\n\n    //\n    // Effect\n    //\n\n    /**\n     * Sets the permission effect to deny access to resources.\n     */\n    public allow(): PolicyStatement {\n        this.effect = PolicyStatementEffect.Allow;\n        return this;\n    }\n\n    /**\n     * Sets the permission effect to allow access to resources.\n     */\n    public deny(): PolicyStatement {\n        this.effect = PolicyStatementEffect.Deny;\n        return this;\n    }\n\n    //\n    // Condition\n    //\n\n    /**\n     * Add a condition to the Policy\n     */\n    public addCondition(key: string, value: any): PolicyStatement {\n        this.condition[key] = value;\n        return this;\n    }\n\n    /**\n     * Add multiple conditions to the Policy\n     */\n    public addConditions(conditions: {[key: string]: any}): PolicyStatement {\n        Object.keys(conditions).map(key => {\n            this.addCondition(key, conditions[key]);\n        });\n        return this;\n    }\n\n    /**\n     * Add a condition to the Policy.\n     *\n     * @deprecated For backwards compatibility. Use addCondition() instead.\n     */\n    public setCondition(key: string, value: any): PolicyStatement {\n        return this.addCondition(key, value);\n    }\n\n    public limitToAccount(accountId: string): PolicyStatement {\n        return this.addCondition('StringEquals', new Token(() => {\n            return { 'sts:ExternalId': accountId };\n        }));\n    }\n\n    //\n    // Serialization\n    //\n\n    public resolve(): any {\n        return this.toJson();\n    }\n\n    public toJson(): any {\n        return {\n            Action: _norm(this.action),\n            Condition: _norm(this.condition),\n            Effect: _norm(this.effect),\n            Principal: _norm(this.principal),\n            Resource: _norm(this.resource),\n            Sid: _norm(this.sid),\n        };\n\n        function _norm(values: any) {\n\n            if (typeof(values) === 'undefined') {\n                return undefined;\n            }\n\n            if (Array.isArray(values)) {\n                if (!values || values.length === 0) {\n                    return undefined;\n                }\n\n                if (values.length === 1) {\n                    return values[0];\n                }\n\n                return values;\n            }\n\n            if (typeof(values) === 'object') {\n                if (Object.keys(values).length === 0) {\n                    return undefined;\n                }\n            }\n\n            return values;\n        }\n    }\n}\n\nexport enum PolicyStatementEffect {\n    Allow = 'Allow',\n    Deny = 'Deny',\n}\n"]}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"permission.js","sourceRoot":"","sources":["permission.ts"],"names":[],"mappings":"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","sourcesContent":["import { Token } from '../core/tokens';\nimport { AwsAccountId, AwsPartition } from './pseudo';\n\nexport class PolicyDocument extends Token {\n    private statements = new Array<PolicyStatement>();\n\n    /**\n     * Creates a new IAM policy document.\n     * @param defaultDocument An IAM policy document to use as an initial\n     * policy. All statements of this document will be copied in.\n     */\n    constructor(private readonly baseDocument?: any) {\n        super();\n    }\n\n    public resolve(): any {\n        if (this.isEmpty) {\n            return undefined;\n        }\n\n        const doc = this.baseDocument || { };\n        doc.Statement = doc.Statement || [ ];\n        doc.Version = doc.Version || '2012-10-17';\n        doc.Statement = doc.Statement.concat(this.statements);\n        return doc;\n    }\n\n    get isEmpty(): boolean {\n        return this.statements.length === 0;\n    }\n\n    /**\n     * The number of statements already added to this policy.\n     * Can be used, for example, to generate uniuqe \"sid\"s within the policy.\n     */\n    get statementCount(): number {\n        return this.statements.length;\n    }\n\n    public addStatement(statement: PolicyStatement): PolicyDocument {\n        this.statements.push(statement);\n        return this;\n    }\n}\n\n/**\n * Represents an IAM principal.\n */\nexport abstract class PolicyPrincipal {\n    /**\n     * When this Principal is used in an AssumeRole policy, the action to use.\n     */\n    public readonly assumeRoleAction: string = 'sts:AssumeRole';\n\n    /**\n     * Return the policy fragment that identifies this principal in a Policy.\n     */\n    public abstract policyFragment(): PrincipalPolicyFragment;\n}\n\n/**\n * A collection of the fields in a PolicyStatement that can be used to identify a principal.\n *\n * This consists of the JSON used in the \"Principal\" field, and optionally a\n * set of \"Condition\"s that need to be applied to the policy.\n */\nexport class PrincipalPolicyFragment {\n    constructor(\n        public readonly principalJson: any,\n        public readonly conditions: {[key: string]: any} = {}) {\n    }\n}\n\nexport class ArnPrincipal extends PolicyPrincipal {\n    constructor(public readonly arn: string) {\n        super();\n    }\n\n    public policyFragment(): PrincipalPolicyFragment {\n        return new PrincipalPolicyFragment({ AWS: this.arn });\n    }\n}\n\nexport class AccountPrincipal extends ArnPrincipal {\n    constructor(public readonly accountId: any) {\n        super(`arn:${new AwsPartition()}:iam::${accountId}:root`);\n    }\n}\n\n/**\n * An IAM principal that represents an AWS service (i.e. sqs.amazonaws.com).\n */\nexport class ServicePrincipal extends PolicyPrincipal {\n    constructor(public readonly service: string) {\n        super();\n    }\n\n    public policyFragment(): PrincipalPolicyFragment {\n        return new PrincipalPolicyFragment({ Service: this.service });\n    }\n}\n\n/**\n * A policy prinicipal for canonicalUserIds - useful for S3 bucket policies that use\n * Origin Access identities.\n *\n * See https://docs.aws.amazon.com/general/latest/gr/acct-identifiers.html\n *\n * and\n *\n * https://docs.aws.amazon.com/AmazonCloudFront/latest/DeveloperGuide/private-content-restricting-access-to-s3.html\n *\n * for more details.\n *\n */\nexport class CanonicalUserPrincipal extends PolicyPrincipal {\n    constructor(public readonly canonicalUserId: any) {\n        super();\n    }\n\n    public policyFragment(): PrincipalPolicyFragment {\n        return new PrincipalPolicyFragment({ CanonicalUser: this.canonicalUserId });\n    }\n}\n\nexport class FederatedPrincipal extends PolicyPrincipal {\n    constructor(\n        public readonly federated: any,\n        public readonly conditions: {[key: string]: any},\n        public readonly assumeRoleAction: string = 'sts:AssumeRole') {\n        super();\n    }\n\n    public policyFragment(): PrincipalPolicyFragment {\n        return new PrincipalPolicyFragment({ Federated: this.federated }, this.conditions);\n    }\n}\n\nexport class AccountRootPrincipal extends AccountPrincipal {\n    constructor() {\n        super(new AwsAccountId());\n    }\n}\n\n/**\n * A principal representing all identities in all accounts\n */\nexport class Anyone extends PolicyPrincipal {\n    /**\n     * Interface compatibility with AccountPrincipal for the purposes of the Lambda library\n     *\n     * The Lambda's addPermission() call works differently from regular\n     * statements, and will use the value of this property directly if present\n     * (which leads to the correct statement ultimately).\n     */\n    public readonly accountId = '*';\n\n    public policyFragment(): PrincipalPolicyFragment {\n        return new PrincipalPolicyFragment('*');\n    }\n}\n\n/**\n * Represents a statement in an IAM policy document.\n */\nexport class PolicyStatement extends Token {\n    private action = new Array<any>();\n    private principal = new Array<any>();\n    private resource = new Array<any>();\n    private condition: { [key: string]: any } = { };\n    private effect?: PolicyStatementEffect;\n    private sid?: any;\n\n    constructor(effect: PolicyStatementEffect = PolicyStatementEffect.Allow) {\n        super();\n        this.effect = effect;\n    }\n\n    //\n    // Actions\n    //\n\n    public addAction(action: string): PolicyStatement {\n        this.action.push(action);\n        return this;\n    }\n\n    public addActions(...actions: string[]): PolicyStatement {\n        actions.forEach(action => this.addAction(action));\n        return this;\n    }\n\n    //\n    // Principal\n    //\n\n    /**\n     * Indicates if this permission has a \"Principal\" section.\n     */\n    public get hasPrincipal() {\n        return this.principal && this.principal.length > 0;\n    }\n\n    public addPrincipal(principal: PolicyPrincipal): PolicyStatement {\n        const fragment = principal.policyFragment();\n        this.principal.push(fragment.principalJson);\n        this.addConditions(fragment.conditions);\n        return this;\n    }\n\n    public addAwsPrincipal(arn: string): PolicyStatement {\n        return this.addPrincipal(new ArnPrincipal(arn));\n    }\n\n    public addAwsAccountPrincipal(accountId: string): PolicyStatement {\n        return this.addPrincipal(new AccountPrincipal(accountId));\n    }\n\n    public addServicePrincipal(service: string): PolicyStatement {\n        return this.addPrincipal(new ServicePrincipal(service));\n    }\n\n    public addFederatedPrincipal(federated: any, conditions: {[key: string]: any}): PolicyStatement {\n        return this.addPrincipal(new FederatedPrincipal(federated, conditions));\n    }\n\n    public addAccountRootPrincipal(): PolicyStatement {\n        return this.addPrincipal(new AccountRootPrincipal());\n    }\n\n    //\n    // Resources\n    //\n\n    public addResource(arn: string): PolicyStatement {\n        this.resource.push(arn);\n        return this;\n    }\n\n    /**\n     * Adds a ``\"*\"`` resource to this statement.\n     */\n    public addAllResources(): PolicyStatement {\n        return this.addResource('*');\n    }\n\n    public addResources(...arns: string[]): PolicyStatement {\n        arns.forEach(r => this.addResource(r));\n        return this;\n    }\n\n    /**\n     * Indicates if this permission as at least one resource associated with it.\n     */\n    public get hasResource() {\n        return this.resource && this.resource.length > 0;\n    }\n\n    public describe(sid: string): PolicyStatement {\n        this.sid = sid;\n        return this;\n    }\n\n    //\n    // Effect\n    //\n\n    /**\n     * Sets the permission effect to deny access to resources.\n     */\n    public allow(): PolicyStatement {\n        this.effect = PolicyStatementEffect.Allow;\n        return this;\n    }\n\n    /**\n     * Sets the permission effect to allow access to resources.\n     */\n    public deny(): PolicyStatement {\n        this.effect = PolicyStatementEffect.Deny;\n        return this;\n    }\n\n    //\n    // Condition\n    //\n\n    /**\n     * Add a condition to the Policy\n     */\n    public addCondition(key: string, value: any): PolicyStatement {\n        this.condition[key] = value;\n        return this;\n    }\n\n    /**\n     * Add multiple conditions to the Policy\n     */\n    public addConditions(conditions: {[key: string]: any}): PolicyStatement {\n        Object.keys(conditions).map(key => {\n            this.addCondition(key, conditions[key]);\n        });\n        return this;\n    }\n\n    /**\n     * Add a condition to the Policy.\n     *\n     * @deprecated For backwards compatibility. Use addCondition() instead.\n     */\n    public setCondition(key: string, value: any): PolicyStatement {\n        return this.addCondition(key, value);\n    }\n\n    public limitToAccount(accountId: string): PolicyStatement {\n        return this.addCondition('StringEquals', new Token(() => {\n            return { 'sts:ExternalId': accountId };\n        }));\n    }\n\n    //\n    // Serialization\n    //\n\n    public resolve(): any {\n        return this.toJson();\n    }\n\n    public toJson(): any {\n        return {\n            Action: _norm(this.action),\n            Condition: _norm(this.condition),\n            Effect: _norm(this.effect),\n            Principal: _norm(this.principal),\n            Resource: _norm(this.resource),\n            Sid: _norm(this.sid),\n        };\n\n        function _norm(values: any) {\n\n            if (typeof(values) === 'undefined') {\n                return undefined;\n            }\n\n            if (Array.isArray(values)) {\n                if (!values || values.length === 0) {\n                    return undefined;\n                }\n\n                if (values.length === 1) {\n                    return values[0];\n                }\n\n                return values;\n            }\n\n            if (typeof(values) === 'object') {\n                if (Object.keys(values).length === 0) {\n                    return undefined;\n                }\n            }\n\n            return values;\n        }\n    }\n}\n\nexport enum PolicyStatementEffect {\n    Allow = 'Allow',\n    Deny = 'Deny',\n}\n"]}
import { Construct } from '../core/construct';
import { Token } from '../core/tokens';
import { CloudFormationToken } from './cloudformation-token';
import { Condition } from './condition';
import { CreationPolicy, DeletionPolicy, UpdatePolicy } from './resource-policy';
import { IDependable, StackElement } from './stack';
import { IDependable, Referenceable } from './stack';
export interface ResourceProps {

@@ -19,3 +19,3 @@ /**

*/
export declare class Resource extends StackElement {
export declare class Resource extends Referenceable {
/**

@@ -51,3 +51,3 @@ * A decoration used to create a CloudFormation attribute property.

*/
getAtt(attributeName: string): Token;
getAtt(attributeName: string): CloudFormationToken;
/**

@@ -54,0 +54,0 @@ * Adds a dependency on another resource.

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

*/
class Resource extends stack_1.StackElement {
class Resource extends stack_1.Referenceable {
/**

@@ -123,2 +123,2 @@ * Creates a resource construct.

exports.Resource = Resource;
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"resource.js","sourceRoot":"","sources":["resource.ts"],"names":[],"mappings":"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","sourcesContent":["import { Construct } from '../core/construct';\nimport { Token } from '../core/tokens';\nimport { capitalizePropertyNames, ignoreEmpty } from '../core/util';\nimport { CloudFormationToken } from './cloudformation-token';\nimport { Condition } from './condition';\nimport { CreationPolicy, DeletionPolicy, UpdatePolicy } from './resource-policy';\nimport { IDependable, StackElement } from './stack';\n\nexport interface ResourceProps {\n    /**\n     * CloudFormation resource type.\n     */\n    type: string;\n\n    /**\n     * CloudFormation properties.\n     */\n    properties?: any;\n}\n\n/**\n * Represents a CloudFormation resource.\n */\nexport class Resource extends StackElement {\n    /**\n     * A decoration used to create a CloudFormation attribute property.\n     * @param customName Custom name for the attribute (default is the name of the property)\n     * NOTE: we return \"any\" here to satistfy jsii, which doesn't support lambdas.\n     */\n    public static attribute(customName?: string): any {\n        return (prototype: any, key: string) => {\n            const name = customName || key;\n            Object.defineProperty(prototype, key, {\n                get() {\n                    return (this as any).getAtt(name);\n                }\n            });\n        };\n    }\n\n    /**\n     * Options for this resource, such as condition, update policy etc.\n     */\n    public readonly options: ResourceOptions = {};\n\n    /**\n     * AWS resource type.\n     */\n    public readonly resourceType: string;\n\n    /**\n     * AWS resource properties\n     */\n    protected readonly properties: any;\n\n    private dependsOn = new Array<IDependable>();\n\n    /**\n     * Creates a resource construct.\n     * @param resourceType The CloudFormation type of this resource (e.g. AWS::DynamoDB::Table)\n     */\n    constructor(parent: Construct, name: string, props: ResourceProps) {\n        super(parent, name);\n\n        if (!props.type) {\n            throw new Error('The `type` property is required');\n        }\n\n        this.resourceType = props.type;\n        this.properties = props.properties || { };\n\n        // 'name' is a special property included for resource constructs and passed\n        // as 'name', but we don't want it to be serialized into the template.\n        if (this.properties.name) {\n            delete this.properties.name;\n        }\n    }\n\n    /**\n     * Returns a token for an runtime attribute of this resource.\n     * Ideally, use generated attribute accessors (e.g. `resource.arn`), but this can be used for future compatibility\n     * in case there is no generated attribute.\n     * @param attributeName The name of the attribute.\n     */\n    public getAtt(attributeName: string): Token {\n        return new CloudFormationToken({ 'Fn::GetAtt': [this.logicalId, attributeName] }, `${this.logicalId}.${attributeName}`);\n    }\n\n    /**\n     * Adds a dependency on another resource.\n     * @param other The other resource.\n     */\n    public addDependency(...other: IDependable[]) {\n        this.dependsOn.push(...other);\n    }\n\n    /**\n     * Emits CloudFormation for this resource.\n     */\n    public toCloudFormation(): object {\n        try {\n            return {\n                Resources: {\n                    [this.logicalId]: {\n                        Type: this.resourceType,\n                        Properties: ignoreEmpty(this.renderProperties()),\n                        DependsOn: ignoreEmpty(this.renderDependsOn()),\n                        CreationPolicy:  capitalizePropertyNames(this.options.creationPolicy),\n                        UpdatePolicy: capitalizePropertyNames(this.options.updatePolicy),\n                        DeletionPolicy: capitalizePropertyNames(this.options.deletionPolicy),\n                        Metadata: ignoreEmpty(this.options.metadata),\n                        Condition: this.options.condition && this.options.condition.logicalId\n                    }\n                }\n            };\n        } catch (e) {\n            // Change message\n            e.message = `While synthesizing ${this.path}: ${e.message}`;\n            // Adjust stack trace (make it look like node built it, too...)\n            const creationStack = ['--- resource created at ---', ...this.creationStackTrace].join('\\n    at ');\n            const problemTrace = e.stack.substr(e.stack.indexOf(e.message) + e.message.length);\n            e.stack = `${e.message}\\n    ${creationStack}\\n    --- problem discovered at ---${problemTrace}`;\n            // Re-throw\n            throw e;\n        }\n    }\n\n    protected renderProperties(): { [key: string]: any } {\n        // FIXME: default implementation is not great, it should throw, but it avoids breaking all unit tests for now.\n        return this.properties;\n    }\n\n    private renderDependsOn() {\n        const logicalIDs = new Set<string>();\n        for (const d of this.dependsOn) {\n            addDependency(d);\n        }\n\n        return Array.from(logicalIDs);\n\n        function addDependency(d: IDependable) {\n            d.dependencyElements.forEach(dep => {\n                const logicalId = (dep as StackElement).logicalId;\n                if (logicalId) {\n                    logicalIDs.add(logicalId);\n                }\n            });\n\n            // break if dependencyElements include only 'd', which means we reached a terminal.\n            if (d.dependencyElements.length === 1 && d.dependencyElements[0] === d) {\n                return;\n            } else {\n                d.dependencyElements.forEach(dep => addDependency(dep));\n            }\n        }\n    }\n}\n\nexport interface ResourceOptions {\n    /**\n     * A condition to associate with this resource. This means that only if the condition evaluates to 'true' when the stack\n     * is deployed, the resource will be included. This is provided to allow CDK projects to produce legacy templates, but noramlly\n     * there is no need to use it in CDK projects.\n     */\n    condition?: Condition;\n\n    /**\n     * Associate the CreationPolicy attribute with a resource to prevent its status from reaching create complete until\n     * AWS CloudFormation receives a specified number of success signals or the timeout period is exceeded. To signal a\n     * resource, you can use the cfn-signal helper script or SignalResource API. AWS CloudFormation publishes valid signals\n     * to the stack events so that you track the number of signals sent.\n     */\n    creationPolicy?: CreationPolicy;\n\n    /**\n     * With the DeletionPolicy attribute you can preserve or (in some cases) backup a resource when its stack is deleted.\n     * You specify a DeletionPolicy attribute for each resource that you want to control. If a resource has no DeletionPolicy\n     * attribute, AWS CloudFormation deletes the resource by default. Note that this capability also applies to update operations\n     * that lead to resources being removed.\n     */\n    deletionPolicy?: DeletionPolicy;\n\n    /**\n     * Use the UpdatePolicy attribute to specify how AWS CloudFormation handles updates to the AWS::AutoScaling::AutoScalingGroup\n     * resource. AWS CloudFormation invokes one of three update policies depending on the type of change you make or whether a\n     * scheduled action is associated with the Auto Scaling group.\n     */\n    updatePolicy?: UpdatePolicy;\n\n    /**\n     * Metadata associated with the CloudFormation resource. This is not the same as the construct metadata which can be added\n     * using construct.addMetadata(), but would not appear in the CloudFormation template automatically.\n     */\n    metadata?: { [key: string]: any };\n}\n"]}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"resource.js","sourceRoot":"","sources":["resource.ts"],"names":[],"mappings":"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","sourcesContent":["import { Construct } from '../core/construct';\nimport { capitalizePropertyNames, ignoreEmpty } from '../core/util';\nimport { CloudFormationToken } from './cloudformation-token';\nimport { Condition } from './condition';\nimport { CreationPolicy, DeletionPolicy, UpdatePolicy } from './resource-policy';\nimport { IDependable, Referenceable, StackElement } from './stack';\n\nexport interface ResourceProps {\n    /**\n     * CloudFormation resource type.\n     */\n    type: string;\n\n    /**\n     * CloudFormation properties.\n     */\n    properties?: any;\n}\n\n/**\n * Represents a CloudFormation resource.\n */\nexport class Resource extends Referenceable {\n    /**\n     * A decoration used to create a CloudFormation attribute property.\n     * @param customName Custom name for the attribute (default is the name of the property)\n     * NOTE: we return \"any\" here to satistfy jsii, which doesn't support lambdas.\n     */\n    public static attribute(customName?: string): any {\n        return (prototype: any, key: string) => {\n            const name = customName || key;\n            Object.defineProperty(prototype, key, {\n                get() {\n                    return (this as any).getAtt(name);\n                }\n            });\n        };\n    }\n\n    /**\n     * Options for this resource, such as condition, update policy etc.\n     */\n    public readonly options: ResourceOptions = {};\n\n    /**\n     * AWS resource type.\n     */\n    public readonly resourceType: string;\n\n    /**\n     * AWS resource properties\n     */\n    protected readonly properties: any;\n\n    private dependsOn = new Array<IDependable>();\n\n    /**\n     * Creates a resource construct.\n     * @param resourceType The CloudFormation type of this resource (e.g. AWS::DynamoDB::Table)\n     */\n    constructor(parent: Construct, name: string, props: ResourceProps) {\n        super(parent, name);\n\n        if (!props.type) {\n            throw new Error('The `type` property is required');\n        }\n\n        this.resourceType = props.type;\n        this.properties = props.properties || { };\n\n        // 'name' is a special property included for resource constructs and passed\n        // as 'name', but we don't want it to be serialized into the template.\n        if (this.properties.name) {\n            delete this.properties.name;\n        }\n    }\n\n    /**\n     * Returns a token for an runtime attribute of this resource.\n     * Ideally, use generated attribute accessors (e.g. `resource.arn`), but this can be used for future compatibility\n     * in case there is no generated attribute.\n     * @param attributeName The name of the attribute.\n     */\n    public getAtt(attributeName: string) {\n        return new CloudFormationToken({ 'Fn::GetAtt': [this.logicalId, attributeName] }, `${this.logicalId}.${attributeName}`);\n    }\n\n    /**\n     * Adds a dependency on another resource.\n     * @param other The other resource.\n     */\n    public addDependency(...other: IDependable[]) {\n        this.dependsOn.push(...other);\n    }\n\n    /**\n     * Emits CloudFormation for this resource.\n     */\n    public toCloudFormation(): object {\n        try {\n            return {\n                Resources: {\n                    [this.logicalId]: {\n                        Type: this.resourceType,\n                        Properties: ignoreEmpty(this.renderProperties()),\n                        DependsOn: ignoreEmpty(this.renderDependsOn()),\n                        CreationPolicy:  capitalizePropertyNames(this.options.creationPolicy),\n                        UpdatePolicy: capitalizePropertyNames(this.options.updatePolicy),\n                        DeletionPolicy: capitalizePropertyNames(this.options.deletionPolicy),\n                        Metadata: ignoreEmpty(this.options.metadata),\n                        Condition: this.options.condition && this.options.condition.logicalId\n                    }\n                }\n            };\n        } catch (e) {\n            // Change message\n            e.message = `While synthesizing ${this.path}: ${e.message}`;\n            // Adjust stack trace (make it look like node built it, too...)\n            const creationStack = ['--- resource created at ---', ...this.creationStackTrace].join('\\n    at ');\n            const problemTrace = e.stack.substr(e.stack.indexOf(e.message) + e.message.length);\n            e.stack = `${e.message}\\n    ${creationStack}\\n    --- problem discovered at ---${problemTrace}`;\n            // Re-throw\n            throw e;\n        }\n    }\n\n    protected renderProperties(): { [key: string]: any } {\n        // FIXME: default implementation is not great, it should throw, but it avoids breaking all unit tests for now.\n        return this.properties;\n    }\n\n    private renderDependsOn() {\n        const logicalIDs = new Set<string>();\n        for (const d of this.dependsOn) {\n            addDependency(d);\n        }\n\n        return Array.from(logicalIDs);\n\n        function addDependency(d: IDependable) {\n            d.dependencyElements.forEach(dep => {\n                const logicalId = (dep as StackElement).logicalId;\n                if (logicalId) {\n                    logicalIDs.add(logicalId);\n                }\n            });\n\n            // break if dependencyElements include only 'd', which means we reached a terminal.\n            if (d.dependencyElements.length === 1 && d.dependencyElements[0] === d) {\n                return;\n            } else {\n                d.dependencyElements.forEach(dep => addDependency(dep));\n            }\n        }\n    }\n}\n\nexport interface ResourceOptions {\n    /**\n     * A condition to associate with this resource. This means that only if the condition evaluates to 'true' when the stack\n     * is deployed, the resource will be included. This is provided to allow CDK projects to produce legacy templates, but noramlly\n     * there is no need to use it in CDK projects.\n     */\n    condition?: Condition;\n\n    /**\n     * Associate the CreationPolicy attribute with a resource to prevent its status from reaching create complete until\n     * AWS CloudFormation receives a specified number of success signals or the timeout period is exceeded. To signal a\n     * resource, you can use the cfn-signal helper script or SignalResource API. AWS CloudFormation publishes valid signals\n     * to the stack events so that you track the number of signals sent.\n     */\n    creationPolicy?: CreationPolicy;\n\n    /**\n     * With the DeletionPolicy attribute you can preserve or (in some cases) backup a resource when its stack is deleted.\n     * You specify a DeletionPolicy attribute for each resource that you want to control. If a resource has no DeletionPolicy\n     * attribute, AWS CloudFormation deletes the resource by default. Note that this capability also applies to update operations\n     * that lead to resources being removed.\n     */\n    deletionPolicy?: DeletionPolicy;\n\n    /**\n     * Use the UpdatePolicy attribute to specify how AWS CloudFormation handles updates to the AWS::AutoScaling::AutoScalingGroup\n     * resource. AWS CloudFormation invokes one of three update policies depending on the type of change you make or whether a\n     * scheduled action is associated with the Auto Scaling group.\n     */\n    updatePolicy?: UpdatePolicy;\n\n    /**\n     * Metadata associated with the CloudFormation resource. This is not the same as the construct metadata which can be added\n     * using construct.addMetadata(), but would not appear in the CloudFormation template automatically.\n     */\n    metadata?: { [key: string]: any };\n}\n"]}

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

import { Construct } from "../core/construct";
import { Construct } from '../core/construct';
import { Token } from '../core/tokens';

@@ -3,0 +3,0 @@ /**

@@ -46,6 +46,6 @@ "use strict";

});
this.value = param.ref;
this.value = new Secret(param.ref);
}
}
exports.SecretParameter = SecretParameter;
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic2VjcmV0LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsic2VjcmV0LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7O0FBQUEsaURBQThDO0FBQzlDLDJDQUF1QztBQUN2QywyQ0FBd0M7QUFFeEM7Ozs7Ozs7OztHQVNHO0FBQ0gsTUFBYSxNQUFPLFNBQVEsY0FBSztDQUVoQztBQUZELHdCQUVDO0FBMkNEOzs7Ozs7Ozs7Ozs7R0FZRztBQUNILE1BQWEsZUFBZ0IsU0FBUSxxQkFBUztJQU0xQyxZQUFZLE1BQWlCLEVBQUUsSUFBWSxFQUFFLEtBQWtCO1FBQzNELEtBQUssQ0FBQyxNQUFNLEVBQUUsSUFBSSxDQUFDLENBQUM7UUFFcEIsTUFBTSxLQUFLLEdBQUcsSUFBSSxxQkFBUyxDQUFDLElBQUksRUFBRSxXQUFXLEVBQUU7WUFDM0MsSUFBSSxFQUFFLG9DQUFvQztZQUMxQyxPQUFPLEVBQUUsS0FBSyxDQUFDLFlBQVk7WUFDM0IsV0FBVyxFQUFFLEtBQUssQ0FBQyxXQUFXO1lBQzlCLGNBQWMsRUFBRSxLQUFLLENBQUMsY0FBYztZQUNwQyxhQUFhLEVBQUUsS0FBSyxDQUFDLGFBQWE7WUFDbEMscUJBQXFCLEVBQUUsS0FBSyxDQUFDLHFCQUFxQjtZQUNsRCxTQUFTLEVBQUUsS0FBSyxDQUFDLFNBQVM7WUFDMUIsU0FBUyxFQUFFLEtBQUssQ0FBQyxTQUFTO1lBQzFCLE1BQU0sRUFBRSxJQUFJO1NBQ2YsQ0FBQyxDQUFDO1FBRUgsSUFBSSxDQUFDLEtBQUssR0FBRyxLQUFLLENBQUMsR0FBRyxDQUFDO0lBQzNCLENBQUM7Q0FDSjtBQXZCRCwwQ0F1QkMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBDb25zdHJ1Y3QgfSBmcm9tIFwiLi4vY29yZS9jb25zdHJ1Y3RcIjtcbmltcG9ydCB7IFRva2VuIH0gZnJvbSAnLi4vY29yZS90b2tlbnMnO1xuaW1wb3J0IHsgUGFyYW1ldGVyIH0gZnJvbSAnLi9wYXJhbWV0ZXInO1xuXG4vKipcbiAqIEEgdG9rZW4gdGhhdCByZXByZXNlbnRzIGEgdmFsdWUgdGhhdCdzIGV4cGVjdGVkIHRvIGJlIGEgc2VjcmV0LCBsaWtlXG4gKiBwYXNzd29yZHMgYW5kIGtleXMuXG4gKlxuICogSXQgaXMgcmVjb21tZW5kZWQgdG8gdXNlIHRoZSBgU2VjcmV0UGFyYW1ldGVyYCBjb25zdHJ1Y3QgaW4gb3JkZXIgdG8gaW1wb3J0XG4gKiBzZWNyZXQgdmFsdWVzIGZyb20gdGhlIFNTTSBQYXJhbWV0ZXIgU3RvcmUgaW5zdGVhZCBvZiBzdG9yaW5nIHRoZW0gaW4geW91clxuICogY29kZS5cbiAqXG4gKiBIb3dldmVyLCB5b3UgY2FuIGFsc28ganVzdCBwYXNzIGluIHZhbHVlcywgbGlrZSBhbnkgb3RoZXIgdG9rZW46IGBuZXcgU2VjcmV0KCdibGEnKWBcbiAqL1xuZXhwb3J0IGNsYXNzIFNlY3JldCBleHRlbmRzIFRva2VuIHtcblxufVxuXG5leHBvcnQgaW50ZXJmYWNlIFNlY3JldFByb3BzIHtcbiAgICAvKipcbiAgICAgKiBUaGUgbmFtZSBvZiB0aGUgU1NNIHBhcmFtZXRlciB3aGVyZSB0aGUgc2VjcmV0IHZhbHVlIGlzIHN0b3JlZC5cbiAgICAgKi9cbiAgICBzc21QYXJhbWV0ZXI6IHN0cmluZztcblxuICAgIC8qKlxuICAgICAqIEEgc3RyaW5nIG9mIHVwIHRvIDQwMDAgY2hhcmFjdGVycyB0aGF0IGRlc2NyaWJlcyB0aGUgcGFyYW1ldGVyLlxuICAgICAqIEBkZWZhdWx0IE5vIGRlc2NyaXB0aW9uXG4gICAgICovXG4gICAgZGVzY3JpcHRpb24/OiBzdHJpbmc7XG5cbiAgICAvKipcbiAgICAgKiBBIHJlZ3VsYXIgZXhwcmVzc2lvbiB0aGF0IHJlcHJlc2VudHMgdGhlIHBhdHRlcm5zIHRvIGFsbG93IGZvciBTdHJpbmcgdHlwZXMuXG4gICAgICovXG4gICAgYWxsb3dlZFBhdHRlcm4/OiBzdHJpbmc7XG5cbiAgICAvKipcbiAgICAgKiBBbiBhcnJheSBjb250YWluaW5nIHRoZSBsaXN0IG9mIHZhbHVlcyBhbGxvd2VkIGZvciB0aGUgcGFyYW1ldGVyLlxuICAgICAqL1xuICAgIGFsbG93ZWRWYWx1ZXM/OiBzdHJpbmdbXTtcblxuICAgIC8qKlxuICAgICAqIEEgc3RyaW5nIHRoYXQgZXhwbGFpbnMgYSBjb25zdHJhaW50IHdoZW4gdGhlIGNvbnN0cmFpbnQgaXMgdmlvbGF0ZWQuXG4gICAgICogRm9yIGV4YW1wbGUsIHdpdGhvdXQgYSBjb25zdHJhaW50IGRlc2NyaXB0aW9uLCBhIHBhcmFtZXRlciB0aGF0IGhhcyBhbiBhbGxvd2VkXG4gICAgICogcGF0dGVybiBvZiBbQS1aYS16MC05XSsgZGlzcGxheXMgdGhlIGZvbGxvd2luZyBlcnJvciBtZXNzYWdlIHdoZW4gdGhlIHVzZXIgc3BlY2lmaWVzXG4gICAgICogYW4gaW52YWxpZCB2YWx1ZTpcbiAgICAgKi9cbiAgICBjb25zdHJhaW50RGVzY3JpcHRpb24/OiBzdHJpbmc7XG5cbiAgICAvKipcbiAgICAgKiBBbiBpbnRlZ2VyIHZhbHVlIHRoYXQgZGV0ZXJtaW5lcyB0aGUgbGFyZ2VzdCBudW1iZXIgb2YgY2hhcmFjdGVycyB5b3Ugd2FudCB0byBhbGxvdyBmb3IgU3RyaW5nIHR5cGVzLlxuICAgICAqL1xuICAgIG1heExlbmd0aD86IG51bWJlcjtcblxuICAgIC8qKlxuICAgICAqIEFuIGludGVnZXIgdmFsdWUgdGhhdCBkZXRlcm1pbmVzIHRoZSBzbWFsbGVzdCBudW1iZXIgb2YgY2hhcmFjdGVycyB5b3Ugd2FudCB0byBhbGxvdyBmb3IgU3RyaW5nIHR5cGVzLlxuICAgICAqL1xuICAgIG1pbkxlbmd0aD86IG51bWJlcjtcbn1cblxuLyoqXG4gKiBEZWZpbmVzIGEgc2VjcmV0IHZhbHVlIHJlc29sdmVkIGZyb20gdGhlIFN5c3RlbXMgTWFuYWdlciAoU1NNKSBQYXJhbWV0ZXJcbiAqIFN0b3JlIGR1cmluZyBkZXBsb3ltZW50LiBUaGlzIGlzIHVzZWZ1bCBmb3IgcmVmZXJlbmNpbmcgdmFsdWVzIHRoYXQgeW91IGRvXG4gKiBub3Qgd2lzaCB0byBpbmNsdWRlIGluIHlvdXIgY29kZSBiYXNlLCBzdWNoIGFzIHNlY3JldHMsIHBhc3N3b3JkcyBhbmQga2V5cy5cbiAqXG4gKiBUaGlzIGNvbnN0cnVjdCB3aWxsIGFkZCBhIENsb3VkRm9ybWF0aW9uIHBhcmFtZXRlciB0byB5b3VyIHRlbXBsYXRlIGJvdW5kIHRvXG4gKiBhbiBTU00gcGFyYW1ldGVyIChvZiB0eXBlIFwiQVdTOjpTU006OlBhcmFtZXRlcjo6VmFsdWU8U3RyaW5nPlwiKS4gRGVwbG95bWVudFxuICogd2lsbCBmYWlsIGlmIHRoZSB2YWx1ZSBkb2Vzbid0IGV4aXN0IGluIHRoZSB0YXJnZXQgZW52aXJvbm1lbnQuXG4gKlxuICogSW1wb3J0YW50OiBGb3IgdmFsdWVzIG90aGVyIHRoYW4gc2VjcmV0cywgcHJlZmVyIHRvIHVzZSB0aGVcbiAqIGBTU01QYXJhbWV0ZXJQcm92aWRlcmAgd2hpY2ggcmVzb2x2ZXMgU1NNIHBhcmFtZXRlciBpbiBkZXNpZ24tdGltZSwgYW5kXG4gKiBlbnN1cmVzIHRoYXQgc3RhY2sgZGVwbG95bWVudHMgYXJlIGRldGVybWluaXN0aWMuXG4gKi9cbmV4cG9ydCBjbGFzcyBTZWNyZXRQYXJhbWV0ZXIgZXh0ZW5kcyBDb25zdHJ1Y3Qge1xuICAgIC8qKlxuICAgICAqIFRoZSB2YWx1ZSBvZiB0aGUgc2VjcmV0IHBhcmFtZXRlci5cbiAgICAgKi9cbiAgICBwdWJsaWMgdmFsdWU6IFNlY3JldDtcblxuICAgIGNvbnN0cnVjdG9yKHBhcmVudDogQ29uc3RydWN0LCBuYW1lOiBzdHJpbmcsIHByb3BzOiBTZWNyZXRQcm9wcykge1xuICAgICAgICBzdXBlcihwYXJlbnQsIG5hbWUpO1xuXG4gICAgICAgIGNvbnN0IHBhcmFtID0gbmV3IFBhcmFtZXRlcih0aGlzLCAnUGFyYW1ldGVyJywge1xuICAgICAgICAgICAgdHlwZTogJ0FXUzo6U1NNOjpQYXJhbWV0ZXI6OlZhbHVlPFN0cmluZz4nLFxuICAgICAgICAgICAgZGVmYXVsdDogcHJvcHMuc3NtUGFyYW1ldGVyLFxuICAgICAgICAgICAgZGVzY3JpcHRpb246IHByb3BzLmRlc2NyaXB0aW9uLFxuICAgICAgICAgICAgYWxsb3dlZFBhdHRlcm46IHByb3BzLmFsbG93ZWRQYXR0ZXJuLFxuICAgICAgICAgICAgYWxsb3dlZFZhbHVlczogcHJvcHMuYWxsb3dlZFZhbHVlcyxcbiAgICAgICAgICAgIGNvbnN0cmFpbnREZXNjcmlwdGlvbjogcHJvcHMuY29uc3RyYWludERlc2NyaXB0aW9uLFxuICAgICAgICAgICAgbWF4TGVuZ3RoOiBwcm9wcy5tYXhMZW5ndGgsXG4gICAgICAgICAgICBtaW5MZW5ndGg6IHByb3BzLm1pbkxlbmd0aCxcbiAgICAgICAgICAgIG5vRWNobzogdHJ1ZSxcbiAgICAgICAgfSk7XG5cbiAgICAgICAgdGhpcy52YWx1ZSA9IHBhcmFtLnJlZjtcbiAgICB9XG59XG4iXX0=
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic2VjcmV0LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsic2VjcmV0LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7O0FBQUEsaURBQThDO0FBQzlDLDJDQUF1QztBQUN2QywyQ0FBd0M7QUFFeEM7Ozs7Ozs7OztHQVNHO0FBQ0gsTUFBYSxNQUFPLFNBQVEsY0FBSztDQUFJO0FBQXJDLHdCQUFxQztBQTJDckM7Ozs7Ozs7Ozs7OztHQVlHO0FBQ0gsTUFBYSxlQUFnQixTQUFRLHFCQUFTO0lBTTFDLFlBQVksTUFBaUIsRUFBRSxJQUFZLEVBQUUsS0FBa0I7UUFDM0QsS0FBSyxDQUFDLE1BQU0sRUFBRSxJQUFJLENBQUMsQ0FBQztRQUVwQixNQUFNLEtBQUssR0FBRyxJQUFJLHFCQUFTLENBQUMsSUFBSSxFQUFFLFdBQVcsRUFBRTtZQUMzQyxJQUFJLEVBQUUsb0NBQW9DO1lBQzFDLE9BQU8sRUFBRSxLQUFLLENBQUMsWUFBWTtZQUMzQixXQUFXLEVBQUUsS0FBSyxDQUFDLFdBQVc7WUFDOUIsY0FBYyxFQUFFLEtBQUssQ0FBQyxjQUFjO1lBQ3BDLGFBQWEsRUFBRSxLQUFLLENBQUMsYUFBYTtZQUNsQyxxQkFBcUIsRUFBRSxLQUFLLENBQUMscUJBQXFCO1lBQ2xELFNBQVMsRUFBRSxLQUFLLENBQUMsU0FBUztZQUMxQixTQUFTLEVBQUUsS0FBSyxDQUFDLFNBQVM7WUFDMUIsTUFBTSxFQUFFLElBQUk7U0FDZixDQUFDLENBQUM7UUFFSCxJQUFJLENBQUMsS0FBSyxHQUFHLElBQUksTUFBTSxDQUFDLEtBQUssQ0FBQyxHQUFHLENBQUMsQ0FBQztJQUN2QyxDQUFDO0NBQ0o7QUF2QkQsMENBdUJDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgQ29uc3RydWN0IH0gZnJvbSAnLi4vY29yZS9jb25zdHJ1Y3QnO1xuaW1wb3J0IHsgVG9rZW4gfSBmcm9tICcuLi9jb3JlL3Rva2Vucyc7XG5pbXBvcnQgeyBQYXJhbWV0ZXIgfSBmcm9tICcuL3BhcmFtZXRlcic7XG5cbi8qKlxuICogQSB0b2tlbiB0aGF0IHJlcHJlc2VudHMgYSB2YWx1ZSB0aGF0J3MgZXhwZWN0ZWQgdG8gYmUgYSBzZWNyZXQsIGxpa2VcbiAqIHBhc3N3b3JkcyBhbmQga2V5cy5cbiAqXG4gKiBJdCBpcyByZWNvbW1lbmRlZCB0byB1c2UgdGhlIGBTZWNyZXRQYXJhbWV0ZXJgIGNvbnN0cnVjdCBpbiBvcmRlciB0byBpbXBvcnRcbiAqIHNlY3JldCB2YWx1ZXMgZnJvbSB0aGUgU1NNIFBhcmFtZXRlciBTdG9yZSBpbnN0ZWFkIG9mIHN0b3JpbmcgdGhlbSBpbiB5b3VyXG4gKiBjb2RlLlxuICpcbiAqIEhvd2V2ZXIsIHlvdSBjYW4gYWxzbyBqdXN0IHBhc3MgaW4gdmFsdWVzLCBsaWtlIGFueSBvdGhlciB0b2tlbjogYG5ldyBTZWNyZXQoJ2JsYScpYFxuICovXG5leHBvcnQgY2xhc3MgU2VjcmV0IGV4dGVuZHMgVG9rZW4geyB9XG5cbmV4cG9ydCBpbnRlcmZhY2UgU2VjcmV0UHJvcHMge1xuICAgIC8qKlxuICAgICAqIFRoZSBuYW1lIG9mIHRoZSBTU00gcGFyYW1ldGVyIHdoZXJlIHRoZSBzZWNyZXQgdmFsdWUgaXMgc3RvcmVkLlxuICAgICAqL1xuICAgIHNzbVBhcmFtZXRlcjogc3RyaW5nO1xuXG4gICAgLyoqXG4gICAgICogQSBzdHJpbmcgb2YgdXAgdG8gNDAwMCBjaGFyYWN0ZXJzIHRoYXQgZGVzY3JpYmVzIHRoZSBwYXJhbWV0ZXIuXG4gICAgICogQGRlZmF1bHQgTm8gZGVzY3JpcHRpb25cbiAgICAgKi9cbiAgICBkZXNjcmlwdGlvbj86IHN0cmluZztcblxuICAgIC8qKlxuICAgICAqIEEgcmVndWxhciBleHByZXNzaW9uIHRoYXQgcmVwcmVzZW50cyB0aGUgcGF0dGVybnMgdG8gYWxsb3cgZm9yIFN0cmluZyB0eXBlcy5cbiAgICAgKi9cbiAgICBhbGxvd2VkUGF0dGVybj86IHN0cmluZztcblxuICAgIC8qKlxuICAgICAqIEFuIGFycmF5IGNvbnRhaW5pbmcgdGhlIGxpc3Qgb2YgdmFsdWVzIGFsbG93ZWQgZm9yIHRoZSBwYXJhbWV0ZXIuXG4gICAgICovXG4gICAgYWxsb3dlZFZhbHVlcz86IHN0cmluZ1tdO1xuXG4gICAgLyoqXG4gICAgICogQSBzdHJpbmcgdGhhdCBleHBsYWlucyBhIGNvbnN0cmFpbnQgd2hlbiB0aGUgY29uc3RyYWludCBpcyB2aW9sYXRlZC5cbiAgICAgKiBGb3IgZXhhbXBsZSwgd2l0aG91dCBhIGNvbnN0cmFpbnQgZGVzY3JpcHRpb24sIGEgcGFyYW1ldGVyIHRoYXQgaGFzIGFuIGFsbG93ZWRcbiAgICAgKiBwYXR0ZXJuIG9mIFtBLVphLXowLTldKyBkaXNwbGF5cyB0aGUgZm9sbG93aW5nIGVycm9yIG1lc3NhZ2Ugd2hlbiB0aGUgdXNlciBzcGVjaWZpZXNcbiAgICAgKiBhbiBpbnZhbGlkIHZhbHVlOlxuICAgICAqL1xuICAgIGNvbnN0cmFpbnREZXNjcmlwdGlvbj86IHN0cmluZztcblxuICAgIC8qKlxuICAgICAqIEFuIGludGVnZXIgdmFsdWUgdGhhdCBkZXRlcm1pbmVzIHRoZSBsYXJnZXN0IG51bWJlciBvZiBjaGFyYWN0ZXJzIHlvdSB3YW50IHRvIGFsbG93IGZvciBTdHJpbmcgdHlwZXMuXG4gICAgICovXG4gICAgbWF4TGVuZ3RoPzogbnVtYmVyO1xuXG4gICAgLyoqXG4gICAgICogQW4gaW50ZWdlciB2YWx1ZSB0aGF0IGRldGVybWluZXMgdGhlIHNtYWxsZXN0IG51bWJlciBvZiBjaGFyYWN0ZXJzIHlvdSB3YW50IHRvIGFsbG93IGZvciBTdHJpbmcgdHlwZXMuXG4gICAgICovXG4gICAgbWluTGVuZ3RoPzogbnVtYmVyO1xufVxuXG4vKipcbiAqIERlZmluZXMgYSBzZWNyZXQgdmFsdWUgcmVzb2x2ZWQgZnJvbSB0aGUgU3lzdGVtcyBNYW5hZ2VyIChTU00pIFBhcmFtZXRlclxuICogU3RvcmUgZHVyaW5nIGRlcGxveW1lbnQuIFRoaXMgaXMgdXNlZnVsIGZvciByZWZlcmVuY2luZyB2YWx1ZXMgdGhhdCB5b3UgZG9cbiAqIG5vdCB3aXNoIHRvIGluY2x1ZGUgaW4geW91ciBjb2RlIGJhc2UsIHN1Y2ggYXMgc2VjcmV0cywgcGFzc3dvcmRzIGFuZCBrZXlzLlxuICpcbiAqIFRoaXMgY29uc3RydWN0IHdpbGwgYWRkIGEgQ2xvdWRGb3JtYXRpb24gcGFyYW1ldGVyIHRvIHlvdXIgdGVtcGxhdGUgYm91bmQgdG9cbiAqIGFuIFNTTSBwYXJhbWV0ZXIgKG9mIHR5cGUgXCJBV1M6OlNTTTo6UGFyYW1ldGVyOjpWYWx1ZTxTdHJpbmc+XCIpLiBEZXBsb3ltZW50XG4gKiB3aWxsIGZhaWwgaWYgdGhlIHZhbHVlIGRvZXNuJ3QgZXhpc3QgaW4gdGhlIHRhcmdldCBlbnZpcm9ubWVudC5cbiAqXG4gKiBJbXBvcnRhbnQ6IEZvciB2YWx1ZXMgb3RoZXIgdGhhbiBzZWNyZXRzLCBwcmVmZXIgdG8gdXNlIHRoZVxuICogYFNTTVBhcmFtZXRlclByb3ZpZGVyYCB3aGljaCByZXNvbHZlcyBTU00gcGFyYW1ldGVyIGluIGRlc2lnbi10aW1lLCBhbmRcbiAqIGVuc3VyZXMgdGhhdCBzdGFjayBkZXBsb3ltZW50cyBhcmUgZGV0ZXJtaW5pc3RpYy5cbiAqL1xuZXhwb3J0IGNsYXNzIFNlY3JldFBhcmFtZXRlciBleHRlbmRzIENvbnN0cnVjdCB7XG4gICAgLyoqXG4gICAgICogVGhlIHZhbHVlIG9mIHRoZSBzZWNyZXQgcGFyYW1ldGVyLlxuICAgICAqL1xuICAgIHB1YmxpYyB2YWx1ZTogU2VjcmV0O1xuXG4gICAgY29uc3RydWN0b3IocGFyZW50OiBDb25zdHJ1Y3QsIG5hbWU6IHN0cmluZywgcHJvcHM6IFNlY3JldFByb3BzKSB7XG4gICAgICAgIHN1cGVyKHBhcmVudCwgbmFtZSk7XG5cbiAgICAgICAgY29uc3QgcGFyYW0gPSBuZXcgUGFyYW1ldGVyKHRoaXMsICdQYXJhbWV0ZXInLCB7XG4gICAgICAgICAgICB0eXBlOiAnQVdTOjpTU006OlBhcmFtZXRlcjo6VmFsdWU8U3RyaW5nPicsXG4gICAgICAgICAgICBkZWZhdWx0OiBwcm9wcy5zc21QYXJhbWV0ZXIsXG4gICAgICAgICAgICBkZXNjcmlwdGlvbjogcHJvcHMuZGVzY3JpcHRpb24sXG4gICAgICAgICAgICBhbGxvd2VkUGF0dGVybjogcHJvcHMuYWxsb3dlZFBhdHRlcm4sXG4gICAgICAgICAgICBhbGxvd2VkVmFsdWVzOiBwcm9wcy5hbGxvd2VkVmFsdWVzLFxuICAgICAgICAgICAgY29uc3RyYWludERlc2NyaXB0aW9uOiBwcm9wcy5jb25zdHJhaW50RGVzY3JpcHRpb24sXG4gICAgICAgICAgICBtYXhMZW5ndGg6IHByb3BzLm1heExlbmd0aCxcbiAgICAgICAgICAgIG1pbkxlbmd0aDogcHJvcHMubWluTGVuZ3RoLFxuICAgICAgICAgICAgbm9FY2hvOiB0cnVlLFxuICAgICAgICB9KTtcblxuICAgICAgICB0aGlzLnZhbHVlID0gbmV3IFNlY3JldChwYXJhbS5yZWYpO1xuICAgIH1cbn1cbiJdfQ==
import cxapi = require('@aws-cdk/cx-api');
import { App } from '../app';
import { Construct } from '../core/construct';
import { Token } from '../core/tokens';
import { Environment } from '../environment';

@@ -223,3 +222,3 @@ import { CloudFormationToken } from './cloudformation-token';

*/
readonly ref: Token;
readonly ref: string;
}

@@ -226,0 +225,0 @@ /**

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

get ref() {
return new Ref(this);
return new Ref(this).toString();
}

@@ -315,2 +315,2 @@ }

exports.Ref = Ref;
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"stack.js","sourceRoot":"","sources":["stack.ts"],"names":[],"mappings":"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","sourcesContent":["import cxapi = require('@aws-cdk/cx-api');\nimport { App } from '../app';\nimport { Construct, PATH_SEP } from '../core/construct';\nimport { resolve, Token } from '../core/tokens';\nimport { Environment } from '../environment';\nimport { CloudFormationToken } from './cloudformation-token';\nimport { HashedAddressingScheme, IAddressingScheme, LogicalIDs } from './logical-id';\nimport { Resource } from './resource';\n\nexport interface StackProps {\n    /**\n     * The AWS environment (account/region) where this stack will be deployed.\n     *\n     * If not supplied, the `default-account` and `default-region` context parameters will be\n     * used. If they are undefined, it will not be possible to deploy the stack.\n     */\n    env?: Environment;\n\n    /**\n     * Strategy for logical ID generation\n     *\n     * Optional. If not supplied, the HashedNamingScheme will be used.\n     */\n    namingScheme?: IAddressingScheme;\n}\n\n/**\n * A root construct which represents a single CloudFormation stack.\n */\nexport class Stack extends Construct {\n    /**\n     * Traverses the tree and looks up for the Stack root.\n     * @param node A construct in the tree\n     * @returns The Stack object (throws if the node is not part of a Stack-rooted tree)\n     */\n    public static find(node: Construct): Stack {\n        let curr: Construct | undefined = node;\n        while (curr != null && !isStack(curr)) {\n            curr = curr.parent;\n        }\n\n        if (curr == null) {\n            throw new Error(`Cannot find a Stack parent for '${node.toString()}'`);\n        }\n        return curr;\n    }\n\n    /**\n     * Adds a metadata annotation \"aws:cdk:physical-name\" to the construct if physicalName\n     * is non-null. This can be used later by tools and aspects to determine if resources\n     * have been created with physical names.\n     */\n    public static annotatePhysicalName(construct: Construct, physicalName?: string) {\n        if (physicalName == null) {\n            return;\n        }\n\n        construct.addMetadata('aws:cdk:physical-name', physicalName);\n    }\n\n    private static readonly VALID_STACK_NAME_REGEX = /^[A-Za-z][A-Za-z0-9-]*$/;\n\n    /**\n     * Lists all missing contextual information.\n     * This is returned when the stack is synthesized under the 'missing' attribute\n     * and allows tooling to obtain the context and re-synthesize.\n     */\n    public readonly missingContext: { [key: string]: cxapi.MissingContext } = { };\n\n    /**\n     * The environment in which this stack is deployed.\n     */\n    public readonly env: Environment;\n\n    /**\n     * Used to determine if this construct is a stack.\n     */\n    public readonly isStack = true;\n\n    /**\n     * Logical ID generation strategy\n     */\n    public readonly logicalIds: LogicalIDs;\n\n    /**\n     * Options for CloudFormation template (like version, transform, description).\n     */\n    public readonly templateOptions: TemplateOptions = {};\n\n    /**\n     * The CloudFormation stack name.\n     */\n    public readonly name: string;\n\n    /**\n     * Creates a new stack.\n     *\n     * @param parent Parent of this stack, usually a Program instance.\n     * @param name The name of the CloudFormation stack. Defaults to \"Stack\".\n     * @param props Stack properties.\n     */\n    public constructor(parent?: App, name?: string, props?: StackProps) {\n        // For unit test convenience parents are optional, so bypass the type check when calling the parent.\n        super(parent!, name!);\n        this.env = this.parseEnvironment(props);\n\n        this.logicalIds = new LogicalIDs(props && props.namingScheme ? props.namingScheme : new HashedAddressingScheme());\n        this.name = name || 'Stack';\n    }\n\n    /**\n     * Looks up a resource by path.\n     *\n     * @returns The Resource or undefined if not found\n     */\n    public findResource(path: string): Resource | undefined {\n        const r = this.findChild(path);\n        if (!r) { return undefined; }\n\n        // found an element, check if it's a resource (duck-type)\n        if (!('resourceType' in r)) {\n            throw new Error(`Found a stack element for ${path} but it is not a resource: ${r.toString()}`);\n        }\n\n        return r as Resource;\n    }\n\n    /**\n     * Returns the CloudFormation template for this stack by traversing\n     * the tree and invoking toCloudFormation() on all Entity objects.\n     */\n    public toCloudFormation() {\n        // before we begin synthesis, we shall lock this stack, so children cannot be added\n        this.lock();\n\n        try {\n            const template: any = {\n                Description: this.templateOptions.description,\n                Transform: this.templateOptions.transform,\n                AWSTemplateFormatVersion: this.templateOptions.templateFormatVersion,\n                Metadata: this.templateOptions.metadata\n            };\n\n            const elements = stackElements(this);\n            const fragments = elements.map(e => e.toCloudFormation());\n\n            // merge in all CloudFormation fragments collected from the tree\n            for (const fragment of fragments) {\n                merge(template, fragment);\n            }\n\n            // resolve all tokens and remove all empties\n            const ret = resolve(template) || { };\n\n            this.logicalIds.assertAllRenamesApplied();\n\n            return ret;\n        } finally {\n            // allow mutations after synthesis is finished.\n            this.unlock();\n        }\n    }\n\n    /**\n     * @param why more information about why region is required.\n     * @returns The region in which this stack is deployed. Throws if region is not defined.\n     */\n    public requireRegion(why?: string) {\n        if (!this.env.region) {\n            throw new Error(`${why ? why + '. ' : ''}Stack requires region information. It can be either supplied via the \"env\" property, ` +\n                    `via the \"${cxapi.DEFAULT_REGION_CONTEXT_KEY}\" context parameters or using \"aws configure\"`);\n        }\n\n        return this.env.region;\n    }\n\n    /**\n     * Indicate that a context key was expected\n     *\n     * Contains instructions on how the key should be supplied.\n     * @param key Key that uniquely identifies this missing context.\n     * @param details The set of parameters needed to obtain the context (specific to context provider).\n     */\n    public reportMissingContext(key: string, details: cxapi.MissingContext) {\n        this.missingContext[key] = details;\n    }\n\n    /**\n     * Rename a generated logical identities\n     */\n    public renameLogical(oldId: string, newId: string) {\n        // tslint:disable-next-line:no-console\n        if (this.children.length > 0) {\n            throw new Error(\"All renames must be set up before adding elements to the stack\");\n        }\n\n        this.logicalIds.renameLogical(oldId, newId);\n    }\n\n    /**\n     * Validate stack name\n     *\n     * CloudFormation stack names can include dashes in addition to the regular identifier\n     * character classes, and we don't allow one of the magic markers.\n     */\n    protected _validateId(name: string) {\n        if (!Stack.VALID_STACK_NAME_REGEX.test(name)) {\n            throw new Error(`Stack name must match the regular expression: ${Stack.VALID_STACK_NAME_REGEX.toString()}, got '${name}'`);\n        }\n    }\n\n    /**\n     * Applied defaults to environment attributes.\n     */\n    private parseEnvironment(props?: StackProps) {\n        // start with `env`.\n        const env: Environment = (props && props.env) || { };\n\n        // if account is not specified, attempt to read from context.\n        if (!env.account) {\n            env.account = this.getContext(cxapi.DEFAULT_ACCOUNT_CONTEXT_KEY);\n        }\n\n        // if region is not specified, attempt to read from context.\n        if (!env.region) {\n            env.region = this.getContext(cxapi.DEFAULT_REGION_CONTEXT_KEY);\n        }\n\n        return env;\n    }\n}\n\nfunction merge(template: any, part: any) {\n    for (const section of Object.keys(part)) {\n        const src = part[section];\n\n        // create top-level section if it doesn't exist\n        let dest = template[section];\n        if (!dest) {\n            template[section] = dest = src;\n        } else {\n            // add all entities from source section to destination section\n            for (const id of Object.keys(src)) {\n                if (id in dest) {\n                    throw new Error(`section '${section}' already contains '${id}'`);\n                }\n                dest[id] = src[id];\n            }\n        }\n    }\n}\n\nconst LOGICAL_ID_MD = 'aws:cdk:logicalId';\n\n/**\n * Represents a construct that can be \"depended on\" via `addDependency`.\n */\nexport interface IDependable {\n    /**\n     * Returns the set of all stack elements (resources, parameters, conditions)\n     * that should be added when a resource \"depends on\" this construct.\n     */\n    readonly dependencyElements: IDependable[];\n}\n\n/**\n * An element of a CloudFormation stack.\n */\nexport abstract class StackElement extends Construct implements IDependable {\n    /**\n     * Returns `true` if a construct is a stack element (i.e. part of the\n     * synthesized cloudformation template).\n     *\n     * Uses duck-typing instead of `instanceof` to allow stack elements from different\n     * versions of this library to be included in the same stack.\n     *\n     * @returns The construct as a stack element or undefined if it is not a stack element.\n     */\n    public static _asStackElement(construct: Construct): StackElement | undefined {\n        if ('logicalId' in construct && 'toCloudFormation' in construct) {\n            return construct as StackElement;\n        } else {\n            return undefined;\n        }\n    }\n\n    /**\n     * The logical ID for this CloudFormation stack element\n     */\n    public readonly logicalId: string;\n\n    /**\n     * The stack this Construct has been made a part of\n     */\n    protected stack: Stack;\n\n    /**\n     * Creates an entity and binds it to a tree.\n     * Note that the root of the tree must be a Stack object (not just any Root).\n     *\n     * @param parent The parent construct\n     * @param props Construct properties\n     */\n    constructor(parent: Construct, name: string) {\n        super(parent, name);\n        const s = Stack.find(this);\n        if (!s) {\n            throw new Error('The tree root must be derived from \"Stack\"');\n        }\n        this.stack = s;\n\n        this.addMetadata(LOGICAL_ID_MD, new Token(() => this.logicalId), this.constructor);\n\n        this.logicalId = this.stack.logicalIds.getLogicalId(this);\n    }\n\n    /**\n     * @returns the stack trace of the point where this Resource was created from, sourced\n     *          from the +metadata+ entry typed +aws:cdk:logicalId+, and with the bottom-most\n     *          node +internal+ entries filtered.\n     */\n    public get creationStackTrace(): string[] {\n        return filterStackTrace(this.metadata.find(md => md.type === LOGICAL_ID_MD)!.trace);\n\n        function filterStackTrace(stack: string[]): string[] {\n            const result = Array.of(...stack);\n            while (result.length > 0 && shouldFilter(result[result.length - 1])) {\n                result.pop();\n            }\n            // It's weird if we filtered everything, so return the whole stack...\n            return result.length === 0 ? stack : result;\n        }\n\n        function shouldFilter(str: string): boolean {\n            return str.match(/[^(]+\\(internal\\/.*/) !== null;\n        }\n    }\n\n    /**\n     * Return the path with respect to the stack\n     */\n    public get stackPath(): string {\n        return this.ancestors(this.stack).map(c => c.id).join(PATH_SEP);\n    }\n\n    public get dependencyElements(): IDependable[] {\n        return [ this ];\n    }\n\n    /**\n     * Returns the CloudFormation 'snippet' for this entity. The snippet will only be merged\n     * at the root level to ensure there are no identity conflicts.\n     *\n     * For example, a Resource class will return something like:\n     * {\n     *     Resources: {\n     *         [this.logicalId]: {\n     *             Type: this.resourceType,\n     *             Properties: this.props,\n     *             Condition: this.condition\n     *         }\n     *     }\n     * }\n     */\n    public abstract toCloudFormation(): object;\n}\n\n/**\n * CloudFormation template options for a stack.\n */\nexport interface TemplateOptions {\n    /**\n     * Gets or sets the description of this stack.\n     * If provided, it will be included in the CloudFormation template's \"Description\" attribute.\n     */\n    description?: string;\n\n    /**\n     * Gets or sets the AWSTemplateFormatVersion field of the CloudFormation template.\n     */\n    templateFormatVersion?: string;\n\n    /**\n     * Gets or sets the top-level template transform for this stack (e.g. \"AWS::Serverless-2016-10-31\").\n     */\n    transform?: string;\n\n    /**\n     * Metadata associated with the CloudFormation template.\n     */\n     metadata?: { [key: string]: any };\n}\n\n/**\n * Base class for referenceable CloudFormation constructs which are not Resources\n *\n * These constructs are things like Conditions and Parameters, can be\n * referenced by taking the `.ref` attribute.\n *\n * Resource constructs do not inherit from Referenceable because they have their\n * own, more specific types returned from the .ref attribute. Also, some\n * resources aren't referenceable at all (such as BucketPolicies or GatewayAttachments).\n */\nexport abstract class Referenceable extends StackElement {\n    /**\n     * Returns a token to a CloudFormation { Ref } that references this entity based on it's logical ID.\n     */\n    public get ref(): Token {\n        return new Ref(this);\n    }\n}\n\n/**\n * Return whether the given object is a Stack.\n *\n * We do attribute detection since we can't reliably use 'instanceof'.\n */\nfunction isStack(construct: Construct): construct is Stack {\n    return (construct as any).isStack;\n}\n\n/**\n * Collect all StackElements from a construct\n *\n * @param node Root node to collect all StackElements from\n * @param into Array to append StackElements to\n * @returns The same array as is being collected into\n */\nfunction stackElements(node: Construct, into: StackElement[] = []): StackElement[] {\n    const element = StackElement._asStackElement(node);\n    if (element) {\n        into.push(element);\n    }\n\n    for (const child of node.children) {\n        stackElements(child, into);\n    }\n\n    return into;\n}\n\n/**\n * A generic, untyped reference to a Stack Element\n */\nexport class Ref extends CloudFormationToken {\n    constructor(element: StackElement) {\n        super({ Ref: element.logicalId }, `${element.logicalId}.Ref`);\n    }\n}"]}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"stack.js","sourceRoot":"","sources":["stack.ts"],"names":[],"mappings":"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","sourcesContent":["import cxapi = require('@aws-cdk/cx-api');\nimport { App } from '../app';\nimport { Construct, PATH_SEP } from '../core/construct';\nimport { resolve, Token } from '../core/tokens';\nimport { Environment } from '../environment';\nimport { CloudFormationToken } from './cloudformation-token';\nimport { HashedAddressingScheme, IAddressingScheme, LogicalIDs } from './logical-id';\nimport { Resource } from './resource';\n\nexport interface StackProps {\n    /**\n     * The AWS environment (account/region) where this stack will be deployed.\n     *\n     * If not supplied, the `default-account` and `default-region` context parameters will be\n     * used. If they are undefined, it will not be possible to deploy the stack.\n     */\n    env?: Environment;\n\n    /**\n     * Strategy for logical ID generation\n     *\n     * Optional. If not supplied, the HashedNamingScheme will be used.\n     */\n    namingScheme?: IAddressingScheme;\n}\n\n/**\n * A root construct which represents a single CloudFormation stack.\n */\nexport class Stack extends Construct {\n    /**\n     * Traverses the tree and looks up for the Stack root.\n     * @param node A construct in the tree\n     * @returns The Stack object (throws if the node is not part of a Stack-rooted tree)\n     */\n    public static find(node: Construct): Stack {\n        let curr: Construct | undefined = node;\n        while (curr != null && !isStack(curr)) {\n            curr = curr.parent;\n        }\n\n        if (curr == null) {\n            throw new Error(`Cannot find a Stack parent for '${node.toString()}'`);\n        }\n        return curr;\n    }\n\n    /**\n     * Adds a metadata annotation \"aws:cdk:physical-name\" to the construct if physicalName\n     * is non-null. This can be used later by tools and aspects to determine if resources\n     * have been created with physical names.\n     */\n    public static annotatePhysicalName(construct: Construct, physicalName?: string) {\n        if (physicalName == null) {\n            return;\n        }\n\n        construct.addMetadata('aws:cdk:physical-name', physicalName);\n    }\n\n    private static readonly VALID_STACK_NAME_REGEX = /^[A-Za-z][A-Za-z0-9-]*$/;\n\n    /**\n     * Lists all missing contextual information.\n     * This is returned when the stack is synthesized under the 'missing' attribute\n     * and allows tooling to obtain the context and re-synthesize.\n     */\n    public readonly missingContext: { [key: string]: cxapi.MissingContext } = { };\n\n    /**\n     * The environment in which this stack is deployed.\n     */\n    public readonly env: Environment;\n\n    /**\n     * Used to determine if this construct is a stack.\n     */\n    public readonly isStack = true;\n\n    /**\n     * Logical ID generation strategy\n     */\n    public readonly logicalIds: LogicalIDs;\n\n    /**\n     * Options for CloudFormation template (like version, transform, description).\n     */\n    public readonly templateOptions: TemplateOptions = {};\n\n    /**\n     * The CloudFormation stack name.\n     */\n    public readonly name: string;\n\n    /**\n     * Creates a new stack.\n     *\n     * @param parent Parent of this stack, usually a Program instance.\n     * @param name The name of the CloudFormation stack. Defaults to \"Stack\".\n     * @param props Stack properties.\n     */\n    public constructor(parent?: App, name?: string, props?: StackProps) {\n        // For unit test convenience parents are optional, so bypass the type check when calling the parent.\n        super(parent!, name!);\n        this.env = this.parseEnvironment(props);\n\n        this.logicalIds = new LogicalIDs(props && props.namingScheme ? props.namingScheme : new HashedAddressingScheme());\n        this.name = name || 'Stack';\n    }\n\n    /**\n     * Looks up a resource by path.\n     *\n     * @returns The Resource or undefined if not found\n     */\n    public findResource(path: string): Resource | undefined {\n        const r = this.findChild(path);\n        if (!r) { return undefined; }\n\n        // found an element, check if it's a resource (duck-type)\n        if (!('resourceType' in r)) {\n            throw new Error(`Found a stack element for ${path} but it is not a resource: ${r.toString()}`);\n        }\n\n        return r as Resource;\n    }\n\n    /**\n     * Returns the CloudFormation template for this stack by traversing\n     * the tree and invoking toCloudFormation() on all Entity objects.\n     */\n    public toCloudFormation() {\n        // before we begin synthesis, we shall lock this stack, so children cannot be added\n        this.lock();\n\n        try {\n            const template: any = {\n                Description: this.templateOptions.description,\n                Transform: this.templateOptions.transform,\n                AWSTemplateFormatVersion: this.templateOptions.templateFormatVersion,\n                Metadata: this.templateOptions.metadata\n            };\n\n            const elements = stackElements(this);\n            const fragments = elements.map(e => e.toCloudFormation());\n\n            // merge in all CloudFormation fragments collected from the tree\n            for (const fragment of fragments) {\n                merge(template, fragment);\n            }\n\n            // resolve all tokens and remove all empties\n            const ret = resolve(template) || { };\n\n            this.logicalIds.assertAllRenamesApplied();\n\n            return ret;\n        } finally {\n            // allow mutations after synthesis is finished.\n            this.unlock();\n        }\n    }\n\n    /**\n     * @param why more information about why region is required.\n     * @returns The region in which this stack is deployed. Throws if region is not defined.\n     */\n    public requireRegion(why?: string) {\n        if (!this.env.region) {\n            throw new Error(`${why ? why + '. ' : ''}Stack requires region information. It can be either supplied via the \"env\" property, ` +\n                    `via the \"${cxapi.DEFAULT_REGION_CONTEXT_KEY}\" context parameters or using \"aws configure\"`);\n        }\n\n        return this.env.region;\n    }\n\n    /**\n     * Indicate that a context key was expected\n     *\n     * Contains instructions on how the key should be supplied.\n     * @param key Key that uniquely identifies this missing context.\n     * @param details The set of parameters needed to obtain the context (specific to context provider).\n     */\n    public reportMissingContext(key: string, details: cxapi.MissingContext) {\n        this.missingContext[key] = details;\n    }\n\n    /**\n     * Rename a generated logical identities\n     */\n    public renameLogical(oldId: string, newId: string) {\n        // tslint:disable-next-line:no-console\n        if (this.children.length > 0) {\n            throw new Error(\"All renames must be set up before adding elements to the stack\");\n        }\n\n        this.logicalIds.renameLogical(oldId, newId);\n    }\n\n    /**\n     * Validate stack name\n     *\n     * CloudFormation stack names can include dashes in addition to the regular identifier\n     * character classes, and we don't allow one of the magic markers.\n     */\n    protected _validateId(name: string) {\n        if (!Stack.VALID_STACK_NAME_REGEX.test(name)) {\n            throw new Error(`Stack name must match the regular expression: ${Stack.VALID_STACK_NAME_REGEX.toString()}, got '${name}'`);\n        }\n    }\n\n    /**\n     * Applied defaults to environment attributes.\n     */\n    private parseEnvironment(props?: StackProps) {\n        // start with `env`.\n        const env: Environment = (props && props.env) || { };\n\n        // if account is not specified, attempt to read from context.\n        if (!env.account) {\n            env.account = this.getContext(cxapi.DEFAULT_ACCOUNT_CONTEXT_KEY);\n        }\n\n        // if region is not specified, attempt to read from context.\n        if (!env.region) {\n            env.region = this.getContext(cxapi.DEFAULT_REGION_CONTEXT_KEY);\n        }\n\n        return env;\n    }\n}\n\nfunction merge(template: any, part: any) {\n    for (const section of Object.keys(part)) {\n        const src = part[section];\n\n        // create top-level section if it doesn't exist\n        let dest = template[section];\n        if (!dest) {\n            template[section] = dest = src;\n        } else {\n            // add all entities from source section to destination section\n            for (const id of Object.keys(src)) {\n                if (id in dest) {\n                    throw new Error(`section '${section}' already contains '${id}'`);\n                }\n                dest[id] = src[id];\n            }\n        }\n    }\n}\n\nconst LOGICAL_ID_MD = 'aws:cdk:logicalId';\n\n/**\n * Represents a construct that can be \"depended on\" via `addDependency`.\n */\nexport interface IDependable {\n    /**\n     * Returns the set of all stack elements (resources, parameters, conditions)\n     * that should be added when a resource \"depends on\" this construct.\n     */\n    readonly dependencyElements: IDependable[];\n}\n\n/**\n * An element of a CloudFormation stack.\n */\nexport abstract class StackElement extends Construct implements IDependable {\n    /**\n     * Returns `true` if a construct is a stack element (i.e. part of the\n     * synthesized cloudformation template).\n     *\n     * Uses duck-typing instead of `instanceof` to allow stack elements from different\n     * versions of this library to be included in the same stack.\n     *\n     * @returns The construct as a stack element or undefined if it is not a stack element.\n     */\n    public static _asStackElement(construct: Construct): StackElement | undefined {\n        if ('logicalId' in construct && 'toCloudFormation' in construct) {\n            return construct as StackElement;\n        } else {\n            return undefined;\n        }\n    }\n\n    /**\n     * The logical ID for this CloudFormation stack element\n     */\n    public readonly logicalId: string;\n\n    /**\n     * The stack this Construct has been made a part of\n     */\n    protected stack: Stack;\n\n    /**\n     * Creates an entity and binds it to a tree.\n     * Note that the root of the tree must be a Stack object (not just any Root).\n     *\n     * @param parent The parent construct\n     * @param props Construct properties\n     */\n    constructor(parent: Construct, name: string) {\n        super(parent, name);\n        const s = Stack.find(this);\n        if (!s) {\n            throw new Error('The tree root must be derived from \"Stack\"');\n        }\n        this.stack = s;\n\n        this.addMetadata(LOGICAL_ID_MD, new Token(() => this.logicalId), this.constructor);\n\n        this.logicalId = this.stack.logicalIds.getLogicalId(this);\n    }\n\n    /**\n     * @returns the stack trace of the point where this Resource was created from, sourced\n     *          from the +metadata+ entry typed +aws:cdk:logicalId+, and with the bottom-most\n     *          node +internal+ entries filtered.\n     */\n    public get creationStackTrace(): string[] {\n        return filterStackTrace(this.metadata.find(md => md.type === LOGICAL_ID_MD)!.trace);\n\n        function filterStackTrace(stack: string[]): string[] {\n            const result = Array.of(...stack);\n            while (result.length > 0 && shouldFilter(result[result.length - 1])) {\n                result.pop();\n            }\n            // It's weird if we filtered everything, so return the whole stack...\n            return result.length === 0 ? stack : result;\n        }\n\n        function shouldFilter(str: string): boolean {\n            return str.match(/[^(]+\\(internal\\/.*/) !== null;\n        }\n    }\n\n    /**\n     * Return the path with respect to the stack\n     */\n    public get stackPath(): string {\n        return this.ancestors(this.stack).map(c => c.id).join(PATH_SEP);\n    }\n\n    public get dependencyElements(): IDependable[] {\n        return [ this ];\n    }\n\n    /**\n     * Returns the CloudFormation 'snippet' for this entity. The snippet will only be merged\n     * at the root level to ensure there are no identity conflicts.\n     *\n     * For example, a Resource class will return something like:\n     * {\n     *     Resources: {\n     *         [this.logicalId]: {\n     *             Type: this.resourceType,\n     *             Properties: this.props,\n     *             Condition: this.condition\n     *         }\n     *     }\n     * }\n     */\n    public abstract toCloudFormation(): object;\n}\n\n/**\n * CloudFormation template options for a stack.\n */\nexport interface TemplateOptions {\n    /**\n     * Gets or sets the description of this stack.\n     * If provided, it will be included in the CloudFormation template's \"Description\" attribute.\n     */\n    description?: string;\n\n    /**\n     * Gets or sets the AWSTemplateFormatVersion field of the CloudFormation template.\n     */\n    templateFormatVersion?: string;\n\n    /**\n     * Gets or sets the top-level template transform for this stack (e.g. \"AWS::Serverless-2016-10-31\").\n     */\n    transform?: string;\n\n    /**\n     * Metadata associated with the CloudFormation template.\n     */\n     metadata?: { [key: string]: any };\n}\n\n/**\n * Base class for referenceable CloudFormation constructs which are not Resources\n *\n * These constructs are things like Conditions and Parameters, can be\n * referenced by taking the `.ref` attribute.\n *\n * Resource constructs do not inherit from Referenceable because they have their\n * own, more specific types returned from the .ref attribute. Also, some\n * resources aren't referenceable at all (such as BucketPolicies or GatewayAttachments).\n */\nexport abstract class Referenceable extends StackElement {\n    /**\n     * Returns a token to a CloudFormation { Ref } that references this entity based on it's logical ID.\n     */\n    public get ref(): string {\n        return new Ref(this).toString();\n    }\n}\n\n/**\n * Return whether the given object is a Stack.\n *\n * We do attribute detection since we can't reliably use 'instanceof'.\n */\nfunction isStack(construct: Construct): construct is Stack {\n    return (construct as any).isStack;\n}\n\n/**\n * Collect all StackElements from a construct\n *\n * @param node Root node to collect all StackElements from\n * @param into Array to append StackElements to\n * @returns The same array as is being collected into\n */\nfunction stackElements(node: Construct, into: StackElement[] = []): StackElement[] {\n    const element = StackElement._asStackElement(node);\n    if (element) {\n        into.push(element);\n    }\n\n    for (const child of node.children) {\n        stackElements(child, into);\n    }\n\n    return into;\n}\n\n/**\n * A generic, untyped reference to a Stack Element\n */\nexport class Ref extends CloudFormationToken {\n    constructor(element: StackElement) {\n        super({ Ref: element.logicalId }, `${element.logicalId}.Ref`);\n    }\n}"]}

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

import { Token } from '../core/tokens';
/**

@@ -9,7 +8,7 @@ * @link http://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-properties-resource-tags.html

*/
key: string | Token;
key: string;
/**
* @link http://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-properties-resource-tags.html#cfn-resource-tags-value
*/
value: string | Token;
value: string;
}
"use strict";
Object.defineProperty(exports, "__esModule", { value: true });
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidGFnLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsidGFnLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiIiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBUb2tlbiB9IGZyb20gJy4uL2NvcmUvdG9rZW5zJztcblxuLyoqXG4gKiBAbGluayBodHRwOi8vZG9jcy5hd3MuYW1hem9uLmNvbS9BV1NDbG91ZEZvcm1hdGlvbi9sYXRlc3QvVXNlckd1aWRlL2F3cy1wcm9wZXJ0aWVzLXJlc291cmNlLXRhZ3MuaHRtbFxuICovXG5leHBvcnQgaW50ZXJmYWNlIFRhZyB7XG4gICAgLyoqXG4gICAgICogQGxpbmsgaHR0cDovL2RvY3MuYXdzLmFtYXpvbi5jb20vQVdTQ2xvdWRGb3JtYXRpb24vbGF0ZXN0L1VzZXJHdWlkZS9hd3MtcHJvcGVydGllcy1yZXNvdXJjZS10YWdzLmh0bWwjY2ZuLXJlc291cmNlLXRhZ3Mta2V5XG4gICAgICovXG4gICAga2V5OiBzdHJpbmcgfCBUb2tlbjtcblxuICAgIC8qKlxuICAgICAqIEBsaW5rIGh0dHA6Ly9kb2NzLmF3cy5hbWF6b24uY29tL0FXU0Nsb3VkRm9ybWF0aW9uL2xhdGVzdC9Vc2VyR3VpZGUvYXdzLXByb3BlcnRpZXMtcmVzb3VyY2UtdGFncy5odG1sI2Nmbi1yZXNvdXJjZS10YWdzLXZhbHVlXG4gICAgICovXG4gICAgdmFsdWU6IHN0cmluZyB8IFRva2VuO1xufSJdfQ==
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidGFnLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsidGFnLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiIiLCJzb3VyY2VzQ29udGVudCI6WyIvKipcbiAqIEBsaW5rIGh0dHA6Ly9kb2NzLmF3cy5hbWF6b24uY29tL0FXU0Nsb3VkRm9ybWF0aW9uL2xhdGVzdC9Vc2VyR3VpZGUvYXdzLXByb3BlcnRpZXMtcmVzb3VyY2UtdGFncy5odG1sXG4gKi9cbmV4cG9ydCBpbnRlcmZhY2UgVGFnIHtcbiAgICAvKipcbiAgICAgKiBAbGluayBodHRwOi8vZG9jcy5hd3MuYW1hem9uLmNvbS9BV1NDbG91ZEZvcm1hdGlvbi9sYXRlc3QvVXNlckd1aWRlL2F3cy1wcm9wZXJ0aWVzLXJlc291cmNlLXRhZ3MuaHRtbCNjZm4tcmVzb3VyY2UtdGFncy1rZXlcbiAgICAgKi9cbiAgICBrZXk6IHN0cmluZztcblxuICAgIC8qKlxuICAgICAqIEBsaW5rIGh0dHA6Ly9kb2NzLmF3cy5hbWF6b24uY29tL0FXU0Nsb3VkRm9ybWF0aW9uL2xhdGVzdC9Vc2VyR3VpZGUvYXdzLXByb3BlcnRpZXMtcmVzb3VyY2UtdGFncy5odG1sI2Nmbi1yZXNvdXJjZS10YWdzLXZhbHVlXG4gICAgICovXG4gICAgdmFsdWU6IHN0cmluZztcbn0iXX0=

@@ -193,3 +193,3 @@ export declare const PATH_SEP = "/";

*/
private readonly locked;
protected readonly locked: boolean;
}

@@ -196,0 +196,0 @@ /**

@@ -361,2 +361,2 @@ "use strict";

}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"construct.js","sourceRoot":"","sources":["construct.ts"],"names":[],"mappings":"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","sourcesContent":["import cxapi = require('@aws-cdk/cx-api');\nimport { makeUniqueId } from '../util/uniqueid';\nexport const PATH_SEP = '/';\n\n/**\n * Represents the building block of the construct graph.\n * When a construct is created, it is always added as a child\n */\nexport class Construct {\n    /**\n     * Returns the parent of this node or undefined if this is a root node.\n     */\n    public readonly parent?: Construct;\n\n    /**\n     * The local id of the construct.\n     * This id is unique amongst its siblings.\n     * To obtain a tree-global unique id for this construct, use `uniqueId`.\n     */\n    public readonly id: string;\n\n    /**\n     * The full path of this construct in the tree.\n     * Components are separated by '/'.\n     */\n    public readonly path: string;\n\n    /**\n     * A tree-global unique alphanumeric identifier for this construct.\n     * Includes all components of the tree.\n     */\n    public readonly uniqueId: string;\n\n    /**\n     * List of children and their names\n     */\n    private readonly _children: { [name: string]: Construct } = { };\n    private readonly context: { [key: string]: any } = { };\n    private readonly _metadata = new Array<MetadataEntry>();\n\n    /**\n     * If this is set to 'true'. addChild() calls for this construct and any child\n     * will fail. This is used to prevent tree mutations during synthesis.\n     */\n    private _locked = false;\n\n    /**\n     * Creates a new construct node.\n     *\n     * @param parent The parent construct\n     * @param props  Properties for this construct\n     */\n    constructor(parent: Construct, id: string) {\n        this.id = id;\n        this.parent = parent;\n\n        // We say that parent is required, but some root constructs bypass the type checks and\n        // actually pass in 'undefined'.\n        if (parent != null) {\n            if (id === '') {\n                throw new Error('Only root constructs may have an empty name');\n            }\n\n            // Has side effect so must be very last thing in constructor\n            parent.addChild(this, this.id);\n        } else {\n            // This is a root construct.\n            this.id = id;\n        }\n\n        // Validate the name we ended up with\n        if (this.id !== '') {\n            this._validateId(this.id);\n        }\n\n        const components = this.rootPath().map(c => c.id);\n        this.path = components.join(PATH_SEP);\n        this.uniqueId = components.length > 0 ? makeUniqueId(components) : '';\n    }\n\n    /**\n     * Returns a string representation of this construct.\n     */\n    public toString() {\n        const path = this.path;\n        return this.typename + (path.length > 0 ? ` [${path}]` : '');\n    }\n\n    /**\n     * Returns a string with a tree representation of this construct and it's children.\n     */\n    public toTreeString(depth = 0) {\n        let out = '';\n        for (let i = 0; i < depth; ++i) {\n            out += '  ';\n        }\n        const name = this.id || '';\n        out += `${this.typename}${name.length > 0 ? ' [' + name + ']' : ''}\\n`;\n        for (const child of this.children) {\n            out += child.toTreeString(depth + 1);\n        }\n        return out;\n    }\n\n    /**\n     * Return a descendant by path, or undefined\n     *\n     * @param name Relative name of a direct or indirect child\n     * @returns a child by path or undefined if not found.\n     */\n    public tryFindChild(path: string): Construct | undefined {\n        // tslint:disable-next-line:no-console\n        if (path.startsWith(PATH_SEP)) {\n            throw new Error('Path must be relative');\n        }\n        const parts = path.split(PATH_SEP);\n\n        let curr: Construct|undefined = this;\n        while (curr != null && parts.length > 0) {\n            curr = curr._children[parts.shift()!];\n        }\n        return curr;\n    }\n\n    /**\n     * Return a descendant by path\n     *\n     * Throws an exception if the descendant is not found.\n     *\n     * @param name Relative name of a direct or indirect child\n     * @returns Child with the given path.\n     */\n    public findChild(path: string): Construct {\n        const ret = this.tryFindChild(path);\n        if (!ret) {\n            throw new Error(`No child with path: '${path}'`);\n        }\n        return ret;\n    }\n\n    /**\n     * All direct children of this construct.\n     */\n    public get children() {\n        return Object.keys(this._children).map(k => this._children[k]);\n    }\n\n    /**\n     * This can be used to set contextual values.\n     * Context must be set before any children are added, since children may consult context info during construction.\n     * If the key already exists, it will be overridden.\n     * @param key The context key\n     * @param value The context value\n     */\n    public setContext(key: string, value: any) {\n        if (this.children.length > 0) {\n            const names = this.children.map(c => c.id);\n            throw new Error('Cannot set context after children have been added: ' + names.join(','));\n        }\n        this.context[key] = value;\n    }\n\n    /**\n     * Retrieves a value from tree context.\n     *\n     * Context is usually initialized at the root, but can be overridden at any point in the tree.\n     *\n     * @param key The context key\n     * @returns The context value or undefined\n     */\n    public getContext(key: string): any {\n        const value = this.context[key];\n        if (value !== undefined) { return value; }\n\n        return this.parent && this.parent.getContext(key);\n    }\n\n    /**\n     * Retrieve a value from tree-global context\n     *\n     * It is an error if the context object is not available.\n     */\n    public requireContext(key: string): any {\n        const value = this.getContext(key);\n\n        if (value == null) {\n            throw new Error(`You must supply a context value named '${key}'`);\n        }\n\n        return value;\n    }\n\n    /**\n     * An array of metadata objects associated with this construct.\n     * This can be used, for example, to implement support for deprecation notices, source mapping, etc.\n     */\n    public get metadata() {\n        return this._metadata;\n    }\n\n    /**\n     * Adds a metadata entry to this construct.\n     * Entries are arbitrary values and will also include a stack trace to allow tracing back to\n     * the code location for when the entry was added. It can be used, for example, to include source\n     * mapping in CloudFormation templates to improve diagnostics.\n     *\n     * @param type a string denoting the type of metadata\n     * @param data the value of the metadata (can be a Token). If null/undefined, metadata will not be added.\n     * @param from a function under which to restrict the metadata entry's stack trace (defaults to this.addMetadata)\n     */\n    public addMetadata(type: string, data: any, from?: any): Construct {\n        if (data == null) {\n            return this;\n        }\n        const trace = createStackTrace(from || this.addMetadata);\n        this._metadata.push({ type, data, trace });\n        return this;\n    }\n\n    /**\n     * Adds a { \"aws:cdk:info\": <message> } metadata entry to this construct.\n     * The toolkit will display the info message when apps are synthesized.\n     * @param message The info message.\n     */\n    public addInfo(message: string): Construct {\n        return this.addMetadata(cxapi.INFO_METADATA_KEY, message);\n    }\n\n    /**\n     * Adds a { warning: <message> } metadata entry to this construct.\n     * The toolkit will display the warning when an app is synthesized, or fail\n     * if run in --strict mode.\n     * @param message The warning message.\n     */\n    public addWarning(message: string): Construct {\n        return this.addMetadata(cxapi.WARNING_METADATA_KEY, message);\n    }\n\n    /**\n     * Adds an { error: <message> } metadata entry to this construct.\n     * The toolkit will fail synthesis when errors are reported.\n     * @param message The error message.\n     */\n    public addError(message: string): Construct {\n        return this.addMetadata(cxapi.ERROR_METADATA_KEY, message);\n    }\n\n    /**\n     * This method can be implemented by derived constructs in order to perform\n     * validation logic. It is called on all constructs before synthesis.\n     *\n     * @returns An array of validation error messages, or an empty array if there the construct is valid.\n     */\n    public validate(): string[] {\n        return [];\n    }\n\n    /**\n     * Invokes 'validate' on all child constructs and then on this construct (depth-first).\n     * @returns A list of validation errors. If the list is empty, all constructs are valid.\n     */\n    public validateTree(): ValidationError[] {\n        let errors = new Array<ValidationError>();\n\n        for (const child of this.children) {\n            errors = errors.concat(child.validateTree());\n        }\n\n        const localErrors = this.validate();\n        return errors.concat(localErrors.map(msg => new ValidationError(this, msg)));\n    }\n\n    /**\n     * Return the ancestors (including self) of this Construct up until and excluding the indicated component\n     *\n     * @param to The construct to return the path components relative to, or\n     * the entire list of ancestors (including root) if omitted.\n     */\n    public ancestors(upTo?: Construct): Construct[] {\n        const ret = new Array<Construct>();\n\n        let curr: Construct | undefined = this;\n        while (curr && curr !== upTo) {\n            ret.unshift(curr);\n            curr = curr.parent;\n        }\n\n        return ret;\n    }\n\n    /**\n     * Validate that the id of the construct legal.\n     * Construct IDs can be any characters besides the path separator.\n     */\n    protected _validateId(id: string) {\n        if (id.indexOf(PATH_SEP) !== -1) {\n            throw new Error(`Construct names cannot include '${PATH_SEP}': ${id}`);\n        }\n    }\n\n    /**\n     * Throws if the `props` bag doesn't include the property `name`.\n     * In the future we can add some type-checking here, maybe even auto-generate during compilation.\n     * @param props The props bag.\n     * @param name The name of the required property.\n     *\n     * @deprecated use ``requireProperty`` from ``@aws-cdk/runtime`` instead.\n     */\n    protected required(props: any, name: string): any {\n        if (!(name in props)) {\n            throw new Error(`Construct of type ${this.typename} is missing required property: ${name}`);\n        }\n\n        const value = props[name];\n        return value;\n    }\n\n    /**\n     * @returns The type name of this node.\n     */\n    private get typename(): string {\n        const ctor: any = this.constructor;\n        return ctor.name || 'Construct';\n    }\n\n    /**\n     * Adds a child construct to this node.\n     *\n     * @param child The child construct\n     * @param name The type name of the child construct.\n     * @returns The resolved path part name of the child\n     */\n    protected addChild(child: Construct, childName: string) {\n        if (this.locked) {\n\n            // special error if root is locked\n            if (!this.path) {\n                throw new Error('Cannot add children during synthesis');\n            }\n\n            throw new Error(`Cannot add children to \"${this.path}\" during synthesis`);\n        }\n\n        if (childName in this._children) {\n            throw new Error(`There is already a Construct with name '${childName}' in ${this.toString()}`);\n        }\n\n        this._children[childName] = child;\n    }\n\n    /**\n     * Locks this construct from allowing more children to be added. After this\n     * call, no more children can be added to this construct or to any children.\n     */\n    protected lock() {\n        this._locked = true;\n    }\n\n    /**\n     * Unlocks this costruct and allows mutations (adding children).\n     */\n    protected unlock() {\n        this._locked = false;\n    }\n\n    /**\n     * Return the path of components up to but excluding the root\n     */\n    private rootPath(): Construct[] {\n        const ancestors = this.ancestors();\n        ancestors.shift();\n        return ancestors;\n    }\n\n    /**\n     * Returns true if this construct or any of it's parent constructs are\n     * locked.\n     */\n    private get locked() {\n        if (this._locked) {\n            return true;\n        }\n\n        if (this.parent && this.parent.locked) {\n            return true;\n        }\n\n        return false;\n    }\n}\n\n/**\n * Represents the root of a construct tree.\n * No parent and no name.\n */\nexport class Root extends Construct {\n    constructor() {\n        // Bypass type checks\n        super(undefined as any, '');\n    }\n}\n\n/**\n * An metadata entry in the construct.\n */\nexport interface MetadataEntry {\n    /**\n     * The type of the metadata entry.\n     */\n    type: string;\n\n    /**\n     * The data.\n     */\n    data?: any;\n\n    /**\n     * A stack trace for when the entry was created.\n     */\n    trace: string[];\n}\n\nexport class ValidationError {\n    constructor(public readonly source: Construct, public readonly message: string) {\n\n    }\n}\n\n// tslint:disable-next-line:ban-types\nfunction createStackTrace(below: Function): string[] {\n    const object = { stack: '' };\n    const previousLimit = Error.stackTraceLimit;\n    try {\n        Error.stackTraceLimit = Number.MAX_SAFE_INTEGER;\n        Error.captureStackTrace(object, below);\n    } finally {\n        Error.stackTraceLimit = previousLimit;\n    }\n    if (!object.stack) {\n        return [];\n    }\n    return object.stack.split('\\n').slice(1).map(s => s.replace(/^\\s*at\\s+/, ''));\n}\n"]}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"construct.js","sourceRoot":"","sources":["construct.ts"],"names":[],"mappings":"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","sourcesContent":["import cxapi = require('@aws-cdk/cx-api');\nimport { makeUniqueId } from '../util/uniqueid';\nexport const PATH_SEP = '/';\n\n/**\n * Represents the building block of the construct graph.\n * When a construct is created, it is always added as a child\n */\nexport class Construct {\n    /**\n     * Returns the parent of this node or undefined if this is a root node.\n     */\n    public readonly parent?: Construct;\n\n    /**\n     * The local id of the construct.\n     * This id is unique amongst its siblings.\n     * To obtain a tree-global unique id for this construct, use `uniqueId`.\n     */\n    public readonly id: string;\n\n    /**\n     * The full path of this construct in the tree.\n     * Components are separated by '/'.\n     */\n    public readonly path: string;\n\n    /**\n     * A tree-global unique alphanumeric identifier for this construct.\n     * Includes all components of the tree.\n     */\n    public readonly uniqueId: string;\n\n    /**\n     * List of children and their names\n     */\n    private readonly _children: { [name: string]: Construct } = { };\n    private readonly context: { [key: string]: any } = { };\n    private readonly _metadata = new Array<MetadataEntry>();\n\n    /**\n     * If this is set to 'true'. addChild() calls for this construct and any child\n     * will fail. This is used to prevent tree mutations during synthesis.\n     */\n    private _locked = false;\n\n    /**\n     * Creates a new construct node.\n     *\n     * @param parent The parent construct\n     * @param props  Properties for this construct\n     */\n    constructor(parent: Construct, id: string) {\n        this.id = id;\n        this.parent = parent;\n\n        // We say that parent is required, but some root constructs bypass the type checks and\n        // actually pass in 'undefined'.\n        if (parent != null) {\n            if (id === '') {\n                throw new Error('Only root constructs may have an empty name');\n            }\n\n            // Has side effect so must be very last thing in constructor\n            parent.addChild(this, this.id);\n        } else {\n            // This is a root construct.\n            this.id = id;\n        }\n\n        // Validate the name we ended up with\n        if (this.id !== '') {\n            this._validateId(this.id);\n        }\n\n        const components = this.rootPath().map(c => c.id);\n        this.path = components.join(PATH_SEP);\n        this.uniqueId = components.length > 0 ? makeUniqueId(components) : '';\n    }\n\n    /**\n     * Returns a string representation of this construct.\n     */\n    public toString() {\n        const path = this.path;\n        return this.typename + (path.length > 0 ? ` [${path}]` : '');\n    }\n\n    /**\n     * Returns a string with a tree representation of this construct and it's children.\n     */\n    public toTreeString(depth = 0) {\n        let out = '';\n        for (let i = 0; i < depth; ++i) {\n            out += '  ';\n        }\n        const name = this.id || '';\n        out += `${this.typename}${name.length > 0 ? ' [' + name + ']' : ''}\\n`;\n        for (const child of this.children) {\n            out += child.toTreeString(depth + 1);\n        }\n        return out;\n    }\n\n    /**\n     * Return a descendant by path, or undefined\n     *\n     * @param name Relative name of a direct or indirect child\n     * @returns a child by path or undefined if not found.\n     */\n    public tryFindChild(path: string): Construct | undefined {\n        // tslint:disable-next-line:no-console\n        if (path.startsWith(PATH_SEP)) {\n            throw new Error('Path must be relative');\n        }\n        const parts = path.split(PATH_SEP);\n\n        let curr: Construct|undefined = this;\n        while (curr != null && parts.length > 0) {\n            curr = curr._children[parts.shift()!];\n        }\n        return curr;\n    }\n\n    /**\n     * Return a descendant by path\n     *\n     * Throws an exception if the descendant is not found.\n     *\n     * @param name Relative name of a direct or indirect child\n     * @returns Child with the given path.\n     */\n    public findChild(path: string): Construct {\n        const ret = this.tryFindChild(path);\n        if (!ret) {\n            throw new Error(`No child with path: '${path}'`);\n        }\n        return ret;\n    }\n\n    /**\n     * All direct children of this construct.\n     */\n    public get children() {\n        return Object.keys(this._children).map(k => this._children[k]);\n    }\n\n    /**\n     * This can be used to set contextual values.\n     * Context must be set before any children are added, since children may consult context info during construction.\n     * If the key already exists, it will be overridden.\n     * @param key The context key\n     * @param value The context value\n     */\n    public setContext(key: string, value: any) {\n        if (this.children.length > 0) {\n            const names = this.children.map(c => c.id);\n            throw new Error('Cannot set context after children have been added: ' + names.join(','));\n        }\n        this.context[key] = value;\n    }\n\n    /**\n     * Retrieves a value from tree context.\n     *\n     * Context is usually initialized at the root, but can be overridden at any point in the tree.\n     *\n     * @param key The context key\n     * @returns The context value or undefined\n     */\n    public getContext(key: string): any {\n        const value = this.context[key];\n        if (value !== undefined) { return value; }\n\n        return this.parent && this.parent.getContext(key);\n    }\n\n    /**\n     * Retrieve a value from tree-global context\n     *\n     * It is an error if the context object is not available.\n     */\n    public requireContext(key: string): any {\n        const value = this.getContext(key);\n\n        if (value == null) {\n            throw new Error(`You must supply a context value named '${key}'`);\n        }\n\n        return value;\n    }\n\n    /**\n     * An array of metadata objects associated with this construct.\n     * This can be used, for example, to implement support for deprecation notices, source mapping, etc.\n     */\n    public get metadata() {\n        return this._metadata;\n    }\n\n    /**\n     * Adds a metadata entry to this construct.\n     * Entries are arbitrary values and will also include a stack trace to allow tracing back to\n     * the code location for when the entry was added. It can be used, for example, to include source\n     * mapping in CloudFormation templates to improve diagnostics.\n     *\n     * @param type a string denoting the type of metadata\n     * @param data the value of the metadata (can be a Token). If null/undefined, metadata will not be added.\n     * @param from a function under which to restrict the metadata entry's stack trace (defaults to this.addMetadata)\n     */\n    public addMetadata(type: string, data: any, from?: any): Construct {\n        if (data == null) {\n            return this;\n        }\n        const trace = createStackTrace(from || this.addMetadata);\n        this._metadata.push({ type, data, trace });\n        return this;\n    }\n\n    /**\n     * Adds a { \"aws:cdk:info\": <message> } metadata entry to this construct.\n     * The toolkit will display the info message when apps are synthesized.\n     * @param message The info message.\n     */\n    public addInfo(message: string): Construct {\n        return this.addMetadata(cxapi.INFO_METADATA_KEY, message);\n    }\n\n    /**\n     * Adds a { warning: <message> } metadata entry to this construct.\n     * The toolkit will display the warning when an app is synthesized, or fail\n     * if run in --strict mode.\n     * @param message The warning message.\n     */\n    public addWarning(message: string): Construct {\n        return this.addMetadata(cxapi.WARNING_METADATA_KEY, message);\n    }\n\n    /**\n     * Adds an { error: <message> } metadata entry to this construct.\n     * The toolkit will fail synthesis when errors are reported.\n     * @param message The error message.\n     */\n    public addError(message: string): Construct {\n        return this.addMetadata(cxapi.ERROR_METADATA_KEY, message);\n    }\n\n    /**\n     * This method can be implemented by derived constructs in order to perform\n     * validation logic. It is called on all constructs before synthesis.\n     *\n     * @returns An array of validation error messages, or an empty array if there the construct is valid.\n     */\n    public validate(): string[] {\n        return [];\n    }\n\n    /**\n     * Invokes 'validate' on all child constructs and then on this construct (depth-first).\n     * @returns A list of validation errors. If the list is empty, all constructs are valid.\n     */\n    public validateTree(): ValidationError[] {\n        let errors = new Array<ValidationError>();\n\n        for (const child of this.children) {\n            errors = errors.concat(child.validateTree());\n        }\n\n        const localErrors = this.validate();\n        return errors.concat(localErrors.map(msg => new ValidationError(this, msg)));\n    }\n\n    /**\n     * Return the ancestors (including self) of this Construct up until and excluding the indicated component\n     *\n     * @param to The construct to return the path components relative to, or\n     * the entire list of ancestors (including root) if omitted.\n     */\n    public ancestors(upTo?: Construct): Construct[] {\n        const ret = new Array<Construct>();\n\n        let curr: Construct | undefined = this;\n        while (curr && curr !== upTo) {\n            ret.unshift(curr);\n            curr = curr.parent;\n        }\n\n        return ret;\n    }\n\n    /**\n     * Validate that the id of the construct legal.\n     * Construct IDs can be any characters besides the path separator.\n     */\n    protected _validateId(id: string) {\n        if (id.indexOf(PATH_SEP) !== -1) {\n            throw new Error(`Construct names cannot include '${PATH_SEP}': ${id}`);\n        }\n    }\n\n    /**\n     * Throws if the `props` bag doesn't include the property `name`.\n     * In the future we can add some type-checking here, maybe even auto-generate during compilation.\n     * @param props The props bag.\n     * @param name The name of the required property.\n     *\n     * @deprecated use ``requireProperty`` from ``@aws-cdk/runtime`` instead.\n     */\n    protected required(props: any, name: string): any {\n        if (!(name in props)) {\n            throw new Error(`Construct of type ${this.typename} is missing required property: ${name}`);\n        }\n\n        const value = props[name];\n        return value;\n    }\n\n    /**\n     * @returns The type name of this node.\n     */\n    private get typename(): string {\n        const ctor: any = this.constructor;\n        return ctor.name || 'Construct';\n    }\n\n    /**\n     * Adds a child construct to this node.\n     *\n     * @param child The child construct\n     * @param name The type name of the child construct.\n     * @returns The resolved path part name of the child\n     */\n    protected addChild(child: Construct, childName: string) {\n        if (this.locked) {\n\n            // special error if root is locked\n            if (!this.path) {\n                throw new Error('Cannot add children during synthesis');\n            }\n\n            throw new Error(`Cannot add children to \"${this.path}\" during synthesis`);\n        }\n\n        if (childName in this._children) {\n            throw new Error(`There is already a Construct with name '${childName}' in ${this.toString()}`);\n        }\n\n        this._children[childName] = child;\n    }\n\n    /**\n     * Locks this construct from allowing more children to be added. After this\n     * call, no more children can be added to this construct or to any children.\n     */\n    protected lock() {\n        this._locked = true;\n    }\n\n    /**\n     * Unlocks this costruct and allows mutations (adding children).\n     */\n    protected unlock() {\n        this._locked = false;\n    }\n\n    /**\n     * Return the path of components up to but excluding the root\n     */\n    private rootPath(): Construct[] {\n        const ancestors = this.ancestors();\n        ancestors.shift();\n        return ancestors;\n    }\n\n    /**\n     * Returns true if this construct or any of it's parent constructs are\n     * locked.\n     */\n    protected get locked() {\n        if (this._locked) {\n            return true;\n        }\n\n        if (this.parent && this.parent.locked) {\n            return true;\n        }\n\n        return false;\n    }\n}\n\n/**\n * Represents the root of a construct tree.\n * No parent and no name.\n */\nexport class Root extends Construct {\n    constructor() {\n        // Bypass type checks\n        super(undefined as any, '');\n    }\n}\n\n/**\n * An metadata entry in the construct.\n */\nexport interface MetadataEntry {\n    /**\n     * The type of the metadata entry.\n     */\n    type: string;\n\n    /**\n     * The data.\n     */\n    data?: any;\n\n    /**\n     * A stack trace for when the entry was created.\n     */\n    trace: string[];\n}\n\nexport class ValidationError {\n    constructor(public readonly source: Construct, public readonly message: string) {\n\n    }\n}\n\n// tslint:disable-next-line:ban-types\nfunction createStackTrace(below: Function): string[] {\n    const object = { stack: '' };\n    const previousLimit = Error.stackTraceLimit;\n    try {\n        Error.stackTraceLimit = Number.MAX_SAFE_INTEGER;\n        Error.captureStackTrace(object, below);\n    } finally {\n        Error.stackTraceLimit = previousLimit;\n    }\n    if (!object.stack) {\n        return [];\n    }\n    return object.stack.split('\\n').slice(1).map(s => s.replace(/^\\s*at\\s+/, ''));\n}\n"]}

@@ -72,6 +72,7 @@ /**

/**
* Returns true if obj is a token (i.e. has the resolve() method)
* Returns true if obj is a token (i.e. has the resolve() method or is a string
* that includes token markers).
* @param obj The object to test.
*/
export declare function isToken(obj: any): obj is Token;
export declare function unresolved(obj: any): obj is Token;
/**

@@ -78,0 +79,0 @@ * Resolves an object by evaluating all tokens and removing any undefined or empty objects or arrays.

@@ -99,9 +99,15 @@ "use strict";

/**
* Returns true if obj is a token (i.e. has the resolve() method)
* Returns true if obj is a token (i.e. has the resolve() method or is a string
* that includes token markers).
* @param obj The object to test.
*/
function isToken(obj) {
return typeof (obj[exports.RESOLVE_METHOD]) === 'function';
function unresolved(obj) {
if (typeof (obj) === 'string') {
return TOKEN_STRING_MAP.createTokenString(obj).test();
}
else {
return typeof (obj[exports.RESOLVE_METHOD]) === 'function';
}
}
exports.isToken = isToken;
exports.unresolved = unresolved;
/**

@@ -154,3 +160,3 @@ * Resolves an object by evaluating all tokens and removing any undefined or empty objects or arrays.

//
if (isToken(obj)) {
if (unresolved(obj)) {
const value = obj[exports.RESOLVE_METHOD]();

@@ -179,2 +185,6 @@ return resolve(value, path);

for (const key of Object.keys(obj)) {
const resolvedKey = resolve(key);
if (typeof (resolvedKey) !== 'string') {
throw new Error(`The key "${key}" has been resolved to ${JSON.stringify(resolvedKey)} but must be resolvable to a string`);
}
const value = resolve(obj[key], path.concat(key));

@@ -185,3 +195,3 @@ // skip undefined

}
result[key] = value;
result[resolvedKey] = value;
}

@@ -227,6 +237,12 @@ return result;

/**
* Returns a `TokenString` for this string.
*/
createTokenString(s) {
return new TokenString(s, BEGIN_TOKEN_MARKER, `[${VALID_KEY_CHARS}]+`, END_TOKEN_MARKER);
}
/**
* Replace any Token markers in this string with their resolved values
*/
resolveMarkers(s) {
const str = new TokenString(s, BEGIN_TOKEN_MARKER, `[${VALID_KEY_CHARS}]+`, END_TOKEN_MARKER);
const str = this.createTokenString(s);
const fragments = str.split(this.lookupToken.bind(this));

@@ -261,2 +277,3 @@ return fragments.join();

this.endMarker = endMarker;
this.pattern = `${regexQuote(this.beginMarker)}(${this.idPattern})${regexQuote(this.endMarker)}`;
}

@@ -267,3 +284,3 @@ /**

split(lookup) {
const re = new RegExp(`${regexQuote(this.beginMarker)}(${this.idPattern})${regexQuote(this.endMarker)}`, 'g');
const re = new RegExp(this.pattern, 'g');
const ret = new TokenStringFragments();

@@ -285,2 +302,9 @@ let rest = 0;

}
/**
* Indicates if this string includes tokens.
*/
test() {
const re = new RegExp(this.pattern, 'g');
return re.test(this.str);
}
}

@@ -346,2 +370,2 @@ /**

}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"tokens.js","sourceRoot":"","sources":["tokens.ts"],"names":[],"mappings":"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","sourcesContent":["import { Construct } from \"./construct\";\n\n/**\n * If objects has a function property by this name, they will be considered tokens, and this\n * function will be called to resolve the value for this object.\n */\nexport const RESOLVE_METHOD = 'resolve';\n\n/**\n * Represents a special or lazily-evaluated value.\n *\n * Can be used to delay evaluation of a certain value in case, for example,\n * that it requires some context or late-bound data. Can also be used to\n * mark values that need special processing at document rendering time.\n *\n * Tokens can be embedded into strings while retaining their original\n * semantics.\n */\nexport class Token {\n    private tokenKey?: string;\n\n    /**\n     * Creates a token that resolves to `value`.\n     *\n     * If value is a function, the function is evaluated upon resolution and\n     * the value it returns will be used as the token's value.\n     *\n     * displayName is used to represent the Token when it's embedded into a string; it\n     * will look something like this:\n     *\n     *      \"embedded in a larger string is ${Token[DISPLAY_NAME.123]}\"\n     *\n     * This value is used as a hint to humans what the meaning of the Token is,\n     * and does not have any effect on the evaluation.\n     *\n     * Must contain only alphanumeric and simple separator characters (_.:-).\n     *\n     * @param valueOrFunction What this token will evaluate to, literal or function.\n     * @param displayName A human-readable display hint for this Token\n     */\n    constructor(private readonly valueOrFunction?: any, private readonly displayName?: string) {\n    }\n\n    /**\n     * @returns The resolved value for this token.\n     */\n    public resolve(): any {\n        let value = this.valueOrFunction;\n        if (typeof(value) === 'function') {\n            value = value();\n        }\n\n        return value;\n    }\n\n    /**\n     * Return a reversible string representation of this token\n     *\n     * If the Token is initialized with a literal, the stringified value of the\n     * literal is returned. Otherwise, a special quoted string representation\n     * of the Token is returned that can be embedded into other strings.\n     *\n     * Strings with quoted Tokens in them can be restored back into\n     * complex values with the Tokens restored by calling `resolve()`\n     * on the string.\n     */\n    public toString(): string {\n        const valueType = typeof this.valueOrFunction;\n        // Optimization: if we can immediately resolve this, don't bother\n        // registering a Token.\n        if (valueType === 'string' || valueType === 'number' || valueType === 'boolean') {\n            return this.valueOrFunction.toString();\n        }\n\n        if (this.tokenKey === undefined) {\n            this.tokenKey = TOKEN_STRING_MAP.register(this, this.displayName);\n        }\n        return this.tokenKey;\n    }\n\n    /**\n     * Turn this Token into JSON\n     *\n     * This gets called by JSON.stringify(). We want to prohibit this, because\n     * it's not possible to do this properly, so we just throw an error here.\n     */\n    public toJSON(): any {\n        // tslint:disable-next-line:max-line-length\n        throw new Error('JSON.stringify() cannot be applied to structure with a Token in it. Use a document-specific stringification method instead.');\n    }\n\n    /**\n     * Return a concated version of this Token in a string context\n     *\n     * The default implementation of this combines strings, but specialized\n     * implements of Token can return a more appropriate value.\n     */\n    public concat(left: any | undefined, right: any | undefined): Token {\n        const parts = [left, resolve(this), right].filter(x => x !== undefined);\n        return new Token(parts.map(x => `${x}`).join(''));\n    }\n}\n\n/**\n * Returns true if obj is a token (i.e. has the resolve() method)\n * @param obj The object to test.\n */\nexport function isToken(obj: any): obj is Token {\n    return typeof(obj[RESOLVE_METHOD]) === 'function';\n}\n\n/**\n * Resolves an object by evaluating all tokens and removing any undefined or empty objects or arrays.\n * Values can only be primitives, arrays or tokens. Other objects (i.e. with methods) will be rejected.\n *\n * @param obj The object to resolve.\n * @param prefix Prefix key path components for diagnostics.\n */\nexport function resolve(obj: any, prefix?: string[]): any {\n    const path = prefix || [ ];\n    const pathName = '/' + path.join('/');\n\n    // protect against cyclic references by limiting depth.\n    if (path.length > 200) {\n        throw new Error('Unable to resolve object tree with circular reference. Path: ' + pathName);\n    }\n\n    //\n    // undefined\n    //\n\n    if (typeof(obj) === 'undefined') {\n        return undefined;\n    }\n\n    //\n    // null\n    //\n\n    if (obj === null) {\n        return null;\n    }\n\n    //\n    // functions - not supported (only tokens are supported)\n    //\n\n    if (typeof(obj) === 'function') {\n        throw new Error(`Trying to resolve a non-data object. Only token are supported for lazy evaluation. Path: ${pathName}. Object: ${obj}`);\n    }\n\n    //\n    // string - potentially replace all stringified Tokens\n    //\n    if (typeof(obj) === 'string') {\n        return TOKEN_STRING_MAP.resolveMarkers(obj as string);\n    }\n\n    //\n    // primitives - as-is\n    //\n\n    if (typeof(obj) !== 'object' || obj instanceof Date) {\n        return obj;\n    }\n\n    //\n    // tokens - invoke 'resolve' and continue to resolve recursively\n    //\n\n    if (isToken(obj)) {\n        const value = obj[RESOLVE_METHOD]();\n        return resolve(value, path);\n    }\n\n    //\n    // arrays - resolve all values, remove undefined and remove empty arrays\n    //\n\n    if (Array.isArray(obj)) {\n        const arr = obj\n            .map((x, i) => resolve(x, path.concat(i.toString())))\n            .filter(x => typeof(x) !== 'undefined');\n\n        return arr;\n    }\n\n    //\n    // objects - deep-resolve all values\n    //\n\n    // Must not be a Construct at this point, otherwise you probably made a type\n    // mistake somewhere and resolve will get into an infinite loop recursing into\n    // child.parent <---> parent.children\n    if (obj instanceof Construct) {\n        throw new Error('Trying to resolve() a Construct at ' + pathName);\n    }\n\n    const result: any = { };\n    for (const key of Object.keys(obj)) {\n        const value = resolve(obj[key], path.concat(key));\n\n        // skip undefined\n        if (typeof(value) === 'undefined') {\n            continue;\n        }\n\n        result[key] = value;\n    }\n\n    return result;\n}\n\n/**\n * Central place where we keep a mapping from Tokens to their String representation\n *\n * The string representation is used to embed token into strings,\n * and stored to be able to\n *\n * All instances of TokenStringMap share the same storage, so that this process\n * works even when different copies of the library are loaded.\n */\nclass TokenStringMap {\n    private readonly tokenMap: {[key: string]: Token};\n\n    constructor() {\n        const glob = global as any;\n        this.tokenMap = glob.__cdkTokenMap = glob.__cdkTokenMap || {};\n    }\n\n    /**\n     * Generating a unique string for this Token, returning a key\n     *\n     * Every call for the same Token will produce a new unique string, no\n     * attempt is made to deduplicate. Token objects should cache the\n     * value themselves, if required.\n     *\n     * The token can choose (part of) its own representation string with a\n     * hint. This may be used to produce aesthetically pleasing and\n     * recognizable token representations for humans.\n     */\n    public register(token: Token, representationHint?: string): string {\n        const counter = Object.keys(this.tokenMap).length;\n        const representation = representationHint || `TOKEN`;\n\n        const key = `${representation}.${counter}`;\n        if (new RegExp(`[^${VALID_KEY_CHARS}]`).exec(key)) {\n            throw new Error(`Invalid characters in token representation: ${key}`);\n        }\n\n        this.tokenMap[key] = token;\n        return `${BEGIN_TOKEN_MARKER}${key}${END_TOKEN_MARKER}`;\n    }\n\n    /**\n     * Replace any Token markers in this string with their resolved values\n     */\n    public resolveMarkers(s: string): any {\n        const str = new TokenString(s, BEGIN_TOKEN_MARKER, `[${VALID_KEY_CHARS}]+`, END_TOKEN_MARKER);\n        const fragments = str.split(this.lookupToken.bind(this));\n        return fragments.join();\n    }\n\n    /**\n     * Find a Token by key\n     */\n    public lookupToken(key: string): Token {\n        if (!(key in this.tokenMap)) {\n            throw new Error(`Unrecognized token key: ${key}`);\n        }\n\n        return this.tokenMap[key];\n    }\n}\n\nconst BEGIN_TOKEN_MARKER = '${Token[';\nconst END_TOKEN_MARKER = ']}';\nconst VALID_KEY_CHARS = 'a-zA-Z0-9:._-';\n\n/**\n * Singleton instance of the token string map\n */\nconst TOKEN_STRING_MAP = new TokenStringMap();\n\n/**\n * Interface that Token joiners implement\n */\nexport interface ITokenJoiner {\n    /**\n     * The name of the joiner.\n     *\n     * Must be unique per joiner: this value will be used to assert that there\n     * is exactly only type of joiner in a join operation.\n     */\n    id: string;\n\n    /**\n     * Return the language intrinsic that will combine the strings in the given engine\n     */\n    join(fragments: any[]): any;\n}\n\n/**\n * A string with markers in it that can be resolved to external values\n */\nclass TokenString {\n    constructor(\n        private readonly str: string,\n        private readonly beginMarker: string,\n        private readonly idPattern: string,\n        private readonly endMarker: string) {\n    }\n\n    /**\n     * Split string on markers, substituting markers with Tokens\n     */\n    public split(lookup: (id: string) => Token): TokenStringFragments {\n        const re = new RegExp(`${regexQuote(this.beginMarker)}(${this.idPattern})${regexQuote(this.endMarker)}`, 'g');\n        const ret = new TokenStringFragments();\n\n        let rest = 0;\n        let m = re.exec(this.str);\n        while (m) {\n            if (m.index > rest) {\n                ret.addString(this.str.substring(rest, m.index));\n            }\n\n            ret.addToken(lookup(m[1]));\n\n            rest = re.lastIndex;\n            m = re.exec(this.str);\n        }\n\n        if (rest < this.str.length) {\n            ret.addString(this.str.substring(rest));\n        }\n\n        return ret;\n    }\n}\n\n/**\n * Result of the split of a string with Tokens\n *\n * Either a literal part of the string, or an unresolved Token.\n */\ntype StringFragment = { type: 'string'; str: string };\ntype TokenFragment = { type: 'token'; token: Token };\ntype Fragment =  StringFragment | TokenFragment;\n\n/**\n * Fragments of a string with markers\n */\nclass TokenStringFragments {\n    private readonly fragments = new Array<Fragment>();\n\n    public values(): any[] {\n        return this.fragments.map(f => f.type === 'token' ? resolve(f.token) : f.str);\n    }\n\n    public addString(str: string) {\n        this.fragments.push({ type: 'string', str });\n    }\n\n    public addToken(token: Token) {\n        this.fragments.push({ type: 'token', token });\n    }\n\n    /**\n     * Combine the resolved string fragments using the Tokens to join.\n     *\n     * Resolves the result.\n     */\n    public join(): any {\n        if (this.fragments.length === 0) { return ''; }\n        if (this.fragments.length === 1) { return resolveFragment(this.fragments[0]); }\n\n        const first = this.fragments[0];\n\n        let i;\n        let token: Token;\n\n        if (first.type === 'token') {\n            token = first.token;\n            i = 1;\n        } else {\n            // We never have two strings in a row\n            token = (this.fragments[1] as TokenFragment).token.concat(first.str, undefined);\n            i = 2;\n        }\n\n        while (i < this.fragments.length) {\n            token = token.concat(undefined, resolveFragment(this.fragments[i]));\n            i++;\n        }\n\n        return resolve(token);\n    }\n}\n\n/**\n * Resolve the value from a single fragment\n */\nfunction resolveFragment(fragment: Fragment): any {\n    return fragment.type === 'string' ? fragment.str : resolve(fragment.token);\n}\n\n/**\n * Quote a string for use in a regex\n */\nfunction regexQuote(s: string) {\n    return s.replace(/[.?*+^$[\\]\\\\(){}|-]/g, \"\\\\$&\");\n}"]}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"tokens.js","sourceRoot":"","sources":["tokens.ts"],"names":[],"mappings":"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","sourcesContent":["import { Construct } from \"./construct\";\n\n/**\n * If objects has a function property by this name, they will be considered tokens, and this\n * function will be called to resolve the value for this object.\n */\nexport const RESOLVE_METHOD = 'resolve';\n\n/**\n * Represents a special or lazily-evaluated value.\n *\n * Can be used to delay evaluation of a certain value in case, for example,\n * that it requires some context or late-bound data. Can also be used to\n * mark values that need special processing at document rendering time.\n *\n * Tokens can be embedded into strings while retaining their original\n * semantics.\n */\nexport class Token {\n    private tokenKey?: string;\n\n    /**\n     * Creates a token that resolves to `value`.\n     *\n     * If value is a function, the function is evaluated upon resolution and\n     * the value it returns will be used as the token's value.\n     *\n     * displayName is used to represent the Token when it's embedded into a string; it\n     * will look something like this:\n     *\n     *      \"embedded in a larger string is ${Token[DISPLAY_NAME.123]}\"\n     *\n     * This value is used as a hint to humans what the meaning of the Token is,\n     * and does not have any effect on the evaluation.\n     *\n     * Must contain only alphanumeric and simple separator characters (_.:-).\n     *\n     * @param valueOrFunction What this token will evaluate to, literal or function.\n     * @param displayName A human-readable display hint for this Token\n     */\n    constructor(private readonly valueOrFunction?: any, private readonly displayName?: string) {\n    }\n\n    /**\n     * @returns The resolved value for this token.\n     */\n    public resolve(): any {\n        let value = this.valueOrFunction;\n        if (typeof(value) === 'function') {\n            value = value();\n        }\n\n        return value;\n    }\n\n    /**\n     * Return a reversible string representation of this token\n     *\n     * If the Token is initialized with a literal, the stringified value of the\n     * literal is returned. Otherwise, a special quoted string representation\n     * of the Token is returned that can be embedded into other strings.\n     *\n     * Strings with quoted Tokens in them can be restored back into\n     * complex values with the Tokens restored by calling `resolve()`\n     * on the string.\n     */\n    public toString(): string {\n        const valueType = typeof this.valueOrFunction;\n        // Optimization: if we can immediately resolve this, don't bother\n        // registering a Token.\n        if (valueType === 'string' || valueType === 'number' || valueType === 'boolean') {\n            return this.valueOrFunction.toString();\n        }\n\n        if (this.tokenKey === undefined) {\n            this.tokenKey = TOKEN_STRING_MAP.register(this, this.displayName);\n        }\n        return this.tokenKey;\n    }\n\n    /**\n     * Turn this Token into JSON\n     *\n     * This gets called by JSON.stringify(). We want to prohibit this, because\n     * it's not possible to do this properly, so we just throw an error here.\n     */\n    public toJSON(): any {\n        // tslint:disable-next-line:max-line-length\n        throw new Error('JSON.stringify() cannot be applied to structure with a Token in it. Use a document-specific stringification method instead.');\n    }\n\n    /**\n     * Return a concated version of this Token in a string context\n     *\n     * The default implementation of this combines strings, but specialized\n     * implements of Token can return a more appropriate value.\n     */\n    public concat(left: any | undefined, right: any | undefined): Token {\n        const parts = [left, resolve(this), right].filter(x => x !== undefined);\n        return new Token(parts.map(x => `${x}`).join(''));\n    }\n}\n\n/**\n * Returns true if obj is a token (i.e. has the resolve() method or is a string\n * that includes token markers).\n * @param obj The object to test.\n */\nexport function unresolved(obj: any): obj is Token {\n    if (typeof(obj) === 'string') {\n        return TOKEN_STRING_MAP.createTokenString(obj).test();\n    } else {\n        return typeof(obj[RESOLVE_METHOD]) === 'function';\n    }\n}\n\n/**\n * Resolves an object by evaluating all tokens and removing any undefined or empty objects or arrays.\n * Values can only be primitives, arrays or tokens. Other objects (i.e. with methods) will be rejected.\n *\n * @param obj The object to resolve.\n * @param prefix Prefix key path components for diagnostics.\n */\nexport function resolve(obj: any, prefix?: string[]): any {\n    const path = prefix || [ ];\n    const pathName = '/' + path.join('/');\n\n    // protect against cyclic references by limiting depth.\n    if (path.length > 200) {\n        throw new Error('Unable to resolve object tree with circular reference. Path: ' + pathName);\n    }\n\n    //\n    // undefined\n    //\n\n    if (typeof(obj) === 'undefined') {\n        return undefined;\n    }\n\n    //\n    // null\n    //\n\n    if (obj === null) {\n        return null;\n    }\n\n    //\n    // functions - not supported (only tokens are supported)\n    //\n\n    if (typeof(obj) === 'function') {\n        throw new Error(`Trying to resolve a non-data object. Only token are supported for lazy evaluation. Path: ${pathName}. Object: ${obj}`);\n    }\n\n    //\n    // string - potentially replace all stringified Tokens\n    //\n    if (typeof(obj) === 'string') {\n        return TOKEN_STRING_MAP.resolveMarkers(obj as string);\n    }\n\n    //\n    // primitives - as-is\n    //\n\n    if (typeof(obj) !== 'object' || obj instanceof Date) {\n        return obj;\n    }\n\n    //\n    // tokens - invoke 'resolve' and continue to resolve recursively\n    //\n\n    if (unresolved(obj)) {\n        const value = obj[RESOLVE_METHOD]();\n        return resolve(value, path);\n    }\n\n    //\n    // arrays - resolve all values, remove undefined and remove empty arrays\n    //\n\n    if (Array.isArray(obj)) {\n        const arr = obj\n            .map((x, i) => resolve(x, path.concat(i.toString())))\n            .filter(x => typeof(x) !== 'undefined');\n\n        return arr;\n    }\n\n    //\n    // objects - deep-resolve all values\n    //\n\n    // Must not be a Construct at this point, otherwise you probably made a type\n    // mistake somewhere and resolve will get into an infinite loop recursing into\n    // child.parent <---> parent.children\n    if (obj instanceof Construct) {\n        throw new Error('Trying to resolve() a Construct at ' + pathName);\n    }\n\n    const result: any = { };\n    for (const key of Object.keys(obj)) {\n        const resolvedKey = resolve(key);\n        if (typeof(resolvedKey) !== 'string') {\n            throw new Error(`The key \"${key}\" has been resolved to ${JSON.stringify(resolvedKey)} but must be resolvable to a string`);\n        }\n\n        const value = resolve(obj[key], path.concat(key));\n\n        // skip undefined\n        if (typeof(value) === 'undefined') {\n            continue;\n        }\n\n        result[resolvedKey] = value;\n    }\n\n    return result;\n}\n\n/**\n * Central place where we keep a mapping from Tokens to their String representation\n *\n * The string representation is used to embed token into strings,\n * and stored to be able to\n *\n * All instances of TokenStringMap share the same storage, so that this process\n * works even when different copies of the library are loaded.\n */\nclass TokenStringMap {\n    private readonly tokenMap: {[key: string]: Token};\n\n    constructor() {\n        const glob = global as any;\n        this.tokenMap = glob.__cdkTokenMap = glob.__cdkTokenMap || {};\n    }\n\n    /**\n     * Generating a unique string for this Token, returning a key\n     *\n     * Every call for the same Token will produce a new unique string, no\n     * attempt is made to deduplicate. Token objects should cache the\n     * value themselves, if required.\n     *\n     * The token can choose (part of) its own representation string with a\n     * hint. This may be used to produce aesthetically pleasing and\n     * recognizable token representations for humans.\n     */\n    public register(token: Token, representationHint?: string): string {\n        const counter = Object.keys(this.tokenMap).length;\n        const representation = representationHint || `TOKEN`;\n\n        const key = `${representation}.${counter}`;\n        if (new RegExp(`[^${VALID_KEY_CHARS}]`).exec(key)) {\n            throw new Error(`Invalid characters in token representation: ${key}`);\n        }\n\n        this.tokenMap[key] = token;\n        return `${BEGIN_TOKEN_MARKER}${key}${END_TOKEN_MARKER}`;\n    }\n\n    /**\n     * Returns a `TokenString` for this string.\n     */\n    public createTokenString(s: string) {\n        return new TokenString(s, BEGIN_TOKEN_MARKER, `[${VALID_KEY_CHARS}]+`, END_TOKEN_MARKER);\n    }\n\n    /**\n     * Replace any Token markers in this string with their resolved values\n     */\n    public resolveMarkers(s: string): any {\n        const str = this.createTokenString(s);\n        const fragments = str.split(this.lookupToken.bind(this));\n        return fragments.join();\n    }\n\n    /**\n     * Find a Token by key\n     */\n    public lookupToken(key: string): Token {\n        if (!(key in this.tokenMap)) {\n            throw new Error(`Unrecognized token key: ${key}`);\n        }\n\n        return this.tokenMap[key];\n    }\n}\n\nconst BEGIN_TOKEN_MARKER = '${Token[';\nconst END_TOKEN_MARKER = ']}';\nconst VALID_KEY_CHARS = 'a-zA-Z0-9:._-';\n\n/**\n * Singleton instance of the token string map\n */\nconst TOKEN_STRING_MAP = new TokenStringMap();\n\n/**\n * Interface that Token joiners implement\n */\nexport interface ITokenJoiner {\n    /**\n     * The name of the joiner.\n     *\n     * Must be unique per joiner: this value will be used to assert that there\n     * is exactly only type of joiner in a join operation.\n     */\n    id: string;\n\n    /**\n     * Return the language intrinsic that will combine the strings in the given engine\n     */\n    join(fragments: any[]): any;\n}\n\n/**\n * A string with markers in it that can be resolved to external values\n */\nclass TokenString {\n    private pattern: string;\n\n    constructor(\n        private readonly str: string,\n        private readonly beginMarker: string,\n        private readonly idPattern: string,\n        private readonly endMarker: string) {\n        this.pattern = `${regexQuote(this.beginMarker)}(${this.idPattern})${regexQuote(this.endMarker)}`;\n    }\n\n    /**\n     * Split string on markers, substituting markers with Tokens\n     */\n    public split(lookup: (id: string) => Token): TokenStringFragments {\n        const re = new RegExp(this.pattern, 'g');\n        const ret = new TokenStringFragments();\n\n        let rest = 0;\n        let m = re.exec(this.str);\n        while (m) {\n            if (m.index > rest) {\n                ret.addString(this.str.substring(rest, m.index));\n            }\n\n            ret.addToken(lookup(m[1]));\n\n            rest = re.lastIndex;\n            m = re.exec(this.str);\n        }\n\n        if (rest < this.str.length) {\n            ret.addString(this.str.substring(rest));\n        }\n\n        return ret;\n    }\n\n    /**\n     * Indicates if this string includes tokens.\n     */\n    public test(): boolean {\n        const re = new RegExp(this.pattern, 'g');\n        return re.test(this.str);\n    }\n}\n\n/**\n * Result of the split of a string with Tokens\n *\n * Either a literal part of the string, or an unresolved Token.\n */\ntype StringFragment = { type: 'string'; str: string };\ntype TokenFragment = { type: 'token'; token: Token };\ntype Fragment =  StringFragment | TokenFragment;\n\n/**\n * Fragments of a string with markers\n */\nclass TokenStringFragments {\n    private readonly fragments = new Array<Fragment>();\n\n    public values(): any[] {\n        return this.fragments.map(f => f.type === 'token' ? resolve(f.token) : f.str);\n    }\n\n    public addString(str: string) {\n        this.fragments.push({ type: 'string', str });\n    }\n\n    public addToken(token: Token) {\n        this.fragments.push({ type: 'token', token });\n    }\n\n    /**\n     * Combine the resolved string fragments using the Tokens to join.\n     *\n     * Resolves the result.\n     */\n    public join(): any {\n        if (this.fragments.length === 0) { return ''; }\n        if (this.fragments.length === 1) { return resolveFragment(this.fragments[0]); }\n\n        const first = this.fragments[0];\n\n        let i;\n        let token: Token;\n\n        if (first.type === 'token') {\n            token = first.token;\n            i = 1;\n        } else {\n            // We never have two strings in a row\n            token = (this.fragments[1] as TokenFragment).token.concat(first.str, undefined);\n            i = 2;\n        }\n\n        while (i < this.fragments.length) {\n            token = token.concat(undefined, resolveFragment(this.fragments[i]));\n            i++;\n        }\n\n        return resolve(token);\n    }\n}\n\n/**\n * Resolve the value from a single fragment\n */\nfunction resolveFragment(fragment: Fragment): any {\n    return fragment.type === 'string' ? fragment.str : resolve(fragment.token);\n}\n\n/**\n * Quote a string for use in a regex\n */\nfunction regexQuote(s: string) {\n    return s.replace(/[.?*+^$[\\]\\\\(){}|-]/g, \"\\\\$&\");\n}"]}

@@ -5,3 +5,3 @@ {

"cli-color@0.1.7",
"/codebuild/output/src515441016/src/packages/@aws-cdk/cdk"
"/codebuild/output/src577315738/src/packages/@aws-cdk/cdk"
]

@@ -30,3 +30,3 @@ ],

"_spec": "0.1.7",
"_where": "/codebuild/output/src515441016/src/packages/@aws-cdk/cdk",
"_where": "/codebuild/output/src577315738/src/packages/@aws-cdk/cdk",
"author": {

@@ -33,0 +33,0 @@ "name": "Mariusz Nowak",

@@ -5,3 +5,3 @@ {

"difflib@0.2.4",
"/codebuild/output/src515441016/src/packages/@aws-cdk/cdk"
"/codebuild/output/src577315738/src/packages/@aws-cdk/cdk"
]

@@ -30,3 +30,3 @@ ],

"_spec": "0.2.4",
"_where": "/codebuild/output/src515441016/src/packages/@aws-cdk/cdk",
"_where": "/codebuild/output/src577315738/src/packages/@aws-cdk/cdk",
"author": {

@@ -33,0 +33,0 @@ "name": "Xueqiao Xu",

@@ -5,3 +5,3 @@ {

"dreamopt@0.6.0",
"/codebuild/output/src515441016/src/packages/@aws-cdk/cdk"
"/codebuild/output/src577315738/src/packages/@aws-cdk/cdk"
]

@@ -30,3 +30,3 @@ ],

"_spec": "0.6.0",
"_where": "/codebuild/output/src515441016/src/packages/@aws-cdk/cdk",
"_where": "/codebuild/output/src577315738/src/packages/@aws-cdk/cdk",
"author": {

@@ -33,0 +33,0 @@ "name": "Andrey Tarantsov",

@@ -5,3 +5,3 @@ {

"es5-ext@0.8.2",
"/codebuild/output/src515441016/src/packages/@aws-cdk/cdk"
"/codebuild/output/src577315738/src/packages/@aws-cdk/cdk"
]

@@ -30,3 +30,3 @@ ],

"_spec": "0.8.2",
"_where": "/codebuild/output/src515441016/src/packages/@aws-cdk/cdk",
"_where": "/codebuild/output/src577315738/src/packages/@aws-cdk/cdk",
"author": {

@@ -33,0 +33,0 @@ "name": "Mariusz Nowak",

@@ -5,3 +5,3 @@ {

"heap@0.2.6",
"/codebuild/output/src515441016/src/packages/@aws-cdk/cdk"
"/codebuild/output/src577315738/src/packages/@aws-cdk/cdk"
]

@@ -30,3 +30,3 @@ ],

"_spec": "0.2.6",
"_where": "/codebuild/output/src515441016/src/packages/@aws-cdk/cdk",
"_where": "/codebuild/output/src577315738/src/packages/@aws-cdk/cdk",
"author": {

@@ -33,0 +33,0 @@ "name": "Xueqiao Xu",

@@ -5,3 +5,3 @@ {

"js-base64@2.4.9",
"/codebuild/output/src515441016/src/packages/@aws-cdk/cdk"
"/codebuild/output/src577315738/src/packages/@aws-cdk/cdk"
]

@@ -30,3 +30,3 @@ ],

"_spec": "2.4.9",
"_where": "/codebuild/output/src515441016/src/packages/@aws-cdk/cdk",
"_where": "/codebuild/output/src577315738/src/packages/@aws-cdk/cdk",
"author": {

@@ -33,0 +33,0 @@ "name": "Dan Kogai"

@@ -5,3 +5,3 @@ {

"json-diff@0.3.1",
"/codebuild/output/src515441016/src/packages/@aws-cdk/cdk"
"/codebuild/output/src577315738/src/packages/@aws-cdk/cdk"
]

@@ -30,3 +30,3 @@ ],

"_spec": "0.3.1",
"_where": "/codebuild/output/src515441016/src/packages/@aws-cdk/cdk",
"_where": "/codebuild/output/src577315738/src/packages/@aws-cdk/cdk",
"author": {

@@ -33,0 +33,0 @@ "name": "Andrey Tarantsov",

@@ -5,3 +5,3 @@ {

"wordwrap@1.0.0",
"/codebuild/output/src515441016/src/packages/@aws-cdk/cdk"
"/codebuild/output/src577315738/src/packages/@aws-cdk/cdk"
]

@@ -30,3 +30,3 @@ ],

"_spec": "1.0.0",
"_where": "/codebuild/output/src515441016/src/packages/@aws-cdk/cdk",
"_where": "/codebuild/output/src577315738/src/packages/@aws-cdk/cdk",
"author": {

@@ -33,0 +33,0 @@ "name": "James Halliday",

{
"name": "@aws-cdk/cdk",
"version": "0.9.1",
"version": "0.9.2",
"description": "AWS Cloud Development Kit Core Library",

@@ -56,8 +56,8 @@ "main": "lib/index.js",

"@types/js-base64": "^2.3.1",
"cdk-build-tools": "^0.9.1",
"cfn2ts": "^0.9.1",
"pkglint": "^0.9.1"
"cdk-build-tools": "^0.9.2",
"cfn2ts": "^0.9.2",
"pkglint": "^0.9.2"
},
"dependencies": {
"@aws-cdk/cx-api": "^0.9.1",
"@aws-cdk/cx-api": "^0.9.2",
"js-base64": "^2.4.5",

@@ -64,0 +64,0 @@ "json-diff": "^0.3.1"

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

'create from components with defaults'(test) {
const arn = lib_1.Arn.fromComponents({
const arn = lib_1.ArnUtils.fromComponents({
service: 'sqs',

@@ -25,3 +25,3 @@ resource: 'myqueuename'

'create from components with specific values for the various components'(test) {
const arn = lib_1.Arn.fromComponents({
const arn = lib_1.ArnUtils.fromComponents({
service: 'dynamodb',

@@ -51,3 +51,3 @@ resource: 'table',

'allow empty string in components'(test) {
const arn = lib_1.Arn.fromComponents({
const arn = lib_1.ArnUtils.fromComponents({
service: 's3',

@@ -80,3 +80,3 @@ resource: 'my-bucket',

'resourcePathSep can be set to ":" instead of the default "/"'(test) {
const arn = lib_1.Arn.fromComponents({
const arn = lib_1.ArnUtils.fromComponents({
service: 'codedeploy',

@@ -104,3 +104,3 @@ resource: 'application',

'fails if resourcePathSep is neither ":" nor "/"'(test) {
test.throws(() => lib_1.Arn.fromComponents({
test.throws(() => lib_1.ArnUtils.fromComponents({
service: 'foo',

@@ -115,15 +115,15 @@ resource: 'bar',

'if doesn\'t start with "arn:"'(test) {
test.throws(() => lib_1.Arn.parse("barn:foo:x:a:1:2"), /ARNs must start with "arn:": barn:foo/);
test.throws(() => lib_1.ArnUtils.parse("barn:foo:x:a:1:2"), /ARNs must start with "arn:": barn:foo/);
test.done();
},
'if the ARN doesnt have enough components'(test) {
test.throws(() => lib_1.Arn.parse('arn:is:too:short'), /ARNs must have at least 6 components: arn:is:too:short/);
test.throws(() => lib_1.ArnUtils.parse('arn:is:too:short'), /ARNs must have at least 6 components: arn:is:too:short/);
test.done();
},
'if "service" is not specified'(test) {
test.throws(() => lib_1.Arn.parse('arn:aws::4:5:6'), /The `service` component \(3rd component\) is required/);
test.throws(() => lib_1.ArnUtils.parse('arn:aws::4:5:6'), /The `service` component \(3rd component\) is required/);
test.done();
},
'if "resource" is not specified'(test) {
test.throws(() => lib_1.Arn.parse('arn:aws:service:::'), /The `resource` component \(6th component\) is required/);
test.throws(() => lib_1.ArnUtils.parse('arn:aws:service:::'), /The `resource` component \(6th component\) is required/);
test.done();

@@ -173,3 +173,3 @@ }

const expected = tests[arn];
test.deepEqual(lib_1.Arn.parse(arn), expected, arn);
test.deepEqual(lib_1.ArnUtils.parse(arn), expected, arn);
});

@@ -180,3 +180,3 @@ test.done();

const theToken = { Ref: 'SomeParameter' };
const parsed = lib_1.Arn.parseToken(new lib_1.Token(() => theToken), ':');
const parsed = lib_1.ArnUtils.parseToken(new lib_1.Token(() => theToken), ':');
test.deepEqual(lib_1.resolve(parsed.partition), { 'Fn::Select': [1, { 'Fn::Split': [':', theToken] }] });

@@ -193,3 +193,3 @@ test.deepEqual(lib_1.resolve(parsed.service), { 'Fn::Select': [2, { 'Fn::Split': [':', theToken] }] });

const theToken = { Ref: 'SomeParameter' };
const parsed = lib_1.Arn.parseToken(new lib_1.Token(() => theToken));
const parsed = lib_1.ArnUtils.parseToken(new lib_1.Token(() => theToken));
test.equal(parsed.sep, '/');

@@ -204,2 +204,2 @@ // tslint:disable-next-line:max-line-length

};
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"test.arn.js","sourceRoot":"","sources":["test.arn.ts"],"names":[],"mappings":"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","sourcesContent":["import { Test } from 'nodeunit';\nimport { Arn, ArnComponents, resolve, Token } from '../../lib';\n\nexport = {\n    'create from components with defaults'(test: Test) {\n        const arn = Arn.fromComponents({\n            service: 'sqs',\n            resource: 'myqueuename'\n        });\n\n        test.deepEqual(resolve(arn), { 'Fn::Join':\n        [ '',\n          [ 'arn',\n            ':',\n            { Ref: 'AWS::Partition' },\n            ':',\n            'sqs',\n            ':',\n            { Ref: 'AWS::Region' },\n            ':',\n            { Ref: 'AWS::AccountId' },\n            ':',\n            'myqueuename' ] ] });\n        test.done();\n    },\n\n    'create from components with specific values for the various components'(test: Test) {\n        const arn = Arn.fromComponents({\n            service: 'dynamodb',\n            resource: 'table',\n            account: '123456789012',\n            region: 'us-east-1',\n            partition: 'aws-cn',\n            resourceName: 'mytable/stream/label'\n        });\n\n        test.deepEqual(resolve(arn), { 'Fn::Join':\n        [ '',\n          [ 'arn',\n            ':',\n            'aws-cn',\n            ':',\n            'dynamodb',\n            ':',\n            'us-east-1',\n            ':',\n            '123456789012',\n            ':',\n            'table',\n            '/',\n            'mytable/stream/label' ] ] });\n        test.done();\n    },\n\n    'allow empty string in components'(test: Test) {\n        const arn = Arn.fromComponents({\n            service: 's3',\n            resource: 'my-bucket',\n            account: '',\n            region: '',\n            partition: 'aws-cn',\n        });\n\n        test.deepEqual(resolve(arn), {\n            'Fn::Join': [\n                '',\n                [\n                    'arn',\n                    ':',\n                    'aws-cn',\n                    ':',\n                    's3',\n                    ':',\n                    '',\n                    ':',\n                    '',\n                    ':',\n                    'my-bucket',\n                ]\n            ]\n        });\n\n        test.done();\n    },\n\n    'resourcePathSep can be set to \":\" instead of the default \"/\"'(test: Test) {\n        const arn = Arn.fromComponents({\n            service: 'codedeploy',\n            resource: 'application',\n            sep: ':',\n            resourceName: 'WordPress_App'\n        });\n\n        test.deepEqual(resolve(arn), { 'Fn::Join':\n        [ '',\n          [ 'arn',\n            ':',\n            { Ref: 'AWS::Partition' },\n            ':',\n            'codedeploy',\n            ':',\n            { Ref: 'AWS::Region' },\n            ':',\n            { Ref: 'AWS::AccountId' },\n            ':',\n            'application',\n            ':',\n            'WordPress_App' ] ] });\n        test.done();\n    },\n\n    'fails if resourcePathSep is neither \":\" nor \"/\"'(test: Test) {\n        test.throws(() => Arn.fromComponents({\n            service: 'foo',\n            resource: 'bar',\n            sep: 'x' }));\n        test.done();\n    },\n\n    'Arn.parse(s)': {\n\n        'fails': {\n            'if doesn\\'t start with \"arn:\"'(test: Test) {\n                test.throws(() => Arn.parse(\"barn:foo:x:a:1:2\"), /ARNs must start with \"arn:\": barn:foo/);\n                test.done();\n            },\n\n            'if the ARN doesnt have enough components'(test: Test) {\n                test.throws(() => Arn.parse('arn:is:too:short'), /ARNs must have at least 6 components: arn:is:too:short/);\n                test.done();\n            },\n\n            'if \"service\" is not specified'(test: Test) {\n                test.throws(() => Arn.parse('arn:aws::4:5:6'), /The `service` component \\(3rd component\\) is required/);\n                test.done();\n            },\n\n            'if \"resource\" is not specified'(test: Test) {\n                test.throws(() => Arn.parse('arn:aws:service:::'), /The `resource` component \\(6th component\\) is required/);\n                test.done();\n            }\n        },\n\n        'various successful parses'(test: Test) {\n            const tests: { [arn: string]: ArnComponents } = {\n                'arn:aws:a4b:region:accountid:resourcetype/resource': {\n                    partition: 'aws',\n                    service: 'a4b',\n                    region: 'region',\n                    account: 'accountid',\n                    resource: 'resourcetype',\n                    resourceName: 'resource',\n                    sep: '/'\n                },\n                'arn:aws:apigateway:us-east-1::a123456789012bc3de45678901f23a45:/test/mydemoresource/*': {\n                    partition: 'aws',\n                    service: 'apigateway',\n                    region: 'us-east-1',\n                    resource: 'a123456789012bc3de45678901f23a45',\n                    sep: ':',\n                    resourceName: '/test/mydemoresource/*'\n                },\n                'arn:aws-cn:cloud9::123456789012:environment:81e900317347585a0601e04c8d52eaEX': {\n                    partition: 'aws-cn',\n                    service: 'cloud9',\n                    account: '123456789012',\n                    resource: 'environment',\n                    resourceName: '81e900317347585a0601e04c8d52eaEX',\n                    sep: ':'\n                },\n                'arn::cognito-sync:::identitypool/us-east-1:1a1a1a1a-ffff-1111-9999-12345678:bla': {\n                    service: 'cognito-sync',\n                    resource: 'identitypool',\n                    resourceName: 'us-east-1:1a1a1a1a-ffff-1111-9999-12345678:bla',\n                    sep: '/'\n                },\n                'arn:aws:s3:::my_corporate_bucket': {\n                    partition: 'aws',\n                    service: 's3',\n                    resource: 'my_corporate_bucket'\n                }\n            };\n\n            Object.keys(tests).forEach(arn => {\n                const expected = tests[arn];\n                test.deepEqual(Arn.parse(arn), expected, arn);\n            });\n\n            test.done();\n        },\n\n        'a Token with : separator'(test: Test) {\n            const theToken = { Ref: 'SomeParameter' };\n            const parsed = Arn.parseToken(new Token(() => theToken), ':');\n\n            test.deepEqual(resolve(parsed.partition), { 'Fn::Select': [ 1, { 'Fn::Split': [ ':', theToken ]} ]});\n            test.deepEqual(resolve(parsed.service), { 'Fn::Select': [ 2, { 'Fn::Split': [ ':', theToken ]} ]});\n            test.deepEqual(resolve(parsed.region), { 'Fn::Select': [ 3, { 'Fn::Split': [ ':', theToken ]} ]});\n            test.deepEqual(resolve(parsed.account), { 'Fn::Select': [ 4, { 'Fn::Split': [ ':', theToken ]} ]});\n            test.deepEqual(resolve(parsed.resource), { 'Fn::Select': [ 5, { 'Fn::Split': [ ':', theToken ]} ]});\n            test.deepEqual(resolve(parsed.resourceName), { 'Fn::Select': [ 6, { 'Fn::Split': [ ':', theToken ]} ]});\n            test.equal(parsed.sep, ':');\n\n            test.done();\n        },\n\n        'a Token with / separator'(test: Test) {\n            const theToken = { Ref: 'SomeParameter' };\n            const parsed = Arn.parseToken(new Token(() => theToken));\n\n            test.equal(parsed.sep, '/');\n\n            // tslint:disable-next-line:max-line-length\n            test.deepEqual(resolve(parsed.resource), { 'Fn::Select': [ 0, { 'Fn::Split': [ '/', { 'Fn::Select': [ 5, { 'Fn::Split': [ ':', theToken ]} ]} ]} ]});\n            // tslint:disable-next-line:max-line-length\n            test.deepEqual(resolve(parsed.resourceName), { 'Fn::Select': [ 1, { 'Fn::Split': [ '/', { 'Fn::Select': [ 5, { 'Fn::Split': [ ':', theToken ]} ]} ]} ]});\n\n            test.done();\n        }\n    },\n\n};"]}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"test.arn.js","sourceRoot":"","sources":["test.arn.ts"],"names":[],"mappings":"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","sourcesContent":["import { Test } from 'nodeunit';\nimport { ArnComponents, ArnUtils, resolve, Token } from '../../lib';\n\nexport = {\n    'create from components with defaults'(test: Test) {\n        const arn = ArnUtils.fromComponents({\n            service: 'sqs',\n            resource: 'myqueuename'\n        });\n\n        test.deepEqual(resolve(arn), { 'Fn::Join':\n        [ '',\n          [ 'arn',\n            ':',\n            { Ref: 'AWS::Partition' },\n            ':',\n            'sqs',\n            ':',\n            { Ref: 'AWS::Region' },\n            ':',\n            { Ref: 'AWS::AccountId' },\n            ':',\n            'myqueuename' ] ] });\n        test.done();\n    },\n\n    'create from components with specific values for the various components'(test: Test) {\n        const arn = ArnUtils.fromComponents({\n            service: 'dynamodb',\n            resource: 'table',\n            account: '123456789012',\n            region: 'us-east-1',\n            partition: 'aws-cn',\n            resourceName: 'mytable/stream/label'\n        });\n\n        test.deepEqual(resolve(arn), { 'Fn::Join':\n        [ '',\n          [ 'arn',\n            ':',\n            'aws-cn',\n            ':',\n            'dynamodb',\n            ':',\n            'us-east-1',\n            ':',\n            '123456789012',\n            ':',\n            'table',\n            '/',\n            'mytable/stream/label' ] ] });\n        test.done();\n    },\n\n    'allow empty string in components'(test: Test) {\n        const arn = ArnUtils.fromComponents({\n            service: 's3',\n            resource: 'my-bucket',\n            account: '',\n            region: '',\n            partition: 'aws-cn',\n        });\n\n        test.deepEqual(resolve(arn), {\n            'Fn::Join': [\n                '',\n                [\n                    'arn',\n                    ':',\n                    'aws-cn',\n                    ':',\n                    's3',\n                    ':',\n                    '',\n                    ':',\n                    '',\n                    ':',\n                    'my-bucket',\n                ]\n            ]\n        });\n\n        test.done();\n    },\n\n    'resourcePathSep can be set to \":\" instead of the default \"/\"'(test: Test) {\n        const arn = ArnUtils.fromComponents({\n            service: 'codedeploy',\n            resource: 'application',\n            sep: ':',\n            resourceName: 'WordPress_App'\n        });\n\n        test.deepEqual(resolve(arn), { 'Fn::Join':\n        [ '',\n          [ 'arn',\n            ':',\n            { Ref: 'AWS::Partition' },\n            ':',\n            'codedeploy',\n            ':',\n            { Ref: 'AWS::Region' },\n            ':',\n            { Ref: 'AWS::AccountId' },\n            ':',\n            'application',\n            ':',\n            'WordPress_App' ] ] });\n        test.done();\n    },\n\n    'fails if resourcePathSep is neither \":\" nor \"/\"'(test: Test) {\n        test.throws(() => ArnUtils.fromComponents({\n            service: 'foo',\n            resource: 'bar',\n            sep: 'x' }));\n        test.done();\n    },\n\n    'Arn.parse(s)': {\n\n        'fails': {\n            'if doesn\\'t start with \"arn:\"'(test: Test) {\n                test.throws(() => ArnUtils.parse(\"barn:foo:x:a:1:2\"), /ARNs must start with \"arn:\": barn:foo/);\n                test.done();\n            },\n\n            'if the ARN doesnt have enough components'(test: Test) {\n                test.throws(() => ArnUtils.parse('arn:is:too:short'), /ARNs must have at least 6 components: arn:is:too:short/);\n                test.done();\n            },\n\n            'if \"service\" is not specified'(test: Test) {\n                test.throws(() => ArnUtils.parse('arn:aws::4:5:6'), /The `service` component \\(3rd component\\) is required/);\n                test.done();\n            },\n\n            'if \"resource\" is not specified'(test: Test) {\n                test.throws(() => ArnUtils.parse('arn:aws:service:::'), /The `resource` component \\(6th component\\) is required/);\n                test.done();\n            }\n        },\n\n        'various successful parses'(test: Test) {\n            const tests: { [arn: string]: ArnComponents } = {\n                'arn:aws:a4b:region:accountid:resourcetype/resource': {\n                    partition: 'aws',\n                    service: 'a4b',\n                    region: 'region',\n                    account: 'accountid',\n                    resource: 'resourcetype',\n                    resourceName: 'resource',\n                    sep: '/'\n                },\n                'arn:aws:apigateway:us-east-1::a123456789012bc3de45678901f23a45:/test/mydemoresource/*': {\n                    partition: 'aws',\n                    service: 'apigateway',\n                    region: 'us-east-1',\n                    resource: 'a123456789012bc3de45678901f23a45',\n                    sep: ':',\n                    resourceName: '/test/mydemoresource/*'\n                },\n                'arn:aws-cn:cloud9::123456789012:environment:81e900317347585a0601e04c8d52eaEX': {\n                    partition: 'aws-cn',\n                    service: 'cloud9',\n                    account: '123456789012',\n                    resource: 'environment',\n                    resourceName: '81e900317347585a0601e04c8d52eaEX',\n                    sep: ':'\n                },\n                'arn::cognito-sync:::identitypool/us-east-1:1a1a1a1a-ffff-1111-9999-12345678:bla': {\n                    service: 'cognito-sync',\n                    resource: 'identitypool',\n                    resourceName: 'us-east-1:1a1a1a1a-ffff-1111-9999-12345678:bla',\n                    sep: '/'\n                },\n                'arn:aws:s3:::my_corporate_bucket': {\n                    partition: 'aws',\n                    service: 's3',\n                    resource: 'my_corporate_bucket'\n                }\n            };\n\n            Object.keys(tests).forEach(arn => {\n                const expected = tests[arn];\n                test.deepEqual(ArnUtils.parse(arn), expected, arn);\n            });\n\n            test.done();\n        },\n\n        'a Token with : separator'(test: Test) {\n            const theToken = { Ref: 'SomeParameter' };\n            const parsed = ArnUtils.parseToken(new Token(() => theToken), ':');\n\n            test.deepEqual(resolve(parsed.partition), { 'Fn::Select': [ 1, { 'Fn::Split': [ ':', theToken ]} ]});\n            test.deepEqual(resolve(parsed.service), { 'Fn::Select': [ 2, { 'Fn::Split': [ ':', theToken ]} ]});\n            test.deepEqual(resolve(parsed.region), { 'Fn::Select': [ 3, { 'Fn::Split': [ ':', theToken ]} ]});\n            test.deepEqual(resolve(parsed.account), { 'Fn::Select': [ 4, { 'Fn::Split': [ ':', theToken ]} ]});\n            test.deepEqual(resolve(parsed.resource), { 'Fn::Select': [ 5, { 'Fn::Split': [ ':', theToken ]} ]});\n            test.deepEqual(resolve(parsed.resourceName), { 'Fn::Select': [ 6, { 'Fn::Split': [ ':', theToken ]} ]});\n            test.equal(parsed.sep, ':');\n\n            test.done();\n        },\n\n        'a Token with / separator'(test: Test) {\n            const theToken = { Ref: 'SomeParameter' };\n            const parsed = ArnUtils.parseToken(new Token(() => theToken));\n\n            test.equal(parsed.sep, '/');\n\n            // tslint:disable-next-line:max-line-length\n            test.deepEqual(resolve(parsed.resource), { 'Fn::Select': [ 0, { 'Fn::Split': [ '/', { 'Fn::Select': [ 5, { 'Fn::Split': [ ':', theToken ]} ]} ]} ]});\n            // tslint:disable-next-line:max-line-length\n            test.deepEqual(resolve(parsed.resourceName), { 'Fn::Select': [ 1, { 'Fn::Split': [ '/', { 'Fn::Select': [ 5, { 'Fn::Split': [ ':', theToken ]} ]} ]} ]});\n\n            test.done();\n        }\n    },\n\n};"]}

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

p.addActions('dynamodb:CreateTable', 'dynamodb:DeleteTable');
p.addResource(new lib_1.Arn('myQueue'));
p.addResource(new lib_1.Arn('yourQueue'));
p.addResource('myQueue');
p.addResource('yourQueue');
p.addAllResources();

@@ -32,3 +32,3 @@ p.addAwsAccountPrincipal(new lib_1.FnConcat('my', 'account', 'name').toString());

p1.addAction('sqs:SendMessage');
p1.addResource(new lib_1.Arn('*'));
p1.addResource('*');
const p2 = new lib_1.PolicyStatement();

@@ -56,3 +56,3 @@ p2.deny();

const doc = new lib_1.PolicyDocument(base);
doc.addStatement(new lib_1.PolicyStatement().addResource(new lib_1.Arn('resource')).addAction('action'));
doc.addStatement(new lib_1.PolicyStatement().addResource('resource').addAction('action'));
test.deepEqual(lib_1.resolve(doc), { Version: 'Foo',

@@ -66,3 +66,3 @@ Something: 123,

'Permission allows specifying multiple actions upon construction'(test) {
const perm = new lib_1.PolicyStatement().addResource(new lib_1.Arn('MyResource')).addActions('Action1', 'Action2', 'Action3');
const perm = new lib_1.PolicyStatement().addResource('MyResource').addActions('Action1', 'Action2', 'Action3');
test.deepEqual(lib_1.resolve(perm), {

@@ -134,3 +134,3 @@ Effect: 'Allow',

'true if there is one resource'(test) {
test.equal(new lib_1.PolicyStatement().addResource(new lib_1.Arn('one-resource')).hasResource, true, 'hasResource is true when there is one resource');
test.equal(new lib_1.PolicyStatement().addResource('one-resource').hasResource, true, 'hasResource is true when there is one resource');
test.done();

@@ -140,4 +140,4 @@ },

const p = new lib_1.PolicyStatement();
p.addResource(new lib_1.Arn('r1'));
p.addResource(new lib_1.Arn('r2'));
p.addResource('r1');
p.addResource('r2');
test.equal(p.hasResource, true, 'hasResource is true when there are multiple resource');

@@ -154,3 +154,3 @@ test.done();

const p = new lib_1.PolicyStatement();
p.addAwsPrincipal(new lib_1.Arn('bla'));
p.addAwsPrincipal('bla');
test.equal(p.hasPrincipal, true);

@@ -170,2 +170,2 @@ test.done();

};
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"test.perms.js","sourceRoot":"","sources":["test.perms.ts"],"names":[],"mappings":"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","sourcesContent":["import { Test } from 'nodeunit';\nimport { Arn, CanonicalUserPrincipal, FnConcat, PolicyDocument, PolicyStatement, resolve } from '../../lib';\n\nexport = {\n    'the Permission class is a programming model for iam'(test: Test) {\n        const p = new PolicyStatement();\n        p.addAction('sqs:SendMessage');\n        p.addActions('dynamodb:CreateTable', 'dynamodb:DeleteTable');\n        p.addResource(new Arn('myQueue'));\n        p.addResource(new Arn('yourQueue'));\n\n        p.addAllResources();\n        p.addAwsAccountPrincipal(new FnConcat('my', 'account', 'name').toString());\n        p.limitToAccount('12221121221');\n\n        test.deepEqual(resolve(p), { Action:\n            [ 'sqs:SendMessage',\n              'dynamodb:CreateTable',\n              'dynamodb:DeleteTable' ],\n           Resource: [ 'myQueue', 'yourQueue', '*' ],\n           Effect: 'Allow',\n           Principal:\n            { AWS:\n               { 'Fn::Join':\n                  [ '',\n                    [ 'arn:',\n                      { Ref: 'AWS::Partition' },\n                      ':iam::',\n                      { 'Fn::Join': [ '', [ 'my', 'account', 'name' ] ] },\n                      ':root' ] ] } },\n           Condition: { StringEquals: { 'sts:ExternalId': '12221121221' } } });\n\n        test.done();\n    },\n\n    'the PolicyDocument class is a dom for iam policy documents'(test: Test) {\n        const doc = new PolicyDocument();\n        const p1 = new PolicyStatement();\n        p1.addAction('sqs:SendMessage');\n        p1.addResource(new Arn('*'));\n\n        const p2 = new PolicyStatement();\n        p2.deny();\n        p2.addActions('cloudformation:CreateStack');\n\n        doc.addStatement(p1);\n        doc.addStatement(p2);\n\n        test.deepEqual(resolve(doc), {\n            Version: '2012-10-17',\n            Statement:\n                [ { Effect: 'Allow', Action: 'sqs:SendMessage', Resource: '*' },\n                  { Effect: 'Deny', Action: 'cloudformation:CreateStack' } ] });\n\n        test.done();\n    },\n\n    'A PolicyDocument can be initialized with an existing policy, which is merged upon serialization'(test: Test) {\n        const base = {\n            Version: 'Foo',\n            Something: 123,\n            Statement: [\n                { Statement1: 1 },\n                { Statement2: 2 }\n            ]\n        };\n        const doc = new PolicyDocument(base);\n        doc.addStatement(new PolicyStatement().addResource(new Arn('resource')).addAction('action'));\n\n        test.deepEqual(resolve(doc), { Version: 'Foo',\n        Something: 123,\n        Statement:\n         [ { Statement1: 1 },\n           { Statement2: 2 },\n           { Effect: 'Allow', Action: 'action', Resource: 'resource' } ] });\n        test.done();\n    },\n\n    'Permission allows specifying multiple actions upon construction'(test: Test) {\n        const perm = new PolicyStatement().addResource(new Arn('MyResource')).addActions('Action1', 'Action2', 'Action3');\n        test.deepEqual(resolve(perm), {\n            Effect: 'Allow',\n            Action: [ 'Action1', 'Action2', 'Action3' ],\n            Resource: 'MyResource' });\n        test.done();\n    },\n\n    'PolicyDoc resolves to undefined if there are no permissions'(test: Test) {\n        const p = new PolicyDocument();\n        test.deepEqual(resolve(p), undefined);\n        test.done();\n    },\n\n    'canonicalUserPrincipal adds a principal to a policy with the passed canonical user id'(test: Test) {\n        const p = new PolicyStatement();\n        const canoncialUser = \"averysuperduperlongstringfor\";\n        p.addPrincipal(new CanonicalUserPrincipal(canoncialUser));\n        test.deepEqual(resolve(p), {\n            Effect: \"Allow\",\n            Principal: {\n              CanonicalUser: canoncialUser\n            }\n        });\n        test.done();\n    },\n\n    'addAccountRootPrincipal adds a principal with the current account root'(test: Test) {\n        const p = new PolicyStatement();\n        p.addAccountRootPrincipal();\n        test.deepEqual(resolve(p), {\n            Effect: \"Allow\",\n            Principal: {\n              AWS: {\n                \"Fn::Join\": [\n                  \"\",\n                  [\n                    \"arn:\",\n                    { Ref: \"AWS::Partition\" },\n                    \":iam::\",\n                    { Ref: \"AWS::AccountId\" },\n                    \":root\"\n                  ]\n                ]\n              }\n            }\n        });\n        test.done();\n    },\n\n    'addFederatedPrincipal adds a Federated principal with the passed value'(test: Test) {\n        const p = new PolicyStatement();\n        p.addFederatedPrincipal(\"com.amazon.cognito\", { StringEquals: { key: 'value' }});\n        test.deepEqual(resolve(p), {\n            Effect: \"Allow\",\n            Principal: {\n                Federated: \"com.amazon.cognito\"\n            },\n            Condition: {\n                StringEquals: { key: 'value' }\n            }\n        });\n        test.done();\n    },\n\n    'hasResource': {\n        'false if there are no resources'(test: Test) {\n            test.equal(new PolicyStatement().hasResource, false, 'hasResource should be false for an empty permission');\n            test.done();\n        },\n\n        'true if there is one resource'(test: Test) {\n            test.equal(\n                new PolicyStatement().addResource(new Arn('one-resource')).hasResource,\n                true,\n                'hasResource is true when there is one resource');\n            test.done();\n        },\n\n        'true for multiple resources'(test: Test) {\n            const p = new PolicyStatement();\n            p.addResource(new Arn('r1'));\n            p.addResource(new Arn('r2'));\n            test.equal(p.hasResource, true, 'hasResource is true when there are multiple resource');\n            test.done();\n        },\n    },\n\n    'hasPrincipal': {\n        'false if there is no principal'(test: Test) {\n            test.equal(new PolicyStatement().hasPrincipal, false);\n            test.done();\n        },\n\n        'true if there is a principal'(test: Test) {\n            const p = new PolicyStatement();\n            p.addAwsPrincipal(new Arn('bla'));\n            test.equal(p.hasPrincipal, true);\n            test.done();\n        }\n    },\n\n    'statementCount returns the number of statement in the policy document'(test: Test) {\n        const p = new PolicyDocument();\n        test.equal(p.statementCount, 0);\n        p.addStatement(new PolicyStatement());\n        test.equal(p.statementCount, 1);\n        p.addStatement(new PolicyStatement());\n        test.equal(p.statementCount, 2);\n        test.done();\n    }\n};\n"]}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"test.perms.js","sourceRoot":"","sources":["test.perms.ts"],"names":[],"mappings":"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","sourcesContent":["import { Test } from 'nodeunit';\nimport { CanonicalUserPrincipal, FnConcat, PolicyDocument, PolicyStatement, resolve } from '../../lib';\n\nexport = {\n    'the Permission class is a programming model for iam'(test: Test) {\n        const p = new PolicyStatement();\n        p.addAction('sqs:SendMessage');\n        p.addActions('dynamodb:CreateTable', 'dynamodb:DeleteTable');\n        p.addResource('myQueue');\n        p.addResource('yourQueue');\n\n        p.addAllResources();\n        p.addAwsAccountPrincipal(new FnConcat('my', 'account', 'name').toString());\n        p.limitToAccount('12221121221');\n\n        test.deepEqual(resolve(p), { Action:\n            [ 'sqs:SendMessage',\n              'dynamodb:CreateTable',\n              'dynamodb:DeleteTable' ],\n           Resource: [ 'myQueue', 'yourQueue', '*' ],\n           Effect: 'Allow',\n           Principal:\n            { AWS:\n               { 'Fn::Join':\n                  [ '',\n                    [ 'arn:',\n                      { Ref: 'AWS::Partition' },\n                      ':iam::',\n                      { 'Fn::Join': [ '', [ 'my', 'account', 'name' ] ] },\n                      ':root' ] ] } },\n           Condition: { StringEquals: { 'sts:ExternalId': '12221121221' } } });\n\n        test.done();\n    },\n\n    'the PolicyDocument class is a dom for iam policy documents'(test: Test) {\n        const doc = new PolicyDocument();\n        const p1 = new PolicyStatement();\n        p1.addAction('sqs:SendMessage');\n        p1.addResource('*');\n\n        const p2 = new PolicyStatement();\n        p2.deny();\n        p2.addActions('cloudformation:CreateStack');\n\n        doc.addStatement(p1);\n        doc.addStatement(p2);\n\n        test.deepEqual(resolve(doc), {\n            Version: '2012-10-17',\n            Statement:\n                [ { Effect: 'Allow', Action: 'sqs:SendMessage', Resource: '*' },\n                  { Effect: 'Deny', Action: 'cloudformation:CreateStack' } ] });\n\n        test.done();\n    },\n\n    'A PolicyDocument can be initialized with an existing policy, which is merged upon serialization'(test: Test) {\n        const base = {\n            Version: 'Foo',\n            Something: 123,\n            Statement: [\n                { Statement1: 1 },\n                { Statement2: 2 }\n            ]\n        };\n        const doc = new PolicyDocument(base);\n        doc.addStatement(new PolicyStatement().addResource('resource').addAction('action'));\n\n        test.deepEqual(resolve(doc), { Version: 'Foo',\n        Something: 123,\n        Statement:\n         [ { Statement1: 1 },\n           { Statement2: 2 },\n           { Effect: 'Allow', Action: 'action', Resource: 'resource' } ] });\n        test.done();\n    },\n\n    'Permission allows specifying multiple actions upon construction'(test: Test) {\n        const perm = new PolicyStatement().addResource('MyResource').addActions('Action1', 'Action2', 'Action3');\n        test.deepEqual(resolve(perm), {\n            Effect: 'Allow',\n            Action: [ 'Action1', 'Action2', 'Action3' ],\n            Resource: 'MyResource' });\n        test.done();\n    },\n\n    'PolicyDoc resolves to undefined if there are no permissions'(test: Test) {\n        const p = new PolicyDocument();\n        test.deepEqual(resolve(p), undefined);\n        test.done();\n    },\n\n    'canonicalUserPrincipal adds a principal to a policy with the passed canonical user id'(test: Test) {\n        const p = new PolicyStatement();\n        const canoncialUser = \"averysuperduperlongstringfor\";\n        p.addPrincipal(new CanonicalUserPrincipal(canoncialUser));\n        test.deepEqual(resolve(p), {\n            Effect: \"Allow\",\n            Principal: {\n              CanonicalUser: canoncialUser\n            }\n        });\n        test.done();\n    },\n\n    'addAccountRootPrincipal adds a principal with the current account root'(test: Test) {\n        const p = new PolicyStatement();\n        p.addAccountRootPrincipal();\n        test.deepEqual(resolve(p), {\n            Effect: \"Allow\",\n            Principal: {\n              AWS: {\n                \"Fn::Join\": [\n                  \"\",\n                  [\n                    \"arn:\",\n                    { Ref: \"AWS::Partition\" },\n                    \":iam::\",\n                    { Ref: \"AWS::AccountId\" },\n                    \":root\"\n                  ]\n                ]\n              }\n            }\n        });\n        test.done();\n    },\n\n    'addFederatedPrincipal adds a Federated principal with the passed value'(test: Test) {\n        const p = new PolicyStatement();\n        p.addFederatedPrincipal(\"com.amazon.cognito\", { StringEquals: { key: 'value' }});\n        test.deepEqual(resolve(p), {\n            Effect: \"Allow\",\n            Principal: {\n                Federated: \"com.amazon.cognito\"\n            },\n            Condition: {\n                StringEquals: { key: 'value' }\n            }\n        });\n        test.done();\n    },\n\n    'hasResource': {\n        'false if there are no resources'(test: Test) {\n            test.equal(new PolicyStatement().hasResource, false, 'hasResource should be false for an empty permission');\n            test.done();\n        },\n\n        'true if there is one resource'(test: Test) {\n            test.equal(\n                new PolicyStatement().addResource('one-resource').hasResource,\n                true,\n                'hasResource is true when there is one resource');\n            test.done();\n        },\n\n        'true for multiple resources'(test: Test) {\n            const p = new PolicyStatement();\n            p.addResource('r1');\n            p.addResource('r2');\n            test.equal(p.hasResource, true, 'hasResource is true when there are multiple resource');\n            test.done();\n        },\n    },\n\n    'hasPrincipal': {\n        'false if there is no principal'(test: Test) {\n            test.equal(new PolicyStatement().hasPrincipal, false);\n            test.done();\n        },\n\n        'true if there is a principal'(test: Test) {\n            const p = new PolicyStatement();\n            p.addAwsPrincipal('bla');\n            test.equal(p.hasPrincipal, true);\n            test.done();\n        }\n    },\n\n    'statementCount returns the number of statement in the policy document'(test: Test) {\n        const p = new PolicyDocument();\n        test.equal(p.statementCount, 0);\n        p.addStatement(new PolicyStatement());\n        test.equal(p.statementCount, 1);\n        p.addStatement(new PolicyStatement());\n        test.equal(p.statementCount, 2);\n        test.done();\n    }\n};\n"]}

@@ -17,3 +17,4 @@ import { Test } from 'nodeunit';

'addDependency adds all dependencyElements of dependent constructs'(test: Test): void;
'resource.ref returns the {Ref} token'(test: Test): void;
};
export = _default;

@@ -6,4 +6,4 @@ "use strict";

super(parent, name, { type: 'My::Counter', properties: { Count: props.Count } });
this.arn = new CounterArnAttr(this.getAtt('Arn'));
this.url = new CounterUrlAttr(() => this.getAtt('URL'));
this.arn = this.getAtt('Arn').toString();
this.url = this.getAtt('URL').toString();
}

@@ -14,6 +14,2 @@ increment(by = 1) {

}
class CounterArnAttr extends lib_1.Arn {
}
class CounterUrlAttr extends lib_1.Token {
}
function withoutHash(logId) {

@@ -292,3 +288,9 @@ return logId.substr(0, logId.length - 8);

},
'resource.ref returns the {Ref} token'(test) {
const stack = new lib_1.Stack();
const r = new lib_1.Resource(stack, 'MyResource', { type: 'R' });
test.deepEqual(lib_1.resolve(r.ref), { Ref: 'MyResource' });
test.done();
}
};
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"test.resource.js","sourceRoot":"","sources":["test.resource.ts"],"names":[],"mappings":"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","sourcesContent":["import { Test } from 'nodeunit';\nimport { applyRemovalPolicy, Arn, Condition, Construct, DeletionPolicy,\n        FnEquals, FnNot, HashedAddressingScheme, IDependable, PolicyStatement,\n        RemovalPolicy, Resource, Root, Stack, Token } from '../../lib';\n\nexport = {\n    'all resources derive from Resource, which derives from Entity'(test: Test) {\n        const stack = new Stack();\n\n        new Resource(stack, 'MyResource', {\n            type: 'MyResourceType',\n            properties: {\n                Prop1: 'p1', Prop2: 123\n            }\n        });\n\n        test.deepEqual(stack.toCloudFormation(), {\n            Resources: {\n                MyResource: {\n                    Type: \"MyResourceType\",\n                    Properties: {\n                        Prop1: \"p1\",\n                        Prop2: 123\n                    }\n                }\n            }\n        });\n\n        test.done();\n    },\n\n    'resources must reside within a Stack and fail upon creation if not'(test: Test) {\n        const root = new Root();\n        test.throws(() => new Resource(root, 'R1', { type: 'ResourceType' }));\n        test.done();\n    },\n\n    'all entities have a logical ID calculated based on their full path in the tree'(test: Test) {\n        const stack = new Stack(undefined, 'TestStack', { namingScheme: new HashedAddressingScheme() });\n        const level1 = new Construct(stack, 'level1');\n        const level2 = new Construct(level1, 'level2');\n        const level3 = new Construct(level2, 'level3');\n        const res1 = new Resource(level1, 'childoflevel1', { type: 'MyResourceType1' });\n        const res2 = new Resource(level3, 'childoflevel3', { type: 'MyResourceType2' });\n\n        test.equal(withoutHash(res1.logicalId), 'level1childoflevel1');\n        test.equal(withoutHash(res2.logicalId), 'level1level2level3childoflevel3');\n\n        test.done();\n    },\n\n    'resource.props can only be accessed by derived classes'(test: Test) {\n        const stack = new Stack();\n        const res = new Counter(stack, 'MyResource', { Count: 10 });\n        res.increment();\n        res.increment(2);\n\n        test.deepEqual(stack.toCloudFormation(), {\n            Resources: {\n                MyResource: { Type: 'My::Counter', Properties: { Count: 13 } }\n            }\n        });\n\n        test.done();\n    },\n\n    'resource attributes can be retrieved using getAtt(s) or attribute properties'(test: Test) {\n        const stack = new Stack();\n        const res = new Counter(stack, 'MyResource', { Count: 10 });\n\n        new Resource(stack, 'YourResource', {\n            type: 'Type',\n            properties: {\n                CounterName: res.getAtt('Name'),\n                CounterArn: res.arn,\n                CounterURL: res.url,\n            }\n        });\n\n        test.deepEqual(stack.toCloudFormation(), {\n            Resources: {\n                MyResource: { Type: 'My::Counter', Properties: { Count: 10 } },\n                YourResource: {\n                    Type: 'Type',\n                    Properties: {\n                        CounterName: { 'Fn::GetAtt': [ 'MyResource', 'Name' ] },\n                        CounterArn: { 'Fn::GetAtt': [ 'MyResource', 'Arn' ] } ,\n                        CounterURL: { 'Fn::GetAtt': [ 'MyResource', 'URL' ] }\n                    }\n                }\n            }\n        });\n\n        test.done();\n    },\n\n    'ARN-type resource attributes have some common functionality'(test: Test) {\n        const stack = new Stack();\n        const res = new Counter(stack, 'MyResource', { Count: 1 });\n        new Resource(stack, 'MyResource2', {\n            type: 'Type',\n            properties: {\n                Perm: new PolicyStatement().addResource(res.arn).addActions('counter:add', 'counter:remove')\n            }\n        });\n\n        test.deepEqual(stack.toCloudFormation(), {\n          Resources: {\n            MyResource: { Type: \"My::Counter\", Properties: { Count: 1 } },\n            MyResource2: {\n              Type: \"Type\",\n              Properties: {\n                Perm: {\n                  Effect: \"Allow\",\n                  Action: [ \"counter:add\", \"counter:remove\" ],\n                  Resource: {\n                    \"Fn::GetAtt\": [ \"MyResource\", \"Arn\" ]\n                  }\n                }\n              }\n            }\n          }\n        });\n\n        test.done();\n    },\n\n    'resource.addDependency(e) can be used to add a DependsOn on another resource'(test: Test) {\n        const stack = new Stack();\n        const r1 = new Counter(stack, 'Counter1', { Count: 1 });\n        const r2 = new Counter(stack, 'Counter2', { Count: 1 });\n        const r3 = new Resource(stack, 'Resource3', { type: 'MyResourceType' });\n        r2.addDependency(r1);\n        r2.addDependency(r3);\n\n        test.deepEqual(stack.toCloudFormation(), {\n            Resources: {\n                Counter1: {\n                    Type: \"My::Counter\",\n                    Properties: { Count: 1 }\n                },\n                Counter2: {\n                    Type: \"My::Counter\",\n                    Properties: { Count: 1 },\n                    DependsOn: [\n                        \"Counter1\",\n                        \"Resource3\"\n                    ]\n                },\n                Resource3: { Type: \"MyResourceType\" }\n            }\n        });\n\n        test.done();\n    },\n\n    'conditions can be attached to a resource'(test: Test) {\n        const stack = new Stack();\n        const r1 = new Resource(stack, 'Resource', { type: 'Type' });\n        const cond = new Condition(stack, 'MyCondition', { expression: new FnNot(new FnEquals('a', 'b')) });\n        r1.options.condition = cond;\n\n        test.deepEqual(stack.toCloudFormation(), {\n            Resources: { Resource: { Type: 'Type', Condition: 'MyCondition' } },\n            Conditions: { MyCondition: { 'Fn::Not': [ { 'Fn::Equals': [ 'a', 'b' ] } ] } }\n        });\n\n        test.done();\n    },\n\n    'creation/update/deletion policies can be set on a resource'(test: Test) {\n        const stack = new Stack();\n        const r1 = new Resource(stack, 'Resource', { type: 'Type' });\n\n        r1.options.creationPolicy = { autoScalingCreationPolicy: { minSuccessfulInstancesPercent: 10 } };\n        // tslint:disable-next-line:max-line-length\n        r1.options.updatePolicy = { autoScalingScheduledAction: { ignoreUnmodifiedGroupSizeProperties: false }, autoScalingReplacingUpdate: { willReplace: true } };\n        r1.options.deletionPolicy = DeletionPolicy.Retain;\n\n        test.deepEqual(stack.toCloudFormation(), {\n            Resources: {\n                Resource: {\n                    Type: 'Type',\n                    CreationPolicy: { AutoScalingCreationPolicy: { MinSuccessfulInstancesPercent: 10 } },\n                    UpdatePolicy: {\n                        AutoScalingScheduledAction: { IgnoreUnmodifiedGroupSizeProperties: false },\n                        AutoScalingReplacingUpdate: { WillReplace: true }\n                    },\n                    DeletionPolicy: 'Retain'\n                }\n            }\n        });\n\n        test.done();\n    },\n\n    'metadata can be set on a resource'(test: Test) {\n        const stack = new Stack();\n        const r1 = new Resource(stack, 'Resource', { type: 'Type' });\n\n        r1.options.metadata = {\n            MyKey: 10,\n            MyValue: 99\n        };\n\n        test.deepEqual(stack.toCloudFormation(), {\n            Resources: {\n                Resource: {\n                    Type: \"Type\",\n                    Metadata: {\n                        MyKey: 10,\n                        MyValue: 99\n                    }\n                }\n            }\n        });\n\n        test.done();\n    },\n\n    'the \"type\" property is required when creating a resource'(test: Test) {\n        const stack = new Stack();\n        test.throws(() => new Resource(stack, 'Resource', { notypehere: true } as any));\n        test.done();\n    },\n\n    'the \"name\" property is deleted when synthesizing into a CloudFormation resource'(test: Test) {\n        const stack = new Stack();\n\n        new Resource(stack, 'Bla', {\n            type: 'MyResource',\n            properties: {\n                Prop1: 'value1',\n                name: 'Bla'\n            }\n        });\n\n        test.deepEqual(stack.toCloudFormation(), { Resources:\n            { Bla: { Type: 'MyResource', Properties: { Prop1: 'value1' } } } });\n        test.done();\n    },\n\n    'removal policy is a high level abstraction of deletion policy used by l2'(test: Test) {\n        const stack = new Stack();\n\n        const orphan = new Resource(stack, 'Orphan', { type: 'T1' });\n        const forbid = new Resource(stack, 'Forbid', { type: 'T2' });\n        const destroy = new Resource(stack, 'Destroy', { type: 'T3' });\n\n        applyRemovalPolicy(orphan, RemovalPolicy.Orphan);\n        applyRemovalPolicy(forbid, RemovalPolicy.Forbid);\n        applyRemovalPolicy(destroy, RemovalPolicy.Destroy);\n\n        test.deepEqual(stack.toCloudFormation(), { Resources:\n            { Orphan: { Type: 'T1', DeletionPolicy: 'Retain' },\n              Forbid: { Type: 'T2', DeletionPolicy: 'Retain' },\n              Destroy: { Type: 'T3' } } });\n        test.done();\n    },\n\n    'addDependency adds all dependencyElements of dependent constructs'(test: Test) {\n\n        class C1 extends Construct implements IDependable {\n            public readonly r1: Resource;\n            public readonly r2: Resource;\n            public readonly r3: Resource;\n\n            constructor(parent: Construct, name: string) {\n                super(parent, name);\n\n                this.r1 = new Resource(this, 'R1', { type: 'T1' });\n                this.r2 = new Resource(this, 'R2', { type: 'T2' });\n                this.r3 = new Resource(this, 'R3', { type: 'T3' });\n            }\n\n            get dependencyElements() {\n                return [ this.r1, this.r2 ];\n            }\n        }\n\n        class C2 extends Construct implements IDependable {\n            public readonly r1: Resource;\n            public readonly r2: Resource;\n            public readonly r3: Resource;\n\n            constructor(parent: Construct, name: string) {\n                super(parent, name);\n\n                this.r1 = new Resource(this, 'R1', { type: 'T1' });\n                this.r2 = new Resource(this, 'R2', { type: 'T2' });\n                this.r3 = new Resource(this, 'R3', { type: 'T3' });\n            }\n\n            get dependencyElements() {\n                return [ this.r3 ];\n            }\n        }\n\n        // C3 returns [ c2 ] for it's dependency elements\n        // this should result in 'flattening' the list of elements.\n        class C3 extends Construct implements IDependable {\n            private readonly c2: C2;\n\n            constructor(parent: Construct, name: string) {\n                super(parent, name);\n\n                this.c2 = new C2(this, 'C2');\n            }\n\n            get dependencyElements() {\n                return [ this.c2 ];\n            }\n        }\n\n        const stack = new Stack();\n        const c1 = new C1(stack, 'MyC1');\n        const c2 = new C2(stack, 'MyC2');\n        const c3 = new C3(stack, 'MyC3');\n\n        const dependingResource = new Resource(stack, 'MyResource', { type: 'R' });\n        dependingResource.addDependency(c1, c2);\n        dependingResource.addDependency(c3);\n\n        test.deepEqual(stack.toCloudFormation(), { Resources:\n            { MyC1R1FB2A562F: { Type: 'T1' },\n              MyC1R2AE2B5066: { Type: 'T2' },\n              MyC1R374967D02: { Type: 'T3' },\n              MyC2R13C9A618D: { Type: 'T1' },\n              MyC2R25330F905: { Type: 'T2' },\n              MyC2R3809EEAD6: { Type: 'T3' },\n              MyC3C2R1C64551A7: { Type: 'T1' },\n              MyC3C2R2F213BD26: { Type: 'T2' },\n              MyC3C2R38CE6F9F7: { Type: 'T3' },\n              MyResource:\n               { Type: 'R',\n                 DependsOn:\n                  [ 'MyC1R1FB2A562F',\n                    'MyC1R2AE2B5066',\n                    'MyC2R3809EEAD6',\n                    'MyC3C2R38CE6F9F7' ] } } });\n        test.done();\n    },\n};\n\ninterface CounterProps {\n    // tslint:disable-next-line:variable-name\n    Count: number;\n}\n\nclass Counter extends Resource {\n    public readonly arn: CounterArnAttr;\n    public readonly url: CounterUrlAttr;\n\n    constructor(parent: Construct, name: string, props: CounterProps) {\n        super(parent, name, { type: 'My::Counter', properties: { Count: props.Count } });\n        this.arn = new CounterArnAttr(this.getAtt('Arn'));\n        this.url = new CounterUrlAttr(() => this.getAtt('URL'));\n    }\n\n    public increment(by = 1) {\n        this.properties.Count += by;\n    }\n}\n\nclass CounterArnAttr extends Arn { }\nclass CounterUrlAttr extends Token { }\n\nfunction withoutHash(logId: string) {\n    return logId.substr(0, logId.length - 8);\n}\n"]}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"test.resource.js","sourceRoot":"","sources":["test.resource.ts"],"names":[],"mappings":"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","sourcesContent":["import { Test } from 'nodeunit';\nimport { applyRemovalPolicy, Condition, Construct, DeletionPolicy,\n        FnEquals, FnNot, HashedAddressingScheme, IDependable, PolicyStatement,\n        RemovalPolicy, resolve, Resource, Root, Stack } from '../../lib';\n\nexport = {\n    'all resources derive from Resource, which derives from Entity'(test: Test) {\n        const stack = new Stack();\n\n        new Resource(stack, 'MyResource', {\n            type: 'MyResourceType',\n            properties: {\n                Prop1: 'p1', Prop2: 123\n            }\n        });\n\n        test.deepEqual(stack.toCloudFormation(), {\n            Resources: {\n                MyResource: {\n                    Type: \"MyResourceType\",\n                    Properties: {\n                        Prop1: \"p1\",\n                        Prop2: 123\n                    }\n                }\n            }\n        });\n\n        test.done();\n    },\n\n    'resources must reside within a Stack and fail upon creation if not'(test: Test) {\n        const root = new Root();\n        test.throws(() => new Resource(root, 'R1', { type: 'ResourceType' }));\n        test.done();\n    },\n\n    'all entities have a logical ID calculated based on their full path in the tree'(test: Test) {\n        const stack = new Stack(undefined, 'TestStack', { namingScheme: new HashedAddressingScheme() });\n        const level1 = new Construct(stack, 'level1');\n        const level2 = new Construct(level1, 'level2');\n        const level3 = new Construct(level2, 'level3');\n        const res1 = new Resource(level1, 'childoflevel1', { type: 'MyResourceType1' });\n        const res2 = new Resource(level3, 'childoflevel3', { type: 'MyResourceType2' });\n\n        test.equal(withoutHash(res1.logicalId), 'level1childoflevel1');\n        test.equal(withoutHash(res2.logicalId), 'level1level2level3childoflevel3');\n\n        test.done();\n    },\n\n    'resource.props can only be accessed by derived classes'(test: Test) {\n        const stack = new Stack();\n        const res = new Counter(stack, 'MyResource', { Count: 10 });\n        res.increment();\n        res.increment(2);\n\n        test.deepEqual(stack.toCloudFormation(), {\n            Resources: {\n                MyResource: { Type: 'My::Counter', Properties: { Count: 13 } }\n            }\n        });\n\n        test.done();\n    },\n\n    'resource attributes can be retrieved using getAtt(s) or attribute properties'(test: Test) {\n        const stack = new Stack();\n        const res = new Counter(stack, 'MyResource', { Count: 10 });\n\n        new Resource(stack, 'YourResource', {\n            type: 'Type',\n            properties: {\n                CounterName: res.getAtt('Name'),\n                CounterArn: res.arn,\n                CounterURL: res.url,\n            }\n        });\n\n        test.deepEqual(stack.toCloudFormation(), {\n            Resources: {\n                MyResource: { Type: 'My::Counter', Properties: { Count: 10 } },\n                YourResource: {\n                    Type: 'Type',\n                    Properties: {\n                        CounterName: { 'Fn::GetAtt': [ 'MyResource', 'Name' ] },\n                        CounterArn: { 'Fn::GetAtt': [ 'MyResource', 'Arn' ] } ,\n                        CounterURL: { 'Fn::GetAtt': [ 'MyResource', 'URL' ] }\n                    }\n                }\n            }\n        });\n\n        test.done();\n    },\n\n    'ARN-type resource attributes have some common functionality'(test: Test) {\n        const stack = new Stack();\n        const res = new Counter(stack, 'MyResource', { Count: 1 });\n        new Resource(stack, 'MyResource2', {\n            type: 'Type',\n            properties: {\n                Perm: new PolicyStatement().addResource(res.arn).addActions('counter:add', 'counter:remove')\n            }\n        });\n\n        test.deepEqual(stack.toCloudFormation(), {\n          Resources: {\n            MyResource: { Type: \"My::Counter\", Properties: { Count: 1 } },\n            MyResource2: {\n              Type: \"Type\",\n              Properties: {\n                Perm: {\n                  Effect: \"Allow\",\n                  Action: [ \"counter:add\", \"counter:remove\" ],\n                  Resource: {\n                    \"Fn::GetAtt\": [ \"MyResource\", \"Arn\" ]\n                  }\n                }\n              }\n            }\n          }\n        });\n\n        test.done();\n    },\n\n    'resource.addDependency(e) can be used to add a DependsOn on another resource'(test: Test) {\n        const stack = new Stack();\n        const r1 = new Counter(stack, 'Counter1', { Count: 1 });\n        const r2 = new Counter(stack, 'Counter2', { Count: 1 });\n        const r3 = new Resource(stack, 'Resource3', { type: 'MyResourceType' });\n        r2.addDependency(r1);\n        r2.addDependency(r3);\n\n        test.deepEqual(stack.toCloudFormation(), {\n            Resources: {\n                Counter1: {\n                    Type: \"My::Counter\",\n                    Properties: { Count: 1 }\n                },\n                Counter2: {\n                    Type: \"My::Counter\",\n                    Properties: { Count: 1 },\n                    DependsOn: [\n                        \"Counter1\",\n                        \"Resource3\"\n                    ]\n                },\n                Resource3: { Type: \"MyResourceType\" }\n            }\n        });\n\n        test.done();\n    },\n\n    'conditions can be attached to a resource'(test: Test) {\n        const stack = new Stack();\n        const r1 = new Resource(stack, 'Resource', { type: 'Type' });\n        const cond = new Condition(stack, 'MyCondition', { expression: new FnNot(new FnEquals('a', 'b')) });\n        r1.options.condition = cond;\n\n        test.deepEqual(stack.toCloudFormation(), {\n            Resources: { Resource: { Type: 'Type', Condition: 'MyCondition' } },\n            Conditions: { MyCondition: { 'Fn::Not': [ { 'Fn::Equals': [ 'a', 'b' ] } ] } }\n        });\n\n        test.done();\n    },\n\n    'creation/update/deletion policies can be set on a resource'(test: Test) {\n        const stack = new Stack();\n        const r1 = new Resource(stack, 'Resource', { type: 'Type' });\n\n        r1.options.creationPolicy = { autoScalingCreationPolicy: { minSuccessfulInstancesPercent: 10 } };\n        // tslint:disable-next-line:max-line-length\n        r1.options.updatePolicy = { autoScalingScheduledAction: { ignoreUnmodifiedGroupSizeProperties: false }, autoScalingReplacingUpdate: { willReplace: true } };\n        r1.options.deletionPolicy = DeletionPolicy.Retain;\n\n        test.deepEqual(stack.toCloudFormation(), {\n            Resources: {\n                Resource: {\n                    Type: 'Type',\n                    CreationPolicy: { AutoScalingCreationPolicy: { MinSuccessfulInstancesPercent: 10 } },\n                    UpdatePolicy: {\n                        AutoScalingScheduledAction: { IgnoreUnmodifiedGroupSizeProperties: false },\n                        AutoScalingReplacingUpdate: { WillReplace: true }\n                    },\n                    DeletionPolicy: 'Retain'\n                }\n            }\n        });\n\n        test.done();\n    },\n\n    'metadata can be set on a resource'(test: Test) {\n        const stack = new Stack();\n        const r1 = new Resource(stack, 'Resource', { type: 'Type' });\n\n        r1.options.metadata = {\n            MyKey: 10,\n            MyValue: 99\n        };\n\n        test.deepEqual(stack.toCloudFormation(), {\n            Resources: {\n                Resource: {\n                    Type: \"Type\",\n                    Metadata: {\n                        MyKey: 10,\n                        MyValue: 99\n                    }\n                }\n            }\n        });\n\n        test.done();\n    },\n\n    'the \"type\" property is required when creating a resource'(test: Test) {\n        const stack = new Stack();\n        test.throws(() => new Resource(stack, 'Resource', { notypehere: true } as any));\n        test.done();\n    },\n\n    'the \"name\" property is deleted when synthesizing into a CloudFormation resource'(test: Test) {\n        const stack = new Stack();\n\n        new Resource(stack, 'Bla', {\n            type: 'MyResource',\n            properties: {\n                Prop1: 'value1',\n                name: 'Bla'\n            }\n        });\n\n        test.deepEqual(stack.toCloudFormation(), { Resources:\n            { Bla: { Type: 'MyResource', Properties: { Prop1: 'value1' } } } });\n        test.done();\n    },\n\n    'removal policy is a high level abstraction of deletion policy used by l2'(test: Test) {\n        const stack = new Stack();\n\n        const orphan = new Resource(stack, 'Orphan', { type: 'T1' });\n        const forbid = new Resource(stack, 'Forbid', { type: 'T2' });\n        const destroy = new Resource(stack, 'Destroy', { type: 'T3' });\n\n        applyRemovalPolicy(orphan, RemovalPolicy.Orphan);\n        applyRemovalPolicy(forbid, RemovalPolicy.Forbid);\n        applyRemovalPolicy(destroy, RemovalPolicy.Destroy);\n\n        test.deepEqual(stack.toCloudFormation(), { Resources:\n            { Orphan: { Type: 'T1', DeletionPolicy: 'Retain' },\n              Forbid: { Type: 'T2', DeletionPolicy: 'Retain' },\n              Destroy: { Type: 'T3' } } });\n        test.done();\n    },\n\n    'addDependency adds all dependencyElements of dependent constructs'(test: Test) {\n\n        class C1 extends Construct implements IDependable {\n            public readonly r1: Resource;\n            public readonly r2: Resource;\n            public readonly r3: Resource;\n\n            constructor(parent: Construct, name: string) {\n                super(parent, name);\n\n                this.r1 = new Resource(this, 'R1', { type: 'T1' });\n                this.r2 = new Resource(this, 'R2', { type: 'T2' });\n                this.r3 = new Resource(this, 'R3', { type: 'T3' });\n            }\n\n            get dependencyElements() {\n                return [ this.r1, this.r2 ];\n            }\n        }\n\n        class C2 extends Construct implements IDependable {\n            public readonly r1: Resource;\n            public readonly r2: Resource;\n            public readonly r3: Resource;\n\n            constructor(parent: Construct, name: string) {\n                super(parent, name);\n\n                this.r1 = new Resource(this, 'R1', { type: 'T1' });\n                this.r2 = new Resource(this, 'R2', { type: 'T2' });\n                this.r3 = new Resource(this, 'R3', { type: 'T3' });\n            }\n\n            get dependencyElements() {\n                return [ this.r3 ];\n            }\n        }\n\n        // C3 returns [ c2 ] for it's dependency elements\n        // this should result in 'flattening' the list of elements.\n        class C3 extends Construct implements IDependable {\n            private readonly c2: C2;\n\n            constructor(parent: Construct, name: string) {\n                super(parent, name);\n\n                this.c2 = new C2(this, 'C2');\n            }\n\n            get dependencyElements() {\n                return [ this.c2 ];\n            }\n        }\n\n        const stack = new Stack();\n        const c1 = new C1(stack, 'MyC1');\n        const c2 = new C2(stack, 'MyC2');\n        const c3 = new C3(stack, 'MyC3');\n\n        const dependingResource = new Resource(stack, 'MyResource', { type: 'R' });\n        dependingResource.addDependency(c1, c2);\n        dependingResource.addDependency(c3);\n\n        test.deepEqual(stack.toCloudFormation(), { Resources:\n            { MyC1R1FB2A562F: { Type: 'T1' },\n              MyC1R2AE2B5066: { Type: 'T2' },\n              MyC1R374967D02: { Type: 'T3' },\n              MyC2R13C9A618D: { Type: 'T1' },\n              MyC2R25330F905: { Type: 'T2' },\n              MyC2R3809EEAD6: { Type: 'T3' },\n              MyC3C2R1C64551A7: { Type: 'T1' },\n              MyC3C2R2F213BD26: { Type: 'T2' },\n              MyC3C2R38CE6F9F7: { Type: 'T3' },\n              MyResource:\n               { Type: 'R',\n                 DependsOn:\n                  [ 'MyC1R1FB2A562F',\n                    'MyC1R2AE2B5066',\n                    'MyC2R3809EEAD6',\n                    'MyC3C2R38CE6F9F7' ] } } });\n        test.done();\n    },\n\n    'resource.ref returns the {Ref} token'(test: Test) {\n        const stack = new Stack();\n        const r = new Resource(stack, 'MyResource', { type: 'R' });\n\n        test.deepEqual(resolve(r.ref), { Ref: 'MyResource' });\n        test.done();\n    }\n};\n\ninterface CounterProps {\n    // tslint:disable-next-line:variable-name\n    Count: number;\n}\n\nclass Counter extends Resource {\n    public readonly arn: string;\n    public readonly url: string;\n\n    constructor(parent: Construct, name: string, props: CounterProps) {\n        super(parent, name, { type: 'My::Counter', properties: { Count: props.Count } });\n        this.arn = this.getAtt('Arn').toString();\n        this.url = this.getAtt('URL').toString();\n    }\n\n    public increment(by = 1) {\n        this.properties.Count += by;\n    }\n}\n\nfunction withoutHash(logId: string) {\n    return logId.substr(0, logId.length - 8);\n}\n"]}

@@ -20,3 +20,5 @@ import { Test } from 'nodeunit';

'side-by-side Tokens resolve correctly'(test: Test): void;
'tokens can be used in hash keys but must resolve to a string'(test: Test): void;
'fails if token in a hash key resolves to a non-string'(test: Test): void;
};
export = _default;

@@ -164,5 +164,5 @@ "use strict";

'isToken(obj) can be used to determine if an object is a token'(test) {
test.ok(lib_1.isToken({ resolve: () => 123 }));
test.ok(lib_1.isToken({ a: 1, b: 2, resolve: () => 'hello' }));
test.ok(!lib_1.isToken({ a: 1, b: 2, resolve: 3 }));
test.ok(lib_1.unresolved({ resolve: () => 123 }));
test.ok(lib_1.unresolved({ a: 1, b: 2, resolve: () => 'hello' }));
test.ok(!lib_1.unresolved({ a: 1, b: 2, resolve: 3 }));
test.done();

@@ -260,3 +260,25 @@ },

},
'tokens can be used in hash keys but must resolve to a string'(test) {
// GIVEN
const token = new lib_1.Token(() => 'I am a string');
// WHEN
const s = {
[token.toString()]: `boom ${token}`
};
// THEN
test.deepEqual(lib_1.resolve(s), { 'I am a string': 'boom I am a string' });
test.done();
},
'fails if token in a hash key resolves to a non-string'(test) {
// GIVEN
const token = new lib_1.CloudFormationToken({ Ref: 'Other' });
// WHEN
const s = {
[token.toString()]: `boom ${token}`
};
// THEN
test.throws(() => lib_1.resolve(s), 'The key "${Token[TOKEN.19]}" has been resolved to {"Ref":"Other"} but must be resolvable to a string');
test.done();
}
};
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"test.tokens.js","sourceRoot":"","sources":["test.tokens.ts"],"names":[],"mappings":"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","sourcesContent":["import { Test } from 'nodeunit';\nimport { CloudFormationToken, isToken, resolve, Token } from '../../lib';\nimport { evaluateCFN } from '../cloudformation/evaluate-cfn';\n\nexport = {\n    'resolve a plain old object should just return the object'(test: Test) {\n        const obj = { PlainOldObject: 123, Array: [ 1, 2, 3 ] };\n        test.deepEqual(resolve(obj), obj);\n        test.done();\n    },\n\n    'if a value is an object with a token value, it will be evaluated'(test: Test) {\n        const obj = {\n            RegularValue: 'hello',\n            LazyValue: new Token('World')\n        };\n\n        test.deepEqual(resolve(obj), {\n            RegularValue: 'hello',\n            LazyValue: 'World'\n        });\n\n        test.done();\n    },\n\n    'tokens are evaluated anywhere in the object tree'(test: Test) {\n        const obj = new Promise1();\n        const actual = resolve({ Obj: obj });\n\n        test.deepEqual(actual, {\n            Obj: [\n              {\n                Data: {\n                  stringProp: \"hello\",\n                  numberProp: 1234\n                },\n                Recurse: 42\n              },\n              {\n                Data: {\n                  stringProp: \"hello\",\n                  numberProp: 1234\n                },\n                Recurse: 42\n              }\n            ]\n        });\n\n        test.done();\n    },\n\n    'tokens are evaluated recursively'(test: Test) {\n        const obj = new Promise1();\n        const actual = resolve(new Token(() => ({ Obj: obj })));\n\n        test.deepEqual(actual, {\n            Obj: [\n              {\n                Data: {\n                  stringProp: \"hello\",\n                  numberProp: 1234\n                },\n                Recurse: 42\n              },\n              {\n                Data: {\n                  stringProp: \"hello\",\n                  numberProp: 1234\n                },\n                Recurse: 42\n              }\n            ]\n        });\n\n        test.done();\n    },\n\n    'empty arrays or objects are kept'(test: Test) {\n        test.deepEqual(resolve({ }), { });\n        test.deepEqual(resolve([ ]), [ ]);\n\n        const obj = {\n            Prop1: 1234,\n            Prop2: { },\n            Prop3: [ ],\n            Prop4: 'hello',\n            Prop5: {\n                PropA: { },\n                PropB: {\n                    PropC: [ undefined, undefined ],\n                    PropD: 'Yoohoo'\n                }\n            }\n        };\n\n        test.deepEqual(resolve(obj), {\n            Prop1: 1234,\n            Prop2: { },\n            Prop3: [ ],\n            Prop4: 'hello',\n            Prop5: {\n                PropA: { },\n                PropB: {\n                    PropC: [ ],\n                    PropD: 'Yoohoo'\n                }\n            }\n        });\n\n        test.done();\n    },\n\n    'if an object has a \"resolve\" property that is not a function, it is not considered a token'(test: Test) {\n        test.deepEqual(resolve({ a_token: { resolve: () => 78787 }}), { a_token: 78787 });\n        test.deepEqual(resolve({ not_a_token: { resolve: 12 } }),     { not_a_token: { resolve: 12 } });\n        test.done();\n    },\n\n    // tslint:disable-next-line:max-line-length\n    'if a resolvable object inherits from a class that is also resolvable, the \"constructor\" function will not get in the way (uses Object.keys instead of \"for in\")'(test: Test) {\n        test.deepEqual(resolve({ prop: new DataType() }), { prop: { foo: 12, goo: 'hello' } });\n        test.done();\n    },\n\n    'isToken(obj) can be used to determine if an object is a token'(test: Test) {\n        test.ok(isToken({ resolve: () => 123 }));\n        test.ok(isToken({ a: 1, b: 2, resolve: () => 'hello' }));\n        test.ok(!isToken({ a: 1, b: 2, resolve: 3 }));\n        test.done();\n    },\n\n    'Token can be used to create tokens that contain a constant value'(test: Test) {\n        test.equal(resolve(new Token(12)), 12);\n        test.equal(resolve(new Token('hello')), 'hello');\n        test.deepEqual(resolve(new Token([ 'hi', 'there' ])), [ 'hi', 'there' ]);\n        test.done();\n    },\n\n    'resolving leaves a Date object in working order'(test: Test) {\n        const date = new Date('2000-01-01');\n        const resolved = resolve(date);\n\n        test.equal(date.toString(), resolved.toString());\n        test.done();\n    },\n\n    'tokens can be stringified and evaluated to conceptual value'(test: Test) {\n        // GIVEN\n        const token = new Token(() => 'woof woof');\n\n        // WHEN\n        const stringified = `The dog says: ${token}`;\n        const resolved = resolve(stringified);\n\n        // THEN\n        test.deepEqual(evaluateCFN(resolved), 'The dog says: woof woof');\n        test.done();\n    },\n\n    'Tokens stringification and reversing of CloudFormation Tokens is implemented using Fn::Join'(test: Test) {\n        // GIVEN\n        const token = new CloudFormationToken(() => 'woof woof');\n\n        // WHEN\n        const stringified = `The dog says: ${token}`;\n        const resolved = resolve(stringified);\n\n        // THEN\n        test.deepEqual(resolved, {\n            'Fn::Join': ['', ['The dog says: ', 'woof woof']]\n        });\n        test.done();\n    },\n\n    'Doubly nested strings evaluate correctly in scalar context'(test: Test) {\n        // GIVEN\n        const token1 = new Token(() => \"world\");\n        const token2 = new Token(() => `hello ${token1}`);\n\n        // WHEN\n        const resolved1 = resolve(token2.toString());\n        const resolved2 = resolve(token2);\n\n        // THEN\n        test.deepEqual(evaluateCFN(resolved1), \"hello world\");\n        test.deepEqual(evaluateCFN(resolved2), \"hello world\");\n\n        test.done();\n    },\n\n    'integer Tokens can be stringified and evaluate to conceptual value'(test: Test) {\n        // GIVEN\n        for (const token of literalTokensThatResolveTo(1)) {\n            // WHEN\n            const stringified = `the number is ${token}`;\n            const resolved = resolve(stringified);\n\n            // THEN\n            test.deepEqual(evaluateCFN(resolved), 'the number is 1');\n        }\n        test.done();\n    },\n\n    'intrinsic Tokens can be stringified and evaluate to conceptual value'(test: Test) {\n        // GIVEN\n        for (const bucketName of cloudFormationTokensThatResolveTo({ Ref: 'MyBucket' })) {\n            // WHEN\n            const resolved = resolve(`my bucket is named ${bucketName}`);\n\n            // THEN\n            const context = {MyBucket: 'TheName'};\n            test.equal(evaluateCFN(resolved, context), 'my bucket is named TheName');\n        }\n\n        test.done();\n    },\n\n    'tokens resolve properly in initial position'(test: Test) {\n        // GIVEN\n        for (const token of tokensThatResolveTo('Hello')) {\n            // WHEN\n            const resolved = resolve(`${token} world`);\n\n            // THEN\n            test.equal(evaluateCFN(resolved), 'Hello world');\n        }\n\n        test.done();\n    },\n\n    'side-by-side Tokens resolve correctly'(test: Test) {\n        // GIVEN\n        for (const token1 of tokensThatResolveTo('Hello ')) {\n            for (const token2 of tokensThatResolveTo('world')) {\n                // WHEN\n                const resolved = resolve(`${token1}${token2}`);\n\n                // THEN\n                test.equal(evaluateCFN(resolved), 'Hello world');\n            }\n        }\n\n        test.done();\n    },\n};\n\nclass Promise2 extends Token {\n    public resolve() {\n        return {\n            Data: {\n                stringProp: 'hello',\n                numberProp: 1234,\n            },\n            Recurse: new Token(() => 42)\n        };\n    }\n}\n\nclass Promise1 extends Token {\n    public p2 = [ new Promise2(), new Promise2() ];\n\n    public resolve() {\n        return this.p2;\n    }\n}\n\nclass BaseDataType {\n    constructor(readonly foo: number) {\n    }\n}\n\nclass DataType extends BaseDataType {\n    public goo = 'hello';\n\n    constructor() {\n        super(12);\n    }\n}\n\n/**\n * Return various flavors of Tokens that resolve to the given value\n */\nfunction literalTokensThatResolveTo(value: any): Token[] {\n    return [\n        new Token(value),\n        new Token(() => value)\n    ];\n}\n\n/**\n * Return various flavors of Tokens that resolve to the given value\n */\nfunction cloudFormationTokensThatResolveTo(value: any): Token[] {\n    return [\n        new CloudFormationToken(value),\n        new CloudFormationToken(() => value)\n    ];\n}\n\n/**\n * Return Tokens in both flavors that resolve to the given string\n */\nfunction tokensThatResolveTo(value: string): Token[] {\n    return literalTokensThatResolveTo(value).concat(cloudFormationTokensThatResolveTo(value));\n}"]}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"test.tokens.js","sourceRoot":"","sources":["test.tokens.ts"],"names":[],"mappings":"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","sourcesContent":["import { Test } from 'nodeunit';\nimport { CloudFormationToken, resolve, Token, unresolved } from '../../lib';\nimport { evaluateCFN } from '../cloudformation/evaluate-cfn';\n\nexport = {\n    'resolve a plain old object should just return the object'(test: Test) {\n        const obj = { PlainOldObject: 123, Array: [ 1, 2, 3 ] };\n        test.deepEqual(resolve(obj), obj);\n        test.done();\n    },\n\n    'if a value is an object with a token value, it will be evaluated'(test: Test) {\n        const obj = {\n            RegularValue: 'hello',\n            LazyValue: new Token('World')\n        };\n\n        test.deepEqual(resolve(obj), {\n            RegularValue: 'hello',\n            LazyValue: 'World'\n        });\n\n        test.done();\n    },\n\n    'tokens are evaluated anywhere in the object tree'(test: Test) {\n        const obj = new Promise1();\n        const actual = resolve({ Obj: obj });\n\n        test.deepEqual(actual, {\n            Obj: [\n              {\n                Data: {\n                  stringProp: \"hello\",\n                  numberProp: 1234\n                },\n                Recurse: 42\n              },\n              {\n                Data: {\n                  stringProp: \"hello\",\n                  numberProp: 1234\n                },\n                Recurse: 42\n              }\n            ]\n        });\n\n        test.done();\n    },\n\n    'tokens are evaluated recursively'(test: Test) {\n        const obj = new Promise1();\n        const actual = resolve(new Token(() => ({ Obj: obj })));\n\n        test.deepEqual(actual, {\n            Obj: [\n              {\n                Data: {\n                  stringProp: \"hello\",\n                  numberProp: 1234\n                },\n                Recurse: 42\n              },\n              {\n                Data: {\n                  stringProp: \"hello\",\n                  numberProp: 1234\n                },\n                Recurse: 42\n              }\n            ]\n        });\n\n        test.done();\n    },\n\n    'empty arrays or objects are kept'(test: Test) {\n        test.deepEqual(resolve({ }), { });\n        test.deepEqual(resolve([ ]), [ ]);\n\n        const obj = {\n            Prop1: 1234,\n            Prop2: { },\n            Prop3: [ ],\n            Prop4: 'hello',\n            Prop5: {\n                PropA: { },\n                PropB: {\n                    PropC: [ undefined, undefined ],\n                    PropD: 'Yoohoo'\n                }\n            }\n        };\n\n        test.deepEqual(resolve(obj), {\n            Prop1: 1234,\n            Prop2: { },\n            Prop3: [ ],\n            Prop4: 'hello',\n            Prop5: {\n                PropA: { },\n                PropB: {\n                    PropC: [ ],\n                    PropD: 'Yoohoo'\n                }\n            }\n        });\n\n        test.done();\n    },\n\n    'if an object has a \"resolve\" property that is not a function, it is not considered a token'(test: Test) {\n        test.deepEqual(resolve({ a_token: { resolve: () => 78787 }}), { a_token: 78787 });\n        test.deepEqual(resolve({ not_a_token: { resolve: 12 } }),     { not_a_token: { resolve: 12 } });\n        test.done();\n    },\n\n    // tslint:disable-next-line:max-line-length\n    'if a resolvable object inherits from a class that is also resolvable, the \"constructor\" function will not get in the way (uses Object.keys instead of \"for in\")'(test: Test) {\n        test.deepEqual(resolve({ prop: new DataType() }), { prop: { foo: 12, goo: 'hello' } });\n        test.done();\n    },\n\n    'isToken(obj) can be used to determine if an object is a token'(test: Test) {\n        test.ok(unresolved({ resolve: () => 123 }));\n        test.ok(unresolved({ a: 1, b: 2, resolve: () => 'hello' }));\n        test.ok(!unresolved({ a: 1, b: 2, resolve: 3 }));\n        test.done();\n    },\n\n    'Token can be used to create tokens that contain a constant value'(test: Test) {\n        test.equal(resolve(new Token(12)), 12);\n        test.equal(resolve(new Token('hello')), 'hello');\n        test.deepEqual(resolve(new Token([ 'hi', 'there' ])), [ 'hi', 'there' ]);\n        test.done();\n    },\n\n    'resolving leaves a Date object in working order'(test: Test) {\n        const date = new Date('2000-01-01');\n        const resolved = resolve(date);\n\n        test.equal(date.toString(), resolved.toString());\n        test.done();\n    },\n\n    'tokens can be stringified and evaluated to conceptual value'(test: Test) {\n        // GIVEN\n        const token = new Token(() => 'woof woof');\n\n        // WHEN\n        const stringified = `The dog says: ${token}`;\n        const resolved = resolve(stringified);\n\n        // THEN\n        test.deepEqual(evaluateCFN(resolved), 'The dog says: woof woof');\n        test.done();\n    },\n\n    'Tokens stringification and reversing of CloudFormation Tokens is implemented using Fn::Join'(test: Test) {\n        // GIVEN\n        const token = new CloudFormationToken(() => 'woof woof');\n\n        // WHEN\n        const stringified = `The dog says: ${token}`;\n        const resolved = resolve(stringified);\n\n        // THEN\n        test.deepEqual(resolved, {\n            'Fn::Join': ['', ['The dog says: ', 'woof woof']]\n        });\n        test.done();\n    },\n\n    'Doubly nested strings evaluate correctly in scalar context'(test: Test) {\n        // GIVEN\n        const token1 = new Token(() => \"world\");\n        const token2 = new Token(() => `hello ${token1}`);\n\n        // WHEN\n        const resolved1 = resolve(token2.toString());\n        const resolved2 = resolve(token2);\n\n        // THEN\n        test.deepEqual(evaluateCFN(resolved1), \"hello world\");\n        test.deepEqual(evaluateCFN(resolved2), \"hello world\");\n\n        test.done();\n    },\n\n    'integer Tokens can be stringified and evaluate to conceptual value'(test: Test) {\n        // GIVEN\n        for (const token of literalTokensThatResolveTo(1)) {\n            // WHEN\n            const stringified = `the number is ${token}`;\n            const resolved = resolve(stringified);\n\n            // THEN\n            test.deepEqual(evaluateCFN(resolved), 'the number is 1');\n        }\n        test.done();\n    },\n\n    'intrinsic Tokens can be stringified and evaluate to conceptual value'(test: Test) {\n        // GIVEN\n        for (const bucketName of cloudFormationTokensThatResolveTo({ Ref: 'MyBucket' })) {\n            // WHEN\n            const resolved = resolve(`my bucket is named ${bucketName}`);\n\n            // THEN\n            const context = {MyBucket: 'TheName'};\n            test.equal(evaluateCFN(resolved, context), 'my bucket is named TheName');\n        }\n\n        test.done();\n    },\n\n    'tokens resolve properly in initial position'(test: Test) {\n        // GIVEN\n        for (const token of tokensThatResolveTo('Hello')) {\n            // WHEN\n            const resolved = resolve(`${token} world`);\n\n            // THEN\n            test.equal(evaluateCFN(resolved), 'Hello world');\n        }\n\n        test.done();\n    },\n\n    'side-by-side Tokens resolve correctly'(test: Test) {\n        // GIVEN\n        for (const token1 of tokensThatResolveTo('Hello ')) {\n            for (const token2 of tokensThatResolveTo('world')) {\n                // WHEN\n                const resolved = resolve(`${token1}${token2}`);\n\n                // THEN\n                test.equal(evaluateCFN(resolved), 'Hello world');\n            }\n        }\n\n        test.done();\n    },\n\n    'tokens can be used in hash keys but must resolve to a string'(test: Test) {\n        // GIVEN\n        const token = new Token(() => 'I am a string');\n\n        // WHEN\n        const s = {\n            [token.toString()]: `boom ${token}`\n        };\n\n        // THEN\n        test.deepEqual(resolve(s), { 'I am a string': 'boom I am a string' });\n        test.done();\n    },\n\n    'fails if token in a hash key resolves to a non-string'(test: Test) {\n        // GIVEN\n        const token = new CloudFormationToken({ Ref: 'Other' });\n\n        // WHEN\n        const s = {\n            [token.toString()]: `boom ${token}`\n        };\n\n        // THEN\n        test.throws(() => resolve(s), 'The key \"${Token[TOKEN.19]}\" has been resolved to {\"Ref\":\"Other\"} but must be resolvable to a string');\n        test.done();\n    }\n};\n\nclass Promise2 extends Token {\n    public resolve() {\n        return {\n            Data: {\n                stringProp: 'hello',\n                numberProp: 1234,\n            },\n            Recurse: new Token(() => 42)\n        };\n    }\n}\n\nclass Promise1 extends Token {\n    public p2 = [ new Promise2(), new Promise2() ];\n\n    public resolve() {\n        return this.p2;\n    }\n}\n\nclass BaseDataType {\n    constructor(readonly foo: number) {\n    }\n}\n\nclass DataType extends BaseDataType {\n    public goo = 'hello';\n\n    constructor() {\n        super(12);\n    }\n}\n\n/**\n * Return various flavors of Tokens that resolve to the given value\n */\nfunction literalTokensThatResolveTo(value: any): Token[] {\n    return [\n        new Token(value),\n        new Token(() => value)\n    ];\n}\n\n/**\n * Return various flavors of Tokens that resolve to the given value\n */\nfunction cloudFormationTokensThatResolveTo(value: any): Token[] {\n    return [\n        new CloudFormationToken(value),\n        new CloudFormationToken(() => value)\n    ];\n}\n\n/**\n * Return Tokens in both flavors that resolve to the given string\n */\nfunction tokensThatResolveTo(value: string): Token[] {\n    return literalTokensThatResolveTo(value).concat(cloudFormationTokensThatResolveTo(value));\n}"]}

Sorry, the diff of this file is not supported yet

SocketSocket SOC 2 Logo

Product

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

Packages

npm

Stay in touch

Get open source security insights delivered straight into your inbox.


  • Terms
  • Privacy
  • Security

Made with ⚡️ by Socket Inc